/* ==========================================================
   ЗЕРНО.lab — Specialty Coffee Roastery
   Lab / data-driven aesthetic — JetBrains Mono + Space Grotesk + Instrument Serif italic
   Deep roast brown #231916, cream #F2EDE3, ember orange #E76A2C
   ========================================================== */

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

:root{
  --bg:#F2EDE3;
  --bg-2:#E6DFCE;
  --paper:#FAF6EC;
  --ink:#231916;
  --ink-2:#3A2D27;
  --ink-3:#6B5A50;
  --ink-4:#9F8B7C;
  --ember:#E76A2C;
  --ember-d:#B14A14;
  --olive:#5F6F3A;
  --line:rgba(35,25,22,.16);
  --line-s:rgba(35,25,22,.32);

  --f-m:"JetBrains Mono",ui-monospace,monospace;
  --f-s:"Space Grotesk",system-ui,sans-serif;
  --f-d:"Instrument Serif","Times New Roman",serif;

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

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

body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--f-s);
  font-size:15px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}

img,svg,video,iframe{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;background:none;border:0;padding:0;color:inherit;cursor:pointer}
ul,ol{margin:0;padding:0;list-style:none}
h1,h2,h3,h4,p,dl,dt,dd,figure,blockquote,fieldset,legend{margin:0;padding:0;border:0}
address{font-style:normal}
table{border-collapse:collapse;width:100%}

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

[data-split]{display:block}
[data-split] > .w{
  display:inline-block;
  transform:translateY(80%);
  opacity:0;
  transition:transform 1s var(--ease-out),opacity .9s var(--ease-out);
  transition-delay:calc(var(--wi,0)*.05s);
}
[data-split].is-in > .w{transform:translateY(0);opacity:1}

body.no-js [data-split]{opacity:1}
body.no-js [data-split] > .w{opacity:1;transform:none}

/* ============ TOP TICKER ============ */
.topline{
  background:var(--ink);
  color:var(--paper);
  overflow:hidden;
  font-family:var(--f-m);
  font-size:11px;
  letter-spacing:.04em;
  padding:7px 0;
  text-transform:uppercase;
  position:relative;
  z-index:2;
}
.topline-track{
  display:flex;gap:48px;
  white-space:nowrap;
  animation:tlSlide 60s linear infinite;
  will-change:transform;
}
.topline-track span{display:inline-block}
@keyframes tlSlide{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ============ HEADER ============ */
.hdr{
  background:var(--bg);
  border-bottom:1px solid var(--line);
  position:sticky;top:0;z-index:30;
  padding:14px var(--pad-x);
  display:flex;align-items:center;gap:24px;
  justify-content:space-between;
}
.hd-logo{display:inline-flex;align-items:center;gap:10px;color:var(--ink)}
.hl-bean{color:var(--ember)}
.hl-w{
  font-family:var(--f-s);font-size:22px;font-weight:700;
  letter-spacing:-.025em;
}
.hl-w i{
  font-family:var(--f-m);font-style:normal;font-size:13px;font-weight:500;
  color:var(--ember);letter-spacing:.02em;
  margin-left:2px;
}
.hd-nav{
  display:flex;gap:22px;
  font-family:var(--f-m);font-size:13px;font-weight:500;
  color:var(--ink-2);
}
.hd-nav a{position:relative;padding:4px 0;transition:color .25s var(--ease)}
.hd-nav a:hover{color:var(--ember)}
.hd-nav a::after{
  content:"";position:absolute;left:0;right:100%;bottom:0;height:1px;background:var(--ember);
  transition:right .25s var(--ease);
}
.hd-nav a:hover::after{right:0}

.hd-right{display:flex;align-items:center;gap:14px}
.hd-stat{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--f-m);font-size:11px;letter-spacing:.04em;color:var(--ink-3);
  padding:6px 10px;
  border:1px solid var(--line);
  text-transform:uppercase;
}
.hd-stat .dot{
  width:6px;height:6px;border-radius:50%;background:var(--olive);
  box-shadow:0 0 0 0 rgba(95,111,58,.6);
  animation:pulse 2.2s ease-in-out infinite;
}
.hd-stat em{font-style:normal;color:var(--olive);font-weight:600}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(95,111,58,.7)}50%{box-shadow:0 0 0 6px rgba(95,111,58,0)}}

.hd-menu{
  display:none;
  width:42px;height:42px;
  border:1px solid var(--line-s);
  align-items:center;justify-content:center;color:var(--ink);
  transition:background .25s var(--ease),color .25s var(--ease);
}
.hd-menu:hover{background:var(--ink);color:var(--paper)}

