/* ================================================================
   ROCKETTECH — BRAND REDESIGN v4 (Teal Identity)
   Google Fonts loaded via <link> in HTML head
   ================================================================ */

:root {
  --teal:      #1A8DA6;
  --teal-dk:   #146E83;
  --teal-lt:   #22B0CE;
  --teal-glow: rgba(26,141,166,.35);
  --gold:      #FFB300;
  --space:     #080E10;
  --night:     #0C1519;
  --mid:       #122028;
  --off:       #F2F7F9;
  --white:     #FFFFFF;
  --t1:        #0A1419;
  --t2:        #4A6170;
  --t3:        #8BA4AE;
  --bdr:       rgba(26,141,166,.15);
  --bdl:       rgba(255,255,255,.1);
  --FD:        'Outfit', sans-serif;
  --FB:        'DM Sans', sans-serif;
  --ease:      cubic-bezier(.4,0,.2,1);
  --tr:        all .3s var(--ease);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--FB);color:var(--t1);background:#fff;line-height:1.7;overflow-x:hidden}
a{text-decoration:none;color:inherit}
ul{list-style:none}
img{max-width:100%;display:block}
button{cursor:pointer;font-family:var(--FB);border:none;background:none}
em{font-style:normal;color:var(--teal)}
h1,h2,h3,h4,h5{font-family:var(--FD);line-height:1.15}

