/* ===================================================================
   TMC Redesign V2 — Design System
   Thurka Metal Crushers and Civil Constructors
   =================================================================== */

/* Google Fonts loaded via <link> tags in HTML to avoid @import blocking */

/* --- CSS Custom Properties --- */
:root {
  /* Backgrounds */
  --bg-deep:       #0b0d10;
  --bg-dark:       #111318;
  --bg-surface:    #181b20;
  --bg-elevated:   #1f2329;
  --bg-card:       #22272e;
  --bg-warm:       #f5f1e8;
  --bg-warm-alt:   #ece6d8;

  /* Text */
  --text-primary:  #edeae4;
  --text-secondary:#929aa4;
  --text-muted:    #5f6670;
  --text-dark:     #1a1c1f;

  /* Accent */
  --amber:         #d4952e;
  --amber-light:   #f0be54;
  --amber-glow:    rgba(212,149,46,.15);
  --amber-glow-strong: rgba(212,149,46,.35);

  /* Industrial */
  --steel:         #3d464f;
  --concrete:      #c6c0b4;
  --rust:          #8c4a2e;
  --quarry:        #2a2e33;
  --green:         #48785a;

  /* Utility */
  --radius-sm:     6px;
  --radius-md:     10px;
  --radius-lg:     16px;
  --shadow-soft:   0 8px 32px rgba(0,0,0,.25);
  --shadow-heavy:  0 24px 80px rgba(0,0,0,.4);
  --glass:         rgba(17,19,24,.65);
  --glass-border:  rgba(255,255,255,.08);
  --max-w:         1200px;
  --header-h:      72px;

  /* Transitions */
  --ease-out:      cubic-bezier(.2,.8,.2,1);
  --ease-spring:   cubic-bezier(.34,1.56,.64,1);
}

/* --- Reset --- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{margin:0;padding:0;font-family:'Inter',ui-sans-serif,system-ui,-apple-system,sans-serif;
  font-size:16px;line-height:1.6;color:var(--text-primary);background:var(--bg-deep);
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}
img,video,canvas,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4,h5,h6,p,figure,blockquote{margin:0}
ul,ol{margin:0;padding:0;list-style:none}
button,input,select,textarea{font:inherit;color:inherit;border:0;background:transparent}
button{cursor:pointer}
address{font-style:normal}

/* --- Typography --- */
h1,h2,h3{font-family:'Outfit','Inter',sans-serif;font-weight:800;letter-spacing:-.02em;line-height:1.05}
h1{font-size:clamp(2.8rem,7vw,5.8rem)}
h2{font-size:clamp(2rem,4.5vw,3.6rem)}
h3{font-size:clamp(1.15rem,2vw,1.35rem);font-weight:700;line-height:1.25}

/* --- Skip Link --- */
.skip-link{position:fixed;top:.75rem;left:.75rem;z-index:999;padding:.6rem 1.2rem;
  background:var(--amber);color:var(--text-dark);font-weight:700;border-radius:var(--radius-sm);
  transform:translateY(-200%);transition:transform .2s}
.skip-link:focus{transform:translateY(0)}

/* ===================================================================
   HEADER
   =================================================================== */
.site-header{position:fixed;top:0;left:0;right:0;z-index:90;display:flex;align-items:center;
  justify-content:space-between;gap:1rem;height:var(--header-h);
  padding:0 clamp(1rem,4vw,2.5rem);
  background:rgba(11,13,16,.45);backdrop-filter:blur(18px) saturate(1.5);
  border-bottom:1px solid var(--glass-border);transition:background .3s,box-shadow .3s}
.site-header.scrolled{background:rgba(11,13,16,.92);box-shadow:0 4px 30px rgba(0,0,0,.35)}

.brand{display:inline-flex;align-items:center;gap:.65rem}
.brand img{width:44px;height:44px;border-radius:var(--radius-sm);
  border:1px solid rgba(255,255,255,.12);object-fit:cover}
