/* ===========================================================================
   Vanguard Nº 854 — landing page styles
   Recreates the design-system prototype (JSX) as plain CSS using the tokens
   in colors_and_type.css.
   =========================================================================== */

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--paper);-webkit-font-smoothing:antialiased;font-family:var(--font-text);color:var(--fg1)}
img{max-width:100%}
a{color:inherit}
::selection{background:var(--brass);color:var(--paper)}
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--brass);outline-offset:2px}
.skip-link{position:absolute;left:-9999px;top:0;z-index:200;background:var(--ink);color:var(--paper);padding:10px 16px;border-radius:0 0 8px 0;text-decoration:none;font-size:14px}
.skip-link:focus{left:0}

/* ---- Layout primitives ---- */
.wrap{max-width:1240px;margin:0 auto;padding:0 clamp(20px,5vw,40px)}
.section{padding:clamp(64px,9vw,128px) 0;position:relative;background:var(--paper);color:var(--fg1)}
.section.sunken{background:var(--paper-sunken)}
.section.dark{background:var(--ink-true);color:var(--fg-on-dark-1)}
.section.darksoft{background:var(--ink-soft);color:var(--fg-on-dark-1)}
.split{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:clamp(32px,5vw,64px);align-items:center}

/* ---- Type helpers ---- */
.eyebrow{font-family:var(--font-text);font-size:13px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--fg3)}
.eyebrow-light{color:var(--fg-on-dark-3)}
.eyebrow.center{text-align:center}
.section h2{font-size:clamp(2rem,3.4vw,3rem);line-height:1.08;margin:16px 0 0}
h2.on-dark,.on-dark{color:var(--paper)}
.lead{font-family:var(--font-text);font-size:var(--t-lead);line-height:1.62;color:var(--fg2);margin:20px 0 0;text-wrap:pretty}
.lead.on-dark{color:var(--fg-on-dark-1)}
.lead.on-dark-2{color:var(--fg-on-dark-2)}
.intro{max-width:720px;margin:0 auto clamp(40px,6vw,68px);text-align:center}
.intro .lead{margin:18px auto 0;max-width:600px}

