/* ============================================================
   AS BARBER · main.css
   Dirección: casa de naipes art-decó para caballeros —
   negro carbón + blanco hueso + champán, Didone de alto
   contraste (monograma AS) sobre geométrica deco, As de Picas.
   ============================================================ */

/* ---------------- Tokens ---------------- */
:root{
  --bg:#0b0b0d;
  --bg-2:#0f0f12;
  --bg-3:#141319;
  --surface:rgba(255,255,255,.025);
  --surface-2:rgba(255,255,255,.045);

  --ink:#f2efe8;            /* bone white */
  --ink-soft:#bcb6a8;
  --ink-faint:#857f72;

  --champ:#c9ad77;          /* champagne / beige accent */
  --champ-2:#e0caa0;        /* lighter highlight */
  --champ-deep:#9a7c49;
  --beige:#d7cbb1;

  --line:rgba(201,173,119,.18);
  --line-soft:rgba(201,173,119,.09);
  --line-strong:rgba(201,173,119,.34);

  --ok:#9fd6a8; --warn:#e7c873; --info:#a9c2ff; --bad:#e98a8a;

  --display:"Bodoni Moda", Georgia, "Times New Roman", serif;
  --body:"Jost", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;

  --r:14px; --r-lg:20px; --r-sm:9px;
  --e:cubic-bezier(.22,1,.36,1);
  --e-out:cubic-bezier(.16,1,.3,1);

  --maxw:1180px; --maxw-wide:1320px;
  --shadow:0 30px 80px -40px rgba(0,0,0,.9);
  --shadow-glow:0 0 0 1px var(--line), 0 40px 90px -50px rgba(0,0,0,.95);
}

/* ---------------- Reset ---------------- */
*{box-sizing:border-box;margin:0;padding:0}
html{overflow-x:clip;scroll-padding-top:84px;-webkit-text-size-adjust:100%}
body{
  font-family:var(--body); color:var(--ink); background:var(--bg);
  line-height:1.65; font-weight:400; overflow-x:clip;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  background-image:
    radial-gradient(900px 560px at 80% -8%, rgba(201,173,119,.10), transparent 60%),
    radial-gradient(760px 520px at -6% 10%, rgba(255,255,255,.03), transparent 58%),
    radial-gradient(1200px 760px at 50% 120%, rgba(201,173,119,.06), transparent 62%);
  background-attachment:fixed;
}
/* fine grain atmosphere */
body::before{
  content:""; position:fixed; inset:0; z-index:0; pointer-events:none; opacity:.045;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.82' numOctaves='2'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)' opacity='.55'/%3E%3C/svg%3E");
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;cursor:pointer;background:none;border:none}
::selection{background:var(--champ);color:#1a1408}
:focus-visible{outline:2px solid var(--champ);outline-offset:3px}

.wrap{width:min(100% - 2.6rem,var(--maxw));margin-inline:auto}
.wrap-wide{width:min(100% - 2.6rem,var(--maxw-wide));margin-inline:auto}
.section{position:relative;z-index:1;padding-block:clamp(4rem,9vw,7.5rem)}
.num{font-variant-numeric:tabular-nums}

/* ---------------- Typography ---------------- */
h1,h2,h3,h4{font-family:var(--display);font-weight:600;line-height:1.04;letter-spacing:-.01em;text-wrap:balance}
.eyebrow{
  display:inline-flex;align-items:center;gap:.7em;
  font-family:var(--body);font-size:.72rem;font-weight:600;letter-spacing:.34em;text-transform:uppercase;
  color:var(--champ);
}
.eyebrow::before{content:"";width:26px;height:1px;background:linear-gradient(90deg,transparent,var(--champ))}
.eyebrow.center::after{content:"";width:26px;height:1px;background:linear-gradient(90deg,var(--champ),transparent)}
.section-head{margin-bottom:clamp(2rem,4vw,3rem)}
.section-head h2{font-size:clamp(2.1rem,5.4vw,3.7rem);margin-top:.6rem}
.section-head.center{text-align:center;display:flex;flex-direction:column;align-items:center}

/* ---------------- Buttons ---------------- */
.btn{
  --bg-btn:transparent;
  display:inline-flex;align-items:center;justify-content:center;gap:.6em;
  font-family:var(--body);font-weight:600;font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;
  padding:1.05em 1.9em;border-radius:var(--r-sm);position:relative;
  border:1px solid var(--line-strong);color:var(--ink);
  transition:transform .25s var(--e),background .3s var(--e),color .3s var(--e),border-color .3s var(--e),box-shadow .3s var(--e);
  white-space:nowrap;
}
.btn svg{width:1.05em;height:1.05em}
.btn:hover{transform:translateY(-2px)}
.btn-sm{padding:.72em 1.25em;font-size:.72rem}
.btn-primary{
  background:linear-gradient(135deg,var(--champ-2),var(--champ) 55%,var(--champ-deep));
  color:#171206;border-color:transparent;font-weight:700;
  box-shadow:0 14px 30px -16px rgba(201,173,119,.7);
}
.btn-primary:hover{box-shadow:0 20px 44px -16px rgba(201,173,119,.85)}
.btn-ghost{background:rgba(255,255,255,.02)}
.btn-ghost:hover{border-color:var(--champ);color:var(--champ-2);background:rgba(201,173,119,.06)}
.btn-line{border-color:var(--line)}
.btn-line:hover{border-color:var(--champ);color:var(--champ-2)}

/* ---------------- Header ---------------- */
.site-header{position:sticky;top:0;z-index:60;transition:background .35s var(--e),box-shadow .35s var(--e),border-color .35s}
.site-header::after{content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:linear-gradient(90deg,transparent,var(--line),transparent)}
.site-header.scrolled{background:rgba(11,11,13,.82);backdrop-filter:blur(16px) saturate(1.3);-webkit-backdrop-filter:blur(16px) saturate(1.3);box-shadow:0 16px 40px -28px rgba(0,0,0,.9)}
.header-inner{display:flex;align-items:center;gap:1.4rem;height:74px}

.brand{display:flex;align-items:center;gap:.7rem;margin-right:auto}
.brand .mono{font-family:var(--display);font-weight:600;font-size:1.55rem;line-height:.9;letter-spacing:.02em;color:var(--ink);display:flex;align-items:center}
.brand .mono .spade{width:.62em;height:.62em;margin-left:.16em;fill:var(--champ);transform:translateY(.04em)}
.brand .sub{font-size:.56rem;letter-spacing:.42em;text-transform:uppercase;color:var(--ink-faint);font-weight:600;border-left:1px solid var(--line);padding-left:.7rem;margin-left:.1rem}
@media(max-width:560px){.brand .sub{display:none}}

.nav{display:flex;align-items:center;gap:1.6rem}
.nav-links{display:flex;align-items:center;gap:1.5rem;list-style:none}
.nav-links a{font-size:.74rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);position:relative;padding:.4em 0;transition:color .25s var(--e)}
.nav-links a::after{content:"";position:absolute;left:0;right:100%;bottom:0;height:1px;background:var(--champ);transition:right .3s var(--e)}
.nav-links a:hover{color:var(--ink)}
.nav-links a:hover::after{right:0}
.header-actions{display:flex;align-items:center;gap:.9rem}
@media(max-width:980px){.nav-links{display:none}}

