/* ============================================
   FULTON COUNTY BARBERSHOP — Williamson Automation
   Built 2026-04-09
   ============================================ */

:root{
  --gold:#C9975B;
  --gold-l:#DEB070;
  --gold-d:#A67C45;
  --bg:#0A0907;
  --bg2:#12100B;
  --bg3:#19160F;
  --card:#1A1710;
  --card-h:#221F16;
  --tx:#F2EDE4;
  --tx2:#9B9282;
  --tx3:#6B6358;
  --bdr:rgba(201,151,91,.10);
  --bdr2:rgba(201,151,91,.22);
  --hd:'Playfair Display',Georgia,serif;
  --bd:'DM Sans',system-ui,sans-serif;
  --ease:cubic-bezier(.22,1,.36,1);
}

/* --- reset --- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scrollbar-width:thin;scrollbar-color:var(--gold-d) var(--bg)}
::-webkit-scrollbar{width:7px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--gold-d);border-radius:4px}
::-webkit-scrollbar-thumb:hover{background:var(--gold)}
body{
  font-family:var(--bd);background:var(--bg);color:var(--tx);
  font-size:clamp(1rem,.95rem + .25vw,1.125rem);
  line-height:1.7;-webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
blockquote{margin:0}

/* --- grain --- */
.grain{
  position:fixed;inset:0;z-index:9999;pointer-events:none;
  opacity:.03;
}

/* --- layout --- */
.wrap{width:min(92%,1200px);margin-inline:auto}
.template-hidden{display:none}

/* --- tag label --- */
.tag{
  font-family:var(--bd);font-size:clamp(.68rem,.64rem + .18vw,.76rem);
  font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);
  display:inline-flex;align-items:center;gap:.85rem;margin-bottom:1.25rem;
}
.tag::before{content:'';width:2.5rem;height:1px;background:var(--gold);flex-shrink:0}
.tag--center{display:flex;justify-content:center}
.tag--center::after{content:'';width:2.5rem;height:1px;background:var(--gold);flex-shrink:0}

/* --- buttons --- */
.btn{
  display:inline-flex;align-items:center;gap:.55rem;
  font-family:var(--bd);font-weight:600;
  font-size:clamp(.86rem,.84rem + .1vw,.95rem);
  border-radius:6px;transition:all .35s var(--ease);white-space:nowrap;
}
.btn--fill{
  padding:clamp(.82rem,.72rem + .28vw,1.02rem) clamp(1.6rem,1.4rem + .55vw,2.4rem);
  background:linear-gradient(135deg,var(--gold),var(--gold-d));
  color:var(--bg);box-shadow:0 4px 18px rgba(201,151,91,.22);
}
.btn--fill:hover{transform:translateY(-3px);box-shadow:0 10px 36px rgba(201,151,91,.35);background:linear-gradient(135deg,var(--gold-l),var(--gold))}
.btn--fill svg{transition:transform .3s var(--ease)}
.btn--fill:hover svg{transform:translateX(4px)}
.btn--outline{
  padding:clamp(.78rem,.68rem + .26vw,.98rem) clamp(1.4rem,1.2rem + .45vw,2rem);
  border:1px solid var(--bdr2);color:var(--tx);
}
.btn--outline:hover{border-color:var(--gold);background:rgba(201,151,91,.06)}

/* --- reveals --- */
.reveal-up,.reveal-left,.reveal-right,.reveal-scale{
  opacity:0;transition:opacity .85s var(--ease),transform .85s var(--ease);
  transition-delay:var(--d,0s);
}
.reveal-up{transform:translateY(32px)}
.reveal-left{transform:translateX(-36px)}
.reveal-right{transform:translateX(36px)}
.reveal-scale{transform:scale(.94)}
.reveal-up.in-view,.reveal-left.in-view,.reveal-right.in-view,.reveal-scale.in-view{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal-up,.reveal-left,.reveal-right,.reveal-scale{opacity:1;transform:none;transition:none}}