/* ---- Buttons ---- */
.btn{font-family:var(--font-text);font-weight:600;font-size:15px;border:0;cursor:pointer;display:inline-flex;align-items:center;gap:9px;border-radius:8px;padding:14px 24px;transition:background .22s var(--ease),transform .22s var(--ease),color .22s var(--ease);white-space:nowrap;text-decoration:none;line-height:1}
.btn svg{flex:none}
.btn:active{transform:scale(.97)}
.btn-primary{background:var(--ink);color:var(--paper)}
.btn-primary:hover{background:#000}
.btn-light{background:var(--paper);color:var(--ink)}
.btn-light:hover{background:#fff}
.btn-quiet{background:#E7E3DA;color:var(--ink)}
.btn-quiet:hover{background:#DED9CE}
.btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--line-strong)}
.btn-ghost:hover{background:rgba(22,21,15,.05)}
.btn-glass{background:rgba(245,242,236,.12);color:var(--paper);border:1px solid rgba(245,242,236,.30);backdrop-filter:blur(8px)}
.btn-glass:hover{background:rgba(245,242,236,.22)}
.btn-block{width:100%;justify-content:center}

/* ---- Nav ---- */
.nav{position:sticky;top:0;z-index:50;background:transparent;transition:background .4s var(--ease),box-shadow .4s var(--ease),backdrop-filter .4s}
.nav.solid{background:rgba(245,242,236,.82);backdrop-filter:blur(14px);box-shadow:0 1px 0 var(--line)}
.nav-inner{max-width:1240px;margin:0 auto;padding:0 clamp(20px,5vw,40px);height:72px;display:flex;align-items:center;justify-content:space-between}
.nav-brand{display:flex;align-items:center;gap:11px;text-decoration:none}
.crest{height:30px;display:block}
.crest-dark{display:none}
.nav.solid .crest-light{display:none}
.nav.solid .crest-dark{display:block}
.nav-word{font-family:var(--font-text);font-weight:600;font-size:14px;letter-spacing:.34em;color:var(--paper);transition:color .4s}
.nav-no{font-family:var(--font-display);font-size:14px;color:var(--fg-on-dark-2);margin-left:-2px;transition:color .4s}
.nav.solid .nav-word{color:var(--ink)}
.nav.solid .nav-no{color:var(--fg3)}
.nav-links{display:flex;gap:28px;align-items:center}
.nav-links a{font-family:var(--font-text);font-size:14.5px;font-weight:500;color:rgba(245,242,236,.82);text-decoration:none;transition:color .25s}
.nav-links a:hover{color:var(--paper)}
.nav.solid .nav-links a{color:var(--fg2)}
.nav.solid .nav-links a:hover{color:var(--ink)}
.nav-right{display:flex;align-items:center;gap:16px}
.lang-toggle{display:flex;align-items:center;gap:5px;font-size:13px;font-weight:600}
.lang-toggle a{text-decoration:none;color:rgba(245,242,236,.45)}
.lang-toggle a.on{color:var(--paper)}
.lang-toggle span{color:rgba(245,242,236,.45)}
.nav.solid .lang-toggle a{color:var(--fg4)}
.nav.solid .lang-toggle a.on{color:var(--ink)}
.nav.solid .lang-toggle span{color:var(--fg4)}
.nav-burger{display:none;background:none;border:0;cursor:pointer;color:var(--paper);padding:4px}
.nav.solid .nav-burger{color:var(--ink)}
.nav-mobile{display:none;flex-direction:column;padding:6px clamp(20px,5vw,40px) 16px;background:rgba(245,242,236,.97);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.nav-mobile a{padding:13px 0;text-decoration:none;color:var(--fg1);font-size:16px;border-bottom:1px solid var(--line)}
.nav-mobile a:last-child{border-bottom:0}
.nav-mobile a.strong{font-weight:600}
@media(max-width:880px){
  .nav-links{display:none}
  .nav-cta{display:none}
  .nav-burger{display:inline-flex}
  .nav-mobile.open{display:flex}
}

/* ---- Hero ---- */
.hero{position:relative;min-height:100vh;display:flex;flex-direction:column;overflow:hidden;margin-top:-72px}
.hero-bg{position:absolute;inset:0;z-index:0;animation:vgKen 40s ease-in-out infinite alternate}
.hero-frame{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-frame-next{opacity:0}
/* Mobile: single vertical still image (no slideshow), cropped from the bottom */
.hero-bg.is-mobile{animation:none}
.hero-bg.is-mobile .hero-frame{object-position:center top}
.hero-bg.is-mobile .hero-frame-next{display:none}
.hero-scrim{position:absolute;inset:0;z-index:1;background:linear-gradient(to top,rgba(12,11,8,.86) 0%,rgba(12,11,8,.30) 42%,rgba(12,11,8,.50) 100%)}
.hero-inner{position:relative;z-index:2;flex:1;display:flex;flex-direction:column;justify-content:flex-end;max-width:1240px;width:100%;margin:0 auto;padding:0 clamp(20px,5vw,40px) clamp(56px,7vw,92px)}
.hero-copy{max-width:880px}
.hero-title{font-family:var(--font-display);font-weight:500;color:var(--paper);font-size:clamp(2.8rem,6.4vw,5.4rem);line-height:1;letter-spacing:-.01em;margin:20px 0 0;text-wrap:balance}
.hero-lead{font-size:clamp(1.05rem,1.5vw,1.3rem);line-height:1.55;color:var(--fg-on-dark-1);margin:24px 0 0;max-width:540px;opacity:.94}
.hero-actions{display:flex;gap:14px;margin-top:36px;flex-wrap:wrap}
.hero-scroll{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:2;color:var(--fg-on-dark-2);display:flex;flex-direction:column;align-items:center;gap:6px;text-decoration:none;font-size:11px;letter-spacing:.2em;text-transform:uppercase}
.hero-pause{position:absolute;right:clamp(20px,5vw,40px);bottom:26px;z-index:3;display:none;align-items:center;justify-content:center;width:40px;height:40px;border-radius:999px;background:rgba(245,242,236,.12);border:1px solid rgba(245,242,236,.30);backdrop-filter:blur(8px);color:var(--paper);cursor:pointer;transition:background .22s var(--ease),transform .22s var(--ease)}
.hero-pause:hover{background:rgba(245,242,236,.22)}
.hero-pause:active{transform:scale(.94)}
.hero-pause svg{display:block}
.hero-pause .hp-pause{display:inline-flex}
.hero-pause .hp-play{display:none;margin-left:2px}
.hero-pause.is-paused .hp-pause{display:none}
.hero-pause.is-paused .hp-play{display:inline-flex}
@media (prefers-reduced-motion: reduce){.hero-pause{display:none!important}}

/* ---- Stat strip ---- */
.statstrip{background:var(--ink-true);color:var(--paper)}
.statstrip-inner{max-width:1240px;margin:0 auto;padding:clamp(40px,5vw,60px) clamp(20px,5vw,40px);display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:28px}
.stat{border-left:1px solid var(--line-on-dark);padding-left:22px}
.stat-n{font-family:var(--font-display);font-weight:500;font-size:clamp(2.4rem,3.6vw,3.1rem);line-height:1}
.stat-u{color:var(--brass);font-size:.55em;margin-left:2px}
.stat-l{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--fg-on-dark-3);margin-top:10px}

/* ---- Generic media figure ---- */
.media{margin:0;position:relative;border-radius:18px;overflow:hidden;box-shadow:var(--shadow-img);cursor:pointer}
.media a{display:block}
.media img{width:100%;object-fit:cover;display:block;transition:transform .6s var(--ease)}
.media:hover img{transform:scale(1.04)}

/* ---- Concept ---- */
.concept .split{grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:clamp(32px,5vw,72px)}
.concept .media img{height:clamp(360px,46vw,560px)}
.feature-row{display:flex;gap:36px;margin:30px 0 0;flex-wrap:wrap}
.feature{display:flex;gap:12px;align-items:flex-start}
.feature-ic{color:var(--ink);margin-top:2px;display:flex}
.feature-s{font-family:var(--font-display);font-size:19px;color:var(--ink)}
.feature-l{font-size:13px;color:var(--fg3)}

/* ---- Loft detail ---- */
.loft-head{display:flex;align-items:baseline;gap:14px;margin:16px 0 0;flex-wrap:wrap}
.loft-head h2{margin:0;font-size:clamp(2rem,3.4vw,3rem);line-height:1.05}
.badge-avail{font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--sprout);border:1px solid color-mix(in oklab,var(--sprout) 40%,transparent);border-radius:999px;padding:5px 12px}
.spec-grid{display:grid;grid-template-columns:1fr 1fr;margin:28px 0 0;border-top:1px solid var(--line-strong)}
.spec{display:flex;justify-content:space-between;padding:14px 0;border-bottom:1px solid var(--line-strong)}
.spec:nth-child(odd){border-right:1px solid var(--line-strong);padding-right:24px}
.spec:nth-child(even){padding-left:24px}
.spec-k{font-size:13px;color:var(--fg3)}
.spec-v{font-family:var(--font-display);font-size:17px;color:var(--ink)}
.loft-cta{display:flex;align-items:center;gap:22px;margin:30px 0 0;flex-wrap:wrap}
.price-label{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--fg3)}
.price{font-family:var(--font-display);font-size:30px;color:var(--ink);margin-top:2px}
.loft-gallery{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.loft-gallery figure{margin:0;border-radius:14px;overflow:hidden;cursor:pointer;box-shadow:var(--shadow-md);aspect-ratio:1/1}
.loft-gallery figure a{display:block;width:100%;height:100%}
.loft-gallery img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s var(--ease)}
.loft-gallery figure:hover img{transform:scale(1.05)}
.loft-gallery .lg-big{grid-column:1/-1;aspect-ratio:16/10}

/* ---- Floor plan ---- */
.pdf-frame{background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow-md);overflow:hidden}
.pdf-frame object{width:100%;aspect-ratio:1191/842;display:block;border:0;background:#fff}
.pdf-fallback{padding:40px;text-align:center;color:var(--fg2)}
.floorplan-foot{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:20px;margin-top:26px}
.fig-row{display:flex;gap:clamp(24px,4vw,52px);flex-wrap:wrap}
.fig-v{font-family:var(--font-display);font-size:24px;color:var(--ink)}
.fig-l{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--fg3);margin-top:3px}
.note{font-size:12.5px;color:var(--fg3);margin:20px 0 0;max-width:620px}

