/* ===== Fox Cigar Bar — Gilbert, AZ ===== */
:root{
  --ink:#15110d;
  --ink-2:#1d1813;
  --leather:#5a3a22;
  --leather-2:#7a4f2e;
  --gold:#c79a4b;
  --gold-2:#e0bd6d;
  --cream:#e9e0d2;
  --muted:#b3a48f;
  --line:rgba(199,154,75,0.18);
  --card:#211a13;
  --card-2:#261d15;
  --maxw:1180px;
  --shadow:0 24px 60px rgba(0,0,0,.55);
  --r:16px;
  --serif:"Cormorant Garamond",Georgia,serif;
  --sans:"Inter",system-ui,-apple-system,sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  color:var(--cream);
  background:var(--ink);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 22px}

h1,h2,h3{font-family:var(--serif);font-weight:600;line-height:1.05;color:var(--cream);letter-spacing:.2px}
h2{font-size:clamp(2rem,4.4vw,3.2rem)}
h3{font-size:1.35rem}

.eyebrow,.hero__eyebrow{
  font-family:var(--sans);
  text-transform:uppercase;
  letter-spacing:.32em;
  font-size:.72rem;
  font-weight:600;
  color:var(--gold);
}

/* ===== Buttons ===== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  gap:.5em;
  padding:.95em 1.7em;
  border-radius:999px;
  font-family:var(--sans);
  font-weight:600;
  font-size:.95rem;
  letter-spacing:.02em;
  cursor:pointer;
  border:1.5px solid transparent;
  transition:transform .25s ease,box-shadow .25s ease,background .25s ease,color .25s ease,border-color .25s ease;
  white-space:nowrap;
}
.btn--gold{
  background:linear-gradient(135deg,var(--gold-2),var(--gold));
  color:#211504;
  box-shadow:0 10px 28px rgba(199,154,75,.28);
}
.btn--gold:hover{transform:translateY(-2px);box-shadow:0 16px 36px rgba(199,154,75,.42)}
.btn--ghost{
  background:transparent;
  color:var(--cream);
  border-color:var(--line);
}
.btn--ghost:hover{border-color:var(--gold);color:var(--gold-2);transform:translateY(-2px)}
.btn--block{display:flex;width:100%;margin-top:.7rem}

/* ===== Header ===== */
.header{
  position:sticky;top:0;z-index:60;
  background:rgba(21,17,13,.72);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
  transition:background .3s ease,box-shadow .3s ease;
}
.header.scrolled{background:rgba(17,13,9,.94);box-shadow:0 10px 30px rgba(0,0,0,.45)}
.header__inner{display:flex;align-items:center;justify-content:space-between;height:72px;gap:1rem}
.brand{display:flex;align-items:center;gap:.6rem}
.brand__mark{width:38px;height:38px;flex:none}
.brand__text{display:flex;flex-direction:column;line-height:1}
.brand__text strong{font-family:var(--serif);font-size:1.35rem;letter-spacing:.22em;color:var(--cream)}
.brand__text em{font-style:normal;font-size:.62rem;letter-spacing:.34em;text-transform:uppercase;color:var(--gold)}

.nav{display:flex;gap:1.9rem}
.nav a{
  font-size:.9rem;font-weight:500;color:var(--muted);
  position:relative;padding:.2rem 0;transition:color .2s ease;
}
.nav a::after{content:"";position:absolute;left:0;bottom:-2px;height:1.5px;width:0;background:var(--gold);transition:width .25s ease}
.nav a:hover{color:var(--cream)}
.nav a:hover::after{width:100%}
.header__cta{padding:.65em 1.2em;font-size:.85rem}

/* ===== Hero ===== */
.hero{
  position:relative;
  padding:clamp(4.5rem,11vw,9rem) 0 clamp(3.5rem,8vw,6rem);
  background:
    radial-gradient(circle at 50% 0%,rgba(90,58,34,.5),transparent 60%),
    linear-gradient(180deg,var(--ink-2),var(--ink));
  overflow:hidden;
  text-align:center;
}
.hero__glow{
  position:absolute;inset:0;
  background:radial-gradient(ellipse 60% 50% at 50% 35%,rgba(199,154,75,.16),transparent 70%);
  pointer-events:none;
}
.hero__inner{position:relative;max-width:880px;margin:0 auto}
.hero__eyebrow{margin-bottom:1.1rem}
.hero__title{font-size:clamp(2.8rem,8vw,5.6rem);margin-bottom:1.3rem}
.hero__sub{font-size:clamp(1.05rem,2.2vw,1.3rem);color:var(--muted);max-width:620px;margin:0 auto 2.1rem}
.hero__cta{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-bottom:1.6rem}
.hero__trust{font-size:.85rem;color:var(--muted);letter-spacing:.04em}

