/* ============================================================
   STAR ROOTER PLUMBING — "Brightest Star in Plumbing"
   Night-sky theme. Deep navy, star-gold glow, signal-red urgency.
   ============================================================ */

:root{
  /* palette */
  --midnight:#05122B;
  --navy:#0A1C40;
  --navy-2:#102a5c;
  --navy-line:rgba(120,160,230,.14);
  --star-gold:#FFD23F;
  --star-gold-soft:#ffe07a;
  --signal-red:#E63027;
  --signal-red-2:#ff4b3e;
  --sky-blue:#5B8DEF;
  --cloud:#F3F7FF;
  --muted:#9FB2D6;
  --muted-2:#6f83ab;

  /* type */
  --f-display:"Space Grotesk", system-ui, sans-serif;
  --f-body:"Inter", system-ui, sans-serif;
  --f-mono:"Space Mono", ui-monospace, monospace;

  /* layout */
  --maxw:1180px;
  --radius:18px;
  --radius-sm:12px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}

body{
  font-family:var(--f-body);
  background:var(--midnight);
  color:var(--cloud);
  line-height:1.6;
  overflow-x:hidden;
  position:relative;
}

/* subtle vertical sky gradient layered above the canvas */
body::before{
  content:"";
  position:fixed;
  inset:0;
  background:
    radial-gradient(1200px 700px at 80% -10%, rgba(91,141,239,.18), transparent 60%),
    radial-gradient(900px 600px at 10% 10%, rgba(255,210,63,.06), transparent 55%),
    linear-gradient(180deg, #061026 0%, #05122B 40%, #050f24 100%);
  z-index:-2;
  pointer-events:none;
}

#starfield{
  position:fixed;
  inset:0;
  z-index:-1;
  pointer-events:none;
}

img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

/* ---------- shared bits ---------- */
.eyebrow{
  font-family:var(--f-mono);
  font-size:.72rem;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--star-gold);
  margin-bottom:1rem;
}
.section__title{
  font-family:var(--f-display);
  font-weight:700;
  font-size:clamp(1.7rem,3.6vw,2.7rem);
  line-height:1.08;
  letter-spacing:-.02em;
  color:#fff;
}
.section__lead{
  color:var(--muted);
  font-size:1.05rem;
  max-width:54ch;
  margin-top:1rem;
}
.section__lead a, .services__head a{color:var(--star-gold-soft)}
.section__head{max-width:680px;margin:0 auto clamp(2.5rem,5vw,4rem);text-align:center}
.section__head .section__lead{margin-left:auto;margin-right:auto}

