/* ==========================================================
   FLORA studio — Botanical Journal / hand-drawn plate aesthetic
   Sage + ochre + blush + ink — soft pastel, never candy
   DM Serif Display + Libre Caslon Text italic + Inter body
   ========================================================== */

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
html,body{margin:0;padding:0;overflow-x:clip}

:root{
  --bg:#F4EFE3;
  --bg-2:#EBE3CF;
  --paper:#FBF6E8;
  --ink:#1B1F18;
  --ink-2:#3A3E33;
  --ink-3:#6E6F5B;
  --ink-4:#A29F84;
  --sage:#6B7847;
  --sage-d:#4D5732;
  --ochre:#C29248;
  --ochre-d:#9A6F23;
  --blush:#A23E4D;
  --blush-d:#7B2436;
  --line:rgba(27,31,24,.18);
  --line-s:rgba(27,31,24,.34);

  --f-d:"DM Serif Display","Libre Caslon Text",serif;
  --f-i:"Libre Caslon Text",Georgia,serif;
  --f-b:"Inter",system-ui,sans-serif;

  --pad-x:clamp(20px,4vw,72px);
  --sec-y:clamp(80px,9vw,140px);

  --ease:cubic-bezier(.22,.9,.3,1);
  --ease-out:cubic-bezier(.19,1,.22,1);
}