/* ============ DRAWER ============ */
.drawer{
  position:fixed;inset:0;z-index:80;
  background:var(--ink);
  color:var(--paper);
  padding:24px var(--pad-x);
  display:flex;flex-direction:column;gap:24px;
  opacity:0;pointer-events:none;
  clip-path:circle(0% at calc(100% - 40px) 30px);
  transition:clip-path .55s var(--ease-out),opacity .3s var(--ease);
}
body.dr-open .drawer{opacity:1;pointer-events:auto;clip-path:circle(150% at calc(100% - 40px) 30px)}
.dr-x{
  align-self:flex-end;width:42px;height:42px;
  border:1px solid rgba(242,237,227,.3);color:var(--paper);
  display:inline-flex;align-items:center;justify-content:center;
}
.dr-nav{display:flex;flex-direction:column;gap:0;flex:1}
.dr-nav a{
  display:grid;grid-template-columns:50px 1fr;align-items:baseline;
  padding:18px 0;
  border-bottom:1px solid rgba(242,237,227,.12);
  opacity:0;transform:translateX(-20px);
  transition:opacity .5s var(--ease) calc(var(--i,0)*.05s + .2s),transform .55s var(--ease) calc(var(--i,0)*.05s + .2s);
}
body.dr-open .dr-nav a{opacity:1;transform:none}
.dr-nav b{
  font-family:var(--f-m);font-size:13px;font-weight:500;color:var(--ember);
  letter-spacing:.04em;
}
.dr-nav span{
  font-family:var(--f-m);font-size:14px;color:var(--paper);
  display:inline-block;letter-spacing:.02em;
}
.dr-nav em{
  display:block;
  font-family:var(--f-d);font-style:italic;font-size:22px;color:rgba(242,237,227,.72);
  margin-top:2px;letter-spacing:-.01em;
}
.dr-base{
  display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;
  padding-top:14px;border-top:1px solid rgba(242,237,227,.12);
  font-family:var(--f-m);font-size:11px;letter-spacing:.04em;color:rgba(242,237,227,.55);
}
.dr-base a{color:var(--ember)}

/* ============ HERO ============ */
.hero{
  padding:clamp(40px,6vw,72px) var(--pad-x) clamp(40px,5vw,72px);
  max-width:1500px;margin:0 auto;
}
.hero-grid{
  display:grid;
  grid-template-columns:1.2fr 1fr;
  gap:clamp(28px,4vw,80px);
  align-items:start;
}
.hero-tag{
  display:flex;gap:12px;align-items:center;flex-wrap:wrap;
  font-family:var(--f-m);font-size:12px;letter-spacing:.04em;
  margin-bottom:24px;
}
.ht-no{
  padding:5px 10px;
  background:var(--ember);color:var(--paper);
  font-weight:600;letter-spacing:.06em;
}
.ht-spec{
  padding:5px 10px;
  border:1px solid var(--line-s);color:var(--ink-3);
  text-transform:uppercase;
}

.hero-h{
  font-family:var(--f-s);
  font-size:clamp(48px,7.6vw,128px);
  font-weight:700;
  line-height:.96;
  letter-spacing:-.04em;
  color:var(--ink);
}
.hero-h span{display:block}
.hero-h em{
  font-family:var(--f-d);font-style:italic;color:var(--ember);font-weight:400;
  letter-spacing:-.02em;
}
.hero-p{
  font-family:var(--f-s);font-size:17px;line-height:1.55;color:var(--ink-2);
  max-width:54ch;margin-top:28px;
}

.hero-cta{display:flex;gap:12px;flex-wrap:wrap;margin-top:28px}
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:13px 20px;
  font-family:var(--f-m);font-size:13px;font-weight:500;letter-spacing:.04em;
  cursor:pointer;
  text-transform:uppercase;
  transition:background .25s var(--ease),color .25s var(--ease),transform .2s var(--ease),border-color .25s var(--ease);
  border:1px solid transparent;
}
.btn-fill{background:var(--ink);color:var(--paper)}
.btn-fill:hover{background:var(--ember);transform:translateY(-1px)}
.btn-line{background:transparent;color:var(--ink);border-color:var(--line-s)}
.btn-line:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}

/* ----- HERO PANEL (data spec) ----- */
.hero-panel{
  background:var(--paper);
  border:1px solid var(--line);
  padding:0;
  font-family:var(--f-m);
  position:relative;
  overflow:hidden;
}
.hero-panel::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--ember);
}
.hp-head{
  display:flex;justify-content:space-between;
  padding:14px 18px;
  font-size:11px;letter-spacing:.06em;text-transform:uppercase;
  color:var(--ember);font-weight:600;
  border-bottom:1px solid var(--line);
  background:var(--bg-2);
}
.hp-rows{padding:8px 18px}
.hp-row{
  display:grid;grid-template-columns:120px 1fr;
  align-items:baseline;gap:12px;
  padding:7px 0;
  font-size:13px;
  border-bottom:1px dashed var(--line);
}
.hp-row:last-child{border-bottom:0}
.hp-row span{
  font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-4);
}
.hp-row b{color:var(--ink);font-weight:500;letter-spacing:.01em}
.hp-row b.dim{color:var(--ember)}