/* language toggle (fixed pattern, champagne thumb) */
.lang{position:relative;display:inline-flex;align-items:center;border:1px solid var(--line);border-radius:100px;padding:3px;background:rgba(255,255,255,.03)}
.lang .thumb{position:absolute;top:3px;left:3px;width:calc(50% - 3px);height:calc(100% - 6px);border-radius:100px;background:linear-gradient(135deg,var(--champ-2),var(--champ));transition:transform .32s var(--e);box-shadow:0 4px 12px -4px rgba(201,173,119,.6)}
.lang[data-lang="es"] .thumb{transform:translateX(100%)}
.lang button{position:relative;z-index:1;width:40px;padding:.34em 0;font-size:.66rem;font-weight:700;letter-spacing:.14em;color:var(--ink-faint);transition:color .25s var(--e)}
.lang button[aria-pressed="true"]{color:#171206}

.burger{display:none;width:42px;height:42px;border:1px solid var(--line);border-radius:var(--r-sm);position:relative}
.burger span{position:absolute;left:11px;right:11px;height:1.6px;background:var(--ink);transition:transform .3s var(--e),opacity .25s}
.burger span:nth-child(1){top:14px}.burger span:nth-child(2){top:20px}.burger span:nth-child(3){top:26px}
body.menu-open .burger span:nth-child(1){transform:translateY(6px) rotate(45deg)}
body.menu-open .burger span:nth-child(2){opacity:0}
body.menu-open .burger span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}
@media(max-width:980px){.burger{display:block}}

/* mobile drawer */
.drawer{position:fixed;inset:0;height:100dvh;z-index:55;background:linear-gradient(180deg,var(--bg-2),var(--bg));padding:6rem 2rem 2rem;display:flex;flex-direction:column;flex-wrap:nowrap;gap:.2rem;opacity:0;visibility:hidden;transition:opacity .35s var(--e),visibility .35s;overflow-y:auto}
body.menu-open .drawer{opacity:1;visibility:visible}
.drawer a{display:flex;align-items:baseline;gap:1rem;padding:1rem .4rem;border-bottom:1px solid var(--line-soft);font-family:var(--display);font-size:1.7rem;color:var(--ink)}
.drawer a span{font-family:var(--body);font-size:.7rem;letter-spacing:.2em;color:var(--champ);font-weight:600}
.drawer .btn{margin-top:1.4rem;justify-content:center;font-size:.8rem}