/* ==========================================================
   NAV
   ========================================================== */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:clamp(1rem,.85rem + .45vw,1.4rem) 0;transition:background .5s,box-shadow .5s,padding .4s}
.nav.scrolled{background:rgba(10,9,7,.88);backdrop-filter:blur(28px) saturate(1.8);-webkit-backdrop-filter:blur(28px) saturate(1.8);box-shadow:0 1px 0 var(--bdr);padding:clamp(.55rem,.45rem + .3vw,.8rem) 0}
.nav__bar{display:flex;align-items:center;justify-content:space-between;width:min(92%,1200px);margin-inline:auto}
.nav__brand{font-family:var(--hd);font-size:clamp(1.05rem,.92rem + .55vw,1.4rem);font-weight:700;letter-spacing:-.02em;line-height:1.1}
.nav__phone-btn{display:none;align-items:center;gap:.55rem;padding:.65rem 1.4rem;background:linear-gradient(135deg,var(--gold),var(--gold-d));color:var(--bg);font-weight:600;font-size:.85rem;border-radius:6px;transition:all .3s var(--ease);box-shadow:0 3px 14px rgba(201,151,91,.2)}
.nav__phone-btn:hover{transform:translateY(-1px);box-shadow:0 6px 22px rgba(201,151,91,.3)}
.nav__burger{display:flex;flex-direction:column;gap:5px;padding:10px;min-width:48px;min-height:48px;align-items:center;justify-content:center}
.nav__burger span{display:block;width:22px;height:2px;background:var(--tx);border-radius:2px;transition:transform .35s var(--ease),opacity .25s}
.nav__burger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav__burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav__burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-menu{position:fixed;inset:0;z-index:99;background:rgba(10,9,7,.96);backdrop-filter:blur(32px);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .4s}
.mobile-menu.is-open{opacity:1;pointer-events:all}
.mobile-menu__body{text-align:center}
.mobile-menu__cta{display:inline-flex;align-items:center;gap:.75rem;padding:1.1rem 2.5rem;background:linear-gradient(135deg,var(--gold),var(--gold-d));color:var(--bg);font-weight:700;font-size:clamp(1.1rem,1rem + .5vw,1.3rem);border-radius:8px;margin-bottom:1.5rem;box-shadow:0 6px 24px rgba(201,151,91,.25)}
.mobile-menu__addr{color:var(--tx2);font-size:.92rem;line-height:1.6}
@media(min-width:768px){.nav__phone-btn{display:flex}.nav__burger{display:none}}

/* ==========================================================
   HERO — centered content
   ========================================================== */
.hero{position:relative;min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;overflow:hidden;clip-path:inset(0)}

