/* Extracted from coupon-promo.php style block 1 */
/* ================================================================
   THEME: COUPON / PROMO PAGE - deep navy + electric green
   Token override - v2 design system pattern
   ================================================================ */
body {
  --color-primary:         #22C55E;
  --color-primary-light:   #4ADE80;
  --color-primary-dark:    #16A34A;
  --color-primary-darker:  #052E16;
  --color-secondary:       #3B82F6;
  --color-secondary-light: #60A5FA;
  --color-accent:          #F59E0B;

  --color-primary-rgb:     34, 197, 94;
  --color-secondary-rgb:   59, 130, 246;
  --color-accent-rgb:      245, 158, 11;

  --border-primary:   rgba(34, 197, 94, 0.20);
  --border-secondary: rgba(34, 197, 94, 0.10);

  --gradient-horizontal: linear-gradient(90deg, #16A34A, #22C55E, #4ADE80);
  --gradient-card-header: linear-gradient(145deg, #041A2E, #0B2D4A, #0D3D5C);
  --shadow-glow: 0 0 30px rgba(34, 197, 94, 0.28);
  --shadow-card: 0 20px 40px -10px rgba(0,0,0,0.12);

  --dark-1: #030F1C;
  --dark-2: #041A2E;
  --dark-3: #0B2D4A;

  --navy: #041A2E;
  --navy-mid: #0B2D4A;
}

*, *::before, *::after { box-sizing: border-box; }

/* ================================================================
   KEYFRAMES
   ================================================================ */
@keyframes pulse-dot  { 0%,100%{transform:scale(1);opacity:1} 50%{transform:scale(1.7);opacity:.35} }
@keyframes fadeSlideUp { from{opacity:0;transform:translateY(22px)} to{opacity:1;transform:translateY(0)} }
@keyframes shimmer    { 0%{left:-100%} 100%{left:200%} }
@keyframes ticker     { 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }
@keyframes float      { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-8px)} }
@keyframes countdown-flip { 0%{transform:rotateX(-15deg)} 100%{transform:rotateX(0)} }

/* ================================================================
   BREADCRUMB
   ================================================================ */