/* ---------------- Deco rule ---------------- */
.rule{border:0;height:auto;display:flex;align-items:center;justify-content:center;gap:1.1rem;margin:0 auto;width:min(100% - 2.6rem,var(--maxw))}
.rule::before,.rule::after{content:"";height:1px;flex:1;background:linear-gradient(90deg,transparent,var(--line-strong),transparent)}
.rule .pip{width:16px;height:16px;fill:var(--champ);opacity:.85;flex:none}

/* ---------------- HERO ---------------- */
.hero{position:relative;z-index:1;padding-top:clamp(2.4rem,6vw,4rem);padding-bottom:0;text-align:center;overflow:hidden}
.hero-inner{display:flex;flex-direction:column;align-items:center}
.hero .eyebrow{opacity:0;transform:translateY(14px)}
.hero.in .eyebrow{animation:up .8s var(--e-out) .05s forwards}

/* AS crest monogram */
.crest{margin:1.4rem 0 .4rem;position:relative;display:inline-block;opacity:0;transform:translateY(18px)}
.hero.in .crest{animation:up .9s var(--e-out) .18s forwards}
.crest .as{font-family:var(--display);font-weight:600;font-size:clamp(4.6rem,16vw,9rem);line-height:.8;letter-spacing:.04em;
  background:linear-gradient(180deg,#fffdf7,#efe7d4 55%,#cdbf9e);-webkit-background-clip:text;background-clip:text;color:transparent;position:relative}
/* champagne shimmer sweep — the hero "wow" */
.crest .as::after{content:"AS";position:absolute;inset:0;
  background:linear-gradient(105deg,transparent 38%,rgba(255,250,235,.9) 50%,transparent 62%);
  -webkit-background-clip:text;background-clip:text;color:transparent;background-size:280% 100%;
  animation:shimmer 5.5s var(--e) 1.4s infinite}
@keyframes shimmer{0%{background-position:140% 0}40%,100%{background-position:-140% 0}}
.crest .word{display:flex;align-items:center;justify-content:center;gap:.9rem;margin-top:.55rem}
.crest .word i{height:1px;width:clamp(24px,7vw,60px);background:linear-gradient(90deg,transparent,var(--champ))}
.crest .word i:last-child{background:linear-gradient(90deg,var(--champ),transparent)}
.crest .word b{font-family:var(--body);font-weight:600;font-size:clamp(.78rem,2.4vw,1.05rem);letter-spacing:.62em;text-indent:.62em;text-transform:uppercase;color:var(--ink-soft)}
.crest .spade-mini{width:.8em;height:.8em;fill:var(--champ)}

.hero-title{font-size:clamp(2.5rem,7vw,5.2rem);line-height:.98;margin:1.6rem 0 0;opacity:0;transform:translateY(18px)}
.hero.in .hero-title{animation:up .9s var(--e-out) .32s forwards}
.hero-title em{font-style:italic;color:var(--champ-2)}
.hero-sub{max-width:46ch;margin:1.4rem auto 0;color:var(--ink-soft);font-size:clamp(1rem,1.6vw,1.18rem);opacity:0;transform:translateY(16px)}
.hero.in .hero-sub{animation:up .9s var(--e-out) .44s forwards}
.hero-cta{display:flex;gap:.9rem;justify-content:center;flex-wrap:wrap;margin-top:2rem;opacity:0;transform:translateY(16px)}
.hero.in .hero-cta{animation:up .9s var(--e-out) .56s forwards}

/* framed hero photo with deco corners */
.hero-frame{position:relative;margin:clamp(2.6rem,6vw,4.4rem) auto 0;width:min(100%,940px);opacity:0;transform:translateY(26px) scale(.985)}
.hero.in .hero-frame{animation:up 1.1s var(--e-out) .7s forwards}
.hero-frame .ph{position:relative;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow)}
.hero-frame img{width:100%;height:auto;aspect-ratio:16/9;object-fit:cover;filter:saturate(.92) contrast(1.04)}
.hero-frame .scrim{position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(8,8,10,.5));pointer-events:none}
.deco-corner{position:absolute;width:30px;height:30px;border:1.5px solid var(--champ);opacity:.8;z-index:2}
.deco-corner.tl{top:-9px;left:-9px;border-right:0;border-bottom:0}
.deco-corner.tr{top:-9px;right:-9px;border-left:0;border-bottom:0}
.deco-corner.bl{bottom:-9px;left:-9px;border-right:0;border-top:0}
.deco-corner.br{bottom:-9px;right:-9px;border-left:0;border-top:0}
.hero-chip{position:absolute;left:50%;bottom:1.1rem;transform:translateX(-50%);display:flex;align-items:center;gap:.6rem;flex-wrap:nowrap;white-space:nowrap;max-width:calc(100% - 1.6rem);
  background:rgba(10,10,12,.66);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--line);border-radius:100px;padding:.5em 1.15em;z-index:3}