.hp-chart{padding:14px 18px;border-top:1px solid var(--line);color:var(--ink-3)}
.hp-chart svg{width:100%;height:80px;display:block;margin-bottom:8px}
.hp-curve{stroke-dasharray:300;stroke-dashoffset:300;animation:drawCurve 1.6s var(--ease-out) .3s forwards}
@keyframes drawCurve{to{stroke-dashoffset:0}}
.hp-pt{opacity:0;animation:fadeIn .4s var(--ease) 1.5s forwards}
@keyframes fadeIn{to{opacity:1}}
.hp-axes{display:flex;justify-content:space-between;font-size:10px;color:var(--ink-4);letter-spacing:.04em;text-transform:uppercase}

.hp-foot{
  padding:12px 18px;
  border-top:1px solid var(--line);
  background:var(--bg-2);
  display:flex;align-items:center;gap:12px;
}
.hp-foot span{font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-4)}
.hp-foot em{
  font-family:var(--f-d);font-size:18px;font-style:italic;color:var(--ember);
  letter-spacing:-.01em;
}

/* ----- HERO STRIP ----- */
.hero-strip{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:8px;
  margin-top:48px;
  padding-top:28px;
  border-top:1px solid var(--line-s);
}
.hero-strip div{
  display:flex;flex-direction:column;gap:6px;
  padding:0 8px;
  border-left:1px solid var(--line);
}
.hero-strip div:first-child{border-left:0;padding-left:0}
.hero-strip span{
  font-family:var(--f-s);font-size:clamp(40px,5vw,68px);font-weight:700;
  line-height:1;letter-spacing:-.03em;
  color:var(--ink);
}
.hero-strip em{
  font-family:var(--f-m);font-size:11px;letter-spacing:.04em;text-transform:uppercase;
  color:var(--ink-3);font-style:normal;
}

/* ============ BEANS TABLE ============ */
.beans{
  padding:var(--sec-y) 0;
  max-width:1500px;margin:0 auto;
}
.rubric{
  font-family:var(--f-m);font-size:12px;letter-spacing:.06em;text-transform:uppercase;
  color:var(--ember);font-weight:500;
}
.sec-head,.b-head{
  display:flex;flex-direction:column;gap:16px;
  padding:0 var(--pad-x) clamp(36px,5vw,72px);
  max-width:1500px;margin:0 auto;
}
.sec-h{
  font-family:var(--f-s);
  font-size:clamp(36px,5.4vw,84px);
  font-weight:700;
  line-height:.98;
  letter-spacing:-.035em;
  color:var(--ink);
  max-width:18ch;
}
.sec-h em{
  font-family:var(--f-d);font-style:italic;font-weight:400;
  color:var(--ember);letter-spacing:-.01em;
}
.sec-p{
  font-family:var(--f-s);font-size:16px;line-height:1.55;color:var(--ink-2);
  max-width:60ch;
}

.b-tbl{
  font-family:var(--f-m);
  margin:0 var(--pad-x);
  width:calc(100% - 2*var(--pad-x));
  border-top:2px solid var(--ink);
  border-bottom:2px solid var(--ink);
}
.b-tbl thead th{
  text-align:left;
  font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-4);
  font-weight:500;
  padding:12px 8px;
  border-bottom:1px solid var(--ink);
}
.b-tbl tbody td{
  padding:16px 8px;
  border-bottom:1px solid var(--line);
  vertical-align:top;
  font-size:13px;
}
.b-tbl tbody tr:last-child td{border-bottom:0}
.b-tbl tbody tr:hover{background:var(--paper)}
.b-tbl td:nth-child(1){color:var(--ember);font-weight:600;letter-spacing:.02em;width:50px}
.b-tbl td:nth-child(2) b{
  font-family:var(--f-s);font-size:16px;color:var(--ink);font-weight:600;
  letter-spacing:-.01em;display:block;
}
.b-tbl td:nth-child(2) em{
  font-style:italic;color:var(--ink-3);font-family:var(--f-d);font-size:15px;
}
.b-tbl td:nth-child(3),.b-tbl td:nth-child(4){color:var(--olive);letter-spacing:.02em}
.b-tbl td:nth-child(5){font-family:var(--f-d);font-style:italic;font-size:16px;color:var(--ink-2);letter-spacing:-.005em}
.b-tbl td:nth-child(6) b{color:var(--ember);font-weight:600;font-size:14px}
.b-tbl td:nth-child(7){font-weight:600;color:var(--ink)}
.b-tbl td:nth-child(8) a{
  color:var(--ember);font-weight:500;letter-spacing:.02em;
  border-bottom:1px solid currentColor;padding-bottom:1px;
  transition:color .25s var(--ease);
}
.b-tbl td:nth-child(8) a:hover{color:var(--ember-d)}

