/* ── reset ─────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;text-size-adjust:100%}
body{
  font_family:"Inter",ui-sans-serif,system-ui,sans-serif;
  font-family:"Inter",ui-sans-serif,system-ui,sans-serif;
  background:var(--bg);color:var(--ink);
  font-weight:400;line-height:1.55;letter-spacing:.005em;
  font-feature-settings:"ss01","cv11";
  text-rendering:optimizeLegibility;
  overflow_x:hidden;overflow-x:hidden;
}
img,svg,video{display:block;max-width:100%;height:auto}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
::selection{background:var(--ink);color:var(--bg)}

/* ── tokens ────────────────────────────────────── */
:root{
  --bg:#f7f5f0;
  --bg_pure:#ffffff;
  --ink:#0a0a0a;
  --ink_soft:#1a1a1a;
  --mute:#6b6b6b;
  --mute_soft:#9a9a96;
  --line:rgba(10,10,10,.12);
  --line_soft:rgba(10,10,10,.06);
  --paper:#efece4;
  --serif:"Fraunces",ui-serif,Georgia,serif;
  --sans:"Inter",ui-sans-serif,system-ui,sans-serif;
  --pad:clamp(20px,4vw,56px);
  --maxw:1440px;
  --ease:cubic-bezier(.2,.7,.2,1);
  --ease_out:cubic-bezier(.16,1,.3,1);
}

/* ── typography ────────────────────────────────── */
.display{
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(48px,9.5vw,168px);
  line-height:.96;
  letter-spacing:-.02em;
  font-variation-settings:"opsz" 144;
}
.display em{font-style:italic;font-weight:300;font-variation-settings:"opsz" 144}
.display .line{display:block}
.display_sm{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(28px,4.4vw,64px);line-height:1.06;
  letter-spacing:-.015em;
}
.lede{
  font-family:var(--serif);font-weight:300;font-style:italic;
  font-size:clamp(18px,1.6vw,24px);line-height:1.45;color:var(--ink_soft);
  max-width:36ch;
}
.cap{
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--mute);font-weight:500;
}
.num{
  font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:14px;color:var(--mute);
}
.rule{
  display:inline_block;display:inline-block;width:32px;height:1px;background:var(--ink);
  vertical-align:middle;margin-right:14px;
}
.dot{margin:0 10px;color:var(--mute_soft)}

/* ── nav ───────────────────────────────────────── */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px var(--pad);
  transition:background .5s var(--ease),padding .35s var(--ease),border .35s var(--ease);
  border-bottom:1px solid transparent;
}
.nav.is_scrolled{
  background:rgba(247,245,240,.86);
  backdrop_filter:saturate(140%) blur(14px);
  backdrop-filter:saturate(140%) blur(14px);
  border-bottom:1px solid var(--line_soft);
  padding-top:12px;padding-bottom:12px;
}
.brand{display:flex;align-items:center;gap:12px}
.brand_mark{
  width:34px;height:34px;border:1px solid var(--ink);border-radius:999px;
  display:grid;place-items:center;
  font-family:var(--serif);font-style:italic;font-weight:300;font-size:18px;
}
.brand_word{
  font-family:var(--serif);font-weight:300;font-size:18px;line-height:1;
  letter-spacing:.01em;
}
.brand_word em{font-style:italic;color:var(--mute);font-size:12px;display:block;margin-top:3px;letter-spacing:.18em;text-transform:uppercase;font-weight:400}
.nav_links{display:flex;gap:34px;align-items:center}
.nav_links a{
  font-size:13px;color:var(--ink_soft);position:relative;padding:6px 0;
  transition:color .25s var(--ease);
}
.nav_links a::after{
  content:"";position:absolute;left:0;right:100%;bottom:0;height:1px;background:var(--ink);
  transition:right .4s var(--ease);
}
.nav_links a:hover{color:var(--ink)}
.nav_links a:hover::after,.nav_links a.is_active::after{right:0}
.nav_right{display:flex;align-items:center;gap:18px}
.lang{display:flex;align-items:center;gap:6px;font-size:12px;letter-spacing:.16em;text-transform:uppercase}
.lang_btn{color:var(--mute);padding:4px;letter-spacing:.16em;font-weight:500;transition:color .2s}
.lang_btn.is_active{color:var(--ink)}
.lang_sep{color:var(--mute_soft)}
.menu_toggle{display:none}

