/* ============================================================
   UnoSei — Single-page site styles (Direction A · premium)
   relies on tokens.css for variables + .ph + .eyebrow
   ============================================================ */

html{ scroll-behavior:smooth; }
body{ overflow-x:hidden; }
::selection{ background:var(--sage-deep); color:var(--bone); }

/* faint film grain for premium texture */
.grain{ position:fixed; inset:0; z-index:1; pointer-events:none; opacity:.045; mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); }

.container{ max-width:1320px; margin:0 auto; padding:0 56px; }

/* ---------- scroll reveal ---------- */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity 1.1s cubic-bezier(.2,.7,.2,1), transform 1.1s cubic-bezier(.2,.7,.2,1); }
.reveal.in{ opacity:1; transform:none; }

/* ============================================================
   NAV
   ============================================================ */
.nav{ position:fixed; top:0; left:0; right:0; z-index:40;
  display:flex; align-items:center; justify-content:space-between;
  padding:22px 56px; transition:background .5s ease, padding .5s ease, box-shadow .5s ease; }
.nav .logo{ height:40px; width:auto; display:block; transition:opacity .4s; }
.nav .logo.ink{ position:absolute; opacity:0; }
.nav-links{ display:flex; gap:34px; align-items:center; }
.nav-links a{ font-family:var(--sans); font-weight:400; font-size:12px; letter-spacing:.16em;
  text-transform:uppercase; color:rgba(244,241,234,.88); text-decoration:none; position:relative; padding:6px 0; transition:color .3s; }
.nav-links a::after{ content:""; position:absolute; left:0; right:100%; bottom:0; height:1px; background:currentColor; transition:right .4s cubic-bezier(.2,.7,.2,1); }
.nav-links a:hover::after{ right:0; }
.nav-cta{ font-family:var(--sans); font-size:12px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--bone); text-decoration:none; border:1px solid rgba(244,241,234,.55); padding:.75em 1.5em; transition:.4s; }
.nav-cta:hover{ background:var(--bone); color:var(--ink); border-color:var(--bone); }

/* scrolled state */
.nav.solid{ background:rgba(244,241,234,.92); backdrop-filter:blur(10px); padding:14px 56px;
  box-shadow:0 1px 0 var(--line-soft); }
.nav.solid .logo.white{ opacity:0; }
.nav.solid .logo.ink{ opacity:1; }
.nav.solid .nav-links a{ color:var(--ink-soft); }
.nav.solid .nav-links a:hover{ color:var(--ink); }
.nav.solid .nav-cta{ color:var(--ink); border-color:var(--ink); }
.nav.solid .nav-cta:hover{ background:var(--ink); color:var(--bone); }

/* hamburger (mobile only) */
.burger{ display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:8px; z-index:60; }
.burger span{ width:26px; height:1.5px; background:var(--bone); transition:.4s; }
.nav.solid .burger span{ background:var(--ink); }
.drawer{ display:none; }

/* ============================================================
   HERO
   ============================================================ */
.hero{ position:relative; height:100vh; min-height:680px; }
.hero .ph{ position:absolute; inset:0; }
.hero::before{ content:""; position:absolute; inset:0; z-index:2;
  background:linear-gradient(180deg, rgba(26,30,24,.5) 0%, rgba(26,30,24,.18) 36%, rgba(26,30,24,.62) 100%); }
.hero-inner{ position:absolute; inset:0; z-index:3; display:flex; flex-direction:column;
  align-items:center; justify-content:center; text-align:center; color:var(--bone); padding:0 32px; }
.hero .eyebrow{ color:rgba(244,241,234,.85); margin-bottom:30px; }
.hero h1{ font-family:var(--serif); font-weight:300; color:var(--bone);
  font-size:clamp(48px, 7vw, 104px); line-height:1.02; letter-spacing:-.012em; margin:0; max-width:14ch; }
.hero h1 em{ font-style:italic; font-weight:400; }
.hero .sub{ margin-top:30px; font-size:clamp(14px,1.2vw,16px); letter-spacing:.02em;
  color:rgba(244,241,234,.88); max-width:50ch; line-height:1.75; }
