:root{
  --paper:#ece3cf; --paper-2:#e1d5ba; --dark:#0f2129; --dark-2:#163039;
  --ink:#16272d; --ink-soft:#5c6d6c; --rule:#c4b393; --rule-dark:rgba(236,227,207,.16);
  --accent:#1f6f6b; --accent-soft:#46a195;
  --max:1480px; --pad:clamp(1.3rem,5vw,4.5rem);
  --ease:cubic-bezier(.19,1,.22,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{background:var(--paper);color:var(--ink);font-family:"Satoshi",system-ui,sans-serif;
  font-size:clamp(15px,.55vw+13px,18px);line-height:1.72;overflow-x:hidden}
img{display:block;width:100%;height:100%;object-fit:cover}
a{color:inherit;text-decoration:none}
::selection{background:var(--accent);color:var(--paper)}

.display{font-family:"Zodiak",Georgia,serif;font-weight:700;line-height:.98;
  letter-spacing:-.015em}
.display em{font-style:italic;font-weight:400;color:var(--accent)}
.tag{font-size:.74rem;font-weight:600;letter-spacing:.26em;text-transform:uppercase;
  color:var(--accent)}

/* Grain */
.grain{position:fixed;inset:0;z-index:120;pointer-events:none;opacity:.035;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='140' height='140'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='3'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>")}

/* Mask + rise reveals */
.ln{display:block;overflow:hidden}
.ln>span{display:block;transform:translateY(110%);transition:transform 1.05s var(--ease)}
.ln.in>span{transform:none}
.ln:nth-child(2)>span{transition-delay:.08s}
.ln:nth-child(3)>span{transition-delay:.16s}
.rise{opacity:0;transform:translateY(26px);transition:opacity .95s var(--ease),transform .95s var(--ease)}
.rise.in{opacity:1;transform:none}
.rise[data-d="1"]{transition-delay:.1s}
.rise[data-d="2"]{transition-delay:.2s}
.rise[data-d="3"]{transition-delay:.3s}

/* Buttons / links */
.btn{display:inline-flex;align-items:center;justify-content:center;background:var(--ink);
  color:var(--paper);font-weight:600;font-size:.86rem;letter-spacing:.04em;text-transform:uppercase;
  padding:1.05rem 2.1rem;border:none;cursor:pointer;border-radius:0;
  transition:background .5s var(--ease),color .5s var(--ease),transform .4s var(--ease)}
.btn:hover{background:var(--accent)}
.btn:active{transform:translateY(1px)}
.btn-block{width:100%}
.ch-dark .btn{background:var(--paper);color:var(--ink)}
.ch-dark .btn:hover{background:var(--accent);color:var(--paper)}
.link-u{align-self:flex-start;font-weight:600;font-size:.82rem;letter-spacing:.06em;
  text-transform:uppercase;padding-bottom:.35rem;
  background:linear-gradient(currentColor,currentColor) 0 100%/0 1px no-repeat;
  transition:background-size .5s var(--ease),color .4s var(--ease)}
.link-u:hover{color:var(--accent);background-size:100% 1px}

/* Header */
.hd{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;
  justify-content:space-between;gap:2rem;padding:1.5rem var(--pad);
  mix-blend-mode:difference;color:#fff}
.hd.solid{position:sticky;mix-blend-mode:normal;color:var(--ink);background:var(--paper);
  border-bottom:1px solid var(--rule);padding-block:1rem}
.brand{font-family:"Zodiak",serif;font-weight:700;font-size:1.22rem;letter-spacing:-.01em;display:flex;align-items:center;gap:.5rem}
.hd-nav{display:flex;gap:2.4rem;font-size:.82rem;font-weight:500}
.hd-nav a{display:flex;gap:.45rem;align-items:baseline;opacity:.78;transition:opacity .3s}
.hd-nav a span{font-size:.66rem;opacity:.6}
.hd-nav a:hover{opacity:1}
.hd-cta{font-size:.78rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;
  border:1px solid currentColor;padding:.6rem 1.3rem;transition:.4s var(--ease)}
.hd-cta:hover{background:currentColor}
.hd.solid .hd-cta:hover{color:var(--paper)}
.hd-burger{display:none;flex-direction:column;gap:6px;background:none;border:none;cursor:pointer;padding:6px}
.hd-burger span{width:26px;height:1.5px;background:currentColor;transition:.3s var(--ease)}
.lang{display:flex;align-items:center;font-size:.74rem;font-weight:600;
  letter-spacing:.08em;flex:none}
.lang button{background:none;border:none;color:inherit;cursor:pointer;font:inherit;
  padding:.3rem .42rem;opacity:.5;transition:opacity .3s var(--ease)}
.lang button:hover{opacity:.85}
.lang button.is-on{opacity:1;text-decoration:underline;text-underline-offset:4px}
.lang i{opacity:.3;font-style:normal}

/* Hero */
.hero{position:relative;min-height:100dvh;display:flex;flex-direction:column;
  justify-content:flex-end;padding:0 var(--pad) clamp(5rem,9vw,7rem);overflow:hidden;
  background:var(--dark);color:var(--paper)}
.hero-fig{position:absolute;inset:0;z-index:0}
.hero-fig img{transform:scale(1.12);will-change:transform;filter:grayscale(.28) brightness(.6) contrast(1.06) saturate(.85)}
.hero-fig::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(15,33,41,.5),rgba(15,33,41,.12) 38%,rgba(15,33,41,.82))}
.hero-grid{position:relative;z-index:2;width:100%;max-width:var(--max);margin:0 auto}
.hero-tag{color:var(--accent-soft);margin-bottom:clamp(1rem,2vw,1.6rem)}
.hero h1{font-size:clamp(2.9rem,9.2vw,8.6rem)}
.hero-foot{display:flex;align-items:flex-end;justify-content:space-between;gap:2.5rem;
  flex-wrap:wrap;margin-top:clamp(1.6rem,4vw,3rem);
  border-top:1px solid var(--rule-dark);padding-top:clamp(1.3rem,2.5vw,2rem)}
.hero-note{max-width:36ch;color:rgba(241,236,225,.74);font-size:1.02rem}
.hero-scroll{position:absolute;left:50%;transform:translateX(-50%);
  bottom:clamp(4.4rem,8vw,6.4rem);z-index:2;
  display:flex;flex-direction:column;align-items:center;gap:.7rem;
  font-size:.68rem;letter-spacing:.24em;text-transform:uppercase;color:rgba(241,236,225,.6)}
.hero-scroll i{width:1px;height:46px;background:linear-gradient(var(--accent-soft),transparent);
  animation:drop 2.4s var(--ease) infinite}
@keyframes drop{0%{transform:scaleY(0);transform-origin:top}45%{transform:scaleY(1);transform-origin:top}
  55%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* Marquee strip */
.strip{background:var(--ink);color:var(--paper);overflow:hidden;
  padding:clamp(.9rem,1.6vw,1.3rem) 0;border-block:1px solid var(--ink)}
.strip-run{display:flex;align-items:center;gap:2.2rem;width:max-content;
  animation:run 34s linear infinite;font-family:"Zodiak",serif;font-size:clamp(1.1rem,2.4vw,1.8rem);
  font-style:italic}
.strip-run i{font-style:normal;color:var(--accent-soft);font-size:.7em}
@keyframes run{to{transform:translateX(-50%)}}

/* Chapter shell */
.chapter{max-width:var(--max);margin:0 auto;
  padding:clamp(4.5rem,11vw,9rem) var(--pad)}
.ch-dark{max-width:none;background:var(--dark);color:var(--paper)}
.ch-dark .chapter,.ch-dark>*{}
.ch-dark .ch-head,.ch-dark .xp,.ch-dark .plates{max-width:var(--max);margin-inline:auto}
.ch-dark .tag{color:var(--accent-soft)}
.ch-dark .display em{color:var(--accent-soft)}
.ch-head{display:grid;grid-template-columns:1fr;gap:1.4rem;margin-bottom:clamp(2.6rem,6vw,5rem)}
.ch-head h2{font-size:clamp(2.4rem,7vw,5.6rem)}

/* About */
.about{display:grid;grid-template-columns:1.05fr 1.1fr;gap:clamp(2rem,5vw,5rem) clamp(2.5rem,7vw,7rem);
  align-items:start;grid-template-areas:"lead fig" "index fig"}
.about-lead{grid-area:lead}
.about-lead .lead{font-family:"Zodiak",serif;font-size:clamp(1.3rem,2.4vw,2rem);
  line-height:1.32;margin-bottom:1.6rem}
.about-lead p:not(.lead){color:var(--ink-soft);max-width:42ch}
.about-fig{grid-area:fig;align-self:start;background:var(--dark)}
.about-fig img{aspect-ratio:4/5;transition:transform 1.6s var(--ease)}
.about-fig:hover img{transform:scale(1.04)}
.about-fig figcaption{margin-top:.9rem;font-size:.78rem;letter-spacing:.06em;
  text-transform:uppercase;color:var(--ink-soft)}
.index{grid-area:index;list-style:none;align-self:end;border-top:1px solid var(--rule)}
.index li{display:flex;gap:1.3rem;align-items:baseline;padding:1.05rem 0;
  border-bottom:1px solid var(--rule);font-size:.98rem}
.index span{font-family:"Zodiak",serif;font-style:italic;color:var(--accent);
  min-width:1.6rem;font-size:.95rem}

/* Suites — editorial plates */
.plate{display:grid;grid-template-columns:1.35fr 1fr;gap:clamp(2rem,5vw,5rem);
  align-items:center;padding:clamp(2.5rem,6vw,5rem) 0;border-top:1px solid var(--rule)}
.plate:last-child{border-bottom:1px solid var(--rule)}
.plate.flip{grid-template-columns:1fr 1.35fr}
.plate.flip .plate-fig{order:2}
.plate-fig{overflow:hidden;background:var(--dark)}
.plate-fig img{aspect-ratio:3/2;transition:transform 1.7s var(--ease);
  filter:grayscale(.18) contrast(1.02)}
.plate:hover .plate-fig img{transform:scale(1.05);filter:none}
.plate-body{display:flex;flex-direction:column;gap:1.1rem}
.plate-fig-no{font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--accent)}
.plate-body h3{font-size:clamp(2rem,4.5vw,3.4rem)}
.plate-body>p{color:var(--ink-soft);max-width:40ch}
.spec{border-top:1px solid var(--rule)}
.spec div{display:flex;justify-content:space-between;gap:1rem;padding:.85rem 0;
  border-bottom:1px solid var(--rule)}
.spec dt{font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft)}
.spec dd{font-family:"Zodiak",serif;font-size:1.05rem}
.spec div:last-child dd{color:var(--accent);font-style:italic;font-size:1.25rem}
.plate-amen{display:flex;flex-wrap:wrap;gap:.4rem 1.1rem;list-style:none;
  margin:.2rem 0 .2rem;padding:0}
.plate-amen li{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink-soft);font-weight:600;position:relative;padding-left:.8rem}
.plate-amen li::before{content:"·";position:absolute;left:0;color:var(--accent)}
.suites-loading{max-width:var(--max);margin:1.5rem auto 0;padding:0 var(--pad);
  color:var(--ink-soft);font-size:.95rem;font-style:italic}