.cp-breadcrumb { background:#F0FDF4; padding:9px 0; border-bottom:1px solid rgba(34,197,94,.12); }
.cp-breadcrumb ol { list-style:none;margin:0;padding:0;display:flex;gap:6px;align-items:center;flex-wrap:wrap;font-size:13px;color:#888; }
.cp-breadcrumb a { color:#888;text-decoration:none; }
.cp-breadcrumb a:hover { color:var(--color-primary); }

/* ================================================================
   TICKER STRIP
   ================================================================ */
.cp-ticker { background:var(--color-primary);overflow:hidden;padding:9px 0;white-space:nowrap; }
.cp-ticker-inner {
  display:inline-flex;gap:56px;
  animation:ticker 30s linear infinite;
  font-size:12px;font-weight:700;color:#fff;letter-spacing:.06em;text-transform:uppercase;
}
.cp-ticker-inner span { display:inline-flex;align-items:center;gap:8px; }

/* ================================================================
   HERO
   ================================================================ */
.cp-hero {
  position:relative;min-height:78vh;
  display:flex;align-items:center;
  background:linear-gradient(145deg, #030F1C 0%, #041A2E 50%, #0B2D4A 100%);
  overflow:hidden;padding:100px 0 80px;
}
.cp-hero-photo {
  position:absolute;inset:0;
  background:url('https://cdn.underhost.com/images/banners/vancouver.webp') center/cover no-repeat;
  opacity:.06;
}
.cp-hero-bloom { position:absolute;border-radius:50%;filter:blur(90px);pointer-events:none; }
.cp-hero-bloom-1 { width:480px;height:480px;background:rgba(34,197,94,.10);top:-80px;right:-60px; }
.cp-hero-bloom-2 { width:360px;height:360px;background:rgba(59,130,246,.08);bottom:-50px;left:-50px; }
.cp-hero-bloom-3 { width:260px;height:260px;background:rgba(34,197,94,.06);top:40%;left:35%; }
.cp-hero-grid {
  position:absolute;inset:0;
  background-image:linear-gradient(rgba(34,197,94,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(34,197,94,.03) 1px,transparent 1px);
  background-size:60px 60px;
}
.cp-hero-inner { position:relative;z-index:1;text-align:center; }

.cp-verified-badge {
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(34,197,94,.12);border:1px solid rgba(34,197,94,.28);
  border-radius:50px;padding:7px 20px;
  font-size:12px;font-weight:700;color:#4ADE80;
  letter-spacing:.08em;text-transform:uppercase;margin-bottom:28px;
}
.cp-verified-badge .dot { width:7px;height:7px;border-radius:50%;background:#22C55E;animation:pulse-dot 1.8s ease-in-out infinite; }

.cp-hero h1 {
  font-size:clamp(28px,4.5vw,58px);font-weight:900;line-height:1.1;
  color:#fff;margin:0 0 12px;letter-spacing:-.025em;
}
.cp-hero h1 .grad {
  background:var(--gradient-horizontal);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.cp-hero h2 {
  font-size:clamp(16px,2.2vw,22px);font-weight:600;color:rgba(255,255,255,.55);
  margin:0 0 20px;letter-spacing:-.01em;
}
.cp-hero-sub {
  font-size:16px;color:rgba(255,255,255,.55);max-width:560px;margin:0 auto 40px;line-height:1.75;
}

/* Stats strip */
.cp-hero-stats {
  display:flex;justify-content:center;gap:40px;flex-wrap:wrap;
  margin-top:48px;padding-top:36px;
  border-top:1px solid rgba(255,255,255,.06);
}
.cp-stat-num {
  font-size:24px;font-weight:800;display:block;line-height:1;
  background:var(--gradient-horizontal);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.cp-stat-lbl { font-size:11px;color:rgba(255,255,255,.38);text-transform:uppercase;letter-spacing:.07em;margin-top:5px; }

/* Buttons */
.cp-btn-pri {
  display:inline-flex;align-items:center;gap:9px;
  background:var(--color-primary);color:#030F1C;
  font-weight:800;font-size:15px;font-family:inherit;
  padding:14px 32px;border-radius:8px;border:none;
  box-shadow:0 4px 16px rgba(34,197,94,.35);
  cursor:pointer;text-decoration:none;
  transition:background .2s,box-shadow .2s,transform .2s;
}
.cp-btn-pri:hover { background:var(--color-primary-light);color:#030F1C;text-decoration:none;transform:translateY(-1px);box-shadow:0 6px 22px rgba(34,197,94,.50); }
.cp-btn-ghost {
  display:inline-flex;align-items:center;gap:9px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.16);
  color:rgba(255,255,255,.8);font-weight:600;font-size:15px;font-family:inherit;
  padding:14px 32px;border-radius:8px;cursor:pointer;text-decoration:none;
  transition:all .2s;
}
.cp-btn-ghost:hover { background:rgba(255,255,255,.12);color:#fff;text-decoration:none; }
.cp-hero-cta { display:flex;justify-content:center;gap:14px;flex-wrap:wrap; }

/* ================================================================
   SECTION HELPERS
   ================================================================ */
.cp-badge {
  display:inline-flex;align-items:center;gap:7px;
  background:rgba(34,197,94,.07);border:1px solid rgba(34,197,94,.20);
  border-radius:50px;padding:7px 18px;
  font-size:12px;font-weight:700;color:var(--color-primary);
  text-transform:uppercase;letter-spacing:.08em;margin-bottom:16px;
}
.cp-badge .dot { width:6px;height:6px;border-radius:50%;background:var(--color-primary);animation:pulse-dot 2s ease-in-out infinite; }
.cp-badge-dark { background:rgba(34,197,94,.10);border-color:rgba(34,197,94,.22);color:#4ADE80; }
.cp-badge-dark .dot { background:#4ADE80; }

.cp-section-title { font-size:clamp(26px,3.5vw,42px);font-weight:800;color:#030F1C;margin:0 0 14px;line-height:1.15;letter-spacing:-.02em; }
.cp-section-title span { color:var(--color-primary); }
.cp-section-title-light { color:#fff; }
.cp-section-sub { font-size:16px;color:#64748B;margin:0 0 52px;line-height:1.7;max-width:680px; }
.cp-section-sub-light { color:rgba(255,255,255,.5); }

/* ================================================================
   COUPON CARDS SECTION
   ================================================================ */
.cp-coupons { background:#F0FDF4;padding:96px 0; }

.cp-coupon-grid {
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:0;
}
@media(max-width:960px) { .cp-coupon-grid { grid-template-columns:1fr 1fr; } }
@media(max-width:580px) { .cp-coupon-grid { grid-template-columns:1fr; } }

.cp-coupon-card {
  background:#fff;border:1px solid #D1FAE5;
  border-radius:20px;overflow:hidden;
  box-shadow:0 4px 6px rgba(0,0,0,.03),0 16px 32px rgba(0,0,0,.05);
  transition:transform .25s ease,box-shadow .25s ease;
  display:flex;flex-direction:column;position:relative;
}
.cp-coupon-card:hover {
  transform:translateY(-6px);
  box-shadow:0 8px 16px rgba(0,0,0,.06),0 28px 48px rgba(34,197,94,.12);
}

/* Card header band */
.cp-coupon-head {
  background:var(--gradient-card-header);
  padding:28px 28px 24px;position:relative;overflow:hidden;
}
.cp-coupon-head::before {
  content:'';position:absolute;inset:0;
  background-image:linear-gradient(rgba(34,197,94,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(34,197,94,.04) 1px,transparent 1px);
  background-size:28px 28px;
}
.cp-coupon-icon {
  width:56px;height:56px;border-radius:14px;
  background:rgba(34,197,94,.15);
  display:flex;align-items:center;justify-content:center;
  font-size:22px;color:#4ADE80;
  position:relative;z-index:1;margin-bottom:14px;
}
.cp-coupon-head-title {
  font-size:20px;font-weight:900;color:#fff;
  position:relative;z-index:1;line-height:1.1;
  letter-spacing:-.02em;
}
.cp-coupon-head-title span {
  display:block;font-size:13px;font-weight:600;color:#4ADE80;margin-top:3px;letter-spacing:.04em;
}

/* Savings ribbon */
.cp-savings-pill {
  position:absolute;top:20px;right:20px;
  background:var(--color-primary);color:#030F1C;
  font-size:12px;font-weight:800;padding:5px 12px;border-radius:50px;
  z-index:2;letter-spacing:.02em;
}
.cp-limited-pill {
  position:absolute;top:48px;right:20px;
  background:rgba(245,158,11,.15);border:1px solid rgba(245,158,11,.30);
  color:#FCD34D;font-size:10px;font-weight:700;
  padding:3px 10px;border-radius:50px;z-index:2;letter-spacing:.06em;text-transform:uppercase;
}

/* Card body */
.cp-coupon-body { padding:24px 28px 28px;flex:1;display:flex;flex-direction:column; }
.cp-coupon-desc { font-size:14px;color:#64748B;margin:0 0 20px;line-height:1.6; }

/* Code display */
.cp-code-wrap {
  background:#F0FDF4;border:1.5px dashed rgba(34,197,94,.35);
  border-radius:12px;padding:14px 16px;
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:16px;
}
.cp-code-text {
  font-size:20px;font-weight:900;color:#052E16;
  letter-spacing:.08em;font-family:'Courier New',monospace;
}
.cp-copy-btn {
  display:inline-flex;align-items:center;gap:6px;
  background:var(--color-primary);color:#030F1C;
  font-size:12px;font-weight:800;font-family:inherit;
  padding:8px 16px;border-radius:8px;border:none;
  cursor:pointer;text-decoration:none;
  transition:background .2s,transform .15s;
  position:relative;overflow:hidden;flex-shrink:0;
}
.cp-copy-btn::after {
  content:'';position:absolute;top:0;left:-100%;width:60%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);
  animation:shimmer 2.5s ease-in-out 0.5s infinite;
}
.cp-copy-btn:hover { background:var(--color-primary-light);transform:scale(1.03); }
.cp-copy-btn.copied { background:#052E16;color:#4ADE80; }

/* Meta row */
.cp-coupon-meta {
  display:flex;align-items:center;gap:12px;flex-wrap:wrap;
  font-size:12px;margin-bottom:20px;
}
.cp-expiry { display:flex;align-items:center;gap:5px;color:#94A3B8; }
.cp-terms  { display:flex;align-items:center;gap:5px;color:#94A3B8; }

/* Apply CTA */
.cp-apply-btn {
  display:flex;align-items:center;justify-content:space-between;
  background:#F8FAFF;border:1px solid #E2E8F0;
  border-radius:10px;padding:13px 18px;
  font-size:14px;font-weight:700;color:#0F172A;
  text-decoration:none;transition:all .2s ease;margin-top:auto;
}
.cp-apply-btn:hover { background:var(--color-primary);color:#030F1C;border-color:var(--color-primary);text-decoration:none; }
.cp-apply-btn i { font-size:12px;transition:transform .2s; }
.cp-apply-btn:hover i { transform:translateX(4px); }

/* Disclaimer */
.cp-disclaimer {
  background:rgba(59,130,246,.05);border-left:3px solid var(--color-secondary);
  border-radius:0 12px 12px 0;padding:14px 20px;
  display:flex;gap:12px;align-items:flex-start;
  font-size:14px;color:#64748B;margin-top:36px;
}
.cp-disclaimer i { color:var(--color-secondary);margin-top:2px;flex-shrink:0; }
.cp-promo-link {
  text-align:center;margin-top:20px;
  font-size:15px;font-weight:600;color:#3B82F6;
}
.cp-promo-link a { color:#3B82F6;font-weight:700; }

/* ================================================================
   BARGAIN BANNER
   ================================================================ */
.cp-bargain {
  background:linear-gradient(145deg, #030F1C 0%, #041A2E 55%, #0B2D4A 100%);
  padding:80px 0;position:relative;overflow:hidden;
}
.cp-bargain::before {
  content:'';position:absolute;inset:0;
  background-image:linear-gradient(rgba(34,197,94,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(34,197,94,.03) 1px,transparent 1px);
  background-size:55px 55px;
}
.cp-bargain-bloom-1 { position:absolute;width:500px;height:500px;border-radius:50%;filter:blur(100px);background:rgba(34,197,94,.08);top:-100px;right:-80px; }
.cp-bargain-bloom-2 { position:absolute;width:350px;height:350px;border-radius:50%;filter:blur(80px);background:rgba(59,130,246,.06);bottom:-60px;left:-40px; }

.cp-bargain-inner { position:relative;z-index:1; }

.cp-bargain-layout {
  display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;
}
@media(max-width:768px) { .cp-bargain-layout { grid-template-columns:1fr;gap:40px; } }

/* Countdown timer */
.cp-timer-label { font-size:12px;font-weight:700;color:rgba(255,255,255,.4);text-transform:uppercase;letter-spacing:.08em;margin-bottom:12px;display:flex;align-items:center;gap:7px; }
.cp-timer-grid { display:flex;align-items:center;gap:8px;margin-bottom:28px; }
.cp-timer-block {
  background:rgba(255,255,255,.05);border:1px solid rgba(34,197,94,.15);
  border-radius:10px;padding:12px 16px;text-align:center;min-width:64px;
}
.cp-timer-val { font-size:26px;font-weight:900;color:#fff;line-height:1;letter-spacing:-.02em;animation:countdown-flip .3s ease; }
.cp-timer-unit { font-size:10px;font-weight:600;color:rgba(255,255,255,.35);text-transform:uppercase;letter-spacing:.08em;margin-top:3px; }
.cp-timer-sep { font-size:22px;font-weight:900;color:rgba(34,197,94,.5);margin-bottom:14px; }

.cp-bargain-trust { display:flex;gap:20px;flex-wrap:wrap;margin-top:8px; }
.cp-trust-chip { display:flex;align-items:center;gap:7px;font-size:13px;font-weight:600;color:rgba(255,255,255,.6); }
.cp-trust-chip i { color:var(--color-primary);font-size:14px; }

/* Right side - server preview cards */
.cp-bargain-servers { display:flex;flex-direction:column;gap:14px; }
.cp-server-pill {
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);
  border-radius:14px;padding:16px 20px;
  display:flex;align-items:center;justify-content:space-between;
  transition:all .25s ease;
}
.cp-server-pill:hover { background:rgba(34,197,94,.06);border-color:rgba(34,197,94,.20); }
.cp-server-pill-left { display:flex;align-items:center;gap:14px; }
.cp-server-pill-icon {
  width:40px;height:40px;border-radius:10px;
  background:rgba(34,197,94,.10);
  display:flex;align-items:center;justify-content:center;
  color:var(--color-primary);font-size:15px;flex-shrink:0;
}
.cp-server-pill-name { font-size:14px;font-weight:700;color:#fff; }
.cp-server-pill-spec { font-size:12px;color:rgba(255,255,255,.4);margin-top:2px; }
.cp-server-pill-price { font-size:16px;font-weight:900;color:var(--color-primary);white-space:nowrap; }
.cp-server-pill-disc { font-size:11px;color:#F87171;font-weight:700;text-align:right;margin-top:2px; }

/* ================================================================
   MIGRATION
   ================================================================ */
.cp-migration { background:#fff;padding:96px 0; }
.cp-mig-layout { display:grid;grid-template-columns:1fr 1.3fr;gap:64px;align-items:center; }
@media(max-width:768px) { .cp-mig-layout { grid-template-columns:1fr; } }

.cp-mig-img-wrap { position:relative; }
.cp-mig-img { border-radius:20px;width:100%; }
.cp-mig-free-badge {
  position:absolute;top:24px;right:-12px;
  background:var(--color-primary);color:#030F1C;
  font-size:13px;font-weight:800;padding:9px 18px;border-radius:8px;
  box-shadow:0 4px 14px rgba(34,197,94,.40);
}
.cp-mig-stats {
  display:flex;gap:0;margin-top:24px;
  background:#F0FDF4;border:1px solid #D1FAE5;border-radius:16px;overflow:hidden;
}
.cp-mig-stat { flex:1;padding:16px;text-align:center; }
.cp-mig-stat + .cp-mig-stat { border-left:1px solid #D1FAE5; }
.cp-mig-stat-num { font-size:22px;font-weight:900;color:var(--color-primary);display:block;line-height:1; }
.cp-mig-stat-lbl { font-size:11px;color:#64748B;margin-top:4px;text-transform:uppercase;letter-spacing:.06em; }

.cp-mig-feature { display:flex;gap:14px;align-items:flex-start;margin-bottom:18px; }
.cp-mig-icon {
  width:40px;height:40px;border-radius:10px;flex-shrink:0;
  background:rgba(34,197,94,.08);
  display:flex;align-items:center;justify-content:center;
  color:var(--color-primary);font-size:16px;
}
.cp-mig-feature h4 { font-size:15px;font-weight:700;color:#0F172A;margin:0 0 3px; }
.cp-mig-feature p  { font-size:13px;color:#64748B;margin:0;line-height:1.6; }

.cp-pills { display:flex;flex-wrap:wrap;gap:8px;margin:20px 0; }
.cp-pill {
  display:inline-flex;align-items:center;gap:6px;
  background:#F8FAFF;border:1px solid #E2E8F0;
  border-radius:50px;padding:7px 14px;font-size:12px;font-weight:600;color:#64748B;
}
.cp-pill i { color:var(--color-secondary); }

/* ================================================================
   WHY UNDERHOST
   ================================================================ */
.cp-why {
  background:linear-gradient(145deg, #030F1C 0%, #041A2E 60%, #0B2D4A 100%);
  padding:96px 0;position:relative;overflow:hidden;
}
.cp-why::before {
  content:'';position:absolute;inset:0;
  background-image:linear-gradient(rgba(34,197,94,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(34,197,94,.03) 1px,transparent 1px);
  background-size:60px 60px;
}
.cp-why-inner { position:relative;z-index:1; }

.cp-benefits-grid { display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin:32px 0; }
@media(max-width:480px) { .cp-benefits-grid { grid-template-columns:1fr; } }

.cp-benefit {
  background:rgba(255,255,255,.04);border:1px solid rgba(34,197,94,.12);
  border-radius:14px;padding:18px 20px;
  display:flex;gap:14px;align-items:flex-start;
  transition:all .2s ease;
}
.cp-benefit:hover { background:rgba(34,197,94,.06);border-color:rgba(34,197,94,.22); }
.cp-benefit-icon {
  width:36px;height:36px;border-radius:9px;flex-shrink:0;
  background:var(--color-primary);
  display:flex;align-items:center;justify-content:center;
  color:#030F1C;font-size:14px;
}
.cp-benefit h5 { font-size:14px;font-weight:700;color:#fff;margin:0 0 3px; }
.cp-benefit p  { font-size:12px;color:rgba(255,255,255,.5);margin:0;line-height:1.55; }

/* ================================================================
   FAQ
   ================================================================ */
.cp-faq { background:#F0FDF4;padding:96px 0; }
.cp-faq-grid { display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:48px; }
@media(max-width:768px) { .cp-faq-grid { grid-template-columns:1fr; } }

.cp-faq-card {
  background:#fff;border:1px solid #D1FAE5;border-radius:16px;padding:22px 26px;
  cursor:pointer;transition:all .2s ease;
}
.cp-faq-card:hover,.cp-faq-card.open { border-color:rgba(34,197,94,.40);box-shadow:0 6px 20px rgba(34,197,94,.08); }
.cp-faq-q { display:flex;gap:12px;align-items:flex-start; }
.cp-faq-num {
  width:28px;height:28px;border-radius:7px;flex-shrink:0;
  background:rgba(34,197,94,.08);
  display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:800;color:var(--color-primary);margin-top:1px;
}
.cp-faq-q h5 { font-size:14px;font-weight:700;color:#0F172A;margin:0;line-height:1.5; }
.cp-faq-a { font-size:13px;color:#64748B;line-height:1.75;margin:12px 0 0 40px;display:none; }
.cp-faq-card.open .cp-faq-a { display:block; }

/* ================================================================
   CTA FOOTER
   ================================================================ */
.cp-cta {
  background:var(--gradient-card-header);padding:72px 0;text-align:center;
  position:relative;overflow:hidden;
}
.cp-cta::before {
  content:'';position:absolute;inset:0;
  background-image:linear-gradient(rgba(34,197,94,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(34,197,94,.04) 1px,transparent 1px);
  background-size:50px 50px;
}
.cp-cta > .container { position:relative;z-index:1; }
.cp-cta h2 { font-size:clamp(24px,4vw,42px);font-weight:900;color:#fff;margin:0 0 14px; }
.cp-cta h2 span { background:var(--gradient-horizontal);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text; }
.cp-cta p { font-size:16px;color:rgba(255,255,255,.5);max-width:480px;margin:0 auto 36px;line-height:1.75; }
.cp-cta-btns { display:flex;justify-content:center;gap:14px;flex-wrap:wrap; }

@media(max-width:768px) {
  .cp-hero { padding:80px 0 60px;min-height:auto; }
  .cp-coupons,.cp-migration,.cp-why,.cp-faq { padding:64px 0; }
  .cp-bargain { padding:60px 0; }
}

