/* ============================================================
   HOME + page hero scenes — Richard's Locksmith & Safes
   ============================================================ */

/* QA capture mode — cap hero so tall-window screenshots show full page */
.qa-static .hero{min-height:760px!important;height:760px!important}
.qa-static [data-reveal]{opacity:1!important;transform:none!important;transition:none!important}

/* ---------- HERO ---------- */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;overflow:hidden;
  padding-top:140px;padding-bottom:80px}
.hero-media{position:absolute;inset:0;z-index:-3}
.hero-media img,.hero-media video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-media .hero-fallback{z-index:0}
.hero-media video{z-index:1}
.hero-media::after{content:"";position:absolute;inset:0;z-index:2;
  background:
    linear-gradient(105deg,rgba(8,8,10,.92) 0%,rgba(8,8,10,.62) 40%,rgba(8,8,10,.12) 72%,transparent 100%),
    linear-gradient(0deg,rgba(8,8,10,.88),transparent 42%)}
.hero-glow{position:absolute;inset:0;z-index:-2;pointer-events:none;
  background:radial-gradient(700px 500px at 18% 60%,rgba(200,160,78,.16),transparent 65%)}

.hero-inner{max-width:760px;position:relative}
.hero .eyebrow{margin-bottom:26px}
.hero h1{margin-bottom:24px}
.hero h1 .ln{display:block;overflow:hidden}
.hero h1 .ln > span{display:inline-block;transform:translateY(110%);
  animation:heroLine 1.1s var(--ease-out) forwards}
.hero h1 .ln:nth-child(2) > span{animation-delay:.12s}
.hero h1 .ln:nth-child(3) > span{animation-delay:.24s}
@keyframes heroLine{to{transform:none}}
.hero-sub{max-width:560px;margin-bottom:38px;opacity:0;animation:fadeUp 1s var(--ease-out) .5s forwards}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap;opacity:0;animation:fadeUp 1s var(--ease-out) .66s forwards}
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}

.hero-trust{display:flex;align-items:center;gap:26px;margin-top:46px;flex-wrap:wrap;
  opacity:0;animation:fadeUp 1s var(--ease-out) .82s forwards}
.hero-trust .ht{display:flex;align-items:center;gap:11px}
.hero-trust .ht .ic{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;
  background:rgba(200,160,78,.08);border:1px solid var(--line)}
.hero-trust .ht .ic svg{width:21px;height:21px;color:var(--gold-lite)}
.hero-trust .ht b{display:block;font-family:var(--display);font-size:1.35rem;line-height:1}
.hero-trust .ht small{font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-family:var(--label)}
.hero-trust .sep{width:1px;height:38px;background:var(--line)}

/* scroll cue */
.scroll-cue{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);z-index:2;
  display:flex;flex-direction:column;align-items:center;gap:10px;
  font-family:var(--label);font-size:10.5px;letter-spacing:.28em;text-transform:uppercase;color:var(--muted);
  opacity:0;animation:fadeUp 1s 1.1s forwards}
.scroll-cue .mouse{width:24px;height:38px;border:1.5px solid var(--line);border-radius:14px;position:relative}
.scroll-cue .mouse::after{content:"";position:absolute;top:7px;left:50%;transform:translateX(-50%);
  width:3px;height:7px;border-radius:2px;background:var(--gold-lite);animation:wheel 1.8s infinite}
@keyframes wheel{0%{opacity:1;transform:translate(-50%,0)}100%{opacity:0;transform:translate(-50%,12px)}}

/* ---------- Emergency ribbon ---------- */
.emer-bar{background:linear-gradient(90deg,#1b0f0d,#2a1411 50%,#1b0f0d);
  border-block:1px solid rgba(200,57,47,.25);overflow:hidden}
.emer-track{display:flex;gap:60px;white-space:nowrap;align-items:center;padding:13px 0;
  animation:marq 32s linear infinite;font-family:var(--label);font-size:13px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--paper-dim)}
.emer-track span{display:inline-flex;align-items:center;gap:12px}
.emer-track svg{width:16px;height:16px;color:var(--red-lite)}
@keyframes marq{to{transform:translateX(-50%)}}