.hero__mesh{
  position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(ellipse at 18% 22%,rgba(201,151,91,.22) 0%,transparent 42%),
    radial-gradient(ellipse at 78% 12%,rgba(180,145,80,.12) 0%,transparent 38%),
    radial-gradient(ellipse at 55% 75%,rgba(140,110,55,.08) 0%,transparent 45%),
    radial-gradient(ellipse at 8% 85%,rgba(100,80,40,.1) 0%,transparent 42%),
    linear-gradient(168deg,#16130D 0%,var(--bg) 28%,#100E09 58%,var(--bg) 100%);
}

.hero__lines{position:absolute;inset:0;z-index:1;background:repeating-linear-gradient(90deg,transparent,transparent 140px,rgba(201,151,91,.025) 140px,rgba(201,151,91,.025) 141px)}
.hero__glow{position:absolute;inset:0;z-index:2;opacity:0;transition:opacity .6s;pointer-events:none}
.hero__photo{position:absolute;inset:0;z-index:3}
.hero__photo img{width:100%;height:100%;object-fit:cover}
.hero__overlay{
  position:absolute;inset:0;z-index:4;
  background:
    radial-gradient(ellipse at 22% 30%,rgba(201,151,91,.1) 0%,transparent 48%),
    linear-gradient(180deg,rgba(10,9,7,.45) 0%,rgba(10,9,7,.05) 22%,rgba(10,9,7,.12) 48%,rgba(10,9,7,.65) 70%,rgba(10,9,7,.97) 100%);
}

/* Centered hero content */
.hero__content{
  position:relative;z-index:6;text-align:center;
  width:min(92%,900px);margin-inline:auto;
  padding-top:clamp(6rem,5rem + 4vw,10rem);
  padding-bottom:clamp(5rem,4rem + 4vw,8rem);
}
.anim-hero{opacity:0;transform:translateY(26px);animation:heroIn 1s var(--ease) forwards;animation-delay:calc(.12s + var(--i)*.14s)}
@keyframes heroIn{to{opacity:1;transform:none}}
@media(prefers-reduced-motion:reduce){.anim-hero{opacity:1;transform:none;animation:none}}

.hero__est{
  display:inline-block;font-size:clamp(.68rem,.64rem + .18vw,.78rem);
  font-weight:600;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold);margin-bottom:1.5rem;
}
.hero__h1{
  font-family:var(--hd);
  font-size:clamp(2.8rem,1.8rem + 5.2vw,6rem);
  font-weight:700;line-height:.95;letter-spacing:-.035em;
  margin-bottom:1rem;overflow-wrap:break-word;word-break:break-word;
}
.hero__sub{
  font-size:clamp(1rem,.88rem + .5vw,1.25rem);
  color:var(--tx2);margin-bottom:2.5rem;max-width:40ch;margin-inline:auto;line-height:1.5;
}
.hero__btns{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;justify-content:center}

.hero__scroll-hint{
  position:absolute;bottom:clamp(1.2rem,1rem + 1.8vw,2.2rem);left:50%;transform:translateX(-50%);z-index:6;
  display:flex;flex-direction:column;align-items:center;gap:.5rem;
  opacity:0;animation:heroIn .7s var(--ease) 1.1s forwards;
}
.hero__scroll-hint span{font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;color:var(--tx3)}
.hero__scroll-bar{width:1px;height:40px;background:var(--bdr);overflow:hidden;border-radius:1px}
.hero__scroll-fill{width:100%;height:50%;background:linear-gradient(180deg,var(--gold),transparent)}

/* ==========================================================
   MARQUEE — single row, seamless
   ========================================================== */
.marquee{overflow:hidden;clip-path:inset(0);padding:clamp(1rem,.8rem + .6vw,1.5rem) 0;border-top:1px solid var(--bdr);border-bottom:1px solid var(--bdr);background:var(--bg2)}
.marquee__track{display:flex;align-items:center;gap:clamp(1.8rem,1.5rem + 1vw,3rem);width:max-content;animation:ticker 40s linear infinite;will-change:transform}
.marquee__track span{font-family:var(--hd);font-size:clamp(.9rem,.82rem + .35vw,1.08rem);letter-spacing:.15em;text-transform:uppercase;color:rgba(201,151,91,.3);white-space:nowrap}
.marquee__dot{width:5px;height:5px;border-radius:50%;background:var(--gold);opacity:.3;flex-shrink:0}
@keyframes ticker{to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.marquee__track{animation:none}}

/* ==========================================================
   SERVICES — centered cards, clean professional
   ========================================================== */
.services{position:relative;overflow:hidden;padding:clamp(5.5rem,4.5rem + 4vw,9rem) 0;background:radial-gradient(ellipse at 12% 35%,rgba(201,151,91,.06) 0%,transparent 42%),linear-gradient(178deg,var(--bg2) 0%,var(--bg) 100%)}
.services__top{margin-bottom:clamp(3rem,2.5rem + 2vw,5rem)}
.services__h2{font-family:var(--hd);font-size:clamp(2rem,1.5rem + 2.2vw,3.8rem);font-weight:700;letter-spacing:-.025em;line-height:1.06}
.services__cards{display:grid;grid-template-columns:1fr;gap:clamp(1rem,.8rem + .6vw,1.2rem)}