/* ── buttons ───────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 22px;border-radius:999px;
  font-size:13px;letter-spacing:.14em;text-transform:uppercase;font-weight:500;
  transition:transform .35s var(--ease),background .35s var(--ease),color .35s var(--ease);
}
.btn svg{width:18px;height:18px;transition:transform .35s var(--ease)}
.btn:hover svg{transform:translateX(4px)}
.btn_solid{background:var(--ink);color:var(--bg)}
.btn_solid:hover{background:#000}
.btn_ghost{border:1px solid var(--ink);color:var(--ink)}
.btn_ghost:hover{background:var(--ink);color:var(--bg)}
.btn_full{width:100%;justify-content:center;margin-top:14px}
.link_under{
  font-size:13px;letter-spacing:.12em;text-transform:uppercase;font-weight:500;
  position:relative;padding-bottom:4px;
}
.link_under::after{content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:currentColor;transform-origin:right;transition:transform .5s var(--ease)}
.link_under:hover::after{transform:scaleX(.4);transform-origin:left}

/* ── shared layout ─────────────────────────────── */
main{padding-top:80px}
.section{padding:clamp(80px,12vh,180px) var(--pad)}
.lock{max-width:var(--maxw);margin:0 auto}
.head{display:grid;grid-template-columns:1fr;gap:18px;max-width:1200px;margin:0 auto clamp(48px,7vh,96px)}
.head_row{display:flex;align-items:center;gap:14px}
.head_row .num{margin-right:6px}
.head_lede{font-family:var(--serif);font-weight:300;font-style:italic;font-size:clamp(17px,1.4vw,22px);color:var(--ink_soft);max-width:48ch}

/* ── hero ──────────────────────────────────────── */
.hero{
  position:relative;min-height:100vh;
  display:grid;grid-template-rows:1fr auto;
  padding:120px var(--pad) 56px;
  overflow:hidden;
}
.hero_media{position:absolute;inset:0;z-index:0;overflow:hidden}
.hero_img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 30%;
  transform:scale(1.05);
  animation:slow_zoom 18s var(--ease_out) forwards;
}
.hero_img_bw{filter:grayscale(1) contrast(1.04)}
.hero_color{
  position:absolute;inset:0;
  clip-path:inset(0 0 0 var(--reveal,50%));
  will-change:clip-path;
}
.hero_handle{
  position:absolute;top:0;bottom:0;left:var(--reveal,50%);
  width:60px;background:transparent;transform:translateX(-50%);
  z-index:5;cursor:ew-resize;border:0;padding:0;
  touch-action:none;
}
.hero_handle::before{
  content:"";position:absolute;left:50%;top:0;bottom:0;
  width:2px;background:var(--ink);transform:translateX(-50%);
  pointer-events:none;
}
.hero_handle::after{
  content:"";position:absolute;left:50%;top:50%;
  width:54px;height:54px;border-radius:999px;
  background:var(--ink);transform:translate(-50%,-50%);
  box-shadow:inset 0 0 0 4px var(--bg);
  pointer-events:none;
}
.hero_handle span{
  position:absolute;top:50%;left:50%;
  width:8px;height:8px;border:1.5px solid var(--bg);
  border-top:0;border-right:0;z-index:1;pointer-events:none;
}
.hero_handle span:first-child{transform:translate(-180%,-50%) rotate(45deg)}
.hero_handle span:last-child{transform:translate(80%,-50%) rotate(-135deg)}
@keyframes slow_zoom{to{transform:scale(1)}}
.hero_veil{
  position:absolute;inset:0;pointer-events:none;
  background:
    linear-gradient(180deg,rgba(247,245,240,.55) 0%,rgba(247,245,240,0) 25%,rgba(247,245,240,0) 60%,rgba(247,245,240,.92) 100%),
    linear-gradient(90deg,rgba(247,245,240,.6) 0%,rgba(247,245,240,0) 45%);
}
.hero_meta{
  position:relative;z-index:2;display:flex;align-items:center;
  font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink_soft);
  pointer-events:none;
}
.hero_meta > *{pointer-events:auto}
.hero_copy{position:relative;z-index:2;align-self:end;max-width:1180px;margin:0 auto;width:100%;pointer-events:none}
.hero_copy a,.hero_copy button{pointer-events:auto}
.hero_copy .display{margin-bottom:34px}
.hero_copy .lede{margin-bottom:42px}
.hero_cta{display:flex;align-items:center;gap:28px;flex-wrap:wrap}
.hero_index{
  position:absolute;right:var(--pad);bottom:56px;z-index:2;
  display:flex;flex-direction:column;align-items:flex-end;gap:6px;
}