.hero-chip .stars{color:var(--champ);letter-spacing:.16em;font-size:.76rem;flex:none}
.hero-chip .t{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hero-chip b{font-family:var(--display);font-size:.92rem}
.hero-chip small{color:var(--ink-faint);font-size:.7rem;letter-spacing:.04em}
@media(max-width:560px){
  .hero-chip{bottom:.65rem;gap:.5rem;padding:.4em .85em}
  .hero-chip .stars{font-size:.64rem}
  .hero-chip b{font-size:.78rem}
  .hero-chip .tail{display:none}
}

/* marquee */
.marquee{margin-top:clamp(2.8rem,6vw,4.4rem);border-block:1px solid var(--line-soft);padding-block:1.1rem;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee .track{display:flex;gap:2.6rem;width:max-content;animation:marq 34s linear infinite}
.marquee span{font-family:var(--display);font-style:italic;font-size:1.15rem;color:var(--ink-faint);display:inline-flex;align-items:center;gap:2.6rem;white-space:nowrap}
.marquee span::after{content:"♠";color:var(--champ);font-style:normal;font-size:.7em}
@keyframes marq{to{transform:translateX(-50%)}}

/* ---------------- ABOUT ---------------- */
.about-top{display:grid;grid-template-columns:1fr .82fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
@media(max-width:900px){.about-top{grid-template-columns:1fr}}
.about-manifesto{font-family:var(--display);font-size:clamp(1.7rem,3.6vw,2.7rem);line-height:1.18;letter-spacing:-.015em;text-wrap:balance}
.about-manifesto .accent{color:var(--champ-2);font-style:italic}
.about-body{margin-top:1.6rem;color:var(--ink-soft);max-width:54ch;display:grid;gap:1rem}
.about-figure{position:relative}
.about-figure .ph{position:relative;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow)}
.about-figure img{width:100%;height:auto;aspect-ratio:4/5;object-fit:cover;filter:saturate(.92) contrast(1.05)}
.about-figure .tag{position:absolute;top:1rem;left:1rem;font-family:var(--display);font-style:italic;font-size:1.05rem;color:var(--champ-2);background:rgba(10,10,12,.6);backdrop-filter:blur(8px);border:1px solid var(--line);border-radius:100px;padding:.3em 1em}
.about-figure .deco-corner{opacity:.75}

/* ritual strip */
.ritual{margin-top:clamp(3rem,6vw,4.5rem);display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;counter-reset:step}
@media(max-width:840px){.ritual{grid-template-columns:repeat(2,1fr)}}
@media(max-width:460px){.ritual{grid-template-columns:1fr}}
.ritual-step{position:relative;padding:1.6rem 1.4rem;border:1px solid var(--line);border-radius:var(--r);background:var(--surface);transition:border-color .3s var(--e),transform .3s var(--e),background .3s}
.ritual-step:hover{border-color:var(--line-strong);transform:translateY(-3px);background:var(--surface-2)}
.ritual-step .n{font-family:var(--display);font-size:1.5rem;color:var(--champ);display:flex;align-items:center;gap:.45rem}
.ritual-step .n .spade{width:.62em;height:.62em;fill:var(--champ);opacity:.7}
.ritual-step h3{font-size:1.18rem;margin:.7rem 0 .35rem;font-weight:500}
.ritual-step p{font-size:.88rem;color:var(--ink-faint);line-height:1.55}

/* ---------------- SERVICES (La Carta — playing cards) ---------------- */
.svc-head{display:flex;align-items:flex-end;justify-content:space-between;gap:1.5rem;flex-wrap:wrap;margin-bottom:clamp(2rem,4vw,3rem)}
.svc-deck{display:grid;grid-template-columns:repeat(6,1fr);gap:1.1rem}
.card{grid-column:span 3;position:relative;display:flex;flex-direction:column;
  border:1px solid var(--line);border-radius:var(--r);background:linear-gradient(180deg,var(--surface-2),var(--surface));
  padding:1.7rem 1.6rem;overflow:hidden;transition:transform .35s var(--e),border-color .35s var(--e),box-shadow .35s var(--e)}
.card::before{content:"";position:absolute;inset:0;border-radius:inherit;background:radial-gradient(120% 80% at 50% -10%,rgba(201,173,119,.10),transparent 60%);opacity:0;transition:opacity .35s}
.card:hover{transform:translateY(-6px);border-color:var(--line-strong);box-shadow:0 30px 60px -34px rgba(0,0,0,.9)}
.card:hover::before{opacity:1}
.card .pip{position:absolute;top:1.1rem;right:1.2rem;width:18px;height:18px;fill:var(--ink-faint);opacity:.5;transition:fill .35s,opacity .35s}
.card:hover .pip{fill:var(--champ);opacity:.9}
.card .idx{font-family:var(--display);font-style:italic;font-size:.95rem;color:var(--ink-faint)}
.card .card-name{font-family:var(--display);font-size:1.5rem;font-weight:500;line-height:1.1;margin:.5rem 0 .9rem;max-width:13ch}
.card .card-price{font-family:var(--display);font-size:2.15rem;font-weight:600;color:var(--champ-2);line-height:1;letter-spacing:-.01em}
.card .card-price .cur{font-size:.62em;color:var(--champ);vertical-align:.35em;margin-right:.08em}
.card .card-desc{margin-top:.9rem;font-size:.9rem;color:var(--ink-soft);line-height:1.55;flex:1}
.card .card-book{margin-top:1.3rem;display:inline-flex;align-items:center;gap:.5em;font-size:.72rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--champ);align-self:flex-start;transition:gap .3s var(--e),color .3s}
.card .card-book svg{width:1.1em;height:1.1em;transition:transform .3s var(--e)}
.card:hover .card-book{color:var(--champ-2)}
.card:hover .card-book svg{transform:translateX(4px)}

/* the Ace — featured */
.card.ace{grid-column:span 6;flex-direction:row;align-items:center;gap:2rem;
  border-color:var(--line-strong);background:
    radial-gradient(110% 160% at 8% 0%,rgba(201,173,119,.14),transparent 55%),
    linear-gradient(180deg,var(--surface-2),var(--surface))}
.card.ace .ace-body{flex:1;min-width:0}
.card.ace .card-name{font-size:clamp(1.8rem,3.4vw,2.6rem);max-width:none;margin-top:.2rem}
.card.ace .card-desc{max-width:52ch}
.card.ace .ace-price{text-align:right;flex:none;display:flex;flex-direction:column;align-items:flex-end;gap:1rem}
.card.ace .card-price{font-size:clamp(2.4rem,5vw,3.4rem)}
.card.ace .big-spade{position:absolute;right:-22px;top:50%;transform:translateY(-50%);width:230px;height:230px;fill:var(--champ);opacity:.05;pointer-events:none}
.card.ace .ace-tag{display:inline-flex;align-items:center;gap:.5em;font-size:.66rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:#171206;background:linear-gradient(135deg,var(--champ-2),var(--champ));padding:.4em 1em;border-radius:100px}
.card.ace .ace-tag .spade{width:.9em;height:.9em;fill:#171206}
@media(max-width:1080px){.svc-deck{grid-template-columns:repeat(4,1fr)}.card{grid-column:span 2}.card.ace{grid-column:span 4}}
@media(max-width:720px){.svc-deck{grid-template-columns:1fr}.card,.card.ace{grid-column:span 1}.card.ace{flex-direction:column;align-items:flex-start}.card.ace .ace-price{text-align:left;align-items:flex-start;width:100%}.card.ace .big-spade{display:none}}

.svc-note{display:flex;align-items:flex-start;gap:.7rem;margin-top:1.8rem;color:var(--ink-faint);font-size:.86rem;max-width:70ch}
.svc-note svg{width:1.1rem;height:1.1rem;flex:none;margin-top:.15rem;stroke:var(--champ)}

/* ---------------- GALLERY (masonry, hole-free) ---------------- */
.gal-grid{column-count:3;column-gap:1rem}
@media(max-width:860px){.gal-grid{column-count:2}}
@media(max-width:480px){.gal-grid{column-count:1}}
.gal-item{display:block;position:relative;overflow:hidden;border:1px solid var(--line);border-radius:var(--r);background:var(--bg-2);margin-bottom:1rem;break-inside:avoid;-webkit-column-break-inside:avoid}
.gal-item img{width:100%;height:auto;object-fit:cover;filter:saturate(.9) contrast(1.04);transition:transform .7s var(--e),filter .5s}
.gal-item:hover img{transform:scale(1.06);filter:saturate(1) contrast(1.06)}
.gal-item .cap{position:absolute;left:0;right:0;bottom:0;padding:1.6rem 1rem .9rem;font-size:.8rem;color:var(--ink);
  background:linear-gradient(180deg,transparent,rgba(8,8,10,.85));opacity:0;transform:translateY(8px);transition:opacity .4s var(--e),transform .4s var(--e)}
.gal-item .cap b{color:var(--champ-2);font-family:var(--display);font-style:italic}
.gal-item:hover .cap{opacity:1;transform:none}

/* ---------------- CONTACT ---------------- */
.contact-band{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(1.6rem,4vw,3.4rem);align-items:stretch}
@media(max-width:900px){.contact-band{grid-template-columns:1fr}}
.contact-main h2{font-size:clamp(2rem,5vw,3.4rem)}
.contact-lead{color:var(--ink-soft);margin:1.1rem 0 2rem;max-width:42ch}
.contact-lines{display:grid;gap:1.1rem;margin-bottom:2rem}
.cline{display:flex;align-items:flex-start;gap:1rem}
.cline .ic{flex:none;width:46px;height:46px;border:1px solid var(--line);border-radius:var(--r-sm);display:grid;place-items:center;color:var(--champ);background:var(--surface);transition:border-color .3s,background .3s}
.cline:hover .ic{border-color:var(--champ);background:rgba(201,173,119,.08)}
.cline .ic svg{width:20px;height:20px}
.cline .k{font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-faint);font-weight:600;margin-bottom:.2rem}
.cline .v{color:var(--ink);font-size:1.02rem;transition:color .25s}
.cline .v:hover{color:var(--champ-2)}
.socials{display:flex;gap:.7rem;margin-top:.4rem}
.socials a{width:46px;height:46px;border:1px solid var(--line);border-radius:var(--r-sm);display:grid;place-items:center;color:var(--ink-soft);transition:color .3s,border-color .3s,transform .3s,background .3s}
.socials a:hover{color:var(--champ-2);border-color:var(--champ);transform:translateY(-3px);background:rgba(201,173,119,.06)}
.socials svg{width:20px;height:20px}

.hours-card{border:1px solid var(--line);border-radius:var(--r-lg);background:linear-gradient(180deg,var(--surface-2),var(--surface));padding:clamp(1.5rem,3vw,2rem);display:flex;flex-direction:column}
.hours-card h3{display:flex;align-items:center;justify-content:space-between;gap:1rem;font-size:1.3rem;font-weight:500;flex-wrap:wrap}
.status{display:inline-flex;align-items:center;gap:.5em;font-family:var(--body);font-size:.66rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;padding:.4em .85em;border-radius:100px;border:1px solid var(--line)}
.status .dot{width:7px;height:7px;border-radius:50%;background:var(--ink-faint)}
.status.open{color:var(--ok);border-color:rgba(159,214,168,.4);background:rgba(159,214,168,.07)}
.status.open .dot{background:var(--ok);box-shadow:0 0 0 0 rgba(159,214,168,.5);animation:pulse 2.2s infinite}
.status.closed{color:var(--bad);border-color:rgba(233,138,138,.35)}
.status.closed .dot{background:var(--bad)}
@keyframes pulse{70%{box-shadow:0 0 0 8px rgba(159,214,168,0)}100%{box-shadow:0 0 0 0 rgba(159,214,168,0)}}
.hours-card ul{list-style:none;margin:1.4rem 0 0;display:grid;gap:.1rem}
.hours-card li{display:flex;justify-content:space-between;gap:1rem;padding:.6rem .2rem;border-bottom:1px solid var(--line-soft);font-size:.92rem}
.hours-card li:last-child{border-bottom:0}
.hours-card li .d{color:var(--ink-soft)}
.hours-card li .h{color:var(--ink);font-variant-numeric:tabular-nums}
.hours-card li.today{color:var(--champ-2)}
.hours-card li.today .d,.hours-card li.today .h{color:var(--champ-2);font-weight:600}
.hours-card .book-row{margin-top:1.6rem}
.hours-card .book-row .btn{width:100%}

/* ---------------- FAQ ---------------- */
.faq-grid{display:grid;gap:.7rem;max-width:860px;margin-inline:auto}
.faq-item{border:1px solid var(--line);border-radius:var(--r);background:var(--surface);overflow:hidden;transition:border-color .3s}
.faq-item[open]{border-color:var(--line-strong)}
.faq-item summary{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.25rem 1.5rem;cursor:pointer;list-style:none;font-family:var(--display);font-size:1.18rem;font-weight:500}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item .pm{flex:none;width:22px;height:22px;position:relative}
.faq-item .pm::before,.faq-item .pm::after{content:"";position:absolute;left:50%;top:50%;width:13px;height:1.6px;background:var(--champ);transform:translate(-50%,-50%);transition:transform .3s var(--e)}
.faq-item .pm::after{transform:translate(-50%,-50%) rotate(90deg)}
.faq-item[open] .pm::after{transform:translate(-50%,-50%) rotate(0)}
.faq-item .ans{padding:0 1.5rem 1.4rem;color:var(--ink-soft);font-size:.96rem;line-height:1.65}

/* ---------------- BLOG ---------------- */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
@media(max-width:860px){.blog-grid{grid-template-columns:1fr}}
.post{border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:var(--surface);transition:transform .35s var(--e),border-color .35s}
.post:hover{transform:translateY(-5px);border-color:var(--line-strong)}
.post .ph{overflow:hidden;border-bottom:1px solid var(--line)}
.post .ph img{width:100%;height:auto;aspect-ratio:3/2;object-fit:cover;filter:saturate(.9) contrast(1.04);transition:transform .7s var(--e)}
.post:hover .ph img{transform:scale(1.05)}
.post .body{padding:1.5rem}
.post .kicker{font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--champ);font-weight:600}
.post h3{font-size:1.32rem;font-weight:500;margin:.7rem 0 .6rem;line-height:1.2}
.post p{font-size:.9rem;color:var(--ink-soft);line-height:1.6}
.post .more{display:inline-flex;align-items:center;gap:.5em;margin-top:1.1rem;font-size:.72rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--champ)}
.post .more svg{width:1.1em;height:1.1em;transition:transform .3s var(--e)}
.post:hover .more svg{transform:translateX(4px)}

