﻿/* ═══════════════════════════════════════════════════════════
   CODIOO — Design System v3.0 | Stripe · Vercel · Linear
   ═══════════════════════════════════════════════════════════ */
/* Google Fonts loaded asynchronously via <link> in base.html */

/* ─── TOKENS ─────────────────────────────────────────────── */
:root {
  --primary:       #2563EB;
  --primary-dark:  #1d4ed8;
  --primary-soft:  rgba(37,99,235,0.08);
  --primary-ring:  rgba(37,99,235,0.2);
  --accent:        #22C55E;
  --accent-dark:   #16a34a;
  --accent-soft:   rgba(34,197,94,0.08);
  --bg:            #F9FAFB;
  --bg2:           #ffffff;
  --bg3:           #EFF6FF;
  --text:          #0f1729;
  --text2:         #374151;
  --muted:         #6B7280;
  --card:          #ffffff;
  --border:        #E5E7EB;
  --border2:       #D1D5DB;
  --shadow:        0 1px 2px rgba(0,0,0,0.04),0 4px 12px rgba(0,0,0,0.06);
  --shadow-md:     0 4px 8px rgba(0,0,0,0.04),0 12px 32px rgba(0,0,0,0.08);
  --shadow-lg:     0 20px 60px rgba(0,0,0,0.10);
  --r-xs: 4px; --r-sm: 8px; --r-md: 12px; --r-lg: 16px; --r-xl: 20px; --r-2xl: 24px; --r-full: 9999px;
  --font-sans: 'Sora', system-ui, -apple-system, sans-serif;
  --font-mono: 'JetBrains Mono', 'Fira Code', monospace;
  --ease: 200ms cubic-bezier(0.4,0,0.2,1);
  --ease-lg: 350ms cubic-bezier(0.4,0,0.2,1);
}
[data-theme="dark"] {
  --bg:    #0B0F19; --bg2: #111827; --bg3: #0d1526;
  --text:  #F1F5F9; --text2: #CBD5E1; --muted: #64748B;
  --card:  #111827; --border: rgba(255,255,255,0.08); --border2: rgba(255,255,255,0.12);
  --shadow:    0 1px 2px rgba(0,0,0,0.3),0 4px 12px rgba(0,0,0,0.3);
  --shadow-md: 0 4px 8px rgba(0,0,0,0.2),0 12px 32px rgba(0,0,0,0.4);
  --shadow-lg: 0 20px 60px rgba(0,0,0,0.5);
  --primary-soft: rgba(37,99,235,0.15);
}

/* ─── BASE ───────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{
  font-family:var(--font-sans);
  background:var(--bg);color:var(--text);
  line-height:1.65;
  transition:background var(--ease-lg),color var(--ease-lg);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
body::before{
  content:'';position:fixed;inset:0;pointer-events:none;z-index:0;
  background-image:linear-gradient(rgba(37,99,235,0.03)1px,transparent 1px),
    linear-gradient(90deg,rgba(37,99,235,0.03)1px,transparent 1px);
  background-size:48px 48px;
}
section,nav,footer,header,main{position:relative;z-index:1}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
ul{list-style:none;padding:0;margin:0}
h1,h2,h3,h4,h5,h6{font-family:var(--font-sans);font-weight:700;letter-spacing:-0.025em;line-height:1.15;color:var(--text)}

/* ─── TYPOGRAPHY ─────────────────────────────────────────── */
.section-title{font-size:clamp(1.8rem,3.5vw,2.6rem);font-weight:800;letter-spacing:-0.03em}
.section-sub{font-size:1.05rem;color:var(--muted);max-width:580px;line-height:1.75}
.text-gradient{background:linear-gradient(135deg,var(--primary)0%,#60a5fa 50%,#818cf8 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.text-accent{color:var(--accent)}
.text-primary{color:var(--primary)}
.font-mono{font-family:var(--font-mono)}
.section-pad{padding:88px 0}
.section-alt{background:var(--bg2)}

/* ─── EYEBROW / CODE TAG ─────────────────────────────────── */
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-mono);font-size:0.72rem;font-weight:600;
  letter-spacing:0.1em;text-transform:uppercase;color:var(--primary-dark);
  padding:5px 12px;border-radius:var(--r-full);
  border:1px solid var(--primary-ring);background:var(--primary-soft);
  margin-bottom:16px;
}
[data-theme="dark"] .eyebrow{color:#60a5fa}
.eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--accent);animation:blink 2s ease-in-out infinite}
@keyframes blink{0%,100%{opacity:1;transform:scale(1)}50%{opacity:0.5;transform:scale(1.4)}}
.code-tag{
  font-family:var(--font-mono);font-size:0.72rem;font-weight:600;
  padding:2px 8px;border-radius:var(--r-xs);
  background:var(--primary-soft);color:var(--primary);
  border:1px solid var(--primary-ring);
}
.tag-green{background:var(--accent-soft);color:var(--accent);border-color:rgba(34,197,94,0.2)}
.tag-yellow{background:rgba(234,179,8,0.08);color:#ca8a04;border-color:rgba(234,179,8,0.2)}
.tag-red{background:rgba(239,68,68,0.08);color:#ef4444;border-color:rgba(239,68,68,0.2)}

/* ─── BUTTONS ────────────────────────────────────────────── */
.btn-primary{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--primary);color:#fff!important;border:none;
  border-radius:var(--r-md);padding:10px 20px;
  font-family:var(--font-sans);font-weight:700;font-size:0.9rem;
  cursor:pointer;transition:background var(--ease),transform var(--ease),box-shadow var(--ease);
  white-space:nowrap;
}
.btn-primary:hover{background:var(--primary-dark);transform:translateY(-1px);box-shadow:0 4px 16px rgba(37,99,235,0.35)}
.btn-primary.lg{padding:13px 26px;font-size:0.96rem;border-radius:var(--r-lg)}
.btn-outline{
  display:inline-flex;align-items:center;gap:8px;
  background:transparent;color:var(--text)!important;
  border:1px solid var(--border2);border-radius:var(--r-md);
  padding:10px 20px;font-family:var(--font-sans);font-weight:600;font-size:0.9rem;
  cursor:pointer;transition:border-color var(--ease),background var(--ease),transform var(--ease);
  white-space:nowrap;
}
.btn-outline:hover{border-color:var(--primary);background:var(--primary-soft);transform:translateY(-1px);color:var(--text)!important}
.btn-outline.lg{padding:13px 26px;font-size:0.96rem;border-radius:var(--r-lg)}
.btn-accent{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--accent);color:#fff!important;border:none;
  border-radius:var(--r-md);padding:10px 20px;
  font-weight:700;font-size:0.9rem;cursor:pointer;
  transition:background var(--ease),transform var(--ease);
  white-space:nowrap;
}
.btn-accent:hover{background:var(--accent-dark);transform:translateY(-1px)}
.btn-white{
  display:inline-flex;align-items:center;gap:8px;
  background:#fff;color:var(--primary)!important;border:none;
  border-radius:var(--r-md);padding:13px 24px;
  font-weight:700;font-size:0.93rem;cursor:pointer;
  transition:transform var(--ease),box-shadow var(--ease);
  white-space:nowrap;
}
.btn-white:hover{transform:translateY(-2px);box-shadow:0 4px 16px rgba(0,0,0,0.15)}
.btn-outline-white{
  display:inline-flex;align-items:center;gap:8px;
  background:transparent;color:rgba(255,255,255,0.9)!important;
  border:1px solid rgba(255,255,255,0.3);border-radius:var(--r-md);
  padding:13px 24px;font-weight:600;font-size:0.93rem;cursor:pointer;
  transition:border-color var(--ease),background var(--ease),transform var(--ease);
  white-space:nowrap;
}
.btn-outline-white:hover{border-color:rgba(255,255,255,0.7);background:rgba(255,255,255,0.08);transform:translateY(-2px)}