/* hero alt (inner pages) */
.page_hero{
  position:relative;padding:140px var(--pad) 80px;
  background:var(--bg);
}
.page_hero .lock{display:grid;gap:32px}
.page_hero .crumbs{display:flex;align-items:center;gap:10px;color:var(--mute)}
.page_hero .display{margin-top:12px}
.page_hero .lede{margin-top:8px}

/* ── marquee ───────────────────────────────────── */
.marquee{
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  overflow:hidden;padding:22px 0;background:var(--bg);
}
.marquee_track{
  display:flex;gap:42px;white-space:nowrap;
  font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:clamp(22px,2.6vw,40px);color:var(--ink_soft);
  animation:marquee 38s linear infinite;
  width:max-content;
}
.marquee_track span{padding-right:0}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ── philosophy ────────────────────────────────── */
.intro{padding:clamp(80px,14vh,180px) var(--pad)}
.intro_lock{max-width:1180px;margin:0 auto;display:grid;grid-template-columns:160px 1fr;gap:48px;align-items:start}
.intro_lock .num{margin-top:18px}

/* ── work / before+after ───────────────────────── */
.work_grid{
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,96px) clamp(36px,4vw,72px);
  max-width:1300px;margin:0 auto;
}
.case{display:grid;gap:28px}
.case:nth_child(odd){transform:translateY(0)}
.case:nth-child(even){transform:translateY(60px)}
.case_meta{display:flex;justify-content:space-between;align-items:baseline}
.case_no{font-family:var(--serif);font-style:italic;color:var(--mute);font-size:14px}
.case_service{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--mute);font-weight:500}
.case_body h3{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(24px,2.4vw,36px);line-height:1.1;letter-spacing:-.01em;
}
.case_body p{margin-top:14px;color:var(--ink_soft);max-width:46ch}
.case_facts{
  display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:22px;
  border-top:1px solid var(--line);padding-top:18px;
}
.case_facts dt{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--mute);margin-bottom:6px}
.case_facts dd{font-family:var(--serif);font-weight:300;font-size:17px}

/* pair reveal */
.pair{
  display:grid;grid-template-columns:1fr 1fr;gap:14px;
}
.tile{
  position:relative;aspect-ratio:4/5;overflow:hidden;background:#000;
  border-radius:18px;margin:0;
}
.tile img{
  width:100%;height:100%;object-fit:cover;display:block;
  transform:scale(1.08);
  transition:transform 1.2s var(--ease_out);
}
.tile figcaption{
  position:absolute;left:18px;top:18px;
  font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:#fff;
  background:rgba(0,0,0,.55);padding:7px 12px;backdrop-filter:blur(8px);font-weight:500;
}
.reveal_tile{opacity:0;transform:translateY(60px);transition:opacity 1.1s var(--ease_out),transform 1.2s var(--ease_out)}
.reveal_tile[data-stagger="1"]{transition-delay:.22s}
.reveal_tile.is_in{opacity:1;transform:translateY(0)}
.reveal_tile.is_in img{transform:scale(1)}
.reveal_tile img{transition:transform 1.6s var(--ease_out)}
@media (max-width:720px){.pair{gap:10px}}

/* before+after slider (legacy, unused) */
.ba{
  position:relative;aspect-ratio:4/5;overflow:hidden;background:#000;
  user-select:none;-webkit-user-select:none;touch-action:none;
  cursor:ew-resize;
  border-radius:2px;
}
.ba_img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  filter:grayscale(.05) contrast(1.03);
  pointer-events:none;
}
.ba_clip{
  position:absolute;inset:0;width:50%;overflow:hidden;
  will-change:width;
}
.ba_clip .ba_img{width:calc(100%*(100/50));max-width:none}
.ba_handle{
  position:absolute;top:0;bottom:0;left:50%;width:0;z-index:3;
  pointer-events:none;will-change:left;
}
.ba_line{
  position:absolute;top:0;bottom:0;left:0;width:1px;background:rgba(255,255,255,.95);
  box-shadow:0 0 0 1px rgba(0,0,0,.12);transform:translateX(-.5px);
}
.ba_knob{
  position:absolute;top:50%;left:0;transform:translate(-50%,-50%);
  width:54px;height:54px;border-radius:999px;
  background:rgba(255,255,255,.96);
  display:grid;place-items:center;color:#0a0a0a;
  box-shadow:0 12px 40px rgba(0,0,0,.25);
}
.ba_knob svg{width:22px;height:22px}
.ba_tag{
  position:absolute;top:18px;font-size:10px;letter-spacing:.22em;text-transform:uppercase;
  background:rgba(0,0,0,.55);color:#fff;padding:7px 12px;border-radius:2px;
  backdrop-filter:blur(8px);z-index:2;font-weight:500;
}
.ba_tag_b{left:18px}
.ba_tag_a{right:18px}
.ba_input{position:absolute;inset:0;width:100%;height:100%;opacity:0;cursor:ew-resize;z-index:4}