/* ---------- buttons ---------- */
.btn{
  --b:transparent;
  display:inline-flex;align-items:center;gap:.5em;
  font-family:var(--f-display);
  font-weight:600;
  font-size:.98rem;
  padding:.82em 1.4em;
  border-radius:999px;
  border:1.5px solid transparent;
  cursor:pointer;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease), background .25s, color .25s;
  white-space:nowrap;
}
.btn--lg{padding:1em 1.7em;font-size:1.05rem}
.btn--gold{background:var(--star-gold);color:#1a1300;box-shadow:0 6px 22px -8px rgba(255,210,63,.7)}
.btn--gold:hover{transform:translateY(-2px);box-shadow:0 12px 30px -8px rgba(255,210,63,.85)}
.btn--red{background:var(--signal-red);color:#fff;box-shadow:0 6px 24px -8px rgba(230,48,39,.8)}
.btn--red:hover{transform:translateY(-2px);background:var(--signal-red-2);box-shadow:0 14px 34px -8px rgba(255,75,62,.9)}
.btn--ghost{background:rgba(255,255,255,.04);border-color:rgba(159,178,214,.4);color:#fff}
.btn--ghost:hover{transform:translateY(-2px);border-color:var(--star-gold);color:var(--star-gold-soft);background:rgba(255,210,63,.06)}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:60;
  display:flex;align-items:center;gap:1.5rem;
  padding:1rem clamp(1rem,4vw,2.4rem);
  transition:background .3s, backdrop-filter .3s, padding .3s, border-color .3s;
  border-bottom:1px solid transparent;
}
.nav.is-stuck{
  background:rgba(6,15,35,.82);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--navy-line);
  padding-top:.7rem;padding-bottom:.7rem;
}
.nav__brand{display:flex;align-items:center;gap:.7rem;flex-shrink:0}
.nav__logo{width:46px;height:auto;filter:drop-shadow(0 2px 8px rgba(255,210,63,.4))}
.nav__name{
  font-family:var(--f-display);font-weight:700;font-size:1.15rem;line-height:1;
  display:flex;flex-direction:column;letter-spacing:-.01em;
}
.nav__name-sub{font-size:.66rem;letter-spacing:.32em;text-transform:uppercase;color:var(--star-gold);font-weight:500;margin-top:2px}

.nav__links{display:flex;gap:1.7rem;margin-left:auto}
.nav__links a{
  font-size:.95rem;color:var(--muted);position:relative;padding:.2rem 0;font-weight:500;
  transition:color .2s;
}
.nav__links a::after{
  content:"";position:absolute;left:0;bottom:-2px;height:2px;width:0;
  background:var(--star-gold);transition:width .3s var(--ease);
}
.nav__links a:hover{color:#fff}
.nav__links a:hover::after{width:100%}
.nav__links-call,.nav__links-cta{display:none}

.nav__actions{display:flex;align-items:center;gap:1rem}
.nav__phone{display:flex;align-items:center;gap:.45rem;font-family:var(--f-mono);font-weight:700;font-size:.95rem;color:#fff;transition:color .2s}
.nav__phone:hover{color:var(--star-gold)}
.nav__phone-icon{color:var(--star-gold)}

.nav__toggle{
  display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px;
}
.nav__toggle span{display:block;width:26px;height:2px;background:#fff;border-radius:2px;transition:transform .3s, opacity .3s}
.nav__toggle.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav__toggle.is-open span:nth-child(2){opacity:0}
.nav__toggle.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;
  min-height:100vh;
  display:flex;flex-direction:column;justify-content:center;
  padding:7rem clamp(1.2rem,5vw,3rem) 4rem;
  max-width:var(--maxw);margin:0 auto;
}
.hero__glow{
  position:absolute;top:30%;right:-5%;width:520px;height:520px;
  background:radial-gradient(circle, rgba(255,210,63,.22), transparent 65%);
  filter:blur(20px);pointer-events:none;z-index:0;
}
.hero__inner{position:relative;z-index:2;max-width:760px}
.hero__eyebrow{opacity:0;transform:translateY(14px);animation:rise .7s var(--ease) .15s forwards}
.hero__title{
  font-family:var(--f-display);
  font-weight:700;
  font-size:clamp(2.7rem,8vw,5.6rem);
  line-height:.98;
  letter-spacing:-.03em;
  color:#fff;
  margin-bottom:1.5rem;
}
.hero__title .reveal-word{
  display:inline-block;opacity:0;transform:translateY(28px) rotate(2deg);
  animation:wordIn .8s var(--ease) forwards;
}
.hero__title .reveal-word:nth-child(1){animation-delay:.30s}
.hero__title .reveal-word:nth-child(2){animation-delay:.40s}
.hero__title .reveal-word:nth-child(3){animation-delay:.52s}
.hero__title .reveal-word:nth-child(4){animation-delay:.64s}
.hero__title .reveal-word:nth-child(5){animation-delay:.74s}
.hero__title-accent{
  color:var(--star-gold);
  position:relative;
  text-shadow:0 0 34px rgba(255,210,63,.55);
}
.hero__title-accent::after{
  content:"★";
  position:absolute;top:-.55em;right:-.62em;font-size:.4em;
  color:var(--star-gold);
  animation:twinkle 2.4s ease-in-out infinite;
  text-shadow:0 0 18px rgba(255,210,63,.9);
}
.hero__sub{
  font-size:clamp(1.05rem,2vw,1.28rem);
  color:var(--muted);
  max-width:52ch;margin-bottom:2rem;
  opacity:0;transform:translateY(14px);animation:rise .7s var(--ease) .9s forwards;
}
.hero__sub strong{color:var(--star-gold-soft)}
.hero__cta{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:2.4rem;opacity:0;animation:rise .7s var(--ease) 1.05s forwards}
.hero__badges{
  list-style:none;display:flex;flex-wrap:wrap;gap:1.6rem;
  font-family:var(--f-mono);font-size:.82rem;color:var(--muted-2);
  opacity:0;animation:rise .7s var(--ease) 1.2s forwards;
}
.hero__badges li{display:flex;align-items:center;gap:.5rem}
.hero__badge-star{color:var(--star-gold)}

/* floating logo star */
.hero__star{
  position:absolute;top:50%;right:clamp(-40px,3vw,40px);transform:translateY(-50%);
  width:clamp(240px,32vw,420px);z-index:1;
  opacity:0;animation:starIn 1.4s var(--ease) .6s forwards;
}
.hero__star-img{width:100%;animation:float 6s ease-in-out infinite;filter:drop-shadow(0 10px 40px rgba(255,210,63,.35))}
.hero__star-halo{
  position:absolute;inset:-12%;border-radius:50%;
  background:radial-gradient(circle, rgba(255,210,63,.28), transparent 62%);
  filter:blur(8px);animation:pulse 4s ease-in-out infinite;
}

.hero__scroll{
  position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:.5rem;z-index:3;
  font-family:var(--f-mono);font-size:.66rem;letter-spacing:.3em;text-transform:uppercase;color:var(--muted-2);
}
.hero__scroll-dot{
  width:22px;height:36px;border:1.5px solid var(--muted-2);border-radius:12px;position:relative;
}
.hero__scroll-dot::after{
  content:"";position:absolute;left:50%;top:7px;width:4px;height:7px;border-radius:2px;
  background:var(--star-gold);transform:translateX(-50%);animation:scrollDot 1.8s var(--ease) infinite;
}

/* ============================================================
   TRUST STRIP
   ============================================================ */
.trust{
  position:relative;z-index:2;
  border-top:1px solid var(--navy-line);
  border-bottom:1px solid var(--navy-line);
  background:linear-gradient(180deg, rgba(16,42,92,.5), rgba(10,28,64,.3));
  backdrop-filter:blur(6px);
}
.trust__inner{
  max-width:var(--maxw);margin:0 auto;
  display:grid;grid-template-columns:repeat(5,1fr);
  padding:2.4rem clamp(1.2rem,4vw,2rem);gap:1.5rem;text-align:center;
}
.trust__item{display:flex;flex-direction:column;gap:.35rem;position:relative}
.trust__item:not(:last-child)::after{
  content:"";position:absolute;right:-.75rem;top:15%;height:70%;width:1px;background:var(--navy-line);
}
.trust__num{
  font-family:var(--f-display);font-weight:700;font-size:clamp(1.8rem,3.2vw,2.5rem);
  color:var(--star-gold);line-height:1;
}
.trust__label{font-size:.82rem;color:var(--muted);display:flex;flex-direction:column;gap:.15rem}
.trust__stars{color:var(--star-gold);letter-spacing:.1em;font-size:.8rem}

/* ============================================================
   ABOUT
   ============================================================ */
.about{max-width:var(--maxw);margin:0 auto;padding:clamp(4rem,9vw,7rem) clamp(1.2rem,5vw,3rem)}
.about__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.about__media{position:relative}
.about__photo{border-radius:var(--radius);box-shadow:0 30px 60px -30px rgba(0,0,0,.8)}
.about__photo--main{width:100%;border:1px solid var(--navy-line)}
.about__photo--inset{
  position:absolute;bottom:-2rem;right:-1.5rem;width:48%;
  border:4px solid var(--midnight);box-shadow:0 20px 40px -18px rgba(0,0,0,.9);
}
.about__badge{
  position:absolute;top:-1.4rem;left:-1.4rem;
  background:var(--star-gold);color:#1a1300;
  display:flex;align-items:center;gap:.5rem;
  padding:.7rem 1.1rem;border-radius:14px;font-family:var(--f-display);font-weight:700;
  font-size:.85rem;line-height:1.05;box-shadow:0 16px 30px -12px rgba(255,210,63,.6);
  transform:rotate(-4deg);
}
.about__badge-star{font-size:1.4rem;animation:twinkle 2.8s ease-in-out infinite}
.about__copy p{color:var(--muted);margin-bottom:1.1rem}
.about__copy .section__title{margin-bottom:1.4rem}
.about__list{list-style:none;margin:1.6rem 0 2rem;display:flex;flex-direction:column;gap:.8rem}
.about__list li{position:relative;padding-left:1.8rem;color:#dbe5fb}
.about__list li::before{content:"★";position:absolute;left:0;color:var(--star-gold);font-size:.9rem;top:.15rem}

/* ============================================================
   SERVICES
   ============================================================ */
.services{max-width:var(--maxw);margin:0 auto;padding:clamp(3rem,7vw,5rem) clamp(1.2rem,5vw,3rem)}
.services__grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;
}
.svc{
  background:linear-gradient(160deg, rgba(18,42,92,.65), rgba(10,28,64,.5));
  border:1px solid var(--navy-line);
  border-radius:var(--radius);
  padding:1.8rem 1.6rem;
  transition:transform .35s var(--ease), border-color .35s, box-shadow .35s, background .35s;
  position:relative;overflow:hidden;
}
.svc::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(220px 120px at var(--mx,50%) var(--my,0%), rgba(255,210,63,.12), transparent 70%);
  opacity:0;transition:opacity .35s;pointer-events:none;
}
.svc:hover{transform:translateY(-6px);border-color:rgba(255,210,63,.5);box-shadow:0 24px 50px -28px rgba(0,0,0,.9)}
.svc:hover::before{opacity:1}
.svc__icon{
  display:inline-flex;align-items:center;justify-content:center;
  width:50px;height:50px;border-radius:14px;font-size:1.5rem;margin-bottom:1.1rem;
  background:rgba(255,210,63,.1);border:1px solid rgba(255,210,63,.25);
}
.svc h3{font-family:var(--f-display);font-weight:600;font-size:1.18rem;margin-bottom:.5rem;color:#fff}
.svc p{color:var(--muted);font-size:.95rem}
.services__note{text-align:center;color:var(--muted-2);font-family:var(--f-mono);font-size:.82rem;margin-top:2.2rem}

/* ============================================================
   PROMISE
   ============================================================ */
.promise{
  position:relative;
  padding:clamp(4rem,8vw,6rem) clamp(1.2rem,5vw,3rem);
  border-top:1px solid var(--navy-line);
  border-bottom:1px solid var(--navy-line);
  background:linear-gradient(180deg, rgba(10,28,64,.35), rgba(5,18,43,.1));
}
.promise__head{max-width:var(--maxw);margin:0 auto 3rem}
.promise__grid{
  max-width:var(--maxw);margin:0 auto;
  display:grid;grid-template-columns:repeat(5,1fr);gap:1rem;
}
.promise__card{
  padding:1.6rem 1.3rem;border-radius:var(--radius-sm);
  background:rgba(255,255,255,.025);
  border:1px solid var(--navy-line);
  transition:transform .3s var(--ease), border-color .3s;
}
.promise__card:hover{transform:translateY(-5px);border-color:rgba(255,210,63,.4)}
.promise__no{
  font-family:var(--f-mono);font-weight:700;font-size:.85rem;color:var(--star-gold);
  display:block;margin-bottom:.9rem;
}
.promise__card h3{font-family:var(--f-display);font-weight:600;font-size:1.05rem;margin-bottom:.5rem;line-height:1.2}
.promise__card p{font-size:.88rem;color:var(--muted)}

/* ============================================================
   WORK / GALLERY
   ============================================================ */
.work{max-width:var(--maxw);margin:0 auto;padding:clamp(4rem,9vw,7rem) clamp(1.2rem,5vw,3rem)}
.work__gallery{
  display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:1rem;
}
.work__item{
  position:relative;border:0;padding:0;cursor:pointer;overflow:hidden;border-radius:var(--radius-sm);
  background:var(--navy);border:1px solid var(--navy-line);
}
.work__item--tall{grid-row:span 2}
.work__item--wide{grid-column:span 2}
.work__item img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .6s var(--ease), filter .4s;
  filter:saturate(.92) brightness(.86);
}
.work__item:hover img{transform:scale(1.07);filter:saturate(1.05) brightness(1)}
.work__cap{
  position:absolute;left:0;right:0;bottom:0;
  padding:1.4rem 1rem .9rem;text-align:left;
  font-family:var(--f-display);font-weight:600;font-size:.92rem;color:#fff;
  background:linear-gradient(0deg, rgba(5,15,35,.92), transparent);
  transform:translateY(8px);opacity:.85;transition:transform .35s var(--ease), opacity .35s;
}
.work__item:hover .work__cap{transform:translateY(0);opacity:1}
.work__item::after{
  content:"⤢";position:absolute;top:.7rem;right:.8rem;
  width:30px;height:30px;display:grid;place-items:center;
  background:rgba(255,210,63,.92);color:#1a1300;border-radius:8px;font-size:.95rem;
  opacity:0;transform:scale(.7);transition:opacity .3s, transform .3s;
}
.work__item:hover::after{opacity:1;transform:scale(1)}

/* ============================================================
   REVIEWS
   ============================================================ */
.reviews{
  padding:clamp(4rem,8vw,6rem) clamp(1.2rem,5vw,3rem);
  border-top:1px solid var(--navy-line);
  background:linear-gradient(180deg, rgba(16,42,92,.28), transparent);
  overflow:hidden;
}
.reviews__head{max-width:var(--maxw);margin:0 auto 3rem;text-align:center}
.reviews__rating{display:inline-flex;align-items:center;gap:.9rem;margin-top:1.2rem;flex-wrap:wrap;justify-content:center}
.reviews__score{font-family:var(--f-display);font-weight:700;font-size:2.4rem;color:var(--star-gold)}
.reviews__stars{font-size:1.4rem;color:var(--star-gold);letter-spacing:.08em;position:relative}
.reviews__star-half{position:relative;color:var(--muted-2)}
.reviews__star-half::before{content:"★";position:absolute;left:0;top:0;width:60%;overflow:hidden;color:var(--star-gold)}
.reviews__count{font-family:var(--f-mono);font-size:.85rem;color:var(--muted)}

.reviews__carousel{max-width:var(--maxw);margin:0 auto;overflow:hidden}
.reviews__track{display:flex;gap:1.4rem;transition:transform .6s var(--ease);will-change:transform}
.review{
  flex:0 0 calc((100% - 2.8rem)/3);
  background:linear-gradient(160deg, rgba(18,42,92,.6), rgba(10,28,64,.5));
  border:1px solid var(--navy-line);border-radius:var(--radius);
  padding:1.9rem 1.7rem;display:flex;flex-direction:column;gap:1rem;
}
.review__stars{color:var(--star-gold);letter-spacing:.12em;font-size:1rem}
.review blockquote{font-size:.98rem;color:#dde6fa;line-height:1.6;flex:1}
.review figcaption{display:flex;flex-direction:column;border-top:1px solid var(--navy-line);padding-top:.9rem}
.review figcaption strong{font-family:var(--f-display);font-weight:600;color:#fff;font-size:1rem}
.review figcaption span{font-size:.78rem;color:var(--star-gold);font-family:var(--f-mono);letter-spacing:.05em;margin-top:2px}

.reviews__controls{max-width:var(--maxw);margin:2.2rem auto 0;display:flex;align-items:center;justify-content:center;gap:1.4rem}
.reviews__btn{
  width:46px;height:46px;border-radius:50%;border:1.5px solid var(--navy-line);
  background:rgba(255,255,255,.03);color:#fff;font-size:1.1rem;cursor:pointer;
  transition:border-color .25s, background .25s, transform .25s;
}
.reviews__btn:hover{border-color:var(--star-gold);color:var(--star-gold);transform:translateY(-2px)}
.reviews__dots{display:flex;gap:.5rem}
.reviews__dots button{
  width:9px;height:9px;border-radius:50%;border:0;cursor:pointer;padding:0;
  background:var(--navy-2);transition:background .25s, width .25s, border-radius .25s;
}
.reviews__dots button.is-active{background:var(--star-gold);width:26px;border-radius:5px}

/* ============================================================
   CONTACT
   ============================================================ */
.contact{max-width:var(--maxw);margin:0 auto;padding:clamp(4rem,9vw,7rem) clamp(1.2rem,5vw,3rem)}
.contact__grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(2rem,5vw,4rem);align-items:start}
.contact__lead{color:var(--muted);margin:1rem 0 1.8rem}
.contact__phone{
  display:inline-flex;align-items:center;gap:.6rem;
  font-family:var(--f-display);font-weight:700;font-size:1.7rem;color:#fff;
  margin-bottom:1.8rem;transition:color .2s;
}
.contact__phone span{color:var(--star-gold)}
.contact__phone:hover{color:var(--star-gold-soft)}
.contact__facts{list-style:none;display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}
.contact__facts li{display:flex;flex-direction:column;gap:.15rem;padding-bottom:1rem;border-bottom:1px solid var(--navy-line)}
.contact__facts span{font-family:var(--f-mono);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--star-gold)}
.contact__facts li{color:#dbe5fb}
.contact__promise{
  display:flex;align-items:center;gap:.7rem;
  background:rgba(230,48,39,.1);border:1px solid rgba(230,48,39,.35);
  padding:1rem 1.2rem;border-radius:var(--radius-sm);
  font-family:var(--f-display);font-weight:600;color:#ffd9d6;
}
.contact__promise-star{color:var(--star-gold);font-size:1.2rem}

.contact__form{
  background:linear-gradient(170deg, rgba(18,42,92,.55), rgba(10,28,64,.5));
  border:1px solid var(--navy-line);border-radius:var(--radius);
  padding:clamp(1.6rem,3vw,2.4rem);position:relative;
}
.field{display:flex;flex-direction:column;gap:.45rem;margin-bottom:1.1rem}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.field label{font-family:var(--f-mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.field input,.field select,.field textarea{
  font-family:var(--f-body);font-size:1rem;color:#fff;
  background:rgba(5,15,35,.6);border:1.5px solid var(--navy-line);
  border-radius:10px;padding:.8rem .9rem;transition:border-color .25s, box-shadow .25s;
  width:100%;
}
.field input::placeholder,.field textarea::placeholder{color:var(--muted-2)}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--star-gold);box-shadow:0 0 0 3px rgba(255,210,63,.15);
}
.field select{appearance:none;cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23FFD23F' d='M6 8L0 0h12z'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.4rem;
}
.field textarea{resize:vertical;min-height:96px}
.field--check{flex-direction:row;align-items:center;gap:.6rem}
.field--check input{width:18px;height:18px;accent-color:var(--star-gold);flex-shrink:0}
.field--check label{text-transform:none;letter-spacing:0;font-family:var(--f-body);font-size:.92rem;color:#dbe5fb}
.field.is-invalid input,.field.is-invalid select{border-color:var(--signal-red)}
.contact__submit{width:100%;justify-content:center;margin-top:.4rem}
.contact__demo-note{text-align:center;font-size:.75rem;color:var(--muted-2);margin-top:.9rem;font-family:var(--f-mono)}

.contact__success[hidden]{display:none}
.contact__success{
  position:absolute;inset:0;border-radius:var(--radius);
  background:linear-gradient(170deg, rgba(12,32,68,.97), rgba(8,22,52,.97));
  display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;
  padding:2rem;gap:.6rem;animation:rise .5s var(--ease);
}
.contact__success-star{font-size:2.6rem;color:var(--star-gold);animation:twinkle 2s ease-in-out infinite;text-shadow:0 0 24px rgba(255,210,63,.7)}
.contact__success h3{font-family:var(--f-display);font-size:1.4rem;color:#fff}
.contact__success p{color:var(--muted);max-width:34ch}
.contact__success a{color:var(--star-gold-soft);font-weight:600}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{border-top:1px solid var(--navy-line);background:rgba(4,12,28,.7);position:relative;z-index:2}
.footer__inner{
  max-width:var(--maxw);margin:0 auto;
  display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:2.5rem;
  padding:clamp(3rem,5vw,4rem) clamp(1.2rem,5vw,3rem) 2.5rem;
}
.footer__logo{width:64px;margin-bottom:1rem;filter:drop-shadow(0 2px 10px rgba(255,210,63,.4))}
.footer__tag{font-family:var(--f-display);font-style:italic;color:var(--star-gold);font-size:1.05rem;margin-bottom:.7rem}
.footer__copy{color:var(--muted);font-size:.9rem;max-width:34ch}
.footer__col h4{font-family:var(--f-display);font-size:.95rem;color:#fff;margin-bottom:1rem;letter-spacing:.02em}
.footer__col a,.footer__col span{display:block;color:var(--muted);font-size:.9rem;margin-bottom:.6rem;transition:color .2s}
.footer__col a:hover{color:var(--star-gold)}
.footer__cta-col .btn{margin-top:.3rem}
.footer__bar{
  max-width:var(--maxw);margin:0 auto;
  padding:1.4rem clamp(1.2rem,5vw,3rem);
  border-top:1px solid var(--navy-line);
  display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;
  font-size:.78rem;color:var(--muted-2);font-family:var(--f-mono);
}

/* ============================================================
   LIGHTBOX
   ============================================================ */
.lightbox{
  position:fixed;inset:0;z-index:100;
  background:rgba(3,9,22,.94);backdrop-filter:blur(8px);
  display:flex;align-items:center;justify-content:center;padding:2rem;
  opacity:0;visibility:hidden;transition:opacity .3s, visibility .3s;
}
.lightbox.is-open{opacity:1;visibility:visible}
.lightbox__figure{max-width:min(900px,92vw);text-align:center;transform:scale(.95);transition:transform .35s var(--ease)}
.lightbox.is-open .lightbox__figure{transform:scale(1)}
.lightbox__figure img{width:100%;border-radius:var(--radius);box-shadow:0 30px 80px -20px rgba(0,0,0,.9)}
.lightbox__figure figcaption{margin-top:1rem;color:var(--muted);font-family:var(--f-mono);font-size:.85rem}
.lightbox__close{
  position:absolute;top:1.4rem;right:1.6rem;width:46px;height:46px;border-radius:50%;
  border:1.5px solid var(--navy-line);background:rgba(255,255,255,.05);color:#fff;font-size:1.5rem;cursor:pointer;
  transition:border-color .25s, color .25s, transform .25s;
}
.lightbox__close:hover{border-color:var(--star-gold);color:var(--star-gold);transform:rotate(90deg)}

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

/* ============================================================
   KEYFRAMES
   ============================================================ */
@keyframes rise{to{opacity:1;transform:none}}
@keyframes wordIn{to{opacity:1;transform:none}}
@keyframes starIn{from{opacity:0;transform:translateY(-50%) scale(.6) rotate(-12deg)}to{opacity:1;transform:translateY(-50%) scale(1) rotate(0)}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-18px)}}
@keyframes pulse{0%,100%{opacity:.55;transform:scale(1)}50%{opacity:1;transform:scale(1.06)}}
@keyframes twinkle{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.8)}}
@keyframes scrollDot{0%{opacity:0;transform:translate(-50%,0)}40%{opacity:1}80%{opacity:0;transform:translate(-50%,12px)}100%{opacity:0}}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1024px){
  .services__grid{grid-template-columns:repeat(2,1fr)}
  .promise__grid{grid-template-columns:repeat(3,1fr)}
  .review{flex:0 0 calc((100% - 1.4rem)/2)}
  .footer__inner{grid-template-columns:1fr 1fr}
  .hero__star{opacity:.25 !important;width:280px}
}
@media (max-width:820px){
  .nav__links,.nav__phone,.nav__cta{display:none}
  .nav{gap:1rem}
  .nav__actions{margin-left:auto}
  .nav__toggle{display:flex}
  .nav.is-stuck .nav__links--open,.nav__links--open{
    display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;gap:0;
    background:rgba(6,15,35,.97);backdrop-filter:blur(14px);
    padding:1rem 1.5rem 1.5rem;border-bottom:1px solid var(--navy-line);margin-left:0;
  }
  .nav__links--open a{padding:.9rem 0;border-bottom:1px solid var(--navy-line)}
  .nav__links--open .nav__links-call{display:block;color:var(--star-gold);font-family:var(--f-mono);font-weight:700;border-bottom:1px solid var(--navy-line)}
  .nav__links--open .nav__links-cta{
    display:block;text-align:center;margin-top:1rem;border:0;
    background:var(--star-gold);color:#1a1300;border-radius:999px;font-weight:600;
    font-family:var(--f-display);padding:.9rem 0;
  }
  .nav__links--open .nav__links-cta::after{display:none}
  .trust__inner{grid-template-columns:repeat(2,1fr);gap:2rem}
  .trust__item:nth-child(3)::after,.trust__item:nth-child(5)::after{display:none}
  .trust__item:nth-child(2)::after{display:none}
  .about__grid{grid-template-columns:1fr;gap:3.5rem}
  .about__photo--inset{width:42%;right:0;bottom:-1.5rem}
  .promise__grid{grid-template-columns:repeat(2,1fr)}
  .work__gallery{grid-template-columns:repeat(2,1fr);grid-auto-rows:170px}
  .work__item--wide{grid-column:span 2}
  .work__item--tall{grid-row:span 1}
  .review{flex:0 0 100%}
  .contact__grid{grid-template-columns:1fr}
  .footer__inner{grid-template-columns:1fr 1fr;gap:2rem}
  .hero__star{display:none}
  .hero{min-height:auto;padding-top:8rem}
}
@media (max-width:480px){
  .services__grid,.promise__grid{grid-template-columns:1fr}
  .trust__inner{grid-template-columns:1fr 1fr}
  .field-row{grid-template-columns:1fr}
  .footer__inner{grid-template-columns:1fr}
  .footer__bar{flex-direction:column;gap:.5rem}
  .hero__cta .btn{width:100%;justify-content:center}
}

/* ============================================================
   REDUCED MOTION
   ============================================================ */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important;scroll-behavior:auto}
  .reveal{opacity:1;transform:none}
  .hero__eyebrow,.hero__title .reveal-word,.hero__sub,.hero__cta,.hero__badges,.hero__star{opacity:1;transform:none;animation:none}
  .hero__star{transform:translateY(-50%)}
}