.brand-text{display:flex;flex-direction:column;line-height:1.2}
.brand-text strong{font-size:1.1rem;letter-spacing:.06em;font-family:'Outfit',sans-serif}
.brand-text small{font-size:.72rem;color:var(--text-secondary);letter-spacing:.03em}

.nav{display:flex;align-items:center;gap:clamp(.6rem,2vw,1.5rem)}
.nav a{font-size:.85rem;font-weight:700;color:rgba(255,255,255,.75);
  letter-spacing:.04em;text-transform:uppercase;transition:color .2s}
.nav a:hover,.nav a:focus-visible{color:#fff}
.nav a.active{color:var(--amber-light)}

.nav-cta{display:inline-flex;align-items:center;gap:.4rem;padding:.55rem 1.1rem;
  background:linear-gradient(135deg,var(--amber),var(--amber-light));color:#111!important;
  border-radius:var(--radius-sm);font-size:.82rem;font-weight:800;letter-spacing:.02em;
  text-transform:uppercase;text-decoration:none;white-space:nowrap;
  transition:box-shadow .22s,transform .22s var(--ease-out)}
.nav-cta:hover{box-shadow:0 6px 24px rgba(212,149,46,.4);transform:translateY(-1px)}
.nav-cta svg{display:inline-block;flex-shrink:0}

.nav-toggle{display:none;flex-direction:column;justify-content:center;align-items:center;
  gap:5px;width:44px;height:44px;background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.14);border-radius:var(--radius-sm)}
.nav-toggle span{display:block;width:20px;height:2px;background:#fff;
  transition:transform .3s,opacity .2s}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.nav-toggle .sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0)}

/* ===================================================================
   HERO SECTION
   =================================================================== */
.hero{position:relative;min-height:100vh;min-height:100svh;display:flex;align-items:center;
  overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;transform:scale(1.06);will-change:transform}
.hero-overlay{position:absolute;inset:0;z-index:2;
  background:linear-gradient(135deg,rgba(11,13,16,.94) 0%,rgba(11,13,16,.7) 40%,rgba(11,13,16,.25) 100%),
             linear-gradient(0deg,rgba(11,13,16,.88) 0%,transparent 50%)}
.hero-canvas{position:absolute;inset:0;z-index:1;opacity:.5;mix-blend-mode:screen;pointer-events:none}

.hero-content{width:min(var(--max-w),calc(100% - 2rem));margin:0 auto;
  padding:clamp(8rem,16vh,12rem) 0 clamp(6rem,10vh,8rem);position:relative;z-index:3}
.hero .eyebrow{margin-bottom:1rem;color:var(--amber-light);font-size:.8rem;font-weight:800;
  letter-spacing:.16em;text-transform:uppercase;display:inline-flex;align-items:center;gap:.6rem}
.hero .eyebrow::before{content:'';width:28px;height:2px;background:var(--amber)}
.hero h1{max-width:820px;margin-bottom:1.2rem}
.hero-sub{max-width:600px;margin-bottom:2rem;color:rgba(255,255,255,.72);
  font-size:clamp(1rem,1.5vw,1.15rem);line-height:1.65}
.hero-ctas{display:flex;flex-wrap:wrap;gap:.75rem}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
  min-height:52px;padding:.85rem 1.6rem;font-weight:800;font-size:.9rem;
  letter-spacing:.03em;border-radius:var(--radius-sm);transition:transform .22s var(--ease-out),
  box-shadow .22s,background .22s,border-color .22s}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:translateY(0)}
.btn-primary{color:#111;background:linear-gradient(135deg,var(--amber),var(--amber-light));
  box-shadow:0 8px 28px rgba(212,149,46,.28)}
.btn-primary:hover{box-shadow:0 12px 40px rgba(212,149,46,.42)}
.btn-ghost{color:#fff;border:1.5px solid rgba(255,255,255,.3);
  background:rgba(255,255,255,.04)}
.btn-ghost:hover{border-color:rgba(255,255,255,.55);background:rgba(255,255,255,.08)}