.hero .acts{ margin-top:42px; display:flex; gap:16px; flex-wrap:wrap; justify-content:center; }
.hero .btn-line{ color:var(--bone); border-color:rgba(244,241,234,.7); }
.hero .btn-line:hover{ background:var(--bone); color:var(--ink); border-color:var(--bone); }
.scrollcue{ position:absolute; bottom:34px; left:50%; transform:translateX(-50%); z-index:3;
  font-family:var(--sans); font-size:10px; letter-spacing:.3em; text-transform:uppercase;
  color:rgba(244,241,234,.7); display:flex; flex-direction:column; align-items:center; gap:12px; }
.scrollcue .ln{ width:1px; height:46px; background:linear-gradient(rgba(244,241,234,.75),transparent); animation:cue 2.4s ease-in-out infinite; transform-origin:top; }
@keyframes cue{ 0%,100%{ transform:scaleY(.4); opacity:.5;} 50%{ transform:scaleY(1); opacity:1;} }

/* side vertical labels on hero */
.hero .vleft,.hero .vright{ position:absolute; z-index:3; top:50%; font-family:var(--sans);
  font-size:10px; letter-spacing:.34em; text-transform:uppercase; color:rgba(244,241,234,.6); }
.hero .vleft{ left:30px; transform:translateY(-50%) rotate(180deg); writing-mode:vertical-rl; }
.hero .vright{ right:30px; transform:translateY(-50%); writing-mode:vertical-rl; }

/* ============================================================
   STORY
   ============================================================ */
.story{ padding:140px 0; }
.story-grid{ display:grid; grid-template-columns:1fr 1fr; gap:90px; align-items:center; }
.story .eyebrow{ margin-bottom:26px; }
.story h2{ font-family:var(--serif); font-weight:300; font-size:clamp(30px,3.4vw,46px); line-height:1.16; margin:0; letter-spacing:-.01em; }
.story h2 em{ font-style:italic; }
.story p{ color:var(--ink-soft); font-size:16px; max-width:50ch; margin:0 0 20px; line-height:1.8; }
.badge-row{ display:flex; gap:12px; flex-wrap:wrap; margin:30px 0 0; }
.badge{ font-family:var(--sans); font-size:10.5px; letter-spacing:.2em; text-transform:uppercase;
  color:var(--sage-deep); border:1px solid var(--line); padding:.7em 1.1em; }
.stats{ display:flex; gap:56px; margin-top:40px; padding-top:38px; border-top:1px solid var(--line); }
.stat .n{ font-family:var(--serif); font-size:46px; color:var(--sage-deep); line-height:1; }
.stat .l{ font-family:var(--sans); font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--ink-faint); margin-top:12px; }

/* ============================================================
   WORK / GALLERIES
   ============================================================ */
.work{ padding:96px 0; }
.work.alt{ background:var(--paper); }
.work-inner{ display:grid; grid-template-columns:.82fr 2.18fr; gap:72px; align-items:start; }
.work.flip .work-inner{ grid-template-columns:2.18fr .82fr; }
.work.flip .rail{ order:2; }
.rail{ position:sticky; top:120px; }
.rail .idx{ font-family:var(--sans); font-size:11px; letter-spacing:.3em; color:var(--sage); margin-bottom:20px; }
.rail h3{ font-family:var(--serif); font-weight:300; font-size:clamp(34px,3.6vw,52px); line-height:1.04; margin:0 0 22px; letter-spacing:-.01em; }
.rail h3 em{ font-style:italic; }
.rail p{ color:var(--ink-soft); font-size:15px; line-height:1.8; max-width:38ch; margin:0 0 26px; }
.rail .folder{ font-family:var(--sans); font-size:10.5px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--ink-faint); border-top:1px solid var(--line); padding-top:18px; margin-bottom:26px; }
.rail .folder b{ color:var(--sage-deep); font-weight:600; }
.rail .more{ font-family:var(--sans); font-size:12px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--ink); text-decoration:none; display:inline-flex; align-items:center; gap:.7em; border-bottom:1px solid var(--ink); padding-bottom:5px; transition:gap .3s; }
.rail .more:hover{ gap:1.3em; }