.b-foot{
  max-width:60ch;
  margin:24px var(--pad-x) 0;
  font-family:var(--f-d);font-size:17px;font-style:italic;line-height:1.55;color:var(--ink-3);
}

/* ============ BREW METHODS ============ */
.brew{
  padding:var(--sec-y) 0;
  background:var(--paper);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.brew-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:1px;
  max-width:1500px;margin:0 auto;
  padding:0 var(--pad-x);
  background:var(--line);
  border:1px solid var(--line);
}
.bm{
  padding:28px 24px;
  background:var(--paper);
  display:flex;flex-direction:column;gap:14px;
  transition:background .3s var(--ease);
}
.bm:hover{background:var(--bg)}
.bm-head{display:flex;flex-direction:column;gap:6px}
.bm-id{
  font-family:var(--f-m);font-size:11px;letter-spacing:.06em;text-transform:uppercase;
  color:var(--ember);font-weight:600;
}
.bm-head h3{
  font-family:var(--f-s);font-size:28px;font-weight:700;
  line-height:1;letter-spacing:-.03em;color:var(--ink);
}
.bm-head h3 em{
  font-family:var(--f-d);font-style:italic;font-weight:400;color:var(--ember);
}
.bm-desc{
  font-family:var(--f-s);font-size:14.5px;color:var(--ink-2);line-height:1.55;
}
.bm-spec{
  display:flex;flex-direction:column;gap:0;
  padding-top:14px;border-top:1px solid var(--line);margin-top:6px;
  font-family:var(--f-m);font-size:13px;
}
.bm-spec div{
  display:grid;grid-template-columns:90px 1fr;
  padding:6px 0;
  border-bottom:1px dashed var(--line);
}
.bm-spec div:last-child{border-bottom:0}
.bm-spec dt{font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-4)}
.bm-spec dd{color:var(--ink);text-align:right;font-weight:500}

/* ============ CALCULATOR ============ */
.calc{padding:var(--sec-y) 0;max-width:1500px;margin:0 auto}
.calc-panel{
  display:grid;
  grid-template-columns:1fr 1.5fr;
  gap:0;
  margin:0 var(--pad-x);
  background:var(--paper);
  border:1px solid var(--ink);
}
.cp-controls{
  padding:32px;
  border-right:1px solid var(--ink);
  background:var(--bg-2);
}
.cp-radio{display:flex;flex-direction:column;gap:8px;margin-bottom:32px}
.cp-radio legend{
  font-family:var(--f-m);font-size:11px;letter-spacing:.06em;text-transform:uppercase;
  color:var(--ember);font-weight:600;margin-bottom:12px;
}
.cp-radio label{
  display:flex;align-items:center;gap:10px;
  padding:12px 14px;
  border:1px solid var(--line-s);background:var(--paper);
  font-family:var(--f-m);font-size:13px;
  cursor:pointer;
  transition:border-color .25s var(--ease),background .25s var(--ease);
}
.cp-radio label:hover{border-color:var(--ember)}
.cp-radio input{
  appearance:none;width:14px;height:14px;border-radius:50%;
  border:1px solid var(--line-s);flex:none;
  transition:background .2s,border-color .2s;
}
.cp-radio input:checked{background:var(--ember);border-color:var(--ember);box-shadow:inset 0 0 0 3px var(--paper)}
.cp-radio label:has(input:checked){border-color:var(--ember);background:rgba(231,106,44,.06)}

.cp-slider{display:flex;flex-direction:column;gap:10px}
.cp-slider label{
  display:flex;justify-content:space-between;align-items:baseline;
  font-family:var(--f-m);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);
}
.cp-slider label span{color:var(--ink);font-size:13px;font-weight:600;letter-spacing:0;text-transform:none}
.cp-slider label b{font-size:18px;color:var(--ember);letter-spacing:-.02em}