/* Hero Stats */
.hero-stats{position:absolute;right:0;bottom:clamp(1rem,4vw,2.5rem);z-index:4;
  display:grid;grid-template-columns:repeat(3,1fr);
  background:var(--glass);backdrop-filter:blur(14px);
  border:1px solid var(--glass-border);border-radius:var(--radius-md);
  box-shadow:var(--shadow-heavy);overflow:hidden}
.hero-stats .stat{padding:1.2rem 1.5rem;border-left:1px solid rgba(255,255,255,.08);
  text-align:center}
.hero-stats .stat:first-child{border-left:0}
.hero-stats .stat-value{display:block;font-family:'Outfit',sans-serif;
  font-size:1.8rem;font-weight:900;line-height:1;color:#fff}
.hero-stats .stat-label{font-size:.72rem;color:var(--text-secondary);
  letter-spacing:.04em;margin-top:.3rem;display:block}

/* ===================================================================
   TRUST STRIP
   =================================================================== */
.trust-strip{position:relative;z-index:5;background:var(--bg-surface);
  border-top:1px solid rgba(255,255,255,.04);border-bottom:1px solid rgba(255,255,255,.04)}
.trust-strip-inner{width:min(var(--max-w),calc(100% - 2rem));margin:0 auto;
  display:grid;grid-template-columns:repeat(4,1fr);gap:1px}
.trust-item{padding:1.5rem 1rem;text-align:center;position:relative}
.trust-item::after{content:'';position:absolute;right:0;top:20%;height:60%;width:1px;
  background:rgba(255,255,255,.06)}
.trust-item:last-child::after{display:none}
.trust-item .trust-number{display:block;font-family:'Outfit',sans-serif;
  font-size:clamp(1.6rem,3vw,2.2rem);font-weight:900;color:var(--amber-light)}
.trust-item .trust-label{font-size:.82rem;color:var(--text-secondary);margin-top:.2rem;display:block}

/* ===================================================================
   SECTIONS — Global
   =================================================================== */
.section{padding:clamp(5rem,10vw,8rem) 1rem}
.section-inner{width:min(var(--max-w),100%);margin:0 auto}
.section-header{max-width:680px;margin-bottom:clamp(2.5rem,5vw,4rem)}
.section-header.centered{text-align:center;margin-inline:auto}
.section-header .eyebrow{margin-bottom:.8rem;color:var(--amber);font-size:.78rem;
  font-weight:800;letter-spacing:.16em;text-transform:uppercase;
  display:inline-flex;align-items:center;gap:.5rem}
.section-header .eyebrow::before{content:'';width:20px;height:2px;background:var(--amber)}
.section-header p{margin-top:1rem;color:var(--text-secondary);font-size:1.05rem;line-height:1.65}

/* Dark sections */
.section--dark{background:var(--bg-dark);color:var(--text-primary)}
.section--surface{background:var(--bg-surface)}
.section--warm{background:var(--bg-warm);color:var(--text-dark)}
.section--warm .section-header p{color:#5a5d5f}
.section--warm h2,.section--warm h3{color:var(--text-dark)}
.section--deep{background:var(--bg-deep)}

/* ===================================================================
   ABOUT SECTION
   =================================================================== */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2.5rem,6vw,5rem);align-items:center}
.about-copy p{color:var(--text-secondary);font-size:1.05rem;line-height:1.7;margin-bottom:1.2rem}
.about-copy p:last-child{margin-bottom:0}
.about-highlights{display:flex;flex-wrap:wrap;gap:.65rem;margin-top:1.8rem}
.about-highlights span{padding:.65rem 1rem;background:var(--bg-card);
  border-left:3px solid var(--amber);font-weight:700;font-size:.88rem;
  border-radius:0 var(--radius-sm) var(--radius-sm) 0}

.about-visual{position:relative}
.about-image-wrapper{position:relative;border-radius:var(--radius-lg);overflow:hidden;
  box-shadow:var(--shadow-heavy)}