/* Experiences */
.xp{list-style:none}
.xp-row{display:grid;grid-template-columns:auto 1fr 1.1fr;gap:clamp(1.5rem,5vw,5rem);
  align-items:baseline;padding:clamp(1.8rem,4vw,3rem) 0;border-top:1px solid var(--rule-dark);
  transition:padding-left .6s var(--ease)}
.xp-row:last-child{border-bottom:1px solid var(--rule-dark)}
.xp-row:hover{padding-left:1.2rem}
.xp-no{font-family:"Zodiak",serif;font-style:italic;font-size:1rem;color:var(--accent-soft)}
.xp-row h3{font-size:clamp(1.7rem,4vw,3rem);font-weight:400;transition:color .4s var(--ease)}
.xp-row:hover h3{color:var(--accent-soft)}
.xp-row p{color:rgba(241,236,225,.62);max-width:44ch}

/* Bento — paper */
.bento{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:minmax(220px,auto);
  grid-auto-flow:dense;gap:clamp(.7rem,1.4vw,1rem)}
.c-wide{grid-column:span 2}.c-tall{grid-row:span 2}
.cell{position:relative;display:flex;flex-direction:column;gap:1.4rem;
  border:1px solid var(--rule);padding:clamp(1.5rem,3vw,2.2rem);overflow:hidden;
  transition:background .5s var(--ease),border-color .5s var(--ease)}