/* ---------------- FOOTER ---------------- */
.footer{position:relative;z-index:1;border-top:1px solid var(--line);padding-block:clamp(3rem,6vw,5rem) 2rem;margin-top:2rem}
.footer-big{font-family:var(--display);font-size:clamp(3.4rem,13vw,9rem);line-height:.85;text-align:center;letter-spacing:.02em;
  background:linear-gradient(180deg,rgba(242,239,232,.16),rgba(201,173,119,.06));-webkit-background-clip:text;background-clip:text;color:transparent;margin-bottom:2.5rem}
.footer-big .spade{display:inline-block;width:.5em;height:.5em;fill:var(--champ);opacity:.7;vertical-align:.06em}
.footer-cols{display:grid;grid-template-columns:1.4fr repeat(3,1fr);gap:2rem;padding-bottom:2.5rem;border-bottom:1px solid var(--line-soft)}
@media(max-width:780px){.footer-cols{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.footer-cols{grid-template-columns:1fr}}
.footer-cols h4{font-family:var(--body);font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--champ);font-weight:600;margin-bottom:1rem}
.footer-cols .col>span{color:var(--ink-faint);font-size:.9rem;line-height:1.6;display:block}
.footer-cols .col a{display:block;color:var(--ink-soft);font-size:.92rem;padding:.28rem 0;transition:color .25s}
.footer-cols .col a:hover{color:var(--champ-2)}
.footer-bottom{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;padding-top:1.6rem;color:var(--ink-faint);font-size:.8rem}