/* ---- Wellness ---- */
.wellness-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:14px}
.wellness-grid figure{margin:0;position:relative;border-radius:16px;overflow:hidden;cursor:pointer;height:clamp(220px,26vw,340px)}
.wellness-grid figure a{display:block;height:100%}
.wellness-grid img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s var(--ease)}
.wellness-grid figure:hover img{transform:scale(1.04)}
.w-7{grid-column:span 7}
.w-5{grid-column:span 5}
.scrim{position:absolute;inset:0;background:linear-gradient(to top,rgba(12,11,8,.8) 0%,rgba(12,11,8,0) 55%)}
.wellness-grid figcaption{position:absolute;left:20px;bottom:18px;font-family:var(--font-display);font-size:clamp(1.1rem,1.6vw,1.5rem);color:var(--paper)}
@media(max-width:720px){.w-7,.w-5{grid-column:span 12}}

/* ---- Security ---- */
.sec-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin:30px 0 0}
.sec-pt{display:flex;gap:12px;align-items:flex-start}
.sec-ic{color:var(--brass);margin-top:1px;display:flex}
.sec-pt span:last-child{font-size:14.5px;color:var(--fg-on-dark-1);line-height:1.4}
.security .media{box-shadow:var(--shadow-lg)}
.security .media img{height:clamp(300px,38vw,460px)}
@media(max-width:520px){.sec-grid{grid-template-columns:1fr}}