/* ─── NAVBAR ─────────────────────────────────────────────── */
#mainNavbar{
  background:rgba(249,250,251,0.82);
  backdrop-filter:blur(20px)saturate(180%);
  -webkit-backdrop-filter:blur(20px)saturate(180%);
  border-bottom:1px solid transparent;
  transition:background var(--ease-lg),border-color var(--ease-lg),box-shadow var(--ease-lg);
  padding:0;
}
[data-theme="dark"] #mainNavbar{background:rgba(11,15,25,0.86)}
#mainNavbar.scrolled{border-bottom-color:var(--border);box-shadow:var(--shadow);background:rgba(249,250,251,0.98)}
[data-theme="dark"] #mainNavbar.scrolled{background:rgba(11,15,25,0.99)}
.navbar-inner{height:64px;display:flex;align-items:center;flex-wrap:wrap}
.brand-mark{display:flex;align-items:center;gap:10px;text-decoration:none}
.brand-icon{
  width:32px;height:32px;border-radius:var(--r-sm);
  background:var(--primary);display:flex;align-items:center;justify-content:center;
  color:#fff;font-family:var(--font-mono);font-size:0.85rem;font-weight:700;flex-shrink:0;
}
.brand-text{font-family:var(--font-sans);font-size:1.1rem;font-weight:800;letter-spacing:-0.03em;color:var(--text)}
.brand-text span{color:var(--primary)}
.navbar-nav .nav-link{
  font-family:var(--font-sans);font-size:0.875rem;font-weight:500;
  color:var(--text2)!important;padding:6px 12px!important;border-radius:var(--r-sm);
  transition:color var(--ease),background var(--ease);
}
.navbar-nav .nav-link:hover{color:var(--text)!important;background:rgba(0,0,0,0.04)}
.navbar-nav .nav-link.active-link{color:var(--primary)!important}
[data-theme="dark"] .navbar-nav .nav-link:hover{background:rgba(255,255,255,0.06)}
.theme-btn{
  width:36px;height:36px;border-radius:var(--r-sm);
  border:1px solid var(--border);background:var(--card);color:var(--text2);
  display:flex;align-items:center;justify-content:center;font-size:0.88rem;
  cursor:pointer;transition:border-color var(--ease),color var(--ease);
}
.theme-btn:hover{border-color:var(--primary);color:var(--primary)}
.navbar-toggler{border:1px solid var(--border);padding:6px 8px;border-radius:var(--r-sm)}
.navbar-toggler-icon{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3E%3Cpath stroke='rgba(15,23,41,0.8)' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3E%3C/svg%3E")}
[data-theme="dark"] .navbar-toggler-icon{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3E%3Cpath stroke='rgba(241,245,249,0.9)' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3E%3C/svg%3E")}

/* ─── ANNOUNCE BAR ───────────────────────────────────────── */
.announce-bar{
  background:var(--primary);color:#fff;
  font-family:var(--font-mono);font-size:0.78rem;font-weight:500;
  padding:9px 48px 9px 16px;text-align:center;position:relative;z-index:1041;letter-spacing:0.01em;
}
.announce-close{
  position:absolute;right:12px;top:50%;transform:translateY(-50%);
  background:none;border:none;color:rgba(255,255,255,0.75);font-size:0.9rem;
  cursor:pointer;padding:4px;transition:color var(--ease);
}
.announce-close:hover{color:#fff}
.announce-link{color:#fff;text-decoration:underline}
.announce-link:hover{color:#fff}

/* ─── HERO ───────────────────────────────────────────────── */
.hero-section{
  min-height:calc(100vh - 104px);display:flex;align-items:center;
  padding:80px 0 60px;background:var(--bg);overflow:hidden;
}
.hero-section::before{
  content:'';position:absolute;top:-200px;right:-200px;
  width:700px;height:700px;border-radius:50%;pointer-events:none;
  background:radial-gradient(circle,rgba(37,99,235,0.07)0%,transparent 60%);
}
.hero-section::after{
  content:'';position:absolute;bottom:-100px;left:-100px;
  width:500px;height:500px;border-radius:50%;pointer-events:none;
  background:radial-gradient(circle,rgba(34,197,94,0.05)0%,transparent 60%);
}
.hero-headline{
  font-size:clamp(2.2rem,5vw,3.8rem);font-weight:900;
  letter-spacing:-0.04em;line-height:1.05;color:var(--text);margin-bottom:20px;
}
.hero-sub{font-size:1.1rem;color:var(--muted);line-height:1.78;max-width:520px;margin-bottom:28px}
.hero-meta{display:flex;align-items:center;gap:20px;flex-wrap:wrap;margin-top:36px;padding-top:28px;border-top:1px solid var(--border)}
.hero-meta-num{font-family:var(--font-mono);font-size:1.5rem;font-weight:700;color:var(--text);line-height:1}
.hero-meta-label{font-size:0.72rem;color:var(--muted);font-weight:500;margin-top:2px}
.hero-meta-div{width:1px;height:32px;background:var(--border)}

/* ─── PIPELINE VISUAL ────────────────────────────────────── */
.pipeline-wrap{display:flex;flex-direction:column;gap:8px;width:100%;max-width:420px;margin:0 auto}
.pipe-card{
  background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);
  padding:14px 18px;display:flex;align-items:center;gap:12px;
  box-shadow:var(--shadow);
  transition:border-color var(--ease),transform var(--ease),box-shadow var(--ease);
}
.pipe-card:hover{border-color:var(--primary);transform:translateX(4px);box-shadow:var(--shadow-md)}
.pipe-icon{
  width:34px;height:34px;border-radius:var(--r-sm);flex-shrink:0;
  display:flex;align-items:center;justify-content:center;font-size:0.88rem;
}
.pi-blue{background:var(--primary-soft);color:var(--primary)}
.pi-green{background:var(--accent-soft);color:var(--accent)}
.pi-purple{background:rgba(139,92,246,0.1);color:#8b5cf6}
.pi-orange{background:rgba(249,115,22,0.1);color:#f97316}
.pi-teal{background:rgba(20,184,166,0.1);color:#14b8a6}
.pipe-title{font-size:0.88rem;font-weight:700;color:var(--text);line-height:1.2}
.pipe-sub{font-family:var(--font-mono);font-size:0.68rem;color:var(--muted);margin-top:2px}
.pipe-badge{
  margin-left:auto;font-family:var(--font-mono);font-size:0.62rem;font-weight:600;
  padding:2px 7px;border-radius:var(--r-xs);white-space:nowrap;flex-shrink:0;
}
.pb-done{background:rgba(34,197,94,0.1);color:var(--accent)}
.pb-run{background:var(--primary-soft);color:var(--primary)}
.pb-queue{background:rgba(107,114,128,0.1);color:var(--muted)}
.pipe-connector{
  display:flex;align-items:center;gap:8px;padding:0 18px;
}
.pipe-conn-line{
  flex:1;height:1px;background:var(--border);position:relative;
}
.pipe-conn-line::after{
  content:'';position:absolute;right:0;top:50%;transform:translateY(-50%);
  border-left:5px solid var(--border);border-top:3px solid transparent;border-bottom:3px solid transparent;
}
.pipe-conn-label{font-family:var(--font-mono);font-size:0.58rem;color:var(--muted);white-space:nowrap}

/* ─── PROBLEM SECTION ────────────────────────────────────── */
.problem-card{
  background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);
  padding:22px 20px;display:flex;align-items:flex-start;gap:14px;
  box-shadow:var(--shadow);height:100%;
  transition:border-color var(--ease),box-shadow var(--ease),transform var(--ease);
}
.problem-card:hover{border-color:rgba(239,68,68,0.25);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.prob-icon{
  width:38px;height:38px;border-radius:var(--r-sm);
  background:rgba(239,68,68,0.08);border:1px solid rgba(239,68,68,0.15);
  display:flex;align-items:center;justify-content:center;
  font-size:0.95rem;color:#ef4444;flex-shrink:0;
}
.problem-title{font-size:0.93rem;font-weight:700;color:var(--text);margin-bottom:5px}
.problem-text{font-size:0.84rem;color:var(--muted);line-height:1.65}

/* ─── SOLUTION SECTION ───────────────────────────────────── */
.solution-card{
  background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);
  padding:26px 22px;height:100%;box-shadow:var(--shadow);
  transition:border-color var(--ease),box-shadow var(--ease),transform var(--ease);
  position:relative;overflow:hidden;
}
.solution-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--primary),var(--accent));
  opacity:0;transition:opacity var(--ease);
}
.solution-card:hover{border-color:rgba(37,99,235,0.22);transform:translateY(-3px);box-shadow:var(--shadow-md)}
.solution-card:hover::before{opacity:1}
.sol-icon{
  width:42px;height:42px;border-radius:var(--r-sm);
  background:var(--primary-soft);border:1px solid var(--primary-ring);
  display:flex;align-items:center;justify-content:center;
  font-size:1.05rem;color:var(--primary);margin-bottom:14px;
}
.solution-title{font-size:0.97rem;font-weight:700;color:var(--text);margin-bottom:8px}
.solution-text{font-size:0.875rem;color:var(--muted);line-height:1.7}
.sol-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:14px}

/* ─── SERVICES ───────────────────────────────────────────── */
.service-card{
  background:var(--card);border:1px solid var(--border);border-radius:var(--r-xl);
  padding:26px 22px;height:100%;box-shadow:var(--shadow);
  display:flex;flex-direction:column;
  transition:border-color var(--ease),box-shadow var(--ease),transform var(--ease);
  cursor:pointer;color:inherit;
}
.service-card:hover{border-color:var(--primary);transform:translateY(-4px);box-shadow:0 0 0 4px var(--primary-soft),var(--shadow-md);color:inherit}
.svc-num{font-family:var(--font-mono);font-size:0.68rem;font-weight:700;color:var(--muted);margin-bottom:10px;letter-spacing:0.05em}
.svc-icon{
  width:46px;height:46px;border-radius:var(--r-md);background:var(--primary);
  display:flex;align-items:center;justify-content:center;
  font-size:1.1rem;color:#fff;margin-bottom:16px;
  transition:transform var(--ease);
}
.service-card:hover .svc-icon{transform:scale(1.06)}
.svc-title{font-size:1rem;font-weight:700;margin-bottom:8px;color:var(--text)}
.svc-text{font-size:0.875rem;color:var(--muted);line-height:1.7;flex:1;margin-bottom:18px}
.svc-link{
  display:inline-flex;align-items:center;gap:5px;
  font-size:0.82rem;font-weight:700;color:var(--primary);
  transition:gap var(--ease);margin-top:auto;
}
.service-card:hover .svc-link{gap:9px}

/* ─── TECH STACK ─────────────────────────────────────────── */
.tech-tabs{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;margin-bottom:28px}
.tech-tab{
  font-family:var(--font-mono);font-size:0.76rem;font-weight:600;
  padding:7px 16px;border-radius:var(--r-full);
  border:1px solid var(--border);background:var(--card);color:var(--muted);
  cursor:pointer;transition:all var(--ease);letter-spacing:0.02em;
}
.tech-tab:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-soft)}
.tech-tab.active{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:0 2px 8px rgba(37,99,235,0.3)}
.tech-grid{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}
.tech-chip{
  font-family:var(--font-mono);font-size:0.78rem;font-weight:500;
  padding:7px 15px;border-radius:var(--r-full);
  border:1px solid var(--border);background:var(--card);color:var(--text2);
  display:inline-flex;align-items:center;gap:6px;
  transition:all var(--ease);cursor:default;
}
.tech-chip i{color:var(--primary);font-size:0.82rem}
.tech-chip:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-soft);transform:translateY(-2px)}
.tech-chip.hidden{display:none}