.about-image-wrapper img{width:100%;height:auto;display:block;
  transition:transform .6s var(--ease-out)}
.about-image-wrapper:hover img{transform:scale(1.04)}
.about-image-overlay{position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 50%,rgba(11,13,16,.55) 100%)}

.about-stats-card{display:grid;grid-template-columns:1fr 1fr;gap:1px;
  margin:-3rem 1.5rem 0;position:relative;z-index:2;
  background:var(--glass-border);border-radius:var(--radius-md);overflow:hidden;
  box-shadow:var(--shadow-soft)}
.about-stat{padding:1.2rem 1rem;background:var(--bg-card);
  backdrop-filter:blur(12px);text-align:center;
  transition:background .25s}
.about-stat:hover{background:var(--bg-elevated)}
.about-stat-value{display:block;font-family:'Outfit',sans-serif;
  font-size:clamp(1.1rem,2vw,1.5rem);font-weight:900;line-height:1.2;
  color:var(--amber-light)}
.about-stat-label{display:block;font-size:.72rem;color:var(--text-secondary);
  letter-spacing:.03em;margin-top:.25rem}

/* ===================================================================
   SERVICES SECTION
   =================================================================== */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}

.service-card{position:relative;background:var(--bg-card);border:1px solid var(--glass-border);
  border-radius:var(--radius-md);overflow:hidden;cursor:pointer;
  transition:transform .28s var(--ease-out),box-shadow .28s,border-color .28s}
.service-card:hover{transform:translateY(-6px);
  box-shadow:0 20px 50px rgba(0,0,0,.35);border-color:rgba(212,149,46,.4)}

.service-card-img{position:relative;overflow:hidden;aspect-ratio:16/10}
.service-card-img img{width:100%;height:100%;object-fit:cover;
  transition:transform .5s var(--ease-out);filter:saturate(.92) brightness(.95)}
.service-card:hover .service-card-img img{transform:scale(1.08);
  filter:saturate(1) brightness(1)}
.service-card-img::after{content:'';position:absolute;inset:0;
  background:linear-gradient(0deg,rgba(11,13,16,.6) 0%,transparent 55%)}

.service-card-body{padding:1.3rem 1.3rem 1.5rem}

/* ===================================================================
   LOCAL SEO LANDING CONTENT
   =================================================================== */
.local-seo{position:relative;overflow:hidden}
.local-seo::before{content:'';position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(circle at 20% 10%,rgba(212,149,46,.16),transparent 32%),
             radial-gradient(circle at 85% 80%,rgba(72,120,90,.14),transparent 34%)}
.seo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;position:relative;z-index:1}
.seo-card{display:block;padding:1.35rem;background:#fff;border:1px solid rgba(26,28,31,.12);
  border-radius:var(--radius-md);box-shadow:0 10px 30px rgba(26,28,31,.08);
  transition:transform .24s var(--ease-out),box-shadow .24s,border-color .24s}
.seo-card:hover{transform:translateY(-4px);box-shadow:0 18px 44px rgba(26,28,31,.14);
  border-color:rgba(212,149,46,.45)}
.seo-card span{display:inline-block;margin-bottom:.75rem;color:var(--rust);font-size:.78rem;
  font-weight:900;letter-spacing:.12em;text-transform:uppercase}
