/* ============================================================
   Devoted Services LLC — Iron-Forge archetype
   wrought-iron black + bronze/steel + cream, picket rhythm
   ============================================================ */

:root{
  --iron:#0e0e10;        /* wrought-iron black */
  --iron-2:#17171b;      /* panel */
  --iron-3:#202026;      /* card */
  --bronze:#c4863f;      /* metallic accent */
  --bronze-lt:#e8b873;
  --bronze-dk:#8a571f;
  --steel:#8d9299;
  --cream:#f4efe6;       /* clean cream */
  --cream-2:#fbf8f2;
  --ink:#1c1b18;
  --line:rgba(196,134,63,.28);
  --maxw:1120px;
  --r:14px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:"Inter",system-ui,-apple-system,sans-serif;
  background:var(--cream);
  color:var(--ink);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
h1,h2,h3{font-family:"Oswald",sans-serif;font-weight:600;line-height:1.08;letter-spacing:.5px;text-transform:uppercase;margin:0}

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

.skip-link{
  position:absolute;left:-999px;top:0;z-index:200;
  background:var(--bronze);color:var(--iron);padding:12px 18px;font-weight:700;border-radius:0 0 8px 0;
}
.skip-link:focus{left:0}

:focus-visible{outline:3px solid var(--bronze);outline-offset:2px;border-radius:4px}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  min-height:48px;padding:0 26px;font-family:"Oswald",sans-serif;
  font-weight:600;letter-spacing:1px;text-transform:uppercase;font-size:.95rem;
  border-radius:8px;cursor:pointer;border:2px solid transparent;
  transition:transform .2s var(--ease),background .2s,box-shadow .2s;
}
.btn-primary{background:var(--bronze);color:var(--iron);box-shadow:0 6px 22px rgba(196,134,63,.35)}
.btn-primary:hover{background:var(--bronze-lt);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--cream);border-color:var(--bronze)}
.btn-ghost:hover{background:rgba(196,134,63,.16);transform:translateY(-2px)}
.btn-block{width:100%}

/* ============================================================
   HEADER
   ============================================================ */
.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(14,14,16,.92);
  backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);
  transition:background .3s;
}
.header-inner{display:flex;align-items:center;justify-content:space-between;min-height:64px}
.logo{display:flex;align-items:center;gap:10px;color:var(--bronze);min-height:44px}
.logo-mark{width:34px;height:34px}
.logo-text{display:flex;flex-direction:column;line-height:1}
.logo-text strong{font-family:"Oswald",sans-serif;font-size:1.18rem;letter-spacing:1px;color:var(--cream);text-transform:uppercase}
.logo-text em{font-style:normal;font-size:.6rem;letter-spacing:3px;color:var(--bronze);text-transform:uppercase;margin-top:2px}

.main-nav{display:none;align-items:center;gap:26px}
.main-nav a{color:var(--cream);font-size:.9rem;font-weight:500;letter-spacing:.4px;transition:color .2s}
.main-nav a:hover{color:var(--bronze-lt)}
.main-nav .nav-cta{
  background:var(--bronze);color:var(--iron);padding:10px 18px;border-radius:7px;font-weight:700;
}
.main-nav .nav-cta:hover{background:var(--bronze-lt);color:var(--iron)}

@media(min-width:860px){.main-nav{display:flex}}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;overflow:hidden;
  background:var(--iron);
  color:var(--cream);
  padding:54px 0 70px;
  /* fence-picket rhythm in the background */
  background-image:repeating-linear-gradient(90deg,
    rgba(196,134,63,.06) 0 2px, transparent 2px 46px);
}
.hero::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(14,14,16,0) 40%,var(--iron) 100%);
  pointer-events:none;z-index:2;
}
.hero-art{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:min(560px,120%);opacity:.5;z-index:1;pointer-events:none;
}
.gate-svg{width:100%;height:auto}
.forge-glow{transform-origin:center;animation:glowPulse 5s ease-in-out infinite}
@keyframes glowPulse{0%,100%{opacity:.5}50%{opacity:1}}

.hero-inner{position:relative;z-index:3;text-align:center;max-width:680px}
.eyebrow{
  font-family:"Oswald",sans-serif;letter-spacing:3px;text-transform:uppercase;
  font-size:.74rem;color:var(--bronze-lt);margin:0 0 16px;
}
.hero h1{font-size:clamp(2.4rem,9vw,4.2rem);margin-bottom:18px}
.hero h1 .accent{color:var(--bronze-lt);display:block}
.hero-sub{font-size:1.06rem;color:rgba(244,239,230,.82);max-width:540px;margin:0 auto 28px}
.hero-actions{display:flex;flex-direction:column;gap:12px;align-items:stretch;max-width:340px;margin:0 auto}