/* ── services ──────────────────────────────────── */
.services_list{max-width:1200px;margin:0 auto;border-top:1px solid var(--line)}
.service{
  display:grid;grid-template-columns:80px 1fr 200px 140px;gap:32px;align-items:center;
  padding:38px 0;border-bottom:1px solid var(--line);
  transition:padding .5s var(--ease);
}
.service_book{justify-self:end;padding:12px 22px;font-size:11px}
.service:hover{padding-left:12px;padding-right:12px}
.service_no{font-family:var(--serif);font-style:italic;font-weight:300;font-size:32px;color:var(--mute)}
.service_body h3{font-family:var(--serif);font-weight:300;font-size:clamp(22px,2.4vw,36px);line-height:1.08;letter-spacing:-.01em}
.service_body p{margin-top:8px;color:var(--ink_soft);max-width:52ch}
.service_from{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--mute);text-align:right;padding-top:18px;display:flex;flex-direction:column;gap:6px;align-items:flex-end}
.service_price{font-family:var(--serif);font-style:italic;font-size:22px;letter-spacing:.01em;color:var(--ink);text-transform:none;font-weight:300}

/* ── delyana about ─────────────────────────────── */
.about{
  display:grid;grid-template-columns:.95fr 1fr;gap:clamp(40px,6vw,96px);
  max-width:1300px;margin:0 auto;align-items:start;padding:0 var(--pad);
}
.about_media{position:relative}
.about_media img{
  width:100%;aspect-ratio:4/5;object-fit:cover;
  border-radius:22px;
}
.about_caption{
  display:block;margin-top:14px;font-size:11px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--mute);
}
.about_copy{padding-top:24px}
.about_copy .display{margin:18px 0 28px}
.about_copy p{margin-bottom:18px;color:var(--ink_soft);max-width:48ch}
.pull{
  font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:clamp(22px,2.4vw,34px);line-height:1.25;letter-spacing:-.01em;
  margin:32px 0;padding-left:24px;border-left:1px solid var(--ink);
}

/* ── studio ────────────────────────────────────── */
.studio{
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,96px);
  max-width:1300px;margin:0 auto;padding:0 var(--pad);align-items:center;
}
.studio_copy h2{margin:18px 0 24px}
.studio_copy p{color:var(--ink_soft);max-width:48ch}
.studio_media{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:240px 240px;gap:14px}
.studio_media figure{border-radius:18px;overflow:hidden;margin:0}
.studio_media img{width:100%;height:100%;object-fit:cover;filter:grayscale(1)}
.studio_a{grid-row:1/3}
.studio_a img{height:100%}
.studio_b{grid-column:2;grid-row:1}
.studio_c{grid-column:2;grid-row:2}

/* ── voices ────────────────────────────────────── */
.voices_grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:clamp(32px,4vw,72px);max-width:1300px;margin:0 auto;
}
.voice p{
  font-family:var(--serif);font-weight:300;font-style:italic;
  font-size:clamp(20px,1.7vw,26px);line-height:1.35;letter-spacing:-.005em;
  color:var(--ink);
}
.voice footer{margin-top:20px;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--mute)}
.voice footer em{font-style:normal;color:var(--mute_soft)}

/* reviews page list */
.review_long{max-width:880px;margin:0 auto;display:grid;gap:64px}
.review_long .voice p{font-size:clamp(22px,2vw,30px)}
.review_long .voice{padding:36px 0;border-bottom:1px solid var(--line)}
.review_long .voice:last_child{border:0}