.seo-card h3{color:var(--text-dark);margin-bottom:.65rem}
.seo-card p{color:#5a5d5f;font-size:.96rem;line-height:1.65}
.area-list{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.5rem;position:relative;z-index:1}
.area-list strong,.area-list span{display:inline-flex;align-items:center;min-height:38px;
  padding:.45rem .75rem;background:#fff;border:1px solid rgba(26,28,31,.12);
  border-radius:999px;color:var(--text-dark);font-weight:800}
.area-list span{color:#5a5d5f;font-weight:700}

.seo-page{background:var(--bg-deep);color:var(--text-primary)}
.seo-hero{position:relative;min-height:72vh;display:flex;align-items:center;overflow:hidden;
  padding:calc(var(--header-h) + 4rem) 1rem 4rem}
.seo-hero::before{content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(11,13,16,.92),rgba(11,13,16,.62)),
             url('/assets/images/optimized/hero-1280.jpg') center/cover;z-index:0}
.seo-hero .section-inner{position:relative;z-index:1}
.seo-hero h1{max-width:860px;margin-bottom:1rem}
.seo-hero p{max-width:720px;color:rgba(255,255,255,.76);font-size:1.1rem}
.seo-breadcrumb{display:flex;gap:.45rem;flex-wrap:wrap;margin-bottom:1.2rem;
  color:var(--amber-light);font-size:.85rem;font-weight:800}
.seo-content{padding:clamp(4rem,8vw,6.5rem) 1rem;background:var(--bg-warm);color:var(--text-dark)}
.seo-content-grid{width:min(var(--max-w),100%);margin:0 auto;display:grid;
  grid-template-columns:minmax(0,1fr) 340px;gap:clamp(2rem,5vw,4rem);align-items:start}
.seo-main h2,.seo-main h3{color:var(--text-dark);margin-bottom:1rem}
.seo-main p{color:#555b60;margin-bottom:1.1rem;font-size:1.02rem}
.seo-main ul{display:grid;gap:.6rem;margin:1rem 0 1.8rem}
.seo-main li{position:relative;padding-left:1.4rem;color:#4c5358}
.seo-main li::before{content:'';position:absolute;left:0;top:.65rem;width:7px;height:7px;
  border-radius:50%;background:var(--amber)}
.seo-sidebar{position:sticky;top:calc(var(--header-h) + 1rem);display:grid;gap:1rem}
.quote-card,.nearby-card{padding:1.2rem;background:#fff;border-radius:var(--radius-md);
  border:1px solid rgba(26,28,31,.12);box-shadow:0 12px 32px rgba(26,28,31,.08)}
.quote-card h3,.nearby-card h3{margin-bottom:.6rem;color:var(--text-dark)}
.quote-card p,.nearby-card p{color:#5a5d5f;margin-bottom:1rem}
.nearby-card div{display:flex;flex-wrap:wrap;gap:.45rem}
.nearby-card span{padding:.38rem .58rem;border-radius:999px;background:#f2eee5;color:#4f565b;
  font-size:.84rem;font-weight:800}
.faq-list{display:grid;gap:1rem;margin-top:1rem}
.faq-item{padding:1rem;background:#fff;border:1px solid rgba(26,28,31,.1);border-radius:var(--radius-md)}
.faq-item strong{display:block;margin-bottom:.35rem;color:var(--text-dark)}
.faq-item p{margin-bottom:0}
.service-card-body h3{margin-bottom:.5rem;color:var(--text-primary)}
.service-card-body p{color:var(--text-secondary);font-size:.9rem;line-height:1.55;margin-bottom:0}
.service-card-num{position:absolute;top:1rem;right:1rem;width:36px;height:36px;
  display:grid;place-items:center;background:var(--glass);backdrop-filter:blur(8px);
  border:1px solid var(--glass-border);border-radius:50%;
  font-family:'Outfit',sans-serif;font-size:.75rem;font-weight:800;color:var(--amber-light)}

/* ===================================================================
   PROCESS SECTION
   =================================================================== */
.process-timeline{display:grid;grid-template-columns:repeat(5,1fr);gap:0;position:relative;
  margin-top:clamp(2rem,4vw,3rem)}
.process-timeline::before{content:'';position:absolute;top:28px;left:10%;right:10%;
  height:3px;background:var(--bg-card);border-radius:2px}
.process-line{position:absolute;top:28px;left:10%;height:3px;width:0;
  background:linear-gradient(90deg,var(--amber),var(--amber-light));border-radius:2px;
  transition:width 1.5s var(--ease-out)}
.process-timeline.is-visible .process-line{width:80%}

.process-step{text-align:center;position:relative;z-index:2}
.process-dot{width:56px;height:56px;margin:0 auto 1.2rem;display:grid;place-items:center;
  background:var(--bg-card);border:2px solid var(--glass-border);border-radius:50%;
  font-family:'Outfit',sans-serif;font-size:1rem;font-weight:900;color:var(--text-muted);
  transition:border-color .4s,color .4s,background .4s,box-shadow .4s}
.process-timeline.is-visible .process-dot{border-color:var(--amber);color:var(--amber-light);
  box-shadow:0 0 24px var(--amber-glow)}
.process-step strong{display:block;margin-bottom:.4rem;font-size:1rem;color:var(--text-primary)}
.process-step p{font-size:.82rem;color:var(--text-secondary);line-height:1.45;
  max-width:160px;margin:0 auto}

/* ===================================================================
   CAPABILITIES SECTION
   =================================================================== */
.capabilities-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}

.capability-card{padding:1.8rem;background:var(--bg-elevated);
  border:1px solid var(--glass-border);border-radius:var(--radius-md);
  transition:border-color .25s,box-shadow .25s,transform .25s var(--ease-out)}
.capability-card:hover{border-color:rgba(212,149,46,.25);
  box-shadow:0 12px 40px rgba(0,0,0,.2);transform:translateY(-3px)}

.capability-icon{width:48px;height:48px;display:grid;place-items:center;
  margin-bottom:1.2rem;background:var(--amber-glow);border-radius:var(--radius-sm);
  color:var(--amber-light);font-size:1.3rem}
.capability-icon svg{width:24px;height:24px;fill:currentColor}
.capability-card h3{margin-bottom:.5rem}
.capability-card p{color:var(--text-secondary);font-size:.9rem;line-height:1.55;margin-bottom:0}

/* ===================================================================
   PARTNERS SECTION
   =================================================================== */
.partner-marquee{overflow:hidden;border:1px solid var(--glass-border);
  border-radius:var(--radius-md);background:var(--bg-card);padding:.5rem 0}
.partner-track{display:flex;width:max-content;animation:marquee 30s linear infinite}
.partner-marquee:hover .partner-track{animation-play-state:paused}
.partner-track img{width:200px;height:100px;object-fit:contain;padding:1rem 2rem;flex:0 0 auto;
  filter:brightness(.7) grayscale(.3);transition:filter .3s}
.partner-track img:hover{filter:brightness(1) grayscale(0)}

/* ===================================================================
   GALLERY SECTION
   =================================================================== */
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.8rem}
.gallery-item{position:relative;overflow:hidden;border-radius:var(--radius-md);
  aspect-ratio:16/10;cursor:pointer}
.gallery-item img{width:100%;height:100%;object-fit:cover;
  transition:transform .5s var(--ease-out),filter .3s}
.gallery-item:hover img{transform:scale(1.08);filter:brightness(1.1)}
.gallery-item::after{content:'';position:absolute;inset:0;
  background:linear-gradient(0deg,rgba(11,13,16,.5) 0%,transparent 50%);
  opacity:0;transition:opacity .3s}
.gallery-item:hover::after{opacity:1}
.gallery-item-label{position:absolute;bottom:0;left:0;right:0;padding:.8rem 1rem;
  z-index:2;color:#fff;font-weight:700;font-size:.85rem;
  transform:translateY(100%);transition:transform .3s var(--ease-out)}
.gallery-item:hover .gallery-item-label{transform:translateY(0)}

/* ===================================================================
   CONTACT SECTION
   =================================================================== */
.contact-section{background:linear-gradient(135deg,var(--bg-dark),var(--quarry))}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:start}

.contact-info h2{margin-bottom:1.2rem}
.contact-info>p{color:var(--text-secondary);font-size:1.05rem;line-height:1.65;margin-bottom:2rem}
.contact-details{display:flex;flex-direction:column;gap:1rem}
.contact-detail{display:flex;align-items:flex-start;gap:.85rem}
.contact-detail-icon{width:40px;height:40px;flex-shrink:0;display:grid;place-items:center;
  background:var(--amber-glow);border-radius:var(--radius-sm);color:var(--amber-light)}
.contact-detail-icon svg{width:18px;height:18px;fill:currentColor}
.contact-detail-text{font-size:.92rem}
.contact-detail-text strong{display:block;color:var(--text-primary);margin-bottom:.15rem}
.contact-detail-text a,.contact-detail-text span{color:var(--text-secondary)}
.contact-detail-text a:hover{color:var(--amber-light)}

.contact-form{background:var(--bg-card);border:1px solid var(--glass-border);
  border-radius:var(--radius-lg);padding:clamp(1.5rem,3vw,2.5rem);box-shadow:var(--shadow-soft)}
.contact-form h3{margin-bottom:1.5rem;font-size:1.3rem}

.form-group{position:relative;margin-bottom:1.2rem}
.form-group label{display:block;font-size:.78rem;font-weight:700;color:var(--text-secondary);
  letter-spacing:.05em;text-transform:uppercase;margin-bottom:.4rem}
.form-group input,.form-group textarea,.form-group select{width:100%;padding:.85rem 1rem;
  background:var(--bg-surface);border:1px solid rgba(255,255,255,.08);
  border-radius:var(--radius-sm);color:var(--text-primary);font-size:.92rem;
  transition:border-color .2s,box-shadow .2s}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:0;
  border-color:var(--amber);box-shadow:0 0 0 3px var(--amber-glow)}
.form-group textarea{resize:vertical;min-height:100px}
.form-group select{appearance:none;cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23929aa4' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 1rem center}
.form-group select option{background:var(--bg-surface);color:var(--text-primary)}

.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}

.btn-submit{width:100%;min-height:54px;margin-top:.5rem}

/* ===================================================================
   FOOTER
   =================================================================== */
.site-footer{background:var(--bg-deep);border-top:1px solid rgba(255,255,255,.04);
  padding:clamp(3rem,6vw,5rem) 1rem clamp(1.5rem,3vw,2rem)}
.footer-inner{width:min(var(--max-w),100%);margin:0 auto}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:clamp(1.5rem,3vw,3rem);
  padding-bottom:clamp(2rem,4vw,3rem);border-bottom:1px solid rgba(255,255,255,.06)}
