/* =========================================
   ROWAN CLOUD — Light Theme
   ========================================= */

:root {
  --green:       #2cac61;
  --green-dark:  #1a7a45;
  --green-mid:   #4dc47a;
  --green-light: #e5f7ee;
  --green-pale:  #f0faf5;
  --green-soft:  #c8ebd8;

  --bg:        #ffffff;
  --bg-alt:    #f5faf7;
  --bg-section:#eef7f2;
  --surface:   #ffffff;
  --card-bg:   #ffffff;

  --border:    #d6eade;
  --border-lt: #eaf4ee;

  --text-h:  #0d1f18;
  --text-b:  #2a4a3e;
  --text-s:  #547a6b;
  --text-m:  #90b0a4;

  --shadow-xs: 0 1px 4px rgba(13,31,24,.06);
  --shadow-sm: 0 2px 12px rgba(13,31,24,.08);
  --shadow-md: 0 4px 24px rgba(13,31,24,.1);
  --shadow-lg: 0 12px 48px rgba(13,31,24,.13);

  --r:    10px;
  --r-lg: 18px;
  --r-xl: 24px;
  --ease: all .25s cubic-bezier(.4,0,.2,1);

  --font-sans:'Inter',system-ui,-apple-system,sans-serif;
  --font-mono:'JetBrains Mono','Fira Code',monospace;
}

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }

body {
  font-family:var(--font-sans);
  background:var(--bg);
  color:var(--text-b);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}

a { color:inherit; text-decoration:none; }
img { max-width:100%; display:block; }

.container { max-width:1160px; margin:0 auto; padding:0 28px; }

/* ── typography helpers ── */
.section-eyebrow {
  display:inline-flex; align-items:center; gap:8px;
  font-size:.72rem; font-weight:700; text-transform:uppercase;
  letter-spacing:2px; color:var(--green); margin-bottom:12px;
}
.section-eyebrow::before { content:''; width:16px; height:2px; background:var(--green); }

h1,h2,h3,h4 { color:var(--text-h); font-weight:800; line-height:1.15; letter-spacing:-.02em; }

.section-title { font-size:clamp(1.9rem,3.8vw,2.8rem); margin-bottom:14px; }
.section-title em { font-style:normal; color:var(--green); }

.section-desc { color:var(--text-s); font-size:1.02rem; max-width:580px; line-height:1.75; }

.section-header       { text-align:center; }
.section-header .section-desc { margin:0 auto; }
.section-header.left  { text-align:left; }
.section-header.left .section-desc { margin:0; }

.tag {
  display:inline-flex; align-items:center; gap:6px;
  background:var(--green-light); border:1px solid var(--green-soft);
  color:var(--green-dark); padding:4px 13px; border-radius:100px;
  font-size:.71rem; font-weight:700; letter-spacing:.4px;
}
.tag .dot { width:5px; height:5px; background:var(--green); border-radius:50%; animation:blink 2s infinite; }

/* =========================================
   NAVBAR
   ========================================= */
.navbar {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  padding:18px 0; transition:var(--ease);
  background:transparent;
}
.navbar.scrolled {
  background:rgba(255,255,255,.96);
  backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px);
  box-shadow:0 1px 0 var(--border), 0 4px 24px rgba(13,31,24,.07);
  padding:12px 0;
}

.nav-container {
  max-width:1160px; margin:0 auto; padding:0 28px;
  display:flex; align-items:center; justify-content:space-between;
}

.nav-logo { height:36px; width:auto; }

.nav-links { display:flex; align-items:center; list-style:none; gap:2px; }
.nav-links > li > a {
  color:var(--text-s); font-size:.875rem; font-weight:500;
  padding:8px 14px; border-radius:8px; transition:var(--ease);
  display:flex; align-items:center; gap:5px;
}
.nav-links > li > a:hover { color:var(--green); background:var(--green-pale); }
.nav-links > li > a.active { color:var(--green); font-weight:600; }

/* Dropdown */
.dropdown { position:relative; }
.chevron { font-size:.6rem; transition:var(--ease); }
.dropdown:hover .chevron { transform:rotate(180deg); }

.dropdown-menu {
  position:absolute; top:calc(100% + 8px); left:50%;
  transform:translateX(-50%) translateY(-6px);
  background:#fff; border:1px solid var(--border);
  border-radius:var(--r-lg); padding:6px; min-width:210px;
  opacity:0; visibility:hidden; transition:var(--ease);
  box-shadow:var(--shadow-lg);
}
.dropdown:hover .dropdown-menu { opacity:1; visibility:visible; transform:translateX(-50%) translateY(0); }
.dropdown-menu a {
  display:flex !important; align-items:center; gap:10px;
  padding:10px 14px !important; border-radius:8px;
  color:var(--text-s) !important; font-size:.85rem !important;
  font-weight:500 !important;
}
.dropdown-menu a:hover { color:var(--green) !important; background:var(--green-pale) !important; }
.dropdown-menu a i { width:15px; color:var(--green); }

.btn-nav {
  background:var(--green) !important; color:#fff !important;
  padding:9px 22px !important; border-radius:8px !important;
  font-weight:600 !important; margin-left:8px; transition:var(--ease) !important;
}
.btn-nav:hover {
  background:var(--green-dark) !important; color:#fff !important;
  transform:translateY(-1px); box-shadow:0 4px 16px rgba(44,172,97,.35) !important;
}

.hamburger {
  display:none; flex-direction:column; gap:5px;
  background:none; border:none; cursor:pointer; padding:6px; z-index:1002;
}
.hamburger span { display:block; width:22px; height:2px; background:var(--text-h); border-radius:2px; transition:var(--ease); }
.hamburger.open span:nth-child(1) { transform:rotate(45deg) translate(5px,5px); }
.hamburger.open span:nth-child(2) { opacity:0; }
.hamburger.open span:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px); }

/* =========================================
   BUTTONS
   ========================================= */
.btn {
  display:inline-flex; align-items:center; gap:8px;
  padding:13px 28px; border-radius:10px; font-weight:600;
  font-size:.93rem; cursor:pointer; border:none; transition:var(--ease);
  white-space:nowrap; font-family:var(--font-sans);
}
.btn-primary {
  background:var(--green); color:#fff;
  box-shadow:0 4px 16px rgba(44,172,97,.3);
}
.btn-primary:hover { background:var(--green-dark); transform:translateY(-1px); box-shadow:0 6px 24px rgba(44,172,97,.45); }

.btn-outline {
  background:#fff; color:var(--text-h);
  border:1.5px solid var(--border); box-shadow:var(--shadow-xs);
}
.btn-outline:hover { border-color:var(--green); color:var(--green); transform:translateY(-1px); box-shadow:var(--shadow-sm); }

.btn-ghost {
  background:var(--green-pale); color:var(--green-dark);
  border:1px solid var(--green-light);
}
.btn-ghost:hover { background:var(--green-light); }

.btn-white {
  background:#fff; color:var(--green);
  box-shadow:0 4px 16px rgba(0,0,0,.1);
}
.btn-white:hover { transform:translateY(-1px); box-shadow:0 8px 24px rgba(0,0,0,.15); }

.btn-lg  { padding:15px 34px; font-size:.98rem; border-radius:12px; }
.btn-sm  { padding:8px 16px; font-size:.8rem; border-radius:8px; }
.btn-xl  { padding:17px 40px; font-size:1.05rem; border-radius:14px; }

/* =========================================
   HERO — HOMEPAGE
   ========================================= */