/* ---- Amenities ---- */
.amenities-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}
.amenity{background:var(--paper-raised);border:1px solid var(--line);border-radius:14px;padding:22px;display:flex;align-items:center;gap:16px;height:100%;transition:box-shadow .3s var(--ease),transform .3s var(--ease)}
.amenity:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
.amenity-ic{color:var(--ink);flex:none;display:flex}
.amenity span:last-child{font-size:15.5px;font-weight:500;color:var(--ink);line-height:1.3}
@media(max-width:720px){.amenities-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:420px){.amenities-grid{grid-template-columns:1fr}}

/* ---- Location ---- */
.loc-list{margin:26px 0 0;border-top:1px solid var(--line-strong)}
.loc-row{display:flex;justify-content:space-between;align-items:center;padding:15px 0;border-bottom:1px solid var(--line-strong)}
.loc-k{display:flex;align-items:center;gap:11px;font-size:15px;color:var(--fg2)}
.loc-ic{color:var(--fg3);display:flex}
.loc-v{font-family:var(--font-display);font-size:19px;color:var(--ink)}
.loc-media .media img,.location .media img{height:clamp(300px,40vw,480px)}
.loc-media::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(12,11,8,.5),transparent 50%);pointer-events:none}
.loc-cap{position:absolute;left:22px;bottom:20px;color:var(--paper);display:flex;flex-direction:column;z-index:2}
.loc-cap-k{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--fg-on-dark-2)}
.loc-cap-v{font-family:var(--font-display);font-size:24px}

/* ---- Interlude ---- */
.interlude{position:relative;height:clamp(440px,70vh,720px);overflow:hidden;cursor:pointer}
.interlude-img{display:block;position:absolute;inset:0;animation:vgKen 34s ease-in-out infinite alternate}
.interlude-img img{width:100%;height:100%;object-fit:cover;display:block}
.interlude-scrim{position:absolute;inset:0;background:linear-gradient(105deg,rgba(12,11,8,.82) 0%,rgba(12,11,8,.42) 48%,rgba(12,11,8,.18) 100%)}
.interlude-inner{position:absolute;inset:0;display:flex;align-items:center}
.interlude-copy{max-width:620px}

