/* ============================================================
   Renegade Coffee — Mesa, AZ
   Palette: espresso brown + warm cream + copper accent
   ============================================================ */

:root{
  --espresso:#2a1a12;
  --espresso-2:#3b2417;
  --bean:#1c110b;
  --cream:#f4e9d8;
  --cream-2:#faf3e6;
  --latte:#c9a97e;
  --copper:#b87333;
  --copper-2:#c98a52;
  --copper-deep:#8f5522;
  --ink:#241812;
  --muted:#7a6252;
  --line:rgba(42,26,18,.12);
  --line-light:rgba(244,233,216,.16);

  --maxw:1180px;
  --radius:16px;
  --radius-sm:10px;
  --shadow:0 18px 40px -18px rgba(28,17,11,.4);
  --shadow-sm:0 8px 22px -12px rgba(28,17,11,.35);

  --f-display:'Bebas Neue', 'Sora', system-ui, sans-serif;
  --f-body:'Sora', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;

  --ease:cubic-bezier(.2,.7,.2,1);
}

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

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

h1,h2,h3{margin:0;line-height:1.05;letter-spacing:.5px}
h1{font-family:var(--f-display);font-weight:400;font-size:clamp(2.9rem,8vw,5.6rem);letter-spacing:1px}
h2{font-family:var(--f-display);font-weight:400;font-size:clamp(2rem,5vw,3.3rem);letter-spacing:1px}
h3{font-weight:700;font-size:1.18rem;letter-spacing:0}
p{margin:0}

.eyebrow{
  font-weight:700;text-transform:uppercase;letter-spacing:.22em;
  font-size:.72rem;color:var(--copper-deep);margin-bottom:.7rem;
}
.eyebrow--copper{color:var(--copper-2)}

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--copper);--fg:#fff;
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  padding:.85rem 1.5rem;border-radius:999px;font-weight:700;font-size:.98rem;
  background:var(--bg);color:var(--fg);border:2px solid transparent;
  cursor:pointer;transition:transform .18s var(--ease),box-shadow .18s var(--ease),background .18s;
  box-shadow:var(--shadow-sm);white-space:nowrap;
}
.btn:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.btn--copper{background:var(--copper);color:#fff}
.btn--copper:hover{background:var(--copper-2)}
.btn--cream{background:var(--cream);color:var(--espresso)}
.btn--cream:hover{background:#fff}
.btn--ghost{background:transparent;color:var(--espresso);border-color:var(--espresso);box-shadow:none}
.btn--ghost:hover{background:var(--espresso);color:var(--cream)}
.btn--ghost-light{color:var(--cream);border-color:var(--cream)}
.btn--ghost-light:hover{background:var(--cream);color:var(--espresso)}

/* ---------- Header ---------- */
.hdr{
  position:sticky;top:0;z-index:60;
  background:rgba(250,243,230,.86);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
}
.hdr__inner{display:flex;align-items:center;gap:1.5rem;height:66px}
.brand{display:flex;align-items:center;gap:.6rem}
.brand__mark{flex:none;border-radius:10px}
.brand__type{
  font-family:var(--f-display);font-size:1.5rem;letter-spacing:1.5px;
  line-height:.85;color:var(--espresso);display:flex;flex-direction:column;
}
.brand__sub{font-size:.62rem;letter-spacing:.45em;color:var(--copper-deep)}
.nav{display:none;gap:1.6rem;margin-left:auto;font-weight:600;font-size:.94rem}
.nav a{color:var(--espresso-2);position:relative;padding:.25rem 0}
.nav a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--copper);transition:width .22s var(--ease)}
.nav a:hover{color:var(--copper-deep)}
.nav a:hover::after{width:100%}
.hdr__cta{margin-left:auto;padding:.6rem 1.1rem;font-size:.9rem}