/* ===== Trust bar ===== */
.trustbar{
  background:var(--ink-2);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.trustbar__inner{
  display:flex;flex-wrap:wrap;justify-content:center;gap:.6rem 2.6rem;
  padding:1.1rem 22px;
}
.trustbar__item span{
  font-size:.82rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;
  color:var(--muted);
}
.trustbar__item{display:flex;align-items:center;gap:.6rem;position:relative}
.trustbar__item::before{content:"◆";color:var(--gold);font-size:.6rem}

/* ===== Sections ===== */
.section{padding:clamp(3.8rem,8vw,6.5rem) 0}
.section--alt{background:linear-gradient(180deg,var(--ink),var(--ink-2))}
.section__head{max-width:680px;margin:0 auto clamp(2.2rem,5vw,3.4rem);text-align:center}
.section__head .eyebrow{display:inline-block;margin-bottom:.9rem}
.section__head h2{margin-bottom:1rem}
.section__lead{color:var(--muted);font-size:1.08rem}

/* ===== Grids ===== */
.grid{display:grid;gap:1.3rem}
.grid--services{grid-template-columns:repeat(3,1fr)}
.grid--quotes{grid-template-columns:repeat(3,1fr)}

.card{
  background:linear-gradient(165deg,var(--card-2),var(--card));
  border:1px solid var(--line);
  border-radius:var(--r);
  padding:2rem 1.7rem;
  transition:transform .3s ease,border-color .3s ease,box-shadow .3s ease;
}
.card:hover{transform:translateY(-6px);border-color:rgba(199,154,75,.5);box-shadow:var(--shadow)}
.card__icon{
  display:inline-flex;width:58px;height:58px;align-items:center;justify-content:center;
  border-radius:14px;background:rgba(199,154,75,.1);border:1px solid var(--line);
  margin-bottom:1.1rem;
}
.card__icon svg{width:34px;height:34px}
.card h3{margin-bottom:.55rem}
.card p{color:var(--muted);font-size:.96rem}

/* ===== Why ===== */
.why{display:grid;grid-template-columns:1.15fr .85fr;gap:3rem;align-items:center}
.why h2{margin:.7rem 0 1rem}
.why__copy>p{color:var(--muted);margin-bottom:1.6rem}
.why__list{list-style:none;display:flex;flex-direction:column;gap:1.1rem;margin-bottom:2rem}
.why__list li{display:flex;gap:.9rem;align-items:flex-start}
.why__list div{color:var(--muted);font-size:.98rem}
.why__list strong{color:var(--cream);font-weight:600}
.why__dot{flex:none;width:11px;height:11px;margin-top:.45rem;border-radius:50%;background:linear-gradient(135deg,var(--gold-2),var(--gold));box-shadow:0 0 12px rgba(199,154,75,.6)}
.why__stats{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.stat{
  background:linear-gradient(165deg,var(--card-2),var(--card));
  border:1px solid var(--line);border-radius:var(--r);
  padding:1.7rem 1.3rem;text-align:center;
}
.stat__num{display:block;font-family:var(--serif);font-size:2.4rem;font-weight:600;color:var(--gold-2);line-height:1}
.stat__label{display:block;margin-top:.5rem;font-size:.82rem;color:var(--muted);letter-spacing:.04em}

/* ===== Showcase scene ===== */
.scene{
  position:relative;
  height:clamp(320px,46vw,440px);
  border-radius:22px;
  overflow:hidden;
  border:1px solid var(--line);
  background:
    radial-gradient(ellipse 50% 60% at 50% 25%,rgba(199,154,75,.22),transparent 60%),
    radial-gradient(ellipse 70% 80% at 50% 120%,rgba(90,58,34,.5),transparent 60%),
    linear-gradient(180deg,#0f0c08,#1a140e);
  box-shadow:var(--shadow);
}
.scene__lamp{
  position:absolute;top:-30%;left:50%;transform:translateX(-50%);
  width:60%;height:80%;
  background:radial-gradient(ellipse 50% 60% at 50% 0%,rgba(224,189,109,.35),transparent 65%);
  pointer-events:none;
}
.scene__floor{
  position:absolute;left:0;right:0;bottom:0;height:34%;
  background:linear-gradient(180deg,transparent,rgba(0,0,0,.55));
}
.scene__glass{
  position:absolute;bottom:14%;left:18%;width:clamp(110px,18vw,170px);
  filter:drop-shadow(0 14px 22px rgba(0,0,0,.6));
}
.scene__cigar{
  position:absolute;bottom:9%;right:14%;width:clamp(170px,28vw,260px);
  filter:drop-shadow(0 14px 22px rgba(0,0,0,.6));
}
.scene__smoke{position:absolute;inset:0;width:100%;height:100%}
.scene__smoke path{
  fill:none;stroke:rgba(233,224,210,.28);stroke-width:3;stroke-linecap:round;
  stroke-dasharray:6 12;
  animation:smokeRise 7s linear infinite;
}
.scene__smoke path:nth-child(2){animation-duration:9s;animation-delay:-2s;stroke:rgba(233,224,210,.18)}
@keyframes smokeRise{
  from{stroke-dashoffset:0;opacity:.7}
  50%{opacity:.35}
  to{stroke-dashoffset:-220;opacity:.7}
}
.showcase__tags{display:flex;flex-wrap:wrap;gap:.7rem;justify-content:center;margin-top:1.8rem}
.showcase__tags span{
  font-size:.8rem;letter-spacing:.06em;color:var(--muted);
  border:1px solid var(--line);border-radius:999px;padding:.45rem 1rem;
  background:rgba(199,154,75,.05);
}

/* ===== Quotes ===== */
.quote{
  background:linear-gradient(165deg,var(--card-2),var(--card));
  border:1px solid var(--line);border-radius:var(--r);
  padding:2rem 1.8rem;position:relative;
}
.quote::before{
  content:"\201C";font-family:var(--serif);font-size:4rem;color:var(--gold);
  position:absolute;top:.1rem;left:1.1rem;opacity:.4;line-height:1;
}
.quote blockquote{font-family:var(--serif);font-size:1.22rem;line-height:1.45;color:var(--cream);margin:1.4rem 0 1rem;font-style:italic}
.quote figcaption{font-size:.85rem;color:var(--gold-2);letter-spacing:.06em;font-weight:600}
.quote__note{text-align:center;margin-top:1.6rem;font-size:.78rem;color:var(--muted);opacity:.8}

/* ===== FAQ ===== */
.faq{max-width:780px;margin:0 auto}
.faq__list{display:flex;flex-direction:column;gap:.9rem}
.faq__item{
  background:linear-gradient(165deg,var(--card-2),var(--card));
  border:1px solid var(--line);border-radius:14px;
  padding:0 1.4rem;overflow:hidden;
}
.faq__item summary{
  cursor:pointer;list-style:none;padding:1.25rem 0;
  font-family:var(--serif);font-size:1.2rem;font-weight:600;color:var(--cream);
  display:flex;justify-content:space-between;align-items:center;gap:1rem;
}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary::after{
  content:"+";color:var(--gold);font-size:1.6rem;font-weight:300;
  transition:transform .25s ease;flex:none;line-height:1;
}
.faq__item[open] summary::after{transform:rotate(45deg)}
.faq__item p{color:var(--muted);padding-bottom:1.3rem;font-size:.97rem;max-width:62ch}

/* ===== CTA band ===== */
.ctaband{
  padding:clamp(3.5rem,7vw,5.5rem) 0;
  background:
    radial-gradient(ellipse 60% 120% at 50% 0%,rgba(199,154,75,.2),transparent 60%),
    linear-gradient(135deg,var(--leather),var(--ink-2));
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  text-align:center;
}
.ctaband__inner{max-width:640px;margin:0 auto}
.ctaband h2{margin-bottom:.8rem}
.ctaband p{color:var(--cream);opacity:.85;margin-bottom:1.8rem;font-size:1.05rem}
.ctaband__btns{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* ===== Contact ===== */
.contact{display:grid;grid-template-columns:1.1fr .9fr;gap:2.6rem;align-items:start}
.contact h2{margin:.7rem 0 1rem}
.contact__copy>p{color:var(--muted);margin-bottom:1.7rem}
.contact__list{list-style:none;display:flex;flex-direction:column;gap:1.15rem}
.contact__list li{display:flex;flex-direction:column;gap:.2rem}
.contact__label{font-size:.72rem;text-transform:uppercase;letter-spacing:.22em;color:var(--gold)}
.contact__list a,.contact__list span:not(.contact__label){font-size:1.05rem;color:var(--cream)}
.contact__list a:hover{color:var(--gold-2)}
.contact__card{
  background:linear-gradient(165deg,var(--card-2),var(--card));
  border:1px solid var(--line);border-radius:var(--r);
  padding:2.2rem 2rem;box-shadow:var(--shadow);
}
.contact__card h3{margin-bottom:.6rem}
.contact__card>p{color:var(--muted);font-size:.95rem;margin-bottom:1.3rem}
.contact__fineprint{margin-top:1.3rem;font-size:.78rem;color:var(--muted);text-align:center;opacity:.85}

/* ===== Footer ===== */
.footer{background:var(--ink-2);border-top:1px solid var(--line);padding-top:3rem}
.footer__inner{display:grid;grid-template-columns:1.4fr 1fr;gap:2rem;padding-bottom:2rem}
.footer__brand .brand__text{margin-bottom:1rem}
.footer__brand p{color:var(--muted);font-size:.92rem;max-width:42ch;margin-bottom:.6rem}
.footer__age{color:var(--gold);font-size:.82rem;letter-spacing:.04em}
.footer__nav{display:flex;flex-direction:column;gap:.7rem;align-items:flex-start}
.footer__nav a{color:var(--muted);font-size:.92rem;transition:color .2s ease}
.footer__nav a:hover{color:var(--gold-2)}
.footer__bottom{
  display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;
  border-top:1px solid var(--line);padding:1.4rem 22px;
  font-size:.82rem;color:var(--muted);
}
.footer__credit a{color:var(--gold-2);font-weight:600}
.footer__credit a:hover{text-decoration:underline}

/* ===== Mobile call bar ===== */
.mobilebar{
  position:fixed;left:0;right:0;bottom:0;z-index:70;
  display:none;gap:.6rem;padding:.6rem .7rem calc(.6rem + env(safe-area-inset-bottom));
  background:rgba(17,13,9,.96);backdrop-filter:blur(10px);
  border-top:1px solid var(--line);
}
.mobilebar__btn{
  flex:1;text-align:center;padding:.9rem;border-radius:12px;font-weight:600;font-size:.95rem;
}
.mobilebar__btn--call{background:linear-gradient(135deg,var(--gold-2),var(--gold));color:#211504}
.mobilebar__btn--reserve{background:transparent;border:1.5px solid var(--line);color:var(--cream)}

/* ===== Intro overlay ===== */
.intro{
  position:fixed;inset:0;z-index:100;
  display:flex;align-items:center;justify-content:center;
  background:radial-gradient(ellipse 60% 60% at 50% 45%,#241b12,#0c0906 75%);
  transition:opacity .7s ease,visibility .7s ease;
}
.intro.is-hidden{opacity:0;visibility:hidden;pointer-events:none}
.intro__skip{
  position:absolute;top:1.4rem;right:1.4rem;
  background:transparent;border:1px solid var(--line);color:var(--muted);
  padding:.5rem 1.1rem;border-radius:999px;font-family:var(--sans);
  font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;
  transition:color .2s ease,border-color .2s ease;
}
.intro__skip:hover{color:var(--gold-2);border-color:var(--gold)}
.intro__stage{text-align:center;padding:1rem}
.intro__art{width:min(360px,72vw);height:auto;margin:0 auto}
.intro__fox{opacity:0;transform-origin:center;animation:foxIn 1s ease .2s forwards}
@keyframes foxIn{
  0%{opacity:0;transform:translateY(14px) scale(.94)}
  100%{opacity:1;transform:translateY(0) scale(1)}
}
.intro__smoke path{
  fill:none;stroke:rgba(233,224,210,.55);stroke-width:3;stroke-linecap:round;
  stroke-dasharray:240;stroke-dashoffset:240;
  animation:smokeDraw 2.2s ease forwards;
}
.intro__smoke path:nth-child(2){animation-delay:.25s}
.intro__smoke path:nth-child(3){animation-delay:.5s}
@keyframes smokeDraw{
  0%{stroke-dashoffset:240;opacity:0}
  40%{opacity:.9}
  100%{stroke-dashoffset:-40;opacity:0}
}
.intro__word{margin-top:.6rem;opacity:0;animation:wordIn .9s ease 1s forwards}
@keyframes wordIn{
  0%{opacity:0;transform:translateY(12px);letter-spacing:.5em;filter:blur(6px)}
  100%{opacity:1;transform:translateY(0);letter-spacing:.22em;filter:blur(0)}
}
.intro__name{display:block;font-family:var(--serif);font-size:clamp(2.6rem,9vw,4.2rem);font-weight:700;color:var(--gold-2);letter-spacing:.22em}
.intro__sub{display:block;font-family:var(--sans);font-size:.8rem;letter-spacing:.5em;text-transform:uppercase;color:var(--cream);margin-top:.4rem}

/* ===== Reveal ===== */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease}
.reveal.is-visible{opacity:1;transform:none}

/* ===== Responsive ===== */
@media(max-width:960px){
  .grid--services,.grid--quotes{grid-template-columns:1fr 1fr}
  .why{grid-template-columns:1fr;gap:2.2rem}
  .contact{grid-template-columns:1fr;gap:2rem}
  .nav{display:none}
}
@media(max-width:680px){
  .grid--services,.grid--quotes,.why__stats{grid-template-columns:1fr}
  .header__cta{display:none}
  .footer__inner{grid-template-columns:1fr}
  .footer__bottom{justify-content:center;text-align:center}
  .mobilebar{display:flex}
  body{padding-bottom:74px}
  .trustbar__inner{gap:.5rem 1.4rem}
}

/* ===== Reduced motion ===== */
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
  .intro{display:none!important}
}