/* ---------- Logo marquee / brands ---------- */
.brand-marq{padding:40px 0;border-block:1px solid var(--line-soft);overflow:hidden;
  -webkit-mask:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);
  mask:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent)}
.brand-marq .track{display:flex;gap:64px;align-items:center;white-space:nowrap;animation:marq 30s linear infinite}
.brand-marq b{font-family:var(--display);font-size:1.55rem;color:var(--muted-2);font-weight:500;
  letter-spacing:.02em;transition:color .3s;flex:none}
.brand-marq b:hover{color:var(--gold-lite)}

/* ---------- Split intro with floating key card ---------- */
.intro-media{perspective:1400px}
.intro-stack{position:relative}
.intro-stack .badge-float{position:absolute;right:-18px;bottom:34px;z-index:3;
  background:rgba(14,14,18,.86);backdrop-filter:blur(14px);border:1px solid var(--line);
  border-radius:16px;padding:18px 22px;box-shadow:var(--shadow-lg);max-width:230px}
.intro-stack .badge-float .row{display:flex;align-items:center;gap:12px}
.intro-stack .badge-float .est{font-family:var(--display);font-size:2.6rem;line-height:1;
  background:var(--grad-gold);-webkit-background-clip:text;background-clip:text;color:transparent}
.intro-stack .badge-float small{font-size:11.5px;color:var(--muted);letter-spacing:.08em;
  text-transform:uppercase;font-family:var(--label)}

/* ---------- Big vault dial decorative ---------- */
.dial{width:clamp(180px,26vw,330px);aspect-ratio:1;border-radius:50%;position:relative;flex:none;
  background:
    radial-gradient(circle at 50% 50%,#16161b 0 38%,transparent 39%),
    conic-gradient(from 0deg,#1c1c22,#2a2a32 25%,#15151a 50%,#2a2a32 75%,#1c1c22);
  border:1px solid var(--line);box-shadow:var(--shadow-lg),inset 0 0 60px rgba(0,0,0,.7)}
.dial::before{content:"";position:absolute;inset:14%;border-radius:50%;
  border:2px dashed rgba(200,160,78,.3);animation:spin 40s linear infinite}
.dial::after{content:"";position:absolute;inset:30%;border-radius:50%;
  background:radial-gradient(circle at 35% 30%,#2a2820,#0d0d11);border:1px solid var(--line);
  box-shadow:var(--shadow-gold)}
.dial .tick{position:absolute;top:50%;left:50%;width:2px;height:50%;transform-origin:bottom center;
  background:linear-gradient(180deg,var(--gold-lite),transparent 70%)}
@keyframes spin{to{transform:rotate(360deg)}}

/* ---------- Services intro media ---------- */
.svc-feature{position:relative;border-radius:var(--radius-lg);overflow:hidden;min-height:100%;
  border:1px solid var(--line);display:flex;flex-direction:column;justify-content:flex-end;padding:40px}
.svc-feature .bg{position:absolute;inset:0;z-index:-2}
.svc-feature .bg img{width:100%;height:100%;object-fit:cover}
.svc-feature::after{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(180deg,rgba(8,8,10,.2),rgba(8,8,10,.92))}

/* services bento */
.svc-bento{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:1fr;gap:20px;margin-top:54px}
.svc-bento .svc-card.wide{grid-column:span 2}
@media (max-width:900px){
  .svc-bento{grid-template-columns:1fr 1fr}
  .svc-bento .svc-card.wide{grid-column:span 2}
}
@media (max-width:560px){
  .svc-bento{grid-template-columns:1fr}
  .svc-bento .svc-card.wide{grid-column:span 1}
}

/* ---------- Page hero (inner pages) ---------- */
.phero{position:relative;padding:170px 0 90px;overflow:hidden}
.phero-media{position:absolute;inset:0;z-index:-3}
.phero-media img{width:100%;height:100%;object-fit:cover}
.phero-media::after{content:"";position:absolute;inset:0;
  background:linear-gradient(100deg,rgba(8,8,10,.96) 30%,rgba(8,8,10,.7) 65%,rgba(8,8,10,.35))}
.phero-inner{max-width:720px}
.crumb{display:flex;gap:9px;align-items:center;font-family:var(--label);font-size:12.5px;
  letter-spacing:.08em;color:var(--muted);margin-bottom:22px}
.crumb a:hover{color:var(--gold-lite)}
.crumb svg{width:14px;height:14px;color:var(--gold)}
.phero h1{margin-bottom:20px}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:48px;align-items:start}
@media (max-width:980px){.contact-grid{grid-template-columns:1fr}}
.field{margin-bottom:18px}
.field label{display:block;font-family:var(--label);font-size:12px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--gold);margin-bottom:9px}
.field input,.field select,.field textarea{width:100%;padding:15px 17px;border-radius:12px;
  background:rgba(255,255,255,.03);border:1px solid var(--line);color:var(--paper);font-family:var(--body);
  font-size:15.5px;transition:.3s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold);
  background:rgba(200,160,78,.05);box-shadow:0 0 0 4px rgba(200,160,78,.08)}