.footer-col h4{font-family:'Outfit',sans-serif;font-size:.92rem;font-weight:800;
  margin-bottom:1rem;color:var(--text-primary);letter-spacing:.03em}
.footer-brand p{color:var(--text-secondary);font-size:.88rem;line-height:1.6;margin-top:.6rem}
.footer-col a{display:block;padding:.3rem 0;color:var(--text-secondary);font-size:.88rem;
  transition:color .2s}
.footer-col a:hover{color:var(--amber-light)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;
  padding-top:1.5rem;color:var(--text-muted);font-size:.8rem;flex-wrap:wrap;gap:.5rem}
.footer-bottom a{color:var(--text-secondary)}
.footer-bottom a:hover{color:var(--amber-light)}

/* ===================================================================
   SCROLL REVEAL
   =================================================================== */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .7s var(--ease-out),
  transform .7s var(--ease-out)}
.reveal.is-visible{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:.1s}
.reveal-delay-2{transition-delay:.2s}
.reveal-delay-3{transition-delay:.3s}
.reveal-delay-4{transition-delay:.4s}
.reveal-delay-5{transition-delay:.5s}

/* Hero entrance */
.hero-enter{opacity:0;transform:translateY(28px);
  animation:heroEnter .9s var(--ease-out) forwards}