.c-tall{justify-content:space-between}
.cell:hover{background:var(--ink);border-color:var(--ink);color:var(--paper)}
.cell-ic{width:44px;height:44px;border:1px solid currentColor;border-radius:50%;
  display:grid;place-items:center;color:var(--accent);opacity:.85;transition:.5s var(--ease)}
.cell-ic svg{width:21px;height:21px}
.cell:hover .cell-ic{color:var(--accent-soft);opacity:1}
.cell h3{font-family:"Zodiak",serif;font-size:1.35rem;font-weight:700;margin-bottom:.4rem}
.cell p{color:var(--ink-soft);font-size:.9rem;line-height:1.6;max-width:36ch}
.cell:hover p{color:rgba(241,236,225,.7)}

/* Gallery plates */
.plates{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:220px;
  grid-auto-flow:dense;gap:clamp(.6rem,1.4vw,1rem)}
.pl{position:relative;overflow:hidden;cursor:pointer;background:var(--dark-2)}
.pl-tall{grid-row:span 2}.pl-wide{grid-column:span 2}
.pl img{transition:transform 1.5s var(--ease),filter .7s var(--ease);
  filter:grayscale(1) brightness(.78)}
.pl:hover img{transform:scale(1.06);filter:none}
.pl figcaption{position:absolute;left:0;right:0;bottom:0;padding:2rem 1.2rem 1rem;
  font-family:"Zodiak",serif;font-size:1.02rem;color:var(--paper);
  background:linear-gradient(0deg,rgba(24,22,18,.82),transparent);
  opacity:0;transform:translateY(10px);transition:.55s var(--ease)}