.cp-slider input[type=range]{
  appearance:none;width:100%;height:4px;
  background:linear-gradient(to right,var(--ember) 0%,var(--ember) 30%,var(--line-s) 30%,var(--line-s) 100%);
  outline:none;
  border-radius:2px;
}
.cp-slider input[type=range]::-webkit-slider-thumb{
  appearance:none;
  width:18px;height:18px;border-radius:50%;
  background:var(--ink);
  border:2px solid var(--paper);
  box-shadow:0 0 0 1px var(--ink);
  cursor:pointer;
  transition:transform .15s var(--ease);
}
.cp-slider input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.15)}
.cp-slider input[type=range]::-moz-range-thumb{
  width:18px;height:18px;border-radius:50%;
  background:var(--ink);border:2px solid var(--paper);
}
.cp-axis{
  display:flex;justify-content:space-between;
  font-family:var(--f-m);font-size:10px;letter-spacing:.04em;color:var(--ink-4);
  margin-top:4px;
}

.cp-output{
  padding:32px;
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:14px;
}
.co-card{
  padding:18px 16px;
  border:1px solid var(--line);
  background:var(--paper);
  display:flex;flex-direction:column;gap:4px;
}
.co-l{
  font-family:var(--f-m);font-size:11px;letter-spacing:.06em;text-transform:uppercase;
  color:var(--ink-4);
}
.co-v{
  font-family:var(--f-s);font-size:42px;font-weight:700;line-height:1;
  letter-spacing:-.03em;color:var(--ember);
}
.co-v--w{font-size:24px}
.co-card em{
  font-family:var(--f-m);font-size:11px;letter-spacing:.04em;color:var(--ink-3);
  font-style:normal;text-transform:lowercase;
}
.co-card--wide{
  grid-column:1 / -1;
  background:var(--bg-2);
}
.co-steps{
  font-family:var(--f-m);font-size:13px;
  display:flex;flex-direction:column;gap:6px;
  margin-top:8px;
}
.co-steps li{
  padding:6px 0;
  color:var(--ink-2);
  border-bottom:1px dashed var(--line);
}
.co-steps li:last-child{border-bottom:0}

/* ============ ROOM GALLERY ============ */
.room{padding:var(--sec-y) 0;max-width:1500px;margin:0 auto}
.room-head{padding-bottom:clamp(28px,4vw,56px)}
.room-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  grid-auto-rows:200px;
  gap:14px;
  padding:0 var(--pad-x);
}
.rg-card{
  margin:0;position:relative;overflow:hidden;
  border:1px solid var(--line);
}
.rg-card img{
  width:100%;height:100%;object-fit:cover;
  filter:saturate(.95) contrast(1.04);
  transition:transform 1.2s var(--ease),filter .4s var(--ease);
}
.rg-card:hover img{transform:scale(1.04);filter:saturate(1) brightness(1.02)}
.rg-card figcaption{
  position:absolute;left:10px;bottom:10px;
  padding:5px 9px;
  background:var(--ink);color:var(--paper);
  font-family:var(--f-m);font-size:10px;letter-spacing:.04em;text-transform:uppercase;
}
.rg-1{grid-column:span 2;grid-row:span 2}
.rg-2{grid-column:span 1;grid-row:span 1}
.rg-3{grid-column:span 1;grid-row:span 2}
.rg-4{grid-column:span 1;grid-row:span 1}
.rg-5{grid-column:span 2;grid-row:span 1}
.rg-6{grid-column:span 1;grid-row:span 1}

/* ============ SUBSCRIBE ============ */
.sub{
  padding:var(--sec-y) 0;
  background:var(--ink);
  color:var(--paper);
}
.sub-inner{
  max-width:1500px;margin:0 auto;
  display:grid;grid-template-columns:1.2fr 1fr;
  gap:clamp(28px,4vw,80px);
  padding:0 var(--pad-x);
  align-items:center;
}
.sub-body{display:flex;flex-direction:column;gap:18px}
.sub .sec-h{color:var(--paper)}
.sub .sec-h em{color:var(--ember)}
.sub .sec-p{color:rgba(242,237,227,.7)}
.sub .rubric{color:var(--ember)}

.sub-plans{display:flex;flex-direction:column;gap:1px;background:rgba(242,237,227,.12);margin-top:18px}
.sp{
  display:grid;grid-template-columns:60px 1fr auto auto;
  gap:14px;align-items:center;
  padding:18px 20px;
  background:var(--ink);
  position:relative;
  font-family:var(--f-m);font-size:14px;
}
.sp-n{font-family:var(--f-m);font-size:13px;font-weight:600;color:var(--ember);letter-spacing:.04em}
.sp-t{font-family:var(--f-s);font-size:17px;font-weight:600;color:var(--paper);letter-spacing:-.01em}
.sp-t em{font-family:var(--f-d);font-style:italic;color:rgba(242,237,227,.6);font-weight:400;font-size:14px}
.sp-p{color:var(--ember);font-weight:600;letter-spacing:.01em;font-size:15px}
.sp-d{color:rgba(242,237,227,.6);font-size:12px;letter-spacing:.02em}
.sp--rec{background:rgba(231,106,44,.08);outline:1px solid var(--ember);outline-offset:-1px}
.sp-flag{
  position:absolute;right:-1px;top:-1px;
  background:var(--ember);color:var(--paper);
  font-family:var(--f-m);font-size:10px;letter-spacing:.05em;text-transform:uppercase;font-weight:600;
  padding:4px 10px;
}