/* ---------------- WhatsApp float ---------------- */
.wa-float{position:fixed;right:1.2rem;bottom:1.2rem;z-index:50;width:56px;height:56px;border-radius:50%;display:grid;place-items:center;
  background:#1faf54;color:#fff;box-shadow:0 14px 34px -12px rgba(31,175,84,.7);transition:transform .3s var(--e),box-shadow .3s}
.wa-float:hover{transform:translateY(-3px) scale(1.05)}
.wa-float svg{width:30px;height:30px;fill:#fff}

/* ---------------- Booking modal ---------------- */
.modal{position:fixed;inset:0;z-index:100;display:none;align-items:center;justify-content:center;padding:1.2rem}
.modal.open{display:flex}
.modal-backdrop{position:absolute;inset:0;background:rgba(6,6,8,.72);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);animation:fade .3s var(--e)}
.modal-card{position:relative;width:min(560px,100%);max-height:92dvh;overflow-y:auto;background:linear-gradient(180deg,var(--bg-2),var(--bg));border:1px solid var(--line-strong);border-radius:var(--r-lg);padding:clamp(1.6rem,4vw,2.6rem);box-shadow:var(--shadow);animation:pop .4s var(--e-out)}
@keyframes pop{from{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:none}}
.modal-close{position:absolute;top:1rem;right:1rem;width:38px;height:38px;border:1px solid var(--line);border-radius:var(--r-sm);display:grid;place-items:center;color:var(--ink-soft);transition:color .25s,border-color .25s}
.modal-close:hover{color:var(--champ-2);border-color:var(--champ)}
.modal-card h3{font-size:1.7rem;margin:.5rem 0 .4rem}
.modal-card .sub{color:var(--ink-soft);font-size:.92rem;margin-bottom:1.5rem}
.bk-field{margin-bottom:1.2rem}
.bk-field>label{display:block;font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--champ);font-weight:600;margin-bottom:.6rem}
.bk-select,.field input{width:100%;background:rgba(255,255,255,.03);border:1px solid var(--line);border-radius:var(--r-sm);color:var(--ink);padding:.85em 1em;font-family:var(--body);font-size:.95rem;transition:border-color .25s,background .25s}
.bk-select:focus,.field input:focus{outline:none;border-color:var(--champ);background:rgba(201,173,119,.05)}
.bk-select option,.bk-select optgroup{background:var(--bg-2);color:var(--ink)}
.field{display:flex;flex-direction:column}
.field>label{font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--champ);font-weight:600;margin-bottom:.5rem}
.field.row,.row{display:grid;grid-template-columns:1fr 1fr;gap:.9rem;margin-bottom:1.2rem}
@media(max-width:460px){.row{grid-template-columns:1fr}}