.pl figcaption span{display:block;font-family:"Satoshi",sans-serif;font-size:.68rem;
  letter-spacing:.18em;text-transform:uppercase;color:var(--accent-soft);margin-bottom:.25rem}
.pl:hover figcaption{opacity:1;transform:none}

/* Testimonials */
.quotes{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(1rem,2.4vw,1.6rem)}
.quote{display:flex;flex-direction:column;gap:1.4rem;
  padding:clamp(1.8rem,3.6vw,2.8rem);border:1px solid var(--rule);
  transition:background .5s var(--ease),border-color .5s var(--ease),transform .6s var(--ease)}
.quote:hover{background:var(--dark);border-color:var(--dark);color:var(--paper);
  transform:translateY(-4px)}
.quote blockquote{position:relative;font-family:"Zodiak",serif;
  font-size:clamp(1.12rem,1.7vw,1.42rem);line-height:1.5;font-style:italic}
.quote blockquote::before{content:"\201C";display:block;font-family:"Zodiak",serif;
  font-style:normal;font-size:3.4rem;line-height:.1;margin:1rem 0 1.1rem;
  color:var(--accent);transition:color .5s var(--ease)}
.quote:hover blockquote::before{color:var(--accent-soft)}
.quote figcaption{margin-top:auto;padding-top:1.1rem;border-top:1px solid var(--rule);
  font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink-soft);font-weight:600;transition:color .5s var(--ease)}
.quote:hover figcaption{color:var(--accent-soft);border-color:var(--rule-dark)}
@media (max-width:760px){.quotes{grid-template-columns:1fr}}

/* CTA */
.ch-cta{border-top:1px solid var(--rule)}
.cta{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2.5rem,7vw,7rem);align-items:center}
.cta-text h2{font-size:clamp(2.2rem,5.5vw,4.4rem);margin:1.2rem 0 1.4rem}
.cta-text p{color:var(--ink-soft);max-width:42ch}
.cta-contact{font-style:normal;font-family:"Zodiak",serif;font-size:1.1rem;
  line-height:1.9;color:var(--accent);margin-top:1.8rem}
.form{display:grid;gap:1.4rem;border-top:2px solid var(--ink);padding-top:2rem}
.f{display:grid;gap:.4rem}
.f-row{display:grid;grid-template-columns:1fr 1fr;gap:1.3rem}
.f label{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);font-weight:600}
.f input,.f select{background:transparent;border:none;border-bottom:1px solid var(--rule);
  color:var(--ink);font:inherit;padding:.6rem 0}
