/* ============================================================
   EDOT MODERN AVATAR v2 – Premium Professional Design
   ============================================================ */

:root {
  --primary: #2563eb;
  --primary-dark: #1d4ed8;
  --primary-light: #dbeafe;
  --primary-50: #eff6ff;
  --accent: #06b6d4;
  --violet: #7c3aed;
  --violet-light: #ede9fe;
  --amber: #f59e0b;
  --rose: #f43f5e;
  --emerald: #10b981;
  --dark: #0f172a;
  --g900: #1e293b; --g800: #1e293b; --g700: #334155; --g600: #475569;
  --g500: #64748b; --g400: #94a3b8; --g300: #cbd5e1; --g200: #e2e8f0;
  --g100: #f1f5f9; --g50: #f8fafc; --white: #fff;
  --shadow-sm: 0 1px 2px rgba(0,0,0,.05);
  --shadow: 0 1px 3px rgba(0,0,0,.1),0 1px 2px rgba(0,0,0,.06);
  --shadow-md: 0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -2px rgba(0,0,0,.1);
  --shadow-lg: 0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -4px rgba(0,0,0,.1);
  --shadow-xl: 0 20px 25px -5px rgba(0,0,0,.1),0 8px 10px -6px rgba(0,0,0,.1);
  --shadow-glow: 0 0 40px rgba(37,99,235,.15);
  --r-sm: 8px; --r: 12px; --r-md: 16px; --r-lg: 20px; --r-xl: 28px; --r-full: 9999px;
  --ease: cubic-bezier(.4,0,.2,1);
  --fast: .15s var(--ease); --med: .3s var(--ease); --slow: .5s var(--ease);
  --container: min(1200px,100% - 2rem);
  --hdr: 72px;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{margin:0;font-family:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;font-size:1rem;line-height:1.65;color:var(--g700);background:var(--white);overflow-x:hidden}
::selection{background:var(--primary);color:var(--white)}
img{max-width:100%;height:auto}
a{color:var(--primary);text-decoration:none;transition:color var(--fast)}
a:hover{color:var(--primary-dark)}
h1,h2,h3,h4{font-family:'Space Grotesk','Inter',sans-serif;color:var(--g900);letter-spacing:-.02em}
.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 1rem}