/* ---- Reserve ---- */
.reserve-grid{gap:clamp(36px,5vw,72px)}
.reserve-contacts{display:flex;gap:26px;margin:30px 0 0;flex-wrap:wrap}
.reserve-contacts a{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--fg-on-dark-1);font-size:15px}
.reserve-contacts .ci{color:var(--brass);display:flex}
.reserve-card{background:rgba(245,242,236,.04);border:1px solid var(--line-on-dark);border-radius:20px;padding:clamp(24px,3vw,34px)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field{display:block;grid-column:1/3}
.field>span{display:block;font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--fg3);margin-bottom:7px}
.field input,.field select,.field textarea{width:100%;font-family:var(--font-text);font-size:15px;color:var(--ink);background:var(--paper-raised);border:1px solid var(--line-strong);border-radius:10px;padding:13px 14px;outline:none}
.field textarea{resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--brass);box-shadow:0 0 0 3px var(--focus-ring)}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.form-submit{margin-top:22px}
.form-note{font-size:12px;color:var(--fg-on-dark-3);margin-top:14px;text-align:center}
.form-error{font-size:13px;color:#E6A08C;margin-top:12px;text-align:center}
.reserve-thanks{text-align:center;padding:40px 10px}
.thanks-ic{color:var(--brass);display:flex;justify-content:center;margin-bottom:16px}
.thanks-h{font-family:var(--font-display);font-size:26px;color:var(--paper)}
.reserve-thanks p{color:var(--fg-on-dark-2);margin-top:10px}

/* ---- Gallery (masonry) ---- */
.masonry{column-width:320px;column-gap:14px}
.masonry figure{margin:0 0 14px;border-radius:14px;overflow:hidden;cursor:pointer;box-shadow:var(--shadow-sm);break-inside:avoid}
.masonry figure a{display:block}
.masonry img{width:100%;display:block;transition:transform .5s var(--ease)}
.masonry figure:hover img{transform:scale(1.04)}

/* ---- Footer ---- */
.footer{background:var(--ink-true);color:var(--fg-on-dark-2);padding:clamp(56px,7vw,88px) 0 36px}
.footer-top{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:40px;border-bottom:1px solid var(--line-on-dark);padding-bottom:48px}
.footer-logo{display:flex;align-items:center;gap:11px}
.fl-word{font-weight:600;font-size:14px;letter-spacing:.3em;color:var(--paper)}
.fl-no{font-family:var(--font-display);font-size:13px;color:var(--fg-on-dark-3)}
.footer-tag{font-family:var(--font-display);font-style:italic;font-size:18px;color:var(--fg-on-dark-1);margin:22px 0 0;max-width:240px;line-height:1.4}
.fc-h{font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--fg-on-dark-3);margin-bottom:18px}
.footer-col ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:11px}
.footer-col a{color:var(--fg-on-dark-2);text-decoration:none;font-size:14.5px}
.footer-col a:hover{color:var(--paper)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:26px;flex-wrap:wrap;gap:12px;font-size:12.5px;color:var(--fg-on-dark-3)}
.footer-bottom a{color:var(--fg-on-dark-3);text-decoration:none}
.footer-bottom a:hover{color:var(--paper)}
.footer-credit{padding-top:16px;text-align:center}
.footer-credit a{font-size:11.5px;letter-spacing:.04em;color:var(--fg-on-dark-3);text-decoration:none;opacity:.85}
.footer-credit a:hover{color:var(--fg-on-dark-2);opacity:1}

/* ---- Sticky bar ---- */
.stickybar{position:fixed;left:0;right:0;bottom:0;z-index:45;transform:translateY(110%);transition:transform .45s var(--ease);pointer-events:none}
.stickybar.show{transform:translateY(0);pointer-events:auto}
.stickybar-inner{max-width:1240px;margin:0 auto;padding:0 clamp(12px,5vw,40px) 16px}
.sb-card{background:rgba(22,21,15,.92);backdrop-filter:blur(14px);border-radius:14px;padding:14px 16px 14px 22px;display:flex;align-items:center;justify-content:space-between;gap:16px;box-shadow:var(--shadow-lg);border:1px solid rgba(245,242,236,.08)}
.sb-info{display:flex;align-items:center;gap:16px;min-width:0}
.sb-dot{width:8px;height:8px;border-radius:99px;background:var(--sprout);flex:none}
.sb-title{font-size:14.5px;font-weight:600;color:var(--paper);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sb-price{font-size:12.5px;color:var(--fg-on-dark-3)}
.sb-btn{padding:11px 18px;font-size:14px;flex:none}
@media(max-width:520px){.sb-title{font-size:12.5px}.sb-btn{padding:10px 14px;font-size:13px}}

/* ---- Lightbox ---- */
.lightbox{position:fixed;inset:0;z-index:100;background:rgba(8,7,5,.94);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:clamp(20px,5vw,64px);animation:vgFade .25s ease}
.lightbox[hidden]{display:none}
.lb-img{max-width:100%;max-height:100%;object-fit:contain;border-radius:10px;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.lb-close{position:absolute;top:24px;right:26px;background:none;border:0;color:var(--fg-on-dark-2);cursor:pointer}
.lb-nav{position:absolute;background:rgba(245,242,236,.08);border:0;color:var(--paper);cursor:pointer;border-radius:99px;width:48px;height:48px;display:flex;align-items:center;justify-content:center}
.lb-prev{left:20px}
.lb-next{right:20px}

/* ---- Motion / reveal ---- */
@keyframes vgFade{from{opacity:0}to{opacity:1}}
@keyframes vgKen{from{transform:scale(1)}to{transform:scale(1.045)}}
.js .reveal{opacity:0;transform:translateY(18px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.js .reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  html{scroll-behavior:auto}
  .js .reveal{opacity:1;transform:none}
}