.sub-note{
  font-family:var(--f-d);font-style:italic;font-size:17px;line-height:1.5;
  color:rgba(242,237,227,.65);
  max-width:54ch;margin-top:12px;
}
.sub-cta{display:flex;gap:12px;flex-wrap:wrap;margin-top:14px}
.sub-cta .btn-fill{background:var(--ember);color:var(--paper)}
.sub-cta .btn-fill:hover{background:var(--paper);color:var(--ink)}
.sub-cta .btn-line{color:var(--paper);border-color:rgba(242,237,227,.3)}
.sub-cta .btn-line:hover{background:var(--paper);color:var(--ink);border-color:var(--paper)}

.sub-fig{position:relative;margin:0}
.sub-fig img{width:100%;aspect-ratio:4/5;object-fit:cover;filter:saturate(.9) contrast(1.05)}
.sf-tag{
  position:absolute;left:14px;top:14px;
  background:var(--paper);color:var(--ink);
  padding:8px 12px;
  font-family:var(--f-m);font-size:11px;letter-spacing:.04em;
  display:flex;align-items:baseline;gap:8px;
}
.sf-tag b{color:var(--ember);font-weight:600;text-transform:uppercase}
.sf-tag em{font-style:normal;font-weight:500}

/* ============ VISIT ============ */
.visit{padding:var(--sec-y) 0;max-width:1500px;margin:0 auto}
.vs-grid{
  display:grid;grid-template-columns:1fr 1.2fr;
  gap:clamp(24px,3vw,72px);
  padding:0 var(--pad-x);
  align-items:start;
}
.vs-body{display:flex;flex-direction:column;gap:16px}
.vs-list{display:flex;flex-direction:column;gap:0;margin-top:8px}
.vs-list div{
  display:grid;grid-template-columns:90px 1fr;
  gap:14px;align-items:baseline;
  padding:14px 0;
  border-bottom:1px solid var(--line);
}
.vs-list dt b{
  font-family:var(--f-m);font-size:13px;color:var(--ember);font-weight:600;letter-spacing:.04em;
}
.vs-list dd{
  font-family:var(--f-s);font-size:17px;color:var(--ink);font-weight:500;
}
.vs-list dd a{color:var(--ink);border-bottom:1px solid var(--ember)}
.vs-list dd em{font-style:italic;color:var(--ink-3);font-weight:400;font-family:var(--f-d)}

.vs-map{
  position:relative;
  min-height:clamp(400px,55vh,580px);
  overflow:hidden;
  border:1px solid var(--ink);
}
.vs-map iframe{position:absolute;inset:0;width:100%;height:100%;border:0;filter:saturate(.6) sepia(.2)}
.vs-ping{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:24px;height:24px;
  pointer-events:none;
}
.vs-ping i{position:absolute;inset:0;border-radius:50%;background:var(--ember);animation:ping 2.4s var(--ease) infinite}
.vs-ping i:nth-child(1){width:10px;height:10px;top:7px;left:7px;animation:none;box-shadow:0 0 10px var(--ember)}
.vs-ping i:nth-child(2){animation-delay:0s}
.vs-ping i:nth-child(3){animation-delay:.8s}
@keyframes ping{0%{transform:scale(.4);opacity:.8}100%{transform:scale(2.4);opacity:0}}

/* ============ FOOTER ============ */
.foot{
  background:var(--paper);
  padding:clamp(56px,6vw,96px) var(--pad-x) clamp(22px,2vw,30px);
  display:flex;flex-direction:column;gap:clamp(40px,6vw,80px);
  border-top:1px solid var(--line);
}
.ft-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:clamp(24px,3vw,48px);
  max-width:1500px;margin:0 auto;width:100%;
}
.ft-c{display:flex;flex-direction:column;gap:7px}
.ft-l{
  font-family:var(--f-m);font-size:11px;letter-spacing:.06em;text-transform:uppercase;
  color:var(--ember);margin-bottom:6px;font-weight:600;
}
.ft-c a,.ft-c address{
  font-family:var(--f-m);font-size:13px;color:var(--ink-2);
  transition:color .25s var(--ease);
}
.ft-c a:hover{color:var(--ember)}