.hero-trust{
  list-style:none;display:flex;flex-wrap:wrap;justify-content:center;gap:14px 28px;
  margin:36px 0 0;padding:0;
}
.hero-trust li{
  display:flex;flex-direction:column;font-size:.78rem;letter-spacing:.5px;
  color:rgba(244,239,230,.7);text-transform:uppercase;
}
.hero-trust span{font-family:"Oswald",sans-serif;color:var(--bronze-lt);font-size:1.05rem;letter-spacing:1px}

@media(min-width:760px){
  .hero{padding:90px 0 110px}
  .hero-inner{text-align:left;margin-left:0}
  .hero-actions{flex-direction:row;margin:0}
  .hero-trust{justify-content:flex-start}
  .hero-art{left:auto;right:-6%;transform:translateY(-50%);top:50%;width:min(620px,55%);opacity:.85}
}

/* ============================================================
   SECTIONS (shared)
   ============================================================ */
.section{padding:64px 0;position:relative}
.kicker{
  font-family:"Oswald",sans-serif;letter-spacing:3px;text-transform:uppercase;
  font-size:.74rem;color:var(--bronze-dk);margin:0 0 10px;font-weight:600;
}
.section-title{
  font-size:clamp(1.8rem,6vw,2.7rem);color:var(--ink);margin-bottom:14px;max-width:18ch;
}
.section-lead{max-width:56ch;color:#5a544a;margin:0 0 30px;font-size:1.02rem}

/* vertical bronze "picket" tick before section titles */
.kicker::before{
  content:"";display:inline-block;width:24px;height:3px;background:var(--bronze);
  vertical-align:middle;margin-right:10px;
}

/* ---------- Services ---------- */
.services{background:var(--cream-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.svc-grid{display:grid;grid-template-columns:1fr;gap:16px;margin-top:8px}
.svc-card{
  background:#fff;border:1px solid rgba(28,27,24,.08);border-left:4px solid var(--bronze);
  border-radius:var(--r);padding:26px 22px;
  transition:transform .3s var(--ease),box-shadow .3s,border-color .3s;
}
.svc-card:hover{transform:translateY(-4px);box-shadow:0 14px 36px rgba(28,27,24,.12);border-left-color:var(--bronze-dk)}
.svc-icon{width:56px;height:56px;color:var(--bronze-dk);margin-bottom:14px}
.svc-icon svg{width:100%;height:100%}
.svc-card h3{font-size:1.25rem;color:var(--ink);margin-bottom:8px}
.svc-card p{margin:0;color:#5a544a;font-size:.96rem}
@media(min-width:620px){.svc-grid{grid-template-columns:1fr 1fr}}
@media(min-width:1000px){.svc-grid{grid-template-columns:repeat(4,1fr)}}

/* ---------- Gallery ---------- */
.gallery{background:var(--iron);color:var(--cream)}
.gallery .section-title{color:var(--cream)}
.gallery .kicker{color:var(--bronze-lt)}
.gallery .section-lead{color:rgba(244,239,230,.72)}
.gallery-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.gtile{
  position:relative;border-radius:var(--r);overflow:hidden;aspect-ratio:4/3;
  border:1px solid var(--line);background:var(--iron-2);
}
.gtile svg{width:100%;height:100%}
.gtile figcaption{
  position:absolute;left:0;right:0;bottom:0;padding:10px 12px;
  font-family:"Oswald",sans-serif;letter-spacing:1px;text-transform:uppercase;font-size:.72rem;
  background:linear-gradient(0deg,rgba(14,14,16,.92),transparent);color:var(--bronze-lt);
}
@media(min-width:760px){.gallery-grid{grid-template-columns:repeat(3,1fr);gap:16px}}

/* ---------- Why Us ---------- */
.why{background:var(--cream-2)}
.why-grid{display:grid;grid-template-columns:1fr;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.why-item{background:var(--cream-2);padding:26px 22px;position:relative}
.why-num{font-family:"Oswald",sans-serif;font-size:1.4rem;color:var(--bronze);letter-spacing:1px}
.why-item h3{font-size:1.18rem;color:var(--ink);margin:6px 0 8px}
.why-item p{margin:0;color:#5a544a;font-size:.95rem}
@media(min-width:620px){.why-grid{grid-template-columns:1fr 1fr}}
@media(min-width:1000px){.why-grid{grid-template-columns:repeat(4,1fr)}}

/* ---------- About ---------- */
.about{background:var(--iron);color:var(--cream)}
.about .section-title{color:var(--cream)}
.about .kicker{color:var(--bronze-lt)}
.about-inner{display:grid;grid-template-columns:1fr;gap:34px;align-items:center}
.about-art{order:-1;max-width:260px;margin:0 auto}
.about-copy p{color:rgba(244,239,230,.82);margin:0 0 16px}
@media(min-width:820px){
  .about-inner{grid-template-columns:.8fr 1.2fr;gap:50px}
  .about-art{order:0;max-width:340px}
}

/* ---------- Reviews ---------- */
.reviews{background:var(--cream-2)}
.reviews-grid{display:grid;grid-template-columns:1fr;gap:16px;margin-bottom:18px}
.review-card{
  background:#fff;border:1px solid rgba(28,27,24,.08);border-top:4px solid var(--bronze);
  border-radius:var(--r);padding:24px 22px;
}
.stars{color:var(--bronze);letter-spacing:3px;font-size:1.1rem;margin-bottom:10px}
.review-card p{margin:0 0 12px;color:var(--ink);font-size:1rem}
.review-tag{font-family:"Oswald",sans-serif;letter-spacing:1px;text-transform:uppercase;font-size:.7rem;color:var(--bronze-dk)}
.reviews-note{font-size:.84rem;color:#8a8276;font-style:italic;margin:0}
@media(min-width:760px){.reviews-grid{grid-template-columns:repeat(3,1fr)}}

/* ---------- Service Area ---------- */
.area{background:var(--cream-2);border-top:1px solid var(--line)}
.area-list{
  list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:0;margin:0;max-width:680px;
}
.area-list li{
  background:#fff;border:1px solid rgba(28,27,24,.1);border-radius:9px;
  padding:13px 16px;font-weight:600;color:var(--ink);position:relative;padding-left:30px;font-size:.95rem;
}
.area-list li::before{
  content:"";position:absolute;left:14px;top:50%;transform:translateY(-50%);
  width:5px;height:18px;background:var(--bronze);border-radius:2px;
}
@media(min-width:620px){.area-list{grid-template-columns:repeat(3,1fr)}}
@media(min-width:900px){.area-list{grid-template-columns:repeat(5,1fr)}}

/* ---------- Contact ---------- */
.contact{background:var(--iron);color:var(--cream)}
.contact .section-title{color:var(--cream)}
.contact .kicker{color:var(--bronze-lt)}
.contact-inner{display:grid;grid-template-columns:1fr;gap:34px}
.contact-copy p{color:rgba(244,239,230,.82)}
.contact-points{list-style:none;padding:0;margin:20px 0 0}
.contact-points li{padding:8px 0;border-bottom:1px solid var(--line);font-size:.95rem;color:rgba(244,239,230,.86)}
.contact-points strong{color:var(--bronze-lt)}

.quote-form{
  background:var(--iron-3);border:1px solid var(--line);border-radius:var(--r);padding:26px 22px;
}
.field{margin-bottom:16px}
.field label{display:block;font-family:"Oswald",sans-serif;letter-spacing:1px;text-transform:uppercase;font-size:.74rem;color:var(--bronze-lt);margin-bottom:6px}
.field input,.field select,.field textarea{
  width:100%;min-height:48px;padding:12px 14px;border-radius:8px;
  border:1px solid rgba(141,146,153,.35);background:var(--iron-2);color:var(--cream);
  font-family:inherit;font-size:1rem;
}
.field textarea{min-height:auto;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--bronze);outline:none}
.form-status{margin:12px 0 0;font-size:.9rem;color:var(--bronze-lt);min-height:1.2em}
@media(min-width:860px){.contact-inner{grid-template-columns:1fr 1fr;gap:50px;align-items:start}}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:#080809;color:rgba(244,239,230,.7);padding:40px 0 90px;border-top:2px solid var(--bronze)}
.footer-inner{display:grid;grid-template-columns:1fr;gap:22px}
.footer-brand .logo-text{margin-bottom:8px}
.footer-brand p{margin:0;font-size:.92rem;max-width:40ch}
.footer-meta p{margin:4px 0;font-size:.85rem}
@media(min-width:760px){.footer-inner{grid-template-columns:1.2fr 1fr}.site-footer{padding-bottom:46px}}

/* ============================================================
   STICKY MOBILE CTA
   ============================================================ */
.sticky-cta{
  position:fixed;left:0;right:0;bottom:0;z-index:90;
  display:flex;gap:10px;padding:10px 14px;
  background:rgba(14,14,16,.96);backdrop-filter:blur(8px);
  border-top:1px solid var(--bronze);
}
.scta{
  flex:1;display:flex;align-items:center;justify-content:center;min-height:48px;
  border-radius:8px;font-family:"Oswald",sans-serif;font-weight:600;letter-spacing:1px;
  text-transform:uppercase;font-size:.92rem;
}
.scta-call{flex:0 0 96px;background:transparent;border:2px solid var(--bronze);color:var(--bronze-lt)}
.scta-quote{background:var(--bronze);color:var(--iron)}
@media(min-width:860px){.sticky-cta{display:none}.site-footer{padding-bottom:46px}}

/* ============================================================
   MOTION — reveal on scroll (JS-driven, fallback safe)
   ============================================================ */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important;scroll-behavior:auto !important}
  .reveal{opacity:1;transform:none}
  .forge-glow{animation:none;opacity:.7}
}