.hero-enter:nth-child(2){animation-delay:.1s}
.hero-enter:nth-child(3){animation-delay:.2s}
.hero-enter:nth-child(4){animation-delay:.3s}
.hero-enter:nth-child(5){animation-delay:.4s}

@keyframes heroEnter{to{opacity:1;transform:translateY(0)}}

/* ===================================================================
   ANIMATIONS
   =================================================================== */
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}

@keyframes glow{0%,100%{box-shadow:0 0 20px var(--amber-glow)}
  50%{box-shadow:0 0 40px var(--amber-glow-strong)}}

@keyframes pulse{0%,100%{opacity:.6}50%{opacity:1}}

/* ===================================================================
   RESPONSIVE
   =================================================================== */
@media(max-width:1024px){
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .seo-grid{grid-template-columns:1fr}
  .seo-content-grid{grid-template-columns:1fr}
  .seo-sidebar{position:static}
  .capabilities-grid{grid-template-columns:repeat(2,1fr)}
  .about-grid{grid-template-columns:1fr}
  .about-visual{max-width:500px;margin:0 auto}
  .contact-grid{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:repeat(2,1fr)}
  .process-timeline{grid-template-columns:repeat(3,1fr);gap:1.5rem}
  .process-step:nth-child(n+4){margin-top:1.5rem}
  .process-timeline::before,.process-line{display:none}
}