.ft-mark{
  font-family:var(--f-s);
  font-size:clamp(80px,18vw,240px);
  font-weight:700;
  line-height:.9;
  letter-spacing:-.06em;
  text-align:center;color:var(--ink);
}
.ft-mark i{
  font-family:var(--f-m);font-style:normal;font-size:.4em;font-weight:500;
  color:var(--ember);letter-spacing:0;
  vertical-align:0.18em;
  margin-left:.04em;
}

.ft-base{
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;
  padding-top:22px;border-top:1px solid var(--line);
  font-family:var(--f-m);font-size:11px;letter-spacing:.04em;color:var(--ink-3);
  max-width:1500px;margin:0 auto;width:100%;
}
.ft-base a{color:var(--ember);border-bottom:1px solid var(--ember)}

/* ============ FAB ============ */
.fab{
  position:fixed;right:24px;bottom:24px;z-index:50;
  display:inline-flex;align-items:center;gap:8px;
  padding:13px 18px;
  background:var(--ember);color:var(--paper);
  font-family:var(--f-m);font-size:12px;letter-spacing:.06em;text-transform:uppercase;font-weight:600;
  box-shadow:0 12px 30px rgba(231,106,44,.4);
  opacity:0;transform:translateY(20px);
  transition:opacity .35s var(--ease),transform .35s var(--ease),background .25s var(--ease);
  pointer-events:none;
}
.fab.is-on{opacity:1;transform:none;pointer-events:auto}
.fab:hover{background:var(--ink)}
body.dr-open .fab{opacity:0;pointer-events:none}

/* ============ RESPONSIVE ============ */
@media (max-width:1023px){
  :root{--pad-x:22px;--sec-y:clamp(64px,8vw,100px)}
  .hd-nav{display:none}
  .hero-grid{grid-template-columns:1fr;gap:32px}
  .brew-grid{grid-template-columns:repeat(2,1fr)}
  .hero-strip{grid-template-columns:repeat(3,1fr);row-gap:18px}
  .hero-strip div:nth-child(4),.hero-strip div:nth-child(5){border-left:0;padding-left:0}
  .hero-strip div:nth-child(4){border-top:1px solid var(--line);padding-top:18px}
  .room-grid{grid-template-columns:repeat(3,1fr);grid-auto-rows:180px}
  .rg-1{grid-column:span 2;grid-row:span 2}
  .calc-panel{grid-template-columns:1fr}
  .cp-controls{border-right:0;border-bottom:1px solid var(--ink)}
}