/* calendar */
.cal{border:1px solid var(--line);border-radius:var(--r);padding:1rem;background:var(--surface)}
.cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:.8rem}
.cal-head b{font-family:var(--display);font-size:1.1rem}
.cal-head button{width:34px;height:34px;border:1px solid var(--line);border-radius:var(--r-sm);display:grid;place-items:center;color:var(--ink-soft);transition:.2s}
.cal-head button:hover:not(:disabled){border-color:var(--champ);color:var(--champ-2)}
.cal-head button:disabled{opacity:.3;cursor:not-allowed}
.cal-dow{display:grid;grid-template-columns:repeat(7,1fr);gap:3px;margin-bottom:4px}
.cal-dow span{text-align:center;font-size:.62rem;letter-spacing:.1em;color:var(--ink-faint);text-transform:uppercase;padding:.4em 0}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}
.cal-cell{aspect-ratio:1;border:0;background:transparent;border-radius:var(--r-sm);color:var(--ink-soft);font-size:.86rem;font-variant-numeric:tabular-nums;display:grid;place-items:center;transition:background .18s,color .18s}
.cal-cell.empty{pointer-events:none}
.cal-cell:not(.dis):not(.empty):hover{background:var(--surface-2);color:var(--ink)}
.cal-cell.today{box-shadow:inset 0 0 0 1px var(--line-strong);color:var(--ink)}
.cal-cell.dis{color:rgba(255,255,255,.14);cursor:not-allowed}
.cal-cell.sel{background:linear-gradient(135deg,var(--champ-2),var(--champ));color:#171206;font-weight:700}

/* time grid */
.time-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(78px,1fr));gap:.5rem}
.time-empty{grid-column:1/-1;color:var(--ink-faint);font-size:.88rem;text-align:center;padding:1.2rem .5rem}
.time-slot{border:1px solid var(--line);border-radius:var(--r-sm);padding:.7em .4em;font-size:.82rem;font-variant-numeric:tabular-nums;color:var(--ink-soft);transition:.2s}
.time-slot:hover{border-color:var(--champ);color:var(--ink)}
.time-slot.sel{background:linear-gradient(135deg,var(--champ-2),var(--champ));color:#171206;font-weight:700;border-color:transparent}

.bk-summary{border:1px dashed var(--line-strong);border-radius:var(--r-sm);padding:.9rem 1.1rem;margin-bottom:1.1rem;display:flex;flex-direction:column;gap:.2rem}
.bk-summary .bs-when{font-family:var(--display);font-size:1.05rem;color:var(--champ-2)}
.bk-summary .bs-svc{font-size:.86rem;color:var(--ink-soft)}
.form-msg{font-size:.86rem;min-height:1.2em;margin-bottom:.6rem;color:var(--ink-faint)}
.form-msg.err{color:var(--bad)}
.form-msg.err.show,.form-msg.show{display:block}
#bookForm .btn-primary{width:100%}
.form-alt{text-align:center;margin-top:1rem;font-size:.86rem;color:var(--ink-faint)}
.form-alt a{color:var(--champ-2);text-decoration:underline;font-weight:600}

.bk-success{display:none;text-align:center;padding:1rem 0}
.bk-success.show{display:block;animation:fade .4s var(--e)}
.bk-ok{width:64px;height:64px;border-radius:50%;display:grid;place-items:center;margin:0 auto 1.2rem;color:#171206;background:linear-gradient(135deg,var(--champ-2),var(--champ))}
.bk-recap{text-align:left;border:1px solid var(--line);border-radius:var(--r);margin:1.4rem 0;overflow:hidden}
.bk-recap div{display:flex;justify-content:space-between;gap:1rem;padding:.8rem 1.1rem;border-bottom:1px solid var(--line-soft);font-size:.92rem}
.bk-recap div:last-child{border-bottom:0}
.bk-recap span:first-child{color:var(--ink-faint);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;align-self:center}
.bk-recap span:last-child{color:var(--ink);text-align:right}
.bk-success-cta{display:flex;gap:.7rem;justify-content:center;flex-wrap:wrap}

/* ---------------- Motion ---------------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .9s var(--e-out),transform .9s var(--e-out)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.1s}.reveal[data-d="2"]{transition-delay:.2s}.reveal[data-d="3"]{transition-delay:.3s}
@keyframes up{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}
@keyframes fade{from{opacity:0}to{opacity:1}}

@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important;scroll-behavior:auto !important}
  .reveal,.hero .eyebrow,.crest,.hero-title,.hero-sub,.hero-cta,.hero-frame{opacity:1 !important;transform:none !important}
  .marquee .track{animation:none}
  .crest .as::after{animation:none;display:none}
}