/* Layout */
.wrap{max-width:1200px;margin:0 auto;padding:0 2rem}
.sec{padding:96px 0}
.sec--dk{background:var(--space);color:#fff}
.sec--off{background:var(--off)}
.sec--mid{background:var(--night)}

/* Section headers */
.stag{display:inline-block;font-size:11px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--teal);background:rgba(26,141,166,.08);border:.5px solid rgba(26,141,166,.3);padding:5px 14px;border-radius:20px;margin-bottom:1.25rem}
.stag--lt{color:#5DD0E8;background:rgba(26,141,166,.14);border-color:rgba(26,141,166,.35)}
.sh{text-align:center;margin-bottom:60px}
.sh--lt .htitle{color:#fff}
.sh--lt .hsub{color:rgba(255,255,255,.45)}
.htitle{font-size:clamp(26px,4vw,42px);font-weight:800;margin-bottom:1rem}
.hsub{font-size:17px;color:var(--t2);max-width:560px;margin:0 auto;line-height:1.8}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 26px;border-radius:8px;font-family:var(--FB);font-size:15px;font-weight:500;transition:var(--tr);white-space:nowrap;border:1.5px solid transparent;cursor:pointer}
.btn--teal{background:var(--teal);color:#fff;border-color:var(--teal)}
.btn--teal:hover{background:var(--teal-dk);border-color:var(--teal-dk);transform:translateY(-2px);box-shadow:0 8px 28px var(--teal-glow)}
.btn--red{background:var(--teal);color:#fff;border-color:var(--teal)}
.btn--red:hover{background:var(--teal-dk);border-color:var(--teal-dk);transform:translateY(-2px);box-shadow:0 8px 28px var(--teal-glow)}
.btn--ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.3)}
.btn--ghost:hover{border-color:rgba(255,255,255,.7);background:rgba(255,255,255,.07)}
.btn--out{background:transparent;color:var(--t1);border-color:rgba(26,141,166,.25)}
.btn--out:hover{border-color:var(--teal);color:var(--teal)}
.btn--lg{padding:14px 34px;font-size:16px}

/* Reveal */
.rv{opacity:0;transform:translateY(26px);transition:opacity .65s var(--ease),transform .65s var(--ease)}
.rv.on{opacity:1;transform:none}
.rv.d1{transition-delay:.1s}.rv.d2{transition-delay:.2s}.rv.d3{transition-delay:.3s}.rv.d4{transition-delay:.4s}

/* ============================================================
   NAVIGATION
   ============================================================ */
.nav{position:fixed;top:0;left:0;right:0;z-index:900;transition:var(--tr)}
.nav.scrolled{background:rgba(8,14,16,.96);backdrop-filter:blur(16px);border-bottom:.5px solid rgba(26,141,166,.15)}
.nav-in{display:flex;align-items:center;height:70px;gap:1.5rem}
.logo{display:flex;align-items:center;gap:10px;flex-shrink:0;text-decoration:none}
.logo-img{width:40px;height:40px;border-radius:50%;object-fit:cover;flex-shrink:0}
.logo-txt{font-family:var(--FD);font-size:20px;font-weight:800;color:#fff;line-height:1}
.logo-txt span{color:var(--teal-lt)}
.nav-ul{display:flex;align-items:center;gap:.15rem;margin-left:auto}
.nav-a{display:flex;align-items:center;gap:4px;padding:8px 12px;font-size:14px;color:rgba(255,255,255,.7);border-radius:8px;transition:var(--tr)}
.nav-a:hover,.nav-a.act{color:#fff;background:rgba(26,141,166,.18)}
.drop{position:relative}
.drop-menu{position:absolute;top:calc(100% + 8px);left:0;background:var(--mid);border:.5px solid rgba(26,141,166,.2);border-radius:12px;padding:8px;min-width:230px;opacity:0;visibility:hidden;transform:translateY(8px);transition:var(--tr);box-shadow:0 24px 64px rgba(0,0,0,.4)}
.drop:hover .drop-menu{opacity:1;visibility:visible;transform:translateY(0)}
.drop-menu a{display:block;padding:9px 14px;font-size:13px;color:rgba(255,255,255,.65);border-radius:8px;transition:var(--tr)}
.drop-menu a:hover{background:rgba(26,141,166,.15);color:var(--teal-lt)}
.nav-cta{margin-left:.5rem}
.burger{display:none;flex-direction:column;gap:5px;padding:8px;margin-left:auto;position:relative;z-index:10000}
.burger span{display:block;width:24px;height:1.5px;background:#fff;transition:var(--tr);border-radius:2px}

/* ============================================================
   HERO
   ============================================================ */
.hero{min-height:100vh;background:var(--space);display:flex;align-items:center;position:relative;overflow:hidden;padding-top:70px}
.hero-bg{position:absolute;inset:0;pointer-events:none}
.orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:.5}
.orb1{width:620px;height:620px;top:-120px;right:-100px;background:radial-gradient(circle,rgba(26,141,166,.48),transparent 70%)}
.orb2{width:420px;height:420px;bottom:-100px;left:-60px;background:radial-gradient(circle,rgba(34,176,206,.18),transparent 70%)}
.hero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(26,141,166,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(26,141,166,.04) 1px,transparent 1px);background-size:64px 64px;mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black,transparent)}
.hero-in{position:relative;z-index:1;padding:80px 2rem}
.hero-badge{display:inline-flex;align-items:center;gap:10px;font-size:11px;font-weight:500;letter-spacing:.09em;text-transform:uppercase;color:rgba(255,255,255,.55);border:.5px solid rgba(26,141,166,.3);background:rgba(26,141,166,.08);padding:7px 16px;border-radius:20px;margin-bottom:1.75rem}
.hero-dot{width:6px;height:6px;background:var(--teal-lt);border-radius:50%;animation:pdot 2s ease-in-out infinite}
@keyframes pdot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(1.6)}}
.hero-logo-badge{width:52px;height:52px;border-radius:50%;object-fit:cover;border:2px solid rgba(26,141,166,.4);box-shadow:0 0 24px rgba(26,141,166,.3)}
.hero-h1{font-size:clamp(40px,6.5vw,76px);font-weight:800;color:#fff;line-height:1.07;margin-bottom:1.5rem;max-width:750px}
.hero-sub{font-size:18px;color:rgba(255,255,255,.48);max-width:520px;line-height:1.8;font-weight:300;margin-bottom:2.5rem}
.hero-acts{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:3.5rem}
.stats-box{display:flex;align-items:center;flex-wrap:wrap;background:rgba(26,141,166,.06);border:.5px solid rgba(26,141,166,.2);border-radius:20px;padding:22px 28px;max-width:620px;gap:0}
.stat{flex:1;min-width:90px;text-align:center}
.stat-n{font-family:var(--FD);font-size:30px;font-weight:800;color:#fff;line-height:1}
.stat-plus{font-family:var(--FD);font-size:20px;font-weight:800;color:var(--teal-lt)}
.stat-l{font-size:10px;color:rgba(255,255,255,.35);text-transform:uppercase;letter-spacing:.09em;margin-top:4px}
.stat-div{width:.5px;height:36px;background:rgba(26,141,166,.25)}
.scroll-hint{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:7px;color:rgba(255,255,255,.28);font-size:10px;letter-spacing:.12em;text-transform:uppercase}
.scroll-line{width:.5px;height:44px;background:linear-gradient(to bottom,var(--teal),transparent);animation:sl 2s ease-in-out infinite}
@keyframes sl{0%,100%{opacity:1}50%{opacity:.3}}

/* ============================================================
   MARQUEE
   ============================================================ */
.mqbar{background:var(--night);border-top:.5px solid rgba(26,141,166,.12);border-bottom:.5px solid rgba(26,141,166,.12);overflow:hidden;padding:15px 0}
.mq-wrap{overflow:hidden}
.mq-inner{display:flex;gap:3rem;width:max-content;animation:mq 36s linear infinite}
.mq-inner span{font-size:12px;font-weight:500;color:rgba(255,255,255,.3);white-space:nowrap;padding:0 1rem;letter-spacing:.05em;position:relative}
.mq-inner span::after{content:'·';position:absolute;right:-1.5rem;color:var(--teal);opacity:.5}
@keyframes mq{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ============================================================
   SERVICE CARDS
   ============================================================ */
.svc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(265px,1fr));gap:22px}
.svc-card{display:block;background:#fff;border:.5px solid var(--bdr);border-radius:20px;padding:2rem;transition:var(--tr);position:relative;overflow:hidden}
.svc-card:hover{transform:translateY(-6px);box-shadow:0 24px 64px rgba(26,141,166,.12);border-color:rgba(26,141,166,.35)}
.svc-card:hover .svc-arr{letter-spacing:.04em}
.svc-ico{width:48px;height:48px;border-radius:8px;display:flex;align-items:center;justify-content:center;margin-bottom:1.25rem}
.svc-bar{width:30px;height:2px;border-radius:2px;margin-bottom:1rem}
.svc-card h3{font-size:20px;font-weight:700;margin-bottom:.75rem}
.svc-card p{font-size:14px;color:var(--t2);line-height:1.75;margin-bottom:1.25rem}
.svc-card ul{margin-bottom:1.5rem}
.svc-card ul li{font-size:13px;color:var(--t2);padding:3px 0 3px 14px;position:relative}
.svc-card ul li::before{content:'›';position:absolute;left:0;color:var(--teal);font-weight:700}
.svc-arr{font-size:13px;font-weight:500;color:var(--teal);transition:var(--tr)}

/* ============================================================
   WHY CARDS
   ============================================================ */
.why-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(255px,1fr));gap:20px;position:relative;z-index:1}
.why-card{background:rgba(255,255,255,.04);border:.5px solid rgba(255,255,255,.08);border-radius:20px;padding:2rem;transition:var(--tr)}
.why-card:hover{background:rgba(26,141,166,.08);border-color:rgba(26,141,166,.35);transform:translateY(-4px)}
.why-n{font-family:var(--FD);font-size:46px;font-weight:800;color:rgba(26,141,166,.2);line-height:1;margin-bottom:1rem}
.why-card h3{font-size:18px;font-weight:700;color:#fff;margin-bottom:.7rem}
.why-card p{font-size:14px;color:rgba(255,255,255,.44);line-height:1.8}

/* ============================================================
   INDUSTRY TAGS
   ============================================================ */
.ind-wrap{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;max-width:820px;margin:0 auto}
.ind-tag{font-size:14px;font-weight:500;padding:10px 20px;border-radius:30px;border:.5px solid rgba(26,141,166,.2);color:var(--t2);background:#fff;transition:var(--tr)}
.ind-tag:hover{background:var(--teal);color:#fff;border-color:var(--teal);transform:translateY(-2px)}

/* ============================================================
   CLIENT PILLS
   ============================================================ */
.cli-section{margin-bottom:2.5rem}
.cli-lbl{font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--t2);margin-bottom:1rem;font-weight:600}
.cli-wrap{display:flex;flex-wrap:wrap;gap:10px}
.cli-pill{font-size:13px;font-weight:500;padding:8px 18px;border-radius:8px;border:.5px solid var(--bdr);background:#fff;color:var(--t1);transition:var(--tr)}
.cli-pill:hover{border-color:var(--teal);color:var(--teal);transform:translateY(-2px);box-shadow:0 4px 14px rgba(26,141,166,.15)}

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.testi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:22px}
.tcard{background:rgba(255,255,255,.04);border:.5px solid rgba(255,255,255,.08);border-radius:20px;padding:2rem;transition:var(--tr)}
.tcard:hover{background:rgba(26,141,166,.07);border-color:rgba(26,141,166,.28);transform:translateY(-3px)}
.tcard-stars{color:var(--gold);font-size:14px;margin-bottom:1rem;letter-spacing:2px}
.tcard-text{font-size:15px;color:rgba(255,255,255,.65);line-height:1.8;margin-bottom:1.25rem;font-style:italic}
.tcard-author{display:flex;align-items:center;gap:12px}
.tcard-av{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--FD);font-size:14px;font-weight:700;color:#fff;background:var(--teal);flex-shrink:0}
.tcard-name{font-size:14px;font-weight:600;color:#fff}
.tcard-role{font-size:12px;color:rgba(255,255,255,.4)}

/* ============================================================
   CTA BAND
   ============================================================ */
.cta{padding:96px 0;background:var(--night);position:relative;overflow:hidden;text-align:center}
.cta-orb{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:600px;height:280px;border-radius:50%;background:radial-gradient(ellipse,rgba(26,141,166,.18),transparent 70%);filter:blur(40px);pointer-events:none}
.cta-in{position:relative;z-index:1}
.cta h2{font-size:clamp(30px,5vw,54px);font-weight:800;color:#fff;margin-bottom:1.25rem;line-height:1.2}
.cta p{font-size:17px;color:rgba(255,255,255,.48);max-width:500px;margin:0 auto 2.5rem;font-weight:300}
.cta-acts{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ============================================================
   FOOTER
   ============================================================ */
.foot{background:var(--space);border-top:.5px solid rgba(26,141,166,.12);padding-top:72px}
.foot-in{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:2.5rem;padding-bottom:56px;border-bottom:.5px solid rgba(26,141,166,.1)}
.foot-logo{display:flex;align-items:center;gap:10px;margin-bottom:1rem;text-decoration:none}
.foot-logo-img{width:38px;height:38px;border-radius:50%;object-fit:cover;border:1.5px solid rgba(26,141,166,.35)}
.foot-logo-txt{font-family:var(--FD);font-size:20px;font-weight:800;color:#fff;line-height:1}
.foot-logo-txt span{color:var(--teal-lt)}
.foot-tag{font-size:14px;color:rgba(255,255,255,.35);line-height:1.75;margin-bottom:1.25rem;max-width:260px}
.foot-tel a{font-size:16px;font-weight:500;color:rgba(255,255,255,.62);transition:var(--tr);display:block;margin-bottom:.4rem}
.foot-tel a:hover{color:var(--teal-lt)}
.foot-addr{font-size:13px;color:rgba(255,255,255,.26);line-height:1.75;margin-top:1rem}
.foot-col h5{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:rgba(255,255,255,.45);margin-bottom:1.25rem}
.foot-col ul{display:flex;flex-direction:column;gap:.5rem}
.foot-col ul a{font-size:14px;color:rgba(255,255,255,.36);transition:var(--tr)}
.foot-col ul a:hover{color:var(--teal-lt)}
.foot-btm{display:flex;justify-content:space-between;align-items:center;padding:22px 2rem;font-size:13px;color:rgba(255,255,255,.2);flex-wrap:wrap;gap:8px}

/* ============================================================
   SOCIAL LINKS (footer)
   ============================================================ */
.foot-social{display:flex;gap:10px;margin-top:1.25rem}
.foot-social a{width:36px;height:36px;border-radius:8px;background:rgba(26,141,166,.08);border:.5px solid rgba(26,141,166,.18);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.4);transition:var(--tr)}
.foot-social a:hover{background:var(--teal);border-color:var(--teal);color:#fff;transform:translateY(-2px)}

/* ============================================================
   PAGE HERO (inner pages)
   ============================================================ */
.ph{background:var(--space);padding:150px 0 90px;position:relative;overflow:hidden;text-align:center}
.ph-orb{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:600px;height:360px;border-radius:50%;background:radial-gradient(ellipse,rgba(26,141,166,.14),transparent 70%);filter:blur(60px);pointer-events:none}
.ph-in{position:relative;z-index:1}
.ph h1{font-size:clamp(34px,5.5vw,62px);font-weight:800;color:#fff;margin-bottom:1rem;line-height:1.1}
.ph p{font-size:17px;color:rgba(255,255,255,.47);max-width:560px;margin:0 auto;font-weight:300;line-height:1.8}

/* ============================================================
   SERVICE DETAIL HERO
   ============================================================ */
.sdh{background:var(--space);padding:150px 0 90px;position:relative;overflow:hidden}
.sdh-in{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center;position:relative;z-index:1}
.sdh h1{font-size:clamp(34px,5vw,58px);font-weight:800;color:#fff;line-height:1.1;margin-bottom:1rem}
.sdh>div p.lead{font-size:17px;color:rgba(255,255,255,.47);line-height:1.8;font-weight:300;margin-bottom:2rem}
.feat-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:2rem}
.feat{display:flex;align-items:center;gap:8px;font-size:14px;color:rgba(255,255,255,.65)}
.feat-ck{width:20px;height:20px;background:rgba(26,141,166,.2);color:var(--teal-lt);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;flex-shrink:0}
.sdh-panel{background:rgba(26,141,166,.05);border:.5px solid rgba(26,141,166,.18);border-radius:20px;padding:2rem}
.sdh-panel-lbl{font-size:11px;color:rgba(255,255,255,.35);letter-spacing:.12em;text-transform:uppercase;margin-bottom:1.5rem}
.pitem{padding:1.1rem;background:rgba(255,255,255,.04);border:.5px solid rgba(255,255,255,.07);border-radius:12px;margin-bottom:12px}
.pitem:last-child{margin-bottom:0}
.pitem h4{font-size:14px;font-weight:600;color:#fff;margin-bottom:4px}
.pitem p{font-size:13px;color:rgba(255,255,255,.38);line-height:1.6}

/* ============================================================
   SERVICE SUB-CARDS
   ============================================================ */
.sub-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(270px,1fr));gap:22px}
.sub-card{background:#fff;border:.5px solid var(--bdr);border-radius:20px;padding:2rem;transition:var(--tr);position:relative;overflow:hidden}
.sub-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--teal);transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease)}
.sub-card:hover{transform:translateY(-5px);box-shadow:0 20px 48px rgba(26,141,166,.1);border-color:rgba(26,141,166,.3)}
.sub-card:hover::before{transform:scaleX(1)}
.sub-ico{width:52px;height:52px;border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:1.25rem}
.sub-card h3{font-size:20px;font-weight:700;margin-bottom:.75rem}
.sub-card p{font-size:14px;color:var(--t2);line-height:1.75;margin-bottom:1.25rem}
.sub-card ul{margin-bottom:1.25rem}
.sub-card ul li{font-size:13px;color:var(--t2);padding:4px 0 4px 14px;position:relative}
.sub-card ul li::before{content:'›';position:absolute;left:0;color:var(--teal);font-weight:700}
.sub-link{font-size:13px;font-weight:500;color:var(--teal)}

/* ============================================================
   PROCESS STEPS
   ============================================================ */
.proc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px}
.proc-step{background:#fff;border:.5px solid var(--bdr);border-radius:20px;padding:2rem;transition:var(--tr)}
.proc-step:hover{transform:translateY(-4px);box-shadow:0 20px 48px rgba(26,141,166,.1);border-color:rgba(26,141,166,.3)}
.proc-n{font-family:var(--FD);font-size:40px;font-weight:800;color:rgba(26,141,166,.12);line-height:1;margin-bottom:.75rem}
.proc-step h3{font-size:17px;font-weight:700;margin-bottom:.5rem}
.proc-step p{font-size:14px;color:var(--t2);line-height:1.75}

/* ============================================================
   FAQ
   ============================================================ */
.faq-wrap{max-width:760px;margin:0 auto}
.faq-item{border-bottom:.5px solid var(--bdr)}
.faq-q{width:100%;text-align:left;padding:1.2rem 0;font-size:16px;font-weight:500;color:var(--t1);display:flex;justify-content:space-between;align-items:center;gap:1rem;cursor:pointer;background:none;border:none;font-family:var(--FB);transition:var(--tr)}
.faq-q:hover{color:var(--teal)}
.faq-q svg{flex-shrink:0;transition:var(--tr)}
.faq-item.open .faq-q svg{transform:rotate(180deg)}
.faq-a{font-size:15px;color:var(--t2);line-height:1.8;padding-bottom:1.2rem;display:none}
.faq-item.open .faq-a{display:block}

/* ============================================================
   OUR WORK PAGE
   ============================================================ */
.ftabs{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin-bottom:2.5rem}
.ftab{font-size:13px;font-weight:500;padding:9px 20px;border-radius:30px;border:.5px solid rgba(26,141,166,.2);background:#fff;color:var(--t2);cursor:pointer;transition:var(--tr)}
.ftab.act,.ftab:hover{background:var(--teal);color:#fff;border-color:var(--teal)}
.work-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:22px;margin-bottom:72px}
.wcard{background:#fff;border:.5px solid var(--bdr);border-radius:20px;overflow:hidden;transition:var(--tr)}
.wcard:hover{transform:translateY(-6px);box-shadow:0 24px 64px rgba(26,141,166,.12)}
.wcard-thumb{height:170px;background:var(--mid);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.wcard-thumb::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(26,141,166,.06),transparent 60%)}
.wcard-lbl{font-family:var(--FD);font-size:22px;font-weight:800;color:rgba(255,255,255,.12);letter-spacing:.04em;position:relative;z-index:1}
.wcard-tag{position:absolute;top:12px;left:12px;font-size:11px;font-weight:500;padding:4px 10px;border-radius:20px;background:rgba(26,141,166,.9);color:#fff}
.wcard-body{padding:1.4rem}
.wcard-client{font-size:17px;font-weight:700;margin-bottom:.4rem}
.wcard-svc{font-size:13px;color:var(--t2);margin-bottom:.9rem}
.wcard-res{font-size:13px;font-weight:500;color:var(--teal);padding:7px 12px;background:rgba(26,141,166,.06);border-radius:6px}

/* ============================================================
   BLOG PAGE
   ============================================================ */
.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:26px}
.bcard{background:#fff;border:.5px solid var(--bdr);border-radius:20px;overflow:hidden;transition:var(--tr)}
.bcard:hover{transform:translateY(-4px);box-shadow:0 20px 48px rgba(26,141,166,.1)}
.bcard-img{height:195px;background:linear-gradient(135deg,var(--mid),var(--space));position:relative;display:flex;align-items:center;justify-content:center}
.bcard-cat{position:absolute;top:12px;left:12px;font-size:11px;font-weight:500;padding:4px 10px;border-radius:20px;background:rgba(26,141,166,.9);color:#fff}
.bcard-ico{font-size:48px;opacity:.12}
.bcard-body{padding:1.5rem}
.bcard-date{font-size:12px;color:var(--t2);margin-bottom:.7rem}
.bcard h3{font-size:18px;font-weight:700;margin-bottom:.7rem;line-height:1.4}
.bcard p{font-size:14px;color:var(--t2);line-height:1.75;margin-bottom:1rem}
.bcard-read{font-size:13px;font-weight:500;color:var(--teal)}

/* ============================================================
   ABOUT PAGE
   ============================================================ */
.about-2col{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}
.about-2col h2{font-size:clamp(26px,4vw,40px);font-weight:800;margin-bottom:1.5rem}
.about-2col p{font-size:16px;color:var(--t2);line-height:1.85;margin-bottom:1rem}
.stat-cards{background:var(--mid);border-radius:32px;padding:2.5rem;display:flex;flex-direction:column;gap:1.25rem}
.stat-card{background:rgba(255,255,255,.04);border:.5px solid rgba(26,141,166,.15);border-radius:12px;padding:1.2rem 1.5rem;display:flex;align-items:center;gap:1rem}
.stat-card-n{font-family:var(--FD);font-size:34px;font-weight:800;color:var(--teal-lt);line-height:1;flex-shrink:0}
.stat-card-l{font-size:14px;color:rgba(255,255,255,.44);line-height:1.5}

/* ============================================================
   CONTACT PAGE
   ============================================================ */
.contact-2col{display:grid;grid-template-columns:1fr 1.65fr;gap:56px;align-items:start}
.contact-2col h2{font-size:clamp(26px,4vw,40px);font-weight:800;margin-bottom:1rem}
.contact-2col>div:first-child>p{font-size:16px;color:var(--t2);margin-bottom:2.5rem;line-height:1.75}
.cdet{display:flex;gap:14px;align-items:flex-start;margin-bottom:1.4rem}
.cdet-ico{width:44px;height:44px;border-radius:12px;background:rgba(26,141,166,.08);display:flex;align-items:center;justify-content:center;color:var(--teal);flex-shrink:0}
.cdet-lbl{font-size:11px;text-transform:uppercase;letter-spacing:.09em;color:var(--t2);margin-bottom:3px}
.cdet-val{font-size:15px;font-weight:500}
.cdet-val a{transition:var(--tr)}
.cdet-val a:hover{color:var(--teal)}
.cform-box{background:#fff;border:.5px solid rgba(26,141,166,.15);border-radius:32px;padding:2.5rem;box-shadow:0 12px 48px rgba(26,141,166,.08)}
.cform-box h3{font-size:22px;font-weight:700;margin-bottom:.5rem}
.cform-box>p{font-size:14px;color:var(--t2);margin-bottom:2rem}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.fg{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.fg label{font-size:13px;font-weight:500;color:var(--t1)}
.fg input,.fg select,.fg textarea{padding:11px 15px;border:.5px solid rgba(26,141,166,.2);border-radius:8px;font-family:var(--FB);font-size:14px;color:var(--t1);background:var(--off);transition:var(--tr);outline:none;width:100%}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--teal);background:#fff;box-shadow:0 0 0 3px rgba(26,141,166,.1)}
.fg textarea{resize:vertical;min-height:115px}
.fsub{width:100%;padding:14px;font-size:16px;font-weight:600}
.promise-badge{margin-top:1rem;padding:1rem 1.25rem;background:rgba(26,141,166,.06);border:.5px solid rgba(26,141,166,.2);border-radius:8px;font-size:13px;color:var(--teal-dk);font-weight:500;text-align:center}
.coffee-box{margin-top:2rem;padding:1.5rem;background:rgba(26,141,166,.05);border:.5px solid rgba(26,141,166,.18);border-radius:12px}
.coffee-box h4{font-size:15px;font-weight:600;color:var(--teal);margin-bottom:.5rem}
.coffee-box p{font-size:14px;color:var(--t2);line-height:1.7}

/* ============================================================
   SERVICES OVERVIEW
   ============================================================ */
.sov-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px}
.sov-card{display:block;background:#fff;border:.5px solid var(--bdr);border-radius:20px;padding:2.25rem;transition:var(--tr)}
.sov-card:hover{transform:translateY(-6px);box-shadow:0 24px 64px rgba(26,141,166,.12);border-color:rgba(26,141,166,.3)}
.sov-top{display:flex;align-items:center;gap:1rem;margin-bottom:1.4rem}
.sov-ico{width:50px;height:50px;border-radius:12px;display:flex;align-items:center;justify-content:center}
.sov-card>p{font-size:14px;color:var(--t2);line-height:1.75;margin-bottom:1.4rem}
.stags{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:1.5rem}
.stag-pill{font-size:12px;font-weight:500;padding:5px 12px;border-radius:20px;background:rgba(26,141,166,.07);color:var(--teal);border:.5px solid rgba(26,141,166,.2)}
.sov-link{font-size:14px;font-weight:500;color:var(--teal);display:flex;align-items:center;gap:6px}

/* ============================================================
   CONTENT MARKETING SPECIAL
   ============================================================ */
.vs-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.vs-box{border-radius:20px;padding:2rem}

/* ============================================================
   MAP & BACK TO TOP & WA FAB
   ============================================================ */
.map-embed{border-radius:32px;overflow:hidden;width:100%;height:300px;border:.5px solid rgba(26,141,166,.15)}
.map-embed iframe{width:100%;height:100%;border:0;display:block}
.wa-fab{position:fixed;bottom:28px;right:28px;z-index:999;width:56px;height:56px;border-radius:50%;background:#25D366;color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 24px rgba(37,211,102,.45);transition:var(--tr);text-decoration:none}
.wa-fab:hover{background:#1ebe5d;transform:scale(1.08)}
.btt{position:fixed;bottom:96px;right:30px;z-index:998;width:40px;height:40px;border-radius:10px;background:rgba(8,14,16,.8);backdrop-filter:blur(12px);border:.5px solid rgba(26,141,166,.2);color:rgba(255,255,255,.5);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--tr);opacity:0;pointer-events:none}
.btt.show{opacity:1;pointer-events:all}
.btt:hover{background:var(--teal);border-color:var(--teal);color:#fff;transform:translateY(-2px)}

/* ============================================================
   FOUNDER GRID
   ============================================================ */
.founder-grid{display:grid;grid-template-columns:200px 1fr;gap:56px;align-items:start;max-width:880px;margin:0 auto}

/* ============================================================
   GLOBAL OVERFLOW PREVENTION
   ============================================================ */
html{overflow-x:hidden}
body{overflow-x:hidden;max-width:100vw}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1024px){
  .foot-in{grid-template-columns:1fr 1fr}
  .about-2col{grid-template-columns:1fr;gap:2.5rem}
  .sdh-in{grid-template-columns:1fr}
  .contact-2col{grid-template-columns:1fr}
}
@media(max-width:768px){
  .sec{padding:64px 0}
  .nav-ul,.nav-cta{display:none}
  .burger{display:flex}
  .nav-ul.open{display:flex;flex-direction:column;position:fixed;top:0;left:0;right:0;bottom:0;background:var(--space);padding:80px 1.5rem 2rem;gap:0;align-items:flex-start;overflow-y:auto;z-index:9999;-webkit-overflow-scrolling:touch}
  .nav-ul.open .nav-a{font-size:17px;padding:14px 8px;width:100%;border-bottom:.5px solid rgba(255,255,255,.06);border-radius:0}
  .nav-ul.open li:first-child .nav-a{border-top:.5px solid rgba(255,255,255,.06)}
  .nav-ul.open .nav-cta{display:flex;margin:1.25rem 0 0;border:none!important}
  .nav-ul.open .drop-menu{position:static;opacity:1;visibility:visible;transform:none;background:transparent;border:none;padding:4px 0 4px 16px;box-shadow:none}
  .nav-ul.open .drop-menu a{font-size:15px;padding:10px 8px;color:rgba(255,255,255,.55);border-radius:0}
  .svc-grid,.why-grid,.proc-grid,.sub-grid{grid-template-columns:1fr}
  .frow{grid-template-columns:1fr}
  .foot-in{grid-template-columns:1fr;gap:2rem}
  .foot-btm{flex-direction:column;text-align:center}
  .cta-acts{flex-direction:column;align-items:center}
  .stats-box{padding:16px 18px}
  .stat-div{display:none}
  .stat{min-width:75px}
  .vs-grid{grid-template-columns:1fr}
}
@media(max-width:480px){
  .wrap{padding:0 1.25rem}
  .hero-h1{font-size:34px}
  .hero-acts{flex-direction:column}
  .hero-acts .btn{justify-content:center}
  .htitle{font-size:24px}
  .cform-box{padding:1.5rem}
  .frow{grid-template-columns:1fr}
  .wa-fab{bottom:18px;right:18px;width:50px;height:50px}
  .btt{bottom:80px;right:20px}
}

/* ============================================================
   MOBILE IMPROVEMENTS
   ============================================================ */
@media(max-width:768px){
  /* Hero */
  .hero-in{padding:50px 1.25rem 60px}
  .hero-badge{font-size:10px;padding:6px 13px}
  .hero-h1{font-size:36px;margin-bottom:1.2rem}
  .hero-sub{font-size:15px;margin-bottom:2rem}
  .hero-acts{gap:10px;margin-bottom:2.5rem}
  .hero-acts .btn--lg{padding:13px 24px;font-size:15px;justify-content:center;width:100%;max-width:280px}
  .stats-box{gap:0;border-radius:16px;padding:16px 12px}
  .stat-n{font-size:24px}
  .stat-plus{font-size:16px}
  .stat-l{font-size:9px}

  /* Nav mobile */
  .nav-ul.open{padding:1rem 1.25rem 2rem;gap:0}
  .nav-ul.open li{border-bottom:.5px solid rgba(255,255,255,.06)}
  .nav-ul.open .nav-a{font-size:16px;padding:13px 8px;border-radius:0}
  .nav-ul.open .drop-menu li{border-bottom:none}
  .nav-ul.open .nav-cta{display:flex;margin:1rem 0 0;border-bottom:none!important}

  /* Section spacing */
  .sec{padding:52px 0}
  .sh{margin-bottom:36px}
  .htitle{font-size:26px;line-height:1.2}
  .hsub{font-size:15px}

  /* Service cards */
  .svc-grid{grid-template-columns:1fr;gap:14px}
  .svc-card{padding:1.5rem}

  /* Why cards */
  .why-grid{grid-template-columns:1fr;gap:14px}
  .why-card{padding:1.5rem}
  .why-n{font-size:34px;margin-bottom:.7rem}

  /* Industry tags */
  .ind-tag{font-size:12px;padding:8px 14px}

  /* Work grid */
  .work-grid{grid-template-columns:1fr;gap:16px}

  /* Blog grid */
  .blog-grid{grid-template-columns:1fr;gap:16px}

  /* Page hero */
  .ph{padding:110px 0 60px}
  .ph h1{font-size:30px}
  .ph p{font-size:15px}

  /* SDH (service detail hero) */
  .sdh{padding:110px 0 60px}
  .sdh h1{font-size:28px}
  .feat-grid{grid-template-columns:1fr;gap:8px}

  /* CTA */
  .cta{padding:60px 0}
  .cta h2{font-size:28px}
  .cta p{font-size:15px}

  /* Footer */
  .foot{padding-top:48px}
  .foot-tag{font-size:13px}
  .foot-btm{padding:16px 1.25rem}

  /* Proc steps */
  .proc-grid{grid-template-columns:1fr 1fr;gap:14px}

  /* About 2col */
  .about-2col{gap:2rem}
  .stat-cards{padding:1.5rem}

  /* Founder grid — stack on mobile */
  .founder-grid{grid-template-columns:1fr;gap:2rem;text-align:center}
  .founder-grid>div:first-child{margin:0 auto;max-width:220px}

  /* About office 2-col grid */
  .about-office-grid{grid-template-columns:1fr!important;gap:2rem!important}

  /* Contact */
  .contact-2col{gap:2rem}
  .cdet{gap:12px}
  .cdet-ico{width:38px;height:38px;flex-shrink:0}
  .cform-box{padding:1.5rem;border-radius:20px}
}
@media(max-width:480px){
  .proc-grid{grid-template-columns:1fr}
  .svc-grid{grid-template-columns:1fr}
  .hero-h1{font-size:30px}
  .logo-txt{font-size:17px}
  .wa-fab{bottom:16px;right:16px;width:48px;height:48px}
  .btt{bottom:74px;right:18px;width:36px;height:36px}
  .stats-box{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:16px}
  .stat-div{display:none}
  .stat{min-width:0;text-align:center;padding:8px 0}
}