/* ─── PORTFOLIO ──────────────────────────────────────────── */
.project-card{
  background:var(--card);border:1px solid var(--border);border-radius:var(--r-xl);
  overflow:hidden;box-shadow:var(--shadow);
  transition:border-color var(--ease),box-shadow var(--ease),transform var(--ease);
  height:100%;display:flex;flex-direction:column;cursor:pointer;
}
.project-card:hover{border-color:var(--primary);transform:translateY(-4px);box-shadow:var(--shadow-md)}
.project-thumb{height:198px;position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:space-between;padding:18px}
.pt-1{background:linear-gradient(135deg,#0f172a 0%,#1e3a8a 100%)}
.pt-2{background:linear-gradient(135deg,#0f2027 0%,#1e3a5f 50%,#2c5364 100%)}
.pt-3{background:linear-gradient(135deg,#1a1a2e 0%,#0f3460 100%)}
.pt-4{background:linear-gradient(135deg,#0d0d0d 0%,#1a1a2e 100%)}
.pt-5{background:linear-gradient(135deg,#0a0a1a 0%,#1a0a2e 100%)}
.pt-6{background:linear-gradient(135deg,#001a0f 0%,#003320 100%)}
.thumb-code{font-family:var(--font-mono);font-size:0.62rem;color:rgba(255,255,255,0.35);line-height:1.7}
.thumb-code .c-green{color:rgba(34,197,94,0.65)}
.thumb-code .c-blue{color:rgba(96,165,250,0.65)}
.thumb-code .c-yellow{color:rgba(251,191,36,0.6)}
.thumb-tags{display:flex;gap:5px;flex-wrap:wrap}
.thumb-tag{
  font-family:var(--font-mono);font-size:0.6rem;font-weight:600;
  padding:2px 7px;border-radius:3px;
  background:rgba(255,255,255,0.12);color:rgba(255,255,255,0.85);border:1px solid rgba(255,255,255,0.15);
}
.project-body{padding:20px;flex:1;display:flex;flex-direction:column}
.project-cat{font-family:var(--font-mono);font-size:0.68rem;font-weight:600;color:var(--primary);text-transform:uppercase;letter-spacing:0.08em;margin-bottom:7px}
.project-title{font-size:1rem;font-weight:700;color:var(--text);margin-bottom:7px}
.project-sub{font-size:0.84rem;color:var(--muted);line-height:1.6;flex:1;margin-bottom:14px}
.psr-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:7px;margin-bottom:14px}
.psr-item{background:var(--bg3);border-radius:var(--r-sm);padding:7px 9px;border:1px solid var(--border)}
.psr-label{font-family:var(--font-mono);font-size:0.56rem;font-weight:700;text-transform:uppercase;letter-spacing:0.08em;color:var(--muted);margin-bottom:2px}
.psr-value{font-size:0.78rem;font-weight:700;color:var(--text2);line-height:1.2}
.psr-item.accent .psr-value{color:var(--accent);font-family:var(--font-mono)}
.project-link{display:inline-flex;align-items:center;gap:5px;font-size:0.8rem;font-weight:700;color:var(--primary);transition:gap var(--ease)}
.project-card:hover .project-link{gap:9px}

/* ─── TESTIMONIALS ───────────────────────────────────────── */
.testi-card{
  background:var(--card);border:1px solid var(--border);border-radius:var(--r-xl);
  padding:26px 22px;height:100%;box-shadow:var(--shadow);
  transition:border-color var(--ease),box-shadow var(--ease),transform var(--ease);
}
.testi-card:hover{border-color:rgba(37,99,235,0.22);transform:translateY(-3px);box-shadow:var(--shadow-md)}
.testi-card.featured{border-color:rgba(37,99,235,0.25);background:linear-gradient(135deg,rgba(37,99,235,0.03),rgba(34,197,94,0.02))}
.testi-quot{font-size:1.8rem;color:var(--primary);line-height:1;margin-bottom:10px}
.testi-text{font-size:0.93rem;color:var(--text2);line-height:1.75;font-style:italic;margin-bottom:22px}
.testi-author{display:flex;align-items:center;gap:11px}
.testi-av{
  width:40px;height:40px;border-radius:50%;background:var(--primary);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-mono);font-size:0.72rem;font-weight:800;color:#fff;flex-shrink:0;
}
.testi-name{font-size:0.88rem;font-weight:700;color:var(--text)}
.testi-role{font-family:var(--font-mono);font-size:0.7rem;color:var(--muted);margin-top:1px}

/* ─── PROCESS ────────────────────────────────────────────── */
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;position:relative}
.process-grid::before{
  content:'';position:absolute;top:27px;left:12.5%;width:75%;height:2px;
  background:linear-gradient(90deg,var(--primary),var(--accent));opacity:0.25;z-index:0;
}
.process-card{display:flex;flex-direction:column;align-items:center;text-align:center;padding:0 14px 24px;position:relative;z-index:1}
.step-num{
  width:54px;height:54px;border-radius:var(--r-lg);background:var(--primary);
  color:#fff;display:flex;align-items:center;justify-content:center;
  font-family:var(--font-mono);font-size:0.95rem;font-weight:700;
  margin-bottom:18px;border:3px solid var(--bg);box-shadow:0 0 0 1px var(--primary);
}
.step-title{font-size:0.92rem;font-weight:700;color:var(--text);margin-bottom:7px}
.step-text{font-size:0.82rem;color:var(--muted);line-height:1.65}

/* ─── BLOG ───────────────────────────────────────────────── */
.blog-card{
  background:var(--card);border:1px solid var(--border);border-radius:var(--r-xl);
  overflow:hidden;box-shadow:var(--shadow);
  transition:border-color var(--ease),box-shadow var(--ease),transform var(--ease);
  height:100%;display:flex;flex-direction:column;
}
.blog-card:hover{border-color:var(--primary);transform:translateY(-4px);box-shadow:var(--shadow-md)}
.blog-thumb{height:175px;position:relative;padding:18px;display:flex;flex-direction:column;justify-content:space-between}
.bt-1{background:linear-gradient(135deg,#0f172a 0%,#1e3a8a 100%)}
.bt-2{background:linear-gradient(135deg,#0d2b00 0%,#14532d 100%)}
.bt-3{background:linear-gradient(135deg,#1a0a2e 0%,#3b0764 100%)}
.blog-cat-tag{
  font-family:var(--font-mono);font-size:0.62rem;font-weight:700;
  text-transform:uppercase;letter-spacing:0.1em;
  padding:3px 9px;border-radius:var(--r-full);
  background:rgba(255,255,255,0.14);color:rgba(255,255,255,0.9);border:1px solid rgba(255,255,255,0.2);
  display:inline-block;
}
.blog-thumb-txt{font-family:var(--font-mono);font-size:0.65rem;color:rgba(255,255,255,0.4);line-height:1.5}
.blog-body{padding:20px;flex:1;display:flex;flex-direction:column}
.blog-meta{display:flex;align-items:center;gap:10px;font-family:var(--font-mono);font-size:0.68rem;color:var(--muted);margin-bottom:11px}
.blog-title{font-size:0.98rem;font-weight:700;color:var(--text);margin-bottom:9px;line-height:1.4}
.blog-excerpt{font-size:0.84rem;color:var(--muted);line-height:1.65;flex:1;margin-bottom:14px}
.blog-link{display:inline-flex;align-items:center;gap:5px;font-size:0.8rem;font-weight:700;color:var(--primary);transition:gap var(--ease);margin-top:auto}
.blog-card:hover .blog-link{gap:9px}

/* ─── CTA ────────────────────────────────────────────────── */
.cta-section{background:var(--bg2);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.cta-block{
  background:var(--primary);border-radius:var(--r-2xl);
  padding:64px 48px;position:relative;overflow:hidden;text-align:center;
}
.cta-block::before{content:'';position:absolute;top:-60px;right:-60px;width:260px;height:260px;border-radius:50%;background:rgba(255,255,255,0.05)}
.cta-block::after{content:'';position:absolute;bottom:-60px;left:-60px;width:220px;height:220px;border-radius:50%;background:rgba(34,197,94,0.1)}
.cta-block>*{position:relative;z-index:1}
.cta-headline{font-size:clamp(1.7rem,3.5vw,2.5rem);font-weight:900;color:#fff;margin-bottom:14px;letter-spacing:-0.03em}
.cta-sub{color:rgba(255,255,255,0.72);font-size:1.02rem;max-width:520px;margin:0 auto 28px;line-height:1.72}

/* ─── NEWSLETTER ─────────────────────────────────────────── */
.nl-wrap{max-width:500px;margin:0 auto;text-align:center}
.nl-row{
  display:flex;gap:8px;background:var(--card);
  border:1px solid var(--border);border-radius:var(--r-md);
  padding:5px 5px 5px 16px;align-items:center;
  transition:border-color var(--ease),box-shadow var(--ease);
}
.nl-row:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px rgba(37,99,235,0.1)}
.nl-input{flex:1;border:none;background:none;font-family:var(--font-sans);font-size:0.9rem;color:var(--text);outline:none}
.nl-input::placeholder{color:var(--muted)}
.nl-error{font-family:var(--font-mono);font-size:0.7rem;color:#ef4444;margin-top:7px;font-weight:600}

/* ─── MARQUEE ────────────────────────────────────────────── */
.marquee-strip{overflow:hidden;padding:18px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);mask-image:linear-gradient(to right,transparent,black 10%,black 90%,transparent);-webkit-mask-image:linear-gradient(to right,transparent,black 10%,black 90%,transparent)}
.marquee-track{display:flex;width:max-content;animation:mScroll 28s linear infinite}
.marquee-track:hover{animation-play-state:paused}
@keyframes mScroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.mq-set{display:flex;align-items:center}
.mq-chip{
  display:inline-flex;align-items:center;gap:7px;
  padding:7px 18px;margin:0 5px;border-radius:var(--r-md);
  border:1px solid var(--border);background:var(--card);
  font-family:var(--font-mono);font-size:0.76rem;font-weight:500;color:var(--text2);white-space:nowrap;
}
.mq-chip i{color:var(--primary)}

/* ─── STATS STRIP ────────────────────────────────────────── */
.stats-strip{
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-xl);
  padding:28px 36px;display:flex;align-items:center;justify-content:space-around;
  flex-wrap:wrap;gap:20px;
}
.stat-big{font-family:var(--font-mono);font-size:1.8rem;font-weight:700;color:var(--primary);line-height:1}
.stat-lbl{font-size:0.76rem;color:var(--muted);margin-top:3px}
.stat-sep{width:1px;height:38px;background:var(--border)}

/* ─── CONTACT ────────────────────────────────────────────── */
.contact-info-item{display:flex;align-items:flex-start;gap:14px;padding:16px 0;border-bottom:1px solid var(--border)}
.contact-info-item:last-child{border-bottom:none}
.contact-icon{
  width:38px;height:38px;border-radius:var(--r-sm);
  background:var(--primary-soft);border:1px solid var(--primary-ring);
  display:flex;align-items:center;justify-content:center;font-size:0.95rem;color:var(--primary);flex-shrink:0;
}
.contact-label{font-family:var(--font-mono);font-size:0.66rem;font-weight:700;text-transform:uppercase;letter-spacing:0.08em;color:var(--muted);margin-bottom:3px}
.contact-value{font-size:0.9rem;color:var(--text2);font-weight:500;line-height:1.5}
a.contact-value:hover{color:var(--primary)}
.form-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r-2xl);padding:28px;box-shadow:var(--shadow-md)}
.form-card-title{font-size:1.15rem;font-weight:800;color:var(--text);margin-bottom:3px}
.form-card-sub{font-family:var(--font-mono);font-size:0.72rem;color:var(--muted);margin-bottom:22px}
.field-label{font-family:var(--font-mono);font-size:0.69rem;font-weight:700;text-transform:uppercase;letter-spacing:0.06em;color:var(--text2);margin-bottom:5px;display:block}
.field-req{color:#ef4444}
.field-input{
  width:100%;padding:10px 13px;border-radius:var(--r-md);
  border:1px solid var(--border);background:var(--bg);color:var(--text);
  font-family:var(--font-sans);font-size:0.9rem;
  transition:border-color var(--ease),box-shadow var(--ease);appearance:none;
}
.field-input::placeholder{color:var(--muted)}
.field-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(37,99,235,0.1)}
.field-input.err{border-color:#ef4444}
.field-input.ok{border-color:var(--accent)}
.field-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%236b7280' viewBox='0 0 16 16'%3E%3Cpath d='M7.247 11.14L2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;cursor:pointer;padding-right:34px}
.field-select{
  color:var(--text);
  background-color:var(--bg);
}

.field-select option{
  color:var(--text);
  background-color:var(--card);
}

[data-theme="dark"] .field-select{
  border-color:var(--border2);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%239ca3af' viewBox='0 0 16 16'%3E%3Cpath d='M7.247 11.14L2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/%3E%3C/svg%3E");
}

[data-theme="dark"] .field-select option{
  background-color:#0f172a;
  color:#e5e7eb;
}

.field-select.is-customized{
  position:absolute !important;
  opacity:0 !important;
  pointer-events:none !important;
  width:1px !important;
  height:1px !important;
  margin:0 !important;
  padding:0 !important;
  border:0 !important;
}

.cs-select{
  position:relative;
}

.cs-toggle{
  width:100%;
  padding:10px 38px 10px 13px;
  border-radius:var(--r-md);
  border:1px solid var(--border);
  background:var(--bg);
  color:var(--text);
  font-family:var(--font-sans);
  font-size:0.9rem;
  text-align:left;
  cursor:pointer;
  transition:border-color var(--ease),box-shadow var(--ease);
  position:relative;
}

.cs-toggle::after{
  content:'';
  position:absolute;
  right:12px;
  top:50%;
  width:16px;
  height:16px;
  transform:translateY(-50%);
  background-repeat:no-repeat;
  background-position:center;
  background-size:16px 16px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%236b7280' viewBox='0 0 16 16'%3E%3Cpath d='M7.247 11.14L2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/%3E%3C/svg%3E");
}

.cs-toggle:hover{border-color:var(--border2)}
.cs-toggle:focus-visible{outline:2px solid var(--primary);outline-offset:2px}

.cs-select.open .cs-toggle{
  border-color:var(--primary);
  box-shadow:0 0 0 3px rgba(37,99,235,0.1);
}

.cs-select.open .cs-toggle::after{
  transform:translateY(-50%) rotate(180deg);
}

.cs-menu{
  position:absolute;
  top:calc(100% + 6px);
  left:0;
  right:0;
  z-index:1200;
  max-height:260px;
  overflow:auto;
  margin:0;
  padding:6px;
  list-style:none;
  border:1px solid var(--border2);
  border-radius:var(--r-md);
  background:var(--card);
  box-shadow:var(--shadow-lg);
}

.cs-option{
  border-radius:8px;
  padding:8px 10px;
  font-size:0.9rem;
  color:var(--text);
  cursor:pointer;
  transition:background-color var(--ease),color var(--ease),box-shadow var(--ease),transform var(--ease);
}

.cs-option:hover,
.cs-option:focus-visible{
  background:rgba(37,99,235,0.12);
  color:var(--primary);
  box-shadow:inset 0 0 0 1px rgba(37,99,235,0.25);
  transform:translateX(2px);
}

.cs-option.is-selected{
  background:var(--primary-soft);
  color:var(--primary);
  font-weight:600;
}

[data-theme="dark"] .cs-option:hover,
[data-theme="dark"] .cs-option:focus-visible{
  background:rgba(96,165,250,0.18);
  color:#bfdbfe;
  box-shadow:inset 0 0 0 1px rgba(96,165,250,0.28);
}

[data-theme="dark"] .cs-toggle::after{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%239ca3af' viewBox='0 0 16 16'%3E%3Cpath d='M7.247 11.14L2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/%3E%3C/svg%3E");
}
.field-error{font-family:var(--font-mono);font-size:0.68rem;color:#ef4444;margin-top:3px;font-weight:600;display:none}
.field-error.show{display:block}
@keyframes btnSpin{to{transform:rotate(360deg)}}
.spin{display:inline-block;animation:btnSpin 0.8s linear infinite}

/* ─── FAQ ────────────────────────────────────────────────── */
/* Section wrapper */
.faq-section{
  position:relative;
  padding:96px 0;
  overflow:hidden;
}
.faq-section-glow{
  position:absolute;
  inset:0;
  background:radial-gradient(ellipse 90% 55% at 50% 0%,rgba(37,99,235,0.07) 0%,transparent 70%);
  pointer-events:none;
}
[data-theme="dark"] .faq-section-glow{
  background:radial-gradient(ellipse 90% 55% at 50% 0%,rgba(37,99,235,0.13) 0%,transparent 70%);
}
.faq-header{margin-bottom:60px}

/* Contact link inside header */
.faq-contact-link{
  color:var(--primary);
  font-weight:600;
  border-bottom:1px solid var(--primary-ring);
  transition:border-color var(--ease),opacity var(--ease);
}
.faq-contact-link:hover{border-color:var(--primary);opacity:0.8}
.faq-contact-link i{font-size:0.78rem;vertical-align:middle}

/* List */
.faq-list{
  max-width:780px;
  margin:0 auto;
  display:flex;
  flex-direction:column;
  gap:10px;
}

/* Card */
.faq-item{
  position:relative;
  border:1.5px solid var(--border);
  border-radius:var(--r-xl);
  background:var(--card);
  box-shadow:var(--shadow);
  overflow:hidden;
  transition:border-color var(--ease-lg),box-shadow var(--ease-lg),transform var(--ease);
}
/* Left gradient accent bar (visible when open) */
.faq-item::before{
  content:'';
  position:absolute;
  left:0;top:0;bottom:0;
  width:3px;
  background:linear-gradient(180deg,var(--primary) 0%,#818cf8 100%);
  opacity:0;
  transition:opacity var(--ease-lg);
  z-index:1;
}
.faq-item:hover{
  border-color:var(--border2);
  box-shadow:var(--shadow-md);
  transform:translateY(-1px);
}
/* Open state — uses :has() (all modern browsers 2023+) */
.faq-item:has(.faq-question:not(.collapsed)){
  border-color:var(--primary-ring);
  box-shadow:0 0 0 1px var(--primary-ring),0 8px 32px rgba(37,99,235,0.09);
  transform:translateY(-1px);
}
[data-theme="dark"] .faq-item:has(.faq-question:not(.collapsed)){
  box-shadow:0 0 0 1px var(--primary-ring),0 8px 32px rgba(37,99,235,0.18);
}
.faq-item:has(.faq-question:not(.collapsed))::before{opacity:1}

/* Question button */
.faq-question{
  width:100%;
  border:none;
  background:transparent;
  display:flex;
  align-items:center;
  gap:16px;
  text-align:left;
  padding:20px 22px;
  cursor:pointer;
  transition:background var(--ease);
}
.faq-question:hover{background:var(--primary-soft)}
.faq-question:not(.collapsed){background:var(--primary-soft)}

/* Number badge */
.faq-num{
  font-family:var(--font-mono);
  font-size:0.65rem;
  font-weight:700;
  letter-spacing:0.06em;
  color:var(--primary);
  background:var(--primary-soft);
  border:1px solid var(--primary-ring);
  border-radius:var(--r-sm);
  padding:3px 8px;
  min-width:38px;
  text-align:center;
  flex-shrink:0;
  transition:background var(--ease),color var(--ease),border-color var(--ease);
}
.faq-item:has(.faq-question:not(.collapsed)) .faq-num{
  background:var(--primary);
  color:#fff;
  border-color:var(--primary);
}

/* Question text */
.faq-q-text{
  flex:1;
  font-size:1rem;
  font-weight:700;
  color:var(--text);
  line-height:1.45;
  transition:color var(--ease);
}
.faq-item:has(.faq-question:not(.collapsed)) .faq-q-text{
  color:var(--primary);
}

/* Toggle icon circle — plus rotates into × when open */
.faq-toggle{
  display:flex;
  align-items:center;
  justify-content:center;
  width:30px;
  height:30px;
  border-radius:var(--r-full);
  background:var(--primary-soft);
  border:1px solid var(--primary-ring);
  color:var(--primary);
  font-size:0.78rem;
  flex-shrink:0;
  transition:background var(--ease),color var(--ease),transform var(--ease-lg);
}
.faq-question:not(.collapsed) .faq-toggle{
  background:var(--primary);
  color:#fff;
  border-color:var(--primary);
  transform:rotate(45deg);
}

/* Answer panel */
.faq-answer{
  padding:16px 22px 22px calc(22px + 38px + 16px);
  border-top:1px solid var(--border);
  color:var(--text2);
  font-size:0.95rem;
  line-height:1.8;
}
.faq-answer p:last-child{margin-bottom:0}
.faq-answer a{color:var(--primary);font-weight:500}
.faq-answer a:hover{text-decoration:underline}

/* Mobile */
@media(max-width:575.98px){
  .faq-section{padding:64px 0}
  .faq-question{padding:16px 16px;gap:12px}
  .faq-answer{padding:14px 16px 18px 16px}
  .faq-header{margin-bottom:40px}
}

/* ─── FOOTER ─────────────────────────────────────────────── */
.footer{background:var(--bg2);border-top:1px solid var(--border);padding:60px 0 0}
.footer-grid{display:grid;grid-template-columns:1.8fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px}
.footer-col-title{font-family:var(--font-mono);font-size:0.7rem;font-weight:700;text-transform:uppercase;letter-spacing:0.1em;color:var(--text);margin-bottom:14px}
.footer-links{display:flex;flex-direction:column;gap:10px}
.footer-links a{font-size:0.875rem;color:var(--muted);font-weight:500;transition:color var(--ease)}
.footer-links a:hover{color:var(--primary)}
.footer-tagline{font-size:0.86rem;color:var(--muted);line-height:1.7;margin-top:8px;max-width:250px}
.footer-bottom{border-top:1px solid var(--border);padding:20px 0;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}
.footer-bottom-links{display:flex;gap:18px;flex-wrap:wrap}
.footer-bottom-links a{font-family:var(--font-mono);font-size:0.7rem;color:var(--muted);font-weight:500;transition:color var(--ease)}
.footer-bottom-links a:hover{color:var(--primary)}
.footer-copy{font-family:var(--font-mono);font-size:0.7rem;color:var(--muted)}
.social-row{display:flex;gap:7px;margin-top:14px}
.social-btn{
  width:32px;height:32px;border-radius:var(--r-sm);
  border:1px solid var(--border);background:var(--card);
  display:flex;align-items:center;justify-content:center;font-size:0.82rem;color:var(--muted);
  transition:all var(--ease);
}
.social-btn:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-soft);transform:translateY(-2px)}

/* ─── PAGE HEADER (inner pages) ─────────────────────────── */
.page-header{background:var(--bg2);border-bottom:1px solid var(--border);padding:64px 0 48px}
.page-header-title{font-size:clamp(2rem,4vw,3rem);font-weight:900;letter-spacing:-0.04em;margin-bottom:14px}
.breadcrumb-row{display:flex;align-items:center;gap:7px;font-family:var(--font-mono);font-size:0.7rem;color:var(--muted);margin-bottom:22px}
.breadcrumb-row a{color:var(--primary)}

/* ─── ARTICLE / BLOG DETAIL ──────────────────────────────── */
.article-body{font-size:1rem;line-height:1.88;color:var(--text2)}
.article-body h2{font-size:1.5rem;font-weight:800;margin:40px 0 16px;color:var(--text);letter-spacing:-0.025em}
.article-body h3{font-size:1.15rem;font-weight:700;margin:28px 0 12px;color:var(--text)}
.article-body p{margin-bottom:20px}
.article-body ul{padding-left:0;margin-bottom:20px}
.article-body ul li{position:relative;padding-left:20px;margin-bottom:8px}
.article-body ul li::before{content:'';position:absolute;left:0;top:10px;width:6px;height:6px;border-radius:50%;background:var(--primary)}
.article-body blockquote{border-left:3px solid var(--primary);padding:12px 20px;margin:24px 0;background:var(--primary-soft);border-radius:0 var(--r-sm) var(--r-sm) 0}
.article-body blockquote p{margin:0;font-style:italic;color:var(--text)}
.article-body code{font-family:var(--font-mono);font-size:0.85em;background:var(--bg3);border:1px solid var(--border);padding:2px 6px;border-radius:var(--r-xs);color:var(--primary)}
.article-body pre{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-lg);padding:20px;overflow-x:auto;margin:24px 0;font-family:var(--font-mono);font-size:0.84rem;line-height:1.7;color:var(--text2)}
.toc-wrap{background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);padding:20px;position:sticky;top:80px}
.toc-title{font-family:var(--font-mono);font-size:0.68rem;font-weight:700;text-transform:uppercase;letter-spacing:0.1em;color:var(--muted);margin-bottom:12px}
.toc-links{display:flex;flex-direction:column;gap:7px}
.toc-link{font-size:0.8rem;color:var(--muted);font-weight:500;padding:2px 0 2px 10px;border-left:2px solid var(--border);transition:border-color var(--ease),color var(--ease)}
.toc-link:hover,.toc-link.active{color:var(--primary);border-left-color:var(--primary)}
.toc-sub{font-size:0.75rem;padding-left:22px;font-weight:400}
.inline-cta-box{background:linear-gradient(135deg,rgba(37,99,235,0.06),rgba(34,197,94,0.04));border:1px solid rgba(37,99,235,0.18);border-radius:var(--r-lg);padding:22px;margin:32px 0}
.inline-cta-text{font-size:0.98rem;font-weight:700;color:var(--text);margin-bottom:12px}
.takeaway-list{display:flex;flex-direction:column;gap:10px}
.takeaway-item{display:flex;align-items:flex-start;gap:10px;font-size:0.9rem;color:var(--text2);line-height:1.6}
.takeaway-item::before{content:'→';font-family:var(--font-mono);font-weight:700;color:var(--accent);flex-shrink:0;margin-top:1px}
.author-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r-xl);padding:22px;display:flex;align-items:center;gap:14px;box-shadow:var(--shadow)}
.author-av{width:52px;height:52px;border-radius:50%;background:var(--primary);display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:0.94rem;font-weight:800;color:#fff;flex-shrink:0}
.author-name{font-size:0.97rem;font-weight:700;color:var(--text)}
.author-title{font-family:var(--font-mono);font-size:0.7rem;color:var(--muted);margin-top:2px}
.author-bio{font-size:0.84rem;color:var(--muted);line-height:1.65;margin-top:6px}
.share-row{
  display:flex;
  align-items:center;
  gap:12px;
  border-top:1px solid var(--border);
  background:transparent;
  box-shadow:none;
}

/* ─── SERVICE DETAIL PAGE ────────────────────────────────── */
.use-case-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);padding:20px;box-shadow:var(--shadow)}
.use-case-icon{width:36px;height:36px;border-radius:var(--r-sm);background:var(--primary-soft);border:1px solid var(--primary-ring);display:flex;align-items:center;justify-content:center;font-size:0.9rem;color:var(--primary);margin-bottom:10px}
.benefit-item{display:flex;align-items:flex-start;gap:10px;padding:12px 0;border-bottom:1px solid var(--border)}
.benefit-item:last-child{border-bottom:none}
.benefit-check{width:20px;height:20px;border-radius:50%;background:var(--accent-soft);border:1px solid rgba(34,197,94,0.2);display:flex;align-items:center;justify-content:center;font-size:0.65rem;color:var(--accent);flex-shrink:0;margin-top:1px}

/* ─── BACK TO TOP ────────────────────────────────────────── */
.back-to-top{
  position:fixed;bottom:24px;right:24px;
  width:42px;height:42px;border-radius:var(--r-md);
  background:var(--primary);color:#fff;border:none;font-size:0.95rem;
  cursor:pointer;box-shadow:0 4px 14px rgba(37,99,235,0.35);
  display:flex;align-items:center;justify-content:center;
  opacity:0;visibility:hidden;transform:translateY(10px);
  transition:opacity var(--ease),visibility var(--ease),transform var(--ease);z-index:1050;
}
.back-to-top.visible{opacity:1;visibility:visible;transform:translateY(0)}
.back-to-top:hover{background:var(--primary-dark);transform:translateY(-2px)}

/* ─── TOAST ──────────────────────────────────────────────── */
.toast-custom{background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);color:var(--text);font-family:var(--font-sans);font-size:0.875rem;min-width:280px}

/* ─── REVEAL ─────────────────────────────────────────────── */
.reveal{opacity:0;transform:translateY(20px);transition:opacity 0.55s cubic-bezier(0.16,1,0.3,1)var(--delay,0s),transform 0.55s cubic-bezier(0.16,1,0.3,1)var(--delay,0s)}
.reveal.in{opacity:1;transform:translateY(0)}

/* ─── FOCUS / A11Y ───────────────────────────────────────── */
:focus-visible{outline:2px solid var(--primary);outline-offset:3px}
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--primary)}

/* ─── RESPONSIVE ─────────────────────────────────────────── */
@media(max-width:991.98px){
  .process-grid{grid-template-columns:1fr 1fr;gap:32px}
  .process-grid::before{display:none}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .hero-section{min-height:auto;padding:60px 0}

  /* ── Mobile navbar ── */
  .navbar-inner{
    height:auto;
    min-height:64px;
    align-items:flex-start;
    padding-bottom:0;
  }
  /* Brand + toggler sit in the top 64px row */
  .navbar-inner>.brand-mark{
    height:64px;
    display:flex;
    align-items:center;
    flex:1;
  }
  .navbar-inner>.navbar-toggler{
    height:64px;
    display:flex;
    align-items:center;
    margin:0;
  }
  /* Collapse takes the full width of the next row */
  .navbar-inner>.navbar-collapse{
    flex-basis:100%;
    width:100%;
  }
  /* Dropdown panel */
  #navMenu{
    background:var(--card);
    border:1px solid var(--border);
    border-radius:var(--r-md);
    padding:8px 12px 16px;
    margin-bottom:10px;
    box-shadow:0 8px 32px rgba(0,0,0,.12);
  }
  #navMenu .navbar-nav{
    gap:0!important;
    flex-direction:column;
    margin-bottom:8px;
  }
  #navMenu .navbar-nav .nav-link{
    padding:11px 12px!important;
    font-size:.9rem;
  }
  #navMenu .navbar-nav .nav-link:hover,
  #navMenu .navbar-nav .nav-link.active-link{
    background:rgba(37,99,235,.08);
    border-radius:var(--r-sm);
  }
  /* Bottom action row */
  #navMenu>.d-flex{
    flex-direction:column;
    align-items:stretch!important;
    gap:8px!important;
    margin-top:4px!important;
  }
  #navMenu>.d-flex .btn-primary{
    justify-content:center;
    text-align:center;
  }
  #navMenu>.d-flex .theme-btn{
    width:36px;
    align-self:flex-start;
  }
}
@media(max-width:767.98px){
  .section-pad{padding:56px 0}
  .hero-headline{font-size:clamp(1.8rem,7vw,2.4rem)}
  .pipeline-wrap{max-width:100%}
  .stats-strip{flex-direction:column;gap:14px}
  .stat-sep{display:none}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;text-align:center}
  .footer-bottom-links{justify-content:center}

  .blog-card.flex-row{
    flex-direction:column !important;
    max-height:none !important;
  }

  .blog-card.flex-row .blog-thumb{
    min-width:0 !important;
    width:100%;
    border-radius:var(--r-xl) var(--r-xl) 0 0 !important;
    height:180px !important;
  }
}
@media(max-width:575.98px){
  .process-grid{grid-template-columns:1fr}
  .nl-row{flex-direction:column;padding:10px;border-radius:var(--r-lg)}
  .nl-input{text-align:center}
  .cta-block{padding:40px 20px}
  .form-card{padding:20px}
}