/* Card structure: gold top accent -> icon circle -> name -> desc -> divider -> price */
.scard{
  --gx:50%;--gy:50%;
  position:relative;overflow:hidden;
  background:var(--card);
  padding:0;
  border:1px solid var(--bdr);
  text-align:center;
  display:flex;flex-direction:column;align-items:center;
  transition:transform .45s var(--ease),border-color .4s,box-shadow .4s,background .4s;
}
/* Organic varied border-radius per card */
.scard:nth-child(1){border-radius:14px 8px 10px 12px}
.scard:nth-child(2){border-radius:8px 14px 12px 8px}
.scard:nth-child(3){border-radius:10px 8px 14px 10px}
.scard:nth-child(4){border-radius:8px 12px 10px 14px}

/* Gold top accent stripe */
.scard::before{
  content:'';display:block;width:100%;height:3px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
  opacity:.5;flex-shrink:0;
}

/* Cursor-tracking inner glow */
.glow-card::after{content:'';position:absolute;inset:0;background:radial-gradient(350px circle at var(--gx) var(--gy),rgba(201,151,91,.07),transparent 45%);opacity:0;transition:opacity .4s;pointer-events:none;z-index:1}
.glow-card:hover::after{opacity:1}

.scard:hover{transform:translateY(-6px);border-color:var(--bdr2);box-shadow:0 18px 52px rgba(0,0,0,.4);background:var(--card-h)}

/* Card inner content area */
.scard__icon-wrap{
  width:52px;height:52px;border-radius:50%;
  background:rgba(201,151,91,.08);border:1px solid rgba(201,151,91,.12);
  display:flex;align-items:center;justify-content:center;
  margin-top:clamp(1.8rem,1.5rem + .6vw,2.4rem);
  margin-bottom:1.2rem;color:var(--gold);
}
.scard__name{
  font-family:var(--hd);font-size:clamp(1.2rem,1.06rem + .5vw,1.45rem);
  font-weight:700;letter-spacing:-.01em;line-height:1.2;margin-bottom:.5rem;
  padding:0 clamp(1.5rem,1.2rem + .6vw,2rem);
}
.scard__desc{
  font-size:clamp(.84rem,.82rem + .08vw,.91rem);
  color:var(--tx2);line-height:1.65;margin-bottom:1.2rem;
  max-width:30ch;padding:0 clamp(1.2rem,1rem + .5vw,1.8rem);
}
.scard__divider{
  width:40px;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
  opacity:.3;margin-bottom:1.2rem;
}
.scard__price{
  font-family:var(--hd);font-size:clamp(1.5rem,1.3rem + .6vw,1.8rem);
  font-weight:700;color:var(--gold);margin-top:auto;
  padding-bottom:clamp(1.8rem,1.5rem + .6vw,2.4rem);
  letter-spacing:-.01em;
}

