/* ===== TOKENS ===== */
:root{
  --bg:#fafaf8;
  --bg2:#f3f1ec;
  --surface:#ffffff;
  --border:#e6e3dc;
  --border-s:#eeece6;
  --text:#111110;
  --text2:#2e2d2b;
  --muted:#6b6a67;
  --dim:#aaa89f;
  --accent:#e85d04;
  --accent-l:#f97316;
  --accent-bg:#fff4ed;
  --accent-border:#fdd3b1;
  --green:#166534;
  --nav-h:68px;
  --ease-out:cubic-bezier(0.23,1,0.32,1);
  --ease-spring:cubic-bezier(0.34,1.56,0.64,1);
  --t:200ms var(--ease-out);
  --r:12px;--rl:20px;--rs:8px;
  --shadow:0 1px 12px rgba(17,17,16,.06);
  --shadow-md:0 4px 32px rgba(17,17,16,.1);
  --shadow-lg:0 8px 56px rgba(17,17,16,.14);
}

/* ===== RESET ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth;overflow-x:hidden;-webkit-text-size-adjust:100%}
body{font-family:'DM Sans',sans-serif;background:var(--bg);color:var(--text);line-height:1.65;overflow-x:hidden;-webkit-font-smoothing:antialiased;max-width:100vw}
h1,h2,h3,h4,h5,h6{font-family:'Space Grotesk',sans-serif;line-height:1.08;font-weight:700;color:var(--text);letter-spacing:-.03em;text-wrap:balance}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{cursor:pointer;border:none;background:none;font:inherit}
ul{list-style:none}
p{text-wrap:pretty;max-width:65ch}
input,textarea,select{font-family:'DM Sans',sans-serif;font-size:1rem;color:var(--text)}

/* ===== LAYOUT ===== */
.container{max-width:1180px;width:100%;margin:0 auto;padding:0 36px}
.section{padding:96px 0}
h2{font-size:clamp(1.85rem,3vw,2.5rem);font-weight:700;letter-spacing:-.035em}
.gradient-text{background:linear-gradient(135deg,var(--accent),#ff9748);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

/* ===== SECTION LABEL ===== */
.sec-label{display:inline-flex;align-items:center;gap:7px;font-size:.7rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:14px}
.sec-label::before{content:'';width:18px;height:2px;background:var(--accent);border-radius:2px;flex-shrink:0}

/* ===== REVEAL ===== */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .55s var(--ease-out),transform .55s var(--ease-out);transition-delay:var(--delay,0ms)}
.reveal.visible{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ===== BUTTONS ===== */
.btn{display:inline-flex;align-items:center;gap:8px;padding:13px 26px;border-radius:9px;font-family:'DM Sans',sans-serif;font-weight:600;font-size:.9rem;transition:transform var(--t),box-shadow var(--t),background var(--t),border-color var(--t),color var(--t);cursor:pointer;border:1.5px solid transparent;white-space:nowrap;letter-spacing:-.01em}
.btn-primary{background:var(--text);color:var(--bg);border-color:var(--text)}
@media(hover:hover) and (pointer:fine){.btn-primary:hover{background:#2a2a28;transform:translateY(-2px);box-shadow:0 8px 28px rgba(17,17,16,.25)}}
.btn-primary:active{transform:scale(.97)!important;box-shadow:none!important}
.btn-outline{background:transparent;border-color:var(--border);color:var(--text2)}
@media(hover:hover) and (pointer:fine){.btn-outline:hover{border-color:var(--text);color:var(--text)}}
.btn-outline:active{transform:scale(.97)!important}
.btn-accent{background:var(--accent);color:#fff;border-color:var(--accent)}
@media(hover:hover) and (pointer:fine){.btn-accent:hover{background:#d14f03;transform:translateY(-2px);box-shadow:0 8px 28px rgba(232,93,4,.3)}}
.btn-accent:active{transform:scale(.97)!important}
.btn-ghost{background:transparent;color:var(--text);border-color:transparent}
@media(hover:hover) and (pointer:fine){.btn-ghost:hover{background:var(--bg2)}}
.btn-lg{padding:16px 32px;font-size:.95rem;border-radius:11px}
.btn-sm{padding:8px 16px;font-size:.82rem;border-radius:7px}
.btn-block{width:100%;justify-content:center}
.btn-pill{border-radius:100px}

/* ===== NAVBAR ===== */
.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;height:var(--nav-h);display:flex;align-items:center;transition:background var(--t),box-shadow var(--t)}
.navbar.scrolled{background:rgba(250,250,248,.96);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:0 1px 0 var(--border)}
.navbar .container{display:flex;align-items:center}
.nav-inner{display:flex;align-items:center;justify-content:space-between;width:100%;gap:8px}
.nav-logo{display:flex;align-items:center;gap:9px;font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:1.05rem;color:var(--text);letter-spacing:-.03em}
.logo-icon{width:32px;height:32px;background:var(--accent);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:.75rem;color:#fff;flex-shrink:0;font-family:'Space Grotesk',sans-serif;font-weight:700}
.nav-menu{display:flex;align-items:center;gap:1px}
.nav-link{font-size:.86rem;font-weight:500;color:var(--muted);transition:color var(--t),background var(--t);padding:7px 13px;border-radius:7px;letter-spacing:-.01em}
@media(hover:hover) and (pointer:fine){.nav-link:hover{color:var(--text);background:var(--bg2)}}
.nav-link.active{color:var(--text);font-weight:600}
.dd-icon{font-size:.6rem;margin-left:3px;transition:transform 200ms var(--ease-out)}
.nav-item{position:relative}
.nav-item:hover .dd-icon{transform:rotate(180deg)}
.nav-dropdown{display:none;position:absolute;top:calc(100% + 8px);left:50%;transform:translateX(-50%);background:rgba(250,250,248,.98);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:12px;padding:6px;min-width:220px;box-shadow:0 8px 32px rgba(17,17,16,.1);z-index:200}
.nav-item:hover .nav-dropdown{display:block!important}
.nav-item.open .nav-dropdown{display:block!important}
.nav-dropdown a{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:8px;color:var(--text);font-size:.84rem;font-weight:500;transition:background var(--t),color var(--t);text-decoration:none}
@media(hover:hover) and (pointer:fine){.nav-dropdown a:hover{background:var(--bg2);color:var(--accent)}}
.nav-dropdown a i{width:16px;text-align:center;color:var(--muted);font-size:.8rem;flex-shrink:0}
.nav-actions{display:flex;align-items:center;gap:8px}
.nav-cta-desktop{border-radius:8px;padding:8px 18px;font-size:.85rem}
.nav-cta-mobile{display:none}
.hamburger{display:none;flex-direction:column;gap:5px;padding:8px;z-index:1010;flex-shrink:0}
.hamburger span{display:block;width:20px;height:1.5px;background:var(--text);border-radius:2px;transition:transform .22s var(--ease-out),opacity .22s var(--ease-out)}
.hamburger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* ===== HERO ===== */
.hero{position:relative;min-height:100dvh;display:flex;flex-direction:column;justify-content:center;padding-top:var(--nav-h);overflow:hidden;background:var(--bg)}
.hero-bg-shape{position:absolute;top:-120px;right:-80px;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle at center,rgba(232,93,4,.07) 0%,transparent 70%);pointer-events:none;z-index:0}
.hero-bg-dots{position:absolute;bottom:0;left:0;right:0;height:300px;background-image:radial-gradient(circle,var(--border) 1px,transparent 1px);background-size:28px 28px;opacity:.5;z-index:0;mask-image:linear-gradient(to top,rgba(0,0,0,.3),transparent)}
.hero-inner{position:relative;z-index:1;padding:64px 0 48px}
.hero-kicker{display:inline-flex;align-items:center;gap:8px;background:var(--accent-bg);border:1px solid var(--accent-border);border-radius:100px;padding:5px 14px 5px 6px;margin-bottom:28px}
.kicker-dot{width:22px;height:22px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.kicker-dot i{font-size:.55rem;color:#fff}
.hero-kicker span{font-size:.74rem;font-weight:600;color:var(--accent);letter-spacing:.04em}
.hero h1{font-size:clamp(2.8rem,5.5vw,4.8rem);font-weight:700;line-height:1.03;letter-spacing:-.05em;max-width:820px;margin-bottom:24px}
.hero-sub{font-size:clamp(1rem,1.6vw,1.12rem);color:var(--muted);max-width:540px;line-height:1.8;margin-bottom:40px}
.hero-actions{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:60px}
.hero-proof{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.hero-proof-avatars{display:flex}
.hero-proof-avatars .av{width:32px;height:32px;border-radius:50%;border:2.5px solid var(--bg);margin-left:-8px;font-size:.65rem;font-weight:700;color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.hero-proof-avatars .av:first-child{margin-left:0}
.hero-proof-text{font-size:.83rem;color:var(--muted)}
.hero-proof-text strong{color:var(--text)}
.hero-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);border:1px solid var(--border);border-radius:var(--rl);overflow:hidden;margin-top:64px}
.hstat{background:var(--surface);padding:28px 24px;position:relative;text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center}
.hstat::after{content:'';position:absolute;top:20px;right:0;width:1px;height:calc(100% - 40px);background:var(--border)}
.hstat:last-child::after{display:none}
.hstat-num{font-family:'Space Grotesk',sans-serif;font-size:2.2rem;font-weight:700;color:var(--text);letter-spacing:-.05em;line-height:1}
.hstat-label{font-size:.78rem;color:var(--muted);margin-top:6px;line-height:1.4}

/* ===== MARQUEE / TICKER ===== */
.ticker{padding:20px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);overflow:hidden;background:var(--bg)}
.ticker-track{display:flex;gap:0;animation:ticker 28s linear infinite}
@media(prefers-reduced-motion:reduce){.ticker-track{animation:none}}
.ticker-item{display:flex;align-items:center;gap:40px;white-space:nowrap;flex-shrink:0;padding-right:40px}
.ticker-item span{font-size:.8rem;font-weight:500;color:var(--dim);letter-spacing:.06em;text-transform:uppercase}
.ticker-sep{width:5px;height:5px;border-radius:50%;background:var(--accent);flex-shrink:0}
@keyframes ticker{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ===== SERVICES Ã¢â‚¬â€ NUMBERED LIST (not cards) ===== */
.services{background:var(--bg)}
.services-split{display:grid;grid-template-columns:1fr 2fr;gap:80px;align-items:start}
.services-intro{position:sticky;top:calc(var(--nav-h) + 32px)}
.services-intro p{color:var(--muted);font-size:.94rem;line-height:1.8;margin-top:14px;margin-bottom:28px}
.svc-list{display:flex;flex-direction:column}
.svc-row{display:grid;grid-template-columns:48px 1fr auto;gap:20px;align-items:center;padding:28px 0;border-bottom:1px solid var(--border);cursor:pointer;transition:background var(--t);border-radius:0}
.svc-row:first-child{border-top:1px solid var(--border)}
@media(hover:hover) and (pointer:fine){.svc-row:hover .svc-row-title{color:var(--accent)}.svc-row:hover .svc-arrow{transform:translate(3px,-3px);color:var(--accent)}}
.svc-num{font-family:'Space Grotesk',sans-serif;font-size:.75rem;font-weight:600;color:var(--dim);letter-spacing:.06em;align-self:start;padding-top:3px}
.svc-row-body{}
.svc-row-title{font-family:'Space Grotesk',sans-serif;font-size:1.08rem;font-weight:600;color:var(--text);transition:color var(--t);margin-bottom:5px;letter-spacing:-.025em}
.svc-row-desc{font-size:.84rem;color:var(--muted);line-height:1.65;max-width:420px}
.svc-row-tags{display:flex;gap:6px;flex-wrap:wrap;margin-top:10px}
.svc-tag{font-size:.68rem;font-weight:500;color:var(--text2);background:var(--bg2);border:1px solid var(--border);border-radius:100px;padding:2px 9px;letter-spacing:.02em}
.svc-arrow{font-size:.82rem;color:var(--dim);transition:transform var(--t),color var(--t);align-self:start;padding-top:4px}

/* ===== ABOUT ===== */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.about-visual{position:relative}
.about-img-wrap{border-radius:var(--rl);overflow:hidden;background:var(--bg2);border:1px solid var(--border);aspect-ratio:4/3;display:flex;align-items:center;justify-content:center}
.about-img-placeholder{font-size:4.5rem;color:var(--border)}
.about-float{position:absolute;bottom:-18px;right:-18px;background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:14px 18px;box-shadow:var(--shadow-md);display:flex;align-items:center;gap:12px}
.about-float-icon{width:38px;height:38px;background:var(--accent);border-radius:9px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.9rem;flex-shrink:0}
.about-float-text strong{display:block;font-size:.88rem;font-weight:600;color:var(--text);letter-spacing:-.02em}
.about-float-text small{font-size:.73rem;color:var(--muted)}
.about-text h2{margin-bottom:16px}
.about-text>p{color:var(--muted);font-size:.95rem;line-height:1.82;margin-bottom:24px}
.about-checklist{display:flex;flex-direction:column;gap:10px;margin-bottom:30px}
.about-check{display:flex;align-items:flex-start;gap:10px;font-size:.87rem;color:var(--text2)}
.about-check i{color:var(--accent);font-size:.8rem;flex-shrink:0;margin-top:3px}
.about-nums{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;margin-top:32px}
.about-num-box{background:var(--surface);padding:20px}
.about-num-box .n{font-family:'Space Grotesk',sans-serif;font-size:1.8rem;font-weight:700;color:var(--text);letter-spacing:-.04em;line-height:1}
.about-num-box p{font-size:.75rem;color:var(--muted);margin-top:4px}

/* ===== PORTFOLIO ===== */
.portfolio{background:var(--bg)}
.port-head{display:grid;grid-template-columns:1fr auto;gap:40px;align-items:end;margin-bottom:40px}
.port-head-text p{color:var(--muted);font-size:.94rem;line-height:1.75;margin-top:10px;max-width:480px}
.filter-bar{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end;align-self:end}
.filter-btn{padding:7px 16px;border-radius:100px;font-size:.8rem;font-weight:500;color:var(--muted);background:var(--surface);border:1px solid var(--border);transition:all 160ms var(--ease-out);cursor:pointer;font-family:'DM Sans',sans-serif;white-space:nowrap}
@media(hover:hover) and (pointer:fine){.filter-btn:hover{border-color:var(--text);color:var(--text)}}
.filter-btn.active{background:var(--text);color:var(--bg);border-color:var(--text)}
.filter-btn:active{transform:scale(.96)}
.portfolio-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.portfolio-grid .portfolio-card{height:100%}
.portfolio-card{border-radius:var(--rl);overflow:hidden;background:var(--surface);border:1px solid var(--border);transition:transform 220ms var(--ease-out),box-shadow 220ms var(--ease-out),opacity 200ms var(--ease-out);display:flex;flex-direction:column}
@media(hover:hover) and (pointer:fine){.portfolio-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}}
.portfolio-card.hidden{opacity:0;transform:scale(.97);pointer-events:none}
.portfolio-thumb{height:200px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.portfolio-thumb i{font-size:2.6rem;color:#fff;opacity:.9}
.portfolio-info{padding:20px 22px 24px;display:flex;flex-direction:column;flex:1}
.p-tag,.portfolio-tag{display:inline-block;font-size:.66rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);background:var(--accent-bg);border:1px solid var(--accent-border);border-radius:6px;padding:3px 9px;margin-bottom:10px;width:fit-content}
.portfolio-info h3{font-size:.97rem;font-weight:600;margin-bottom:6px;letter-spacing:-.02em;line-height:1.35}
.portfolio-info p{font-size:.83rem;color:var(--muted);line-height:1.6;margin-bottom:16px;flex:1}
.port-link{display:inline-flex;align-items:center;gap:5px;font-size:.8rem;font-weight:600;color:var(--text);transition:gap 160ms var(--ease-out);margin-top:auto}
@media(hover:hover) and (pointer:fine){.port-link:hover{gap:9px}}

/* ===== TESTIMONIALS ===== */
.testimonials{background:var(--bg)}
.t-header{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:end;margin-bottom:52px}
.t-header h2{margin-bottom:0}
.t-header p{color:var(--muted);font-size:.94rem;line-height:1.8}
.t-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.t-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--rl);padding:32px;display:flex;flex-direction:column;gap:16px;transition:box-shadow 220ms var(--ease-out),border-color 220ms var(--ease-out)}
@media(hover:hover) and (pointer:fine){.t-card:hover{border-color:var(--dim);box-shadow:var(--shadow-md)}}
.t-card:first-child{background:var(--text);border-color:var(--text)}
.t-card:first-child blockquote{color:rgba(250,250,248,.75)}
.t-card:first-child .t-author-name{color:var(--bg)}
.t-card:first-child .t-author-role{color:rgba(250,250,248,.45)}
.t-stars{display:flex;gap:3px;color:#f59e0b;font-size:.75rem}
.t-card:first-child .t-stars{color:#fb923c}
blockquote{font-size:.92rem;color:var(--text2);line-height:1.82;font-style:italic;font-weight:400}
.t-author{display:flex;align-items:center;gap:10px;margin-top:auto}
.t-avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.8rem;color:#fff;flex-shrink:0}
.t-author-name{font-size:.88rem;font-weight:600;color:var(--text);letter-spacing:-.015em}
.t-author-role{font-size:.75rem;color:var(--muted)}
/* Keep old slider styles for inner pages */
.slider-wrap{position:relative}
.slider-track{display:flex;overflow:hidden}
.testimonial-card{flex-shrink:0;width:100%;display:none;background:var(--surface);border-radius:var(--rl);padding:36px;border:1px solid var(--border)}
.testimonial-card.active{display:block}
.quote-mark{font-size:3.5rem;line-height:.75;color:var(--accent);opacity:.2;font-family:Georgia,serif;display:block;margin-bottom:6px}
.stars{color:#f59e0b;font-size:.8rem;display:flex;gap:3px;margin-bottom:14px}
.testimonial-card blockquote{font-size:1rem;color:var(--text2);line-height:1.8;margin-bottom:24px;font-style:italic}
.testimonial-author{display:flex;align-items:center;gap:12px}
.author-avatar{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.82rem;color:#fff;flex-shrink:0}
.author-name{font-weight:600;font-size:.9rem;color:var(--text)}
.author-role{font-size:.77rem;color:var(--muted)}
.slider-controls{display:flex;align-items:center;gap:10px;margin-top:20px}
.slider-btn{width:36px;height:36px;border-radius:50%;border:1px solid var(--border);background:var(--surface);color:var(--muted);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all 160ms var(--ease-out);font-size:.8rem}
@media(hover:hover) and (pointer:fine){.slider-btn:hover{border-color:var(--text);color:var(--text)}}
.slider-btn:active{transform:scale(.92)}
#sliderDots{display:flex;gap:6px}
.dot{width:7px;height:7px;border-radius:50%;background:var(--border);cursor:pointer;transition:all .2s var(--ease-out);border:none}
.dot.active{background:var(--text);width:20px;border-radius:4px}

/* ===== CTA ===== */
.cta-section{padding:96px 0;background:var(--bg2);border-top:1px solid var(--border)}
.cta-inner{display:grid;grid-template-columns:1fr auto;gap:48px;align-items:center;padding:56px 60px;background:var(--surface);border:1px solid var(--border);border-radius:24px;box-shadow:var(--shadow)}
.cta-inner h2{font-size:clamp(1.6rem,2.8vw,2.2rem);margin-bottom:10px}
.cta-inner>div:first-child p{color:var(--muted);font-size:.94rem;line-height:1.75}
.cta-perks{display:flex;gap:18px;flex-wrap:wrap;margin-top:18px}
.cta-perks span{font-size:.8rem;color:var(--muted);display:flex;align-items:center;gap:6px}
.cta-perks span i{color:var(--accent);font-size:.72rem}
.cta-actions{display:flex;flex-direction:column;gap:10px;align-items:stretch;flex-shrink:0;min-width:200px}
.btn-outline-dark{background:transparent;border:1.5px solid var(--border);color:var(--text2)}
@media(hover:hover) and (pointer:fine){.btn-outline-dark:hover{border-color:var(--text);color:var(--text)}}
.btn-outline-dark:active{transform:scale(.97)!important}

/* ===== TEAM ===== */
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.team-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--rl);overflow:hidden;display:flex;flex-direction:column;transition:transform 220ms var(--ease-out),box-shadow 220ms var(--ease-out),border-color 220ms var(--ease-out)}
@media(hover:hover) and (pointer:fine){.team-card:hover{border-color:var(--dim);box-shadow:var(--shadow-md);transform:translateY(-4px)}}
.team-photo{height:320px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;flex-shrink:0}
.team-photo i{font-size:5.5rem;color:rgba(255,255,255,.35)}
.team-photo img{width:100%;height:100%;object-fit:cover;object-position:top center;display:block}
.team-info{padding:16px 18px 20px;background:var(--surface)}
.team-card h3{font-size:1rem;font-weight:600;margin-bottom:4px;letter-spacing:-.02em;color:var(--text)}
.team-card .role{font-size:.78rem;color:var(--accent);font-weight:600;display:block}

/* ===== BLOG ===== */
.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}
.blog-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--rl);overflow:hidden;transition:transform 220ms var(--ease-out),box-shadow 220ms var(--ease-out)}
@media(hover:hover) and (pointer:fine){.blog-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}}
.blog-thumb{aspect-ratio:16/9;display:flex;align-items:center;justify-content:center;font-size:2rem}
.blog-body{padding:20px 22px}
.blog-meta{display:flex;align-items:center;gap:10px;font-size:.73rem;color:var(--muted);margin-bottom:10px;flex-wrap:wrap}
.blog-cat{color:var(--accent);font-weight:600}
.blog-card h3{font-size:.94rem;font-weight:600;margin-bottom:7px;line-height:1.45;letter-spacing:-.02em}
.blog-card p{font-size:.82rem;color:var(--muted);line-height:1.65;margin-bottom:14px}
.blog-link{display:inline-flex;align-items:center;gap:5px;font-size:.8rem;font-weight:600;color:var(--text);transition:gap 160ms var(--ease-out)}
@media(hover:hover) and (pointer:fine){.blog-link:hover{gap:9px}}

/* ===== TRUSTED ===== */
.trusted{padding:40px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--bg)}
.trusted-label{font-size:.7rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--dim);text-align:center;margin-bottom:22px}
.trusted-logos{display:flex;align-items:center;justify-content:center;gap:48px;flex-wrap:wrap}
.trusted-logo{font-size:.86rem;font-weight:700;color:var(--dim);letter-spacing:-.02em;opacity:.4}

/* ===== CONTACT ===== */
.contact-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:64px;align-items:start}
.contact-info>p{color:var(--muted);margin-bottom:28px;line-height:1.8;font-size:.94rem}
.contact-items{display:flex;flex-direction:column;gap:16px;margin-bottom:28px}
.ci{display:flex;align-items:flex-start;gap:12px}
.ci-icon{width:36px;height:36px;background:var(--bg2);border:1px solid var(--border);border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--accent);flex-shrink:0;font-size:.84rem}
.ci-label{font-size:.7rem;color:var(--muted);font-weight:500;text-transform:uppercase;letter-spacing:.07em}
.ci-val{font-size:.87rem;color:var(--text);font-weight:500;margin-top:2px}
.form-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--rl);padding:36px;box-shadow:var(--shadow)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-group{margin-bottom:14px}
.form-group label{display:block;font-size:.79rem;font-weight:600;color:var(--text2);margin-bottom:6px;letter-spacing:-.01em}
.form-group input,.form-group textarea,.form-group select{width:100%;padding:11px 14px;border:1.5px solid var(--border);border-radius:9px;background:var(--bg);color:var(--text);font-size:.9rem;font-family:'DM Sans',sans-serif;transition:border-color .18s var(--ease-out),box-shadow .18s var(--ease-out);resize:vertical}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(232,93,4,.1)}
.form-group input[aria-invalid="true"],.form-group textarea[aria-invalid="true"]{border-color:#ef4444}
.field-error{font-size:.75rem;color:#ef4444;margin-top:4px;min-height:16px;display:block}
.form-feedback{margin-top:14px;padding:11px 15px;border-radius:9px;font-size:.87rem;font-weight:500}
.form-feedback.success{background:#f0fdf4;color:#15803d;border:1px solid #bbf7d0}
.form-feedback.error{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}

/* ===== PRICING ===== */
.pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:14px}
.pricing-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--rl);padding:32px;transition:transform 220ms var(--ease-out),box-shadow 220ms var(--ease-out);position:relative}
@media(hover:hover) and (pointer:fine){.pricing-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}}
.pricing-card.featured{border-color:var(--text);background:var(--text);color:var(--bg)}
.pricing-card.featured h3,.pricing-card.featured .price{color:var(--bg)}
.pricing-card.featured>p,.pricing-card.featured .price span{color:rgba(250,250,248,.45)}
.pricing-card.featured li{color:rgba(250,250,248,.78)}
.pricing-card.featured .btn-primary{background:var(--bg);color:var(--text)}
.pricing-badge{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--accent);color:#fff;font-size:.7rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;padding:4px 14px;border-radius:100px;white-space:nowrap;font-family:'DM Sans',sans-serif}
.pricing-card h3{font-size:1rem;font-weight:600;margin-bottom:7px}
.pricing-card>p{font-size:.83rem;color:var(--muted);margin-bottom:22px}
.price{font-family:'Space Grotesk',sans-serif;font-size:2.2rem;font-weight:700;line-height:1;color:var(--text);letter-spacing:-.05em}
.price span{font-size:.87rem;font-weight:400;color:var(--muted)}
.pricing-card>ul{margin:20px 0;display:flex;flex-direction:column;gap:9px}
.pricing-card li{display:flex;align-items:center;gap:8px;font-size:.85rem;color:var(--text2)}
.pricing-card li i{color:var(--accent);font-size:.76rem;flex-shrink:0}
.pricing-card.featured li i{color:#fb923c}

/* ===== PAGE HERO ===== */
.page-hero{padding:120px 0 56px;background:var(--bg);border-bottom:1px solid var(--border)}
.page-hero h1{font-size:clamp(2rem,4vw,2.8rem);margin-bottom:14px}
.page-hero p{color:var(--muted);max-width:500px;font-size:1rem}
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:.77rem;color:var(--muted);margin-top:18px;flex-wrap:wrap}
.breadcrumb a{color:var(--accent)}
.breadcrumb i{font-size:.58rem}

