/* Wapahani Art Center — v2 public site.
   Soft / editorial design system, extracted from the approved homepage so every
   page shares one language: cream canvas, rounded cards, pill buttons, Fraunces
   display serif, soft shadows, building-borrowed colour palette. */

:root{
  --canvas:#FBF6ED;
  --canvas-2:#F4ECDD;
  --ink:#221C30;
  --ink-soft:#5C5570;
  --line:#E7DECF;
  --coral:#E5533B;
  --peri:#8C8FD9;
  --marigold:#EDB14A;
  --rose:#E7A0B6;
  --t-coral:#FBE5DE;
  --t-peri:#E9E9F8;
  --t-marigold:#FBEFD2;
  --t-rose:#F8E7ED;
  --sans:"Inter",system-ui,-apple-system,sans-serif;
  --serif:"Fraunces",Georgia,serif;
  --shadow:0 2px 6px rgba(34,28,48,.05), 0 24px 60px -20px rgba(34,28,48,.18);
  --shadow-sm:0 1px 3px rgba(34,28,48,.05), 0 12px 28px -16px rgba(34,28,48,.16);
  --r:26px;
  --maxw:1180px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);background:var(--canvas);color:var(--ink);
  font-size:17px;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
::selection{background:var(--coral);color:#fff}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
@media(max-width:540px){ .wrap{padding:0 20px} }

.serif{font-family:var(--serif);font-weight:300;font-variation-settings:"opsz" 140;letter-spacing:-.02em;line-height:1.04}
.eyebrow{font-size:.78rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-soft)}
.eyebrow .dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--coral);margin-right:10px;vertical-align:1px}
.lead{font-size:1.18rem;color:var(--ink-soft);line-height:1.55}
.muted{color:var(--ink-soft)}
.center{text-align:center}

/* ---------- NAV ---------- */
.nav{position:absolute;top:0;left:0;right:0;z-index:20}
.nav-in{max-width:var(--maxw);margin:0 auto;padding:30px 28px;display:flex;align-items:center;gap:30px}
.logo{display:flex;align-items:center;gap:13px;font-family:var(--serif);font-weight:500;font-size:1.28rem;letter-spacing:-.02em}
.logo-img{height:48px;width:auto;display:block}
@media(max-width:860px){.logo-img{height:42px}}
.logo .glyph{width:42px;height:42px;border-radius:50%;background:var(--coral);color:#fff;display:grid;place-items:center;font-size:1.15rem}
.logo small{display:block;font-family:var(--sans);font-size:.6rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft);margin-top:3px}
.nav-links{margin-left:auto;display:flex;align-items:center;gap:34px}
.nav-links a{font-size:.92rem;font-weight:500;color:var(--ink-soft);transition:color .2s}
.nav-links a:hover,.nav-links a.is-active{color:var(--ink)}
.nav-cta{padding:11px 22px;border-radius:999px;background:var(--ink);color:var(--canvas)!important;font-weight:600;font-size:.88rem;transition:background .2s}
.nav-cta:hover{background:var(--coral)}
.burger{display:none;margin-left:auto;background:none;border:0;font-size:1.5rem;color:var(--ink);cursor:pointer}
@media(max-width:860px){
  .nav-in{padding:22px 20px}
  .nav-links{display:none;position:absolute;top:74px;left:20px;right:20px;background:#fff;border-radius:20px;
    flex-direction:column;align-items:stretch;gap:0;padding:10px;box-shadow:var(--shadow)}
  .nav-links.open{display:flex}
  .nav-links a{padding:15px 18px;border-radius:12px}
  .nav-links a:hover,.nav-links a.is-active{background:var(--canvas)}
  .nav-cta{text-align:center}
  .burger{display:block}
}

/* ---------- BUTTONS / LINKS ---------- */
.btn{display:inline-flex;align-items:center;gap:11px;padding:16px 30px;border-radius:999px;
  background:var(--ink);color:var(--canvas);font-weight:600;font-size:.98rem;cursor:pointer;border:0;
  font-family:var(--sans);transition:transform .25s,background .25s,color .25s}