@media(max-width:768px){
  .nav{position:fixed;top:var(--header-h);left:0;right:0;
    flex-direction:column;gap:0;background:rgba(11,13,16,.96);
    backdrop-filter:blur(20px);border-bottom:1px solid var(--glass-border);
    max-height:0;overflow:hidden;transition:max-height .35s var(--ease-out)}
  .nav.is-open{max-height:620px}
  .nav a{display:block;padding:1rem 1.5rem;border-bottom:1px solid rgba(255,255,255,.04);
    font-size:.95rem;width:100%}
  .nav-toggle{display:flex}

  .seo-page .site-header{height:auto;min-height:var(--header-h);align-items:flex-start;
    flex-direction:column;padding-top:.85rem;padding-bottom:.85rem}
  .seo-page .nav{position:static;display:flex;max-height:none;overflow:visible;
    flex-direction:row;flex-wrap:wrap;gap:.35rem;background:transparent;border-bottom:0;
    backdrop-filter:none;width:100%}
  .seo-page .nav a{width:auto;padding:.45rem .65rem;border-bottom:0;font-size:.78rem}
  .seo-page .nav .nav-cta{padding:.55rem .85rem}

  .hero-stats{position:relative;right:auto;bottom:auto;margin-top:2rem;width:100%}
  .hero-content{padding:clamp(7rem,14vh,10rem) 0 2rem}

  .trust-strip-inner{grid-template-columns:repeat(2,1fr)}
  .seo-hero{min-height:auto;padding:calc(var(--header-h) + 3rem) 1rem 3rem}
  .trust-item:nth-child(2)::after{display:none}

  .services-grid{grid-template-columns:1fr}
  .capabilities-grid{grid-template-columns:1fr}
  .process-timeline{grid-template-columns:1fr;gap:1rem}
  .process-step{display:flex;align-items:flex-start;gap:1rem;text-align:left}
  .process-dot{margin:0;flex-shrink:0}
  .process-step p{max-width:none}

  .gallery-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}

  .form-row{grid-template-columns:1fr}
}

@media(max-width:480px){
  .hero h1{font-size:2.2rem}
  .hero-ctas{flex-direction:column}
  .btn{width:100%;justify-content:center}
  .trust-strip-inner{grid-template-columns:1fr}
  .trust-item::after{display:none}
}

/* ===================================================================
   REDUCED MOTION
   =================================================================== */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;
    transition-duration:.01ms!important;scroll-behavior:auto!important}
  .partner-track{animation:none!important}
  .reveal{opacity:1;transform:none}
  .hero-enter{opacity:1;transform:none;animation:none}
  .hero-bg img{transform:none}
}

/* ===================================================================
   FOCUS / ACCESSIBILITY
   =================================================================== */
:focus-visible{outline:2px solid var(--amber);outline-offset:3px;border-radius:2px}
::selection{background:var(--amber);color:#111}