.cluster{ display:grid; grid-template-columns:repeat(12,1fr); grid-auto-rows:1px; gap:18px; }
.cluster .ph{ width:100%; height:100%; transition:transform 1.2s cubic-bezier(.2,.7,.2,1); }
.cluster figure{ margin:0; overflow:hidden; position:relative; }
.cluster figure:hover .ph{ transform:scale(1.045); }
.cluster figure figcaption{ position:absolute; left:16px; bottom:14px; z-index:3;
  font-family:var(--sans); font-size:10px; letter-spacing:.2em; text-transform:uppercase; color:#fff;
  opacity:0; transform:translateY(8px); transition:.5s; text-shadow:0 1px 14px rgba(0,0,0,.5); }
.cluster figure:hover figcaption{ opacity:1; transform:none; }
/* arrangement: feature + two */
.c-feature{ grid-column:span 7; grid-row:span 520; }
.c-top{ grid-column:span 5; grid-row:span 251; }
.c-bot{ grid-column:span 5; grid-row:span 251; }
.work.flip .c-feature{ grid-column:span 7; }

/* boudoir — intimate dark band */
.work.dark{ background:var(--sage-deep); }
.work.dark .rail .idx{ color:var(--sage-mist); }
.work.dark .rail h3{ color:var(--bone); }
.work.dark .rail p{ color:rgba(244,241,234,.72); }
.work.dark .rail .folder{ color:rgba(244,241,234,.5); border-color:rgba(244,241,234,.18); }
.work.dark .rail .folder b{ color:var(--sage-mist); }
.work.dark .rail .more{ color:var(--bone); border-color:rgba(244,241,234,.6); }

/* ============================================================
   HOME — mixed showcase (a glimpse across categories)
   ============================================================ */
.showcase{ padding:120px 0 110px; }
.showcase .sc-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:30px; margin-bottom:54px; }
.showcase .sc-head .eyebrow{ margin-bottom:18px; }
.showcase .sc-head h2{ font-family:var(--serif); font-weight:300; font-size:clamp(32px,3.8vw,52px);
  line-height:1.08; margin:0; letter-spacing:-.01em; max-width:18ch; }
.showcase .sc-head h2 em{ font-style:italic; }
.showcase .sc-head .sc-sub{ font-family:var(--sans); font-size:14px; color:var(--ink-soft); max-width:32ch; line-height:1.7; }

.collage{ display:grid; grid-template-columns:repeat(6,1fr); grid-auto-rows:88px; gap:18px; grid-auto-flow:dense; }
.stile{ position:relative; overflow:hidden; display:block; text-decoration:none; }
.stile img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; transition:transform 1.5s cubic-bezier(.2,.7,.2,1); }
.stile .ph{ position:absolute; inset:0; transition:transform 1.5s cubic-bezier(.2,.7,.2,1); }
.stile::after{ content:""; position:absolute; inset:0; z-index:2;
  background:linear-gradient(180deg, rgba(26,30,24,0) 38%, rgba(26,30,24,.62) 100%); opacity:.5; transition:opacity .6s; }
.stile:hover img,.stile:hover .ph{ transform:scale(1.05); }
.stile:hover::after{ opacity:.85; }
.stile-cap{ position:absolute; left:22px; bottom:20px; z-index:3; color:var(--bone); }
.stile-cap .cat{ display:block; font-family:var(--serif); font-size:27px; line-height:1; }
.stile-cap .go{ display:block; font-family:var(--sans); font-size:10.5px; letter-spacing:.2em; text-transform:uppercase;
  color:rgba(244,241,234,.85); margin-top:10px; opacity:0; transform:translateY(8px); transition:.5s; }
.stile:hover .stile-cap .go{ opacity:1; transform:none; }
.t-a{ grid-column:span 4; grid-row:span 6; }
.t-b{ grid-column:span 2; grid-row:span 3; }
.t-c{ grid-column:span 2; grid-row:span 3; }
.t-d{ grid-column:span 3; grid-row:span 4; }
.t-e{ grid-column:span 3; grid-row:span 4; }
.t-f{ grid-column:span 6; grid-row:span 3; }

