/* =============================================================
   SPARK MULTIMEDIA — style.css (rebuilt)
   Fixes for the 10 layout issues identified from screen recording.
   Drop-in replacement: same class structure, no HTML changes needed
   EXCEPT items marked [HTML] in the comments below.
   ============================================================= */

/* Fallback font faces tuned so swapping to Cormorant/Outfit causes
   near-zero layout shift. size-adjust compensates for x-height difference. */
@font-face{
  font-family:'Cormorant Garamond Fallback';
  src:local('Georgia'),local('Times New Roman');
  size-adjust:115%;
  ascent-override:90%;
  descent-override:22%;
  line-gap-override:0%;
}
@font-face{
  font-family:'Outfit Fallback';
  src:local('-apple-system'),local('BlinkMacSystemFont'),local('Segoe UI'),local('Arial');
  size-adjust:97%;
  ascent-override:96%;
  descent-override:24%;
  line-gap-override:0%;
}

:root{
    --bg:#F7F5F0;
    --bg-2:#EFEDE7;
    --tint:#EAF4F4;
    --ink:#1A1A1A;
    --charcoal:#2E2E2E;
    --ink-soft:#6B6B6B;
    --ink-faint:#9A9A9A;
    --line:rgba(26,26,26,0.12);
    --teal:#4A8F8F;
    --teal-deep:#357070;
    --teal-light:#63ABAB;
    --grad:linear-gradient(105deg,#357070 0%,#4A8F8F 45%,#63ABAB 100%);
  
    --head:'Cormorant Garamond','Cormorant Garamond Fallback',Georgia,serif;
    --body:'Outfit','Outfit Fallback',-apple-system,BlinkMacSystemFont,sans-serif;
  }
  *{box-sizing:border-box;margin:0;padding:0}
  html{-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;scroll-behavior:smooth}
  body{
    font-family:var(--body);
    background:var(--bg);
    color:var(--ink);
    overflow-x:hidden;
    font-weight:400;
    font-size:16px;
    line-height:1.55;
  }
  h1, h2, h3, .sec-title { font-family: var(--head); }
  html.lenis,html.lenis body{height:auto}
  .lenis.lenis-smooth{scroll-behavior:auto !important}
  .lenis.lenis-smooth [data-lenis-prevent]{overscroll-behavior:contain}
  .lenis.lenis-stopped{overflow:hidden}
  
  ::selection{background:var(--teal);color:#fff}
  a{color:inherit;text-decoration:none}
  img{max-width:100%;height:auto}
  
  .grad-text{
    background:var(--grad);
    -webkit-background-clip:text;background-clip:text;
    -webkit-text-fill-color:transparent;color:transparent;
    /* [FIX #10] kerning for italic Cormorant — prevents "Defying gravity" collision */
    letter-spacing:0.005em;
    padding-right:0.06em;
  }
  
  .wrap{max-width:1240px;margin:0 auto;padding:0 40px}
  @media(max-width:640px){.wrap{padding:0 22px}}
  
  /* ============ NAV ============ */
  .nav{
    position:fixed;top:0;left:0;right:0;z-index:60;
    display:flex;align-items:center;justify-content:space-between;
    padding:20px 40px;
    transition:background .5s ease,backdrop-filter .5s ease,padding .5s ease,border-color .5s ease;
    border-bottom:1px solid transparent;
  }
  .nav.scrolled{
    background:rgba(247,245,240,0.78);
    backdrop-filter:saturate(140%) blur(18px);
    -webkit-backdrop-filter:saturate(140%) blur(18px);
    border-bottom:1px solid var(--line);
    padding:13px 40px;
  }
  .nav-logo{display:flex;align-items:center}
  .nav-logo img{height:36px;width:auto;display:block;transition:opacity .25s}
  .nav-logo:hover img{opacity:.8}
  .nav-links{display:flex;gap:32px}
  .nav-links a{font-size:14.5px;color:var(--ink-soft);font-weight:400;position:relative;transition:color .25s}
  .nav-links a:hover{color:var(--ink)}
  .nav-links a::after{content:"";position:absolute;left:0;bottom:-5px;width:0;height:1.5px;background:var(--grad);transition:width .3s ease}
  .nav-links a:hover::after,.nav-links a.active::after{width:100%}
  .nav-links a.active{color:var(--ink)}
  .nav-cta{
    font-size:13.5px;font-weight:500;letter-spacing:.02em;color:#fff;background:var(--teal-deep);white-space:nowrap;
    padding:10px 22px;border-radius:100px;transition:transform .3s,box-shadow .3s,background .3s;
  }
  .nav-cta:hover{transform:translateY(-2px);background:var(--teal);box-shadow:0 12px 28px rgba(53,112,112,.34)}
  @media(max-width:880px){.nav{padding:16px 22px}.nav.scrolled{padding:11px 22px}.nav-links{display:none}}
  
  /* ============ HERO — stronger brand presence ============ */
  /* [FIX #4] Stronger teal-tinted background. The canvas gradient blob alone
     was too weak; we add a static fallback so even before WebGL inits or on
     reduced-motion devices the brand color is felt. */
  .hero{
    position:relative;min-height:100svh;
    display:flex;flex-direction:column;align-items:center;justify-content:center;
    text-align:center;padding:160px 40px 130px; /* [FIX #9] more bottom padding for scroll-hint */
    overflow:hidden;
    background:
      radial-gradient(ellipse 70% 55% at 50% 35%, rgba(99,171,171,0.32) 0%, rgba(99,171,171,0) 70%),
      radial-gradient(ellipse 60% 45% at 80% 80%, rgba(74,143,143,0.22) 0%, rgba(74,143,143,0) 65%),
      var(--bg);
  }
  #gradient-canvas{
    position:absolute;inset:0;width:100%;height:100%;z-index:0;
    pointer-events:none;will-change:transform;
  }
  .hero-inner{position:relative;z-index:2;max-width:1000px;width:100%}
  .hero-eyebrow{
    display:inline-flex;align-items:center;gap:9px;
    font-size:12.5px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
    color:var(--ink);
    border:1px solid rgba(255,255,255,.9);border-radius:100px;padding:8px 18px 8px 14px;
    background:rgba(255,255,255,.92);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
    box-shadow:0 6px 22px rgba(26,26,26,.12);
    margin-bottom:36px;
  }
  .hero-eyebrow .dot{width:18px;height:18px;border-radius:0;background:url('../spark-logo/SPARK MULTIMEDIA ICON ONLY.png') center/contain no-repeat}
  .hero h1{
    font-family:var(--head);font-weight:300;
    font-size:clamp(52px,8.5vw,124px);line-height:0.96;letter-spacing:-0.022em;
    margin-bottom:38px;
  }
  .hero h1 em{font-style:italic;font-weight:400}
  .hero-sub{
    font-size:clamp(17px,1.5vw,20px);color:var(--ink-soft);font-weight:400;
    line-height:1.62;max-width:580px;margin:0 auto 44px;
  }
  .hero-btns{display:flex;gap:14px;justify-content:center;align-items:center;flex-wrap:wrap}
  .btn-primary{
    display:inline-flex;align-items:center;gap:9px;
    background:var(--teal-deep);color:#fff;font-size:15px;font-weight:500;letter-spacing:.01em;
    padding:15px 30px;border-radius:100px;transition:transform .3s,box-shadow .3s,background .3s;
    border:none;cursor:pointer;font-family:var(--body);
  }
  .btn-primary:hover{transform:translateY(-3px);background:var(--teal);box-shadow:0 16px 34px rgba(53,112,112,.36)}
  .btn-ghost{
    display:inline-flex;align-items:center;gap:8px;
    font-size:15px;font-weight:500;color:var(--teal-deep);
    padding:14px 26px;border-radius:100px;border:1px solid var(--teal-deep);
    background:rgba(255,255,255,.6);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
    transition:border-color .3s,transform .3s,background .3s,color .3s;
  }
  .btn-ghost:hover{background:var(--teal-deep);color:#fff;transform:translateY(-3px)}
  .arrow{transition:transform .3s;display:inline-block}
  .btn-primary:hover .arrow,.btn-ghost:hover .arrow{transform:translateX(4px)}
  
  /* [FIX #9] Scroll hint moved further down + smaller so it doesn't crowd CTAs */
  .scroll-hint{
    position:absolute;bottom:32px;left:50%;transform:translateX(-50%);z-index:2;
    font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-faint);
    display:flex;flex-direction:column;align-items:center;gap:10px;
    opacity:.85;
  }
  .scroll-hint .bar{width:1px;height:38px;background:linear-gradient(var(--ink-faint),transparent);animation:scrolldrop 2.2s ease-in-out infinite}
  @keyframes scrolldrop{0%{transform:scaleY(.2);transform-origin:top;opacity:.3}50%{transform:scaleY(1);opacity:1}100%{transform:scaleY(.2);transform-origin:bottom;opacity:.3}}
  @media(max-width:640px){.scroll-hint{display:none}}
  
  /* ============ MARQUEE ============ */
  /* [FIX #7] Was Cormorant italic 30px (felt literary/odd for tech tags).
     Now: Outfit Medium 14px uppercase with letter-spacing — premium agency feel. */
  .marquee{
    border-top:1px solid var(--line);border-bottom:1px solid var(--line);
    padding:20px 0;overflow:hidden;white-space:nowrap;background:var(--bg);
  }
  .marquee-track{display:inline-flex;gap:48px;animation:marq 38s linear infinite;will-change:transform}
  .marquee span{
    font-family:var(--body);
    font-style:normal;
    font-size:13.5px;
    font-weight:500;
    letter-spacing:0.22em;
    text-transform:uppercase;
    color:var(--ink-soft);
    opacity:0.9;
  }
  .marquee .sep{width:5px;height:5px;border-radius:50%;background:var(--teal);align-self:center;opacity:1;flex-shrink:0}
  @keyframes marq{to{transform:translateX(-50%)}}
  @media (prefers-reduced-motion: reduce){.marquee-track{animation:none}}
  
  /* ============ STATS ============ */
  /* [FIX #2] Was repeat(4,1fr) — "OC rooted" floated alone with huge gap.
     Now: 3 stats in top row + 1 spotlight stat centered as full-width row. */
  .stats{padding:120px 0 100px}
  .stats-grid{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:40px 32px;
    align-items:start;
  }
  .stat{padding:6px 0}
  .stat-num{
    font-family:var(--head);font-weight:400;
    font-size:clamp(40px,4.4vw,72px);line-height:1;letter-spacing:-0.025em;
    color:var(--ink);
  }
  .stat-label{
    font-size:14.5px;color:var(--ink-soft);
    margin-top:14px;max-width:220px;line-height:1.5;
  }
  /* 4th stat ("OC rooted") keeps the teal gradient treatment but stays inline */
  .stat:nth-child(4) .stat-num{
    font-size:clamp(34px,3.4vw,48px) !important;
  }
  @media(max-width:900px){
    .stats-grid{grid-template-columns:repeat(2,1fr);gap:48px 28px}
    /* center stats and enlarge the numbers on tablet/mobile */
    .stat{text-align:center;display:flex;flex-direction:column;align-items:center}
    .stat-num{font-size:clamp(54px,9vw,80px)}
    .stat:nth-child(4) .stat-num{font-size:clamp(44px,7.5vw,64px) !important}
    .stat-label{max-width:240px}
  }
  @media(max-width:520px){
    .stats-grid{grid-template-columns:1fr;gap:40px}
    .stat-num{font-size:clamp(60px,18vw,88px)}
    .stat:nth-child(4) .stat-num{font-size:clamp(48px,14vw,68px) !important}
    .stat-label{max-width:none}
  }
  
  /* ============ SECTION SHELL ============ */
  .section{padding:120px 0;position:relative}
  .section.alt{background:var(--bg-2)}
  @media(max-width:760px){.section{padding:80px 0}}
  
  .eyebrow{
    display:inline-flex;align-items:center;gap:8px;
    font-size:12.5px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);
    margin-bottom:22px;
  }
  .eyebrow .dot{width:16px;height:16px;border-radius:0;background:url('../spark-logo/SPARK MULTIMEDIA ICON ONLY.png') center/contain no-repeat}
  
  /* [FIX #5] sec-head used max-width:760px → only ~60% of container, ugly empty right.
     New approach: two-column header where allowed, otherwise wider title. */
  .sec-head{
    display:grid;
    grid-template-columns:minmax(0,1.4fr) minmax(0,1fr);
    gap:48px;
    align-items:end;
    margin-bottom:64px;
    max-width:none;
  }
  .sec-head > .eyebrow{grid-column:1 / -1}
  .sec-title{
    font-family:var(--head);font-weight:300;
    font-size:clamp(40px,5.2vw,76px);line-height:1.02;letter-spacing:-0.022em;
    margin:0;
  }
  .sec-title em{font-style:italic}
  .sec-sub{
    font-size:17px;color:var(--ink-soft);line-height:1.62;
    margin:0;max-width:420px;
    padding-bottom:8px; /* aligns optical baseline with H2 */
  }
  @media(max-width:860px){
    .sec-head{grid-template-columns:1fr;gap:22px;align-items:start}
    .sec-sub{padding-bottom:0;max-width:560px}
  }
  
  /* ============ SERVICES ============ */
  /* [FIX #3] Service cards remain as anchors with image content for now (your HTML
     uses PNGs). CSS below adds: real hover lift, accessible focus ring, equal-height
     alignment, and a subtle inner border. When you rebuild the HTML to use
     icon+text+price (recommended), this CSS will still apply gracefully. */
  .svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:stretch}
  .svc{
    position:relative;line-height:0;
    transition:transform .5s cubic-bezier(.2,.7,.2,1);
    display:block;
  }
  .svc:hover{transform:translateY(-8px)}
  .svc:focus-visible{outline:3px solid var(--teal);outline-offset:3px}
  .svc img{width:100%;height:auto;display:block;aspect-ratio:5/4;object-fit:contain}
  @media(max-width:980px){.svc-grid{grid-template-columns:repeat(2,1fr)}}
  @media(max-width:600px){.svc-grid{grid-template-columns:1fr;gap:18px}}
  
  /* ============ ABOUT / FOUNDER ============ */
  /* [FIX #6] Was align-items:center but text column ended way before image column.
     Solution: rebalance — give text a touch more room, lift image-sub closer to
     the image, and add a quote-style border-left accent to the signature so the
     text column has more visual weight. */
  .about-grid{
    display:grid;
    grid-template-columns:1.05fr 1fr;
    gap:72px;
    align-items:center;
  }
  .about-media{position:relative;padding:0 16px 36px 0}
  .about-img-main{
    width:100%;border-radius:22px;display:block;
    aspect-ratio:4/3;object-fit:cover;
    box-shadow:0 24px 60px rgba(26,26,26,.16);
  }
  /* Portrait variant for founder photo — taller frame, top-weighted crop */
  .about-img-main.about-img-portrait{
    aspect-ratio:3/4;object-position:center top;
  }
  .about-img-sub{
    position:absolute;
    right:-12px;bottom:-12px;
    width:46%;border-radius:16px;
    aspect-ratio:4/3;object-fit:cover;
    border:5px solid var(--bg);
    box-shadow:0 18px 40px rgba(26,26,26,.18);
  }
  .section.alt .about-img-sub{border-color:var(--bg-2)}
  .about-copy .eyebrow{margin-bottom:18px}
  .about-copy .sec-title{margin-bottom:28px}
  .about-copy p{
    font-size:16.5px;color:var(--ink-soft);
    line-height:1.72;margin-bottom:20px;max-width:540px;
  }
  .about-sign{
    font-family:var(--head);font-style:italic;font-size:22px;color:var(--ink);
    margin-top:18px;padding-left:18px;
    border-left:2px solid var(--teal);
    -webkit-text-fill-color:initial;
  }
  @media(max-width:860px){
    .about-grid{grid-template-columns:1fr;gap:60px}
    .about-media{padding:0 12px 28px 0}
    .about-img-sub{width:40%}
  }
  
  /* ============ WHY CHOOSE US ============ */
  .why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:32px}
  .why{padding:4px 0}
  .why-ic{
    width:52px;height:52px;border-radius:14px;
    border:1px solid var(--line);
    display:flex;align-items:center;justify-content:center;
    color:var(--teal-deep);margin-bottom:22px;background:var(--tint);
  }
  .why h4{font-size:21px;font-weight:600;letter-spacing:-0.01em;margin-bottom:10px}
  .why p{font-size:15px;color:var(--ink-soft);line-height:1.62}
  @media(max-width:820px){
    .why-grid{grid-template-columns:repeat(2,1fr);gap:48px 28px}
    /* center value cards on tablet/mobile */
    .why{display:flex;flex-direction:column;align-items:center;text-align:center}
    .why-ic{margin-left:auto;margin-right:auto}
  }
  @media(max-width:480px){.why-grid{grid-template-columns:1fr;gap:40px}}
  
  /* ============ PROCESS ============ */
  .proc-list{border-top:1px solid var(--line)}
  .proc-row{
    display:grid;grid-template-columns:96px 1fr 1.3fr;gap:32px;align-items:start;
    padding:38px 8px;border-bottom:1px solid var(--line);position:relative;
    transition:background .4s,padding-left .4s;
  }
  .proc-row:hover{background:rgba(255,255,255,.55);padding-left:20px}
  .proc-num{font-family:var(--head);font-style:italic;font-size:36px;color:var(--ink-faint);transition:color .3s}
  .proc-row:hover .proc-num{
    background:var(--grad);-webkit-background-clip:text;background-clip:text;
    -webkit-text-fill-color:transparent;color:transparent;
  }
  .proc-name{font-size:clamp(22px,2.4vw,32px);font-weight:500;letter-spacing:-0.012em;line-height:1.2}
  .proc-desc{font-size:15.5px;color:var(--ink-soft);line-height:1.65;padding-top:6px}
  @media(max-width:760px){
    .proc-row{grid-template-columns:1fr;gap:10px;padding:28px 8px}
    .proc-row:hover{padding-left:8px}
    .proc-num{font-size:24px}
  }
  
  /* ============ TESTIMONIALS ============ */
  .testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
  .tcard{
    background:rgba(255,255,255,.75);border:1px solid var(--line);
    border-radius:24px;padding:34px;
    display:flex;flex-direction:column;
    transition:transform .4s,box-shadow .4s;
  }
  .tcard:hover{transform:translateY(-4px);box-shadow:0 24px 50px rgba(26,26,26,.1)}
  .tquote{
    font-family:var(--head);font-size:21px;font-style:italic;
    line-height:1.42;letter-spacing:-0.005em;margin-bottom:26px;flex:1;
  }
  .tquote::before{content:"\201C";font-size:42px;line-height:0;vertical-align:-0.3em;margin-right:4px;color:var(--teal);opacity:.6}
  .tauthor{display:flex;align-items:center;gap:13px;padding-top:22px;border-top:1px solid var(--line)}
  .tav{
    width:44px;height:44px;border-radius:50%;
    display:flex;align-items:center;justify-content:center;
    font-size:13.5px;font-weight:600;color:#fff;flex-shrink:0;
  }
  .tname{font-size:15px;font-weight:600}
  .trole{font-size:13px;color:var(--ink-soft);margin-top:2px}
  @media(max-width:860px){.testi-grid{grid-template-columns:1fr;gap:18px}}
  
  /* ============ CTA / AUDIT FORM ============ */
  .cta{
    position:relative;text-align:center;padding:140px 40px;overflow:hidden;
    background:var(--ink);color:#fff;
  }
  #cta-canvas{position:absolute;inset:0;width:100%;height:100%;z-index:0;opacity:.92}
  .cta-inner{position:relative;z-index:2;max-width:1100px;margin:0 auto}
  .cta .eyebrow{color:rgba(255,255,255,.7)}
  .cta h2{
    font-family:var(--head);font-weight:300;
    font-size:clamp(40px,5vw,72px);line-height:1.14;letter-spacing:-0.022em;
    margin-bottom:20px;
  }
  .cta h2 em{font-style:italic}
  .cta p{font-size:18px;color:rgba(255,255,255,.74);line-height:1.6;margin:0 0 0;max-width:480px}
  
  .btn-light{
    display:inline-flex;align-items:center;gap:10px;background:#fff;color:var(--ink);
    font-size:16px;font-weight:500;padding:17px 38px;border-radius:100px;
    transition:transform .3s,box-shadow .3s;
    border:none;cursor:pointer;font-family:var(--body);
  }
  .btn-light:hover{transform:translateY(-3px);box-shadow:0 18px 40px rgba(0,0,0,.4)}
  
  .audit-grid{
    display:grid;grid-template-columns:1fr 1fr;gap:64px;
    text-align:left;align-items:start;
  }
  .cta .audit-left h2{font-size:clamp(36px,4.4vw,60px);margin-bottom:20px}
  .cta .audit-left p{margin:0;max-width:420px}
  .audit-contact{list-style:none;margin-top:38px;display:flex;flex-direction:column;gap:18px}
  .audit-contact li{display:flex;flex-direction:column;gap:3px}
  .audit-contact .lab{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.5);font-weight:500}
  .audit-contact .val{font-size:18px;color:#fff;font-weight:400}
  .audit-contact .val a:hover{color:var(--teal-light)}
  
  .audit-form{
    background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.16);
    border-radius:24px;padding:32px;
    backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
    display:flex;flex-direction:column;gap:15px;
  }
  .field-row{display:grid;grid-template-columns:1fr 1fr;gap:13px}
  @media(max-width:520px){.field-row{grid-template-columns:1fr}}
  .field{display:flex;flex-direction:column;gap:7px}
  .field label{font-size:11.5px;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.65);font-weight:500}
  .field label .req{color:var(--teal-light)}
  .field input,.field textarea{
    background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.2);
    border-radius:12px;padding:13px 15px;color:#fff;
    font-family:var(--body);font-size:15px;
    transition:border-color .25s,background .25s;width:100%;
  }
  .field input::placeholder,.field textarea::placeholder{color:rgba(255,255,255,.36)}
  .field input:focus,.field textarea:focus{outline:none;border-color:var(--teal-light);background:rgba(255,255,255,.13)}
  .field input.err,.field textarea.err{border-color:#ff9a8b}
  .field textarea{resize:vertical;min-height:88px;font-family:var(--body)}
  .form-submit{margin-top:8px;justify-content:center;border:none;cursor:pointer;width:100%}
  .form-note{font-size:12.5px;color:rgba(255,255,255,.5);text-align:center;margin:0}
  .audit-success{display:none;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:46px 24px;min-height:340px}
  .audit-success.show{display:flex}
  .audit-success .check{width:60px;height:60px;border-radius:50%;background:var(--grad);display:flex;align-items:center;justify-content:center;margin-bottom:22px}
  .audit-success h3{font-family:var(--head);font-weight:400;font-size:34px;color:#fff;margin-bottom:12px}
  .audit-success p{color:rgba(255,255,255,.7);max-width:300px;margin:0}
  @media(max-width:860px){
    .audit-grid{grid-template-columns:1fr;gap:40px}
    .cta{padding:100px 24px}
  }
  
  /* ============ FOOTER ============ */
  .footer{background:var(--bg-2);color:var(--ink-soft);padding:72px 0 40px;border-top:1px solid var(--line)}
  .footer-top{
    display:flex;justify-content:space-between;align-items:flex-start;
    gap:48px;flex-wrap:wrap;padding-bottom:48px;
    border-bottom:1px solid var(--line);
  }
  .footer-brand{
    font-family:var(--head);font-size:30px;color:var(--ink);
    font-weight:400;max-width:340px;line-height:1.2;
  }
  .footer-cols{display:flex;gap:64px;flex-wrap:wrap}
  .fcol h5{font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:16px;font-weight:500}
  .fcol a{display:block;font-size:15px;color:var(--ink-soft);margin-bottom:11px;transition:color .25s}
  .fcol a:hover{color:var(--teal-deep)}
  .footer-bottom{
    display:flex;justify-content:space-between;align-items:center;
    padding-top:32px;flex-wrap:wrap;gap:14px;font-size:13.5px;
  }
  
  /* ============ MOBILE NAV ============ */
  .nav-burger{
    display:none;flex-direction:column;justify-content:center;align-items:center;
    width:44px;height:44px;cursor:pointer;background:none;border:none;padding:0;gap:6px;
    position:relative;z-index:70; /* stay above the mobile menu overlay */
  }
  .nav-burger span{
    display:block;width:22px;height:1.5px;background:var(--ink);
    transition:transform .3s ease,opacity .2s ease;transform-origin:center;
  }
  /* Burger animates into an X while the menu is open */
  .nav-burger.is-open span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
  .nav-burger.is-open span:nth-child(2){opacity:0}
  .nav-burger.is-open span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}
  @media(max-width:880px){
    .nav-burger{display:flex}
    .nav-cta{display:none}
  }
  .nav-mobile{
    position:fixed;inset:0;z-index:55;background:var(--bg);
    height:100vh;height:100dvh;
    display:flex;flex-direction:column;align-items:center;justify-content:center;
    gap:8px;padding:80px 24px;opacity:0;pointer-events:none;transition:opacity .3s ease;
  }
  .nav-mobile.open{opacity:1;pointer-events:all}
  .nav-mobile-links{display:flex;flex-direction:column;align-items:center;gap:6px}
  .nav-mobile-links a{
    font-family:var(--head);font-size:clamp(36px,8vw,56px);font-weight:300;
    color:var(--ink);letter-spacing:-0.01em;padding:8px 24px;transition:color .25s;
  }
  .nav-mobile-links a:hover{color:var(--teal-deep)}
  .nav-mobile-cta{margin-top:28px}
  /* The animated burger now also closes the menu, so this separate
     close button is hidden to avoid two overlapping controls. */
  .nav-mobile-close{display:none}
  
  /* ============ PAGE HERO (inner pages) ============ */
  .page-hero{
    position:relative;padding:180px 40px 100px;
    background:
      radial-gradient(ellipse 80% 60% at 60% 40%, rgba(99,171,171,.22) 0%, transparent 70%),
      var(--bg);
    overflow:hidden;
  }
  .page-hero-inner{position:relative;z-index:2;max-width:900px}
  .page-hero .eyebrow{margin-bottom:22px}
  .page-hero h1{
    font-family:var(--head);font-weight:300;
    font-size:clamp(52px,7vw,104px);line-height:0.98;letter-spacing:-0.022em;margin-bottom:30px;
  }
  .page-hero h1 em{font-style:italic}
  .page-hero .hero-sub{
    font-size:clamp(17px,1.5vw,21px);color:var(--ink-soft);
    line-height:1.62;max-width:560px;margin:0;
  }
  
  /* ============ BREADCRUMB ============ */
  .breadcrumb{
    display:flex;align-items:center;gap:8px;
    font-size:13px;color:var(--ink-faint);margin-bottom:36px;
  }
  .breadcrumb a{color:var(--ink-soft);transition:color .2s}
  .breadcrumb a:hover{color:var(--teal-deep)}
  .breadcrumb .sep{opacity:.5}
  
  /* ============ SERVICE DETAIL PAGE ============ */
  .svc-hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
  @media(max-width:860px){.svc-hero-grid{grid-template-columns:1fr;gap:48px}}
  .svc-detail-img{width:100%;display:block}
  
  .pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:56px}
  @media(max-width:860px){.pricing-grid{grid-template-columns:1fr}}
  .price-card{
    background:#fff;border:1px solid var(--line);border-radius:24px;
    padding:38px 30px;display:flex;flex-direction:column;
    transition:transform .4s cubic-bezier(.2,.7,.2,1),box-shadow .4s;
  }
  .price-card:hover{transform:translateY(-6px);box-shadow:0 28px 60px rgba(26,26,26,.12)}
  .price-card.featured{background:var(--ink);color:#fff;border-color:var(--ink)}
  .price-card.featured .price-sub,.price-card.featured .price-desc{color:rgba(255,255,255,.65)}
  .price-badge{display:inline-block;font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:5px 14px;border-radius:100px;background:var(--tint);color:var(--teal-deep);margin-bottom:22px;align-self:flex-start}
  .price-card.featured .price-badge{background:rgba(255,255,255,.14);color:rgba(255,255,255,.85)}
  .price-name{font-size:22px;font-weight:600;letter-spacing:-0.01em;margin-bottom:10px}
  .price-amount{font-family:var(--head);font-size:clamp(38px,4.5vw,58px);font-weight:300;letter-spacing:-0.02em;line-height:1;margin:8px 0 4px}
  .price-sub{font-size:13px;color:var(--ink-soft);margin-bottom:24px}
  .price-desc{font-size:15px;color:var(--ink-soft);line-height:1.62;margin-bottom:28px;flex:1}
  .price-features{list-style:none;display:flex;flex-direction:column;gap:11px;margin-bottom:32px}
  .price-features li{display:flex;align-items:flex-start;gap:9px;font-size:14.5px}
  .price-features li::before{content:"\2713";color:var(--teal);font-weight:700;flex-shrink:0;margin-top:1px}
  .price-card.featured .price-features li::before{color:var(--teal-light)}
  .price-cta{margin-top:auto;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 24px;border-radius:100px;font-size:15px;font-weight:500;transition:transform .3s,box-shadow .3s,background .3s;text-align:center}
  .price-cta-light{background:var(--teal-deep);color:#fff}
  .price-cta-light:hover{background:var(--teal);transform:translateY(-2px);box-shadow:0 12px 28px rgba(53,112,112,.32)}
  .price-cta-dark{background:#fff;color:var(--ink)}
  .price-cta-dark:hover{transform:translateY(-2px);box-shadow:0 12px 28px rgba(0,0,0,.3)}
  
  /* ============ BLOG ============ */
  .blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
  @media(max-width:940px){.blog-grid{grid-template-columns:repeat(2,1fr)}}
  @media(max-width:600px){.blog-grid{grid-template-columns:1fr}}
  .blog-card{
    background:#fff;border:1px solid var(--line);border-radius:20px;overflow:hidden;
    display:flex;flex-direction:column;
    transition:transform .4s cubic-bezier(.2,.7,.2,1),box-shadow .4s;
  }
  .blog-card:hover{transform:translateY(-6px);box-shadow:0 28px 60px rgba(26,26,26,.12)}
  .blog-card-img{width:100%;aspect-ratio:16/10;object-fit:cover;display:block}
  .blog-card-body{padding:26px 26px 30px;flex:1;display:flex;flex-direction:column}
  .blog-tag{font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--teal-deep);margin-bottom:12px}
  .blog-card-title{font-family:var(--head);font-size:clamp(20px,2vw,26px);font-weight:400;line-height:1.22;letter-spacing:-0.01em;margin-bottom:12px}
  .blog-card-excerpt{font-size:14.5px;color:var(--ink-soft);line-height:1.6;flex:1}
  .blog-card-meta{display:flex;align-items:center;justify-content:space-between;margin-top:20px;padding-top:18px;border-top:1px solid var(--line);font-size:13px;color:var(--ink-faint)}
  .blog-card-read{color:var(--teal-deep);font-weight:500;font-size:13.5px;display:inline-flex;align-items:center;gap:5px;transition:gap .2s}
  .blog-card:hover .blog-card-read{gap:9px}

  /* ---- Featured post ---- */
  .featured-post{
    display:grid;grid-template-columns:1fr 1fr;gap:0;align-items:stretch;
    background:var(--bg-2);border:1px solid var(--line);border-radius:28px;overflow:hidden;
    color:inherit;transition:transform .4s cubic-bezier(.2,.7,.2,1),box-shadow .4s;
  }
  .featured-post:hover{transform:translateY(-4px);box-shadow:0 32px 64px rgba(26,26,26,.12)}
  .featured-post-media{
    min-height:340px;display:flex;align-items:center;justify-content:center;
  }
  .featured-post-media span{font-size:72px}
  .featured-post-body{padding:48px 44px;display:flex;flex-direction:column;justify-content:center}
  .featured-post-title{
    font-family:var(--head);font-size:clamp(26px,3.2vw,42px);font-weight:400;
    line-height:1.15;letter-spacing:-0.01em;margin:8px 0 16px;
  }
  .featured-post-excerpt{font-size:16px;color:var(--ink-soft);line-height:1.65;margin-bottom:28px}
  .featured-post-meta{
    display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;
    font-size:13px;color:var(--ink-faint);
  }
  .featured-post-btn{font-size:14px;padding:12px 22px;flex-shrink:0}
  @media(max-width:760px){
    .featured-post{grid-template-columns:1fr}
    .featured-post-media{min-height:200px}
    .featured-post-media span{font-size:56px}
    .featured-post-body{padding:32px 26px 34px}
  }

  /* ---- Industries grid (about) ---- */
  .industries-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
  .industry-card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:26px 24px;text-align:center}
  .industry-emoji{font-size:28px;margin-bottom:12px}
  .industry-name{font-weight:600;font-size:15px}
  .industry-desc{font-size:13px;color:var(--ink-soft);margin-top:6px}
  @media(max-width:860px){.industries-grid{grid-template-columns:repeat(3,1fr)}}
  @media(max-width:600px){.industries-grid{grid-template-columns:repeat(2,1fr);gap:14px}}
  @media(max-width:380px){.industries-grid{grid-template-columns:1fr}}

  /* ============ SHOP ============ */
  .shop-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
  @media(max-width:940px){.shop-grid{grid-template-columns:repeat(2,1fr)}}
  @media(max-width:580px){.shop-grid{grid-template-columns:1fr}}
  .shop-card{
    background:#fff;border:1px solid var(--line);border-radius:20px;overflow:hidden;
    display:flex;flex-direction:column;
    transition:transform .4s cubic-bezier(.2,.7,.2,1),box-shadow .4s;
  }
  .shop-card:hover{transform:translateY(-6px);box-shadow:0 24px 56px rgba(26,26,26,.12)}
  .shop-card-img-wrap{position:relative;background:var(--bg-2);aspect-ratio:1}
  .shop-card-img{width:100%;height:100%;object-fit:cover;display:block}
  .shop-badge{position:absolute;top:14px;left:14px;font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;background:var(--teal-deep);color:#fff;padding:4px 12px;border-radius:100px}
  .shop-card-body{padding:22px 22px 24px;flex:1;display:flex;flex-direction:column}
  .shop-card-title{font-size:17px;font-weight:600;letter-spacing:-0.01em;margin-bottom:6px}
  .shop-card-desc{font-size:14px;color:var(--ink-soft);line-height:1.5;flex:1;margin-bottom:18px}
  .shop-card-footer{display:flex;align-items:center;justify-content:space-between;gap:12px}
  .shop-price{font-family:var(--head);font-size:26px;font-weight:400;letter-spacing:-0.01em}
  .shop-btn{display:inline-flex;align-items:center;gap:7px;background:var(--ink);color:#fff;font-size:13.5px;font-weight:500;padding:10px 20px;border-radius:100px;transition:background .25s,transform .25s}
  .shop-btn:hover{background:var(--teal-deep);transform:translateY(-2px)}
  .shop-empty{text-align:center;padding:80px 40px;color:var(--ink-soft)}
  .shop-empty h3{font-family:var(--head);font-size:36px;font-weight:300;margin-bottom:14px}
  
  /* ============ CONTACT PAGE ============ */
  .contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
  @media(max-width:860px){.contact-grid{grid-template-columns:1fr;gap:48px}}
  .contact-info{display:flex;flex-direction:column;gap:40px}
  .contact-item h4{font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint);font-weight:500;margin-bottom:8px}
  .contact-item p,.contact-item a{font-family:var(--head);font-size:clamp(22px,2.6vw,32px);font-weight:400;color:var(--ink);line-height:1.2}
  .contact-item a:hover{color:var(--teal-deep)}
  .contact-form-wrap{background:var(--bg-2);border:1px solid var(--line);border-radius:28px;padding:44px}
  @media(max-width:600px){.contact-form-wrap{padding:28px 22px}}
  .contact-form{display:flex;flex-direction:column;gap:18px}
  .contact-field{display:flex;flex-direction:column;gap:7px}
  .contact-field label{font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);font-weight:500}
  .contact-field label .req{color:var(--teal-deep)}
  .contact-field input,.contact-field textarea,.contact-field select{
    background:#fff;border:1px solid var(--line);border-radius:12px;
    padding:13px 16px;color:var(--ink);font-family:var(--body);font-size:15.5px;
    transition:border-color .25s,box-shadow .25s;width:100%;
  }
  .contact-field input:focus,.contact-field textarea:focus,.contact-field select:focus{
    outline:none;border-color:var(--teal-deep);box-shadow:0 0 0 3px rgba(53,112,112,.12);
  }
  .contact-field input.err,.contact-field textarea.err{border-color:#e05252}
  .contact-field textarea{resize:vertical;min-height:120px}
  .contact-field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none'%3E%3Cpath d='M6 9l6 6 6-6' stroke='%236B6B6B' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center}
  .contact-submit{display:inline-flex;align-items:center;justify-content:center;gap:10px;background:var(--teal-deep);color:#fff;font-size:15.5px;font-weight:500;padding:16px 32px;border-radius:100px;border:none;cursor:pointer;transition:background .3s,transform .3s,box-shadow .3s;width:100%;font-family:var(--body)}
  .contact-submit:hover{background:var(--teal);transform:translateY(-2px);box-shadow:0 14px 30px rgba(53,112,112,.3)}
  .contact-success{display:none;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:60px 24px}
  .contact-success.show{display:flex}
  .contact-success .check{width:64px;height:64px;border-radius:50%;background:var(--grad);display:flex;align-items:center;justify-content:center;margin-bottom:22px}
  .contact-success h3{font-family:var(--head);font-size:36px;font-weight:400;margin-bottom:12px}
  .contact-success p{color:var(--ink-soft);max-width:320px}
  .map-wrap{border-radius:20px;overflow:hidden;border:1px solid var(--line);margin-top:0}
  .map-wrap iframe{display:block;width:100%;height:340px;border:0}
  
  /* No CSS-based pre-hide: GSAP sets opacity/transform via .set() before
     animating. This avoids blank-page flash when fonts or scripts are slow. */
  @media (prefers-reduced-motion: reduce){
    .marquee-track,.scroll-hint .bar{animation:none !important}
  }
  .hero-inner,.scroll-hint{min-height:0}
  #gradient-canvas,#cta-canvas{display:block}
  
  /* ============ ACCESSIBILITY ============ */
  :focus-visible{outline:3px solid var(--teal);outline-offset:3px;border-radius:4px}
  .sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

  /* ============ LOADING SCREEN (video) ============ */
  /* Fallback color matched to the video's own background so the area the
     video doesn't cover blends seamlessly with the clip. */
  .loader{
    position:fixed;inset:0;z-index:9999;
    display:flex;align-items:center;justify-content:center;
    background:#498986;
    overflow:hidden;
    transition:opacity .6s ease,visibility .6s ease;
  }
  .loader.done{opacity:0;visibility:hidden;pointer-events:none}
  .loader-video{
    position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
    /* Mobile & tablet: fit to WIDTH (full-width, keep aspect ratio, never crop).
       The teal .loader bg fills the leftover space top/bottom. */
    width:100%;height:auto;
    max-width:100%;
    object-fit:contain;
    background:transparent;
    pointer-events:none;         /* no interaction / no control bar */
  }
  /* Desktop: fit to HEIGHT (full-height, keep aspect ratio). Leftover space
     is on the left/right, filled by the teal .loader bg. */
  @media(min-width:1025px){
    .loader-video{
      width:auto;height:100%;
      max-width:none;max-height:100%;
    }
  }
  /* Hide native video controls everywhere (incl. WebKit fullscreen button) */
  .loader-video::-webkit-media-controls,
  .loader-video::-webkit-media-controls-enclosure,
  .loader-video::-webkit-media-controls-panel,
  .loader-video::-webkit-media-controls-start-playback-button{
    display:none !important;-webkit-appearance:none;
  }
  /* Logo + bar loader (used on all pages except the home video loader) */
  .loader-inner{display:flex;flex-direction:column;align-items:center;gap:30px}
  .loader:not(.loader-video-mode){background:
      radial-gradient(ellipse 70% 55% at 50% 40%, rgba(99,171,171,0.28) 0%, rgba(99,171,171,0) 70%),
      var(--bg);}
  .loader-logo{
    width:min(260px,62vw);height:auto;display:block;
    animation:loaderPulse 1.8s ease-in-out infinite;
  }
  .loader-bar{
    width:160px;height:3px;border-radius:100px;
    background:rgba(26,26,26,.10);overflow:hidden;
  }
  .loader-bar span{
    display:block;height:100%;width:40%;border-radius:100px;
    background:var(--grad);
    animation:loaderSlide 1.2s ease-in-out infinite;
  }
  @keyframes loaderPulse{
    0%,100%{opacity:.78;transform:scale(.985)}
    50%{opacity:1;transform:scale(1)}
  }
  @keyframes loaderSlide{
    0%{transform:translateX(-120%)}
    100%{transform:translateX(320%)}
  }
  @media (prefers-reduced-motion: reduce){
    .loader-logo,.loader-bar span{animation:none}
  }

  /* ============ FOUNDER CARD (Our Story) ============ */
  .founder-card{
    display:flex;align-items:center;gap:18px;
    margin-top:30px;padding:20px 22px;
    background:var(--bg-2);border:1px solid var(--line);border-radius:18px;
    max-width:540px;
  }
  .section.alt .founder-card{background:var(--bg)}
  .founder-av{
    flex-shrink:0;width:54px;height:54px;border-radius:50%;
    display:flex;align-items:center;justify-content:center;
    background:var(--grad);color:#fff;
    font-family:var(--body);font-weight:600;font-size:18px;letter-spacing:.02em;
  }
  .founder-name{font-family:var(--head);font-size:21px;font-weight:600;letter-spacing:-0.01em;line-height:1.1}
  .founder-role{font-size:12.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--teal-deep);font-weight:500;margin:3px 0 7px}
  .founder-bio{font-size:14px;color:var(--ink-soft);line-height:1.55}

  /* ============ SOCIAL BUTTONS ============ */
  .socials{display:flex;gap:12px;margin-top:26px}
  .social-btn{
    width:44px;height:44px;border-radius:50%;
    display:inline-flex;align-items:center;justify-content:center;
    color:var(--ink);background:rgba(255,255,255,.7);
    border:1px solid var(--line);
    transition:transform .3s,background .3s,color .3s,box-shadow .3s,border-color .3s;
  }
  .social-btn:hover{
    transform:translateY(-3px);
    background:var(--teal-deep);color:#fff;border-color:var(--teal-deep);
    box-shadow:0 12px 26px rgba(53,112,112,.32);
  }

  /* footer social row (on dark footer) */
  .footer-socials{display:flex;gap:12px;margin-top:18px}
  .footer-socials a{
    width:38px;height:38px;border-radius:50%;
    display:inline-flex;align-items:center;justify-content:center;
    color:var(--ink);background:rgba(255,255,255,.7);
    border:1px solid var(--line);
    transition:transform .3s,background .3s,color .3s,border-color .3s;
  }
  .footer-socials a:hover{transform:translateY(-3px);background:var(--teal-deep);color:#fff;border-color:var(--teal-deep)}

  /* ============ BLOG ARTICLE (sub-page) ============ */
  .article-hero{
    position:relative;padding:150px 0 50px;
    background:
      radial-gradient(ellipse 60% 50% at 50% 30%, rgba(99,171,171,0.20) 0%, rgba(99,171,171,0) 70%),
      var(--bg);
  }
  .article-hero .wrap{max-width:820px}
  .article-hero .blog-tag{font-size:12px;margin-bottom:18px;display:inline-block}
  .article-title{
    font-family:var(--head);font-weight:300;
    font-size:clamp(34px,5vw,60px);line-height:1.08;letter-spacing:-0.02em;margin-bottom:22px;
  }
  .article-title em{font-style:italic;font-weight:400}
  .article-meta{
    display:flex;align-items:center;gap:18px;flex-wrap:wrap;
    font-size:14px;color:var(--ink-faint);
    padding-bottom:6px;
  }
  .article-meta .author{display:flex;align-items:center;gap:10px;color:var(--ink-soft);font-weight:500}
  .article-meta .author .av{
    width:34px;height:34px;border-radius:50%;background:var(--grad);color:#fff;
    display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;
  }
  .article-cover{
    width:100%;aspect-ratio:16/8;border-radius:24px;overflow:hidden;margin:8px 0 0;
    display:flex;align-items:center;justify-content:center;
  }
  .article-cover span{font-size:clamp(60px,10vw,110px)}
  .article-body{max-width:760px;margin:0 auto;padding:56px 0 20px}
  .article-body > *{max-width:680px}
  .article-body p{font-size:17px;color:var(--charcoal);line-height:1.75;margin-bottom:24px}
  .article-body h2{
    font-family:var(--head);font-weight:400;font-size:clamp(26px,3vw,36px);
    letter-spacing:-0.01em;line-height:1.2;margin:46px 0 18px;
  }
  .article-body h3{font-size:20px;font-weight:600;margin:34px 0 12px;letter-spacing:-0.01em}
  .article-body ul{list-style:none;margin:0 0 26px;display:flex;flex-direction:column;gap:12px}
  .article-body ul li{
    position:relative;padding-left:28px;font-size:16.5px;color:var(--charcoal);line-height:1.6;
  }
  .article-body ul li::before{
    content:"";position:absolute;left:0;top:8px;width:14px;height:14px;
    background:url('../spark-logo/SPARK MULTIMEDIA ICON ONLY.png') center/contain no-repeat;
  }
  .article-body blockquote{
    margin:34px 0;padding:6px 0 6px 26px;border-left:3px solid var(--teal);
    font-family:var(--head);font-style:italic;font-size:24px;line-height:1.4;color:var(--ink);
  }
  .article-cta{
    margin:50px auto 0;max-width:680px;background:var(--ink);border-radius:24px;
    padding:44px 40px;color:#fff;text-align:center;
  }
  .article-cta h3{font-family:var(--head);font-weight:300;font-size:clamp(24px,3vw,34px);margin-bottom:12px;letter-spacing:-0.01em}
  .article-cta p{color:rgba(255,255,255,.7);font-size:15.5px;margin-bottom:24px}

  /* ============ RECOMMENDED SECTION ============ */
  .recommended{background:var(--bg-2)}
  .rec-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
  @media(max-width:940px){.rec-grid{grid-template-columns:repeat(2,1fr)}}
  @media(max-width:600px){.rec-grid{grid-template-columns:1fr}}

  /* =============================================================
     END OF FILE — Summary of fixes applied:
     #1  FOIT       → also fix HTML: &display=block → &display=swap
     #2  Stats grid → 3 cols + spotlight row for 4th stat
     #3  Services   → CSS handles current PNG approach; ready for rebuild
     #4  Hero weak  → added radial-gradient brand-tinted background
     #5  Sec-head   → 2-col grid layout (title + sub side by side)
     #6  About      → rebalanced with quote-style sign + tighter image sub
     #7  Marquee    → Outfit uppercase replaces Cormorant italic
     #8  Counter    → JS fix needed in js/script.js (lower duration)
     #9  Scroll hint→ smaller, more bottom space, hidden on mobile
     #10 Defying    → letter-spacing + padding-right on .grad-text
     ============================================================= */