/* ── book ──────────────────────────────────────── */
.book{
  display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(40px,6vw,96px);
  max-width:1300px;margin:0 auto;padding:0 var(--pad);align-items:start;
}
.book_hero h2{margin:18px 0 22px}
.book_hero p{color:var(--ink_soft);max-width:42ch;margin-bottom:42px}
.book_meta{display:grid;gap:14px}
.book_meta li{display:flex;justify-content:space-between;border-bottom:1px solid var(--line);padding-bottom:10px;font-size:13px}
.book_meta li span{color:var(--mute);text-transform:uppercase;letter-spacing:.18em;font-size:11px}
.book_meta li em{font-style:normal;font-family:var(--serif);font-weight:300;font-size:16px}

.book_widget{position:relative}
.book_frame{
  background:var(--bg_pure);
  border:1px solid var(--line);
  padding:36px;border-radius:4px;
}
.book_frame .cap{display:block;margin-bottom:6px}
.book_frame h3{font-family:var(--serif);font-weight:300;font-size:26px;margin-bottom:24px}

.cal_head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.cal_head span{font-family:var(--serif);font-style:italic;font-size:18px}
.cal_nav button{width:32px;height:32px;border:1px solid var(--line);border-radius:999px;font-size:16px;color:var(--ink_soft);transition:all .25s var(--ease)}
.cal_nav button:hover{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.cal_grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}
.cal_d{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--mute);text-align:center;padding:8px 0}
.cal_c{
  aspect-ratio:1;display:grid;place-items:center;
  font-family:var(--serif);font-weight:300;font-size:14px;
  border-radius:999px;transition:all .25s var(--ease);cursor:pointer;
}
.cal_c:hover{background:var(--paper)}
.cal_c.is_sel{background:var(--ink);color:var(--bg);font-weight:400}
.cal_c.is_out{color:var(--mute_soft)}
.slots{display:flex;gap:8px;flex-wrap:wrap;margin:22px 0 6px}
.slot{
  padding:10px 16px;border:1px solid var(--line);border-radius:999px;
  font-family:var(--serif);font-weight:300;font-size:14px;
  transition:all .25s var(--ease);
}
.slot:hover{border-color:var(--ink)}
.slot.is_sel{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.book_note{margin-top:18px;text-align:center;color:var(--mute);font-size:11px;letter-spacing:.18em;text-transform:uppercase}

/* contact */
.contact_grid{
  display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(40px,5vw,80px);
  max-width:1200px;margin:0 auto;padding:0 var(--pad);
}
.contact_form{display:grid;gap:18px}
.field{display:grid;gap:6px}
.field label{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--mute)}
.field input,.field textarea,.field select{
  font:inherit;background:transparent;border:0;border-bottom:1px solid var(--line);
  padding:10px 0;font-size:16px;color:var(--ink);
  transition:border .3s var(--ease);
}
.field input:focus,.field textarea:focus,.field select:focus{outline:0;border-bottom-color:var(--ink)}
.field textarea{min-height:120px;resize:vertical}
.contact_aside p{color:var(--ink_soft);max-width:36ch;margin-bottom:24px}
.contact_aside .group{margin-bottom:24px}
.contact_aside .group span{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--mute);display:block;margin-bottom:6px}
.contact_aside .group p{font-family:var(--serif);font-weight:300;font-size:18px;margin:0}

/* ── work page grid (more cases) ───────────────── */
.work_page{
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,96px) clamp(36px,4vw,72px);
  max-width:1300px;margin:0 auto;padding:0 var(--pad);
}

/* ── footer ────────────────────────────────────── */
.foot{padding:96px var(--pad) 36px;border-top:1px solid var(--line);background:var(--bg)}
.foot_lock{max-width:var(--maxw);margin:0 auto}
.foot_brand{display:flex;align-items:center;gap:18px;margin-bottom:64px}
.brand_mark_lg{width:56px;height:56px;font-size:28px}
.foot_title{font-family:var(--serif);font-weight:300;font-size:32px;letter-spacing:.005em}
.foot_title em{color:var(--mute);font-size:18px;display:block;letter-spacing:.18em;text-transform:uppercase;margin-top:4px}
.foot_cols{display:grid;grid-template-columns:repeat(4,1fr);gap:48px;border-top:1px solid var(--line);padding-top:48px}
.foot_cols .cap{display:block;margin-bottom:14px}
.foot_cols p{font-size:14px;line-height:1.7;color:var(--ink_soft)}
.foot_base{display:flex;justify-content:space-between;margin-top:80px;padding-top:24px;border-top:1px solid var(--line_soft);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--mute)}