.sc-index{ display:flex; flex-wrap:wrap; gap:8px 30px; margin-top:46px; padding-top:30px; border-top:1px solid var(--line); }
.sc-index a{ font-family:var(--sans); font-size:12px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--ink-soft); text-decoration:none; transition:color .3s; }
.sc-index a:hover{ color:var(--sage-deep); }
.sc-index a::after{ content:"→"; margin-left:.6em; color:var(--sage); opacity:0; transition:opacity .3s; }
.sc-index a:hover::after{ opacity:1; }

/* ============================================================
   PACKAGES
   ============================================================ */
.pkg{ padding:140px 0; }
.sec-head{ text-align:center; max-width:62ch; margin:0 auto 70px; }
.sec-head .eyebrow{ margin-bottom:22px; }
.sec-head h2{ font-family:var(--serif); font-weight:300; font-size:clamp(34px,4.2vw,58px); line-height:1.06; margin:0 0 20px; letter-spacing:-.01em; }
.sec-head h2 em{ font-style:italic; }
.sec-head p{ color:var(--ink-soft); font-size:15.5px; line-height:1.8; margin:0; }

.pkg-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:24px; }

/* per-event tabs */
.pkg-tabs{ display:flex; justify-content:center; flex-wrap:wrap; gap:0; width:fit-content; max-width:100%;
  margin:0 auto 18px; border:1px solid var(--line); }
.pkg-tab{ font-family:var(--sans); font-weight:500; font-size:12px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--ink-faint); background:transparent; border:none; border-right:1px solid var(--line);
  padding:15px 30px; cursor:pointer; transition:background .4s, color .4s; white-space:nowrap; }
.pkg-tab:last-child{ border-right:none; }
.pkg-tab:hover:not(.active){ color:var(--ink); }
.pkg-tab.active{ background:var(--sage-deep); color:var(--bone); }
.pkg-panel{ display:none; }
.pkg-panel.active{ display:block; }
.pkg-note{ text-align:center; font-family:var(--sans); font-size:12.5px; letter-spacing:.02em; font-style:italic;
  color:var(--sage); margin:0 auto 34px; max-width:54ch; }

/* 3-up package cards */
.pkg-grid.three{ grid-template-columns:repeat(3,1fr); }
.pkg-grid.three .pcard{ padding:40px 32px; }
.pkg-grid.three .pcard h4{ font-size:25px; }
.feat-tag{ font-family:var(--sans); font-size:9.5px; font-weight:600; letter-spacing:.26em; text-transform:uppercase;
  color:var(--sage); margin-bottom:14px; }