.hero {
  background:linear-gradient(160deg,#0d2118 0%,#143326 40%,#1a4a30 100%);
  padding:148px 0 100px; position:relative; overflow:hidden;
}

.hero-pattern {
  position:absolute; inset:0; pointer-events:none;
  background-image:
    radial-gradient(circle at 70% 50%,rgba(44,172,97,.18) 0%,transparent 60%),
    radial-gradient(circle at 20% 80%,rgba(44,172,97,.1) 0%,transparent 50%);
}
.hero-grid-lines {
  position:absolute; inset:0; pointer-events:none;
  background-image:
    linear-gradient(rgba(44,172,97,.06) 1px,transparent 1px),
    linear-gradient(90deg,rgba(44,172,97,.06) 1px,transparent 1px);
  background-size:56px 56px;
}

.hero-content {
  position:relative; z-index:1;
  max-width:1160px; margin:0 auto; padding:0 28px;
  display:grid; grid-template-columns:1fr 1fr; gap:72px; align-items:center;
}

.hero-eyebrow {
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(44,172,97,.15); border:1px solid rgba(44,172,97,.3);
  color:#7fefb0; padding:5px 14px; border-radius:100px;
  font-size:.72rem; font-weight:700; letter-spacing:1.5px;
  text-transform:uppercase; margin-bottom:22px; font-family:var(--font-mono);
}
.hero-ping { width:6px; height:6px; background:#7fefb0; border-radius:50%; animation:blink 2s infinite; }

.hero-title {
  font-size:clamp(2.6rem,5.5vw,4.6rem); font-weight:900;
  line-height:1.06; letter-spacing:-.03em;
  color:#fff; margin-bottom:22px;
}
.hero-title .accent {
  background:linear-gradient(135deg,#2cac61 20%,#7fefb0);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}

.hero-desc { color:rgba(255,255,255,.65); font-size:1.1rem; line-height:1.75; margin-bottom:36px; max-width:480px; }

.hero-actions { display:flex; gap:12px; flex-wrap:wrap; }

.hero-trust {
  display:flex; align-items:center; gap:20px;
  margin-top:40px; padding-top:28px; border-top:1px solid rgba(255,255,255,.1);
}
.hero-trust-item {
  display:flex; align-items:center; gap:8px;
  font-size:.82rem; color:rgba(255,255,255,.5);
}
.hero-trust-item i { color:var(--green); font-size:.88rem; }

/* Homepage hero illustration */
.hero-illustration { display:flex; justify-content:center; align-items:center; }
.hero-svg { width:100%; max-width:480px; height:auto; animation:svgFadeIn .45s ease .12s both; }
@keyframes svgFadeIn { from { opacity:0; } }

/* =========================================
   PAGE HERO (inner pages)
   ========================================= */
.page-hero {
  background:linear-gradient(160deg,#0d2118 0%,#143326 50%,#1c4d33 100%);
  padding:148px 0 72px; position:relative; overflow:hidden;
}
.page-hero::after {
  content:''; position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(ellipse at 80% 50%,rgba(44,172,97,.15) 0%,transparent 60%);
}
.page-hero-inner { position:relative; z-index:1; max-width:1160px; margin:0 auto; padding:0 28px; }
.page-hero-eyebrow {
  display:inline-flex; align-items:center; gap:7px;
  background:rgba(44,172,97,.15); border:1px solid rgba(44,172,97,.28);
  color:#7fefb0; padding:4px 13px; border-radius:100px;
  font-size:.7rem; font-weight:700; letter-spacing:1.5px;
  text-transform:uppercase; margin-bottom:16px; font-family:var(--font-mono);
}
.page-hero-title {
  font-size:clamp(2.2rem,5vw,3.8rem); font-weight:900;
  letter-spacing:-.025em; color:#fff; margin-bottom:14px; line-height:1.1;
}
.page-hero-title em { font-style:normal; color:#7fefb0; }
.page-hero-desc { color:rgba(255,255,255,.6); font-size:1.04rem; max-width:560px; line-height:1.75; }

/* =========================================
   FEATURES
   ========================================= */
.features { padding:96px 0; background:var(--bg); }
.features-grid {
  display:flex; flex-wrap:wrap; justify-content:center;
  gap:20px; margin-top:52px;
}
.feature-card {
  flex:0 0 min(100%,340px);
  background:var(--card-bg); border:1px solid var(--border);
  border-radius:var(--r-lg); padding:30px; transition:var(--ease);
  box-shadow:var(--shadow-xs);
}
.feature-card:hover {
  border-color:var(--green-soft); transform:translateY(-3px);
  box-shadow:var(--shadow-md), 0 0 0 4px var(--green-pale);
}
.feature-icon {
  width:48px; height:48px; background:var(--green-light); border-radius:12px;
  display:flex; align-items:center; justify-content:center;
  font-size:1.2rem; color:var(--green); margin-bottom:18px;
}
.feature-title { font-size:.98rem; font-weight:700; color:var(--text-h); margin-bottom:8px; }
.feature-desc { color:var(--text-s); font-size:.86rem; line-height:1.72; }

/* =========================================
   PRODUCTS
   ========================================= */
.products { padding:80px 0; background:var(--bg-alt); }
.products-flex {
  display:flex; flex-wrap:wrap; justify-content:center;
  gap:24px; margin-top:52px;
}
.product-card {
  flex:0 0 min(100%, 348px);
  background:#fff; border:1px solid var(--border);
  border-radius:var(--r-xl); padding:36px 30px; text-align:center;
  transition:var(--ease); box-shadow:var(--shadow-sm);
  position:relative; overflow:hidden;
}
.product-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg,var(--green),var(--green-mid));
  opacity:0; transition:var(--ease);
}
.product-card:hover { transform:translateY(-5px); box-shadow:var(--shadow-lg); }
.product-card:hover::before { opacity:1; }

.product-illus { width:90px; height:90px; margin:0 auto 22px; }
.product-name { font-size:1.3rem; font-weight:800; color:var(--text-h); margin-bottom:10px; }
.product-desc { color:var(--text-s); font-size:.875rem; line-height:1.72; margin-bottom:22px; }
.product-from { font-size:.7rem; color:var(--text-m); text-transform:uppercase; letter-spacing:1.5px; margin-bottom:4px; font-weight:600; }
.product-price { font-size:1.9rem; font-weight:900; color:var(--green); margin-bottom:22px; }
.product-price span { font-size:.85rem; font-weight:400; color:var(--text-m); }

/* =========================================
   STATS
   ========================================= */
.stats { padding:80px 0; background:var(--bg); }
.stats-inner {
  background:linear-gradient(135deg,#0d2118 0%,#1a4030 100%);
  border-radius:var(--r-xl); padding:60px;
  display:grid; grid-template-columns:repeat(4,1fr); gap:40px;
  text-align:center; position:relative; overflow:hidden;
}
.stats-inner::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse at 50% 0%,rgba(44,172,97,.2) 0%,transparent 60%);
  pointer-events:none;
}
.stat-number {
  font-size:2.8rem; font-weight:900; color:var(--green);
  margin-bottom:6px; line-height:1; font-family:var(--font-mono);
}
.stat-label { color:rgba(255,255,255,.5); font-size:.82rem; text-transform:uppercase; letter-spacing:1.2px; }

/* =========================================
   BILLING TOGGLE
   ========================================= */
.billing-wrap {
  display:flex; flex-direction:column; align-items:center;
  gap:10px; margin-bottom:40px;
}
.billing-toggle {
  display:inline-flex; background:#f0f4f2;
  border:1px solid var(--border); border-radius:100px; padding:4px;
}
.billing-btn {
  padding:8px 22px; border-radius:100px; border:none; cursor:pointer;
  font-size:.875rem; font-weight:600; transition:var(--ease);
  background:transparent; color:var(--text-s);
}
.billing-btn.active { background:var(--green); color:#fff; box-shadow:0 2px 8px rgba(44,172,97,.35); }
.billing-note {
  display:inline-flex; align-items:center; gap:6px;
  font-size:.78rem; color:var(--green-dark); font-weight:600;
  background:var(--green-light); padding:4px 12px; border-radius:100px;
}
.billing-note i { font-size:.75rem; }

/* =========================================
   PRICING CARDS (web hosting)
   ========================================= */
.pricing { padding:80px 0; background:var(--bg); }
.flex-pricing {
  display:flex; flex-wrap:wrap; justify-content:center;
  gap:16px; margin-top:40px;
}

.pricing-card {
  flex:0 0 min(100%, 240px);
  background:#fff; border:1.5px solid var(--border);
  border-radius:var(--r-lg); padding:24px 20px;
  transition:var(--ease); display:flex; flex-direction:column;
  box-shadow:var(--shadow-xs); position:relative;
}
.pricing-card.popular {
  border-color:var(--green); box-shadow:0 0 0 3px var(--green-light),var(--shadow-md);
}
.pricing-card.popular::before {
  content:'Popular';
  position:absolute; top:-1px; left:50%; transform:translateX(-50%);
  background:var(--green); color:#fff;
  font-size:.62rem; font-weight:800; letter-spacing:1px;
  padding:3px 14px; border-radius:0 0 8px 8px;
}
.pricing-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-md); border-color:var(--green-soft); }
.pricing-card.popular:hover { box-shadow:0 0 0 3px var(--green-light),var(--shadow-lg); }

/* Plan illustration in card */
.plan-illus { height:72px; margin:0 auto 14px; display:flex; align-items:center; justify-content:center; }
.plan-illus svg { height:72px; width:auto; }

.pricing-name {
  font-size:.75rem; font-weight:700; color:var(--text-m);
  text-transform:uppercase; letter-spacing:1.5px; margin-bottom:6px; text-align:center;
}
.pricing-price {
  font-size:1.9rem; font-weight:900; color:var(--text-h); text-align:center;
  line-height:1; margin-bottom:2px;
}
.pricing-price small { font-size:.78rem; font-weight:400; color:var(--text-m); }
.pricing-period { font-size:.72rem; color:var(--text-m); text-align:center; margin-bottom:16px; }
.pricing-divider { height:1px; background:var(--border); margin:14px 0; }

.pricing-features { list-style:none; flex:1; margin-bottom:18px; }
.pricing-features li {
  display:flex; align-items:flex-start; gap:8px;
  padding:4px 0; font-size:.81rem; color:var(--text-s);
}
.pricing-features li i { color:var(--green); font-size:.7rem; margin-top:3px; flex-shrink:0; }
.pricing-features li strong { color:var(--text-h); font-weight:600; }

/* =========================================
   COMPARISON TABLE
   ========================================= */
.comparison-section { padding:20px 0 80px; background:var(--bg); }
.comparison-wrap {
  overflow-x:auto; margin-top:40px;
  border-radius:var(--r-xl); border:1px solid var(--border);
  box-shadow:var(--shadow-md);
}

.comparison-table { width:100%; border-collapse:collapse; min-width:740px; }

/* Header row */
.ct-head { background:#fff; }
.ct-head th {
  padding:22px 16px; text-align:center;
  border-right:1px solid var(--border);
  border-bottom:2px solid var(--border);
  vertical-align:bottom;
}
.ct-head th:first-child {
  text-align:left; border-right:1px solid var(--border);
  padding:22px 20px; width:185px;
}
.ct-head th:last-child { border-right:none; }

.ct-plan-col { background:#fff; }
.ct-plan-col.featured {
  background:linear-gradient(180deg,var(--green-pale) 0%,#fff 100%) !important;
}
.ct-col-illus { height:60px; display:flex; align-items:center; justify-content:center; margin-bottom:10px; }
.ct-col-illus svg { height:54px; width:auto; }
.ct-plan-name { font-size:.7rem; font-weight:800; color:var(--text-m); text-transform:uppercase; letter-spacing:1.5px; margin-bottom:4px; }
.ct-plan-price { font-size:1.5rem; font-weight:900; color:var(--text-h); line-height:1; }
.ct-plan-price small { font-size:.75rem; font-weight:400; color:var(--text-m); }
.ct-plan-period { font-size:.7rem; color:var(--text-m); margin-bottom:12px; }
.ct-plan-badge {
  display:inline-block; background:var(--green); color:#fff;
  font-size:.58rem; font-weight:800; letter-spacing:1.5px;
  padding:2px 10px; border-radius:100px; margin-bottom:10px;
}
.ct-head-label { font-size:.72rem; font-weight:700; color:var(--text-m); text-align:left !important; }

/* ---- single border token used everywhere in the table ---- */
/* All vertical separators and row dividers use --border (one shade, no mixing) */

/* Section rows */
.ct-section-row td {
  background:var(--bg-section); padding:9px 20px;
  border-top:1px solid var(--border); border-bottom:1px solid var(--border);
  border-right:1px solid var(--border);
  font-size:.69rem; color:var(--text-s); text-transform:uppercase;
  letter-spacing:2px; font-weight:700;
}
.ct-section-row td:first-child { color:var(--text-h); }
.ct-section-row td:last-child { border-right:none; }
/* Featured column section cell */
.ct-section-row .ct-featured-cell {
  background:var(--green-light) !important;
}
/* Extreme column section cell */
.ct-section-row .ct-extreme-col {
  background:#112e1e !important;
  border-left:2px solid rgba(44,172,97,.3) !important;
  border-right:none !important;
  border-top:1px solid rgba(44,172,97,.18) !important;
  border-bottom:1px solid rgba(44,172,97,.18) !important;
}

/* Data rows — same border colour as section rows so grid is uniform */
.comparison-table tbody tr:not(.ct-section-row) td {
  padding:13px 16px;
  border-bottom:1px solid var(--border);
  border-right:1px solid var(--border);
  font-size:.875rem; background:#fff;
}
.comparison-table tbody tr:not(.ct-section-row) td:first-child {
  color:var(--text-b); font-weight:500; padding-left:20px;
  background:var(--bg-alt); border-right:1px solid var(--border);
}
.comparison-table tbody tr:not(.ct-section-row) td:not(:first-child) { text-align:center; }
.comparison-table tbody tr:not(.ct-section-row) td:last-child { border-right:none; }
/* Featured column — continuous green tint */
.ct-featured-cell { background:var(--green-pale) !important; }
.comparison-table tbody tr:not(.ct-section-row):hover td:not(:first-child):not(.ct-featured-cell):not(.ct-extreme-col) { background:var(--bg-alt); }
.comparison-table tbody tr:not(.ct-section-row):hover .ct-featured-cell { background:var(--green-light) !important; }
.comparison-table tbody tr:last-child td { border-bottom:none; }

/* Footer row — order buttons at bottom of table */
.ct-footer-row td {
  padding:16px; text-align:center;
  border-top:2px solid var(--border);
  background:#fff;
}
.ct-footer-row td:first-child { background:var(--bg-alt); border-right:1px solid var(--border); }
.ct-footer-row .ct-featured-cell { border-top:2px solid var(--border) !important; }
.ct-footer-row .ct-extreme-col { border-top:2px solid rgba(44,172,97,.3) !important; }

.ct-check { color:var(--green); font-size:.95rem; }
.ct-cross { color:var(--border); font-size:.9rem; }
.ct-val   { font-weight:700; font-size:.87rem; color:var(--text-h); }
.ct-free  { color:var(--green) !important; }
.ct-badge {
  display:inline-flex; align-items:center; gap:4px;
  background:var(--green-light); border:1px solid var(--green-soft);
  color:var(--green-dark); padding:2px 9px; border-radius:100px;
  font-size:.68rem; font-weight:700;
}
.ct-special {
  background:rgba(240,180,41,.1); border:1px solid rgba(240,180,41,.35);
  color:#a07000;
}

/* =========================================
   VPS CARDS
   ========================================= */
.vps-section { padding:80px 0; background:var(--bg); }
.vps-flex {
  display:flex; flex-wrap:wrap; justify-content:center;
  gap:18px; margin-top:52px;
}
.vps-card {
  flex:0 0 min(100%,248px);
  background:#fff; border:1.5px solid var(--border);
  border-radius:var(--r-lg); padding:24px;
  transition:var(--ease); display:flex; flex-direction:column;
  box-shadow:var(--shadow-xs); position:relative;
}
.vps-card.featured {
  border-color:var(--green); box-shadow:0 0 0 3px var(--green-light),var(--shadow-md);
}
.vps-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-md); }
.vps-card.featured:hover { box-shadow:0 0 0 3px var(--green-light),var(--shadow-lg); }

.vps-badge {
  position:absolute; top:14px; right:14px;
  background:var(--green); color:#fff;
  font-size:.58rem; font-weight:800; letter-spacing:1.5px;
  padding:3px 10px; border-radius:100px;
}
.vps-ram { font-size:2.2rem; font-weight:900; color:var(--text-h); line-height:1; }
.vps-ram-sub { font-size:.67rem; color:var(--text-m); text-transform:uppercase; letter-spacing:2px; margin-bottom:16px; }
.vps-specs { display:grid; grid-template-columns:1fr 1fr; gap:8px; margin-bottom:14px; }
.vps-spec {
  background:var(--bg-alt); border:1px solid var(--border-lt);
  border-radius:8px; padding:9px 11px;
}
.vps-spec-val { font-weight:700; font-size:.85rem; color:var(--text-h); }
.vps-spec-key { font-size:.65rem; color:var(--text-m); text-transform:uppercase; letter-spacing:1px; }
.vps-bw {
  font-size:.77rem; color:var(--text-s); padding:8px 10px;
  background:var(--green-pale); border:1px solid var(--green-light);
  border-radius:7px; margin-bottom:14px; display:flex; align-items:center; gap:7px;
}
.vps-bw i { color:var(--green); }
.vps-price { font-size:1.7rem; font-weight:900; color:var(--green); margin-top:auto; padding-top:14px; border-top:1px solid var(--border-lt); }
.vps-price small { font-size:.78rem; color:var(--text-m); font-weight:400; }

/* =========================================
   TECH SPECS
   ========================================= */
.tech-specs { padding:80px 0; background:var(--bg-alt); }
.tech-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-top:44px; }
.tech-card {
  background:#fff; border:1px solid var(--border);
  border-radius:var(--r); padding:22px; display:flex;
  align-items:flex-start; gap:14px; transition:var(--ease); box-shadow:var(--shadow-xs);
}
.tech-card:hover { transform:translateY(-2px); box-shadow:var(--shadow-md); }
.tech-icon { width:42px; height:42px; background:var(--green-light); border-radius:10px; display:flex; align-items:center; justify-content:center; color:var(--green); font-size:1.05rem; flex-shrink:0; }
.tech-title { font-size:.875rem; font-weight:700; color:var(--text-h); margin-bottom:4px; }
.tech-desc { font-size:.79rem; color:var(--text-s); line-height:1.58; }

/* =========================================
   CONFIGURATOR
   ========================================= */
.configurator {
  background:#fff; border:1px solid var(--border);
  border-radius:var(--r-xl); padding:48px; margin-top:52px;
  box-shadow:var(--shadow-md);
}
.config-grid { display:grid; grid-template-columns:1fr 300px; gap:48px; align-items:start; }
.config-section { margin-bottom:28px; }
.config-section:last-child { margin-bottom:0; }
.config-label {
  display:block; font-size:.72rem; font-weight:700; color:var(--text-m);
  text-transform:uppercase; letter-spacing:2px; margin-bottom:12px;
}
.slider-value-label { display:flex; justify-content:space-between; margin-bottom:10px; }
.slider-current { font-size:.95rem; font-weight:800; color:var(--green); }
.slider-range    { font-size:.76rem; color:var(--text-m); }

input[type=range].config-slider {
  width:100%; -webkit-appearance:none; appearance:none;
  height:4px; background:var(--border); border-radius:2px;
  outline:none; cursor:pointer;
}
input[type=range].config-slider::-webkit-slider-thumb {
  -webkit-appearance:none; width:18px; height:18px; border-radius:50%;
  background:var(--green); cursor:pointer; border:2px solid #fff;
  box-shadow:0 2px 8px rgba(44,172,97,.4);
}

.included-tag {
  display:inline-flex; align-items:center; gap:6px;
  background:var(--green-pale); border:1px solid var(--green-light);
  color:var(--green-dark); padding:5px 12px; border-radius:100px;
  font-size:.78rem; font-weight:600; margin:4px 4px 4px 0;
}
.included-tag i { font-size:.7rem; }

.config-summary {
  background:var(--bg-alt); border:1.5px solid var(--border);
  border-radius:var(--r-lg); padding:26px;
  position:sticky; top:100px;
}
.config-sum-title {
  font-size:.72rem; font-weight:700; color:var(--text-m);
  text-transform:uppercase; letter-spacing:2px; margin-bottom:18px;
}
.config-line {
  display:flex; justify-content:space-between; padding:9px 0;
  border-bottom:1px solid var(--border); font-size:.85rem;
}
.config-line:last-of-type { border-bottom:none; }
.config-line-key { color:var(--text-m); }
.config-line-val { color:var(--text-h); font-weight:700; }
.config-total {
  background:var(--green); border-radius:12px;
  padding:18px; margin-top:18px; text-align:center;
}
.config-total-label { font-size:.68rem; color:rgba(255,255,255,.7); text-transform:uppercase; letter-spacing:2px; margin-bottom:4px; }
.config-total-price { font-size:2rem; font-weight:900; color:#fff; }
.config-total-sub { font-size:.7rem; color:rgba(255,255,255,.65); margin-top:2px; }

/* =========================================
   SUPPORT
   ========================================= */
.support-channels {
  display:flex; flex-wrap:wrap; justify-content:center;
  gap:18px; margin-top:52px;
}
.support-channel {
  flex:0 0 min(100%,240px);
  background:#fff; border:1px solid var(--border);
  border-radius:var(--r-lg); padding:28px; text-align:center;
  transition:var(--ease); display:block; box-shadow:var(--shadow-xs);
}
.support-channel:hover { border-color:var(--green-soft); transform:translateY(-3px); box-shadow:var(--shadow-md); }
.support-ch-icon {
  width:56px; height:56px; background:var(--green-light); border-radius:14px;
  display:flex; align-items:center; justify-content:center;
  font-size:1.4rem; color:var(--green); margin:0 auto 14px;
}
.support-ch-title { font-size:.96rem; font-weight:700; color:var(--text-h); margin-bottom:7px; }
.support-ch-desc  { font-size:.83rem; color:var(--text-s); line-height:1.58; }

.ticket-section { padding:80px 0; background:var(--bg-alt); }
.ticket-form {
  background:#fff; border:1px solid var(--border);
  border-radius:var(--r-xl); padding:48px; margin-top:52px; box-shadow:var(--shadow-md);
}
.form-grid { display:grid; grid-template-columns:1fr 1fr; gap:20px; }
.form-group { display:flex; flex-direction:column; gap:8px; }
.form-group.full { grid-column:1/-1; }
.form-label { font-size:.72rem; font-weight:700; color:var(--text-s); text-transform:uppercase; letter-spacing:.8px; }
.form-control {
  background:var(--bg-alt); border:1.5px solid var(--border);
  border-radius:8px; padding:12px 16px; color:var(--text-h);
  font-size:.9rem; font-family:var(--font-sans); transition:var(--ease);
  outline:none; width:100%;
}
.form-control:focus { border-color:var(--green); background:#fff; box-shadow:0 0 0 3px var(--green-pale); }
.form-control::placeholder { color:var(--text-m); }
select.form-control { cursor:pointer; }
textarea.form-control { resize:vertical; min-height:130px; }

/* =========================================
   CTA SECTION
   ========================================= */
.cta { padding:80px 0; background:var(--bg-alt); }
.cta-inner {
  background:linear-gradient(140deg,#0d2118 0%,#1a4030 60%,#1d5038 100%);
  border-radius:var(--r-xl); padding:52px 60px; text-align:center; position:relative; overflow:hidden;
}
.cta-inner::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse at 50% 0%,rgba(44,172,97,.25) 0%,transparent 60%);
  pointer-events:none;
}
.cta-title { font-size:clamp(1.8rem,3.5vw,2.8rem); font-weight:900; color:#fff; margin-bottom:14px; position:relative; }
.cta-desc  { color:rgba(255,255,255,.6); font-size:1.04rem; margin-bottom:32px; max-width:480px; margin-left:auto; margin-right:auto; position:relative; }
.cta-actions { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; position:relative; }

/* =========================================
   FAQ
   ========================================= */
.faq { padding:80px 0; background:var(--bg); }
.faq-list { margin-top:44px; max-width:800px; margin-left:auto; margin-right:auto; }
.faq-item {
  background:#fff; border:1px solid var(--border);
  border-radius:var(--r); margin-bottom:9px; overflow:hidden; transition:var(--ease);
  box-shadow:var(--shadow-xs);
}
.faq-item.open { border-color:var(--green-soft); box-shadow:var(--shadow-sm); }
.faq-question {
  width:100%; background:none; border:none; padding:17px 22px;
  display:flex; align-items:center; justify-content:space-between;
  cursor:pointer; color:var(--text-h); font-size:.9rem; font-weight:600;
  text-align:left; gap:14px; font-family:var(--font-sans);
}
.faq-question i { color:var(--green); transition:var(--ease); flex-shrink:0; }
.faq-item.open .faq-question i { transform:rotate(45deg); }
.faq-answer { max-height:0; overflow:hidden; transition:max-height .32s ease; }
.faq-item.open .faq-answer { max-height:320px; }
.faq-answer-inner { padding:0 22px 18px; color:var(--text-s); font-size:.875rem; line-height:1.75; }

/* =========================================
   FOOTER
   ========================================= */
.footer { background:#0d2118; padding:80px 0 32px; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:52px; margin-bottom:52px; }
.footer-logo { height:32px; filter:brightness(0) invert(1); margin-bottom:14px; }
.footer-tagline { color:rgba(255,255,255,.45); font-size:.85rem; line-height:1.72; margin-bottom:22px; max-width:240px; }
.footer-social { display:flex; gap:8px; }
.footer-social a {
  width:34px; height:34px; background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.12); border-radius:8px;
  display:flex; align-items:center; justify-content:center;
  color:rgba(255,255,255,.4); font-size:.82rem; transition:var(--ease);
}
.footer-social a:hover { background:rgba(44,172,97,.2); border-color:var(--green); color:var(--green); }
.footer-col-title {
  font-size:.72rem; font-weight:700; text-transform:uppercase;
  letter-spacing:1.5px; margin-bottom:18px; color:rgba(255,255,255,.5);
}
.footer-links { list-style:none; display:flex; flex-direction:column; gap:10px; }
.footer-links a { color:rgba(255,255,255,.45); font-size:.85rem; transition:var(--ease); }
.footer-links a:hover { color:var(--green); }
.footer-bottom {
  padding-top:28px; border-top:1px solid rgba(255,255,255,.08);
  display:flex; align-items:center; justify-content:space-between;
}
.footer-copy { color:rgba(255,255,255,.3); font-size:.78rem; }
.footer-copy a { color:var(--green); }
.footer-legal { display:flex; gap:20px; }
.footer-legal a { color:rgba(255,255,255,.3); font-size:.78rem; transition:var(--ease); }
.footer-legal a:hover { color:rgba(255,255,255,.6); }

/* =========================================
   AOS
   ========================================= */
.aos { opacity:0; transform:translateY(20px); transition:opacity .55s ease,transform .55s ease; }
.aos.visible { opacity:1; transform:translateY(0); }
.aos-delay-1{transition-delay:.08s} .aos-delay-2{transition-delay:.16s}
.aos-delay-3{transition-delay:.24s} .aos-delay-4{transition-delay:.32s}
.aos-delay-5{transition-delay:.40s} .aos-delay-6{transition-delay:.48s}

/* =========================================
   ANIMATIONS
   ========================================= */
@keyframes blink { 0%,100%{opacity:1;} 50%{opacity:.3;} }
@keyframes float { 0%,100%{transform:translateY(0);} 50%{transform:translateY(-8px);} }

/* =========================================
   RESPONSIVE
   ========================================= */
@media(max-width:1024px) {
  .hero-content { grid-template-columns:1fr; text-align:center; gap:40px; }
  .hero-illustration { display:none; }
  .hero-actions { justify-content:center; }
  .hero-trust { justify-content:center; }
  .hero-desc { margin:0 auto 36px; }
  .stats-inner { grid-template-columns:repeat(2,1fr); padding:40px; gap:28px; }
  .footer-grid { grid-template-columns:1fr 1fr; gap:40px; }
  .tech-grid { grid-template-columns:1fr 1fr; }
  .config-grid { grid-template-columns:1fr; }
  .config-summary { position:static; }
  .about-stats-bar { grid-template-columns:repeat(2,1fr) !important; }
  .about-stats-bar > div:nth-child(2) { border-right:none; }
  .about-stats-bar > div:nth-child(3),
  .about-stats-bar > div:nth-child(4) { border-top:1px solid var(--border); }
  .about-stats-bar > div:nth-child(3) { border-right:1px solid var(--border); }
}

@media(max-width:768px) {
  .nav-links {
    display:none; position:fixed; top:0; left:0; right:0; bottom:0;
    background:rgba(255,255,255,.98); backdrop-filter:blur(20px);
    flex-direction:column; justify-content:center; align-items:center;
    gap:6px; padding:80px 24px 24px; z-index:1001;
  }
  .nav-links.open { display:flex; }
  .nav-links > li > a { color:var(--text-h); font-size:1.1rem; }
  .hamburger { display:flex; }
  .form-grid { grid-template-columns:1fr; }
  .footer-grid { grid-template-columns:1fr; gap:32px; }
  .footer-bottom { flex-direction:column; gap:14px; text-align:center; }
  .stats-inner { grid-template-columns:1fr 1fr; padding:30px; }
  .cta-inner { padding:48px 24px; }
  .configurator { padding:24px; }
  .ticket-form { padding:24px; }
  .tech-grid { grid-template-columns:1fr; }
  .dropdown-menu { left:0; transform:translateX(0) translateY(-6px); }
  .dropdown:hover .dropdown-menu { transform:translateX(0) translateY(0); }
}

@media(max-width:480px) {
  .stats-inner { grid-template-columns:1fr 1fr; }
  .pricing-card { flex:0 0 min(100%,100%); max-width:340px; }
}

/* .pricing-extreme — defined below in the redesigned section */

/* =========================================
   EXTREME PRICING CARD (inline with siblings)
   ========================================= */
.pricing-card-extreme {
  background:linear-gradient(160deg,#0d2118 0%,#143326 100%);
  border-color:rgba(44,172,97,.35) !important;
  box-shadow:0 0 0 3px rgba(44,172,97,.12),var(--shadow-md) !important;
}
.pricing-card-extreme:hover {
  border-color:rgba(44,172,97,.6) !important;
  box-shadow:0 0 0 4px rgba(44,172,97,.18),var(--shadow-lg) !important;
}
.pricing-card-extreme::before {
  content:'Max Power';
  position:absolute; top:-1px; left:50%; transform:translateX(-50%);
  background:linear-gradient(90deg,var(--green),var(--green-mid)); color:#fff;
  font-size:.62rem; font-weight:800; letter-spacing:1px;
  padding:3px 14px; border-radius:0 0 8px 8px;
}
.btn-extreme {
  background:rgba(44,172,97,.2); color:#7fefb0;
  border:1.5px solid rgba(44,172,97,.4);
  box-shadow:none;
}
.btn-extreme:hover {
  background:rgba(44,172,97,.35); color:#7fefb0;
  border-color:rgba(44,172,97,.6); transform:translateY(-1px);
}

/* =========================================
   STARTER HORIZONTAL STRIP
   ========================================= */
.pricing-starter {
  display:grid;
  grid-template-columns:80px 1fr auto;
  align-items:center;
  gap:32px;
  background:#fff;
  border:1.5px solid var(--border);
  border-radius:var(--r-xl);
  padding:24px 36px;
  margin-bottom:0;
  box-shadow:var(--shadow-xs);
  transition:var(--ease);
  position:relative;
  overflow:hidden;
}
.pricing-starter::before {
  content:'';
  position:absolute; top:0; left:0; bottom:0; width:4px;
  background:linear-gradient(180deg, var(--green), var(--green-mid));
  border-radius:4px 0 0 4px;
}
.pricing-starter:hover {
  box-shadow:var(--shadow-md);
  transform:translateY(-2px);
  border-color:rgba(44,172,97,.3);
}
.starter-illus { width:72px; height:72px; flex-shrink:0; }
.starter-illus svg { width:72px; height:72px; }
.starter-eyebrow {
  font-size:.67rem; font-weight:700; text-transform:uppercase;
  letter-spacing:1.4px; color:var(--green); margin-bottom:4px;
  display:flex; align-items:center; gap:6px;
}
.starter-name {
  font-size:1.35rem; font-weight:900; color:var(--text-h); margin-bottom:10px;
  font-family:var(--font-sans);
}
.starter-features {
  display:flex; flex-wrap:wrap; gap:5px 20px;
}
.starter-feat {
  display:flex; align-items:center; gap:6px;
  font-size:.8rem; color:var(--text-s);
}
.starter-feat i { color:var(--green); font-size:.68rem; }
.starter-price-block {
  text-align:right; flex-shrink:0;
}
.starter-from {
  font-size:.62rem; color:var(--text-m); text-transform:uppercase;
  letter-spacing:1.4px; margin-bottom:1px;
}
.starter-price {
  font-size:1.95rem; font-weight:900; color:var(--green);
  font-family:var(--font-mono); line-height:1.1; margin-bottom:2px;
  white-space:nowrap;
}
.starter-price small { font-size:.75rem; font-weight:400; color:var(--text-m); }
.starter-period { font-size:.68rem; color:var(--text-m); margin-bottom:14px; }
@media(max-width:860px) {
  .pricing-starter {
    grid-template-columns:1fr;
    text-align:center; padding:28px 24px;
  }
  .pricing-starter::before { top:0; left:0; right:0; bottom:auto; width:auto; height:4px; border-radius:4px 4px 0 0; }
  .starter-illus { margin:0 auto; }
  .starter-features { justify-content:center; }
  .starter-price-block { text-align:center; }
  .starter-eyebrow { justify-content:center; }
}

/* =========================================
   VPS COMPARISON TABLE
   ========================================= */
.vps-compare-wrap {
  background:#fff; border:1px solid var(--border); border-radius:var(--r-xl);
  overflow:hidden; margin-top:52px; box-shadow:var(--shadow-md);
  overflow-x:auto;
}
/* Single source of truth for grid columns */
.vps-compare-header,
.vps-compare-row {
  display:grid;
  grid-template-columns:110px 2fr 90px 1.3fr 115px 140px 110px;
  column-gap:24px; row-gap:0; align-items:center;
  min-width:900px;
}
.vps-compare-header {
  padding:16px 32px;
  background:var(--bg-section); border-bottom:2px solid var(--border);
}
.vps-compare-header > div {
  font-size:.64rem; font-weight:800; text-transform:uppercase; letter-spacing:1.4px;
  color:var(--text-m); display:flex; align-items:center; gap:5px; white-space:nowrap;
}
.vps-compare-header > div svg { width:14px; height:14px; flex-shrink:0; }

.vps-compare-row {
  padding:20px 32px;
  border-bottom:1px solid var(--border-lt); transition:background .15s;
}
.vps-compare-row:last-child { border-bottom:none; }
.vps-compare-row:hover { background:var(--bg-alt); }
.vps-compare-row.featured {
  background:linear-gradient(90deg,var(--green-pale) 0%,#fff 100%);
  border-left:3px solid var(--green);
  padding-left:29px;
}
.vps-compare-row.featured:hover { background:linear-gradient(90deg,var(--green-light) 0%,var(--green-pale) 100%); }

.vcr-badge {
  display:inline-flex; align-items:center; justify-content:center;
  background:var(--text-h); color:#fff;
  font-size:.78rem; font-weight:800; padding:5px 12px;
  border-radius:8px; font-family:var(--font-mono);
}
.vps-compare-row.featured .vcr-badge { background:var(--green); }

.vcr-best {
  display:inline-flex; align-items:center; gap:4px;
  background:var(--green); color:#fff;
  font-size:.6rem; font-weight:800; letter-spacing:1px;
  padding:2px 8px; border-radius:100px; margin-left:6px;
  text-transform:uppercase;
}

.spec-bar-cell { padding-right:12px; }
.spec-bar-val {
  font-weight:800; font-size:.9rem; color:var(--text-h); margin-bottom:5px;
  font-family:var(--font-mono);
}
.spec-bar-val small { font-size:.72rem; font-weight:400; color:var(--text-m); }
.spec-bar-track {
  height:5px; background:var(--border); border-radius:3px; overflow:hidden;
}
.spec-bar-fill {
  height:100%; border-radius:3px;
  background:linear-gradient(90deg,var(--green),var(--green-mid));
  transition:width .6s ease;
}
.vps-compare-row.featured .spec-bar-fill {
  background:linear-gradient(90deg,var(--green-dark),var(--green));
}

.vcr-cores {
  display:flex; flex-direction:column; align-items:flex-start; gap:6px;
}
.vcr-cores-val {
  font-weight:800; font-size:.9rem; color:var(--text-h);
  font-family:var(--font-mono); line-height:1;
}
.vcr-cores-val small { font-size:.68rem; font-weight:400; color:var(--text-m); margin-left:3px; }
.core-pips { display:flex; gap:3px; }
.core-pip {
  width:8px; height:8px; background:var(--green-soft); border-radius:2px;
}
.core-pip.filled { background:var(--green); }

.vcr-bw {
  display:inline-flex; align-items:center; gap:5px;
  background:var(--green-pale); color:var(--green-dark);
  font-size:.72rem; font-weight:700; padding:4px 9px;
  border-radius:100px; border:1px solid var(--green-light);
  white-space:nowrap;
}
.vcr-bw i { font-size:.65rem; }

.vcr-price { font-size:1.25rem; font-weight:900; color:var(--green); font-family:var(--font-mono); white-space:nowrap; }
.vcr-price small { font-size:.75rem; font-weight:400; color:var(--text-m); }

/* Subtle separator before price column */
.vps-compare-row > div:nth-child(6),
.vps-compare-header > div:nth-child(6) {
  border-left:1px solid var(--border);
  padding-left:20px;
}

/* Right-align the Order button so it mirrors the left padding on the Plan column */
.vps-compare-row > div:last-child { display:flex; justify-content:flex-end; }
.vps-compare-header > div:last-child { justify-content:flex-end; }

/* VPS table Order button — no lift on hover, just slide the arrow */
.vps-compare-row .btn:hover {
  transform:none !important;
  box-shadow:none !important;
}
.vps-compare-row .btn:hover i {
  transform:translateX(4px);
  transition:transform .2s ease;
}
.vps-compare-row .btn i {
  transition:transform .2s ease;
}

@media(max-width:768px) {
  .vps-compare-header { display:none; }
  .vps-compare-row {
    grid-template-columns:1fr 1fr !important;
    grid-template-rows:auto auto auto auto;
    padding:18px; gap:10px; min-width:unset;
  }
  .vps-compare-row > div:nth-child(1) { grid-row:1; grid-column:1; }
  .vps-compare-row > div:nth-child(6) { grid-row:1; grid-column:2; text-align:right; }
  .spec-bar-cell { grid-column:1/-1; }
  .vps-compare-row > div:nth-child(5),
  .vps-compare-row > div:nth-child(3) { grid-column:1; }
  .vps-compare-row > div:nth-child(7) { grid-column:2; justify-self:end; }
}

/* =========================================
   SUPPORT WIZARD
   ========================================= */
.support-wizard { padding:72px 0; background:var(--bg); }

.dept-grid {
  display:grid; grid-template-columns:repeat(4,1fr);
  gap:18px; margin-top:44px;
}
.dept-card {
  background:#fff; border:2px solid var(--border);
  border-radius:var(--r-lg); padding:28px 22px; text-align:center;
  cursor:pointer; transition:var(--ease); position:relative;
  box-shadow:var(--shadow-xs);
}
.dept-card:hover { border-color:var(--green-soft); transform:translateY(-3px); box-shadow:var(--shadow-md); }
.dept-card.active { border-color:var(--green); box-shadow:0 0 0 3px var(--green-pale),var(--shadow-md); }
.dept-card.active::after {
  content:''; position:absolute; bottom:-12px; left:50%;
  transform:translateX(-50%);
  border-left:10px solid transparent; border-right:10px solid transparent;
  border-top:12px solid var(--green); pointer-events:none;
}

.dept-icon-wrap {
  width:64px; height:64px; border-radius:18px; margin:0 auto 16px;
  display:flex; align-items:center; justify-content:center; font-size:1.5rem;
  transition:var(--ease);
}
.dept-card:hover .dept-icon-wrap,
.dept-card.active .dept-icon-wrap { transform:scale(1.1); }

.dept-card-title { font-size:1rem; font-weight:800; color:var(--text-h); margin-bottom:6px; }
.dept-card-desc  { font-size:.8rem; color:var(--text-s); line-height:1.5; }

/* Result panel */
.wizard-result {
  display:none; margin-top:28px;
  background:#fff; border:1px solid var(--border);
  border-top:3px solid var(--green);
  border-radius:var(--r-xl); padding:36px;
  box-shadow:var(--shadow-md); animation:slideDown .3s ease;
}
.wizard-result.visible { display:grid; grid-template-columns:1fr 1fr; gap:36px; align-items:start; }
@keyframes slideDown { from{opacity:0;transform:translateY(-12px);} to{opacity:1;transform:translateY(0);} }

.wizard-result-title { font-size:1.4rem; font-weight:800; color:var(--text-h); margin-bottom:8px; }
.wizard-result-desc  { color:var(--text-s); font-size:.9rem; line-height:1.7; margin-bottom:20px; }
.wizard-result-cta   { display:flex; gap:10px; flex-wrap:wrap; }

.kb-suggestions { list-style:none; }
.kb-suggestions li { border-bottom:1px solid var(--border-lt); }
.kb-suggestions li:last-child { border-bottom:none; }
.kb-suggestions a {
  display:flex; align-items:center; gap:10px;
  padding:11px 0; font-size:.875rem; color:var(--text-b); transition:var(--ease);
}
.kb-suggestions a:hover { color:var(--green); padding-left:4px; }
.kb-suggestions a i { color:var(--green-soft); font-size:.8rem; flex-shrink:0; }
.kb-suggestions-label {
  font-size:.72rem; font-weight:700; text-transform:uppercase; letter-spacing:2px;
  color:var(--text-m); margin-bottom:10px;
}

@media(max-width:768px) {
  .dept-grid { grid-template-columns:1fr 1fr; }
  .wizard-result.visible { grid-template-columns:1fr; gap:24px; }
}
@media(max-width:480px) {
  .dept-grid { grid-template-columns:1fr 1fr; }
}

/* =========================================
   SUPPORT CONTACT HERO
   ========================================= */
.support-contact-section {
  padding:72px 0; background:var(--bg-alt);
}
.support-contact-grid {
  display:grid; grid-template-columns:1fr 1fr; gap:20px; margin-top:44px;
}
.support-contact-card {
  background:#fff; border:2px solid var(--border); border-radius:var(--r-xl);
  padding:36px; display:flex; align-items:flex-start; gap:20px;
  transition:var(--ease); text-decoration:none; box-shadow:var(--shadow-sm);
  position:relative; overflow:hidden;
}
.support-contact-card.primary { border-color:var(--green); }
.support-contact-card.primary::before {
  content:''; position:absolute; top:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg,var(--green),var(--green-mid));
}
.support-contact-card:hover { transform:translateY(-3px); box-shadow:var(--shadow-lg); }

.scc-icon {
  width:52px; height:52px; border-radius:14px; flex-shrink:0;
  display:flex; align-items:center; justify-content:center; font-size:1.3rem;
}
.scc-label {
  font-size:.7rem; font-weight:800; text-transform:uppercase; letter-spacing:1.5px;
  color:var(--text-m); margin-bottom:5px;
}
.scc-title { font-size:1.25rem; font-weight:800; color:var(--text-h); margin-bottom:6px; }
.scc-desc  { font-size:.86rem; color:var(--text-s); line-height:1.6; margin-bottom:14px; }
.scc-action {
  display:inline-flex; align-items:center; gap:6px;
  font-size:.85rem; font-weight:700; color:var(--green);
}
.scc-action i { font-size:.75rem; transition:var(--ease); }
.support-contact-card:hover .scc-action i { transform:translateX(3px); }

@media(max-width:768px) {
  .support-contact-grid { grid-template-columns:1fr; }
}

/* =========================================
   SELF-HELP RESOURCES
   ========================================= */
.self-help { padding:72px 0; background:var(--bg); }
.self-help-grid {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:18px; margin-top:44px;
}
.self-help-card {
  background:#fff; border:1px solid var(--border); border-radius:var(--r-lg);
  padding:28px; display:flex; align-items:flex-start; gap:16px;
  transition:var(--ease); text-decoration:none; box-shadow:var(--shadow-xs);
}
.self-help-card:hover { border-color:var(--green-soft); transform:translateY(-2px); box-shadow:var(--shadow-md); }
.shc-icon {
  width:48px; height:48px; border-radius:13px; flex-shrink:0;
  display:flex; align-items:center; justify-content:center; font-size:1.2rem;
}
.shc-title { font-size:.95rem; font-weight:700; color:var(--text-h); margin-bottom:5px; }
.shc-desc  { font-size:.82rem; color:var(--text-s); line-height:1.55; }

@media(max-width:768px) {
  .self-help-grid { grid-template-columns:1fr; }
}

/* =========================================
   TERMS OF SERVICE PAGE
   ========================================= */
.terms-page { padding:60px 0 100px; background:var(--bg); }
.terms-grid { display:grid; grid-template-columns:240px 1fr; gap:48px; align-items:start; }
.terms-nav {
  position:sticky; top:100px; background:#fff; border:1px solid var(--border);
  border-radius:var(--r-lg); padding:20px; box-shadow:var(--shadow-xs);
}
.terms-nav-title {
  font-size:.7rem; font-weight:800; text-transform:uppercase; letter-spacing:2px;
  color:var(--text-m); margin-bottom:14px;
}
.terms-nav a {
  display:block; padding:7px 10px; border-radius:7px; font-size:.84rem;
  color:var(--text-s); transition:var(--ease); border-left:2px solid transparent;
}
.terms-nav a:hover { color:var(--green); background:var(--green-pale); }
.terms-nav a.active { color:var(--green); background:var(--green-pale); border-left-color:var(--green); }

.terms-meta {
  display:flex; gap:20px; margin-bottom:32px; flex-wrap:wrap;
}
.terms-meta-item {
  display:flex; align-items:center; gap:7px; font-size:.82rem; color:var(--text-m);
}
.terms-meta-item i { color:var(--green); }

.terms-body { max-width:760px; }
.terms-section { margin-bottom:44px; scroll-margin-top:100px; }
.terms-section h2 {
  font-size:1.2rem; font-weight:800; color:var(--text-h); margin-bottom:14px;
  padding-bottom:10px; border-bottom:1px solid var(--border);
  display:flex; align-items:center; gap:10px;
}
.terms-section h2 .tos-num {
  display:inline-flex; align-items:center; justify-content:center;
  width:28px; height:28px; background:var(--green); color:#fff;
  border-radius:8px; font-size:.78rem; font-weight:900; flex-shrink:0;
}
.terms-section p { color:var(--text-s); font-size:.91rem; line-height:1.8; margin-bottom:12px; }
.terms-section p:last-child { margin-bottom:0; }
.terms-highlight {
  background:var(--green-pale); border-left:3px solid var(--green);
  border-radius:0 var(--r) var(--r) 0; padding:14px 18px; margin:14px 0;
}
.terms-highlight p { color:var(--text-b); margin:0; }
.terms-warning {
  background:#fff8e6; border-left:3px solid #f0b429;
  border-radius:0 var(--r) var(--r) 0; padding:14px 18px; margin:14px 0;
}
.terms-warning p { color:#7a5800; margin:0; }

@media(max-width:900px) {
  .terms-grid { grid-template-columns:1fr; }
  .terms-nav { position:static; }
}

/* =========================================
   2×2 / 3×2 FEATURE GRID
   ========================================= */
.features-grid-2x2 {
  display:grid; grid-template-columns:repeat(2,1fr);
  gap:20px; margin-top:40px;
}
.features-grid-3x2 {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:20px; margin-top:40px;
}
@media(max-width:900px) {
  .features-grid-3x2 { grid-template-columns:repeat(2,1fr); }
}
@media(max-width:640px) {
  .features-grid-2x2,
  .features-grid-3x2 { grid-template-columns:1fr; }
}

/* =========================================
   NAVBAR — transparent over dark heroes
   ========================================= */
.navbar:not(.scrolled) .nav-logo {
  filter:brightness(0) invert(1);
}
.navbar:not(.scrolled) .nav-links > li > a {
  color:rgba(255,255,255,.8);
}
.navbar:not(.scrolled) .nav-links > li > a:hover {
  color:#fff; background:rgba(255,255,255,.1);
}
.navbar:not(.scrolled) .nav-links > li > a.active {
  color:#7fefb0;
}
.navbar:not(.scrolled) .hamburger span {
  background:rgba(255,255,255,.9);
}
/* Keep dropdown still readable */
.navbar:not(.scrolled) .dropdown-menu a {
  color:var(--text-s) !important;
}
.navbar:not(.scrolled) .dropdown-menu a:hover {
  color:var(--green) !important;
}

/* =========================================
   STATUS BANNER
   ========================================= */
.status-banner {
  padding:9px 0; position:relative; z-index:999;
}
.status-banner.operational  { background:#e5f7ee; border-bottom:1px solid var(--green-soft); }
.status-banner.degraded     { background:#fff8e0; border-bottom:1px solid #f0d060; }
.status-banner.outage       { background:#fff0f0; border-bottom:1px solid #f09090; }
.status-banner-inner {
  display:flex; align-items:center; justify-content:center; gap:10px;
  font-size:.84rem; font-weight:500; color:var(--text-h);
}
.status-dot {
  width:8px; height:8px; border-radius:50%; flex-shrink:0;
}
.operational .status-dot  { background:#2cac61; animation:blink 2s infinite; }
.degraded    .status-dot  { background:#f0b429; animation:blink 1.5s infinite; }
.outage      .status-dot  { background:#e53535; animation:blink 1s infinite; }
.status-link {
  color:var(--green); font-weight:700; font-size:.82rem;
  text-decoration:underline; text-underline-offset:2px;
}
.operational .status-link  { color:var(--green-dark); }
.degraded    .status-link  { color:#9a7a00; }
.outage      .status-link  { color:#c03030; }

/* =========================================
   KB SEARCH BAR
   ========================================= */
.kb-search-section {
  background:linear-gradient(180deg,var(--bg-alt) 0%,var(--bg) 100%);
  padding:40px 0; border-bottom:1px solid var(--border);
}
.kb-search-label {
  text-align:center; margin-bottom:16px;
  font-size:.78rem; font-weight:700; text-transform:uppercase;
  letter-spacing:2px; color:var(--text-m);
}
.kb-search-form {
  display:flex; align-items:center; background:#fff;
  border:2px solid var(--border); border-radius:14px;
  padding:6px 6px 6px 20px; box-shadow:var(--shadow-md);
  gap:12px; transition:var(--ease);
  max-width:800px; margin:0 auto;
}
.kb-search-form:focus-within {
  border-color:var(--green); box-shadow:0 0 0 4px var(--green-pale),var(--shadow-md);
}
.kb-search-icon { color:var(--text-m); font-size:1rem; flex-shrink:0; }
.kb-search-input {
  flex:1; border:none; outline:none; font-size:1rem;
  color:var(--text-h); background:transparent; font-family:var(--font-sans);
}
.kb-search-input::placeholder { color:var(--text-m); }
.kb-search-btn {
  background:var(--green); color:#fff; border:none; border-radius:10px;
  padding:12px 22px; font-size:.9rem; font-weight:600; cursor:pointer;
  display:flex; align-items:center; gap:8px; white-space:nowrap;
  transition:var(--ease); font-family:var(--font-sans);
}
.kb-search-btn:hover { background:var(--green-dark); }
.kb-search-tags {
  display:flex; gap:8px; flex-wrap:wrap; justify-content:center; margin-top:12px;
}
.kb-search-tag {
  background:var(--green-pale); border:1px solid var(--green-light);
  color:var(--green-dark); padding:4px 13px; border-radius:100px;
  font-size:.76rem; font-weight:600; cursor:pointer; transition:var(--ease);
  text-decoration:none;
}
.kb-search-tag:hover { background:var(--green-light); }

/* =========================================
   FAQ FOOTER LINK
   ========================================= */
.faq-footer {
  text-align:center; margin-top:24px; padding-top:20px;
  border-top:1px dashed var(--border);
}
.faq-footer p { color:var(--text-m); font-size:.875rem; }
.faq-footer a { color:var(--green); font-weight:700; }
.faq-footer a:hover { text-decoration:underline; text-underline-offset:2px; }

/* =========================================
   HOW IT WORKS (homepage between stats+CTA)
   ========================================= */
.how-it-works { padding:80px 0; background:var(--bg); }
.steps-grid {
  display:grid;
  grid-template-columns:1fr 48px 1fr 48px 1fr;
  align-items:start; margin-top:52px; gap:0;
}
.step-card {
  background:#fff; border:1px solid var(--border);
  border-radius:var(--r-xl); padding:32px 28px;
  box-shadow:var(--shadow-sm); transition:var(--ease); text-align:center;
}
.step-card:hover { transform:translateY(-3px); box-shadow:var(--shadow-md); border-color:var(--green-soft); }
.step-num {
  font-size:3.5rem; font-weight:900; font-family:var(--font-mono);
  color:var(--green-light); line-height:1; margin-bottom:16px;
}
.step-icon-wrap {
  width:56px; height:56px; border-radius:16px; margin:0 auto 16px;
  display:flex; align-items:center; justify-content:center; font-size:1.4rem;
}
.step-title { font-size:1.1rem; font-weight:800; color:var(--text-h); margin-bottom:8px; }
.step-desc  { font-size:.875rem; color:var(--text-s); line-height:1.7; }
.step-connector {
  display:flex; align-items:center; justify-content:center;
  padding-top:60px; color:var(--green-soft); font-size:1.2rem;
}
@media(max-width:900px) {
  .steps-grid {
    grid-template-columns:1fr;
    gap:16px;
  }
  .step-connector { padding-top:0; transform:rotate(90deg); height:40px; }
}

/* =========================================
   ABOUT PAGE
   ========================================= */
.about-who { padding:96px 0; background:var(--bg); }
.about-who-grid {
  display:grid; grid-template-columns:1fr 1fr; gap:72px; align-items:center;
}
.about-who-title { font-size:clamp(1.9rem,3.8vw,2.8rem); font-weight:800; margin-bottom:20px; }
.about-who-title em { font-style:normal; color:var(--green); }
.about-who-body { color:var(--text-s); font-size:1rem; line-height:1.85; }
.about-who-body p { margin-bottom:16px; }
.about-who-body p:last-child { margin-bottom:0; }
.about-who-stats {
  display:grid; grid-template-columns:1fr 1fr; gap:18px;
}
.about-stat-card {
  background:var(--bg-alt); border:1px solid var(--border);
  border-radius:var(--r-lg); padding:22px; text-align:center;
  transition:var(--ease);
}
.about-stat-card:hover { border-color:var(--green-soft); }
.about-stat-num { font-size:2.2rem; font-weight:900; color:var(--green); font-family:var(--font-mono); line-height:1; margin-bottom:4px; }
.about-stat-label { font-size:.78rem; color:var(--text-m); text-transform:uppercase; letter-spacing:1.2px; }

/* Values cards */
.about-values { padding:80px 0; background:var(--bg-alt); }
.values-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:52px; }
.value-card {
  background:#fff; border:1px solid var(--border); border-radius:var(--r-xl);
  padding:32px 28px; transition:var(--ease); box-shadow:var(--shadow-xs);
  display:flex; flex-direction:column;
}
.value-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-md); }
.value-icon {
  width:56px; height:56px; border-radius:16px; margin-bottom:20px;
  display:flex; align-items:center; justify-content:center; font-size:1.35rem;
}
.value-title { font-size:1.05rem; font-weight:800; color:var(--text-h); margin-bottom:10px; }
.value-desc  { color:var(--text-s); font-size:.875rem; line-height:1.72; flex:1; }
.value-tag   {
  display:inline-flex; align-items:center; gap:5px; margin-top:14px;
  font-size:.7rem; font-weight:700; text-transform:uppercase; letter-spacing:1.2px;
  padding:4px 10px; border-radius:100px;
}

/* Timeline */
.about-timeline { padding:80px 0; background:var(--bg); }
.timeline-wrap {
  position:relative; margin-top:52px;
  padding-bottom:16px;
}
.timeline-track {
  position:absolute; top:9px; left:0; right:0; height:2px;
  background:var(--border);
}
.timeline-track-fill {
  position:absolute; top:9px; left:0; height:2px;
  background:linear-gradient(90deg,var(--green),var(--green-mid));
  transition:width 1.5s ease;
}
.timeline-items {
  display:grid; grid-template-columns:repeat(5,1fr);
  gap:24px; position:relative;
}
.timeline-item { text-align:center; padding-top:0; }
.timeline-dot {
  width:18px; height:18px; border-radius:50%; background:var(--green);
  border:3px solid #fff; box-shadow:0 0 0 3px var(--green-soft);
  margin:0 auto 14px; position:relative; z-index:1; transition:var(--ease);
}
.timeline-item:hover .timeline-dot { transform:scale(1.3); box-shadow:0 0 0 4px var(--green-light); }
.timeline-year {
  font-family:var(--font-mono); font-size:.8rem; font-weight:800;
  color:var(--green); margin-bottom:6px;
}
.timeline-title { font-weight:700; color:var(--text-h); font-size:.9rem; margin-bottom:4px; }
.timeline-desc  { font-size:.78rem; color:var(--text-s); line-height:1.55; }
@media(max-width:900px) {
  .timeline-items { grid-template-columns:1fr; }
  .timeline-track, .timeline-track-fill { display:none; }
  .timeline-item { text-align:left; padding-left:28px; border-left:2px solid var(--border); margin-left:9px; padding-top:0; padding-bottom:20px; }
  .timeline-dot { position:absolute; left:-10px; margin:0; top:0; }
  .timeline-item { position:relative; }
}

/* Different section */
.about-different { padding:80px 0; background:var(--bg-alt); }
.different-grid {
  display:grid; grid-template-columns:1fr 1fr; gap:32px; margin-top:52px;
}
.different-col { }
.different-col-title {
  font-size:1rem; font-weight:800; margin-bottom:18px;
  display:flex; align-items:center; gap:10px;
}
.different-col-title .col-badge {
  font-size:.68rem; font-weight:800; letter-spacing:1.5px;
  padding:4px 12px; border-radius:100px; text-transform:uppercase;
}
.different-list { list-style:none; display:flex; flex-direction:column; gap:10px; }
.different-list li {
  display:flex; align-items:center; gap:12px; padding:12px 16px;
  background:#fff; border:1px solid var(--border); border-radius:var(--r);
  font-size:.875rem;
}
.different-list li i { font-size:.85rem; flex-shrink:0; }
.different-list.them li i  { color:#e53535; }
.different-list.us   li i  { color:var(--green); }
.different-list.them li    { color:var(--text-s); }
.different-list.us   li    { color:var(--text-b); font-weight:500; }
/* About page — responsive stats bar (4-col → 2-col on mobile) */
@media(max-width:640px) {
  .about-stats-bar { grid-template-columns:repeat(2,1fr) !important; }
  .about-stats-bar > div:nth-child(2) { border-right:1px solid var(--border); }
  .about-stats-bar > div:nth-child(3),
  .about-stats-bar > div:nth-child(4) { border-top:1px solid var(--border); }
  .about-stats-bar > div:nth-child(3) { border-right:1px solid var(--border); }
  .about-stats-bar > div:nth-child(4) { border-right:none; }
}
@media(max-width:768px) {
  .about-who-grid { grid-template-columns:1fr; gap:40px; }
  .values-grid    { grid-template-columns:1fr 1fr; }
  .different-grid { grid-template-columns:1fr; }
}
@media(max-width:580px) {
  .values-grid { grid-template-columns:1fr; }
}

/* =========================================
   EXTREME PLAN — redesigned
   ========================================= */
.pricing-extreme {
  display:grid; grid-template-columns:auto 1fr auto;
  align-items:center; gap:36px;
  background:#0d2118; border:1px solid rgba(44,172,97,.25);
  border-top:3px solid var(--green);
  border-radius:var(--r-xl); padding:32px 40px; margin-top:20px;
  position:relative; overflow:hidden;
  box-shadow:0 12px 40px rgba(13,31,24,.3);
}
.pricing-extreme::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse at 15% 50%,rgba(44,172,97,.13) 0%,transparent 55%);
  pointer-events:none;
}
.extreme-illus { flex-shrink:0; width:80px; height:80px; position:relative; z-index:1; }
.extreme-illus svg { width:80px; height:80px; }
.extreme-body { position:relative; z-index:1; }
.extreme-eyebrow {
  display:inline-flex; align-items:center; gap:6px; margin-bottom:8px;
  background:rgba(44,172,97,.18); border:1px solid rgba(44,172,97,.35);
  color:#7fefb0; padding:4px 13px; border-radius:100px;
  font-size:.68rem; font-weight:800; letter-spacing:1.5px;
}
.extreme-name { font-size:1.6rem; font-weight:900; color:#fff; margin-bottom:8px; }
.extreme-features {
  display:flex; flex-wrap:wrap; gap:6px 20px; list-style:none;
}
.extreme-features li {
  display:flex; align-items:center; gap:7px;
  color:rgba(255,255,255,.7); font-size:.82rem;
}
.extreme-features li i { color:#7fefb0; font-size:.72rem; }
.extreme-price-block { text-align:right; position:relative; z-index:1; flex-shrink:0; }
.extreme-price-label { font-size:.68rem; color:rgba(255,255,255,.4); text-transform:uppercase; letter-spacing:1.5px; margin-bottom:6px; }
.extreme-amount { font-size:2.4rem; font-weight:900; color:#7fefb0; line-height:1; font-family:var(--font-mono); }
.extreme-amount small { font-size:.8rem; font-weight:400; color:rgba(255,255,255,.45); }
.extreme-billing { font-size:.72rem; color:rgba(255,255,255,.5); margin-bottom:14px; }

@media(max-width:900px) {
  .pricing-extreme {
    grid-template-columns:1fr;
    text-align:center; padding:28px 24px;
  }
  .extreme-illus { margin:0 auto; }
  .extreme-features { justify-content:center; }
  .extreme-price-block { text-align:center; }
}

/* vcr-badge + vcr-best stacking */
.vcr-badge-wrap { display:flex; flex-direction:column; align-items:flex-start; gap:6px; }

/* =========================================
   COMPARISON TABLE — EXTREME COLUMN
   ========================================= */
.ct-extreme-col {
  background:#0d2118 !important;
  border-left:2px solid rgba(44,172,97,.3) !important;
}
/* Row separators inside extreme column — dark green, not white */
.comparison-table tbody tr:not(.ct-section-row) .ct-extreme-col {
  border-bottom:1px solid rgba(44,172,97,.12) !important;
}
/* Icon — make it white/light so it reads on dark background */
.ct-extreme-col .ct-col-illus svg {
  filter:brightness(0) invert(1) opacity(.75);
}
.ct-extreme-col .ct-plan-name   { color:rgba(255,255,255,.55) !important; }
.ct-extreme-col .ct-plan-price  { color:#7fefb0 !important; font-size:1.6rem !important; }
.ct-extreme-col .ct-plan-price small { color:rgba(255,255,255,.45) !important; }
.ct-extreme-col .ct-plan-period { color:rgba(255,255,255,.5) !important; }
.ct-extreme-col .btn { background:rgba(44,172,97,.2) !important; color:#7fefb0 !important; border:1px solid rgba(44,172,97,.4) !important; }
.ct-extreme-col .btn:hover { background:rgba(44,172,97,.35) !important; }
.ct-extreme-col .ct-val   { color:#7fefb0 !important; font-weight:800 !important; }
.ct-extreme-col .ct-free  { color:#7fefb0 !important; }
.ct-extreme-col .ct-badge { background:rgba(44,172,97,.18) !important; border-color:rgba(44,172,97,.35) !important; color:#7fefb0 !important; }
.ct-extreme-col .ct-check { color:#7fefb0 !important; }
.ct-extreme-col .ct-cross { color:rgba(255,255,255,.18) !important; }
/* 2× Boosted — green to match column theme instead of amber */
.ct-extreme-col .ct-special { background:rgba(44,172,97,.22) !important; border-color:rgba(44,172,97,.45) !important; color:#7fefb0 !important; }
.ct-extreme-col:not(th) { color:rgba(255,255,255,.7) !important; }


/* =========================================
   ABOUT PAGE — HERO LAYOUT
   ========================================= */
.about-hero-layout { display:grid; grid-template-columns:1fr 1fr; gap:72px; align-items:center; }
@media(max-width:900px) { .about-hero-layout { grid-template-columns:1fr; gap:40px; } }

/* =========================================
   ABOUT PAGE — ENHANCED SECTIONS
   ========================================= */
/* Mission / manifesto section */
.about-mission {
  padding:96px 0;
  background:linear-gradient(160deg,#0d2118 0%,#143326 60%,#1c4d33 100%);
  position:relative; overflow:hidden;
}
.about-mission::before {
  content:''; position:absolute; inset:0; pointer-events:none;
  background:
    radial-gradient(ellipse at 25% 50%,rgba(44,172,97,.2) 0%,transparent 55%),
    radial-gradient(ellipse at 80% 80%,rgba(44,172,97,.1) 0%,transparent 45%);
}
.about-mission-grid {
  position:relative; z-index:1;
  display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center;
}
.about-mission-label {
  display:inline-flex; align-items:center; gap:8px; margin-bottom:22px;
  background:rgba(44,172,97,.13); border:1px solid rgba(44,172,97,.28);
  color:#7fefb0; padding:5px 15px; border-radius:100px;
  font-size:.72rem; font-weight:700; letter-spacing:1.5px; text-transform:uppercase; font-family:var(--font-mono);
}
.about-mission-quote {
  font-size:clamp(1.7rem,3.5vw,2.6rem); font-weight:900;
  color:#fff; line-height:1.25; letter-spacing:-.025em; margin-bottom:28px;
}
.about-mission-quote em { font-style:normal; color:#7fefb0; }
.about-mission-sub { color:rgba(255,255,255,.5); font-size:1rem; line-height:1.78; }
.about-mission-stats {
  display:grid; grid-template-columns:1fr 1fr; gap:16px;
}
.about-mission-stat {
  background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.1);
  border-radius:var(--r-lg); padding:24px 20px; text-align:center;
  transition:var(--ease);
}
.about-mission-stat:hover { background:rgba(44,172,97,.12); border-color:rgba(44,172,97,.3); }
.about-mission-stat-num { font-size:2.2rem; font-weight:900; color:#7fefb0; font-family:var(--font-mono); line-height:1; margin-bottom:6px; }
.about-mission-stat-label { font-size:.76rem; color:rgba(255,255,255,.5); text-transform:uppercase; letter-spacing:1.2px; }
@media(max-width:900px) {
  .about-mission-grid { grid-template-columns:1fr; gap:44px; }
}

/* Perks / why us strip */
.about-perks { padding:52px 0; background:var(--bg-section); border-top:1px solid var(--border); border-bottom:1px solid var(--border); }
.about-perks-inner { display:flex; align-items:center; justify-content:center; gap:48px; flex-wrap:wrap; }
.about-perk { display:flex; align-items:center; gap:12px; }
.about-perk-icon { width:44px; height:44px; border-radius:12px; display:flex; align-items:center; justify-content:center; font-size:1.1rem; flex-shrink:0; }
.about-perk-title { font-size:.9rem; font-weight:700; color:var(--text-h); }
.about-perk-sub { font-size:.78rem; color:var(--text-m); }

/* Team section */
.team-section { padding:80px 0; background:var(--bg); }
.team-grid { display:flex; flex-wrap:wrap; justify-content:center; gap:24px; margin-top:52px; }
.team-card {
  flex:0 0 min(100%,230px);
  background:#fff; border:1px solid var(--border);
  border-radius:var(--r-xl); padding:36px 24px; text-align:center;
  transition:var(--ease); box-shadow:var(--shadow-sm); position:relative; overflow:hidden;
}
.team-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg,var(--green),var(--green-mid));
  opacity:0; transition:var(--ease);
}
.team-card:hover { transform:translateY(-5px); box-shadow:var(--shadow-lg); border-color:var(--green-soft); }
.team-card:hover::before { opacity:1; }
.team-avatar {
  width:84px; height:84px; border-radius:50%; background:var(--green-light);
  border:3px solid var(--green-soft); margin:0 auto 18px;
  display:flex; align-items:center; justify-content:center;
  font-size:2.4rem; color:var(--green); overflow:hidden; transition:var(--ease);
}
.team-card:hover .team-avatar { border-color:var(--green); transform:scale(1.05); }
.team-name  { font-size:1rem; font-weight:800; color:var(--text-h); margin-bottom:4px; }
.team-role  { font-size:.72rem; color:var(--green-dark); font-weight:700; text-transform:uppercase; letter-spacing:1.2px; margin-bottom:10px; }
.team-bio   { font-size:.83rem; color:var(--text-s); line-height:1.6; }
.team-social { display:flex; justify-content:center; gap:8px; margin-top:16px; }
.team-social a {
  width:32px; height:32px; background:var(--bg-alt); border:1px solid var(--border);
  border-radius:8px; display:flex; align-items:center; justify-content:center;
  color:var(--text-m); font-size:.78rem; transition:var(--ease);
}
.team-social a:hover { background:var(--green-light); border-color:var(--green-soft); color:var(--green); }

/* Testimonials */
.testimonials { padding:80px 0; background:var(--bg-alt); }
.testimonials-grid {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:20px; margin-top:52px;
}
.testimonial-card {
  background:#fff; border:1px solid var(--border); border-radius:var(--r-xl);
  padding:32px 28px 28px; transition:var(--ease); box-shadow:var(--shadow-xs);
  display:flex; flex-direction:column; position:relative;
}
.testimonial-card:hover { transform:translateY(-3px); box-shadow:var(--shadow-md); border-color:var(--green-soft); }
.testimonial-quote-mark {
  font-size:4rem; line-height:1; color:var(--green-light);
  font-family:Georgia,serif; margin-bottom:8px;
}
.testimonial-stars { display:flex; gap:3px; margin-bottom:14px; }
.testimonial-stars i { color:#f0b429; font-size:.85rem; }
.testimonial-text { color:var(--text-s); font-size:.9rem; line-height:1.78; flex:1; }
.testimonial-author { margin-top:22px; padding-top:18px; border-top:1px solid var(--border-lt); display:flex; align-items:center; gap:12px; }
.testimonial-avatar {
  width:42px; height:42px; border-radius:50%; background:var(--green-light);
  display:flex; align-items:center; justify-content:center;
  color:var(--green); font-size:1rem; flex-shrink:0; font-weight:700;
}
.testimonial-name   { font-size:.9rem; font-weight:700; color:var(--text-h); }
.testimonial-handle { font-size:.76rem; color:var(--text-m); }
@media(max-width:900px) { .testimonials-grid { grid-template-columns:1fr 1fr; } }
@media(max-width:640px) { .testimonials-grid { grid-template-columns:1fr; } }

/* =========================================
   HOMEPAGE — HOW IT WORKS (between stats + CTA)
   ========================================= */
/* CSS already defined above in .how-it-works */

/* =========================================
   SUPPORT — RESOURCE-ONLY WIZARD RESULTS
   ========================================= */
.wizard-result-contact {
  display:flex; flex-direction:column; gap:10px; margin-bottom:20px;
}
.wizard-contact-item {
  display:flex; align-items:center; gap:12px;
  background:var(--bg-alt); border:1px solid var(--border);
  border-radius:10px; padding:12px 16px; font-size:.875rem;
  transition:var(--ease); text-decoration:none; color:var(--text-b);
}
.wizard-contact-item:hover { border-color:var(--green-soft); background:var(--green-pale); color:var(--green-dark); }
.wizard-contact-item i { color:var(--green); width:16px; text-align:center; flex-shrink:0; }
.wizard-contact-item strong { font-weight:700; color:var(--text-h); }

/* KB visit button — matches tag style of other self-help cards */
.shc-visit-btn {
  display:inline-flex; align-items:center; gap:6px;
  background:var(--green-light); border:1px solid var(--green-soft);
  color:var(--green-dark); padding:4px 13px;
  border-radius:100px; font-size:.72rem; font-weight:700;
  margin-top:10px; transition:var(--ease);
}
.shc-visit-btn:hover { background:var(--green-soft); }

/* =========================================
   VPS — 3-column use cases
   ========================================= */
/* features-grid-3x2 already defined */

/* =========================================
   RESELLER CONFIGURATOR — WHMCS TOGGLE
   ========================================= */
.whmcs-toggle {
  display:flex; align-items:flex-start; gap:14px;
  background:#fff; border:1.5px solid var(--border);
  border-radius:var(--r-lg); padding:16px 18px; cursor:pointer;
  transition:var(--ease); user-select:none;
}
.whmcs-toggle:hover { border-color:var(--green-soft); background:var(--green-pale); }
.whmcs-toggle input[type=checkbox] { position:absolute; opacity:0; width:0; height:0; }
.whmcs-toggle-track {
  width:42px; height:24px; background:var(--border); border-radius:12px;
  flex-shrink:0; position:relative; transition:var(--ease); margin-top:1px;
}
.whmcs-toggle input:checked ~ .whmcs-toggle-track { background:var(--green); }
.whmcs-toggle-thumb {
  width:18px; height:18px; background:#fff; border-radius:50%;
  position:absolute; top:3px; left:3px;
  box-shadow:0 1px 4px rgba(0,0,0,.2); transition:var(--ease);
}
.whmcs-toggle input:checked ~ .whmcs-toggle-track .whmcs-toggle-thumb { left:21px; }
.whmcs-toggle-text { flex:1; }
.whmcs-toggle-name { display:block; font-size:.9rem; font-weight:700; color:var(--text-h); margin-bottom:3px; }
.whmcs-toggle-desc { display:block; font-size:.8rem; color:var(--text-s); }
