/* ======================================
   Reset & Base
   ====================================== */
*, *::before, *::after { box-sizing: border-box; }
html, body { height: 100%; margin: 0; padding: 0; }
body {
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  line-height: 1.6;
  color: #0b0b0f;
  background: #ffffff;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
a { color: inherit; text-decoration: none; }

/* ======================================
   Tokens (match index theme)
   ====================================== */
:root {
  --primary: #0056b3;
  --primary-contrast: #ffffff;
  --accent: #00a0ff;
  --accent-secondary: #0056b3;
  --muted: #6b7280;

  --secondary: #64748b;
  --success: #10b981;
  --warning: #f59e0b;
  --danger: #ef4444;
  --light: #f8fafc;
  --dark: #0f172a;
  --border: #e2e8f0;

  --shadow: 0 10px 25px rgba(0,0,0,0.08), 0 2px 8px rgba(0,0,0,0.06);
  --shadow-sm: 0 4px 6px -1px rgba(0,0,0,.1), 0 2px 4px -1px rgba(0,0,0,.06);
  --shadow-lg: 0 10px 15px -3px rgba(0,0,0,.1), 0 4px 6px -2px rgba(0,0,0,.05);
  --shadow-xl: 0 20px 25px -5px rgba(0,0,0,.1), 0 10px 10px -5px rgba(0,0,0,.04);

  --radius: .75rem;
  --radius-lg: 1rem;
  --radius-2xl: 36px;

  --container-width: 1200px;
}

/* ======================================
   Background (make .bg-gradient look like index bg-glow)
   ====================================== */
.bg-gradient {
  position: fixed; inset: 0; pointer-events: none; z-index: -1; overflow: hidden;
  background:
    radial-gradient(600px 300px at 10% 70%, rgba(0,160,255,.2), transparent 60%),
    radial-gradient(600px 300px at 90% 75%, rgba(0,86,179,.2), transparent 60%),
    linear-gradient(135deg, rgba(240,249,255,.6) 0%, rgba(214,240,255,.6) 100%);
}

/* Utilities */
.hidden { display: none !important; }

/* ======================================
   Container
   ====================================== */
.container { max-width: var(--container-width); margin: 0 auto; padding: 0 24px; }

/* ======================================
   Navbar (match index visuals)
   ====================================== */
.navbar { display: flex; align-items: center; justify-content: space-between; height: 72px; }
.brand { display: inline-flex; align-items: center; gap: 10px; font-weight: 800; letter-spacing: .2px; }
.brand .logo {
  display:inline-grid; place-items:center; width:42px; height:42px; border-radius:14px;
  background:#0b0b0f; color:#fff; font-weight:900; font-size:20px; position:relative;
  box-shadow: var(--shadow);
}
.brand .logo::after {
  content:''; position:absolute; bottom:8px; right:8px; width:12px; height:12px; border-radius:999px; background: var(--accent);
  box-shadow: 0 0 0 3px rgba(255,62,165,0.25);
}
.brand .brand-text { font-size:22px; color: var(--primary); font-weight:900; }

.nav-links { display:flex; align-items:center; gap:28px; color:#1f2937; }
.nav-links a { opacity:.85; font-weight:500; }
.nav-links a:hover { opacity:1; }

/* ======================================
   Buttons (index feel)
   ====================================== */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  border:1px solid rgba(0,0,0,.08); background:#fff; color:#111;
  padding:10px 16px; border-radius:12px; cursor:pointer;
  box-shadow:0 1px 2px rgba(0,0,0,.06);
  transition: transform .05s ease, box-shadow .2s ease, background .2s ease, color .2s ease;
}
.btn:hover { box-shadow: var(--shadow); }
.btn:active { transform: translateY(1px); }
.btn-primary {
  background: var(--primary); color: var(--primary-contrast);
  border-color: transparent; padding:12px 18px; border-radius:14px; font-weight:600;
}
.btn-secondary { background: transparent; color: var(--primary); border-color: var(--primary); }
.btn-secondary:hover { background: var(--primary); color:#fff; }
.btn-outline { background: transparent; color: var(--dark); border-color: var(--border); }
.btn-outline:hover { background: var(--dark); color: #fff; border-color: var(--dark); }
.btn-large { padding: 1rem 2rem; font-size: 1.125rem; }

/* ======================================
   Hero
   ====================================== */
.hero { text-align:center; padding: 56px 0 24px; }
.hero-badge {
  display:inline-flex; align-items:center; padding:10px 16px; gap:8px;
  background:#e6f5ff; border:none; border-radius:999px;
  font-size:14px; font-weight:600; color:#0056b3; margin-bottom: 2rem;
}
.hero h1 {
  font-size: clamp(36px, 5.2vw, 64px);
  font-weight: 800; line-height: 1.1; margin: 0 0 1.5rem 0;
}
.hero-subtitle {
  font-size: clamp(16px, 2.2vw, 20px); color:#4b5563; max-width: 600px; margin: 0 auto 3rem;
}

/* ======================================
   Billing Toggle
   ====================================== */
.billing-toggle { display:flex; align-items:center; justify-content:center; gap:1rem; margin-bottom:2rem; }
.billing-label { font-weight:600; color: var(--secondary); }
.discount-badge {
  background: var(--success); color:#fff; padding:.25rem .5rem; border-radius:.5rem;
  font-size:.75rem; font-weight:700; margin-left:.5rem;
}
.toggle-switch { position:relative; display:inline-block; width:60px; height:34px; }
.toggle-switch input { opacity:0; width:0; height:0; }
.toggle-slider {
  position:absolute; cursor:pointer; inset:0; background-color: var(--border); transition:.4s; border-radius:34px;
}
.toggle-slider:before {
  content:""; position:absolute; height:26px; width:26px; left:4px; bottom:4px;
  background:#fff; transition:.4s; border-radius:50%; box-shadow: var(--shadow);
}
input:checked + .toggle-slider { background-color: var(--primary); }
input:checked + .toggle-slider:before { transform: translateX(26px); }

/* ======================================
   Pricing Section
   ====================================== */
.pricing-section { padding: 2rem 1.5rem 4rem; }
.pricing-grid {
  display:grid; grid-template-columns: repeat(auto-fit, minmax(350px,1fr));
  gap:2rem; max-width:1100px; margin:0 auto;
}
.pricing-card {
  background:#fff; border:2px solid var(--border); border-radius: var(--radius-lg);
  padding:2rem; position:relative; transition: all .3s ease; box-shadow: var(--shadow);
}
.pricing-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-xl); }
.pricing-card.popular { border-color: var(--primary); transform: scale(1.05); box-shadow: var(--shadow-lg); }
.pricing-card.popular:hover { transform: scale(1.05) translateY(-4px); }

.popular-badge {
  position:absolute; top:-12px; left:50%; transform: translateX(-50%);
  background: var(--primary); color:#fff; padding:.5rem 1.5rem; border-radius:2rem; font-size:.875rem; font-weight:700;
}

.plan-header { text-align:center; margin-bottom:2rem; }
.plan-name { font-size:1.5rem; font-weight:800; margin:0 0 .5rem 0; color: var(--dark); }
.plan-description { color: var(--secondary); margin:0; }

.plan-pricing { text-align:center; margin-bottom:2rem; }
.price-display { display:flex; align-items:baseline; justify-content:center; gap:.25rem; margin-bottom:.5rem; }
.currency { font-size:1.5rem; font-weight:600; color: var(--secondary); }
.price { font-size:3rem; font-weight:800; color: var(--dark); line-height:1; }
.period { font-size:1.125rem; color: var(--secondary); }
.price-note { color: var(--secondary); font-size:.875rem; margin:0; }

.feature-highlight {
  display:flex; align-items:flex-start; gap:1rem; padding:1.5rem;
  background: var(--light); border-radius: var(--radius); margin-bottom:1.5rem;
}
.feature-icon {
  width:3rem; height:3rem; background:#fff; border-radius: var(--radius);
  display:flex; align-items:center; justify-content:center; color: var(--primary); flex-shrink:0; box-shadow: var(--shadow);
}
.feature-highlight h4 { font-size:1.125rem; font-weight:700; margin:0 0 .25rem 0; color: var(--dark); }
.feature-highlight p { color: var(--secondary); margin:0; font-size:.875rem; }

.features-list { list-style:none; padding:0; margin:0 0 2rem 0; }
.features-list li {
  display:flex; align-items:center; gap:.75rem; padding:.5rem 0; color: var(--secondary);
}
.features-list li::before {
  content:'✓'; width:1.25rem; height:1.25rem; background: var(--success); color:#fff;
  border-radius:50%; display:flex; align-items:center; justify-content:center;
  font-size:.75rem; font-weight:bold; flex-shrink:0;
}
.plan-button { width:100%; padding:1rem; font-size:1.125rem; font-weight:700; }
.popular .plan-button { background: var(--primary); color:#fff; border-color: var(--primary); }
.popular .plan-button:hover { background: #004999; border-color: #004999; } /* slightly darker than --primary */

/* ======================================
   Comparison
   ====================================== */
.comparison-section { padding:4rem 1.5rem; background: var(--light); }
.comparison-section h2 {
  text-align:center; font-size:2.5rem; font-weight:800; margin:0 0 3rem 0; color: var(--dark);
}
.comparison-table-wrapper { overflow-x:auto; border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); }
.comparison-table { width:100%; background:#fff; border-collapse:collapse; font-size:.875rem; }
.comparison-table th, .comparison-table td {
  padding:1rem; text-align:left; border-bottom:1px solid var(--border);
}
.comparison-table th { background: var(--dark); color:#fff; font-weight:700; text-align:center; }
.comparison-table th:first-child { text-align:left; }
.comparison-table td:first-child { font-weight:600; color: var(--dark); }
.comparison-table td:not(:first-child) { text-align:center; }
.check { color: var(--success); font-weight:bold; font-size:1.125rem; }
.cross { color: var(--secondary); font-weight:bold; font-size:1.125rem; }

/* ======================================
   FAQ
   ====================================== */
.faq-section { padding:4rem 1.5rem; }
.faq-section h2 {
  text-align:center; font-size:2.5rem; font-weight:800; margin:0 0 3rem 0; color: var(--dark);
}
.faq-grid {
  display:grid; grid-template-columns: repeat(auto-fit, minmax(300px,1fr));
  gap:2rem; max-width:800px; margin:0 auto;
}
.faq-item {
  background:#fff; padding:2rem; border-radius: var(--radius-lg);
  box-shadow: var(--shadow); border:1px solid var(--border);
}
.faq-item h3 { font-size:1.25rem; font-weight:700; margin:0 0 1rem 0; color: var(--dark); }
.faq-item p { color: var(--secondary); margin:0; line-height:1.7; }

/* ======================================
   CTA
   ====================================== */
.cta-section { padding:5rem 1.5rem; text-align:center; }
.cta-content h2 { font-size:2.5rem; font-weight:800; margin:0 0 1rem 0; color: var(--dark); }
.cta-content p { font-size:1.25rem; color: var(--secondary); margin-bottom:2.5rem; }
.cta-buttons { display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; }

/* ======================================
   Footer
   ====================================== */
.footer { background: var(--dark); color:#fff; padding:3rem 0 1rem; }
.footer-content { display:grid; grid-template-columns:1fr 2fr; gap:3rem; margin-bottom:2rem; }
.footer-brand p { color: rgba(255,255,255,.7); margin-top:1rem; }
.footer-brand .logo { background: linear-gradient(135deg, var(--primary), var(--accent)); }
.footer-brand .brand-text { color:#fff; }
.footer-links { display:grid; grid-template-columns: repeat(3,1fr); gap:2rem; }
.footer-column h4 { font-weight:600; margin-bottom:1rem; color:#fff; }
.footer-column a {
  display:block; color: rgba(255,255,255,.7); text-decoration:none; margin-bottom:.5rem; transition: color .2s ease;
}
.footer-column a:hover { color: var(--accent); }
.footer-bottom {
  border-top:1px solid rgba(255,255,255,.1); padding-top:1rem; text-align:center; color: rgba(255,255,255,.7);
}

/* ======================================
   Accessibility touches
   ====================================== */
a:focus-visible, button:focus-visible, input:focus-visible, textarea:focus-visible {
  outline:3px solid color-mix(in oklab, var(--accent) 60%, white);
  outline-offset:2px; border-radius:10px;
}

/* ======================================
   Responsive
   ====================================== */
@media (max-width: 1024px) {
  .pricing-card.popular { transform: none; }
  .pricing-card.popular:hover { transform: translateY(-4px); }
}
@media (max-width: 768px) {
  .navbar { flex-direction: column; gap: 1rem; padding: 1rem 1.5rem; }
  .nav-links { gap: 1rem; flex-wrap: wrap; justify-content: center; }
  .hero { padding: 3rem 1.5rem 2rem; }

  .billing-toggle { flex-direction: column; gap: .5rem; }

  .pricing-grid { grid-template-columns: 1fr; gap: 1.5rem; }
  .pricing-card { padding: 1.5rem; }

  .comparison-table { font-size: .75rem; }
  .comparison-table th, .comparison-table td { padding: .75rem .5rem; }

  .faq-grid { grid-template-columns: 1fr; gap: 1.5rem; }
  .faq-item { padding: 1.5rem; }

  .cta-buttons { flex-direction: column; align-items: center; }

  .footer-content { grid-template-columns: 1fr; gap: 2rem; }
  .footer-links { grid-template-columns: 1fr; gap: 1.5rem; }
}
@media (max-width: 480px) {
  .container { padding: 0 1rem; }
  .hero h1 { font-size: 2rem; }
  .hero-subtitle { font-size: 1rem; }

  .pricing-card { padding: 1rem; }
  .price { font-size: 2.5rem; }

  .feature-highlight { padding: 1rem; }

  .comparison-section h2,
  .faq-section h2,
  .cta-content h2 { font-size: 2rem; }

  .cta-content p { font-size: 1rem; }
}