@media(min-width:900px){
  .nav{display:flex}
  .hdr__cta{margin-left:0}
}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden;color:var(--cream);
  background:linear-gradient(160deg,var(--espresso) 0%,var(--espresso-2) 55%,#4a2c1a 100%);
}
.hero__bg{position:absolute;inset:0;opacity:.5;pointer-events:none;
  background:
    radial-gradient(700px 420px at 82% -8%,rgba(184,115,51,.4),transparent 60%),
    radial-gradient(560px 420px at 10% 110%,rgba(201,169,126,.18),transparent 60%);
}
.hero__bg::after{content:"";position:absolute;inset:0;
  background-image:radial-gradient(rgba(244,233,216,.06) 1px,transparent 1px);
  background-size:26px 26px;mask:linear-gradient(180deg,#000,transparent 85%)}
.hero__inner{position:relative;padding:clamp(3.5rem,9vw,6.5rem) 0 clamp(3rem,7vw,5rem);max-width:840px}
.hero .eyebrow{color:var(--copper-2)}
.hero h1 .hl{color:var(--copper-2)}
.hero__sub{margin-top:1.3rem;font-size:clamp(1.02rem,2.2vw,1.28rem);color:rgba(244,233,216,.9);max-width:640px}
.hero__cta{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:2rem}
.hero .btn--ghost{color:var(--cream);border-color:var(--cream)}
.hero .btn--ghost:hover{background:var(--cream);color:var(--espresso)}
.trustline{margin-top:1.8rem;font-size:.85rem;color:rgba(244,233,216,.7);letter-spacing:.02em}

/* ---------- Trust bar ---------- */
.trustbar{background:var(--bean);color:var(--cream)}
.trustbar__inner{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line-light)}
.trustbar__item{background:var(--bean);padding:1.3rem 1.1rem;display:flex;flex-direction:column;gap:.15rem;text-align:center}
.trustbar__item strong{font-family:var(--f-display);font-size:1.35rem;letter-spacing:1px;color:var(--copper-2)}
.trustbar__item span{font-size:.82rem;color:rgba(244,233,216,.72)}
@media(min-width:760px){.trustbar__inner{grid-template-columns:repeat(4,1fr)}}

/* ---------- Sections ---------- */
.section{padding:clamp(3.5rem,8vw,6rem) 0}
.section--dark{background:linear-gradient(180deg,var(--espresso) 0%,var(--espresso-2) 100%);color:var(--cream)}
.section--cream{background:var(--cream)}
.section__head{max-width:640px;margin-bottom:2.6rem}
.section--dark .section__head h2{color:var(--cream)}
.section__lead{margin-top:.9rem;color:var(--muted);font-size:1.05rem}
.section--dark .section__lead{color:rgba(244,233,216,.8)}

/* ---------- Grids ---------- */
.grid{display:grid;gap:1.1rem}
.grid--menu{grid-template-columns:1fr}
.grid--why{grid-template-columns:1fr}
.grid--quotes{grid-template-columns:1fr}
@media(min-width:640px){.grid--menu{grid-template-columns:repeat(2,1fr)}}
@media(min-width:960px){
  .grid--menu{grid-template-columns:repeat(3,1fr)}
  .grid--why{grid-template-columns:repeat(3,1fr)}
  .grid--quotes{grid-template-columns:repeat(3,1fr)}
}

/* ---------- Menu cards ---------- */
.card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:1.6rem 1.5rem;box-shadow:var(--shadow-sm);
  transition:transform .2s var(--ease),box-shadow .2s var(--ease),border-color .2s;
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:rgba(184,115,51,.4)}
.card__icon{width:56px;height:56px;border-radius:14px;display:grid;place-items:center;
  background:linear-gradient(150deg,var(--cream) 0%,#efe1cc 100%);color:var(--copper-deep);margin-bottom:1.1rem}
.card__icon svg{width:32px;height:32px}
.card h3{margin-bottom:.5rem;color:var(--espresso)}
.card p{color:var(--muted);font-size:.95rem}

/* ---------- Why / features ---------- */
.feature{
  background:rgba(244,233,216,.05);border:1px solid var(--line-light);
  border-radius:var(--radius);padding:1.8rem 1.6rem;position:relative;overflow:hidden;
  transition:transform .2s var(--ease),background .2s;
}
.feature:hover{transform:translateY(-4px);background:rgba(244,233,216,.09)}
.feature__num{font-family:var(--f-display);font-size:2.6rem;color:var(--copper-2);opacity:.85;line-height:1;margin-bottom:.6rem}
.feature h3{color:var(--cream);margin-bottom:.55rem}
.feature p{color:rgba(244,233,216,.78);font-size:.96rem}

/* ---------- Showcase ---------- */
.showcase{display:grid;gap:2.5rem;align-items:center}
@media(min-width:900px){.showcase{grid-template-columns:.9fr 1.1fr;gap:3.5rem}}

.showcase__art{display:grid;place-items:center;padding:1rem}
.mug{position:relative;width:min(260px,70vw);aspect-ratio:1/1;display:grid;place-items:end center}
.mug__body{
  position:relative;width:70%;height:60%;
  background:linear-gradient(180deg,#fff 0%,var(--cream) 100%);
  border:3px solid var(--espresso);border-radius:10px 10px 34px 34px;
  box-shadow:var(--shadow);
}
.mug__crema{
  position:absolute;top:8px;left:8px;right:8px;height:22px;border-radius:8px;
  background:radial-gradient(circle at 35% 40%,var(--copper-2),var(--espresso-2));
}
.mug__crema::after{content:"";position:absolute;inset:0;margin:auto;width:38%;height:60%;
  border-radius:50%;background:var(--cream);opacity:.85;
  clip-path:polygon(50% 0,62% 40%,50% 100%,38% 40%)}
.mug__handle{position:absolute;right:4%;bottom:20%;width:20%;height:32%;
  border:3px solid var(--espresso);border-left:none;border-radius:0 30px 30px 0}
.mug__saucer{position:absolute;bottom:-2%;width:92%;height:5%;border-radius:50%;
  background:var(--espresso);opacity:.9;filter:blur(.3px)}
.mug__steam{position:absolute;top:2%;left:0;right:0;height:34%;display:flex;justify-content:center;gap:16px}
.mug__steam span{display:block;width:5px;height:100%;border-radius:6px;
  background:linear-gradient(180deg,rgba(184,115,51,.55),transparent);
  animation:steam 3.2s ease-in-out infinite}
.mug__steam span:nth-child(2){animation-delay:.5s;height:120%}
.mug__steam span:nth-child(3){animation-delay:1s}
@keyframes steam{0%{opacity:0;transform:translateY(6px) scaleY(.9)}40%{opacity:.9}100%{opacity:0;transform:translateY(-14px) scaleY(1.15)}}

.showcase__steps{display:grid;gap:1.1rem}
.rstep{display:flex;gap:1rem;align-items:flex-start}
.rstep__dot{flex:none;width:44px;height:44px;border-radius:50%;display:grid;place-items:center;
  background:var(--cream);border:1px solid var(--line)}
.rstep h3{color:var(--espresso);font-size:1.05rem;margin-bottom:.15rem}
.rstep p{color:var(--muted);font-size:.92rem}
.bean{display:block;width:16px;height:20px;border-radius:50%;position:relative;transform:rotate(18deg)}
.bean::after{content:"";position:absolute;inset:0;margin:auto;width:2px;height:80%;background:var(--cream);border-radius:2px}
.b1{background:#9c7a52}.b2{background:var(--copper-deep)}.b3{background:var(--espresso-2)}.b4{background:var(--bean)}

.roastprofile{display:flex;align-items:flex-end;gap:8px;height:90px;margin-top:1rem;padding:.8rem 1rem;
  background:var(--cream);border:1px solid var(--line);border-radius:var(--radius-sm)}
.roastprofile span{flex:1;height:var(--h);border-radius:6px 6px 2px 2px;
  background:linear-gradient(180deg,var(--copper-2),var(--espresso-2));transition:height .4s var(--ease)}
.roastprofile__cap{font-size:.82rem;color:var(--muted);margin-top:.5rem}

/* ---------- Testimonials ---------- */
.quote{
  margin:0;background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:1.7rem 1.5rem 1.4rem;box-shadow:var(--shadow-sm);position:relative;
  transition:transform .2s var(--ease)}
.quote:hover{transform:translateY(-4px)}
.quote__mark{font-family:var(--f-display);font-size:3.2rem;color:var(--copper);line-height:.4;height:1.4rem}
.quote blockquote{margin:0 0 1rem;color:var(--ink);font-size:1rem}
.quote figcaption{font-weight:700;color:var(--copper-deep);font-size:.92rem}
.quote__note{margin-top:1.4rem;font-size:.8rem;color:var(--muted);font-style:italic}

/* ---------- FAQ ---------- */
.faq{display:grid;gap:.8rem}
.faq__item{background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:0 1.2rem;box-shadow:var(--shadow-sm)}
.faq__item summary{list-style:none;cursor:pointer;font-weight:700;color:var(--espresso);
  padding:1.05rem 1.8rem 1.05rem 0;position:relative;font-size:1.02rem}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary::after{content:"+";position:absolute;right:0;top:50%;transform:translateY(-50%);
  font-size:1.5rem;color:var(--copper);transition:transform .2s var(--ease)}
.faq__item[open] summary::after{transform:translateY(-50%) rotate(45deg)}
.faq__item p{color:var(--muted);padding:0 0 1.1rem;font-size:.96rem}

/* ---------- CTA band ---------- */
.ctaband{background:
  radial-gradient(600px 300px at 80% -20%,rgba(184,115,51,.5),transparent 60%),
  linear-gradient(160deg,var(--espresso-2),var(--bean));
  color:var(--cream);text-align:center;padding:clamp(3rem,7vw,4.5rem) 0}
.ctaband__inner{max-width:640px;margin:0 auto}
.ctaband h2{color:var(--cream)}
.ctaband p{margin-top:.8rem;color:rgba(244,233,216,.85);font-size:1.08rem}
.ctaband__btns{display:flex;flex-wrap:wrap;gap:.9rem;justify-content:center;margin-top:1.8rem}

/* ---------- Visit / contact ---------- */
.visit{display:grid;gap:2rem}
@media(min-width:900px){.visit{grid-template-columns:1fr 1fr;gap:2.5rem;align-items:stretch}}
.visit__info{display:grid;gap:1.5rem;align-content:start}
.infoblock h3{color:var(--espresso);margin-bottom:.4rem}
.infoblock address{font-style:normal;color:var(--ink);font-size:1.02rem}
.infoblock a{color:var(--copper-deep);font-weight:600;border-bottom:1px solid transparent}
.infoblock a:hover{border-color:var(--copper-deep)}
.muted{color:var(--muted);font-size:.82rem;margin-top:.35rem}
.hours{list-style:none;margin:0;padding:0;display:grid;gap:.35rem;max-width:320px}
.hours li{display:flex;justify-content:space-between;gap:1rem;padding:.35rem 0;border-bottom:1px dashed var(--line)}
.hours li span:last-child{color:var(--copper-deep);font-weight:600}
.visit__cta{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:.4rem}

/* CSS-only map */
.visit__map{min-height:320px}
.map{position:relative;width:100%;height:100%;min-height:320px;border-radius:var(--radius);overflow:hidden;
  border:1px solid var(--line);box-shadow:var(--shadow);background:#e9dcc4}
.map__grid{position:absolute;inset:0;
  background-image:linear-gradient(rgba(42,26,18,.06) 1px,transparent 1px),
    linear-gradient(90deg,rgba(42,26,18,.06) 1px,transparent 1px);
  background-size:38px 38px}
.map__road{position:absolute;background:#f7efe0}
.map__road--h{left:0;right:0;height:14px}
.map__road--v{top:0;bottom:0;width:14px}
.map__road--main{height:22px;background:#fff;box-shadow:0 0 0 1px rgba(42,26,18,.06)}
.map__block{position:absolute;background:rgba(184,115,51,.14);border:1px solid rgba(184,115,51,.22);border-radius:4px}
.map__pin{position:absolute;transform:translate(-50%,-100%);display:flex;flex-direction:column;align-items:center;z-index:2}
.map__dot{width:20px;height:20px;border-radius:50% 50% 50% 0;transform:rotate(45deg);
  background:var(--copper);border:3px solid var(--cream);box-shadow:var(--shadow-sm)}
.map__dot::after{content:"";position:absolute;inset:0;margin:auto;width:6px;height:6px;background:var(--cream);border-radius:50%}
.map__label{margin-top:8px;background:var(--espresso);color:var(--cream);font-size:.75rem;font-weight:700;
  padding:.25rem .6rem;border-radius:999px;white-space:nowrap;transform:rotate(0)}
.map__street{position:absolute;font-size:.72rem;font-weight:700;color:var(--muted);letter-spacing:.05em}

/* ---------- Footer ---------- */
.ft{background:var(--bean);color:rgba(244,233,216,.82)}
.ft__inner{display:grid;gap:1.8rem;padding:2.8rem 22px 1.6rem;grid-template-columns:1fr}
@media(min-width:760px){.ft__inner{grid-template-columns:1.4fr 1fr}}
.brand__type--ft{color:var(--cream);font-size:1.7rem}
.ft__brand p{margin-top:.8rem;font-size:.92rem;max-width:360px}
.ft__nav{display:flex;flex-wrap:wrap;gap:1.2rem;align-content:start;font-weight:600}
.ft__nav a:hover{color:var(--copper-2)}
.ft__bottom{display:flex;flex-wrap:wrap;justify-content:space-between;gap:.6rem;
  padding:1.2rem 22px 2rem;border-top:1px solid var(--line-light);font-size:.82rem}
.ft__credit a{color:var(--copper-2);font-weight:600}
.ft__credit a:hover{text-decoration:underline}

/* ---------- Mobile bottom bar ---------- */
.mobilebar{
  position:fixed;left:0;right:0;bottom:0;z-index:70;display:flex;
  background:rgba(28,17,11,.96);backdrop-filter:blur(8px);
  border-top:1px solid var(--line-light);
  padding-bottom:env(safe-area-inset-bottom);
}
.mobilebar a{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;
  padding:.55rem 0 .6rem;color:var(--cream);font-size:.68rem;font-weight:600}
.mobilebar a:not(:last-child){border-right:1px solid var(--line-light)}
.mobilebar svg{width:22px;height:22px;color:var(--copper-2)}
.mobilebar a:active{background:rgba(184,115,51,.2)}
@media(min-width:760px){.mobilebar{display:none}}
body{padding-bottom:64px}
@media(min-width:760px){body{padding-bottom:0}}

/* ---------- Scroll reveal ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ============================================================
   Opening animation
   ============================================================ */
.intro{
  position:fixed;inset:0;z-index:200;display:grid;place-items:center;
  background:radial-gradient(700px 500px at 50% 30%,var(--espresso-2),var(--bean));
  animation:introOut .5s var(--ease) 2.0s forwards;
}
.intro.hide{opacity:0;visibility:hidden;pointer-events:none}
.intro__skip{
  position:absolute;top:18px;right:18px;background:rgba(244,233,216,.12);color:var(--cream);
  border:1px solid var(--line-light);border-radius:999px;padding:.45rem 1.1rem;
  font-family:var(--f-body);font-weight:600;font-size:.85rem;cursor:pointer;transition:background .2s}
.intro__skip:hover{background:rgba(244,233,216,.24)}
.intro__stage{display:grid;place-items:center;gap:1rem}
.intro__svg{width:min(220px,60vw)}
.intro__word{font-family:var(--f-display);font-size:clamp(2rem,10vw,3.4rem);letter-spacing:8px;
  color:var(--cream);opacity:0;animation:wordIn .6s var(--ease) 1.2s forwards}

.pour{transform-origin:top center;transform:scaleY(0);animation:pour .7s var(--ease) .15s forwards}
.crema{transform-origin:center;opacity:0;transform:scale(.6);animation:cremaIn .5s var(--ease) .75s forwards}
.art{opacity:0;transform:scale(.4);transform-box:fill-box;transform-origin:center;
  animation:artIn .7s var(--ease) 1.05s forwards}
.cup{opacity:0;transform:translateY(14px);animation:cupIn .5s var(--ease) 0s forwards}
.steam{opacity:0;stroke-dasharray:40;stroke-dashoffset:40}
.s1{animation:steamDraw 1s var(--ease) 1.3s forwards}
.s2{animation:steamDraw 1s var(--ease) 1.5s forwards}

@keyframes cupIn{to{opacity:1;transform:none}}
@keyframes pour{to{transform:scaleY(1)}}
@keyframes cremaIn{to{opacity:1;transform:scale(1)}}
@keyframes artIn{0%{opacity:0;transform:scale(.4) rotate(-12deg)}100%{opacity:1;transform:scale(1) rotate(0)}}
@keyframes steamDraw{to{opacity:.9;stroke-dashoffset:0}}
@keyframes wordIn{to{opacity:1;letter-spacing:12px}}
@keyframes introOut{to{opacity:0;visibility:hidden}}

/* honor reduced motion */
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .reveal{opacity:1;transform:none;transition:none}
  .mug__steam span{animation:none;opacity:.5}
  .intro{display:none !important}
  .pour,.crema,.art,.cup,.steam,.intro__word{animation:none}
}