.pcard.feat{ border-top:2px solid var(--sage-deep); background:linear-gradient(180deg,#fbfaf6,#f3f1e8); }
.pcard .price .amt{ font-family:var(--serif); font-size:30px; color:var(--sage-deep); line-height:1; }

/* offer / payment banner */
.pkg-offer{ text-align:center; margin-top:46px; padding-top:38px; border-top:1px solid var(--line); }
.pkg-offer .so{ font-family:var(--serif); font-style:italic; font-size:23px; color:var(--sage-deep); }
.pkg-offer .pm{ font-family:var(--sans); font-size:12px; letter-spacing:.04em; color:var(--ink-faint); margin-top:12px; }

/* corporate / other quote form */
.quote-intro{ text-align:center; max-width:62ch; margin:0 auto 40px; color:var(--ink-soft); font-size:15.5px; line-height:1.8; }
.quote-form{ max-width:780px; margin:0 auto; background:var(--paper); border:1px solid var(--line); padding:48px 50px; }
.quote-form .hint{ font-family:var(--sans); font-size:11.5px; color:var(--ink-faint); line-height:1.6; margin:18px 0 0; }
.pcard{ background:var(--paper); border:1px solid var(--line); padding:46px 42px; display:flex; flex-direction:column; transition:.5s cubic-bezier(.2,.7,.2,1); }
.pcard:hover{ transform:translateY(-6px); box-shadow:var(--shadow-soft); border-color:var(--stone); }
.pcard .ptop{ display:flex; align-items:baseline; justify-content:space-between; gap:16px; padding-bottom:22px; border-bottom:1px solid var(--line); margin-bottom:26px; }
.pcard h4{ font-family:var(--serif); font-weight:400; font-size:27px; margin:0; letter-spacing:-.005em; }
.pcard .price{ text-align:right; white-space:nowrap; }
.pcard .price .pre{ display:block; font-family:var(--sans); font-size:9.5px; letter-spacing:.2em; text-transform:uppercase; color:var(--ink-faint); margin-bottom:5px; }
.pcard .price .amt{ font-family:var(--serif); font-size:30px; color:var(--sage-deep); line-height:1; }
.pcard ul{ list-style:none; margin:0 0 30px; padding:0; display:flex; flex-direction:column; gap:13px; }
.pcard li{ font-family:var(--sans); font-size:13.5px; color:var(--ink-soft); line-height:1.55; padding-left:22px; position:relative; }
.pcard li::before{ content:""; position:absolute; left:0; top:9px; width:7px; height:7px; border:1px solid var(--sage); transform:rotate(45deg); }
.pcard .pfoot{ margin-top:auto; }
.pcard .pnote{ font-family:var(--sans); font-size:11px; color:var(--ink-faint); line-height:1.6; margin:0 0 20px; font-style:italic; }

/* addons */
.addons{ margin-top:30px; background:var(--sand); border:1px solid var(--line); padding:46px 48px; }
.addons h4{ font-family:var(--serif); font-weight:400; font-size:24px; margin:0 0 8px; }
.addons .lead{ font-family:var(--sans); font-size:13.5px; color:var(--ink-soft); margin:0 0 30px; max-width:60ch; line-height:1.7; }
.addon-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line); border:1px solid var(--line); }
.addon{ background:var(--sand); padding:22px 20px; }
.addon .loc{ font-family:var(--sans); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-faint); margin-bottom:10px; }
.addon .fee{ font-family:var(--serif); font-size:22px; color:var(--sage-deep); }
.addon .x{ font-family:var(--sans); font-size:10.5px; color:var(--ink-faint); margin-top:6px; }

/* ============================================================
   CONTACT
   ============================================================ */
.contact{ background:var(--sage-deep); color:var(--bone); padding:140px 0; }
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:80px; }
.contact .eyebrow{ color:var(--sage-mist); margin-bottom:24px; }
.contact h2{ font-family:var(--serif); font-weight:300; font-size:clamp(36px,4.4vw,60px); line-height:1.04; margin:0 0 26px; color:var(--bone); }
.contact h2 em{ font-style:italic; }
.contact .lead{ color:rgba(244,241,234,.78); font-size:16px; line-height:1.8; max-width:42ch; margin:0 0 40px; }
.cinfo{ display:flex; flex-direction:column; gap:24px; margin-top:10px; }
.cinfo .row{ border-top:1px solid rgba(244,241,234,.18); padding-top:18px; }
.cinfo .k{ font-family:var(--sans); font-size:10px; letter-spacing:.24em; text-transform:uppercase; color:var(--sage-mist); margin-bottom:8px; }
.cinfo .v{ font-family:var(--serif); font-size:20px; color:var(--bone); }
.cinfo .v a{ color:var(--bone); text-decoration:none; }
.socials{ display:flex; gap:14px; margin-top:34px; }
.socials a{ font-family:var(--sans); font-size:11px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--bone); text-decoration:none; border:1px solid rgba(244,241,234,.4); padding:.85em 1.3em; transition:.4s; }
.socials a:hover{ background:var(--bone); color:var(--sage-deep); border-color:var(--bone); }

/* form */
.form{ background:var(--bone); padding:48px 46px; color:var(--ink); }
.form .fh{ font-family:var(--serif); font-size:24px; font-weight:400; margin:0 0 28px; }
.field{ margin-bottom:22px; }
.field label{ display:block; font-family:var(--sans); font-size:10.5px; letter-spacing:.18em; text-transform:uppercase; color:var(--ink-faint); margin-bottom:10px; }
.field input,.field select,.field textarea{ width:100%; font-family:var(--sans); font-size:15px; color:var(--ink);
  background:transparent; border:none; border-bottom:1px solid var(--stone); padding:10px 2px; outline:none; transition:border-color .3s; }