@media(min-width:640px){.services__cards{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1060px){.services__cards{grid-template-columns:repeat(4,1fr)}}

/* ==========================================================
   PROOF STRIP
   ========================================================== */
.proof{position:relative;overflow:hidden;padding:clamp(1.8rem,1.4rem + 1vw,2.8rem) 0;background:var(--card);border-top:1px solid var(--bdr);border-bottom:1px solid var(--bdr)}
.proof__inner{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:clamp(.8rem,.6rem + .6vw,1.6rem);text-align:center}
.proof__stars{display:flex;align-items:center;gap:.6rem}
.proof__score{font-family:var(--hd);font-size:clamp(1.6rem,1.4rem + .65vw,2.1rem);font-weight:700;line-height:1}
.proof__star-row{display:flex;gap:2px}
.proof__star-row svg{width:18px;height:18px;fill:var(--gold)}
.proof__sep{width:1px;height:28px;background:var(--bdr)}
.proof__count{font-size:clamp(.8rem,.76rem + .14vw,.88rem);color:var(--tx2);font-weight:500}
.proof__quote{font-size:clamp(.88rem,.84rem + .14vw,.98rem);color:var(--tx2);max-width:36ch;line-height:1.5}
.hide-mobile{display:none}
@media(min-width:768px){.hide-mobile{display:block}}
@media(max-width:639px){.proof__sep{width:36px;height:1px}}

/* ==========================================================
   REVIEWS — 3 equal aligned cards
   ========================================================== */
.reviews{position:relative;overflow:hidden;padding:clamp(5.5rem,4.5rem + 4vw,9rem) 0;background:radial-gradient(ellipse at 78% 22%,rgba(201,151,91,.06) 0%,transparent 42%),var(--bg)}
.reviews__top{margin-bottom:clamp(3rem,2.5rem + 2vw,4.5rem)}
.reviews__h2{font-family:var(--hd);font-size:clamp(2rem,1.5rem + 2.2vw,3.8rem);font-weight:700;letter-spacing:-.025em;line-height:1.06}

.reviews__grid{display:grid;grid-template-columns:1fr;gap:clamp(1rem,.8rem + .6vw,1.5rem)}
.rev{
  --gx:50%;--gy:50%;
  background:var(--card);border:1px solid var(--bdr);
  padding:clamp(2rem,1.7rem + .9vw,2.8rem);
  position:relative;overflow:hidden;border-radius:12px;
  display:flex;flex-direction:column;
}
.rev__mark{font-family:var(--hd);font-size:clamp(3rem,2.5rem + 1.5vw,4.5rem);color:var(--gold);line-height:.7;margin-bottom:.6rem;opacity:.3}
.rev__text{font-size:clamp(.93rem,.9rem + .12vw,1.04rem);line-height:1.8;color:var(--tx);margin-bottom:1.4rem;flex:1}
.rev__who{font-weight:600;font-size:.82rem;color:var(--gold);letter-spacing:.03em;font-style:normal;margin-top:auto}

@media(min-width:768px){.reviews__grid{grid-template-columns:repeat(3,1fr)}}

/* ==========================================================
   ABOUT — with image placeholder
   ========================================================== */
.about{position:relative;overflow:hidden;padding:clamp(5.5rem,4.5rem + 4vw,9rem) 0;background:radial-gradient(ellipse at 10% 52%,rgba(201,151,91,.05) 0%,transparent 42%),var(--bg2)}
.about__grid{display:grid;grid-template-columns:1fr;gap:clamp(2.5rem,2rem + 2.5vw,4.5rem);align-items:center}
.about__photo{position:relative;max-width:420px;order:1}
.about__frame{position:relative;z-index:1;border-radius:14px;overflow:hidden;aspect-ratio:4/5;background:var(--card)}
.about__frame img{width:100%;height:100%;object-fit:cover}

/* Gradient placeholder when image doesn't exist */
.about__placeholder{
  display:none;position:absolute;inset:0;
  background:
    radial-gradient(ellipse at 30% 30%,rgba(201,151,91,.12) 0%,transparent 50%),
    radial-gradient(ellipse at 70% 70%,rgba(140,110,55,.08) 0%,transparent 50%),
    linear-gradient(160deg,var(--bg3) 0%,var(--card) 100%);
  align-items:center;justify-content:center;flex-direction:column;
}

.about__frame-accent{
  position:absolute;z-index:0;top:12px;left:12px;right:-12px;bottom:-12px;
  border:1.5px solid var(--gold);opacity:.12;border-radius:14px;
}

.about__copy{order:2}
.about__h2{font-family:var(--hd);font-size:clamp(2rem,1.5rem + 2.2vw,3.8rem);font-weight:700;letter-spacing:-.025em;line-height:1.06;margin-bottom:1.8rem;position:relative}
.about__squiggle{display:block;width:clamp(110px,28vw,180px);height:10px;margin-top:.5rem;color:var(--gold);opacity:.45}
.about__text{font-size:clamp(.93rem,.9rem + .12vw,1.04rem);line-height:1.85;color:var(--tx2);max-width:48ch;margin-bottom:2rem}
.about__meta{display:flex;align-items:center;gap:1.4rem;padding-top:1.6rem;border-top:1px solid var(--bdr)}
.about__meta-block{font-size:.82rem;color:var(--tx3)}
.about__meta-block strong{display:block;font-family:var(--hd);font-size:clamp(1.08rem,1rem + .28vw,1.26rem);color:var(--tx);font-weight:700;margin-bottom:.1rem}
.about__meta-block span{font-size:.78rem}
.about__meta-line{width:1px;height:34px;background:var(--bdr)}
@media(min-width:768px){
  .about__grid{grid-template-columns:1.1fr .9fr}
  .about__copy{order:1}.about__photo{order:2;max-width:none}
}

/* ==========================================================
   GALLERY (hidden)
   ========================================================== */
.gallery{padding:clamp(5.5rem,4.5rem + 4vw,9rem) 0;background:var(--bg)}
.gallery__top{margin-bottom:clamp(2.5rem,2rem + 1.5vw,3.5rem)}
.gallery__h2{font-family:var(--hd);font-size:clamp(2rem,1.5rem + 2vw,3rem);font-weight:700;letter-spacing:-.025em;line-height:1.06}
.gallery__mosaic{display:grid;grid-template-columns:1fr;gap:clamp(.6rem,.4rem + .4vw,.9rem)}
.gallery__item{overflow:hidden;border-radius:10px}
.gallery__item img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}
.gallery__item:hover img{transform:scale(1.06)}
@media(min-width:768px){
  .gallery__mosaic{grid-template-columns:repeat(3,1fr);grid-template-rows:auto auto}
  .gallery__item--tall{grid-row:span 2;aspect-ratio:3/4;border-radius:14px 8px 8px 14px}
  .gallery__item:nth-child(2){aspect-ratio:4/3;border-radius:8px 14px 6px 8px}
  .gallery__item:nth-child(3){aspect-ratio:4/3;border-radius:8px 6px 14px 8px}
}