/* ===== SERVICE DETAIL ===== */
.section-header{max-width:640px;margin:0 auto 56px;text-align:center}
.section-header p{color:var(--muted);margin-top:14px;font-size:.95rem;line-height:1.78}
.section-tag{display:inline-flex;align-items:center;gap:6px;font-size:.7rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);background:var(--accent-bg);border:1px solid var(--accent-border);padding:4px 12px;border-radius:100px;margin-bottom:12px}
.services-detail-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}
.sd-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--rl);padding:30px;transition:transform 220ms var(--ease-out),box-shadow 220ms var(--ease-out),border-color 220ms var(--ease-out)}
@media(hover:hover) and (pointer:fine){.sd-card:hover{border-color:var(--dim);box-shadow:var(--shadow-md);transform:translateY(-3px)}}
.sd-icon{width:46px;height:46px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:1rem;margin-bottom:16px;color:#fff;flex-shrink:0}
.sd-card h3{font-size:1.05rem;font-weight:600;margin-bottom:9px;letter-spacing:-.025em}
.sd-card>p{color:var(--muted);font-size:.87rem;line-height:1.75;margin-bottom:16px}
.sd-features{display:flex;flex-direction:column;gap:8px}
.sd-feature{display:flex;align-items:center;gap:8px;font-size:.83rem;color:var(--text2)}
.sd-feature i{color:var(--accent);flex-shrink:0}

/* ===== PROCESS ===== */
.process-steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:0;position:relative}
.process-steps::before{content:'';position:absolute;top:26px;left:10%;right:10%;height:1px;background:var(--border);z-index:0}
.process-step{text-align:center;padding:20px 14px;position:relative;z-index:1}
.step-num{width:52px;height:52px;border-radius:50%;background:var(--text);color:var(--bg);font-weight:700;font-size:1rem;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;font-family:'Space Grotesk',sans-serif}
.process-step h3{font-size:.93rem;font-weight:600;margin-bottom:7px;letter-spacing:-.02em}
.process-step p{font-size:.8rem;color:var(--muted)}