body{
  background:
    radial-gradient(80% 60% at 100% 0%, rgba(107,120,71,.06) 0%, transparent 60%),
    radial-gradient(60% 60% at 0% 100%, rgba(194,146,72,.05) 0%, transparent 60%),
    var(--bg);
  color:var(--ink);
  font-family:var(--f-b);
  font-size:16px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
img,svg,video,iframe{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;background:none;border:0;padding:0;color:inherit;cursor:pointer}
ul,ol{margin:0;padding:0;list-style:none}
h1,h2,h3,h4,p,dl,dt,dd,figure,blockquote{margin:0;padding:0;border:0}
address{font-style:normal}

::selection{background:var(--blush);color:var(--paper)}
:focus-visible{outline:2px solid var(--blush);outline-offset:3px}

/* ============ HEADER ============ */
.hdr{
  position:sticky;top:0;z-index:30;
  padding:14px var(--pad-x);
  background:rgba(244,239,227,.88);
  backdrop-filter:blur(10px) saturate(1.2);
  border-bottom:1px solid var(--line);
  display:flex;align-items:center;gap:22px;justify-content:space-between;
}
.lg{display:inline-flex;align-items:center;gap:10px;color:var(--ink)}
.lg-mark{color:var(--blush)}
.lg-w{
  font-family:var(--f-d);font-size:30px;
  letter-spacing:-.005em;
  line-height:1;
}
.lg-w i{
  font-family:var(--f-i);font-style:italic;font-weight:400;
  font-size:16px;color:var(--ochre-d);letter-spacing:0;
}
.nv{
  display:flex;gap:28px;
  font-family:var(--f-i);font-size:17px;color:var(--ink-2);
  font-style:italic;
}
.nv a{position:relative;padding:4px 0;transition:color .25s var(--ease)}
.nv a:hover{color:var(--blush)}
.nv a::before{
  content:"·";color:var(--ochre);position:absolute;left:-12px;top:0;opacity:0;
  transition:opacity .3s var(--ease);
}
.nv a:hover::before{opacity:1}

.cta{
  font-family:var(--f-b);font-size:13px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;
  padding:12px 22px;
  background:var(--ink);color:var(--bg);
  border-radius:999px;
  transition:background .25s var(--ease),transform .2s var(--ease);
}
.cta:hover{background:var(--blush);transform:translateY(-1px)}

.mb{display:none;width:42px;height:42px;align-items:center;justify-content:center;color:var(--ink);border:1px solid var(--line-s)}

/* ============ DRAWER ============ */
.drawer{
  position:fixed;inset:0;z-index:80;
  background:var(--paper);
  padding:24px var(--pad-x);
  display:flex;flex-direction:column;gap:32px;
  opacity:0;pointer-events:none;transform:translateY(-10px);
  transition:opacity .35s var(--ease),transform .45s var(--ease);
}
body.dr-open .drawer{opacity:1;pointer-events:auto;transform:none}
.dr-x{align-self:flex-end;width:42px;height:42px;border:1px solid var(--line-s);display:inline-flex;align-items:center;justify-content:center;color:var(--ink)}
.drawer nav{flex:1;display:flex;flex-direction:column;justify-content:center;gap:8px}
.drawer nav a{
  display:flex;align-items:baseline;gap:20px;
  padding:14px 0;border-bottom:1px solid var(--line);
  opacity:0;transform:translateY(20px);
  transition:opacity .55s var(--ease) calc(var(--i,0)*.07s + .15s),transform .55s var(--ease) calc(var(--i,0)*.07s + .15s);
}
body.dr-open .drawer nav a{opacity:1;transform:none}
.drawer nav b{font-family:var(--f-i);font-style:italic;font-size:20px;color:var(--ochre);font-weight:400;min-width:28px}
.drawer nav em{
  font-family:var(--f-d);font-style:normal;font-size:clamp(28px,7vw,48px);color:var(--ink);
  letter-spacing:-.01em;
}
.dr-foot{display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;padding-top:18px;border-top:1px solid var(--line);font-family:var(--f-i);font-style:italic;font-size:14px;color:var(--ink-3)}
.dr-foot a{color:var(--blush)}

/* ============ HERO ============ */
.hero{
  padding:clamp(40px,5vw,72px) var(--pad-x) clamp(56px,7vw,96px);
  max-width:1500px;margin:0 auto;
}
.hero-grid{
  display:grid;
  grid-template-columns:1.2fr 1fr;
  grid-template-rows:auto auto;
  gap:clamp(24px,3vw,56px) clamp(28px,4vw,80px);
  align-items:end;
}
.hero-left{grid-row:1 / 3;display:flex;flex-direction:column;gap:22px}
.rb{
  font-family:var(--f-i);font-size:13px;font-style:italic;
  color:var(--blush);letter-spacing:.01em;
}
.hh{
  font-family:var(--f-d);
  font-size:clamp(48px,7vw,120px);
  font-weight:400;line-height:.96;letter-spacing:-.02em;
  color:var(--ink);
}
.hh span{display:block}
.hh em{font-family:var(--f-i);font-style:italic;color:var(--blush);font-weight:400;letter-spacing:-.01em}
.hh-l1{padding-left:.3em}
.hh-l3{padding-left:1em}
.hh-l4{font-size:.7em;font-style:italic;color:var(--sage);font-family:var(--f-i);padding-left:2em;line-height:1;margin-top:.1em}

.hp{
  font-family:var(--f-b);font-size:16px;line-height:1.65;color:var(--ink-2);
  max-width:54ch;
}
.cta-r{display:flex;gap:14px;flex-wrap:wrap;margin-top:8px}

.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:13px 22px;
  font-family:var(--f-b);font-size:13px;font-weight:600;letter-spacing:.04em;
  text-transform:uppercase;
  cursor:pointer;
  border-radius:999px;
  border:1px solid transparent;
  transition:background .25s var(--ease),color .25s var(--ease),transform .2s var(--ease),border-color .25s var(--ease);
}
.btn-d{background:var(--ink);color:var(--bg)}
.btn-d:hover{background:var(--blush);transform:translateY(-1px)}
.btn-l{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-l:hover{background:var(--ink);color:var(--bg)}

.hero-fig{position:relative;margin:0;grid-row:1;grid-column:2}
.hero-fig img{
  width:100%;aspect-ratio:4/5;object-fit:cover;
  filter:saturate(.92) contrast(1.05);
  border-radius:2px;
  transition:transform 1.4s var(--ease);
}
.hero-fig:hover img{transform:scale(1.02)}
.hero-fig figcaption{
  display:flex;flex-direction:column;gap:2px;
  margin-top:10px;
  font-family:var(--f-i);font-size:13px;color:var(--ink-3);font-style:italic;
}
.cap-bot{color:var(--ochre-d)}
.cap-bot em{font-weight:700;color:var(--blush);font-style:italic}
.cap-list{font-family:var(--f-i);font-style:italic;color:var(--sage)}

.hero-aside{
  grid-row:2;grid-column:2;
  background:var(--paper);
  border:1px solid var(--line);
  padding:18px 20px;
  display:flex;flex-direction:column;gap:8px;
}
.ha-l{
  font-family:var(--f-i);font-size:13px;font-style:italic;color:var(--blush);
}
.ha-list{display:flex;flex-direction:column;gap:0}
.ha-list li{
  display:grid;grid-template-columns:24px 1fr auto;
  gap:10px;align-items:baseline;
  padding:5px 0;
  border-bottom:1px dashed var(--line);
}
.ha-list li:last-child{border-bottom:0}
.ha-list b{font-family:var(--f-i);font-size:18px;font-style:italic;color:var(--ochre);font-weight:400;text-align:center}
.ha-list li:has(b:not([data-active])) b{font-style:normal}
.ha-list span{font-family:var(--f-d);font-size:16px;color:var(--ink);letter-spacing:-.01em}
.ha-list em{font-family:var(--f-i);font-size:12px;font-style:italic;color:var(--ink-4)}
.ha-foot{font-family:var(--f-i);font-size:11px;color:var(--ink-4);font-style:italic;padding-top:4px}

/* ============ SECTION HEAD ============ */
.sh{
  display:flex;flex-direction:column;gap:18px;
  max-width:1500px;margin:0 auto;
  padding:0 var(--pad-x) clamp(36px,4vw,56px);
}
.sh-h{
  font-family:var(--f-d);font-size:clamp(40px,5.6vw,84px);
  font-weight:400;line-height:1;letter-spacing:-.02em;
  color:var(--ink);
  max-width:18ch;
}
.sh-h em{font-family:var(--f-i);font-style:italic;color:var(--blush);font-weight:400;letter-spacing:-.005em}
.sh-h--light{color:var(--paper)}
.sh-p{font-family:var(--f-b);font-size:16px;line-height:1.6;color:var(--ink-2);max-width:58ch}
.sh-p--light{color:rgba(251,246,232,.8)}

/* ============ TODAY ============ */
.today{padding:var(--sec-y) 0;max-width:1500px;margin:0 auto}
.td{
  display:grid;grid-template-columns:1fr 1.05fr;
  gap:clamp(24px,3vw,72px);
  padding:0 var(--pad-x);
  align-items:start;
}
.td-img{margin:0;overflow:hidden;border:1px solid var(--line)}
.td-img img{
  width:100%;aspect-ratio:4/5;object-fit:cover;filter:saturate(.96);
  transition:transform 1.3s var(--ease);
}
.td-img:hover img{transform:scale(1.03)}
.td-body{display:flex;flex-direction:column;gap:14px}
.td-no{
  font-family:var(--f-i);font-style:italic;font-size:14px;color:var(--ochre-d);
}
.td-body h3{
  font-family:var(--f-d);font-size:clamp(28px,3.6vw,46px);font-weight:400;
  line-height:1.05;letter-spacing:-.015em;color:var(--ink);
}
.td-body h3 em{font-family:var(--f-i);font-style:italic;color:var(--blush);font-weight:400}
.td-recipe{
  display:flex;flex-direction:column;gap:0;
  margin-top:10px;
  border-top:1px solid var(--line);
}
.td-recipe li{
  display:grid;grid-template-columns:50px 1fr auto;
  gap:14px;align-items:baseline;
  padding:11px 0;
  border-bottom:1px dashed var(--line);
  font-family:var(--f-b);font-size:15px;color:var(--ink);
}
.td-recipe span{
  font-family:var(--f-d);font-size:22px;color:var(--sage);font-weight:400;
  text-align:right;letter-spacing:-.01em;
}
.td-recipe em{font-family:var(--f-i);font-size:13px;font-style:italic;color:var(--ink-3)}
.td-foot{
  display:flex;justify-content:space-between;align-items:center;
  gap:18px;flex-wrap:wrap;
  padding-top:14px;
}
.td-px{
  font-family:var(--f-d);font-size:30px;color:var(--ink);font-weight:400;
  letter-spacing:-.01em;
}
.td-px em{font-family:var(--f-i);font-style:italic;color:var(--blush)}

/* ============ CATALOG ============ */
.cat{
  padding:var(--sec-y) 0;
  background:var(--paper);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.cat-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:clamp(18px,2vw,36px);
  margin:0 var(--pad-x);
  max-width:1500px;
}
.ct{display:flex;flex-direction:column;gap:12px;position:relative;transition:transform .4s var(--ease)}
.ct:hover{transform:translateY(-4px)}
.ct-img{margin:0;overflow:hidden;border:1px solid var(--line)}
.ct-img img{
  width:100%;aspect-ratio:4/5;object-fit:cover;
  filter:saturate(.94);transition:transform 1s var(--ease);
}
.ct:hover .ct-img img{transform:scale(1.05)}
.ct h3{
  font-family:var(--f-d);font-size:24px;font-weight:400;
  line-height:1.05;letter-spacing:-.01em;color:var(--ink);
}
.ct h3 em{font-family:var(--f-i);font-style:italic;color:var(--blush);font-weight:400}
.ct p{font-family:var(--f-b);font-size:14px;line-height:1.55;color:var(--ink-3)}
.ct-px{
  font-family:var(--f-d);font-size:18px;color:var(--sage-d);
  letter-spacing:-.005em;padding-top:6px;
  border-top:1px dashed var(--line);
}
.ct-px b{font-weight:400;color:var(--ink);font-size:24px;margin-left:6px}
.ct-flag{
  position:absolute;right:8px;top:8px;
  font-family:var(--f-i);font-style:italic;font-size:12px;
  color:var(--paper);background:var(--blush);
  padding:5px 10px;border-radius:999px;
}
.ct--st .ct-img{border-color:var(--blush)}

.cat-foot{
  max-width:60ch;margin:32px var(--pad-x) 0;
  font-family:var(--f-i);font-style:italic;font-size:16px;line-height:1.6;color:var(--ink-3);
}

/* ============ EVENTS ============ */
.ev{
  display:grid;grid-template-columns:1fr 1.05fr;
  background:var(--sage-d);color:var(--paper);
  align-items:center;
  min-height:80svh;
}
.ev-img{position:relative;overflow:hidden;height:100%;min-height:50svh}
.ev-img img{width:100%;height:100%;object-fit:cover;filter:saturate(.92) brightness(.96);transition:transform 1.4s var(--ease)}
.ev-img:hover img{transform:scale(1.05)}
.ev-body{padding:clamp(56px,7vw,120px) clamp(32px,4vw,80px);display:flex;flex-direction:column;gap:16px}
.ev-body .rb{color:#D6BD7A}
.ev-list{display:flex;flex-direction:column;gap:0;margin-top:10px}
.ev-list div{
  display:grid;grid-template-columns:1fr 1.5fr;gap:14px;align-items:baseline;
  padding:14px 0;border-bottom:1px solid rgba(251,246,232,.18);
}
.ev-list dt{
  font-family:var(--f-d);font-size:22px;color:var(--paper);font-weight:400;letter-spacing:-.01em;
}
.ev-list dd{font-family:var(--f-i);font-style:italic;font-size:15.5px;color:rgba(251,246,232,.75)}
.ev-body .btn-d{background:var(--paper);color:var(--ink);margin-top:14px;align-self:flex-start}
.ev-body .btn-d:hover{background:var(--blush);color:var(--paper)}

/* ============ SCHOOL ============ */
.sc{padding:var(--sec-y) 0;max-width:1500px;margin:0 auto}
.sc-list{
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:1px;
  background:var(--line);
  border:1px solid var(--line);
  margin:0 var(--pad-x);
}
.sc-c{
  display:grid;grid-template-columns:80px 1fr;
  gap:20px;
  padding:28px 24px;
  background:var(--bg);
  align-items:start;
  transition:background .3s var(--ease);
}
.sc-c:hover{background:var(--paper)}
.sc-n{
  font-family:var(--f-d);font-size:62px;color:var(--ochre);font-weight:400;
  letter-spacing:-.02em;line-height:.9;
}
.sc-c h3{
  font-family:var(--f-d);font-size:24px;font-weight:400;color:var(--ink);
  letter-spacing:-.01em;line-height:1.1;margin-bottom:6px;
}
.sc-c h3 em{font-family:var(--f-i);font-style:italic;color:var(--blush);font-weight:400}
.sc-c p{font-family:var(--f-b);font-size:14.5px;line-height:1.55;color:var(--ink-3)}
.sc-c p em{font-family:var(--f-i);font-style:italic;color:var(--sage-d);display:inline-block;margin-top:6px}

/* ============ STORY ============ */
.st{padding:var(--sec-y) 0;max-width:1500px;margin:0 auto}
.st-grid{
  display:grid;grid-template-columns:1fr 1.1fr;
  gap:clamp(24px,3vw,72px);
  padding:0 var(--pad-x);
  align-items:center;
}
.st-fig{margin:0;overflow:hidden}
.st-fig img{width:100%;aspect-ratio:4/5;object-fit:cover;filter:saturate(.95);transition:transform 1.2s var(--ease)}
.st-fig:hover img{transform:scale(1.03)}
.st-body{display:flex;flex-direction:column;gap:16px}
.st-q{
  font-family:var(--f-i);font-style:italic;font-size:clamp(20px,2.4vw,28px);
  line-height:1.4;color:var(--ink);
  padding:18px 0 12px;
  border-top:1px solid var(--blush);
  margin-top:14px;
  max-width:38ch;letter-spacing:-.005em;
}
.st-sign{
  font-family:var(--f-i);font-style:italic;font-size:22px;color:var(--blush);
  transform:rotate(-2deg);transform-origin:left;align-self:flex-start;
}

/* ============ VISIT ============ */
.vs{padding:var(--sec-y) 0;max-width:1500px;margin:0 auto}
.vs-head{padding-bottom:clamp(36px,4vw,56px)}
.vs-grid{
  display:grid;grid-template-columns:1fr 1.2fr;
  gap:clamp(24px,3vw,72px);
  padding:0 var(--pad-x);
}
.vs-info{display:flex;flex-direction:column;gap:18px}
.vs-l{display:flex;flex-direction:column;gap:0}
.vs-l div{
  display:grid;grid-template-columns:120px 1fr;
  gap:14px;align-items:baseline;
  padding:13px 0;border-bottom:1px solid var(--line);
}
.vs-l dt{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--f-i);font-size:13px;font-style:italic;color:var(--ink-3);
}
.vs-l dt svg{color:var(--blush)}
.vs-l dd{font-family:var(--f-d);font-size:18px;color:var(--ink);letter-spacing:-.01em}
.vs-l dd a{color:var(--blush);border-bottom:1px solid var(--blush)}

.vs-map{
  position:relative;
  min-height:clamp(400px,55vh,560px);
  overflow:hidden;border:1px solid var(--line-s);
}
.vs-map iframe{position:absolute;inset:0;width:100%;height:100%;border:0;filter:saturate(.6) sepia(.18)}

/* ============ FOOTER ============ */
.ft{
  background:var(--ink);color:var(--paper);
  padding:clamp(56px,6vw,96px) var(--pad-x) clamp(22px,2vw,32px);
  display:flex;flex-direction:column;gap:clamp(40px,5vw,72px);
}
.ft-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(24px,3vw,48px);
  max-width:1500px;margin:0 auto;width:100%;
}
.ft-c{display:flex;flex-direction:column;gap:8px}
.ft-l{font-family:var(--f-i);font-style:italic;font-size:13px;color:#D6BD7A;margin-bottom:6px}
.ft-c a,.ft-c address{font-family:var(--f-d);font-size:20px;color:var(--paper);letter-spacing:-.005em;transition:color .25s var(--ease)}
.ft-c a:hover{color:#D6BD7A}

.ft-mark{
  text-align:center;
  font-family:var(--f-d);font-size:clamp(110px,26vw,360px);
  line-height:.86;letter-spacing:-.04em;color:var(--paper);
}
.ft-mark em{font-family:var(--f-i);font-style:italic;color:#D6BD7A;font-weight:400;display:block}
.ft-mark span{font-family:var(--f-i);font-style:italic;font-size:.3em;color:rgba(251,246,232,.55);letter-spacing:.04em;font-weight:400;display:block;margin-top:-.2em}

.ft-base{
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;
  padding-top:22px;border-top:1px solid rgba(251,246,232,.14);
  font-family:var(--f-i);font-style:italic;font-size:13px;color:rgba(251,246,232,.55);
  max-width:1500px;margin:0 auto;width:100%;
}

/* ============ FAB ============ */
.fab{
  position:fixed;right:24px;bottom:24px;z-index:50;
  width:54px;height:54px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  background:var(--blush);color:var(--paper);
  box-shadow:0 12px 32px rgba(162,62,77,.4);
  opacity:0;transform:translateY(16px);pointer-events:none;
  transition:opacity .35s var(--ease),transform .35s var(--ease),background .25s var(--ease);
}
.fab.is-on{opacity:1;transform:none;pointer-events:auto}
.fab:hover{background:var(--blush-d)}
body.dr-open .fab{opacity:0;pointer-events:none}

/* ============ RESPONSIVE ============ */
@media (max-width:1023px){
  :root{--pad-x:22px;--sec-y:clamp(64px,8vw,100px)}
  .nv{display:none}
  .cta{display:none}
  .mb{display:inline-flex}
  .hero-grid{grid-template-columns:1fr;grid-template-rows:auto auto auto}
  .hero-left{grid-row:1}
  .hero-fig{grid-row:2;grid-column:1}
  .hero-aside{grid-row:3;grid-column:1}
  .td{grid-template-columns:1fr;gap:24px}
  .cat-grid{grid-template-columns:repeat(2,1fr)}
  .ev{grid-template-columns:1fr}
  .ev-img{min-height:50vw;max-height:480px}
  .sc-list{grid-template-columns:1fr}
  .st-grid{grid-template-columns:1fr;gap:32px}
  .vs-grid{grid-template-columns:1fr;gap:28px}
}

@media (max-width:767px){
  :root{--pad-x:16px;--sec-y:56px}
  body{font-size:15.5px}
  .hdr{padding:12px 16px;gap:10px}
  .lg-w{font-size:24px}
  .lg-w i{font-size:13px}

  .hero{padding:32px 16px 48px}
  .hh{font-size:clamp(40px,12vw,64px)}
  .hh-l3{padding-left:.4em}
  .hh-l4{padding-left:1em;font-size:.55em}
  .hp{font-size:15px}
  .cta-r{flex-direction:column;align-items:stretch}
  .cta-r .btn{justify-content:center;min-height:48px}

  .hero-fig img{aspect-ratio:5/4}
  .hero-aside{padding:14px 16px}
  .ha-list b{font-size:16px}
  .ha-list span{font-size:14px}
  .ha-list em{font-size:11px}

  .sh-h{font-size:36px}

  .td-body h3{font-size:24px}
  .td-recipe li{grid-template-columns:36px 1fr auto;gap:10px;font-size:14px}
  .td-recipe span{font-size:18px}
  .td-px{font-size:24px}
  .td-foot{flex-direction:column;align-items:stretch;gap:12px}
  .td-foot .btn{justify-content:center;min-height:48px}

  .cat-grid{grid-template-columns:1fr;gap:22px}
  .cat-foot{margin-left:16px;margin-right:16px;font-size:14px}
  .ct h3{font-size:21px}

  .ev-body{padding:48px 22px}
  .ev-list dt{font-size:18px}
  .ev-list dd{font-size:13.5px}

  .sc-list{margin:0 16px}
  .sc-c{grid-template-columns:60px 1fr;padding:22px 18px}
  .sc-n{font-size:46px}
  .sc-c h3{font-size:20px}
  .sc-c p{font-size:13.5px}

  .st-q{font-size:18px}
  .st-sign{font-size:18px}

  .vs-l div{grid-template-columns:110px 1fr;padding:11px 0;gap:10px}
  .vs-l dd{font-size:15.5px}
  .vs-map{min-height:320px}

  .ft-grid{grid-template-columns:1fr 1fr;gap:18px}
  .ft-c a,.ft-c address{font-size:15.5px}
  .ft-mark{font-size:clamp(82px,22vw,160px)}
  .ft-base{font-size:11.5px;flex-direction:column;gap:6px}
  .fab{right:14px;bottom:14px;width:48px;height:48px}
}

@media (max-width:479px){
  .ft-grid{grid-template-columns:1fr}
}

@media (hover:none) and (pointer:coarse){
  .btn,.cta,.mb,.dr-x,.fab{min-height:44px}
}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms !important;transition-duration:.01ms !important;scroll-behavior:auto !important}
}
