/* ═══════════════════════════════════════════════════════
   iwsapp.my — Light Modern SaaS Design System
   Fonts: Bricolage Grotesque (display) + Outfit (body)
   Theme: Clean white / slate / WhatsApp green accents
═══════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap');

:root {
  --bg:#FFFFFF; --bg-2:#F7F9FC; --bg-3:#EEF2F7; --bg-4:#E4EAF2;
  --txt:#0F1728; --txt-2:#374151; --txt-3:#6B7280; --txt-4:#9CA3AF;
  --g:#25D366; --g-mid:#1DB954; --g-dark:#128C7E;
  --g-pale:#E8FFF3; --g-pale-2:#D1FAE5;
  --blue:#3B82F6; --blue-pale:#EFF6FF;
  --amber:#F59E0B; --amber-pale:#FFFBEB;
  --violet:#8B5CF6; --violet-pale:#F5F3FF;
  --cyan:#06B6D4; --cyan-pale:#ECFEFF;
  --border:#E5E7EB; --border-2:#D1D5DB;
  --shadow-xs:0 1px 3px rgba(15,23,42,.06),0 1px 2px rgba(15,23,42,.04);
  --shadow-sm:0 2px 8px rgba(15,23,42,.06),0 1px 3px rgba(15,23,42,.04);
  --shadow:0 4px 16px rgba(15,23,42,.08),0 2px 6px rgba(15,23,42,.05);
  --shadow-md:0 8px 28px rgba(15,23,42,.10),0 4px 10px rgba(15,23,42,.06);
  --shadow-lg:0 16px 48px rgba(15,23,42,.12),0 8px 18px rgba(15,23,42,.07);
  --shadow-g:0 6px 24px rgba(37,211,102,.28);
  --r:14px; --r-sm:10px; --r-xs:7px;
  --ease:cubic-bezier(.4,0,.2,1); --t:.2s;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:'Inter',sans-serif;font-size:16px;line-height:1.65;color:var(--txt);background:var(--bg);-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
ul{list-style:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
input,textarea,select{font-family:inherit}

.wrap,.container{max-width:1180px;margin:0 auto;padding:0 32px}
section{padding:96px 0}

h1,h2,h3,h4{font-family:'Inter',sans-serif;line-height:1.15;font-weight:800;color:var(--txt)}

.eyebrow{display:inline-flex;align-items:center;gap:7px;font-size:11.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--g-dark);background:var(--g-pale);border:1px solid var(--g-pale-2);padding:5px 13px;border-radius:100px;margin-bottom:16px}
.eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--g);animation:blink 2s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}

.headline{font-size:clamp(26px,3.5vw,44px);font-weight:800;letter-spacing:-.025em;color:var(--txt);margin-bottom:14px;line-height:1.12}
.headline em{font-style:normal;background:linear-gradient(135deg,var(--g-dark) 0%,var(--g) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.lead{font-size:17px;color:var(--txt-3);max-width:600px;line-height:1.75}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:'Inter',sans-serif;font-size:15px;font-weight:600;padding:12px 24px;border-radius:10px;border:1.5px solid transparent;transition:all var(--t) var(--ease);white-space:nowrap;cursor:pointer;line-height:1}
.btn-primary{background:var(--g);color:#fff;border-color:var(--g);box-shadow:0 2px 8px rgba(37,211,102,.3)}
.btn-primary:hover{background:var(--g-mid);border-color:var(--g-mid);transform:translateY(-2px);box-shadow:var(--shadow-g)}
.btn-secondary{background:var(--bg);color:var(--txt);border-color:var(--border-2);box-shadow:var(--shadow-xs)}
.btn-secondary:hover{border-color:var(--g);color:var(--g-dark);transform:translateY(-1px);box-shadow:var(--shadow-sm)}
.btn-ghost{background:rgba(37,211,102,.07);color:var(--g-dark);border-color:rgba(37,211,102,.25)}
.btn-ghost:hover{background:var(--g-pale);border-color:var(--g)}
.btn-outline{background:transparent;color:var(--txt-2);border-color:var(--border-2)}
.btn-outline:hover{border-color:var(--txt-2);color:var(--txt);transform:translateY(-1px)}
.btn-dark{background:var(--txt);color:#fff;border-color:var(--txt);box-shadow:var(--shadow-sm)}
.btn-dark:hover{background:#1e2d45;transform:translateY(-1px);box-shadow:var(--shadow)}
.btn-lg{padding:15px 30px;font-size:16px;border-radius:12px}
.btn-sm{padding:8px 17px;font-size:14px;border-radius:8px}

/* NAV */
.nav{position:sticky;top:0;z-index:900;background:rgba(255,255,255,.92);backdrop-filter:blur(20px) saturate(1.6);border-bottom:1px solid var(--border);transition:box-shadow var(--t)}
.nav.scrolled{box-shadow:0 2px 24px rgba(15,23,42,.08)}
.nav-inner{max-width:1180px;margin:0 auto;padding:0 32px;height:66px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.nav-logo{display:flex;align-items:center;gap:10px}
.nav-logo-icon{width:36px;height:36px;border-radius:9px;background:linear-gradient(135deg,var(--g-dark),var(--g));display:flex;align-items:center;justify-content:center;font-size:17px;color:#fff;font-weight:900;box-shadow:0 2px 8px rgba(37,211,102,.35)}
.nav-logo-text{font-family:'Inter',sans-serif;font-size:18px;font-weight:800;color:var(--txt)}
.nav-logo-text span{color:var(--g-dark)}
.nav-links{display:flex;align-items:center;gap:2px}
.nav-links a{font-size:14px;font-weight:500;color:var(--txt-3);padding:7px 12px;border-radius:8px;transition:color var(--t),background var(--t)}
.nav-links a:hover{color:var(--txt);background:var(--bg-2)}
.nav-links a.active{color:var(--g-dark);font-weight:600;background:var(--g-pale)}
.nav-right{display:flex;align-items:center;gap:10px}
.btn-nav-wa{display:flex;align-items:center;gap:7px;background:var(--g);color:#fff;font-size:14px;font-weight:700;padding:9px 18px;border-radius:9px;box-shadow:0 2px 8px rgba(37,211,102,.3);transition:all var(--t)}
.btn-nav-wa:hover{background:var(--g-mid);transform:translateY(-1px);box-shadow:var(--shadow-g)}

/* HERO */
.hero{position:relative;background:linear-gradient(180deg,#F0FDF7 0%,#FFFFFF 65%);overflow:hidden;padding:100px 0 72px}
.hero::before{content:'';position:absolute;inset:0;pointer-events:none;background-image:radial-gradient(circle,#CBD5E1 1px,transparent 1px);background-size:28px 28px;opacity:.3;mask-image:radial-gradient(ellipse 80% 100% at 50% 0%,black 40%,transparent 100%)}
.hero::after{content:'';position:absolute;top:-200px;left:50%;transform:translateX(-50%);width:900px;height:500px;border-radius:50%;background:radial-gradient(ellipse,rgba(37,211,102,.12) 0%,transparent 70%);pointer-events:none}
.hero-inner{position:relative;z-index:2;display:grid;grid-template-columns:1.1fr 0.9fr;gap:60px;align-items:center;width:100%}
.hero-eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--g-dark);background:var(--g-pale);border:1.5px solid var(--g-pale-2);padding:6px 14px;border-radius:100px;margin-bottom:22px}
.hero-eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--g);animation:blink 2s infinite}
.hero-title{font-family:'Inter',sans-serif;font-size:clamp(38px,5.5vw,66px);font-weight:800;letter-spacing:-.03em;line-height:1.08;color:var(--txt);margin-bottom:22px}
.hero-title .hl{background:linear-gradient(135deg,var(--g-dark) 0%,var(--g) 60%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-sub{font-size:18px;color:var(--txt-3);max-width:520px;margin-bottom:36px;line-height:1.7}
.hero-pills{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:36px}
.hero-pill{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--txt-2);background:var(--bg);border:1.5px solid var(--border);padding:6px 13px;border-radius:100px;box-shadow:var(--shadow-xs)}
.hero-pill i{color:var(--g-dark);font-size:11px}
.hero-cta{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:52px}
.hero-trust{display:flex;align-items:center;flex-wrap:wrap;gap:0;padding-top:28px;border-top:1px solid var(--border)}
.trust-stat{display:flex;flex-direction:column;align-items:center;padding:0 24px}
.trust-stat:first-child{padding-left:0}
.trust-stat strong{font-family:'Inter',sans-serif;font-size:22px;font-weight:800;color:var(--g-dark);display:block}
.trust-stat span{font-size:12px;color:var(--txt-4);font-weight:500}
.trust-div{width:1px;height:36px;background:var(--border)}

/* PHONE MOCKUP */
.hero-right{position:relative;display:flex;justify-content:center;align-items:center}
.phone-wrap{position:relative;width:300px}
.phone-glow{position:absolute;width:320px;height:320px;border-radius:50%;background:radial-gradient(circle,rgba(37,211,102,.18) 0%,transparent 70%);top:50%;left:50%;transform:translate(-50%,-50%);filter:blur(20px);pointer-events:none;animation:glow-pulse 4s ease-in-out infinite}
@keyframes glow-pulse{0%,100%{transform:translate(-50%,-50%) scale(1)}50%{transform:translate(-50%,-50%) scale(1.1)}}
.phone-mockup{width:280px;background:#fff;border:1.5px solid var(--border);border-radius:36px;padding:20px 16px 28px;margin:0 auto;position:relative;z-index:2;box-shadow:0 24px 80px rgba(15,23,42,.12),0 8px 24px rgba(15,23,42,.07)}
.phone-notch{width:80px;height:8px;background:var(--bg-3);border-radius:100px;margin:0 auto 18px}
.phone-hdr{display:flex;align-items:center;gap:10px;background:linear-gradient(135deg,var(--g-dark),var(--g));border-radius:14px;padding:10px 14px;margin-bottom:14px}
.phone-hdr i{font-size:20px;color:#fff}
.phone-hdr .pname{font-size:13px;font-weight:700;color:#fff}
.phone-hdr .pstatus{font-size:10px;color:rgba(255,255,255,.75)}
.chat-msgs{display:flex;flex-direction:column;gap:8px}
.bbl{max-width:87%;font-size:12.5px;line-height:1.48;padding:9px 12px;border-radius:14px}
.bbl-in{background:var(--bg-2);color:var(--txt-2);border:1px solid var(--border);border-radius:14px 14px 14px 2px}
.bbl-out{background:linear-gradient(135deg,var(--g-dark),var(--g));color:#fff;border-radius:14px 14px 2px 14px;margin-left:auto}
.bbl-time{font-size:9px;color:var(--txt-4);display:block;margin-top:2px}
.bbl-out .bbl-time{color:rgba(255,255,255,.65);text-align:right}
.float-card{position:absolute;z-index:3;background:#fff;border:1.5px solid var(--border);border-radius:14px;padding:12px 16px;box-shadow:var(--shadow-md)}
.float-card:nth-child(1){top:-14px;right:-28px;animation:float-a 3.2s ease-in-out infinite}
.float-card:nth-child(2){bottom:36px;left:-36px;animation:float-b 3.6s ease-in-out infinite}
@keyframes float-a{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@keyframes float-b{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
.fc-val{font-family:'Inter',sans-serif;font-size:20px;font-weight:800;color:var(--g-dark)}
.fc-label{font-size:10px;color:var(--txt-4);font-weight:500}

/* STRIP */
.strip{border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--bg-2);padding:18px 0}
.strip-inner{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.strip-lbl{font-size:11px;color:var(--txt-4);font-weight:700;letter-spacing:.08em;text-transform:uppercase;white-space:nowrap}
.strip-items{display:flex;align-items:center;gap:28px;flex-wrap:wrap;flex:1}
.strip-item{font-size:13px;font-weight:600;color:var(--txt-4);display:flex;align-items:center;gap:7px;white-space:nowrap}
.strip-item i{color:var(--g-dark)}

/* SECTION HELPERS */
.sec-alt{background:var(--bg-2)}
.sec-hdr{margin-bottom:56px}

/* CATEGORY CARDS */
.cats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:24px}
.cat{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--r);padding:28px 22px;position:relative;overflow:hidden;transition:transform var(--t) var(--ease),box-shadow var(--t),border-color var(--t);box-shadow:var(--shadow-xs)}
.cat::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;border-radius:var(--r) var(--r) 0 0}
.cat-marketing::before{background:linear-gradient(90deg,#F59E0B,#FBBF24)}
.cat-utility::before{background:linear-gradient(90deg,#3B82F6,#60A5FA)}
.cat-auth::before{background:linear-gradient(90deg,#25D366,#34D399)}
.cat-service::before{background:linear-gradient(90deg,#8B5CF6,#A78BFA)}
.cat:hover{transform:translateY(-5px);box-shadow:var(--shadow-md)}
.cat-marketing:hover{border-color:#F59E0B}
.cat-utility:hover{border-color:#3B82F6}
.cat-auth:hover{border-color:#25D366}
.cat-service:hover{border-color:#8B5CF6}
.cat-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:14px}
.cat-icon{width:44px;height:44px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:19px}
.cat-marketing .cat-icon{background:var(--amber-pale);color:var(--amber)}
.cat-utility .cat-icon{background:var(--blue-pale);color:var(--blue)}
.cat-auth .cat-icon{background:var(--g-pale);color:var(--g-dark)}
.cat-service .cat-icon{background:var(--violet-pale);color:var(--violet)}
.cat-badge{font-size:10px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;padding:3px 10px;border-radius:100px}
.cat-marketing .cat-badge{background:var(--amber-pale);color:var(--amber)}
.cat-utility .cat-badge{background:var(--blue-pale);color:var(--blue)}
.cat-auth .cat-badge{background:var(--g-pale);color:var(--g-dark)}
.cat-service .cat-badge{background:var(--violet-pale);color:var(--violet)}
.cat h3{font-size:16px;font-weight:700;color:var(--txt);margin-bottom:8px}
.cat p{font-size:13px;color:var(--txt-3);line-height:1.6;margin-bottom:14px}
.cat-uses{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:16px}
.cat-use{font-size:11px;font-weight:600;background:var(--bg-2);color:var(--txt-4);padding:3px 9px;border-radius:100px;border:1px solid var(--border)}
.cat-price{font-family:'Inter',sans-serif;font-size:20px;font-weight:800;color:var(--txt);border-top:1px solid var(--border);padding-top:12px}
.cat-price small{font-size:12px;font-weight:400;color:var(--txt-4)}
.cats-note{display:flex;align-items:center;gap:10px;background:var(--g-pale);border:1.5px solid var(--g-pale-2);border-radius:var(--r-sm);padding:14px 20px;font-size:14px;color:var(--txt-2)}
.cats-note i{color:var(--g-dark);flex-shrink:0}
.cats-note a{color:var(--g-dark);font-weight:700}

/* SERVICE CARDS */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.svc{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--r);padding:34px 28px;position:relative;overflow:hidden;transition:transform var(--t) var(--ease),box-shadow var(--t),border-color var(--t);box-shadow:var(--shadow-xs)}
.svc:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);border-color:var(--g-pale-2)}
.svc-featured{border-color:var(--g);background:linear-gradient(160deg,var(--g-pale) 0%,var(--bg) 45%)}
.svc-badge{position:absolute;top:20px;right:20px;background:var(--g);color:#fff;font-size:10px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;padding:4px 11px;border-radius:100px;box-shadow:0 2px 8px rgba(37,211,102,.4)}
.svc-icon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:22px;margin-bottom:18px}
.svc-icon-g{background:var(--g-pale);color:var(--g-dark)}
.svc-icon-c{background:var(--cyan-pale);color:var(--cyan)}
.svc-icon-a{background:var(--amber-pale);color:var(--amber)}
.svc-icon-b{background:var(--blue-pale);color:var(--blue)}
.svc h3{font-size:19px;font-weight:700;color:var(--txt);margin-bottom:9px}
.svc p{font-size:14px;color:var(--txt-3);line-height:1.7;margin-bottom:18px}
.svc ul{margin-bottom:22px}
.svc li{display:flex;align-items:flex-start;gap:9px;font-size:13.5px;color:var(--txt-2);padding:5px 0;border-bottom:1px solid var(--border)}
.svc li:last-child{border:none}
.svc li i{color:var(--g-dark);font-size:11px;margin-top:4px;flex-shrink:0}
.svc-link{display:inline-flex;align-items:center;gap:6px;font-size:14px;font-weight:700;color:var(--g-dark);transition:gap var(--t)}
.svc-link:hover{gap:10px}

/* WHY US */
.why-inner{display:grid;grid-template-columns:1fr 1.4fr;gap:80px;align-items:center}
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.why-card{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--r-sm);padding:22px 20px;box-shadow:var(--shadow-xs);transition:transform var(--t),box-shadow var(--t),border-color var(--t)}
.why-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--g-pale-2)}
.why-card-icon{width:40px;height:40px;border-radius:10px;background:var(--g-pale);color:var(--g-dark);display:flex;align-items:center;justify-content:center;font-size:17px;margin-bottom:11px}
.why-card h4{font-size:14px;font-weight:700;color:var(--txt);margin-bottom:5px}
.why-card p{font-size:13px;color:var(--txt-3);line-height:1.6}

/* INDUSTRY TABS */
.ind-tabs-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:32px}
.ind-tab{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--txt-3);background:var(--bg);border:1.5px solid var(--border);padding:10px 20px;border-radius:10px;cursor:pointer;transition:all var(--t);box-shadow:var(--shadow-xs)}
.ind-tab.active,.ind-tab:hover{background:var(--g-pale);border-color:var(--g-pale-2);color:var(--g-dark);box-shadow:var(--shadow-sm)}
.ind-tab.active{border-color:var(--g);font-weight:700}
.ind-panel{display:none}
.ind-panel.active{display:grid;grid-template-columns:1fr 1fr;gap:52px;align-items:center;background:var(--bg);border:1.5px solid var(--border);border-radius:var(--r);padding:44px;box-shadow:var(--shadow);animation:fadeSlide .3s ease}
@keyframes fadeSlide{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.ind-text h3{font-size:22px;font-weight:700;color:var(--txt);margin-bottom:10px}
.ind-text p{font-size:15px;color:var(--txt-3);margin-bottom:20px}
.ind-text ul li{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:var(--txt-2);padding:7px 0;border-bottom:1px solid var(--border)}
.ind-text li:last-child{border:none}
.ind-text li i{color:var(--g-dark);font-size:12px;margin-top:3px;flex-shrink:0}
.ind-chat{background:var(--bg-2);border-radius:20px;border:1.5px solid var(--border);overflow:hidden;box-shadow:var(--shadow-sm)}
.ind-chat-hdr{background:linear-gradient(135deg,var(--g-dark),var(--g));padding:14px 18px;display:flex;align-items:center;gap:10px}
.ind-chat-avatar{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.25);display:flex;align-items:center;justify-content:center;font-size:16px;color:#fff}
.ind-chat-hdr .cname{font-size:13px;font-weight:700;color:#fff;display:block}
.ind-chat-hdr .conline{font-size:10px;color:rgba(255,255,255,.8)}
.ind-chat-body{padding:18px 16px;display:flex;flex-direction:column;gap:9px}

/* STATS BAR */
.stats-bar{background:linear-gradient(135deg,var(--g-dark) 0%,#1A9E7A 100%);padding:32px 0}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.stat-item{text-align:center}
.stat-number{font-family:'Inter',sans-serif;font-size:30px;font-weight:800;color:#fff;letter-spacing:-.02em}
.stat-label{font-size:12px;color:rgba(255,255,255,.75);font-weight:500;margin-top:3px}

/* SUBPAGE HERO */
.subpage-hero{position:relative;overflow:hidden;background:linear-gradient(180deg,var(--g-pale) 0%,var(--bg) 100%);padding:72px 0 64px;border-bottom:1px solid var(--border)}
.subpage-hero::before{content:'';position:absolute;inset:0;pointer-events:none;background-image:radial-gradient(circle,#CBD5E1 1px,transparent 1px);background-size:24px 24px;opacity:.28;mask-image:radial-gradient(ellipse 80% 100% at 50% 0%,black 30%,transparent 100%)}
.subpage-hero-content{position:relative;z-index:2}
.hero-breadcrumb{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--txt-4);margin-bottom:20px;flex-wrap:wrap}
.hero-breadcrumb a{color:var(--txt-3);transition:color var(--t)}
.hero-breadcrumb a:hover{color:var(--g-dark)}
.hero-breadcrumb span:last-child{color:var(--g-dark);font-weight:600}
.hero-breadcrumb span{color:var(--txt-4)}
.subpage-hero h1{font-family:'Inter',sans-serif;font-size:clamp(28px,4vw,50px);font-weight:800;letter-spacing:-.02em;color:var(--txt);margin-bottom:14px}
.hero-subtitle{font-size:17px;color:var(--txt-3);max-width:640px;margin-bottom:28px}
.hero-features-compact{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:28px}
.hero-feature{display:flex;align-items:center;gap:7px;font-size:13px;font-weight:600;color:var(--txt-2);background:var(--bg);border:1.5px solid var(--border);padding:6px 14px;border-radius:100px;box-shadow:var(--shadow-xs)}
.hero-feature i{color:var(--g-dark);font-size:11px}
.hero-cta-compact{display:flex;flex-wrap:wrap;gap:12px}

/* PRICING */
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-bottom:28px}
.plan{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--r);padding:34px 26px;position:relative;box-shadow:var(--shadow-xs);transition:transform var(--t) var(--ease),box-shadow var(--t),border-color var(--t)}
.plan:hover{transform:translateY(-5px);box-shadow:var(--shadow-md)}
.plan-hot{border-color:var(--g);background:linear-gradient(160deg,var(--g-pale) 0%,var(--bg) 40%)}
.plan-hot:hover{box-shadow:0 12px 40px rgba(37,211,102,.18)}
.plan-badge{position:absolute;top:-14px;left:50%;transform:translateX(-50%);background:linear-gradient(135deg,var(--g-dark),var(--g));color:#fff;font-size:11px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;padding:5px 16px;border-radius:100px;white-space:nowrap;box-shadow:0 3px 10px rgba(37,211,102,.4)}
.plan-name{font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--txt-4);margin-bottom:5px}
.plan-tagline{font-size:14px;color:var(--txt-3);margin-bottom:18px;padding-bottom:18px;border-bottom:1px solid var(--border)}
.plan-price{margin-bottom:22px}
.plan-price strong{font-family:'Inter',sans-serif;font-size:38px;font-weight:800;color:var(--txt);letter-spacing:-.03em}
.plan-price span{font-size:14px;color:var(--txt-4)}
.plan-features{margin-bottom:28px}
.plan-features li{display:flex;align-items:flex-start;gap:9px;font-size:14px;color:var(--txt-2);padding:8px 0;border-bottom:1px solid var(--border)}
.plan-features li:last-child{border:none}
.plan-features li i{color:var(--g-dark);font-size:11px;margin-top:3px;flex-shrink:0}
.plan-btn{display:flex;justify-content:center;align-items:center;gap:8px;width:100%;padding:13px;border-radius:10px;font-family:'Inter',sans-serif;font-size:15px;font-weight:700;border:1.5px solid;cursor:pointer;transition:all var(--t) var(--ease);text-decoration:none}
.plan-btn-g{background:var(--g);color:#fff;border-color:var(--g);box-shadow:0 2px 8px rgba(37,211,102,.3)}
.plan-btn-g:hover{background:var(--g-mid);transform:translateY(-1px);box-shadow:var(--shadow-g)}
.plan-btn-o{background:var(--bg);color:var(--txt);border-color:var(--border-2);box-shadow:var(--shadow-xs)}
.plan-btn-o:hover{border-color:var(--txt);transform:translateY(-1px);box-shadow:var(--shadow-sm)}
.pricing-note{display:flex;align-items:center;gap:10px;background:var(--bg-2);border:1.5px solid var(--border);border-radius:var(--r-sm);padding:15px 20px;font-size:14px;color:var(--txt-3);flex-wrap:wrap}
.pricing-note i{color:var(--amber);flex-shrink:0}
.pricing-note strong{color:var(--txt-2)}
.pricing-note a{color:var(--g-dark);font-weight:700}

/* CAT EXPLAINER */
.cat-full-list{display:flex;flex-direction:column;gap:16px}
.cat-full{background:var(--bg);border-radius:var(--r);border:1.5px solid var(--border);border-left:4px solid var(--border);padding:30px 34px;display:grid;grid-template-columns:1fr auto;gap:36px;align-items:center;box-shadow:var(--shadow-xs);transition:transform var(--t),box-shadow var(--t)}
.cat-full:hover{transform:translateX(4px);box-shadow:var(--shadow)}
.cat-full.cm{border-left-color:var(--amber)}
.cat-full.cu{border-left-color:var(--blue)}
.cat-full.ca{border-left-color:var(--g)}
.cat-full.cs{border-left-color:var(--violet)}
.cat-pill{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:4px 12px;border-radius:100px;margin-bottom:10px}
.cm .cat-pill{background:var(--amber-pale);color:var(--amber)}
.cu .cat-pill{background:var(--blue-pale);color:var(--blue)}
.ca .cat-pill{background:var(--g-pale);color:var(--g-dark)}
.cs .cat-pill{background:var(--violet-pale);color:var(--violet)}
.cat-full h3{font-size:20px;font-weight:700;color:var(--txt);margin-bottom:8px}
.cat-full p{font-size:14px;color:var(--txt-3);margin-bottom:14px}
.cat-tags{display:flex;flex-wrap:wrap;gap:7px}
.cat-tag{font-size:12px;font-weight:500;background:var(--bg-2);color:var(--txt-3);padding:4px 12px;border-radius:100px;border:1px solid var(--border)}
.price-box{min-width:160px;text-align:center;border-radius:var(--r-sm);padding:22px 24px}
.price-box.cm-bg{background:var(--amber-pale);border:1.5px solid #FDE68A}
.price-box.cu-bg{background:var(--blue-pale);border:1.5px solid #BFDBFE}
.price-box.ca-bg{background:var(--g-pale);border:1.5px solid var(--g-pale-2)}
.price-box.cs-bg{background:var(--violet-pale);border:1.5px solid #DDD6FE}
.price-country{font-size:11px;font-weight:700;color:var(--txt-4);text-transform:uppercase;letter-spacing:.08em;margin-bottom:5px}
.price-big{font-family:'Inter',sans-serif;font-size:34px;font-weight:800;color:var(--txt);line-height:1}
.price-unit{font-size:12px;color:var(--txt-4);margin:4px 0 8px}
.price-note{font-size:11px;color:var(--txt-4)}

/* FAQ */
.faq-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:36px}
.faq-item{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--r-sm);overflow:hidden;box-shadow:var(--shadow-xs)}
.faq-q{width:100%;display:flex;justify-content:space-between;align-items:center;gap:16px;background:none;border:none;padding:20px 22px;font-family:'Inter',sans-serif;font-size:15px;font-weight:600;color:var(--txt);cursor:pointer;text-align:left;transition:background var(--t)}
.faq-q:hover{background:var(--bg-2)}
.faq-ico{width:28px;height:28px;border-radius:50%;flex-shrink:0;background:var(--g-pale);border:1.5px solid var(--g-pale-2);display:flex;align-items:center;justify-content:center;font-size:11px;color:var(--g-dark);transition:transform var(--t),background var(--t)}
.faq-a{display:none;padding:16px 22px 20px;font-size:15px;color:var(--txt-3);line-height:1.7;border-top:1px solid var(--border);background:var(--bg-2)}
.faq-a.open{display:block;animation:fadeSlide .25s ease}
.faq-item.open .faq-ico{background:var(--g-pale-2);transform:rotate(45deg)}
.faq-more{text-align:center;font-size:15px;color:var(--txt-3)}
.faq-more a{color:var(--g-dark);font-weight:700}

/* CTA BANNER */
.cta-banner{position:relative;overflow:hidden;text-align:center;background:linear-gradient(135deg,var(--g-dark) 0%,#1A9E7A 50%,#25D366 100%);padding:96px 0}
.cta-banner::before{content:'';position:absolute;inset:0;pointer-events:none;background-image:radial-gradient(circle,rgba(255,255,255,.08) 1px,transparent 1px);background-size:24px 24px}
.cta-inner{position:relative;z-index:2}
.cta-inner h2{font-family:'Inter',sans-serif;font-size:clamp(26px,4vw,48px);font-weight:800;color:#fff;margin-bottom:14px;letter-spacing:-.02em}
.cta-inner p{font-size:17px;color:rgba(255,255,255,.85);max-width:560px;margin:0 auto 36px}
.cta-btns{display:flex;justify-content:center;flex-wrap:wrap;gap:14px;margin-bottom:28px}
.cta-checks{display:flex;justify-content:center;flex-wrap:wrap;gap:22px}
.cta-check{display:flex;align-items:center;gap:7px;font-size:14px;color:rgba(255,255,255,.8)}
.cta-check i{color:rgba(255,255,255,.95)}
.cta-banner .btn-primary{background:#fff;color:var(--g-dark);border-color:#fff}
.cta-banner .btn-primary:hover{background:var(--g-pale)}
.cta-banner .btn-ghost,.cta-banner .btn-secondary{background:transparent;color:#fff;border-color:rgba(255,255,255,.5)}
.cta-banner .btn-ghost:hover,.cta-banner .btn-secondary:hover{background:rgba(255,255,255,.12);border-color:#fff}

/* CONTACT */
.contact-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:56px;align-items:start}
.contact-info-cards{display:flex;flex-direction:column;gap:14px}
.contact-card{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--r-sm);padding:20px;display:flex;align-items:flex-start;gap:16px;box-shadow:var(--shadow-xs);transition:border-color var(--t),box-shadow var(--t)}
.contact-card:hover{border-color:var(--g);box-shadow:var(--shadow-sm)}
.contact-card-icon{width:44px;height:44px;border-radius:11px;background:var(--g-pale);color:var(--g-dark);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.contact-card h4{font-size:14px;font-weight:700;color:var(--txt);margin-bottom:4px}
.contact-card a,.contact-card p{font-size:14px;color:var(--txt-3)}
.contact-card a:hover{color:var(--g-dark)}
.contact-form{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--r);padding:40px;box-shadow:var(--shadow)}
.contact-form h3{font-size:22px;font-weight:700;color:var(--txt);margin-bottom:24px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-group{margin-bottom:18px}
.form-group label{display:block;font-size:13px;font-weight:600;color:var(--txt-2);margin-bottom:7px}
.form-group input,.form-group textarea,.form-group select{width:100%;background:var(--bg);border:1.5px solid var(--border-2);border-radius:var(--r-sm);padding:11px 15px;color:var(--txt);font-size:14px;font-family:'Inter',sans-serif;transition:border-color var(--t),box-shadow var(--t);-webkit-appearance:none}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--g);box-shadow:0 0 0 3px var(--g-pale)}
.form-group input::placeholder,.form-group textarea::placeholder{color:var(--txt-4)}
.form-group textarea{resize:vertical;min-height:120px}

/* ABOUT */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start}
.about-features{display:flex;flex-direction:column;gap:20px}
.about-feature{display:flex;align-items:flex-start;gap:14px}
.about-feature-icon{width:42px;height:42px;border-radius:10px;background:var(--g-pale);color:var(--g-dark);display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0}
.about-feature h3{font-size:16px;font-weight:700;color:var(--txt);margin-bottom:4px}
.about-feature p{font-size:14px;color:var(--txt-3)}
.about-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.about-stat{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--r-sm);padding:22px 18px;text-align:center;box-shadow:var(--shadow-xs)}
.about-stat-val{font-family:'Inter',sans-serif;font-size:30px;font-weight:800;color:var(--g-dark);display:block;margin-bottom:4px}
.about-stat-lbl{font-size:13px;color:var(--txt-4)}
.timeline{display:flex;flex-direction:column}
.timeline-item{display:flex;gap:18px;padding-bottom:24px;position:relative}
.timeline-item::before{content:'';position:absolute;left:19px;top:36px;bottom:0;width:1px;background:var(--border)}
.timeline-item:last-child::before{display:none}
.timeline-dot{width:40px;height:40px;border-radius:50%;background:var(--g-pale);border:2px solid var(--g-pale-2);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;color:var(--g-dark);flex-shrink:0}
.timeline-content h4{font-size:15px;font-weight:700;color:var(--txt);margin-bottom:3px}
.timeline-content p{font-size:13px;color:var(--txt-3)}

/* FEATURE SECTIONS */
.feature-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;margin-bottom:64px}
.feature-grid.reverse{direction:rtl}
.feature-grid.reverse>*{direction:ltr}
.feature-badge{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--g-dark);background:var(--g-pale);border:1.5px solid var(--g-pale-2);padding:5px 13px;border-radius:100px;margin-bottom:16px}
.feature-content h2{font-family:'Inter',sans-serif;font-size:clamp(22px,3vw,34px);font-weight:800;color:var(--txt);margin-bottom:14px;letter-spacing:-.02em}
.feature-content p{font-size:15px;color:var(--txt-3);margin-bottom:20px;line-height:1.75}
.feature-content ul li{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:var(--txt-2);padding:8px 0;border-bottom:1px solid var(--border)}
.feature-content ul li:last-child{border:none}
.feature-content li i{color:var(--g-dark);font-size:12px;margin-top:3px;flex-shrink:0}
.feature-visual{background:var(--bg-2);border:1.5px solid var(--border);border-radius:var(--r);padding:32px;min-height:280px;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm)}

/* FOOTER */
.footer{background:var(--txt);padding:72px 0 0}
.footer-grid{display:grid;grid-template-columns:1.8fr 1fr 1fr 1fr 1fr;gap:36px;padding-bottom:56px;border-bottom:1px solid rgba(255,255,255,.1)}
.footer-logo-row{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.footer-logo-icon{width:36px;height:36px;border-radius:9px;background:linear-gradient(135deg,var(--g-dark),var(--g));display:flex;align-items:center;justify-content:center;font-size:17px;color:#fff;font-weight:900}
.footer-logo-text{font-family:'Inter',sans-serif;font-size:17px;font-weight:800;color:#fff}
.footer-logo-text span{color:var(--g)}
.footer-desc{font-size:14px;color:rgba(255,255,255,.5);line-height:1.75;margin-bottom:18px}
.footer-contacts{display:flex;flex-direction:column;gap:8px}
.footer-ci{display:flex;align-items:flex-start;gap:8px;font-size:13px;color:rgba(255,255,255,.4)}
.footer-ci strong{color:rgba(255,255,255,.65);flex-shrink:0}
.footer-ci a{color:rgba(255,255,255,.5);transition:color var(--t)}
.footer-ci a:hover{color:var(--g)}
.footer-col h5{font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.35);margin-bottom:18px}
.footer-col ul li{margin-bottom:10px}
.footer-col ul a{font-size:14px;color:rgba(255,255,255,.45);transition:color var(--t)}
.footer-col ul a:hover{color:#fff}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding:22px 0;flex-wrap:wrap;gap:12px}
.footer-copy{font-size:13px;color:rgba(255,255,255,.3)}
.footer-social{display:flex;gap:10px}
.footer-social a{width:34px;height:34px;border-radius:8px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;font-size:14px;color:rgba(255,255,255,.4);transition:all var(--t)}
.footer-social a:hover{background:rgba(37,211,102,.15);border-color:rgba(37,211,102,.4);color:var(--g)}

/* SCROLL REVEAL */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .5s ease,transform .5s ease}
.reveal.visible{opacity:1;transform:none}

/* RESPONSIVE */
@media(max-width:1024px){
  .hero-inner{grid-template-columns:1fr;gap:48px}
  .hero-right{display:none}
  .cats-grid{grid-template-columns:repeat(2,1fr)}
  .svc-grid{grid-template-columns:1fr 1fr}
  .why-inner{grid-template-columns:1fr;gap:48px}
  .ind-panel.active{grid-template-columns:1fr;gap:32px}
  .pricing-grid{grid-template-columns:1fr 1fr}
  .feature-grid{grid-template-columns:1fr}
  .feature-grid.reverse{direction:ltr}
  .contact-grid{grid-template-columns:1fr}
  .about-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .cat-full{grid-template-columns:1fr}
}
@media(max-width:768px){
  section{padding:64px 0}
  .hero{padding:80px 0 56px}
  .wrap,.container{padding:0 20px}
  .nav-links{display:none}
  .cats-grid{grid-template-columns:1fr 1fr}
  .svc-grid{grid-template-columns:1fr}
  .why-grid{grid-template-columns:1fr 1fr}
  .pricing-grid{grid-template-columns:1fr}
  .faq-grid{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .ind-panel.active{padding:28px 22px}
}
@media(max-width:480px){
  .cats-grid{grid-template-columns:1fr}
  .why-grid{grid-template-columns:1fr}
  .about-stats{grid-template-columns:1fr 1fr}
}

/* ══════════════════════════════════════════
   MEGA DROPDOWN NAV
══════════════════════════════════════════ */
.nav-dropdown-wrap { position:relative; }
.nav-dropdown-btn {
  display:flex; align-items:center;
  font-family:'Inter',sans-serif; font-size:14px; font-weight:500;
  color:var(--txt-3); padding:7px 12px; border-radius:8px;
  background:none; border:none; cursor:pointer;
  transition:color var(--t),background var(--t);
}
.nav-dropdown-btn:hover,
.nav-dropdown-btn.active { color:var(--g-dark); background:var(--g-pale); }

.nav-mega {
  display:none;
  position:fixed;
  top:66px;
  left:50%;
  transform:translateX(-50%);
  width:min(1100px, 96vw);
  background:#fff;
  border:1.5px solid var(--border);
  border-radius:var(--r);
  box-shadow:0 20px 60px rgba(15,23,42,.14),0 4px 16px rgba(15,23,42,.07);
  z-index:999;
}
/* Inner wrapper handles the rounded-corner clipping instead of the menu itself */
.nav-mega .mega-inner { border-radius:var(--r); overflow:hidden; }
/* Invisible upward extension so the menu and nav connect with no dead zone */
.nav-mega::before {
  content:'';
  position:absolute;
  top:-14px; left:0; right:0;
  height:14px;
  background:transparent;
}
.nav-dropdown-wrap:hover .nav-mega,
.nav-dropdown-wrap:focus-within .nav-mega { display:block; animation:megaIn .18s ease; }
@keyframes megaIn { from{opacity:0;transform:translateX(-50%) translateY(-8px)} to{opacity:1;transform:translateX(-50%) translateY(0)} }

.mega-inner {
  display:grid;
  grid-template-columns:1fr 1fr 1fr 1fr;
  gap:0;
  align-items:start;
}
.mega-col {
  padding:22px 18px;
  border-right:1px solid var(--border);
  min-height:100%;
}
.mega-col:last-child { border-right:none; }
.mega-col-title {
  font-size:10px; font-weight:700; letter-spacing:.12em; text-transform:uppercase;
  color:var(--txt-4); margin-bottom:10px; padding-bottom:8px;
  border-bottom:1px solid var(--border);
}
.mega-link {
  display:flex; align-items:center; gap:10px;
  padding:8px 8px; border-radius:var(--r-sm);
  transition:background var(--t); margin-bottom:1px;
  color:var(--txt);
}
.mega-link:hover { background:var(--bg-2); }
.mega-link-icon {
  width:30px; height:30px; border-radius:7px; flex-shrink:0;
  display:flex; align-items:center; justify-content:center; font-size:13px;
}
.mega-link strong { display:block; font-size:12.5px; font-weight:600; color:var(--txt); line-height:1.2; }
.mega-link span   { display:block; font-size:11px; color:var(--txt-4); margin-top:1px; line-height:1.3; }

/* Feature page shared */
.feat-hero-img { width:100%; max-width:480px; margin:0 auto; }
.feat-steps { display:flex; flex-direction:column; gap:0; counter-reset:steps; }
.feat-step {
  display:flex; gap:20px; padding-bottom:32px;
  position:relative; counter-increment:steps;
}
.feat-step::before { content:''; position:absolute; left:19px; top:44px; bottom:0; width:1px; background:var(--border); }
.feat-step:last-child::before { display:none; }
.feat-step-num {
  width:40px; height:40px; border-radius:50%; flex-shrink:0;
  background:var(--g-pale); border:2px solid var(--g-pale-2);
  display:flex; align-items:center; justify-content:center;
  font-size:15px; font-weight:800; color:var(--g-dark);
}
.feat-step h4 { font-size:16px; font-weight:700; color:var(--txt); margin-bottom:5px; }
.feat-step p  { font-size:14px; color:var(--txt-3); line-height:1.7; }

.usecase-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.usecase-card {
  background:var(--bg); border:1.5px solid var(--border);
  border-radius:var(--r); padding:28px 22px;
  box-shadow:var(--shadow-xs);
  transition:transform var(--t),box-shadow var(--t),border-color var(--t);
}
.usecase-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-md); border-color:var(--g-pale-2); }
.usecase-icon { font-size:28px; margin-bottom:14px; }
.usecase-card h4 { font-size:15px; font-weight:700; color:var(--txt); margin-bottom:7px; }
.usecase-card p  { font-size:13.5px; color:var(--txt-3); line-height:1.65; }

/* Comparison table */
.compare-table { width:100%; border-collapse:collapse; font-size:14px; }
.compare-table th { background:var(--txt); color:#fff; padding:14px 16px; text-align:left; font-weight:700; }
.compare-table th:not(:first-child) { text-align:center; }
.compare-table td { padding:13px 16px; border-bottom:1px solid var(--border); }
.compare-table td:not(:first-child) { text-align:center; }
.compare-table tr:nth-child(even) td { background:var(--bg-2); }
.compare-table .yes { color:var(--g-dark); font-weight:700; }
.compare-table .no  { color:var(--txt-4); }
.compare-table .col-iws { background:rgba(37,211,102,.06); }

@media(max-width:1080px) {
  .nav-mega { width:98vw; }
  .mega-inner { grid-template-columns:1fr 1fr; }
}
@media(max-width:900px) {
  .nav-mega { display:none !important; }
  .usecase-grid { grid-template-columns:1fr 1fr; }
}
@media(max-width:600px) { .usecase-grid { grid-template-columns:1fr; } }

/* ── MEGA MENU HOVER FIX ─────────────────────────
   The gap between the nav button and the dropdown
   causes mouseout events — bridge it with a pseudo
   element that covers the gap seamlessly.
──────────────────────────────────────────────── */
.nav-dropdown-wrap { padding-bottom: 0; }

/* Show mega on hover/focus of the wrapper OR hovering the mega itself */
.nav-dropdown-wrap:hover .nav-mega,
.nav-dropdown-wrap:focus-within .nav-mega,
.nav-mega:hover {
  display: block !important;
  animation: megaIn .18s ease;
}

/* Invisible bridge that fills the ENTIRE gap between the button
   and the fixed-position mega menu. The wrapper's ::after extends
   downward from the button all the way to the menu top (~66px),
   so the mouse never leaves a hoverable area while travelling down. */
.nav-dropdown-wrap::after {
  content: '';
  position: absolute;
  top: 100%;
  left: -20px;
  right: -20px;
  height: 28px;   /* spans button bottom down to the mega menu */
  background: transparent;
  z-index: 998;
}
/* Only active when the wrapper is hovered, so it doesn't block other nav items */
.nav-dropdown-wrap:not(:hover)::after { display: none; }

/* Legal page styles */
.legal-wrap { max-width: 860px; margin: 0 auto; padding: 56px 32px; }
.legal-meta {
  background: var(--bg-2); border: 1.5px solid var(--border);
  border-radius: var(--r-sm); padding: 14px 20px;
  font-size: 13px; color: var(--txt-3);
  margin-bottom: 32px; display: flex; gap: 24px; flex-wrap: wrap;
}
.legal-meta strong { color: var(--txt-2); }
.legal-warn {
  background: #FFF7ED; border: 1.5px solid #FED7AA;
  border-radius: var(--r-sm); padding: 14px 18px;
  font-size: 14px; color: #9A3412; line-height: 1.7; margin-bottom: 24px;
}
.legal-toc {
  background: var(--bg-2); border: 1.5px solid var(--border);
  border-radius: var(--r-sm); padding: 24px; margin-bottom: 36px;
}
.legal-toc h4 { font-size: 14px; font-weight: 700; color: var(--txt); margin-bottom: 14px; }
.legal-toc ol { padding-left: 20px; margin: 0; columns: 2; }
.legal-toc ol li { font-size: 13px; color: var(--txt-3); padding: 3px 0; break-inside: avoid; }
.legal-toc ol li a { color: var(--g-dark); }
.legal-section { margin-bottom: 28px; padding-bottom: 28px; border-bottom: 1px solid var(--border); }
.legal-section:last-child { border-bottom: none; }
.legal-section h4 {
  font-family: 'Inter', sans-serif; font-size: 15px; font-weight: 700;
  color: var(--g-dark); margin: 0 0 12px; padding-bottom: 10px;
  border-bottom: 2px solid var(--g-pale-2);
}
.legal-section p { font-size: 14px; color: var(--txt-3); line-height: 1.8; margin: 0 0 10px; }
.legal-section ul, .legal-section ol { padding-left: 22px; margin: 0 0 12px; }
.legal-section ul li, .legal-section ol li { font-size: 14px; color: var(--txt-3); line-height: 1.8; padding: 2px 0; }
.legal-section a { color: var(--g-dark); font-weight: 600; }
.legal-highlight {
  background: var(--g-pale); border-left: 4px solid var(--g);
  padding: 13px 18px; border-radius: 0 var(--r-sm) var(--r-sm) 0;
  margin: 12px 0; font-size: 14px; color: var(--txt-3); line-height: 1.75;
}
.legal-highlight strong { color: var(--g-dark); }
.legal-important {
  background: #FFF1F2; border-left: 4px solid #E11D48;
  padding: 13px 18px; border-radius: 0 var(--r-sm) var(--r-sm) 0;
  margin: 12px 0; font-size: 14px; color: #9F1239; line-height: 1.75;
}
.legal-important strong { color: #BE123C; }
.legal-contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; margin-top: 20px; }
.legal-office { background: var(--bg-2); border: 1.5px solid var(--border); border-radius: var(--r-sm); padding: 20px; }
.legal-office h5 { font-size: 13px; font-weight: 700; color: var(--txt); margin: 0 0 10px; }
.legal-office p { font-size: 13px; color: var(--txt-3); line-height: 1.7; margin: 0; }
.legal-office a { color: var(--g-dark); }
@media(max-width:640px) {
  .legal-wrap { padding: 36px 18px; }
  .legal-toc ol { columns: 1; }
  .legal-contact-grid { grid-template-columns: 1fr; }
}

/* ══════════════════════════════════════════════
   BURGER BUTTON
══════════════════════════════════════════════ */
.nav-burger {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 40px; height: 40px;
  background: var(--bg-2);
  border: 1.5px solid var(--border);
  border-radius: 9px;
  cursor: pointer;
  padding: 8px 9px;
  transition: background var(--t), border-color var(--t);
  flex-shrink: 0;
}
.nav-burger:hover { background: var(--g-pale); border-color: var(--g-pale-2); }
.nav-burger span {
  display: block;
  width: 100%; height: 2px;
  background: var(--txt);
  border-radius: 2px;
  transition: transform .28s var(--ease), opacity .2s, width .2s;
  transform-origin: center;
}
/* Animate to X when open */
.nav-burger.is-open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-burger.is-open span:nth-child(2) { opacity: 0; width: 0; }
.nav-burger.is-open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ══════════════════════════════════════════════
   MOBILE OVERLAY
══════════════════════════════════════════════ */
.mob-overlay {
  position: fixed; inset: 0;
  background: rgba(15,23,42,.45);
  backdrop-filter: blur(3px);
  z-index: 998;
  opacity: 0;
  pointer-events: none;
  visibility: hidden;
  transition: opacity .3s var(--ease), visibility .3s var(--ease);
}
.mob-overlay.show { opacity: 1; pointer-events: all; visibility: visible; }

/* ══════════════════════════════════════════════
   MOBILE SLIDE-IN MENU
══════════════════════════════════════════════ */
.mob-menu {
  position: fixed;
  top: 0; right: 0; bottom: 0;
  width: min(340px, 88vw);
  background: #fff;
  z-index: 999;
  transform: translateX(100%);
  transition: transform .32s var(--ease);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  box-shadow: -8px 0 40px rgba(15,23,42,.12);
}
.mob-menu.show { transform: translateX(0); }

/* Mob header */
.mob-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 20px;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.mob-close {
  width: 36px; height: 36px;
  border-radius: 8px;
  background: var(--bg-2);
  border: 1.5px solid var(--border);
  display: flex; align-items: center; justify-content: center;
  font-size: 15px; color: var(--txt-3);
  cursor: pointer;
  transition: all var(--t);
}
.mob-close:hover { background: #FEF2F2; border-color: #FECACA; color: #DC2626; }

/* WA CTA strip */
.mob-wa { padding: 14px 20px; border-bottom: 1px solid var(--border); flex-shrink: 0; }
.mob-wa-btn {
  display: flex; align-items: center; justify-content: center;
  gap: 8px; width: 100%;
  background: var(--g); color: #fff;
  font-size: 15px; font-weight: 700;
  padding: 13px; border-radius: 10px;
  box-shadow: 0 2px 10px rgba(37,211,102,.3);
  transition: background var(--t), transform var(--t);
}
.mob-wa-btn:hover { background: var(--g-mid); transform: translateY(-1px); }
.mob-wa-btn i { font-size: 17px; }

/* Nav scroll area */
.mob-nav {
  flex: 1;
  overflow-y: auto;
  padding: 10px 12px 20px;
  -webkit-overflow-scrolling: touch;
}
.mob-nav::-webkit-scrollbar { width: 4px; }
.mob-nav::-webkit-scrollbar-thumb { background: var(--border); border-radius: 4px; }

/* Regular link */
.mob-link {
  display: flex; align-items: center; gap: 12px;
  font-size: 15px; font-weight: 600; color: var(--txt-2);
  padding: 12px 14px;
  border-radius: 10px;
  transition: background var(--t), color var(--t);
  margin-bottom: 2px;
}
.mob-link i { width: 18px; text-align: center; color: var(--txt-4); font-size: 14px; }
.mob-link:hover { background: var(--bg-2); color: var(--txt); }
.mob-link:hover i { color: var(--g-dark); }
.mob-active { background: var(--g-pale) !important; color: var(--g-dark) !important; }
.mob-active i { color: var(--g-dark) !important; }

/* Accordion trigger */
.mob-accordion {
  display: flex; align-items: center; justify-content: space-between;
  width: 100%; padding: 12px 14px;
  background: none; border: none;
  font-family: 'Inter', sans-serif;
  font-size: 15px; font-weight: 600; color: var(--txt-2);
  border-radius: 10px;
  cursor: pointer;
  transition: background var(--t), color var(--t);
  margin-bottom: 2px;
}
.mob-accordion span { display: flex; align-items: center; gap: 12px; }
.mob-accordion span i { width: 18px; text-align: center; font-size: 14px; }
.mob-accordion:hover { background: var(--bg-2); color: var(--txt); }
.mob-acc-icon { font-size: 11px; color: var(--txt-4); transition: transform .25s var(--ease); flex-shrink: 0; }
.mob-acc-open .mob-acc-icon,
.mob-accordion.mob-acc-open .mob-acc-icon { transform: rotate(180deg); color: var(--g-dark); }
.mob-accordion.mob-acc-open { background: var(--g-pale); color: var(--g-dark); }

/* Accordion body */
.mob-acc-body {
  display: none;
  padding: 4px 0 6px 14px;
  border-left: 2px solid var(--g-pale-2);
  margin: 0 0 4px 20px;
}
.mob-acc-body.open { display: block; animation: accOpen .22s ease; }
@keyframes accOpen { from{opacity:0;transform:translateY(-6px)} to{opacity:1;transform:none} }

.mob-acc-section {
  font-size: 10px; font-weight: 700;
  letter-spacing: .1em; text-transform: uppercase;
  color: var(--txt-4);
  padding: 10px 10px 6px;
}
.mob-sub-link {
  display: flex; align-items: center; gap: 10px;
  font-size: 14px; font-weight: 500; color: var(--txt-2);
  padding: 9px 10px;
  border-radius: 8px;
  transition: background var(--t), color var(--t);
  margin-bottom: 1px;
}
.mob-sub-link:hover { background: var(--bg-2); color: var(--g-dark); }
.mob-sub-icon {
  width: 28px; height: 28px; border-radius: 7px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: 12px;
}

/* Mob footer */
.mob-menu .mob-footer {
  flex-shrink: 0;
  padding: 14px 20px;
  border-top: 1px solid var(--border);
  display: flex; align-items: center; gap: 10px;
  font-size: 12px;
}
.mob-menu .mob-footer a { color: var(--txt-4); transition: color var(--t); }
.mob-menu .mob-footer a:hover { color: var(--g-dark); }
.mob-menu .mob-footer span { color: var(--border); }

/* ══════════════════════════════════════════════
   RESPONSIVE — show burger, hide desktop links
══════════════════════════════════════════════ */
@media(max-width:768px) {
  .nav-links { display: none !important; }
  .nav-burger { display: flex !important; }
  /* Keep WA button hidden on very small screens to save space */
  .btn-nav-wa { display: none; }
}
@media(max-width:400px) {
  .mob-menu { width: 100vw; }
}
/* Prevent body scroll when menu open */
body.mob-open { overflow: hidden; }

/* Desktop dropdown: JS-toggled open state (click/touch) */
.nav-dropdown-wrap.dd-open .nav-mega { display: block !important; animation: megaIn .18s ease; }
.nav-dropdown-wrap.dd-open .nav-chev { transform: rotate(180deg); color: var(--g-dark); }
.nav-chev { transition: transform .2s var(--ease); display: inline-block; }

/* ══════════════════════════════════════════
   PRICING PAGE — What's Included grid
══════════════════════════════════════════ */
.incl-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-bottom: 36px;
}
.incl-item {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  background: var(--bg);
  border: 1.5px solid var(--border);
  border-radius: var(--r-sm);
  padding: 18px 18px;
  box-shadow: var(--shadow-xs);
  transition: border-color var(--t), box-shadow var(--t);
}
.incl-item:hover { border-color: var(--g-pale-2); box-shadow: var(--shadow-sm); }
.incl-icon {
  width: 34px; height: 34px; flex-shrink: 0;
  background: var(--g-pale);
  border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  font-size: 15px; color: var(--g-dark);
}
.incl-title { font-size: 14px; font-weight: 700; color: var(--txt); margin-bottom: 3px; }
.incl-desc  { font-size: 13px; color: var(--txt-3); line-height: 1.55; }

/* No fees banner */
.no-fees-banner {
  display: flex;
  align-items: center;
  background: var(--g-pale);
  border: 2px solid var(--g-pale-2);
  border-radius: var(--r);
  padding: 24px 32px;
  flex-wrap: wrap;
  gap: 0;
}
.no-fees-item {
  display: flex; align-items: center; gap: 14px;
  flex: 1; min-width: 180px;
  padding: 8px 0;
}
.no-fees-item i {
  font-size: 22px; color: #DC2626; flex-shrink: 0;
}
.no-fees-item strong { display: block; font-size: 15px; font-weight: 700; color: var(--txt); }
.no-fees-item span   { display: block; font-size: 12px; color: var(--txt-3); margin-top: 2px; }
.no-fees-div {
  width: 1px; height: 48px;
  background: var(--g-pale-2);
  margin: 0 24px;
  flex-shrink: 0;
}

/* Steps grid */
.steps-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}
.step-card {
  background: var(--bg);
  border: 1.5px solid var(--border);
  border-radius: var(--r);
  padding: 28px 22px;
  position: relative;
  box-shadow: var(--shadow-xs);
  transition: transform var(--t), box-shadow var(--t), border-color var(--t);
}
.step-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: var(--g-pale-2); }
.step-num {
  position: absolute; top: -14px; left: 22px;
  width: 28px; height: 28px; border-radius: 50%;
  background: var(--g); color: #fff;
  font-size: 13px; font-weight: 800;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 2px 8px rgba(37,211,102,.35);
}
.step-icon {
  font-size: 26px; color: var(--g-dark);
  margin-bottom: 14px; margin-top: 8px;
}
.step-card h4 { font-size: 15px; font-weight: 700; color: var(--txt); margin-bottom: 8px; }
.step-card p  { font-size: 13px; color: var(--txt-3); line-height: 1.65; margin-bottom: 14px; }
.step-link {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: 13px; font-weight: 700; color: var(--g-dark);
  transition: gap var(--t);
}
.step-link:hover { gap: 9px; }

/* International box */
.intl-box {
  display: flex; align-items: center; gap: 28px;
  background: var(--bg);
  border: 1.5px solid var(--border);
  border-radius: var(--r);
  padding: 36px 40px;
  box-shadow: var(--shadow);
  flex-wrap: wrap;
}
.intl-icon { font-size: 40px; color: var(--g-dark); flex-shrink: 0; }
.intl-text { flex: 1; min-width: 240px; }
.intl-text h3 { font-size: 20px; font-weight: 700; color: var(--txt); margin-bottom: 8px; }
.intl-text p  { font-size: 15px; color: var(--txt-3); }

@media(max-width:1024px) { .steps-grid { grid-template-columns: repeat(2,1fr); } }
@media(max-width:768px)  {
  .incl-grid { grid-template-columns: 1fr 1fr; }
  .steps-grid { grid-template-columns: 1fr 1fr; }
  .no-fees-banner { flex-direction: column; gap: 16px; padding: 24px; }
  .no-fees-div { width: 100%; height: 1px; margin: 0; }
  .intl-box { flex-direction: column; text-align: center; padding: 28px 24px; }
}
@media(max-width:480px) {
  .incl-grid { grid-template-columns: 1fr; }
  .steps-grid { grid-template-columns: 1fr; }
}

/* ══════════════════════════════════════════
   HOMEPAGE — 4 rate cards (snap-4)
══════════════════════════════════════════ */
.snap-4-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
  margin-bottom: 24px;
}
.snap-4 {
  background: var(--bg);
  border: 1.5px solid var(--border);
  border-radius: var(--r);
  overflow: hidden;
  box-shadow: var(--shadow-xs);
  transition: transform var(--t), box-shadow var(--t);
}
.snap-4:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.snap-4-top {
  padding: 24px 20px 20px;
  border-bottom: 1.5px solid;
  text-align: center;
}
.snap-4-label {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 11px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase;
  margin-bottom: 12px;
}
.snap-4-price {
  font-family: 'Inter', sans-serif;
  font-size: 36px; font-weight: 800; color: var(--txt);
  letter-spacing: -.02em; line-height: 1;
  margin-bottom: 4px;
}
.snap-4-unit { font-size: 12px; color: var(--txt-4); font-weight: 500; }
.snap-4 > p {
  padding: 16px 18px;
  font-size: 13px; color: var(--txt-3); line-height: 1.6;
  margin: 0;
}

/* No-fees strip */
.snap-no-fees {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 10px 28px;
  background: var(--g-pale);
  border: 1.5px solid var(--g-pale-2);
  border-radius: var(--r-sm);
  padding: 18px 28px;
  font-size: 14px; font-weight: 600; color: var(--txt-2);
}
.snap-no-fees i { margin-right: 5px; }
.snap-more-link {
  color: var(--g-dark); font-weight: 700;
  display: inline-flex; align-items: center; gap: 5px;
  transition: gap var(--t);
}
.snap-more-link:hover { gap: 9px; }

@media(max-width:900px)  { .snap-4-grid { grid-template-columns: repeat(2,1fr); } }
@media(max-width:480px)  { .snap-4-grid { grid-template-columns: 1fr 1fr; } }
@media(max-width:360px)  { .snap-4-grid { grid-template-columns: 1fr; } }

/* ══════════════════════════════════════════
   ADD-ON MODULES — pricing page
══════════════════════════════════════════ */
.addon-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-bottom: 24px;
}
.addon-card {
  background: var(--bg);
  border: 1.5px solid var(--border);
  border-radius: var(--r);
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  box-shadow: var(--shadow-xs);
  transition: transform var(--t), box-shadow var(--t), border-color var(--t);
}
.addon-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: var(--amber); }
.addon-icon {
  width: 48px; height: 48px; border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  font-size: 20px; flex-shrink: 0;
}
.addon-body { flex: 1; }
.addon-body h4 { font-size: 15px; font-weight: 700; color: var(--txt); margin-bottom: 7px; }
.addon-body p  { font-size: 13px; color: var(--txt-3); line-height: 1.65; margin-bottom: 12px; }
.addon-tags { display: flex; flex-wrap: wrap; gap: 5px; }
.addon-tags span {
  font-size: 11px; font-weight: 600;
  background: var(--bg-2); color: var(--txt-4);
  border: 1px solid var(--border);
  padding: 3px 9px; border-radius: 100px;
}
.addon-cta {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 13px; font-weight: 700; color: var(--g-dark);
  transition: gap var(--t);
  margin-top: auto;
}
.addon-cta:hover { gap: 10px; }

.addon-note {
  display: flex; align-items: center; gap: 14px;
  background: var(--amber-pale);
  border: 1.5px solid #FDE68A;
  border-radius: var(--r-sm);
  padding: 16px 20px;
  font-size: 14px; color: #78350F;
  flex-wrap: wrap;
}
.addon-note i { color: var(--amber); font-size: 16px; flex-shrink: 0; }
.addon-note strong { color: #92400E; }
.addon-note span { flex: 1; line-height: 1.6; }

@media(max-width:1024px) { .addon-grid { grid-template-columns: repeat(2,1fr); } }
@media(max-width:600px)  { .addon-grid { grid-template-columns: 1fr; } }

/* ══════════════════════════════════════════
   WHY IWSAPP — local grid
══════════════════════════════════════════ */
.why-local-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-bottom: 0;
}
.why-local-card {
  background: var(--bg);
  border: 1.5px solid var(--border);
  border-radius: var(--r);
  padding: 28px 24px;
  box-shadow: var(--shadow-xs);
  transition: transform var(--t), box-shadow var(--t), border-color var(--t);
}
.why-local-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: var(--g-pale-2); }
.why-local-icon {
  width: 48px; height: 48px; border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  font-size: 20px; margin-bottom: 16px;
}
.why-local-card h4 { font-size: 15px; font-weight: 700; color: var(--txt); margin-bottom: 8px; }
.why-local-card p  { font-size: 13.5px; color: var(--txt-3); line-height: 1.7; }

/* Fit cards */
.fit-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.fit-card { background: var(--bg); border: 1.5px solid var(--border); border-radius: var(--r); padding: 32px 28px; box-shadow: var(--shadow-xs); }
.fit-yes  { border-color: var(--g-pale-2); background: linear-gradient(160deg, var(--g-pale) 0%, var(--bg) 40%); }
.fit-consider { border-color: #FDE68A; background: linear-gradient(160deg, var(--amber-pale) 0%, var(--bg) 40%); }
.fit-header {
  display: flex; align-items: center; gap: 8px;
  font-size: 15px; font-weight: 700; margin-bottom: 18px;
}
.fit-yes .fit-header { color: var(--g-dark); }
.fit-consider .fit-header { color: #92400E; }
.fit-card ul li { display: flex; align-items: flex-start; gap: 10px; font-size: 14px; color: var(--txt-2); padding: 8px 0; border-bottom: 1px solid var(--border); }
.fit-card ul li:last-child { border: none; }
.fit-card ul li::before { content: '–'; color: var(--txt-4); flex-shrink: 0; }

/* ══════════════════════════════════════════
   COMPARISON TABLE (shared: both pages)
══════════════════════════════════════════ */
.cmp-wrap { overflow-x: auto; border-radius: var(--r); box-shadow: var(--shadow); margin-bottom: 20px; }
.cmp-table {
  width: 100%; border-collapse: collapse;
  font-size: 14px; min-width: 680px;
}
.cmp-table thead tr { background: var(--txt); }
.cmp-table th {
  padding: 16px 18px; text-align: left;
  color: #fff; font-weight: 700; font-size: 13px;
  line-height: 1.4;
}
.cmp-table th small { display: block; font-weight: 400; opacity: .7; font-size: 11px; margin-top: 3px; }
.cmp-feature-col { width: 30%; }
.cmp-global-col  { width: 35%; background: rgba(255,255,255,.06); }
.cmp-iws-col     { width: 35%; background: rgba(37,211,102,.12); }
.cmp-table tbody tr { border-bottom: 1px solid var(--border); }
.cmp-table tbody tr.alt td { background: var(--bg-2); }
.cmp-table tbody tr:not(.alt) td { background: var(--bg); }
.cmp-feature { padding: 14px 18px; font-weight: 600; color: var(--txt-2); font-size: 13.5px; }
.cmp-global  {
  padding: 14px 18px; color: var(--txt-3); font-size: 13px; line-height: 1.5;
}
.cmp-global .fa-minus-circle { color: #DC2626; margin-right: 5px; flex-shrink: 0; }
.cmp-iws {
  padding: 14px 18px; color: var(--txt-2); font-size: 13px;
  font-weight: 500; line-height: 1.5;
}
.cmp-iws .fa-check-circle { color: var(--g-dark); margin-right: 5px; flex-shrink: 0; }
.cmp-note {
  display: flex; align-items: flex-start; gap: 10px;
  background: var(--bg-2); border: 1.5px solid var(--border);
  border-radius: var(--r-sm); padding: 14px 18px;
  font-size: 13px; color: var(--txt-4); line-height: 1.6;
}
.cmp-note i { color: var(--txt-4); flex-shrink: 0; margin-top: 1px; }

/* ══════════════════════════════════════════
   API VS APP PAGE
══════════════════════════════════════════ */
.vsa-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 28px;
  margin-bottom: 0;
}
.vsa-card {
  background: var(--bg);
  border: 1.5px solid var(--border);
  border-radius: var(--r);
  padding: 32px 28px;
  position: relative;
  box-shadow: var(--shadow-xs);
}
.vsa-api {
  border-color: var(--g);
  background: linear-gradient(160deg, var(--g-pale) 0%, var(--bg) 40%);
}
.vsa-badge {
  position: absolute; top: -14px; left: 50%; transform: translateX(-50%);
  background: linear-gradient(135deg, var(--g-dark), var(--g));
  color: #fff; font-size: 11px; font-weight: 800;
  letter-spacing: .05em; text-transform: uppercase;
  padding: 5px 18px; border-radius: 100px;
  white-space: nowrap; box-shadow: 0 3px 10px rgba(37,211,102,.35);
}
.vsa-card-header { display: flex; align-items: center; gap: 14px; margin-bottom: 14px; }
.vsa-icon {
  width: 48px; height: 48px; border-radius: 12px;
  background: var(--bg-2); color: var(--g-dark);
  display: flex; align-items: center; justify-content: center;
  font-size: 22px; flex-shrink: 0;
}
.vsa-type { font-size: 11px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--txt-4); margin-bottom: 3px; }
.vsa-card h3 { font-size: 20px; font-weight: 700; color: var(--txt); }
.vsa-desc { font-size: 14px; color: var(--txt-3); line-height: 1.7; margin-bottom: 14px; }
.vsa-best {
  background: var(--bg-2); border-radius: var(--r-sm);
  padding: 12px 15px; font-size: 13px; color: var(--txt-2);
  margin-bottom: 20px; line-height: 1.6;
}
.vsa-best strong { color: var(--txt); }
.vsa-features { margin-bottom: 20px; }
.vsa-features li {
  display: flex; align-items: flex-start; gap: 9px;
  font-size: 13.5px; color: var(--txt-2);
  padding: 7px 0; border-bottom: 1px solid var(--border);
}
.vsa-features li:last-child { border: none; }
.vsa-features .fa-check { color: var(--g-dark); font-size: 11px; margin-top: 3px; flex-shrink: 0; }
.vsa-features .fa-minus  { color: var(--txt-4); font-size: 11px; margin-top: 3px; flex-shrink: 0; }
.text-warn { color: var(--txt-4) !important; }
.vsa-verdict {
  font-size: 13px; font-weight: 600; padding: 12px 15px;
  border-radius: var(--r-sm); line-height: 1.5;
}
.vsa-verdict-app { background: var(--bg-2); color: var(--txt-3); border: 1px solid var(--border); }
.vsa-verdict-api { background: var(--g-pale); color: var(--g-dark); border: 1.5px solid var(--g-pale-2); }

/* Signs grid */
.signs-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}
.sign-item {
  display: flex; align-items: flex-start; gap: 12px;
  background: var(--bg); border: 1.5px solid var(--border);
  border-radius: var(--r-sm); padding: 16px;
  box-shadow: var(--shadow-xs);
  transition: border-color var(--t), box-shadow var(--t);
}
.sign-item:hover { border-color: var(--g-pale-2); box-shadow: var(--shadow-sm); }
.sign-icon {
  width: 32px; height: 32px; border-radius: 8px;
  background: var(--amber-pale); color: var(--amber);
  display: flex; align-items: center; justify-content: center;
  font-size: 14px; flex-shrink: 0;
}
.sign-item p { font-size: 13px; color: var(--txt-2); line-height: 1.55; margin: 0; }

@media(max-width:1024px) {
  .why-local-grid { grid-template-columns: repeat(2,1fr); }
  .fit-grid  { grid-template-columns: 1fr; }
  .vsa-cards { grid-template-columns: 1fr; }
  .signs-grid{ grid-template-columns: repeat(2,1fr); }
}
@media(max-width:640px) {
  .why-local-grid { grid-template-columns: 1fr; }
  .signs-grid{ grid-template-columns: 1fr; }
}

/* Template guide */
.tmpl-category-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-bottom:0; }
.tmpl-rules { display:grid; grid-template-columns:1fr 1fr; gap:24px; }
.tmpl-approved, .tmpl-rejected {
  background:var(--bg); border-radius:var(--r); padding:28px; box-shadow:var(--shadow-xs);
}
.tmpl-approved { border:1.5px solid var(--g-pale-2); }
.tmpl-rejected  { border:1.5px solid #FECACA; }
.tmpl-approved ul li, .tmpl-rejected ul li {
  font-size:14px; color:var(--txt-2); padding:8px 0;
  border-bottom:1px solid var(--border); display:flex; align-items:flex-start; gap:8px;
}
.tmpl-approved ul li::before { content:'✓'; color:var(--g-dark); font-weight:700; flex-shrink:0; }
.tmpl-rejected ul li::before  { content:'✗'; color:#DC2626;      font-weight:700; flex-shrink:0; }
.tmpl-approved ul li:last-child, .tmpl-rejected ul li:last-child { border:none; }
code { background:var(--bg-2); border:1px solid var(--border); padding:1px 6px; border-radius:4px; font-size:12px; }

@media(max-width:900px) {
  .tmpl-category-grid { grid-template-columns:1fr; }
  .tmpl-rules { grid-template-columns:1fr; }
}

/* ══════════════════════════════════════════
   HOMEPAGE — 4 industry cards
   MEGA MENU — 4 column layout
══════════════════════════════════════════ */
.ind-grid-4 {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}
.ind-card-4 {
  display: flex; flex-direction: column;
  background: var(--bg);
  border: 1.5px solid var(--border);
  border-radius: var(--r);
  padding: 28px 22px;
  box-shadow: var(--shadow-xs);
  transition: transform var(--t), box-shadow var(--t), border-color var(--t);
  color: var(--txt);
  text-decoration: none;
}
.ind-card-4:hover { transform: translateY(-5px); box-shadow: var(--shadow-md); border-color: var(--g-pale-2); }
.ind-card-4-icon {
  width: 48px; height: 48px; border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  font-size: 20px; margin-bottom: 16px;
}
.ind-card-4 h4 { font-size: 15px; font-weight: 700; color: var(--txt); margin-bottom: 8px; }
.ind-card-4 p  { font-size: 13px; color: var(--txt-3); line-height: 1.65; flex: 1; margin-bottom: 14px; }
.ind-card-4-link {
  font-size: 13px; font-weight: 700; color: var(--g-dark);
  display: inline-flex; align-items: center; gap: 5px;
  transition: gap var(--t);
}
.ind-card-4:hover .ind-card-4-link { gap: 9px; }

/* Mega menu 4 cols — defined above */

/* Footer — 5 cols responsive */
@media(max-width:1100px) {
  .footer-grid { grid-template-columns: 1.5fr 1fr 1fr !important; }
}
@media(max-width:768px) {
  .ind-grid-4 { grid-template-columns: 1fr 1fr; }
  .footer-grid { grid-template-columns: 1fr !important; }
}
@media(max-width:480px) {
  .ind-grid-4 { grid-template-columns: 1fr; }
}

/* ── FOOTER 5-col responsive ─────────── */
.footer-grid { grid-template-columns: 1.8fr 1fr 1fr 1fr 1fr !important; gap: 32px !important; }
@media(max-width:1100px) { .footer-grid { grid-template-columns: 1fr 1fr 1fr !important; } }
@media(max-width:768px)  { .footer-grid { grid-template-columns: 1fr 1fr !important; } }
@media(max-width:480px)  { .footer-grid { grid-template-columns: 1fr !important; } }

/* Safety: ensure mob-footer never renders outside mob-menu */
.mob-footer { display: none !important; }
.mob-menu .mob-footer { display: flex !important; }

/* ══════════════════════════════════════════
   AUTOMATION USE CASES PAGE
══════════════════════════════════════════ */
/* AI Chatbot vs Flows compare */
.auto-compare { display:grid; grid-template-columns:1fr 1fr; gap:24px; }
.auto-compare-card {
  background:var(--bg); border:1.5px solid var(--border);
  border-radius:var(--r); padding:32px 28px;
  box-shadow:var(--shadow-xs);
  transition:transform var(--t),box-shadow var(--t),border-color var(--t);
}
.auto-compare-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-md); border-color:var(--g-pale-2); }
.auto-compare-icon {
  width:54px; height:54px; border-radius:14px;
  display:flex; align-items:center; justify-content:center;
  font-size:24px; margin-bottom:16px;
}
.auto-compare-card h3 { font-size:19px; font-weight:700; color:var(--txt); margin-bottom:9px; }
.auto-compare-card p  { font-size:14px; color:var(--txt-3); line-height:1.7; margin-bottom:16px; }
.auto-tag-row { display:flex; flex-wrap:wrap; gap:7px; }
.auto-tag {
  font-size:11.5px; font-weight:600;
  background:var(--bg-2); color:var(--txt-3);
  border:1px solid var(--border);
  padding:4px 11px; border-radius:100px;
}

/* Chat showcase grid */
.chat-showcase {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:28px;
  align-items:start;
}
.chat-demo { display:flex; flex-direction:column; gap:16px; }
.chat-demo-label { display:flex; align-items:flex-start; gap:12px; }
.chat-demo-num {
  width:28px; height:28px; border-radius:50%; flex-shrink:0;
  background:var(--g); color:#fff;
  display:flex; align-items:center; justify-content:center;
  font-size:13px; font-weight:800;
}
.chat-demo-label h4 { font-size:15px; font-weight:700; color:var(--txt); margin-bottom:3px; }
.chat-demo-label p  { font-size:12.5px; color:var(--txt-4); line-height:1.5; }

/* WhatsApp Flow form card (inside chat) */
.flow-card {
  background:#fff; border:1.5px solid var(--border);
  border-radius:14px; padding:16px;
  box-shadow:0 2px 10px rgba(15,23,42,.06);
  max-width:92%;
}
.flow-card-title {
  font-size:13px; font-weight:700; color:var(--txt);
  padding-bottom:12px; margin-bottom:12px;
  border-bottom:1px solid var(--border);
  display:flex; align-items:center; gap:8px;
}
.flow-card-title i { color:var(--g-dark); }
.flow-field { margin-bottom:11px; }
.flow-field label {
  display:block; font-size:10.5px; font-weight:600;
  color:var(--txt-4); margin-bottom:4px;
  text-transform:uppercase; letter-spacing:.04em;
}
.flow-select, .flow-input {
  font-size:12.5px; color:var(--txt); font-weight:500;
  background:var(--bg-2); border:1px solid var(--border);
  border-radius:8px; padding:9px 11px;
  display:flex; align-items:center; justify-content:space-between;
}
.flow-select i { font-size:10px; color:var(--txt-4); }
.flow-input-muted { color:var(--txt-4); font-weight:400; font-style:italic; }
.flow-stars { font-size:18px; color:#FACC15; letter-spacing:3px; }
.flow-radio-row { display:flex; gap:8px; }
.flow-radio {
  flex:1; text-align:center; font-size:12px; font-weight:600;
  padding:8px; border-radius:8px;
  background:var(--bg-2); border:1px solid var(--border); color:var(--txt-3);
}
.flow-radio-on {
  background:var(--g-pale); border-color:var(--g-pale-2); color:var(--g-dark);
}
.flow-submit {
  width:100%; margin-top:4px;
  background:linear-gradient(135deg,var(--g-dark),var(--g));
  color:#fff; font-family:'Inter',sans-serif;
  font-size:13px; font-weight:700;
  border:none; border-radius:9px; padding:11px;
  cursor:pointer;
}

@media(max-width:1024px) {
  .chat-showcase { grid-template-columns:1fr 1fr; }
}
@media(max-width:768px) {
  .auto-compare { grid-template-columns:1fr; }
  .chat-showcase { grid-template-columns:1fr; max-width:440px; margin:0 auto; }
}

/* ══════════════════════════════════════════
   CLOUD PBX PAGE
══════════════════════════════════════════ */
.pbx-feat-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.pbx-feat {
  background:var(--bg); border:1.5px solid var(--border);
  border-radius:var(--r); padding:26px 22px;
  box-shadow:var(--shadow-xs);
  transition:transform var(--t),box-shadow var(--t),border-color var(--t);
}
.pbx-feat:hover { transform:translateY(-4px); box-shadow:var(--shadow-md); border-color:var(--g-pale-2); }
.pbx-feat-icon {
  width:48px; height:48px; border-radius:12px;
  display:flex; align-items:center; justify-content:center;
  font-size:20px; margin-bottom:14px;
}
.pbx-feat h4 { font-size:15px; font-weight:700; color:var(--txt); margin-bottom:8px; }
.pbx-feat p  { font-size:13.5px; color:var(--txt-3); line-height:1.65; }

/* iCRM integration cards */
.crm-int-grid { display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.crm-int-card {
  display:flex; align-items:flex-start; gap:16px;
  background:var(--bg); border:1.5px solid var(--border);
  border-radius:var(--r); padding:24px;
  box-shadow:var(--shadow-xs);
  transition:border-color var(--t),box-shadow var(--t);
}
.crm-int-card:hover { border-color:#BFDBFE; box-shadow:var(--shadow-sm); }
.crm-int-icon {
  width:44px; height:44px; border-radius:11px; flex-shrink:0;
  background:#EFF6FF; color:#2563EB;
  display:flex; align-items:center; justify-content:center; font-size:18px;
}
.crm-int-card h4 { font-size:15px; font-weight:700; color:var(--txt); margin-bottom:6px; }
.crm-int-card p  { font-size:13px; color:var(--txt-3); line-height:1.6; }
.crm-int-cta {
  display:flex; align-items:center; gap:20px;
  background:#EFF6FF; border:1.5px solid #BFDBFE;
  border-radius:var(--r); padding:22px 28px; margin-top:24px;
  flex-wrap:wrap;
}
.crm-int-cta strong { display:block; font-size:15px; color:var(--txt); margin-bottom:3px; }
.crm-int-cta span { display:block; font-size:13px; color:var(--txt-3); }
.crm-int-cta > div { flex:1; min-width:240px; }

/* PBX pricing */
.pbx-price-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.pbx-plan {
  background:var(--bg); border:1.5px solid var(--border);
  border-radius:var(--r); padding:28px 22px;
  position:relative; box-shadow:var(--shadow-xs);
  transition:transform var(--t),box-shadow var(--t),border-color var(--t);
}
.pbx-plan:hover { transform:translateY(-4px); box-shadow:var(--shadow-md); }
.pbx-plan-hot { border:2px solid var(--g); box-shadow:var(--shadow-md); }
.pbx-plan-badge {
  position:absolute; top:-12px; left:50%; transform:translateX(-50%);
  background:linear-gradient(135deg,var(--g-dark),var(--g)); color:#fff;
  font-size:10px; font-weight:800; letter-spacing:.05em; text-transform:uppercase;
  padding:4px 14px; border-radius:100px; white-space:nowrap;
}
.pbx-plan-name { font-size:13px; font-weight:700; letter-spacing:.05em; text-transform:uppercase; color:var(--txt-4); margin-bottom:10px; }
.pbx-plan-price { font-size:32px; font-weight:800; color:var(--txt); letter-spacing:-.02em; }
.pbx-plan-price span { font-size:13px; font-weight:500; color:var(--txt-4); }
.pbx-plan-from { font-size:12px !important; font-weight:600 !important; color:var(--txt-4) !important; display:block; margin-bottom:-2px; }
.pbx-plan-ext { font-size:13px; font-weight:700; color:var(--g-dark); margin-top:4px; }
.pbx-plan-desc { font-size:12.5px; color:var(--txt-4); margin:4px 0 16px; padding-bottom:16px; border-bottom:1px solid var(--border); }
.pbx-plan-feats { margin-bottom:20px; }
.pbx-plan-feats li { display:flex; align-items:flex-start; gap:8px; font-size:13px; color:var(--txt-2); padding:5px 0; }
.pbx-plan-feats .fa-check { color:var(--g-dark); font-size:11px; margin-top:3px; flex-shrink:0; }
.pbx-plan-btn { display:block; text-align:center; padding:11px; border-radius:10px; font-size:14px; font-weight:700; transition:all var(--t); }
.pbx-plan-btn-g { background:var(--g); color:#fff; }
.pbx-plan-btn-g:hover { background:var(--g-mid,#1faa52); }
.pbx-plan-btn-o { background:var(--bg-2); color:var(--txt); border:1.5px solid var(--border); }
.pbx-plan-btn-o:hover { border-color:var(--g); color:var(--g-dark); }
.pbx-price-note {
  display:flex; align-items:center; gap:10px; justify-content:center;
  margin-top:24px; font-size:13.5px; color:var(--txt-3);
  background:var(--bg-2); border:1px solid var(--border);
  border-radius:var(--r-sm); padding:16px 20px;
}
.pbx-price-note i { color:var(--txt-4); }
.pbx-price-note a { color:var(--g-dark); font-weight:700; }

/* PBX AI features */
.pbx-ai-grid { display:grid; grid-template-columns:1fr 1fr; gap:24px; }
.pbx-ai-card {
  background:var(--bg); border:1.5px solid var(--border);
  border-radius:var(--r); padding:30px 26px; box-shadow:var(--shadow-xs);
}
.pbx-ai-icon { width:50px; height:50px; border-radius:13px; display:flex; align-items:center; justify-content:center; font-size:22px; margin-bottom:16px; }
.pbx-ai-card h4 { font-size:17px; font-weight:700; color:var(--txt); margin-bottom:9px; }
.pbx-ai-card p  { font-size:14px; color:var(--txt-3); line-height:1.7; margin-bottom:14px; }
.addon-flag { display:inline-block; font-size:11px; font-weight:600; color:#B45309; background:var(--amber-pale); border:1px solid #FDE68A; padding:4px 12px; border-radius:100px; }

/* PBX why */
.pbx-why-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.pbx-why {
  text-align:center; padding:28px 24px;
  background:var(--bg); border:1.5px solid var(--border);
  border-radius:var(--r); box-shadow:var(--shadow-xs);
}
.pbx-why-icon {
  width:56px; height:56px; border-radius:50%; margin:0 auto 16px;
  background:var(--g-pale); color:var(--g-dark);
  display:flex; align-items:center; justify-content:center; font-size:24px;
}
.pbx-why h4 { font-size:16px; font-weight:700; color:var(--txt); margin-bottom:8px; }
.pbx-why p  { font-size:13.5px; color:var(--txt-3); line-height:1.65; }

@media(max-width:1024px) {
  .pbx-feat-grid { grid-template-columns:1fr 1fr; }
  .pbx-price-grid { grid-template-columns:1fr 1fr; }
}
@media(max-width:768px) {
  .pbx-feat-grid { grid-template-columns:1fr; }
  .crm-int-grid { grid-template-columns:1fr; }
  .pbx-price-grid { grid-template-columns:1fr 1fr; }
  .pbx-ai-grid { grid-template-columns:1fr; }
  .pbx-why-grid { grid-template-columns:1fr; }
}
@media(max-width:480px) { .pbx-price-grid { grid-template-columns:1fr; } }