/* ── reveal ────────────────────────────────────── */
.reveal{opacity:0;transform:translateY(36px);transition:opacity 1s var(--ease_out),transform 1.1s var(--ease_out)}
.reveal.is_in{opacity:1;transform:none}
.reveal_d1{transition-delay:.08s}
.reveal_d2{transition-delay:.16s}
.reveal_d3{transition-delay:.24s}

/* line draw */
.draw_in{position:relative;overflow:hidden;display:inline-block}
.draw_in::after{content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:var(--ink);transform:scaleX(0);transform-origin:left;transition:transform .9s var(--ease_out) .2s}
.is_in .draw_in::after{transform:scaleX(1)}

/* ── responsive ────────────────────────────────── */
@media (max-width:1024px){
  .nav_links{display:none}
  .menu_toggle{display:grid;place-items:center;width:40px;height:40px;border:1px solid var(--ink);border-radius:999px}
  .work_grid,.work_page{grid-template-columns:1fr;gap:64px}
  .case:nth-child(even){transform:none}
  .about,.studio,.book,.contact_grid{grid-template-columns:1fr;gap:48px}
  .voices_grid{grid-template-columns:1fr}
  .foot_cols{grid-template-columns:1fr 1fr;gap:36px}
  .service{grid-template-columns:48px 1fr;gap:18px}
  .service_from{grid-column:2;text-align:left;padding-top:8px;align-items:flex-start}
  .service_book{grid-column:2;justify-self:start}
  .intro_lock{grid-template-columns:1fr;gap:18px}
  .studio_media{grid-template-rows:200px 200px}
}
@media (max-width:640px){
  .hero{padding:120px 20px 40px}
  .hero_index{right:20px;bottom:24px}
  .marquee_track{font-size:22px;gap:28px}
  .ba_knob{width:46px;height:46px}
  .foot_cols{grid-template-columns:1fr}
  .foot_base{flex-direction:column;gap:10px}
  .case_facts{grid-template-columns:1fr 1fr}
  .studio_media{grid-template-columns:1fr;grid-template-rows:repeat(3,200px)}
  .studio_a{grid-row:auto}.studio_b,.studio_c{grid-column:1}
}

/* ── mobile menu sheet ─────────────────────────── */
.sheet{
  position:fixed;inset:0;z-index:60;background:var(--bg);
  display:flex;flex-direction:column;padding:24px var(--pad);
  transform:translateY(-100%);transition:transform .6s var(--ease);
  pointer-events:none;
}
.sheet.is_open{transform:none;pointer-events:auto}
.sheet_head{display:flex;justify-content:space-between;align-items:center}
.sheet_links{margin-top:64px;display:grid;gap:18px}
.sheet_links a{
  font-family:var(--serif);font-weight:300;font-size:44px;line-height:1.05;letter-spacing:-.01em;
}
.sheet_links a em{font-style:italic}
.sheet_foot{margin-top:auto;display:flex;justify-content:space-between;align-items:center;padding-top:36px;border-top:1px solid var(--line)}

/* tiny utility */
.cap_dim{color:var(--mute)}
.hr{height:1px;background:var(--line);margin:48px 0;border:0}

/* ── Clicka mount ──────────────────────────────── */
/* #clicka_booking is now a global portal host — the SDK renders its own modal */
#clicka_booking{ all: unset; }
.clicka_booking_notice{
  position:fixed;left:50%;bottom:24px;transform:translateX(-50%);
  background:var(--ink);color:var(--bg_pure);
  padding:12px 18px;border-radius:999px;font-size:13px;letter-spacing:.02em;
  z-index:2147483001;box-shadow:0 8px 30px rgba(0,0,0,.18);
}
.clicka_pending{display:grid;gap:18px;justify-items:start}
.clicka_pending_t{
  font-family:var(--serif);font-weight:300;font-size:clamp(22px,2vw,28px);line-height:1.15;
  letter-spacing:-.01em;color:var(--ink);max-width:24ch;
}
.clicka_pulse{
  position:relative;width:100%;height:6px;border-radius:99px;background:var(--paper);overflow:hidden;
}
.clicka_pulse::after{
  content:"";position:absolute;inset:0;width:30%;background:var(--ink);border-radius:99px;
  animation:clicka_run 1.6s var(--ease) infinite;
}
@keyframes clicka_run{
  0%{transform:translateX(-100%)}
  100%{transform:translateX(380%)}
}