/* Preloader */
.preloader{position:fixed;inset:0;z-index:99999;display:flex;align-items:center;justify-content:center;background:var(--white);transition:opacity .5s,visibility .5s}
.preloader.hidden{opacity:0;visibility:hidden;pointer-events:none}
.preloader-inner{text-align:center}
.preloader-ring{width:52px;height:52px;margin:0 auto 1rem;position:relative;border-radius:50%;border:3px solid var(--g200);border-top-color:var(--primary);animation:spin .7s linear infinite}
.preloader-ring-dot{position:absolute;top:-3px;left:50%;width:10px;height:10px;margin-left:-5px;background:var(--primary);border-radius:50%;box-shadow:0 0 8px rgba(37,99,235,.5)}
@keyframes spin{to{transform:rotate(360deg)}}
.preloader-text{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:1.15rem;background:linear-gradient(135deg,var(--primary),var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

/* Skip */
.skip-link{position:absolute;top:-100px;left:1rem;z-index:10000;padding:.75rem 1.25rem;background:var(--primary);color:var(--white);font-weight:600;border-radius:var(--r-sm);transition:top var(--med)}
.skip-link:focus{top:1rem}

/* ========== HEADER ========== */
.header{position:fixed;top:0;left:0;right:0;height:var(--hdr);z-index:1000;background:rgba(255,255,255,.8);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid transparent;transition:box-shadow var(--med),border-color var(--med)}
.header.header-scrolled{box-shadow:0 1px 12px rgba(0,0,0,.06);border-bottom-color:var(--g200)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:100%}

.site-logo{display:flex;align-items:center;gap:.65rem}
.brand-mark{width:44px;height:40px;display:block;border-radius:var(--r-sm);object-fit:contain;background:linear-gradient(135deg,var(--primary),var(--accent));padding:4px;box-shadow:0 2px 8px rgba(37,99,235,.18);transition:transform var(--fast)}
.site-logo:hover .brand-mark{transform:scale(1.05)}
.brand-text{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:1.1rem;color:var(--g900);letter-spacing:-.02em}
.brand-light{font-weight:500;color:var(--g500)}

.menu-toggle{display:none;flex-direction:column;gap:5px;padding:8px;background:none;border:none;cursor:pointer;border-radius:var(--r-sm)}
.menu-toggle span{width:22px;height:2px;background:var(--g700);border-radius:2px;transition:var(--med)}

.primary-menu{list-style:none;margin:0;padding:0;display:flex;align-items:center;gap:2px}
.primary-menu>li{position:relative}
.primary-menu>li>a{display:block;padding:8px 12px;font-weight:600;font-size:.82rem;color:var(--g600);border-radius:var(--r-sm);transition:color var(--fast),background var(--fast)}
.primary-menu>li>a:hover,.primary-menu>li.current>a{color:var(--primary);background:var(--primary-50)}

.sub-menu{position:absolute;top:100%;left:0;min-width:200px;padding:6px 0;margin:6px 0 0;list-style:none;background:var(--white);border:1px solid var(--g200);border-radius:var(--r);box-shadow:var(--shadow-lg);opacity:0;visibility:hidden;transform:translateY(-6px);transition:opacity var(--med),visibility var(--med),transform var(--med)}
.primary-menu>li:hover .sub-menu{opacity:1;visibility:visible;transform:translateY(0)}
.sub-menu a{display:block;padding:10px 18px;font-size:.85rem;color:var(--g600);transition:background var(--fast),color var(--fast),padding-left var(--fast)}
.sub-menu a:hover{background:var(--g50);color:var(--primary);padding-left:22px}

/* ========== BUTTONS ========== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:11px 24px;font-family:inherit;font-weight:600;font-size:.875rem;border-radius:var(--r);border:none;cursor:pointer;transition:all var(--med);text-decoration:none;line-height:1.4}
.btn-lg{padding:14px 32px;font-size:.9375rem}
.btn-sm{padding:8px 18px;font-size:.8rem}
.btn-block{width:100%}
.btn-primary{background:linear-gradient(135deg,var(--primary),var(--accent));color:var(--white);box-shadow:0 4px 14px rgba(37,99,235,.3)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(37,99,235,.35);color:var(--white)}
.btn-glass{background:rgba(255,255,255,.15);backdrop-filter:blur(8px);border:1.5px solid rgba(37,99,235,.25);color:var(--primary)}
.btn-glass:hover{background:var(--primary);color:var(--white);border-color:var(--primary);transform:translateY(-2px)}
.btn-white{background:var(--white);color:var(--g900);box-shadow:var(--shadow-md)}
.btn-white:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);color:var(--g900)}
@keyframes edotPulse{0%,100%{box-shadow:0 4px 14px rgba(37,99,235,.3)}50%{box-shadow:0 4px 24px rgba(37,99,235,.5)}}
.edot-pulse{animation:edotPulse 2.5s infinite}

/* ========== HERO ========== */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;padding:calc(var(--hdr) + 3rem) 0 4rem;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-gradient{position:absolute;inset:0;background:linear-gradient(160deg,var(--primary-50) 0%,rgba(6,182,212,.06) 35%,rgba(124,58,237,.04) 70%,var(--white) 100%)}
.hero-mesh{position:absolute;inset:0;background-image:radial-gradient(circle at 1px 1px,var(--g300) .5px,transparent 0);background-size:32px 32px;opacity:.3}
.hero-shapes .shape{position:absolute;border-radius:50%;filter:blur(80px);opacity:.35}
.shape-1{width:420px;height:420px;background:var(--primary);top:-120px;right:-80px}
.shape-2{width:280px;height:280px;background:var(--accent);bottom:10%;left:-60px}
.shape-3{width:200px;height:200px;background:var(--violet);top:55%;right:18%}
.shape-4{width:160px;height:160px;background:var(--amber);bottom:20%;right:40%;opacity:.2}

.hero-inner{position:relative;z-index:1;display:grid;grid-template-columns:1.1fr .9fr;gap:3rem;align-items:center}
.hero-badge-wrap{margin-bottom:1.25rem}
.hero-badge{display:inline-flex;align-items:center;gap:.5rem;padding:6px 14px;font-size:.78rem;font-weight:600;color:var(--violet);background:var(--violet-light);border-radius:var(--r-full);border:1px solid rgba(124,58,237,.15)}
.badge-dot{width:6px;height:6px;border-radius:50%;background:var(--emerald);animation:dotBlink 1.5s infinite}
@keyframes dotBlink{0%,100%{opacity:1}50%{opacity:.3}}

.hero-title{margin:0 0 1.25rem;font-size:clamp(2.25rem,4.5vw,3.5rem);font-weight:800;line-height:1.15;letter-spacing:-.035em;color:var(--dark)}
.gradient-text{background:linear-gradient(135deg,var(--primary),var(--accent),var(--violet));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-desc{margin:0 0 2rem;font-size:1.05rem;color:var(--g500);max-width:500px;line-height:1.7}
.hero-cta{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:2.5rem}

/* Hero Stats */
.hero-stats{display:flex;align-items:center;gap:1.5rem;padding:1.25rem 1.5rem;background:rgba(255,255,255,.7);backdrop-filter:blur(12px);border:1px solid var(--g200);border-radius:var(--r-md);max-width:420px}
.stat{text-align:center;flex:1}
.stat-number{font-family:'Space Grotesk',sans-serif;font-size:1.75rem;font-weight:800;color:var(--primary);line-height:1}
.stat-suffix{font-family:'Space Grotesk',sans-serif;font-size:1rem;font-weight:700;color:var(--accent)}
.stat-label{display:block;margin-top:.25rem;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--g500)}
.stat-divider{width:1px;height:36px;background:var(--g200)}

/* Hero Cards */
.hero-visual{display:flex;justify-content:center;align-items:center}
.hero-card-stack{position:relative;width:280px;height:320px}
.hero-card{background:var(--white);border-radius:var(--r-lg);box-shadow:var(--shadow-xl);border:1px solid var(--g200);padding:2rem;transition:transform var(--med),box-shadow var(--med)}
.hero-card-back{position:absolute;top:0;right:-16px;width:240px;height:120px;display:flex;align-items:center;gap:1rem;padding:1.25rem;transform:rotate(6deg);z-index:0;opacity:.8;font-size:.85rem;font-weight:600;color:var(--g600)}
.hero-card-back .hc-icon{font-size:1.5rem}
.hero-card-front{position:relative;z-index:1;text-align:center;margin-top:50px}
.hero-card-front .hc-icon{font-size:2.5rem;margin-bottom:.75rem}
.hero-card-front h3{margin:0 0 .5rem;font-size:1.15rem}
.hero-card-front p{margin:0 0 1rem;font-size:.85rem;color:var(--g500)}
.hero-card-stack:hover .hero-card-front{transform:translateY(-6px);box-shadow:var(--shadow-glow)}

/* ========== SECTIONS ========== */
.section{padding:5.5rem 0}
.section-header{text-align:center;max-width:600px;margin:0 auto 3rem}
.section-header.light .section-title,.section-header.light .section-desc{color:var(--white)}
.section-header.light .section-badge{background:rgba(255,255,255,.15);color:var(--white);border-color:rgba(255,255,255,.2)}
.section-badge{display:inline-block;padding:5px 14px;margin-bottom:.75rem;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--primary);background:var(--primary-50);border:1px solid var(--primary-light);border-radius:var(--r-full)}
.section-title{margin:0 0 .75rem;font-size:clamp(1.75rem,3vw,2.25rem);font-weight:800;letter-spacing:-.025em}
.section-desc{margin:0;font-size:1rem;color:var(--g500);line-height:1.7}
.sub-heading{text-align:center;font-size:1.15rem;font-weight:700;color:var(--g900);margin:0 0 1.5rem}

/* ========== RIBBON ========== */
.ribbon{padding:2.25rem 0;position:relative;overflow:hidden}
.ribbon-gradient{background:linear-gradient(135deg,var(--primary),#1e3a8a)}
.ribbon-violet{background:linear-gradient(135deg,var(--violet),var(--rose))}
.ribbon-inner{display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap}
.ribbon-right{justify-content:flex-end}
.ribbon-text{margin:0;font-size:1.1rem;font-weight:600;color:var(--white);max-width:560px}

/* ========== MEGA MENU ========== */
.mega-menu{position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(-8px);width:680px;padding:1.25rem;background:var(--white);border:1px solid var(--g200);border-radius:var(--r-md);box-shadow:var(--shadow-xl);opacity:0;visibility:hidden;transition:opacity var(--med),visibility var(--med),transform var(--med);z-index:100}
.primary-menu>li:hover>.mega-menu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.mega-inner{display:grid;grid-template-columns:1fr 1fr .85fr;gap:1.25rem}
.mega-heading{margin:0 0 .65rem;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--g400)}
.mega-item{display:flex;align-items:flex-start;gap:.65rem;padding:.6rem .65rem;border-radius:var(--r-sm);transition:background var(--fast);text-decoration:none}
.mega-item:hover{background:var(--g50)}
.mi-icon{width:36px;height:36px;flex-shrink:0;display:flex;align-items:center;justify-content:center;border-radius:var(--r-sm)}
.mi-blue{background:var(--primary-light);color:var(--primary)}
.mi-violet{background:var(--violet-light);color:var(--violet)}
.mi-emerald{background:#d1fae5;color:var(--emerald)}
.mi-amber{background:#fef3c7;color:#d97706}
.mi-rose{background:#ffe4e6;color:var(--rose)}
.mi-cyan{background:#cffafe;color:#0891b2}
.mega-item strong{display:block;font-size:.85rem;color:var(--g900);line-height:1.3}
.mega-item small{display:block;font-size:.75rem;color:var(--g500);margin-top:1px}

.mega-promo-card{background:linear-gradient(135deg,var(--primary),var(--violet));border-radius:var(--r);padding:1.25rem;color:var(--white);position:relative;overflow:hidden}
.mpc-badge{position:absolute;top:12px;right:12px;padding:3px 10px;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;background:var(--amber);color:var(--dark);border-radius:var(--r-full)}
.mega-promo-card h4{margin:0 0 .4rem;font-size:1rem;color:var(--white)}
.mega-promo-card p{margin:0 0 .75rem;font-size:.8rem;opacity:.9;line-height:1.5}
.mega-promo-card .btn{background:var(--white);color:var(--primary)}

/* ========== PRODUCTS ========== */
.products{background:var(--g50);overflow:hidden}
.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1.5rem}
.product-card{background:var(--white);border-radius:var(--r-md);border:1px solid var(--g200);overflow:hidden;transition:all var(--med)}
.product-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-xl);border-color:transparent}

/* Visual / mockup area */
.pc-visual{position:relative;padding:1.5rem 1.5rem 0;overflow:hidden}
.pc-blue{background:linear-gradient(135deg,#dbeafe,#bfdbfe)}
.pc-violet{background:linear-gradient(135deg,#ede9fe,#ddd6fe)}
.pc-emerald{background:linear-gradient(135deg,#d1fae5,#a7f3d0)}
.pc-amber{background:linear-gradient(135deg,#fef3c7,#fde68a)}
.pc-rose{background:linear-gradient(135deg,#ffe4e6,#fecdd3)}
.pc-cyan{background:linear-gradient(135deg,#cffafe,#a5f3fc)}

/* Mini mockup browser */
.pc-mockup{background:var(--white);border-radius:var(--r-sm) var(--r-sm) 0 0;box-shadow:0 -2px 12px rgba(0,0,0,.06);overflow:hidden;transform:translateY(8px);transition:transform var(--med)}
.product-card:hover .pc-mockup{transform:translateY(0)}
.pc-bar{display:flex;gap:4px;padding:8px 10px;background:var(--g100);border-bottom:1px solid var(--g200)}
.pc-bar span{width:8px;height:8px;border-radius:50%;background:var(--g300)}
.pc-bar span:first-child{background:#f87171}
.pc-bar span:nth-child(2){background:#fbbf24}
.pc-bar span:nth-child(3){background:#34d399}
.pc-screen{padding:.75rem;display:grid;grid-template-columns:1fr 1fr;gap:.5rem;min-height:90px}

/* Placeholder widgets inside mockup */
.pc-widget{border-radius:4px;min-height:32px}
.pw1{background:var(--primary-light);grid-column:span 2;min-height:24px}
.pw2{background:#dbeafe}
.pw3{background:#bfdbfe}
.pw4{background:var(--violet-light);grid-column:span 2;min-height:24px}
.pw5{background:#ddd6fe}
.pw6{background:#c4b5fd}
.pw7{background:#d1fae5;grid-column:span 2;min-height:28px}
.pw8{background:#a7f3d0;grid-column:span 2;min-height:18px}
.pw9{background:#fef3c7;grid-column:span 2;min-height:24px}
.pw10{background:#fde68a}
.pw11{background:#fcd34d}
.pw12{background:#ffe4e6;grid-column:span 2;min-height:28px}
.pw13{background:#fecdd3;grid-column:span 2;min-height:18px}
.pw14{background:#cffafe;grid-column:span 2;min-height:24px}
.pw15{background:#a5f3fc}
.pw16{background:#67e8f9}

.pc-badge-float{position:absolute;top:12px;right:12px;padding:4px 12px;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;background:var(--white);color:var(--primary);border-radius:var(--r-full);box-shadow:var(--shadow)}

/* Product body */
.pc-body{padding:1.5rem}
.pc-tag-row{display:flex;gap:.4rem;margin-bottom:.65rem;flex-wrap:wrap}
.pc-tag{padding:3px 10px;font-size:.68rem;font-weight:700;border-radius:var(--r-full);text-transform:uppercase;letter-spacing:.04em}
.tag-blue{background:var(--primary-light);color:var(--primary)}
.tag-violet{background:var(--violet-light);color:var(--violet)}
.tag-emerald{background:#d1fae5;color:#059669}
.tag-amber{background:#fef3c7;color:#d97706}
.tag-rose{background:#ffe4e6;color:#e11d48}
.tag-cyan{background:#cffafe;color:#0891b2}
.product-card h3{margin:0 0 .5rem;font-size:1.15rem}
.product-card>* p,.pc-body>p{margin:0 0 .75rem;font-size:.88rem;color:var(--g500);line-height:1.65}

.pc-features{margin:0 0 1rem;padding:0;list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:.3rem .75rem}
.pc-features li{font-size:.8rem;color:var(--g600);padding-left:1.1rem;position:relative;line-height:1.5}
.pc-features li::before{content:'';position:absolute;left:0;top:6px;width:6px;height:6px;border-radius:50%;background:var(--emerald)}

/* ========== FOCUS ========== */
.focus{background:var(--white)}
.focus-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.25rem}
.focus-card{text-align:center;padding:2rem 1.5rem;border-radius:var(--r-md);border:1px solid var(--g200);background:var(--g50);transition:all var(--med)}
.focus-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:var(--primary-light);background:var(--white)}
.focus-icon{width:52px;height:52px;margin:0 auto 1rem;display:flex;align-items:center;justify-content:center;border-radius:var(--r);background:linear-gradient(135deg,var(--primary),var(--accent));color:var(--white)}
.focus-icon svg{width:26px;height:26px}
.focus-card h3{margin:0 0 .5rem;font-size:1.05rem}
.focus-card p{margin:0;font-size:.88rem;color:var(--g500)}

/* ========== ABOUT ========== */
.about{background:var(--g50)}

/* Story block */
.about-story{display:grid;grid-template-columns:1.4fr .6fr;gap:2rem;margin-bottom:2rem;align-items:start}
.as-main h3{margin:0 0 .75rem;font-size:1.25rem;color:var(--g900)}
.as-main p{margin:0 0 1rem;font-size:.92rem;color:var(--g600);line-height:1.7}
.as-vision-card{background:linear-gradient(135deg,var(--primary),var(--accent));color:var(--white);padding:1.75rem;border-radius:var(--r-md);box-shadow:0 8px 24px rgba(37,99,235,.2)}
.as-vision-card h4{margin:0 0 .5rem;font-size:1rem;color:var(--white)}
.as-vision-card p{margin:0;font-size:.88rem;line-height:1.65;opacity:.95}

/* Leadership */
.leadership-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1.25rem}
.leader-card{display:flex;align-items:flex-start;gap:1rem;padding:1.25rem;background:var(--white);border:1px solid var(--g200);border-radius:var(--r-md);transition:all var(--med)}
.leader-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:transparent}
.lc-avatar{flex-shrink:0}
.lc-initials{width:52px;height:52px;border-radius:50%;color:var(--white);font-family:'Space Grotesk',sans-serif;font-size:1.1rem;font-weight:700;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px rgba(37,99,235,.2)}
.leader-card h4{margin:0 0 .15rem;font-size:.95rem;color:var(--g900)}
.lc-role{margin:0 0 .4rem;font-size:.75rem;font-weight:700;color:var(--primary);text-transform:uppercase;letter-spacing:.05em}
.lc-bio{margin:0;font-size:.8rem;color:var(--g500);line-height:1.55}

.about-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.25rem;margin-bottom:3rem}
.about-card{background:var(--white);padding:1.75rem;border-radius:var(--r-md);border:1px solid var(--g200);transition:all var(--med)}
.about-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--primary-light)}
.about-icon{font-size:2rem;margin-bottom:.75rem}
.about-card h3{margin:0 0 .5rem;font-size:1.1rem}
.about-card p{margin:0;font-size:.9rem;color:var(--g500)}

/* Skills */
.skills-section{margin-bottom:3rem}
.skills-grid{display:flex;justify-content:center;flex-wrap:wrap;gap:2.5rem}
.skill-item{text-align:center}
.skill-circle{position:relative;width:100px;height:100px;margin:0 auto .75rem}
.skill-circle svg{width:100%;height:100%;transform:rotate(-90deg)}
.skill-bg{fill:none;stroke:var(--g200);stroke-width:5}
.skill-fill{fill:none;stroke:url(#skillGrad);stroke-width:5;stroke-linecap:round;stroke-dasharray:283;stroke-dashoffset:283;transition:stroke-dashoffset 1.5s var(--ease)}
.skill-circle.animated .skill-fill{stroke-dashoffset:calc(283 - (283 * var(--percent)) / 100)}
.skill-value{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:'Space Grotesk',sans-serif;font-size:1.25rem;font-weight:800;color:var(--primary)}
.skill-label{margin:0;font-size:.82rem;font-weight:600;color:var(--g600)}

/* Clients */
.clients-grid{display:flex;justify-content:center;flex-wrap:wrap;gap:1.25rem}
.client-logo{width:120px;height:54px;display:flex;align-items:center;justify-content:center;background:var(--white);border:1px solid var(--g200);border-radius:var(--r-sm);font-weight:700;color:var(--g400);font-size:.78rem;transition:all var(--med)}
.client-logo:hover{border-color:var(--primary-light);box-shadow:var(--shadow)}

/* ========== SERVICES ========== */
.services{background:linear-gradient(160deg,var(--primary),var(--primary-dark),#1e3a8a);color:var(--white)}
.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.25rem}
.service-card{background:rgba(255,255,255,.08);backdrop-filter:blur(8px);padding:2rem;border-radius:var(--r-md);border:1px solid rgba(255,255,255,.12);transition:all var(--med)}
.service-card:hover{background:rgba(255,255,255,.16);transform:translateY(-4px)}
.sc-icon{font-size:2rem;margin-bottom:.75rem}
.service-card h3{margin:0 0 .5rem;font-size:1.1rem;color:var(--white)}
.service-card p{margin:0 0 .75rem;font-size:.88rem;color:rgba(255,255,255,.8)}
.svc-link{display:inline-flex;align-items:center;gap:.3rem;font-size:.82rem;font-weight:600;color:rgba(255,255,255,.7);transition:color var(--fast),gap var(--fast)}
.svc-link:hover{color:var(--white);gap:.5rem}

/* ========== AI DIALER ========== */
.ai-dialer{background:var(--white)}
.ai-dialer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.25rem;margin-bottom:2.5rem}
.ai-dialer-feature{background:var(--g50);padding:2rem;border-radius:var(--r-md);border:1px solid var(--g200);transition:all var(--med)}
.ai-dialer-feature:hover{transform:translateY(-4px);box-shadow:0 12px 24px rgba(37,99,235,.1);border-color:var(--primary-light);background:var(--white)}
.adf-icon{font-size:2.25rem;margin-bottom:.75rem}
.ai-dialer-feature h3{margin:0 0 .5rem;font-size:1.1rem}
.ai-dialer-feature p{margin:0;font-size:.9rem;color:var(--g500)}
/* Deployment Models */
.models-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:1.25rem}
.model-card{border-radius:var(--r-md);border:1px solid var(--g200);background:var(--white);overflow:hidden;transition:all var(--med)}
.model-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-xl);border-color:transparent}
.mc-header{display:flex;align-items:center;gap:.75rem;padding:1.25rem;color:var(--white)}
.mc-blue{background:linear-gradient(135deg,var(--primary),var(--accent))}
.mc-emerald{background:linear-gradient(135deg,var(--emerald),#34d399)}
.mc-violet{background:linear-gradient(135deg,var(--violet),#a78bfa)}
.mc-amber{background:linear-gradient(135deg,#d97706,var(--amber))}
.mc-icon{width:52px;height:52px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.2);border-radius:var(--r);border:1px solid rgba(255,255,255,.25)}
.mc-header h4{margin:0;font-size:1.1rem;color:var(--white)}
.mc-body{padding:1.25rem}
.mc-body>p{margin:0 0 1rem;font-size:.85rem;color:var(--g600);line-height:1.65}
.mc-highlights{margin:0;padding:0;list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:.3rem .75rem}
.mc-highlights li{font-size:.78rem;color:var(--g600);padding-left:1rem;position:relative;line-height:1.5}
.mc-highlights li::before{content:'';position:absolute;left:0;top:5px;width:6px;height:6px;border-radius:50%;background:var(--emerald)}

.ai-dialer-cta{text-align:center;padding:2rem;background:linear-gradient(135deg,var(--primary-50),rgba(6,182,212,.08));border:1px solid var(--primary-light);border-radius:var(--r-lg)}
.ai-dialer-cta p{margin:0 0 1rem;color:var(--g600)}

/* ========== SOLUTIONS ========== */
.solutions{background:var(--dark);color:var(--g300)}
.solutions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.25rem;max-width:900px;margin:0 auto}
.solution-card{padding:2rem;border-radius:var(--r-md);border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.03);transition:all var(--med)}
.solution-card:hover{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.15);transform:translateY(-4px)}
.sol-number{font-family:'Space Grotesk',sans-serif;font-size:2.5rem;font-weight:800;background:linear-gradient(135deg,var(--primary),var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;margin-bottom:.75rem}
.solution-card h3{margin:0 0 .35rem;font-size:1.1rem;color:var(--white)}
.solution-card p{margin:0;font-size:.9rem;color:var(--g400)}

/* ========== TEAM ========== */
.team{background:var(--g50)}
.team-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.25rem}
.team-card{text-align:center;padding:2rem 1.5rem;border-radius:var(--r-md);border:1px solid var(--g200);background:var(--white);transition:all var(--med)}
.team-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.team-avatar{margin-bottom:1rem}
.team-initials{width:72px;height:72px;margin:0 auto;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--violet));color:var(--white);font-family:'Space Grotesk',sans-serif;font-size:1.4rem;font-weight:700;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 14px rgba(37,99,235,.25)}
.team-card h3{margin:0 0 .25rem;font-size:1.05rem}
.team-role{margin:0 0 .5rem;font-size:.78rem;font-weight:700;color:var(--primary);text-transform:uppercase;letter-spacing:.06em}
.team-bio{margin:0 0 1rem;font-size:.85rem;color:var(--g500)}
.team-social{display:flex;justify-content:center;gap:.4rem}
.team-social a{width:32px;height:32px;border-radius:50%;font-size:.65rem;font-weight:700;background:var(--g100);color:var(--g500);display:flex;align-items:center;justify-content:center;transition:all var(--fast)}
.team-social a:hover{background:var(--primary);color:var(--white);transform:scale(1.1)}

/* ========== TESTIMONIALS ========== */
.testimonials{background:var(--white)}
.testimonials-slider{max-width:680px;margin:0 auto}
.testimonials-track{position:relative;min-height:220px}
.testimonial-card{position:absolute;inset:0;opacity:0;transform:translateX(30px);transition:opacity .5s var(--ease),transform .5s var(--ease);pointer-events:none}
.testimonial-card.active{position:relative;opacity:1;transform:translateX(0);pointer-events:auto}
.tc-stars{color:var(--amber);font-size:1rem;margin-bottom:.75rem;letter-spacing:2px}
.testimonial-card blockquote{margin:0 0 1.25rem;padding:0;border:none;font-style:italic;font-size:1.05rem;line-height:1.7;color:var(--g600);position:relative;padding-left:1.75rem}
.testimonial-card blockquote::before{content:'\201C';position:absolute;left:0;top:-6px;font-size:2.5rem;color:var(--primary);opacity:.25;font-family:Georgia,serif;line-height:1}
.testimonial-author{display:flex;align-items:center;gap:.75rem}
.ta-avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--violet));color:var(--white);font-weight:700;font-size:.8rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.testimonial-author strong{display:block;font-size:.9rem;color:var(--g900)}
.testimonial-author span{font-size:.8rem;color:var(--g500)}

.testimonials-nav{display:flex;align-items:center;justify-content:center;gap:.75rem;margin-top:1.25rem}
.t-prev,.t-next{width:38px;height:38px;border:1px solid var(--g300);border-radius:50%;background:var(--white);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--g500);transition:all var(--fast)}
.t-prev:hover,.t-next:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-50)}
.t-dots{display:flex;gap:6px}
.dot{width:8px;height:8px;border-radius:50%;border:none;background:var(--g300);cursor:pointer;padding:0;transition:all var(--fast)}
.dot.active{background:var(--primary);width:20px;border-radius:4px}

/* ========== NEWS ========== */
.news{background:var(--g50)}
.news-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.25rem}
.news-card{background:var(--white);border-radius:var(--r-md);border:1px solid var(--g200);overflow:hidden;transition:all var(--med)}
.news-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.news-thumb{height:170px;display:flex;align-items:center;justify-content:center;font-family:'Space Grotesk',sans-serif;font-size:2rem;font-weight:800;color:var(--white)}
.t1{background:linear-gradient(135deg,var(--primary),var(--accent))}
.t2{background:linear-gradient(135deg,var(--violet),var(--primary))}
.t3{background:linear-gradient(135deg,var(--amber),var(--rose))}
.news-body{padding:1.25rem 1.5rem}
.news-date{font-size:.72rem;font-weight:700;color:var(--g400);text-transform:uppercase;letter-spacing:.06em}
.news-body h3{margin:.4rem 0;font-size:1.05rem;line-height:1.4}
.news-body h3 a{color:var(--g900)}
.news-body h3 a:hover{color:var(--primary)}
.news-body>p{margin:0;font-size:.85rem;color:var(--g500)}

/* ========== CONTACT ========== */
.contact{background:var(--white)}

/* Quick Bar */
.contact-quick-bar{display:flex;align-items:center;justify-content:center;gap:1.5rem;flex-wrap:wrap;padding:1.25rem 2rem;background:var(--g50);border:1px solid var(--g200);border-radius:var(--r-md);max-width:700px;margin:0 auto}
.cqb-item{display:flex;align-items:center;gap:.65rem;font-size:.88rem;color:var(--g600)}
.cqb-item svg{flex-shrink:0;color:var(--primary)}
.cqb-item a{color:var(--primary);font-weight:600;display:block;line-height:1.5}
.cqb-item a:hover{color:var(--primary-dark)}
.cqb-divider{width:1px;height:32px;background:var(--g300)}

/* Office Cards */
.offices-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem}
.office-card{border-radius:var(--r-md);border:1px solid var(--g200);background:var(--white);overflow:hidden;transition:all var(--med)}
.office-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:transparent}
.office-ho{border-width:2px;border-color:var(--primary-light)}

.oc-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;color:var(--white);position:relative}
.oc-blue{background:linear-gradient(135deg,var(--primary),var(--accent))}
.oc-violet{background:linear-gradient(135deg,var(--violet),#a78bfa)}
.oc-emerald{background:linear-gradient(135deg,var(--emerald),#34d399)}
.oc-amber{background:linear-gradient(135deg,#d97706,var(--amber))}
.oc-rose{background:linear-gradient(135deg,var(--rose),#fb7185)}

.oc-badge{padding:3px 10px;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;background:rgba(255,255,255,.25);border:1px solid rgba(255,255,255,.3);border-radius:var(--r-full);color:var(--white)}

.oc-body{padding:1.25rem}
.oc-body h4{margin:0 0 .5rem;font-size:1.05rem;color:var(--g900)}
.oc-addr{margin:0 0 .75rem;font-size:.82rem;color:var(--g500);line-height:1.6}
.oc-contact{display:flex;flex-direction:column;gap:.35rem}
.oc-phone{display:inline-flex;align-items:center;gap:.4rem;font-size:.82rem;font-weight:600;color:var(--g700);transition:color var(--fast)}
.oc-phone:hover{color:var(--primary)}
.oc-phone svg{flex-shrink:0;color:var(--primary)}
.oc-email{font-size:.82rem;color:var(--primary);font-weight:500}
.oc-email:hover{color:var(--primary-dark)}

/* Contact Form */
.contact-form-wrap{max-width:720px;margin:0 auto}
.contact-form{background:var(--g50);padding:2rem;border-radius:var(--r-md);border:1px solid var(--g200)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-group{margin-bottom:1rem}
.contact-form label{display:block;margin-bottom:.4rem;font-weight:600;font-size:.82rem;color:var(--g700)}
.contact-form input,.contact-form textarea{width:100%;padding:11px 14px;font-family:inherit;font-size:.9rem;border:1.5px solid var(--g300);border-radius:var(--r-sm);background:var(--white);transition:border-color var(--fast),box-shadow var(--fast)}
.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(37,99,235,.12)}
.contact-form textarea{resize:vertical;min-height:120px}

/* ========== FOOTER ========== */
.site-footer{position:relative;background:var(--dark);color:var(--g400);padding:3rem 0 2rem}
.footer-top-bar{position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--primary),var(--accent),var(--violet),var(--emerald))}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:2rem;margin-bottom:2rem}
.footer-logo{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}
.footer-logo .brand-mark{width:40px;height:36px;background:linear-gradient(135deg,var(--primary),var(--violet));padding:3px;box-shadow:0 2px 8px rgba(37,99,235,.25)}
.footer-logo .brand-text{font-size:.95rem;color:var(--white)}
.footer-brand p{font-size:.85rem;color:var(--g500);margin:0;line-height:1.65}
.footer-col h4{margin:0 0 1rem;font-size:.9rem;font-weight:700;color:var(--white);text-transform:uppercase;letter-spacing:.06em}
.footer-col ul{margin:0;padding:0;list-style:none;font-size:.85rem}
.footer-col ul li{padding:3px 0}
.footer-col a{color:var(--g400)}
.footer-col a:hover{color:var(--white)}

.social-links{display:flex;flex-wrap:wrap;gap:.4rem}
.social-icon{width:34px;height:34px;border-radius:50%;font-size:.65rem;font-weight:700;display:flex;align-items:center;justify-content:center;color:var(--white);transition:transform var(--fast),filter var(--fast)}
.social-icon:hover{transform:scale(1.15);color:var(--white)}
.si-facebook{background:#1877f2}
.si-twitter{background:#1da1f2}
.si-linkedin{background:#0a66c2}
.si-instagram{background:linear-gradient(135deg,#f58529,#dd2a7b,#8134af)}
.si-behance{background:#1769ff}
.si-dribbble{background:#ea4c89}

.footer-bottom{padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.08);display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;font-size:.8rem;color:var(--g500)}
.footer-bottom p{margin:0}
.footer-bottom a{color:var(--accent)}
.footer-bottom a:hover{color:var(--white)}

/* ========== CALL BUTTON ========== */
.call-button{position:fixed;bottom:96px;right:22px;z-index:999;display:flex;align-items:center;gap:6px;padding:14px 18px;background:linear-gradient(135deg,var(--emerald),#059669);color:var(--white);font-weight:600;font-size:.85rem;border-radius:var(--r-full);box-shadow:0 4px 20px rgba(16,185,129,.4);transition:transform var(--med),box-shadow var(--med);animation:callPulse 2s infinite}
@keyframes callPulse{0%,100%{box-shadow:0 4px 20px rgba(16,185,129,.4)}50%{box-shadow:0 4px 32px rgba(16,185,129,.6)}}
.call-button:hover{transform:scale(1.06);color:var(--white)}
.call-button svg{flex-shrink:0}

/* ========== BACK TO TOP ========== */
.back-to-top{position:fixed;bottom:22px;right:22px;z-index:998;width:44px;height:44px;display:flex;align-items:center;justify-content:center;padding:0;background:linear-gradient(135deg,var(--primary),var(--accent));color:var(--white);border:none;border-radius:50%;cursor:pointer;box-shadow:0 4px 14px rgba(37,99,235,.35);opacity:0;visibility:hidden;transform:translateY(16px);transition:opacity var(--med),visibility var(--med),transform var(--med),box-shadow var(--med)}
.back-to-top.visible{opacity:1;visibility:visible;transform:translateY(0)}
.back-to-top:hover{box-shadow:0 6px 20px rgba(37,99,235,.45);transform:translateY(-3px)}

/* ========== HIGHLIGHTS STRIP ========== */
.hl-strip{padding:2.5rem 0 1.5rem;background:var(--g50)}
.hl-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.hl-card{display:flex;align-items:center;gap:.85rem;padding:1.1rem 1.25rem;border-radius:var(--r-md);border:1px solid var(--g200);background:var(--white);text-decoration:none;position:relative;overflow:hidden;transition:all var(--med)}
.hl-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:transparent}
.hl-icon{width:48px;height:48px;flex-shrink:0;display:flex;align-items:center;justify-content:center;border-radius:var(--r)}
.hl-amber .hl-icon{background:#fef3c7;color:#d97706}
.hl-cyan .hl-icon{background:#cffafe;color:#0891b2}
.hl-blue .hl-icon{background:var(--primary-light);color:var(--primary)}
.hl-violet .hl-icon{background:var(--violet-light);color:var(--violet)}
.hl-body{display:flex;flex-direction:column;gap:2px;min-width:0}
.hl-body strong{font-size:.92rem;color:var(--g900);white-space:nowrap}
.hl-body span{font-size:.76rem;color:var(--g500);line-height:1.4}
.hl-badge{position:absolute;top:8px;right:10px;padding:2px 8px;font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;border-radius:var(--r-full);color:var(--white)}
.hl-amber .hl-badge{background:linear-gradient(135deg,#d97706,#fbbf24)}
.hl-cyan .hl-badge{background:linear-gradient(135deg,#0891b2,#22d3ee)}
.hl-blue .hl-badge{background:linear-gradient(135deg,var(--primary),var(--accent))}
.hl-violet .hl-badge{background:linear-gradient(135deg,var(--violet),#a78bfa)}

/* ========== AI DIALER SPOTLIGHT ========== */
.dl-spotlight{padding:4rem 0;background:var(--white)}
.dl-inner{display:grid;grid-template-columns:1.15fr .85fr;gap:3rem;align-items:center}
.dl-metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem}
.dl-metric{text-align:center;padding:.75rem .5rem;background:var(--g50);border-radius:var(--r);border:1px solid var(--g200)}
.dl-num{display:block;font-family:'Space Grotesk',sans-serif;font-size:1.5rem;font-weight:800;color:var(--primary);line-height:1.1}
.dl-label{display:block;font-size:.68rem;font-weight:600;color:var(--g500);text-transform:uppercase;letter-spacing:.04em;margin-top:.2rem}
.dl-features{display:flex;flex-wrap:wrap;gap:.4rem}
.dl-features span{padding:5px 12px;font-size:.72rem;font-weight:600;background:var(--primary-50);color:var(--primary);border:1px solid var(--primary-light);border-radius:var(--r-full)}
.dl-visual{display:flex;justify-content:center}
.dl-visual img{width:100%;max-width:440px;border-radius:var(--r-lg);box-shadow:0 20px 48px rgba(0,0,0,.15)}

/* ========== TRUST BAR ========== */
.trust-bar{padding:2rem 0;background:linear-gradient(135deg,var(--primary-50),rgba(6,182,212,.06))}
.tb-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem}
.tb-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:var(--white);border-radius:var(--r);border:1px solid var(--g200);box-shadow:var(--shadow-sm)}
.tb-icon{width:42px;height:42px;flex-shrink:0;display:flex;align-items:center;justify-content:center;border-radius:var(--r-sm)}
.tb-blue{background:var(--primary-light);color:var(--primary)}
.tb-emerald{background:#d1fae5;color:#059669}
.tb-violet{background:var(--violet-light);color:var(--violet)}
.tb-amber{background:#fef3c7;color:#d97706}
.tb-item strong{display:block;font-size:.88rem;color:var(--g900);line-height:1.2}
.tb-item span{display:block;font-size:.72rem;color:var(--g500)}

/* ========== e DoT AI PRODUCT BRAND ========== */
.edot-ai{font-family:'Space Grotesk','Inter',sans-serif;font-weight:800;letter-spacing:-.03em;white-space:nowrap}
.edot-ai .edot-e{color:var(--primary)}
.edot-ai .edot-dot{background:linear-gradient(135deg,var(--primary),var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.edot-ai .edot-t{color:var(--accent)}
.edot-ai .edot-suffix{font-weight:600;color:var(--g600);letter-spacing:0}
.edot-ai-lg{font-size:1.35em}
.edot-ai-hero{font-size:1.1em}
.edot-ai-badge{display:inline-flex;align-items:center;gap:.35rem;padding:4px 14px;font-size:.78rem;background:linear-gradient(135deg,rgba(37,99,235,.08),rgba(6,182,212,.08));border:1px solid rgba(37,99,235,.18);border-radius:var(--r-full)}

/* ========== FADE-IN ========== */
.edot-fade-in{opacity:0;transform:translateY(20px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.edot-fade-in.edot-visible{opacity:1;transform:translateY(0)}

/* ========== PERFORMANCE HELPERS ========== */
/* Skip rendering below-the-fold blocks until needed. */
.section,.pp-section,.products-grid,.services-grid,.solutions-grid,.about-grid,.about-story,.leadership-grid,.focus-grid,.offices-grid,.news-grid,.uc-grid,.feat-grid,.hiw-grid,.focus-map,.focus-track-grid,.focus-metrics,.models-grid,.features-list-grid{
  content-visibility:auto;
  contain-intrinsic-size:1px 900px;
}

/* Respect reduced-motion users and cut animation work on low-power devices. */
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{
    animation-duration:.01ms!important;
    animation-iteration-count:1!important;
    transition-duration:.01ms!important;
  }
  .edot-fade-in{opacity:1;transform:none}
}

/* ========== RESPONSIVE ========== */
@media(max-width:1024px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:960px){
  .dl-inner{grid-template-columns:1fr}
  .dl-content{text-align:center}
  .dl-content .section-title{text-align:center}
  .dl-visual img{max-width:360px}
  .hero-inner{grid-template-columns:1fr;text-align:center}
  .hero-desc{margin-left:auto;margin-right:auto}
  .hero-cta{justify-content:center}
  .hero-stats{margin:0 auto;max-width:100%}
  .hero-visual{display:none}
  .about-story{grid-template-columns:1fr}
}
@media(max-width:768px){
  .menu-toggle{display:flex}
  .nav-wrap{position:fixed;top:var(--hdr);left:0;right:0;background:var(--white);box-shadow:var(--shadow-xl);padding:1rem;max-height:0;overflow:hidden;opacity:0;transition:max-height var(--med),opacity var(--med)}
  .nav-wrap.open{max-height:85vh;opacity:1;overflow-y:auto}
  .primary-menu{flex-direction:column;align-items:stretch}
  .primary-menu>li>a{padding:12px 16px;font-size:.9rem}
  .sub-menu,.mega-menu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:none;margin:0;padding:0;width:100%;max-height:0;overflow:hidden;transition:max-height var(--med)}
  .mega-menu{border-radius:0}
  .mega-inner{grid-template-columns:1fr;gap:.75rem}
  .mega-promo{display:none}
  .primary-menu>li.dropdown-open .sub-menu,.primary-menu>li.dropdown-open .mega-menu{max-height:600px;padding:.5rem 0 .5rem 1rem;border-top:1px solid var(--g200)}
  .hl-grid{grid-template-columns:1fr 1fr}
  .tb-grid{grid-template-columns:1fr 1fr}
  .dl-metrics{grid-template-columns:repeat(2,1fr)}
  .products-grid{grid-template-columns:1fr}
  .ribbon-inner{flex-direction:column;text-align:center}
  .ribbon-right{justify-content:center}
  .call-button{bottom:78px;padding:12px 14px}
  .call-button-text{display:none}
  .back-to-top{bottom:18px;right:18px;width:40px;height:40px}
  .form-row{grid-template-columns:1fr}
  .offices-grid{grid-template-columns:1fr}
  .contact-quick-bar{flex-direction:column;text-align:center}
  .cqb-divider{width:60px;height:1px}
  .footer-grid{grid-template-columns:1fr}
}
@media(max-width:480px){
  .hl-grid{grid-template-columns:1fr}
  .tb-grid{grid-template-columns:1fr}
  .dl-metrics{grid-template-columns:repeat(2,1fr)}
  .dl-features{justify-content:center}
  .section{padding:3.5rem 0}
  .hero-cta{flex-direction:column}
  .hero-cta .btn{width:100%}
  .hero-stats{flex-direction:column;gap:.75rem}
  .stat-divider{width:60px;height:1px}
  .footer-bottom{flex-direction:column;text-align:center}
}

/* Print */
@media print{
  .header,.site-footer,.back-to-top,.call-button,.preloader,.ribbon{display:none!important}
  body{color:#000;background:#fff}
  a{color:#000;text-decoration:underline}
}

/* Focus */
*:focus-visible{outline:2px solid var(--primary);outline-offset:2px;border-radius:2px}