.f input::placeholder{color:#a59c86}
.f input:focus,.f select:focus{outline:none;border-color:var(--accent)}
.f select option{background:var(--paper)}
.f small{font-size:.74rem;color:#a59c86}
.form-msg{font-size:.9rem;font-weight:600;min-height:1.2rem;color:var(--accent)}

/* Custom dropdown */
.dd{position:relative}
.dd-native{position:absolute;width:1px;height:1px;margin:-1px;padding:0;
  border:0;opacity:0;pointer-events:none;clip:rect(0 0 0 0);overflow:hidden}
.dd-btn{width:100%;display:flex;align-items:center;justify-content:space-between;
  gap:1rem;background:transparent;border:none;border-bottom:1px solid var(--rule);
  color:var(--ink);font:inherit;padding:.6rem 0;cursor:pointer;text-align:left;
  transition:border-color .25s var(--ease)}
.dd-btn:focus-visible{outline:none;border-color:var(--accent)}
.dd.is-open .dd-btn{border-color:var(--accent)}
.dd-val{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dd-caret{width:.7rem;height:.7rem;flex:none;color:var(--accent);
  transition:transform .28s var(--ease)}
.dd.is-open .dd-caret{transform:rotate(180deg)}
.dd-list{position:absolute;top:calc(100% + .5rem);left:0;right:0;z-index:40;
  margin:0;padding:.3rem;list-style:none;background:var(--paper);
  border:1px solid var(--rule);box-shadow:0 22px 44px -20px rgba(15,33,41,.5);
  max-height:15rem;overflow:auto;opacity:0;visibility:hidden;
  transform:translateY(-6px);transition:opacity .18s var(--ease),
  transform .18s var(--ease),visibility .18s}
.dd.is-open .dd-list{opacity:1;visibility:visible;transform:none}
.dd-opt{padding:.65rem .8rem;cursor:pointer;font-size:.95rem;color:var(--ink);
  border-radius:2px;transition:background .15s var(--ease),color .15s var(--ease)}
.dd-opt:hover,.dd-opt.is-active{background:var(--paper-2)}
.dd-opt.is-sel{color:var(--accent);font-weight:600}
.dd-opt.is-sel.is-active,.dd-opt.is-sel:hover{background:var(--accent);color:var(--paper)}

/* Footer */
.ft{background:var(--dark);color:var(--paper);overflow:hidden}
.ft-mark{padding:clamp(2rem,5vw,4rem) 0;border-top:1px solid var(--rule-dark)}
.ft-run{display:flex;align-items:center;gap:2.5rem;width:max-content;
  animation:run 30s linear infinite;font-family:"Zodiak",serif;font-style:italic;
  font-size:clamp(2.6rem,8vw,6rem);opacity:.9}
.ft-run i{font-style:normal;color:var(--accent-soft)}
.ft-grid{max-width:var(--max);margin:0 auto;display:grid;
  grid-template-columns:1.6fr 1fr 1fr 1fr;gap:2.5rem;
  padding:clamp(2.5rem,6vw,4.5rem) var(--pad)}
.ft-logo{display:flex;align-items:center;gap:.7rem;margin-bottom:1rem;color:var(--accent-soft)}
.ft-logo span{font-family:"Zodiak",serif;font-weight:700;font-style:italic;font-size:1.25rem;letter-spacing:-.01em;color:var(--paper)}
.ft-line{font-family:"Zodiak",serif;font-size:1.4rem;line-height:1.4}
.ft h4{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--accent-soft);margin-bottom:1rem;font-family:"Satoshi",sans-serif;font-weight:600}
.ft nav a{display:block;color:rgba(241,236,225,.78);padding:.26rem 0;font-size:.95rem;transition:color .3s}
.ft nav a:hover{color:var(--paper)}
.ft p{color:rgba(241,236,225,.7);font-size:.92rem}
.ft-copy{font-size:.82rem!important}
.ft-copy a{color:var(--accent-soft);transition:color .3s var(--ease)}
.ft-copy a:hover{color:var(--paper);text-decoration:underline;text-underline-offset:3px}

/* Lightbox */
.lightbox{position:fixed;inset:0;z-index:130;display:grid;
  grid-template-columns:auto 1fr auto;align-items:center;gap:clamp(.5rem,3vw,2rem);
  padding:clamp(1rem,5vw,3rem);background:rgba(20,18,14,.96);backdrop-filter:blur(6px);
  opacity:0;pointer-events:none;transition:opacity .4s var(--ease)}
.lightbox.open{opacity:1;pointer-events:auto}
.lb-stage{display:flex;flex-direction:column;align-items:center;gap:1rem;min-width:0;max-height:88vh}
.lb-stage img{max-width:100%;max-height:80vh;width:auto;height:auto;object-fit:contain;
  animation:rise2 .5s var(--ease)}
@keyframes rise2{from{opacity:0;transform:scale(.97)}}
.lb-stage figcaption{font-family:"Zodiak",serif;font-style:italic;color:rgba(241,236,225,.8);font-size:.95rem}
.lb-x,.lb-p,.lb-n{background:transparent;border:1px solid var(--rule-dark);color:var(--paper);
  width:48px;height:48px;border-radius:50%;display:grid;place-items:center;cursor:pointer;
  transition:.3s var(--ease)}
.lb-x{position:absolute;top:clamp(1rem,4vw,2rem);right:clamp(1rem,4vw,2rem)}
.lb-x:hover,.lb-p:hover,.lb-n:hover{border-color:var(--accent-soft);color:var(--accent-soft)}

/* Chat */
.chat-widget{position:fixed;right:clamp(1rem,3vw,2rem);bottom:clamp(1rem,3vw,2rem);z-index:115}
.chat-fab{width:58px;height:58px;border-radius:50%;border:none;background:var(--ink);
  color:var(--paper);cursor:pointer;display:grid;place-items:center;
  transition:transform .5s var(--ease),background .4s var(--ease)}
.chat-fab:hover{transform:scale(1.06);background:var(--accent)}
.chat-fab .i-close{display:none}
.chat-widget.open .chat-fab{background:var(--accent)}
.chat-widget.open .i-open{display:none}.chat-widget.open .i-close{display:block}
.chat-panel{position:absolute;right:0;bottom:72px;width:min(372px,86vw);background:var(--paper);
  border:1px solid var(--ink);box-shadow:0 30px 70px -24px rgba(20,18,14,.6);
  display:flex;flex-direction:column;overflow:hidden;transform-origin:bottom right;
  opacity:0;transform:scale(.92) translateY(12px);pointer-events:none;transition:.34s var(--ease)}
.chat-widget.open .chat-panel{opacity:1;transform:none;pointer-events:auto}
.chat-hd{display:flex;align-items:flex-start;gap:.7rem;padding:1.1rem 1.2rem;
  background:var(--ink);color:var(--paper)}
.chat-dot{width:8px;height:8px;border-radius:50%;background:var(--accent-soft);
  flex:none;margin-top:.42rem;margin-left:auto;animation:pulse 2.4s var(--ease) infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(187,106,62,.5)}70%{box-shadow:0 0 0 9px rgba(187,106,62,0)}100%{box-shadow:0 0 0 0 rgba(187,106,62,0)}}
.chat-hd strong{display:block;font-family:"Zodiak",serif;font-size:1rem}
.chat-hd span{font-size:.76rem;opacity:.7}
.chat-body{height:328px;overflow-y:auto;padding:1.2rem;display:flex;flex-direction:column;gap:.6rem}
.msg{max-width:82%;padding:.65rem .9rem;font-size:.89rem;line-height:1.55;animation:rise3 .3s var(--ease)}
.msg.bot{align-self:flex-start;background:var(--paper-2);border:1px solid var(--rule)}
.msg.user{align-self:flex-end;background:var(--ink);color:var(--paper)}
.msg b,.msg strong{font-weight:700}
.msg.bot p{margin:0 0 .45em}
.msg.bot p:last-child{margin-bottom:0}
.msg.bot ul,.msg.bot ol{margin:.3em 0 .3em 1.1em;padding:0}
.msg.bot li{margin-bottom:.2em}
.msg.bot li:last-child{margin-bottom:0}
.msg.typing{align-self:flex-start;display:flex;gap:5px;background:var(--paper-2);border:1px solid var(--rule)}
.msg.typing i{width:6px;height:6px;border-radius:50%;background:var(--ink-soft);animation:blink 1.3s infinite}
.msg.typing i:nth-child(2){animation-delay:.2s}.msg.typing i:nth-child(3){animation-delay:.4s}
@keyframes rise3{from{opacity:0;transform:translateY(6px)}}
@keyframes blink{0%,60%,100%{opacity:.25}30%{opacity:1}}
.chat-quick{display:flex;align-items:center;gap:.45rem;
  padding:.6rem .7rem .6rem 1.2rem;border-top:1px solid var(--rule)}
.chat-quick:not(.is-ready){display:none}
.chat-quick-track{display:flex;gap:.4rem;flex:1;min-width:0;overflow-x:auto;
  scroll-behavior:smooth;scroll-snap-type:x proximity;
  -ms-overflow-style:none;scrollbar-width:none;
  -webkit-mask:linear-gradient(90deg,#000 calc(100% - 1.6rem),transparent);
          mask:linear-gradient(90deg,#000 calc(100% - 1.6rem),transparent)}
.chat-quick-track::-webkit-scrollbar{display:none}
.chat-quick-track button{flex:none;white-space:nowrap;scroll-snap-align:start;
  background:transparent;border:1px solid var(--rule);color:var(--ink-soft);
  font:inherit;font-size:.77rem;padding:.34rem .72rem;border-radius:999px;
  cursor:pointer;transition:border-color .3s var(--ease),color .3s var(--ease)}
.chat-quick-track button:hover{border-color:var(--accent);color:var(--accent)}
.chat-quick-toggle{flex:none;display:flex;align-items:center;gap:.35rem;
  width:28px;height:28px;justify-content:center;padding:0;
  background:var(--paper);border:1px solid var(--rule);color:var(--ink-soft);
  border-radius:999px;cursor:pointer;font:inherit;font-size:.74rem;font-weight:600;
  transition:border-color .3s var(--ease),color .3s var(--ease),width .3s var(--ease)}
.chat-quick-toggle:hover{border-color:var(--accent);color:var(--accent)}
.chat-quick-toggle .cq-lbl{display:none}
.chat-quick-toggle .cq-ic{width:13px;height:13px;flex:none;
  transition:transform .3s var(--ease)}
.chat-quick.is-collapsed{padding-block:.5rem}
.chat-quick.is-collapsed .chat-quick-track{display:none}
.chat-quick.is-collapsed .chat-quick-toggle{width:auto;padding:.32rem .8rem;
  margin-right:auto}
.chat-quick.is-collapsed .cq-lbl{display:inline}
.chat-quick.is-collapsed .cq-ic{transform:rotate(180deg)}
.chat-input{display:flex;align-items:center;gap:.55rem;padding:.8rem;
  border-top:1px solid var(--rule)}
.chat-input input{flex:1;min-width:0;background:transparent;border:1px solid var(--rule);
  color:var(--ink);font:inherit;padding:0 .85rem;height:42px}
.chat-input input:focus{outline:none;border-color:var(--accent)}
.chat-input button{flex:none;width:42px;height:42px;border:none;background:var(--ink);
  color:var(--paper);cursor:pointer;display:grid;place-items:center;transition:.3s var(--ease)}
.chat-input button:hover{background:var(--accent)}

/* ── Como Chegar ─────────────────────────────────────────────────────────── */
.chegar-body{display:grid;grid-template-columns:1fr 1fr;gap:clamp(3rem,7vw,7rem);align-items:start}
.chegar-modes{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:2.8rem}
.chegar-mode{display:flex;flex-direction:column;gap:.5rem;padding:1.2rem 1rem;
  border:1px solid var(--rule-dark);background:rgba(255,255,255,.04);transition:background .3s var(--ease)}
.chegar-mode:hover{background:rgba(255,255,255,.08)}
.chegar-mode svg{color:var(--accent-soft);flex:none}
.chegar-mode strong{font-size:.88rem;font-weight:600;color:var(--paper)}
.chegar-mode span{font-size:.78rem;color:rgba(236,227,207,.55);line-height:1.4}
.chegar-steps{list-style:none;border-top:1px solid var(--rule-dark)}
.chegar-step{display:grid;grid-template-columns:2.4rem 1fr;gap:.8rem 1rem;
  padding:1.3rem 0;border-bottom:1px solid var(--rule-dark);align-items:start}
.step-no{font-family:"Zodiak",serif;font-style:italic;font-size:1.1rem;
  color:var(--accent-soft);padding-top:.1rem}
.chegar-step strong{display:block;font-size:.9rem;font-weight:600;color:var(--paper);margin-bottom:.2rem}
.chegar-step p{font-size:.86rem;color:rgba(236,227,207,.62);line-height:1.56;margin:0}
.chegar-actions{display:flex;align-items:center;gap:1rem;margin-top:2rem;flex-wrap:wrap}
.chegar-link{font-size:.78rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  color:var(--accent-soft);opacity:.8;transition:opacity .3s var(--ease)}
.chegar-link:hover{opacity:1}
.chegar-map{position:relative;background:var(--dark-2);overflow:hidden}
.chegar-map iframe{width:100%;aspect-ratio:4/3;display:block;border:0;filter:grayscale(.35) contrast(1.05)}
.chegar-address{margin-top:1.4rem;padding:1.2rem 1.4rem;background:rgba(255,255,255,.05);
  border-left:2px solid var(--accent)}
.chegar-address p{font-size:.84rem;color:rgba(236,227,207,.75);line-height:1.7;margin:0}
.chegar-address strong{color:var(--paper);display:block;margin-bottom:.3rem;font-size:.82rem;
  letter-spacing:.06em;text-transform:uppercase}

/* ── Blog section ────────────────────────────────────────────────────────── */
.posts-grid{display:grid;grid-template-columns:repeat(3,1fr);
  gap:clamp(1.8rem,3.5vw,3rem)}
.post-card{display:flex;flex-direction:column}
.post-card-img{display:block;aspect-ratio:16/11;overflow:hidden;background:var(--dark);flex:none}
.post-card-img img{transition:transform 1.4s var(--ease)}
.post-card-img:hover img{transform:scale(1.04)}
.post-card-body{display:flex;flex-direction:column;gap:.7rem;padding-top:1.3rem;flex:1}
.post-cat{font-size:.71rem;font-weight:600;letter-spacing:.22em;
  text-transform:uppercase;color:var(--accent)}
.post-card h3{font-family:"Zodiak",Georgia,serif;font-weight:700;line-height:1.06;
  letter-spacing:-.012em;font-size:clamp(1.3rem,1.8vw,1.75rem)}
.post-card h3 a{background:linear-gradient(currentColor,currentColor) 0 100%/0 1px no-repeat;
  transition:background-size .5s var(--ease),color .4s var(--ease)}
.post-card h3 a:hover{color:var(--accent);background-size:100% 1px}
.post-card-body p{color:var(--ink-soft);font-size:.93rem;flex:1;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.post-meta{display:flex;align-items:center;gap:.9rem;font-size:.74rem;
  font-weight:500;color:var(--ink-soft);border-top:1px solid var(--rule);
  padding-top:.85rem;margin-top:auto}
.post-meta time{color:var(--ink)}
.post-meta .dot{opacity:.35}

/* Responsive */
@media (max-width:1080px){
  .hd-nav{display:none}
  .hd-burger{display:flex}
  .hd-cta{display:none}
  .hd.open .hd-nav{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;
    gap:1.1rem;background:var(--paper);color:var(--ink);padding:2rem var(--pad);
    border-bottom:1px solid var(--rule);mix-blend-mode:normal}
  .hd.open{mix-blend-mode:normal;color:var(--ink);background:var(--paper)}
}
@media (max-width:900px){
  .chegar-body{grid-template-columns:1fr}
  .chegar-map{order:-1}
  .posts-grid{grid-template-columns:1fr 1fr}
  .about{grid-template-columns:1fr;grid-template-areas:"lead" "fig" "index"}
  .about-fig img{aspect-ratio:3/2}
  .plate,.plate.flip{grid-template-columns:1fr;gap:1.6rem}
  .plate.flip .plate-fig{order:0}
  .xp-row{grid-template-columns:auto 1fr;row-gap:.5rem}
  .xp-row p{grid-column:1/-1;padding-left:2.4rem}
  .cta{grid-template-columns:1fr;gap:2.5rem}
  .bento{grid-template-columns:repeat(2,1fr)}
  .c-tall{grid-row:span 1}
  .plates{grid-template-columns:repeat(2,1fr);grid-auto-rows:40vw}
  .pl-tall{grid-row:span 1}
  .pl figcaption{opacity:1;transform:none}
  .ft-grid{grid-template-columns:1fr 1fr}
  .hero-scroll{display:none}
}
@media (max-width:620px){
  .chegar-modes{grid-template-columns:1fr}
  .posts-grid{grid-template-columns:1fr}
  .hero-foot{flex-direction:column;align-items:flex-start;gap:1.4rem}
  .f-row{grid-template-columns:1fr}
  .bento{display:flex;flex-direction:column}
  .c-wide,.c-tall{grid-column:auto;grid-row:auto}
  .plates{grid-template-columns:1fr;grid-auto-rows:64vw}
  .pl-wide{grid-column:auto}
  .ft-grid{grid-template-columns:1fr}
  .lightbox{grid-template-columns:1fr}
  .lb-p,.lb-n{position:absolute;bottom:clamp(1rem,5vw,2rem);z-index:2}
  .lb-p{left:clamp(1rem,5vw,2rem)}.lb-n{right:clamp(1rem,5vw,2rem)}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto}
  .rise,.ln>span{opacity:1;transform:none}
}