/* ==========================================================
   LOCATION — redesigned, professional
   ========================================================== */
.loc{position:relative;overflow:hidden;padding:clamp(5.5rem,4.5rem + 4vw,9rem) 0;background:radial-gradient(ellipse at 62% 32%,rgba(201,151,91,.04) 0%,transparent 42%),var(--bg2)}
.loc__top{margin-bottom:clamp(2.5rem,2rem + 1.5vw,4rem)}
.loc__h2{font-family:var(--hd);font-size:clamp(2rem,1.5rem + 2vw,3rem);font-weight:700;letter-spacing:-.025em;line-height:1.06}
.loc__grid{display:grid;grid-template-columns:1fr;gap:clamp(2rem,1.5rem + 2vw,3rem)}

.loc__hours-card{
  background:var(--card);border:1px solid var(--bdr);border-radius:12px;
  padding:clamp(1.7rem,1.4rem + .75vw,2.4rem);margin-bottom:1.5rem;
}
.loc__card-title{font-family:var(--hd);font-size:clamp(1.12rem,1rem + .35vw,1.3rem);font-weight:700;margin-bottom:1.15rem;letter-spacing:-.01em}
.hours-tbl{width:100%;border-collapse:collapse}
.hours-tbl td{padding:.5rem 0;border-bottom:1px solid var(--bdr);font-size:clamp(.84rem,.82rem + .08vw,.91rem)}
.hours-tbl tr:last-child td{border-bottom:none}
.hours-tbl td:first-child{font-weight:500;color:var(--tx)}
.hours-tbl td:last-child{text-align:right;color:var(--tx2)}

.loc__details{display:flex;flex-direction:column;gap:1rem}
.loc__phone-btn{
  display:inline-flex;align-items:center;gap:.6rem;
  padding:.75rem 1.6rem;
  background:linear-gradient(135deg,var(--gold),var(--gold-d));
  color:var(--bg);font-weight:600;font-size:.92rem;
  border-radius:8px;width:fit-content;
  box-shadow:0 4px 16px rgba(201,151,91,.2);
  transition:all .3s var(--ease);
}
.loc__phone-btn:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(201,151,91,.3)}
.loc__address{display:flex;align-items:center;gap:.7rem;font-size:clamp(.88rem,.85rem + .12vw,.97rem);color:var(--tx2)}
.loc__address svg{color:var(--gold);flex-shrink:0}