@media (max-width:767px){
  :root{--pad-x:16px;--sec-y:64px}
  body{font-size:15px}

  .topline{padding:6px 0}
  .topline-track{animation-duration:80s;font-size:10.5px}

  .hdr{padding:12px 16px;gap:10px}
  .hl-w{font-size:20px}
  .hl-w i{font-size:11px}
  .hd-stat{display:none}
  .hd-menu{display:inline-flex}

  .hero{padding:32px 16px 40px}
  .hero-tag{font-size:11px;margin-bottom:18px}
  .hero-h{font-size:clamp(38px,11vw,58px)}
  .hero-p{font-size:15px;margin-top:20px}
  .hero-cta{flex-direction:column;align-items:stretch}
  .hero-cta .btn{justify-content:center;min-height:48px;font-size:12px}

  .hero-panel{font-size:12px}
  .hp-head{padding:12px 14px;font-size:10.5px}
  .hp-rows{padding:6px 14px}
  .hp-row{grid-template-columns:96px 1fr;font-size:12px;padding:6px 0}
  .hp-chart{padding:12px 14px}
  .hp-foot{padding:10px 14px}
  .hp-foot em{font-size:16px}

  .hero-strip{
    grid-template-columns:repeat(2,1fr);gap:14px;
    margin-top:32px;padding-top:20px;
  }
  .hero-strip div{padding:0;border-left:0}
  .hero-strip div:nth-child(2),.hero-strip div:nth-child(4){padding-left:14px;border-left:1px solid var(--line)}
  .hero-strip div:nth-child(3){border-top:1px solid var(--line);padding-top:14px}
  .hero-strip div:nth-child(4){border-top:1px solid var(--line);padding-top:14px}
  .hero-strip div:nth-child(5){grid-column:1 / -1;border-top:1px solid var(--line);padding-top:14px}
  .hero-strip span{font-size:34px}
  .hero-strip em{font-size:10.5px}

  .sec-h{font-size:34px}

  /* table to cards on mobile */
  .b-tbl{display:block;border:0;margin:0 16px;width:auto}
  .b-tbl thead{display:none}
  .b-tbl tbody{display:block}
  .b-tbl tbody tr{
    display:grid;grid-template-columns:auto 1fr auto;gap:6px 10px;
    padding:16px 0;
    border-top:1px solid var(--ink);
  }
  .b-tbl tbody tr:first-child{border-top:2px solid var(--ink)}
  .b-tbl tbody tr:last-child{border-bottom:2px solid var(--ink)}
  .b-tbl tbody td{display:block;padding:2px 0;border:0}
  .b-tbl td:nth-child(1){grid-column:1;font-size:11px;letter-spacing:.04em;color:var(--ember);font-weight:700}
  .b-tbl td:nth-child(2){grid-column:2 / -1;font-size:14px}
  .b-tbl td:nth-child(2) b{font-size:15px}
  .b-tbl td:nth-child(2) em{font-size:13px}
  .b-tbl td:nth-child(3),.b-tbl td:nth-child(4){
    grid-row:3;display:inline-block;font-size:11px;
    padding-right:8px;
  }
  .b-tbl td:nth-child(3){grid-column:1 / 3}
  .b-tbl td:nth-child(4){grid-column:3}
  .b-tbl td:nth-child(5){grid-column:1 / -1;font-size:13.5px}
  .b-tbl td:nth-child(6){grid-row:5;grid-column:1;font-size:13px}
  .b-tbl td:nth-child(7){grid-row:5;grid-column:2;font-size:15px;font-weight:700;text-align:right}
  .b-tbl td:nth-child(8){grid-row:5;grid-column:3;text-align:right;font-size:12px}
  .b-foot{margin-left:16px;margin-right:16px;font-size:15px}

  .brew-grid{grid-template-columns:1fr;border:1px solid var(--line);margin:0 16px;padding:0;background:var(--line)}
  .bm{padding:22px 18px}

  .calc-panel{margin:0 16px}
  .cp-controls{padding:22px}
  .cp-output{padding:22px;grid-template-columns:1fr 1fr}
  .co-v{font-size:32px}
  .co-v--w{font-size:18px}

  .room-grid{
    grid-template-columns:repeat(2,1fr);
    grid-auto-rows:140px;gap:10px;
    padding:0 16px;
  }
  .rg-1{grid-column:span 2;grid-row:span 2}
  .rg-2,.rg-3,.rg-4,.rg-5,.rg-6{grid-column:span 1;grid-row:span 1}
  .rg-5{grid-column:span 2}

  .sub-inner{grid-template-columns:1fr;gap:32px}
  .sub-fig img{aspect-ratio:5/4}
  .sp{grid-template-columns:40px 1fr auto;gap:10px;padding:14px;font-size:13px}
  .sp-d{grid-column:1 / -1;margin-top:-2px}
  .sp-flag{font-size:9.5px;padding:3px 8px}
  .sub-cta{flex-direction:column;align-items:stretch}
  .sub-cta .btn{justify-content:center;min-height:48px}

  .vs-grid{grid-template-columns:1fr;gap:20px}
  .vs-list div{grid-template-columns:80px 1fr;padding:11px 0;gap:10px}
  .vs-list dd{font-size:15px}
  .vs-map{min-height:320px}

  .ft-grid{grid-template-columns:1fr 1fr;gap:18px}
  .ft-mark{font-size:clamp(72px,24vw,140px)}
  .ft-base{font-size:10.5px;flex-direction:column;gap:6px}

  .fab{right:14px;bottom:14px;padding:11px 15px;font-size:11px}
}

@media (max-width:479px){
  .b-tbl tbody tr{grid-template-columns:auto 1fr}
  .b-tbl td:nth-child(2){grid-column:2}
  .b-tbl td:nth-child(3),.b-tbl td:nth-child(4){grid-column:1 / -1;display:inline-block;margin-right:8px}
  .b-tbl td:nth-child(5){grid-column:1 / -1}
  .b-tbl td:nth-child(6){grid-row:auto;grid-column:1}
  .b-tbl td:nth-child(7){grid-row:auto;grid-column:2;text-align:right}
  .b-tbl td:nth-child(8){grid-row:auto;grid-column:1 / -1;text-align:right;margin-top:6px;border-top:1px dashed var(--line);padding-top:8px}

  .ft-grid{grid-template-columns:1fr}
  .cp-output{grid-template-columns:1fr}
}

@media (hover:none) and (pointer:coarse){
  .btn,.hd-menu,.dr-x,.fab{min-height:44px}
  .cp-radio label,.b-tbl tbody tr{min-height:44px}
}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms !important;transition-duration:.01ms !important;scroll-behavior:auto !important}
  [data-split] > .w{opacity:1 !important;transform:none !important}
  .topline-track,.hp-curve,.hp-pt,.vs-ping i{animation:none}
}