.btn:hover{background:var(--coral);color:#fff;transform:translateY(-2px)}
.btn .a{transition:transform .25s}
.btn:hover .a{transform:translateX(4px)}
.btn.ghost{background:transparent;color:var(--ink);box-shadow:inset 0 0 0 2px var(--ink)}
.btn.ghost:hover{background:var(--ink);color:var(--canvas);box-shadow:inset 0 0 0 2px var(--ink)}
.btn.light{background:#fff;color:var(--ink)}
.btn.light:hover{background:var(--marigold);color:var(--ink)}
.btn-sm{padding:11px 20px;font-size:.86rem}
.link-arrow{font-weight:600;font-size:.98rem;display:inline-flex;align-items:center;gap:9px;color:var(--ink);
  border-bottom:2px solid var(--coral);padding-bottom:3px;transition:gap .2s}
.link-arrow:hover{gap:14px}

/* ---------- PAGE HERO (inner pages; clears the absolute nav) ---------- */
.page-hero{padding:150px 0 64px;position:relative}
@media(max-width:880px){.page-hero{padding:120px 0 48px}}
.page-hero .ph-grid{max-width:var(--maxw);margin:0 auto;padding:0 28px;display:grid;
  grid-template-columns:1.1fr .9fr;gap:54px;align-items:center}
@media(max-width:880px){.page-hero .ph-grid{grid-template-columns:1fr;gap:34px}}
.page-hero h1{font-family:var(--serif);font-weight:300;font-variation-settings:"opsz" 140;
  font-size:clamp(2.8rem,6.5vw,5rem);line-height:1.0;letter-spacing:-.035em;margin:22px 0 0}
.page-hero h1 em{font-style:italic;color:var(--coral)}
.page-hero p.sub{font-size:1.18rem;color:var(--ink-soft);max-width:42ch;margin:24px 0 0;line-height:1.55}
.page-hero .back{display:inline-flex;gap:8px;align-items:center;font-size:.9rem;font-weight:600;color:var(--ink-soft);margin-bottom:6px}
.page-hero .back:hover{color:var(--coral)}

/* soft arch art (decorative, reused from homepage) */
.art{position:relative;height:clamp(360px,42vw,520px)}
.art .arch{position:absolute;border-radius:999px 999px 18px 18px;overflow:hidden}
.art .a1{inset:0 14% 0 0;background:linear-gradient(160deg,var(--peri),var(--rose));box-shadow:var(--shadow)}
.art .a2{width:46%;bottom:0;right:0;height:62%;background:linear-gradient(160deg,var(--marigold),var(--coral));box-shadow:var(--shadow);border-radius:999px 999px 18px 18px}
.art .a1 img,.art .a2 img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.art .blob{position:absolute;width:118px;height:118px;border-radius:50%;background:var(--canvas);
  top:11%;right:8%;display:grid;place-items:center;box-shadow:var(--shadow-sm);
  font-family:var(--serif);font-style:italic;font-size:1.05rem;color:var(--ink);text-align:center;line-height:1.15}
.art .tag{position:absolute;left:-14px;bottom:18%;background:#fff;border-radius:14px;padding:13px 18px;
  box-shadow:var(--shadow-sm);font-size:.82rem;font-weight:600}
.art .tag b{color:var(--coral)}

/* ---------- SECTIONS ---------- */
section.blk{padding:clamp(64px,9vw,120px) 0}
section.blk.tight{padding-top:0}
.center-stmt{max-width:880px;margin:0 auto;padding:0 28px;text-align:center}
.center-stmt h2{font-family:var(--serif);font-weight:300;font-variation-settings:"opsz" 140;
  font-size:clamp(1.9rem,3.6vw,3rem);line-height:1.22;letter-spacing:-.02em}
.center-stmt h2 em{font-style:italic;color:var(--peri)}
.center-stmt .k{margin-bottom:26px}
.sec-head{max-width:var(--maxw);margin:0 auto 48px;padding:0 28px;display:flex;
  justify-content:space-between;align-items:flex-end;gap:30px;flex-wrap:wrap}
.sec-head h2{font-family:var(--serif);font-weight:300;font-variation-settings:"opsz" 140;
  font-size:clamp(2.2rem,4.6vw,3.6rem);line-height:1.05;letter-spacing:-.03em}
.sec-head .k{margin-bottom:16px}

/* ---------- INFO ROWS (about, artist, event) ---------- */
.info{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.info-row{display:grid;grid-template-columns:280px 1fr;gap:48px;padding:44px 0;border-top:1px solid var(--line)}
.info-row:first-child{border-top:0;padding-top:0}
.info-row h3{font-family:var(--serif);font-weight:400;font-size:clamp(1.6rem,3vw,2.3rem);letter-spacing:-.02em;line-height:1.06}
.info-row .body p{font-size:1.12rem;color:var(--ink-soft);margin-bottom:1em;line-height:1.6}
.info-row .body p:last-child{margin-bottom:0}
@media(max-width:780px){.info-row{grid-template-columns:1fr;gap:16px;padding:32px 0}}

/* ---------- MAKERS (directory grid) ---------- */
.makers{max-width:var(--maxw);margin:0 auto;padding:0 28px;display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
@media(max-width:1080px){.makers{grid-template-columns:repeat(3,1fr)}}
@media(max-width:680px){.makers{grid-template-columns:repeat(2,1fr);gap:14px}}
.mk{background:#fff;border-radius:18px;overflow:hidden;box-shadow:var(--shadow-sm);
  transition:transform .3s,box-shadow .3s;display:block}
.mk:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.mk .ph{aspect-ratio:1/1;position:relative;display:grid;place-items:center}
.mk .ph .ini{font-family:var(--serif);font-style:italic;font-size:2.6rem;color:rgba(34,28,48,.34)}
.mk .ph img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.t-marigold{background:var(--t-marigold)}.t-peri{background:var(--t-peri)}
.t-rose{background:var(--t-rose)}.t-coral{background:var(--t-coral)}
.mk .bd{padding:14px 16px 17px}
.mk .nm{font-family:var(--serif);font-weight:400;font-size:1.12rem;letter-spacing:-.02em;line-height:1.1}
.mk .sp{font-size:.7rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);margin-top:6px}
.mk .su{font-size:.74rem;color:var(--ink-soft);margin-top:5px}

/* directory search/filter toolbar */
.dir-tools{max-width:var(--maxw);margin:0 auto 34px;padding:0 28px;display:flex;gap:14px;flex-wrap:wrap}
.dir-tools input,.dir-tools select{padding:14px 18px;border-radius:999px;border:1px solid var(--line);
  background:#fff;font:inherit;font-size:1rem;color:var(--ink);box-shadow:var(--shadow-sm)}
.dir-tools input{flex:1;min-width:220px}
.dir-tools input:focus,.dir-tools select:focus{outline:none;border-color:var(--coral)}

/* ---------- STUDIOS PANEL (reusable CTA) ---------- */
.studios{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.panel{background:var(--peri);color:#fff;border-radius:36px;padding:clamp(44px,6vw,86px);
  display:grid;grid-template-columns:1.1fr .9fr;gap:54px;align-items:center;position:relative;overflow:hidden}
@media(max-width:780px){.panel{grid-template-columns:1fr;gap:34px;border-radius:28px}}
.panel::after{content:"";position:absolute;width:340px;height:340px;border-radius:50%;background:rgba(255,255,255,.10);right:-90px;top:-120px}
.panel h2{font-family:var(--serif);font-weight:300;font-variation-settings:"opsz" 140;
  font-size:clamp(2rem,4vw,3.2rem);line-height:1.08;letter-spacing:-.03em;position:relative}
.panel .k{color:rgba(255,255,255,.8);margin-bottom:18px}
.panel .eyebrow .dot{background:var(--marigold)}
.panel .facts{display:flex;gap:42px;margin:30px 0 0;position:relative;flex-wrap:wrap}
.panel .facts .n{font-family:var(--serif);font-weight:300;font-size:2.5rem;letter-spacing:-.03em}
.panel .facts .l{font-size:.82rem;color:rgba(255,255,255,.78);margin-top:4px}
.panel .side{position:relative}
.panel .btn{background:#fff;color:var(--ink)}
.panel .btn:hover{background:var(--marigold);color:var(--ink)}
.panel .call{display:block;margin-top:18px;font-size:.92rem;color:rgba(255,255,255,.82)}

/* feature cards (studios "what you get") */
.feats{max-width:var(--maxw);margin:0 auto;padding:0 28px;display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
@media(max-width:860px){.feats{grid-template-columns:1fr}}
.feat{background:#fff;border-radius:var(--r);padding:34px 30px;box-shadow:var(--shadow-sm)}
.feat .n{font-family:var(--serif);font-style:italic;font-size:1.5rem;color:var(--coral);margin-bottom:14px}
.feat h3{font-family:var(--serif);font-weight:400;font-size:1.5rem;letter-spacing:-.02em;margin-bottom:8px}
.feat p{color:var(--ink-soft);font-size:1rem}

/* available studio cards */
.studio-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
@media(max-width:860px){.studio-cards{grid-template-columns:repeat(2,1fr)}}
@media(max-width:540px){.studio-cards{grid-template-columns:1fr}}
.scard{background:#fff;border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-sm);display:flex;flex-direction:column}
.scard .top{padding:22px 24px;font-family:var(--serif);font-weight:300;font-size:2rem;letter-spacing:-.03em}
.scard .bd{padding:0 24px 24px;display:flex;flex-direction:column;gap:6px;flex:1}
.scard .sz{font-family:var(--serif);font-weight:400;font-size:1.25rem}
.scard .pr{color:var(--ink-soft);font-size:.96rem;margin-bottom:8px}
.scard .btn{align-self:flex-start;margin-top:auto}
.bld-head{font-family:var(--serif);font-weight:400;font-size:1.5rem;letter-spacing:-.02em;margin:34px 0 18px}
.bld-head:first-child{margin-top:0}

/* ---------- EVENTS ---------- */
.events{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.ev{display:grid;grid-template-columns:130px 1fr auto;gap:30px;align-items:center;padding:28px 0;border-top:1px solid var(--line)}
.ev:last-child{border-bottom:1px solid var(--line)}
.ev .d{font-family:var(--serif);font-weight:300;font-size:1.55rem;letter-spacing:-.02em;line-height:1}
.ev .d small{display:block;font-family:var(--sans);font-size:.72rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);margin-top:6px}
.ev .ti{font-family:var(--serif);font-weight:400;font-size:1.42rem;letter-spacing:-.02em}
.ev .ho{font-size:.86rem;color:var(--ink-soft);margin-top:5px}
.ev .pill{font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:7px 13px;border-radius:999px;background:var(--t-coral);color:var(--coral)}
.ev .pill.ten{background:var(--t-peri);color:var(--peri)}
.ev:hover .ti{color:var(--coral)}
@media(max-width:680px){.ev{grid-template-columns:1fr;gap:8px}.ev .pill{justify-self:start}}
.empty{max-width:var(--maxw);margin:0 auto;padding:60px 28px;text-align:center;font-family:var(--serif);font-style:italic;font-size:1.5rem;color:var(--ink-soft)}
.filters{max-width:var(--maxw);margin:0 auto 34px;padding:0 28px;display:flex;gap:12px;flex-wrap:wrap}
.chip{padding:10px 20px;border-radius:999px;border:1px solid var(--line);background:#fff;font-size:.88rem;font-weight:600;color:var(--ink-soft)}
.chip.on{background:var(--ink);color:var(--canvas);border-color:var(--ink)}
.chip:hover{border-color:var(--coral);color:var(--ink)}

/* ---------- PROSE (event/artist body) ---------- */
.prose{font-size:1.12rem;color:var(--ink-soft);line-height:1.7}
.prose a{color:var(--coral);text-decoration:underline;text-underline-offset:3px}
.prose p{margin-bottom:1em}

/* connect list (artist) */
.connect{list-style:none;font-size:1.05rem;line-height:2.1}
.connect li{display:flex;gap:12px;align-items:baseline}
.connect .dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--coral);flex:0 0 auto;position:relative;top:-2px}
.connect a{color:var(--ink);text-decoration:underline;text-underline-offset:3px}
.connect a:hover{color:var(--coral)}

/* ---------- PULLQUOTE ---------- */
.pullquote{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.pullquote .inner{background:var(--coral);color:#fff;border-radius:36px;padding:clamp(44px,7vw,86px)}
@media(max-width:540px){.pullquote .inner{border-radius:28px}}
.pullquote q{font-family:var(--serif);font-weight:300;font-variation-settings:"opsz" 140;
  font-size:clamp(1.6rem,3.6vw,2.8rem);line-height:1.18;letter-spacing:-.02em;display:block;max-width:24ch}
.pullquote cite{display:block;margin-top:28px;font-style:normal;font-size:.82rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.85)}

/* ---------- GALLERY ---------- */
.collage{max-width:var(--maxw);margin:0 auto;padding:0 28px;display:grid;grid-template-columns:repeat(6,1fr);gap:18px;grid-auto-flow:dense}
.tile{border-radius:20px;overflow:hidden;min-height:200px;display:flex;align-items:flex-end;padding:22px;position:relative;
  font-size:.8rem;font-weight:600;letter-spacing:.04em;box-shadow:var(--shadow-sm)}
.tile span{position:relative;z-index:1}
.tile img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.tile.t-marigold,.tile.t-rose{color:var(--ink)}
.tile.t-peri,.tile.t-coral{color:var(--ink)}
.tile:nth-child(7n+1){grid-column:span 4;grid-row:span 2;background:var(--t-marigold)}
.tile:nth-child(7n+2){grid-column:span 2;grid-row:span 2;background:var(--t-peri)}
.tile:nth-child(7n+3){grid-column:span 2;background:var(--t-rose)}
.tile:nth-child(7n+4){grid-column:span 4;background:var(--t-coral)}
.tile:nth-child(7n+5){grid-column:span 3;background:var(--t-peri)}
.tile:nth-child(7n+6){grid-column:span 3;background:var(--t-marigold)}
.tile:nth-child(7n+7){grid-column:span 6;background:var(--t-rose)}
@media(max-width:820px){.collage{grid-template-columns:repeat(2,1fr)}
  .tile,.tile:nth-child(n){grid-column:span 1;grid-row:span 1}}

/* ---------- FORMS ---------- */
.form{max-width:680px}
.field{margin-bottom:18px}
.field label{display:block;font-size:.78rem;font-weight:600;letter-spacing:.13em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:9px}
.field input,.field textarea,.field select{width:100%;padding:15px 18px;border-radius:16px;border:1px solid var(--line);
  background:#fff;font:inherit;font-size:1rem;color:var(--ink);box-shadow:var(--shadow-sm)}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--coral)}
.field textarea{min-height:150px;resize:vertical}
.flash{padding:15px 20px;border-radius:16px;margin-bottom:22px;font-weight:600;font-size:.96rem}
.flash-success{background:var(--t-peri);color:#3a3d8a}
.flash-error{background:var(--t-coral);color:#a5341f}
.flash-note{background:var(--t-peri);color:var(--ink)}

/* contact split */
.split{max-width:var(--maxw);margin:0 auto;padding:0 28px;display:grid;grid-template-columns:.85fr 1.15fr;gap:32px;align-items:start}
@media(max-width:820px){.split{grid-template-columns:1fr;gap:24px}}
.split .card-ink{background:var(--ink);color:var(--canvas);border-radius:var(--r);padding:clamp(32px,4vw,56px)}
.split .card-ink a{color:var(--marigold)}
.split .card-ink .lead{color:rgba(251,246,237,.82)}
.split .card-soft{background:#fff;border-radius:var(--r);padding:clamp(32px,4vw,56px);box-shadow:var(--shadow-sm)}

/* ---------- FOOTER ---------- */
footer{margin-top:clamp(70px,10vw,130px);background:var(--ink);color:var(--canvas)}
.f-top{max-width:var(--maxw);margin:0 auto;padding:84px 28px 56px;display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:50px}
@media(max-width:780px){.f-top{grid-template-columns:1fr;gap:38px}}
.f-top .big{font-family:var(--serif);font-weight:300;font-variation-settings:"opsz" 140;font-size:clamp(2.4rem,5vw,3.6rem);line-height:1.08;letter-spacing:-.03em}
.f-top .big em{font-style:italic;color:var(--marigold)}
.f-top p{color:rgba(251,246,237,.65);margin-top:18px;max-width:34ch}
.f-col h4{font-size:.72rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:rgba(251,246,237,.5);margin-bottom:18px}
.f-col a,.f-col li{display:block;color:rgba(251,246,237,.85);margin-bottom:12px;font-size:.95rem;list-style:none}
.f-col a:hover{color:var(--marigold)}
.f-strip{height:8px;display:flex}
.f-strip i{flex:1}
.f-strip i:nth-child(1){background:var(--marigold)}.f-strip i:nth-child(2){background:var(--peri)}
.f-strip i:nth-child(3){background:var(--rose)}.f-strip i:nth-child(4){background:var(--coral)}
.f-end{max-width:var(--maxw);margin:0 auto;padding:24px 28px;display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;font-size:.82rem;color:rgba(251,246,237,.5)}
.f-end a{color:rgba(251,246,237,.7)}
.f-end a:hover{color:var(--marigold)}

/* ---------- REVEAL ---------- */
.rv{opacity:1}
html.js .rv{opacity:0;transform:translateY(22px);transition:opacity .8s cubic-bezier(.2,.7,.2,1),transform .8s cubic-bezier(.2,.7,.2,1)}
html.js .rv.io{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){html.js .rv{opacity:1;transform:none}}

/* ===================== MODERN POLISH ===================== */
:focus-visible{outline:2px solid var(--coral);outline-offset:3px;border-radius:6px}
[id]{scroll-margin-top:100px}

/* ambient depth — soft colour glows behind the flat canvas */
body::before{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:radial-gradient(58vw 52vh at 82% -6%, rgba(140,143,217,.16), transparent 60%),
             radial-gradient(52vw 46vh at -6% 4%, rgba(237,177,74,.12), transparent 55%);}

/* sticky frosted nav: transparent over the hero, frosted glass once scrolled */
.nav{position:fixed;transition:background .3s ease,box-shadow .3s ease}
.nav-in{transition:padding .3s ease}
.nav.scrolled{background:rgba(251,246,237,.78);
  -webkit-backdrop-filter:saturate(1.5) blur(14px);backdrop-filter:saturate(1.5) blur(14px);
  box-shadow:0 1px 0 rgba(34,28,48,.05),0 18px 40px -30px rgba(34,28,48,.6)}
.nav.scrolled .nav-in{padding-top:18px;padding-bottom:18px}

/* animated underline on nav links (desktop) */
@media(min-width:861px){
  .nav-links a:not(.nav-cta){position:relative}
  .nav-links a:not(.nav-cta)::after{content:"";position:absolute;left:0;right:100%;bottom:-3px;height:2px;
    background:var(--coral);transition:right .28s cubic-bezier(.2,.7,.2,1)}
  .nav-links a:not(.nav-cta):hover::after,.nav-links a.is-active::after{right:0}
}

/* button + card depth */
.btn{box-shadow:0 1px 2px rgba(34,28,48,.16);transition:transform .25s,background .25s,color .25s,box-shadow .25s}
.btn:hover{box-shadow:0 14px 30px -10px rgba(229,83,59,.5)}
.mk,.feat,.scard,.card-soft{box-shadow:0 0 0 1px rgba(34,28,48,.045),var(--shadow-sm)}
.mk:hover{box-shadow:0 0 0 1px rgba(34,28,48,.045),var(--shadow)}

/* ===================== HOMEPAGE HERO (index.php only) ===================== */
.hero{position:relative;padding:172px 0 96px}
.hero-grid{max-width:var(--maxw);margin:0 auto;padding:0 28px;display:grid;
  grid-template-columns:1.06fr .94fr;gap:60px;align-items:center}
.hero h1{font-family:var(--serif);font-weight:300;font-variation-settings:"opsz" 140;
  font-size:clamp(3.1rem,7vw,5.8rem);line-height:1.0;letter-spacing:-.035em;margin:26px 0 0}
.hero h1 em{font-style:italic;color:var(--coral)}
.hero p.sub{font-size:1.18rem;color:var(--ink-soft);max-width:33ch;margin:28px 0 38px;line-height:1.55}
.hero-actions{display:flex;align-items:center;gap:22px;flex-wrap:wrap}
.hero .art{height:clamp(420px,46vw,560px)}
@media(max-width:880px){
  .hero{padding:128px 0 70px}
  .hero-grid{grid-template-columns:1fr;gap:44px}
  .hero .art{height:360px}
  .hero h1{font-size:clamp(2.8rem,11vw,3.6rem)}
  .hero p.sub{max-width:46ch}
}
.palette{max-width:var(--maxw);margin:64px auto 0;padding:0 28px;display:flex;align-items:center;gap:22px;flex-wrap:wrap}
.palette .sw{display:flex;gap:9px}
.palette .sw i{width:30px;height:30px;border-radius:9px;display:block}
.palette .c1{background:var(--marigold)}.palette .c2{background:var(--peri)}
.palette .c3{background:#fff;box-shadow:inset 0 0 0 1px var(--line)}
.palette .c4{background:var(--rose)}.palette .c5{background:var(--coral)}
.palette span{font-size:.86rem;color:var(--ink-soft)}

/* ===================== CONTACT MAP (Leaflet) ===================== */
.contact-map{height:clamp(340px,46vw,470px);border-radius:var(--r);overflow:hidden;
  box-shadow:0 0 0 1px rgba(34,28,48,.06),var(--shadow);position:relative;z-index:0;background:var(--canvas-2)}
.map-pin{display:grid;place-items:center;width:34px;height:34px;background:var(--coral);
  border-radius:50% 50% 50% 0;transform:rotate(-45deg);box-shadow:0 6px 14px rgba(34,28,48,.4);border:2px solid #fff}
.map-pin b{transform:rotate(45deg);color:#fff;font-weight:700;font-size:.95rem;font-family:var(--sans)}
.map-key{display:flex;gap:14px 28px;flex-wrap:wrap;margin-top:22px;font-size:.96rem;font-weight:600}
.map-key span{display:inline-flex;align-items:center;gap:10px}
.map-key .map-dot{display:grid;place-items:center;width:24px;height:24px;border-radius:50%;background:var(--coral);color:#fff;font-size:.78rem;font-weight:700;font-style:normal;flex:0 0 auto}
.leaflet-popup-content-wrapper{border-radius:14px;box-shadow:var(--shadow)}
.leaflet-popup-content{font-family:var(--sans);font-size:.92rem;line-height:1.55;margin:14px 16px}
.leaflet-popup-content a{color:var(--coral);font-weight:600}
.leaflet-container{font-family:var(--sans)}

/* ===================== STUDIO AVAILABILITY MAP ===================== */
.fp{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.fp-tabs{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:24px}
.fp-tab{padding:11px 20px;border-radius:999px;border:1px solid var(--line);background:#fff;font:inherit;
  font-size:.92rem;font-weight:600;color:var(--ink-soft);cursor:pointer;display:inline-flex;align-items:center;gap:9px;
  transition:background .2s,color .2s,border-color .2s}
.fp-tab:hover{border-color:var(--coral);color:var(--ink)}
.fp-tab.on{background:var(--ink);color:var(--canvas);border-color:var(--ink)}
.fp-tab-n{font-size:.66rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;padding:2px 8px;border-radius:999px;background:var(--coral);color:#fff}
.fp-panel{display:none}
.fp-panel.on{display:block}
.stu-floor{font-size:.74rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);margin:4px 0 14px}
.stu-grid{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:30px}
/* Spacer absorbs leftover slack on the LAST row only, so a lone last tile
   (e.g. Studio Q / M) keeps its natural sqft width instead of stretching full. */
.stu-grid::after{content:"";flex:99999 1 0;min-width:0;height:0;margin:0;padding:0}
.stu{position:relative;flex:var(--w,250) 1 calc(var(--w,250) * 0.5px);min-width:150px;
  display:flex;flex-direction:column;gap:5px;align-items:flex-start;min-height:152px;
  padding:18px;border-radius:18px;border:0;cursor:default;text-align:left;font-family:var(--sans);
  background:#fff;box-shadow:0 0 0 1px rgba(34,28,48,.06),var(--shadow-sm);
  transition:transform .25s,box-shadow .25s}
/* Lower-level tiles a touch shorter than main-floor ones */
.stu-grid-lower .stu{min-height:120px}
.stu-grid-lower .stu-letter{font-size:2.1rem}
.stu-tag{font-size:.62rem;font-weight:800;letter-spacing:.16em;text-transform:uppercase;opacity:.8}
.stu-letter{font-family:var(--serif);font-weight:300;font-size:2.6rem;line-height:.9;letter-spacing:-.02em;margin-top:auto}
.stu-info{font-size:.82rem;font-weight:600;opacity:.92}
.stu-go{font-size:.78rem;font-weight:700;color:inherit;opacity:0;transition:opacity .2s}
.stu-available{background:var(--coral);color:#fff;cursor:pointer;box-shadow:0 0 0 1px var(--coral),var(--shadow-sm)}
.stu-available:hover{transform:translateY(-5px);box-shadow:0 16px 32px -12px rgba(229,83,59,.55)}
.stu-occupied{background:var(--canvas-2);color:var(--ink-soft)}
.stu-hold{background:var(--t-marigold);color:#7a5210;cursor:pointer}
.stu-unknown{background:#fff;color:var(--ink);cursor:pointer}
.stu-hold:hover,.stu-unknown:hover{transform:translateY(-4px);box-shadow:0 14px 28px -14px rgba(34,28,48,.28)}
.stu-available:hover .stu-go,.stu-hold:hover .stu-go,.stu-unknown:hover .stu-go{opacity:1}
.fp-legend{display:flex;gap:14px 20px;flex-wrap:wrap;margin-top:6px;font-size:.9rem;font-weight:600;color:var(--ink-soft)}
.fp-legend span{display:inline-flex;align-items:center;gap:8px}
.fp-key{width:18px;height:18px;border-radius:5px;display:inline-block;flex:0 0 auto;box-shadow:inset 0 0 0 1px rgba(34,28,48,.12)}
.fp-key.stu-available{background:var(--coral)}
.fp-key.stu-occupied{background:var(--canvas-2)}
.fp-key.stu-hold{background:var(--t-marigold)}
.fp-key.stu-unknown{background:#fff}
@media(max-width:560px){.stu{min-width:130px}}