.loc__map-frame{border-radius:12px;overflow:hidden;border:1px solid var(--bdr);aspect-ratio:16/10;width:100%;min-height:280px}
.loc__map-frame iframe{width:100%;height:100%;border:0}
@media(min-width:768px){.loc__grid{grid-template-columns:.45fr .55fr;align-items:start}}

/* ==========================================================
   SHIMMER DIVIDER
   ========================================================== */
.shimmer-line{height:1px;background:linear-gradient(90deg,transparent 0%,var(--bdr) 25%,var(--gold) 50%,var(--bdr) 75%,transparent 100%)}

/* ==========================================================
   CTA
   ========================================================== */
.cta{position:relative;padding:clamp(6.5rem,5.5rem + 5vw,11rem) 0;text-align:center;overflow:hidden;clip-path:inset(0);background:radial-gradient(ellipse at 50% 32%,rgba(201,151,91,.14) 0%,transparent 48%),linear-gradient(168deg,var(--card) 0%,var(--bg) 100%)}
.cta__pulse{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:min(500px,90vw);height:min(340px,60vw);background:radial-gradient(ellipse,rgba(201,151,91,.08) 0%,transparent 58%);pointer-events:none}
.cta__h2{font-family:var(--hd);font-size:clamp(2.2rem,1.7rem + 2.6vw,4.2rem);font-weight:700;letter-spacing:-.025em;line-height:1.04;margin-bottom:2rem;position:relative;z-index:1}
.cta__big-btn{
  display:inline-flex;align-items:center;gap:.85rem;
  padding:clamp(1rem,.9rem + .4vw,1.35rem) clamp(2.2rem,1.9rem + .8vw,3.5rem);
  background:linear-gradient(135deg,var(--gold),var(--gold-d));
  color:var(--bg);font-family:var(--hd);font-size:clamp(1.3rem,1.1rem + .7vw,1.8rem);
  font-weight:700;border-radius:8px;box-shadow:0 6px 28px rgba(201,151,91,.28);
  transition:all .35s var(--ease);margin-bottom:1.7rem;position:relative;z-index:1;
}
.cta__big-btn:hover{transform:translateY(-3px);box-shadow:0 16px 52px rgba(201,151,91,.4)}
.cta__addr{font-size:clamp(.88rem,.84rem + .14vw,.98rem);color:var(--tx2);position:relative;z-index:1}

/* ==========================================================
   FOOTER
   ========================================================== */
.foot{padding:clamp(2.5rem,2rem + 1.5vw,3.5rem) 0;background:var(--bg);border-top:1px solid var(--bdr)}
.foot__row{display:grid;grid-template-columns:1fr;gap:1.4rem;padding-bottom:1.5rem}
.foot__brand{font-family:var(--hd);font-size:clamp(1rem,.9rem + .35vw,1.18rem);font-weight:700;margin-bottom:.2rem}
.foot__sub{font-size:.82rem;color:var(--tx3)}
.foot__right{display:flex;flex-direction:column;gap:.3rem;font-size:.82rem;color:var(--tx2);line-height:1.6}
.foot__right a{color:var(--tx2);transition:color .25s}
.foot__right a:hover{color:var(--gold)}
.foot__legal{display:flex;flex-direction:column;gap:.45rem;padding-top:1.5rem;border-top:1px solid var(--bdr);font-size:.76rem;color:var(--tx3)}
.foot__legal a{color:var(--gold-d);transition:color .25s}
.foot__legal a:hover{color:var(--gold)}
@media(min-width:768px){
  .foot__row{grid-template-columns:1fr 1fr;align-items:start}
  .foot__right{text-align:right}
  .foot__legal{flex-direction:row;justify-content:space-between}
}