.field textarea{min-height:130px;resize:vertical}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media (max-width:560px){.form-row{grid-template-columns:1fr}}
.contact-info .ci{display:flex;gap:16px;padding:22px 0;border-bottom:1px solid var(--line-soft)}
.contact-info .ci .ic{width:50px;height:50px;border-radius:13px;flex:none;display:grid;place-items:center;
  background:radial-gradient(circle at 30% 25%,#23211b,#121116);border:1px solid var(--line);box-shadow:var(--shadow-gold)}
.contact-info .ci .ic svg{width:23px;height:23px;color:var(--gold-lite)}
.contact-info .ci b{font-family:var(--label);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold)}
.contact-info .ci p{font-size:16px;color:var(--paper)}
.contact-info .ci a:hover{color:var(--gold-lite)}
.map-frame{border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--line);height:320px;margin-top:34px}
.map-frame iframe{width:100%;height:100%;border:0;filter:grayscale(.3) invert(.9) hue-rotate(180deg) contrast(.9)}

/* ---------- Pricing-ish cards ---------- */
.price-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:22px;margin-top:50px}
.price-card{padding:36px 30px;border-radius:var(--radius);background:linear-gradient(180deg,var(--char),var(--ink-2));
  border:1px solid var(--line);position:relative;overflow:hidden;transition:.5s var(--ease)}
.price-card:hover{transform:translateY(-6px);border-color:rgba(200,160,78,.4)}
.price-card.feature{border-color:rgba(200,160,78,.5);box-shadow:var(--shadow-gold)}
.price-card .tag{position:absolute;top:18px;right:18px;font-family:var(--label);font-size:10.5px;
  letter-spacing:.12em;text-transform:uppercase;color:#16120A;background:var(--grad-gold);
  padding:5px 11px;border-radius:999px}
.price-card h3{font-size:1.45rem;margin-bottom:6px}
.price-card .from{font-family:var(--label);color:var(--muted);font-size:13px;margin-bottom:18px}
.price-card .amt{font-family:var(--display);font-size:2.8rem;line-height:1;margin-bottom:20px;
  background:var(--grad-gold);-webkit-background-clip:text;background-clip:text;color:transparent}
.price-card .amt small{font-size:1rem;color:var(--muted);-webkit-text-fill-color:var(--muted)}
.price-card ul li{display:flex;gap:11px;padding:8px 0;font-size:14.5px;color:var(--paper-dim);border-top:1px solid var(--line-soft)}
.price-card ul li:first-child{border-top:none}
.price-card ul svg{width:19px;height:19px;color:var(--gold-lite);flex:none;margin-top:2px}

/* ---------- area chips ---------- */
.area-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;margin-top:40px}
.area-chip{padding:16px 18px;border-radius:12px;background:var(--char);border:1px solid var(--line);
  display:flex;align-items:center;gap:11px;font-size:14.5px;color:var(--paper-dim);transition:.4s}
.area-chip:hover{border-color:var(--gold);color:var(--gold-lite);transform:translateY(-3px)}
.area-chip svg{width:17px;height:17px;color:var(--gold);flex:none}