/* ===== VALUES ===== */
.values-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}
.value-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--rl);padding:24px;transition:border-color 200ms var(--ease-out),box-shadow 200ms var(--ease-out)}
@media(hover:hover) and (pointer:fine){.value-card:hover{border-color:var(--dim);box-shadow:var(--shadow)}}
.value-icon{font-size:1.3rem;color:var(--accent);margin-bottom:12px}
.value-card h3{font-size:.94rem;font-weight:600;margin-bottom:6px;letter-spacing:-.02em}
.value-card p{font-size:.8rem;color:var(--muted);line-height:1.65}

/* ===== COUNTERS ===== */
.counters{background:var(--text)}
.counters-grid{display:grid;grid-template-columns:repeat(4,1fr)}
.counter-item{padding:52px 24px;text-align:center;position:relative}
.counter-item:not(:last-child)::after{content:'';position:absolute;right:0;top:24px;height:calc(100% - 48px);width:1px;background:rgba(250,250,248,.1)}
.counter-num{font-family:'Space Grotesk',sans-serif;font-size:2.8rem;font-weight:700;color:#fff;line-height:1;letter-spacing:-.05em}
.counter-suffix{font-size:1.6rem;font-weight:700;color:var(--accent)}
.counter-item p{font-size:.8rem;color:rgba(250,250,248,.45);margin-top:8px;letter-spacing:.01em}

/* ===== FOOTER ===== */
.footer{background:var(--text);color:rgba(250,250,248,.42);padding:64px 0 0}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;margin-bottom:48px}
.footer-brand .nav-logo{margin-bottom:14px;color:var(--bg);display:inline-flex}
.footer-brand .logo-icon{background:var(--accent)}
.footer-brand p{font-size:.83rem;line-height:1.75;max-width:240px}
.footer-social{display:flex;gap:7px;margin-top:20px;flex-wrap:wrap}
.footer-social a{width:32px;height:32px;border-radius:7px;background:rgba(250,250,248,.05);border:1px solid rgba(250,250,248,.09);display:flex;align-items:center;justify-content:center;color:rgba(250,250,248,.36);font-size:.78rem;transition:all 180ms var(--ease-out)}
@media(hover:hover) and (pointer:fine){.footer-social a:hover{background:var(--accent);border-color:var(--accent);color:#fff;transform:translateY(-2px)}}
.footer-social a:active{transform:scale(.92)}
.footer-col h4{font-size:.72rem;font-weight:600;color:var(--bg);letter-spacing:.1em;text-transform:uppercase;margin-bottom:16px}
.footer-col ul{display:flex;flex-direction:column;gap:9px}
.footer-col li a{font-size:.82rem;color:rgba(250,250,248,.38);transition:color .18s var(--ease-out)}
@media(hover:hover) and (pointer:fine){.footer-col li a:hover{color:var(--bg)}}
.footer-bottom{border-top:1px solid rgba(250,250,248,.07);padding:20px 0;display:flex;align-items:center;justify-content:space-between;font-size:.77rem;gap:16px;flex-wrap:wrap}
.newsletter-form{display:flex;gap:6px;margin-top:12px}
.newsletter-form input{flex:1;min-width:0;padding:9px 12px;border-radius:8px;border:1px solid rgba(250,250,248,.09);background:rgba(250,250,248,.05);color:var(--bg);font-size:.82rem;font-family:'DM Sans',sans-serif}
.newsletter-form input::placeholder{color:rgba(250,250,248,.24)}
.newsletter-form input:focus{outline:none;border-color:var(--accent)}
.newsletter-form button{padding:9px 15px;background:var(--accent);color:#fff;border-radius:8px;font-size:.8rem;font-weight:600;white-space:nowrap;cursor:pointer;flex-shrink:0;font-family:'DM Sans',sans-serif;transition:background 160ms var(--ease-out)}
@media(hover:hover) and (pointer:fine){.newsletter-form button:hover{background:var(--accent-l)}}

/* ===== SCROLL-TO-TOP ===== */
.scroll-top{position:fixed;bottom:24px;right:24px;width:40px;height:40px;border-radius:10px;background:var(--text);color:var(--bg);border:none;display:flex;align-items:center;justify-content:center;font-size:.8rem;cursor:pointer;opacity:0;visibility:hidden;transform:translateY(12px) scale(.9);transition:opacity 220ms var(--ease-out),transform 220ms var(--ease-out),visibility 220ms;box-shadow:0 4px 16px rgba(17,17,16,.22);z-index:998}
.scroll-top.visible{opacity:1;visibility:visible;transform:none}
@media(hover:hover) and (pointer:fine){.scroll-top:hover{transform:translateY(-3px);box-shadow:0 8px 28px rgba(17,17,16,.3)}}
.scroll-top:active{transform:scale(.93)}

/* ===== LEGACY COMPAT (inner pages) ===== */
.service-card{background:var(--surface);border-radius:var(--rl);padding:28px;border:1px solid var(--border);transition:transform 220ms var(--ease-out),box-shadow 220ms var(--ease-out);display:flex;flex-direction:column}
@media(hover:hover) and (pointer:fine){.service-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}}
.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}
.svc-icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1rem;margin-bottom:18px;color:#fff;flex-shrink:0}
.service-card h3{font-size:1.02rem;font-weight:600;margin-bottom:8px;letter-spacing:-.02em}
.service-card>p{color:var(--muted);font-size:.86rem;line-height:1.72;margin-bottom:14px;flex:1}
.svc-features{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.svc-feature{display:flex;align-items:center;gap:8px;font-size:.81rem;color:var(--text2)}
.svc-feature i{color:var(--accent);font-size:.7rem;flex-shrink:0}
.svc-link{display:inline-flex;align-items:center;gap:6px;font-size:.81rem;font-weight:600;color:var(--accent);transition:gap 160ms var(--ease-out);margin-top:auto}
@media(hover:hover) and (pointer:fine){.svc-link:hover{gap:10px}}
.stat-box{background:var(--surface);padding:24px 18px;text-align:center}
.stat-box .num{font-family:'Space Grotesk',sans-serif;font-size:1.8rem;font-weight:700;letter-spacing:-.04em;color:var(--text);line-height:1}
.stat-box p{font-size:.74rem;color:var(--muted);margin-top:5px}
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;margin-top:24px}
.section-header p{color:var(--muted);margin-top:12px;font-size:.94rem;line-height:1.78}

/* ===== MISC ===== */
.divider{height:1px;background:var(--border)}
.hidden{display:none!important}
.social-link{transition:opacity 180ms var(--ease-out)}
@media(hover:hover) and (pointer:fine){.social-link:hover{opacity:.65}}
.scroll-hint{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);width:36px;height:36px;border:1px solid var(--border);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--dim);font-size:.72rem;animation:scrollBounce 2s ease-in-out infinite;z-index:1;background:var(--surface)}
@keyframes scrollBounce{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(6px)}}
.section-cta{text-align:center;margin-top:48px}