.field input:focus,.field select:focus,.field textarea:focus{ border-color:var(--sage-deep); }
.field textarea{ resize:vertical; min-height:80px; }
.field input::placeholder,.field textarea::placeholder{ color:var(--ink-faint); }
.two{ display:grid; grid-template-columns:1fr 1fr; gap:24px; }
.submit-row{ display:flex; flex-direction:column; gap:12px; margin-top:34px; }
.submit-row .btn-solid{ width:100%; justify-content:center; }
.btn-viber{ background:#7360f2; border-color:#7360f2; color:#fff; }
.btn-viber:hover{ background:transparent; color:#7360f2; }
.btn-msgr{ background:var(--sage-deep); border-color:var(--sage-deep); color:#fff; }
.btn-msgr:hover{ background:transparent; color:var(--sage-deep); }
.form .hint{ font-family:var(--sans); font-size:11.5px; color:var(--ink-faint); line-height:1.6; margin:18px 0 0; }
.toast{ position:fixed; bottom:28px; left:50%; transform:translateX(-50%) translateY(140%); z-index:90;
  background:var(--ink); color:var(--bone); font-family:var(--sans); font-size:13px; letter-spacing:.02em;
  padding:16px 26px; box-shadow:var(--shadow-soft); transition:transform .55s cubic-bezier(.2,.7,.2,1); }
.toast.show{ transform:translateX(-50%) translateY(0); }

/* ============================================================
   FOOTER
   ============================================================ */
.footer{ background:var(--ink); color:rgba(244,241,234,.7); padding:80px 0 40px; }
.foot-top{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:50px; align-items:start; padding-bottom:50px; border-bottom:1px solid rgba(244,241,234,.14); }
.footer .flogo{ height:54px; margin-bottom:24px; }
.footer .ftag{ font-family:var(--serif); font-style:italic; font-size:19px; color:rgba(244,241,234,.8); max-width:30ch; line-height:1.5; }
.fcol h5{ font-family:var(--sans); font-size:10px; letter-spacing:.24em; text-transform:uppercase; color:var(--sage-mist); margin:0 0 18px; }
.fcol a,.fcol p{ display:block; font-family:var(--sans); font-size:13.5px; color:rgba(244,241,234,.7); text-decoration:none; margin:0 0 11px; line-height:1.6; transition:color .3s; }
.fcol a:hover{ color:var(--bone); }
.foot-bot{ display:flex; justify-content:space-between; align-items:center; padding-top:30px; flex-wrap:wrap; gap:14px; }
.foot-bot span{ font-family:var(--sans); font-size:11px; letter-spacing:.05em; color:rgba(244,241,234,.5); }

/* mobile bottom bar (hidden on desktop) */
.mobar{ display:none; }

/* ============================================================
   RESPONSIVE — dedicated mobile layout
   ============================================================ */
@media (max-width:900px){
  .container{ padding:0 24px; }
  .nav{ padding:18px 22px; }
  .nav.solid{ padding:14px 22px; }
  .nav .logo{ height:34px; }
  .nav-links,.nav-cta{ display:none; }
  .burger{ display:flex; }

  /* full-screen drawer */
  .drawer{ display:flex; position:fixed; inset:0; z-index:55; background:var(--sage-deep);
    flex-direction:column; justify-content:center; padding:40px 30px;
    transform:translateY(-100%); transition:transform .6s cubic-bezier(.7,0,.2,1); }
  .drawer.open{ transform:none; }
  .drawer a{ font-family:var(--serif); font-weight:300; font-size:34px; color:var(--bone);
    text-decoration:none; padding:13px 0; border-bottom:1px solid rgba(244,241,234,.14); }
  .drawer a:last-of-type{ border-bottom:none; }
  .drawer .dctas{ display:flex; flex-direction:column; gap:12px; margin-top:30px; }
  .drawer .dctas a{ font-family:var(--sans); font-size:13px; letter-spacing:.16em; text-transform:uppercase;
    text-align:center; border:1px solid rgba(244,241,234,.4); padding:16px; border-bottom:1px solid rgba(244,241,234,.4); }

  .hero{ height:92vh; min-height:560px; }
  .hero .vleft,.hero .vright{ display:none; }
  .hero h1{ font-size:clamp(40px,12vw,60px); }
  .hero .sub{ font-size:14px; padding:0 6px; }
  .hero .acts{ flex-direction:column; width:100%; max-width:300px; }
  .hero .acts .btn-line{ width:100%; justify-content:center; }

  .story{ padding:80px 0; }
  .story-grid{ grid-template-columns:1fr; gap:36px; }
  .stats{ gap:30px; flex-wrap:wrap; }
  .stat .n{ font-size:38px; }

  .work{ padding:64px 0; }
  .work-inner,.work.flip .work-inner{ grid-template-columns:1fr; gap:34px; }
  .work.flip .rail{ order:0; }
  .rail{ position:static; }
  /* mobile galleries -> horizontal swipe carousel */
  .cluster{ display:flex; grid-auto-rows:auto; gap:14px; overflow-x:auto; scroll-snap-type:x mandatory;
    margin:0 -24px; padding:0 24px 14px; -webkit-overflow-scrolling:touch; }
  .cluster::-webkit-scrollbar{ display:none; }
  .cluster figure{ scroll-snap-align:start; flex:0 0 76%; }
  .cluster .ph{ height:420px !important; }
  .c-feature,.c-top,.c-bot{ grid-column:auto; grid-row:auto; }
  .cluster figure figcaption{ opacity:1; transform:none; }

  .showcase{ padding:64px 0; }
  .showcase .sc-head{ flex-direction:column; align-items:flex-start; gap:16px; margin-bottom:32px; }
  .collage{ grid-template-columns:repeat(2,1fr); grid-auto-rows:74px; gap:12px; }
  .t-a{ grid-column:span 2; grid-row:span 5; }
  .t-b{ grid-column:span 1; grid-row:span 4; }
  .t-c{ grid-column:span 1; grid-row:span 4; }
  .t-d{ grid-column:span 1; grid-row:span 4; }
  .t-e{ grid-column:span 1; grid-row:span 4; }
  .t-f{ grid-column:span 2; grid-row:span 4; }
  .stile-cap .cat{ font-size:21px; }
  .stile-cap .go{ opacity:1; transform:none; }
  .sc-index{ gap:6px 20px; }

  .pkg{ padding:80px 0; }
  .pkg-grid,.pkg-grid.three{ grid-template-columns:1fr; gap:16px; }
  .pcard,.pkg-grid.three .pcard{ padding:34px 28px; }
  .quote-form{ padding:32px 24px; }
  .pkg-tabs{ width:100%; overflow-x:auto; flex-wrap:nowrap; justify-content:flex-start; }
  .pkg-tab{ flex:0 0 auto; padding:14px 22px; }
  .addons{ padding:34px 26px; }
  .addon-grid{ grid-template-columns:repeat(2,1fr); }

  .contact{ padding:80px 0; }
  .contact-grid{ grid-template-columns:1fr; gap:50px; }
  .contact h2{ font-size:clamp(34px,10vw,46px); }
  .form{ padding:34px 26px; }
  .two{ grid-template-columns:1fr; gap:22px; }
  .submit-row{ flex-direction:column; }
  .submit-row .btn-solid,.submit-row .btn-line{ width:100%; justify-content:center; }

  .foot-top{ grid-template-columns:1fr; gap:40px; }
  .foot-bot{ flex-direction:column; align-items:flex-start; }

  /* sticky mobile inquire bar */
  .mobar{ display:flex; position:fixed; bottom:0; left:0; right:0; z-index:45;
    background:rgba(244,241,234,.95); backdrop-filter:blur(10px); border-top:1px solid var(--line);
    padding:12px 16px calc(12px + env(safe-area-inset-bottom)); gap:10px; }
  .mobar a{ flex:1; text-align:center; font-family:var(--sans); font-size:12px; letter-spacing:.14em;
    text-transform:uppercase; text-decoration:none; padding:15px; }
  .mobar .mb-inq{ background:var(--sage-deep); color:var(--bone); }
  .mobar .mb-viber{ background:#7360f2; color:#fff; }
  body{ padding-bottom:64px; }
}

@media (max-width:430px){
  .addon-grid{ grid-template-columns:1fr; }
  .badge-row{ gap:8px; }
}