/* ===== RESPONSIVE ===== */
@media(max-width:1024px){
  .container{padding:0 28px}
  .section{padding:72px 0}
  .services-split{grid-template-columns:1fr;gap:48px}
  .services-intro{position:static}
  .hero-stats{grid-template-columns:repeat(2,1fr)}
  .about-grid{grid-template-columns:1fr;gap:48px}
  .t-header{grid-template-columns:1fr;gap:12px}
  .t-grid{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .contact-grid{grid-template-columns:1fr;gap:36px}
  .cta-inner{grid-template-columns:1fr;text-align:center}
  .cta-actions{flex-direction:row;justify-content:center;min-width:0}
  .cta-perks{justify-content:center}
  .portfolio-grid{grid-template-columns:repeat(2,1fr)}
  port-head{display:grid;grid-template-columns:1fr auto;gap:40px;align-items:end;margin-bottom:24px}
  .filter-bar{justify-content:flex-start}
}

@media(max-width:768px){
  .container{padding:0 18px}
  .navbar{padding:0 16px}
  .hamburger{display:flex}
  .nav-actions .nav-cta-desktop{display:none}
  .nav-menu{
    position:fixed;top:var(--nav-h);left:16px;right:16px;
    background:rgba(250,250,248,.98);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
    flex-direction:column;align-items:stretch;padding:10px;gap:3px;
    border:1px solid var(--border);border-radius:16px;
    box-shadow:0 8px 40px rgba(17,17,16,.12);z-index:999;
    opacity:0;transform:translateY(-8px) scale(.98);pointer-events:none;
    transition:opacity 200ms var(--ease-out),transform 200ms var(--ease-out);
    display:flex;max-height:calc(100dvh - var(--nav-h) - 24px);overflow-y:auto}
  .nav-menu.open{opacity:1;transform:none;pointer-events:auto}
  .nav-link{padding:12px 14px;border-radius:10px;font-size:.93rem;color:var(--text)}
  .nav-item:hover .nav-dropdown{display:none!important}
  .nav-dropdown{position:static;transform:none;box-shadow:none;border:none;border-radius:0;background:transparent;backdrop-filter:none;-webkit-backdrop-filter:none;padding:2px 0 4px 12px;min-width:0;border-left:2px solid var(--border);margin-top:2px}
  .nav-item.open .nav-dropdown{display:block!important}
  .nav-item.open .dd-icon{transform:rotate(180deg)}
  .nav-cta-mobile{display:block;padding-top:6px;border-top:1px solid var(--border-s);margin-top:3px}
  .nav-cta-mobile .btn{width:100%;justify-content:center;border-radius:10px;padding:13px}
  .section{padding:56px 0}
  .hero-inner{padding:48px 0 36px}
  .hero-stats{grid-template-columns:repeat(2,1fr)}
  .hstat{padding:20px 18px}
  .hstat::after{display:none}
  .hstat-num{font-size:1.7rem}
  .about-float{right:0;bottom:-14px}
  .t-grid{grid-template-columns:1fr}
  .t-header{margin-bottom:36px}
  .portfolio-grid{grid-template-columns:1fr}
  .blog-grid{grid-template-columns:1fr}
  .port-head{grid-template-columns:1fr;gap:20px}
  .filter-bar{justify-content:flex-start}
  .team-grid{grid-template-columns:repeat(2,1fr)}
  .counters-grid{grid-template-columns:repeat(2,1fr)}
  .counter-item{padding:32px 14px}
  .counter-item:not(:last-child)::after{top:16px;height:calc(100% - 32px)}
  .counter-num{font-size:1.8rem}
  .stats-row,.about-nums{grid-template-columns:repeat(2,1fr)}
  .pricing-grid{grid-template-columns:1fr}
  .values-grid{grid-template-columns:1fr 1fr}
  .process-steps::before{display:none}
  .form-row{grid-template-columns:1fr}
  .form-card{padding:22px 18px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:28px}
  .footer-bottom{flex-direction:column;text-align:center;gap:8px}
  .cta-inner{padding:36px 24px;border-radius:18px}
  .cta-actions{flex-direction:column}
  .cta-actions .btn{justify-content:center}
  .trusted-logos{gap:28px}
  .svc-row{grid-template-columns:36px 1fr auto;gap:12px;padding:22px 0}
}

@media(max-width:480px){
  .section{padding:44px 0}
  .hero h1{font-size:2.2rem;letter-spacing:-.04em}
  .hero-stats{grid-template-columns:1fr 1fr}
  h2{font-size:1.6rem}
  .t-grid{grid-template-columns:1fr}
  .team-grid{grid-template-columns:1fr 1fr}
  .values-grid,.footer-grid,.process-steps{grid-template-columns:1fr}
  .filter-btn{padding:6px 12px;font-size:.76rem}
  .counters-grid{grid-template-columns:1fr 1fr}
  .newsletter-form{flex-direction:column}
  .newsletter-form button{width:100%}
  .footer{padding:40px 0 0}
  .page-hero{padding:96px 0 36px}
  .about-float{position:static;margin-top:14px;border-radius:12px}
  .svc-row{grid-template-columns:1fr;gap:8px}
  .svc-num{display:none}
}
.team-photo img{width:100%;height:100%;object-fit:cover;object-position:top center;display:block}
.nav-logo img{height:38px;width:auto;display:block}