/* ---------- Base */
:root{
  --bg:#f7f9fc;
  --panel:#ffffff;
  --text:#0f1222;
  --muted:#6b7280;
  --line:rgba(15,18,34,.08);
  --primary:#1a73e8;       /* brand blue (matches screenshot tone) */
  --primary-ink:#0b4ea2;
  --dark:#111418;
  --radius-pill:999px;
  --radius:14px;
  --shadow:0 10px 30px rgba(16,24,40,.10);
  --shadow-sm:0 2px 10px rgba(16,24,40,.10);
  --max:1120px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{margin:0; font:15px/1.5 system-ui,-apple-system,"Segoe UI",Roboto,Inter,Arial,sans-serif; color:var(--text); background:var(--bg);}

/* ---------- Decorative background */
.bg-bokeh{
  position:fixed; inset:-20vmax; z-index:-1;
  background:
    radial-gradient(20vmax 20vmax at 10% 20%, rgba(26,115,232,.10), transparent 60%),
    radial-gradient(22vmax 22vmax at 80% 10%, rgba(26,115,232,.10), transparent 70%),
    radial-gradient(18vmax 18vmax at 50% 90%, rgba(26,115,232,.08), transparent 60%),
    #eaf1ff;
  filter: saturate(1.1);
}

/* ---------- Header (matches screenshot) */
.site-header{ position:sticky; top:12px; z-index:20; display:flex; justify-content:center; padding:0 16px; }
.nav-shell{
  width:100%; max-width:var(--max); background:var(--panel);
  border:1px solid var(--line); border-radius:28px; box-shadow:var(--shadow-sm);
  display:flex; align-items:center; justify-content:space-between;
  padding:10px 14px; gap:10px;
}
.brand{ font-weight:800; font-size:18px; text-decoration:none; color:var(--primary); }
.brand span{ color:var(--primary); }
.brand.small{ font-size:16px; }
.nav-left{display:flex; align-items:center; gap:8px;}
.nav-center{ display:flex; gap:22px; align-items:center; justify-content:center; flex:1; }
.nav-center .nav-link{
  color:#101828; text-decoration:none; font-weight:600; opacity:.85;
}
.nav-center .nav-link:hover{ opacity:1; }
.nav-center .nav-link.active{ color:#000; text-underline-offset:6px; text-decoration:underline; }
.nav-right{ display:flex; align-items:center; gap:10px; }

/* Buttons */
.btn{ display:inline-flex; align-items:center; justify-content:center; gap:8px;
  border-radius:10px; padding:10px 14px; border:1px solid var(--line); background:#f8fafc; color:#0f1222; cursor:pointer; }
.btn:hover{ filter:brightness(.98); }
.btn-ghost{ background:#fff; }
.btn-dark{ background:#111418; color:#fff; border-color:#111418; }
.btn:focus{ outline:2px solid rgba(26,115,232,.3); outline-offset:2px; }

/* Mobile hamburger */
.nav-hamburger{ display:none; width:40px; height:40px; border-radius:10px; border:1px solid var(--line); background:#fff; }
.nav-hamburger span{ display:block; width:18px; height:2px; background:#111; margin:4px auto; }

/* Mobile flyout */
.mobile-nav{
  display:none; position:absolute; top:64px; left:50%; transform:translateX(-50%);
  width:100%; max-width:var(--max); background:#fff; border:1px solid var(--line); border-radius:18px; box-shadow:var(--shadow); padding:12px;
}
.mobile-nav.open{ display:block; }
.mobile-nav .m-link{ display:block; padding:10px 12px; color:#0f1222; text-decoration:none; border-radius:10px; }
.mobile-nav .m-link:hover{ background:#f3f4f6; }
.mobile-nav .m-actions{ display:flex; gap:10px; padding:6px 12px 4px; }

/* ---------- Layout & components */
.container{ width:100%; max-width:var(--max); margin:0 auto; padding:24px 16px; }
.section{ padding:32px 0; }
.section.alt{ background:#fff; border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.two-col{ display:grid; grid-template-columns:1.2fr .8fr; gap:24px; align-items:center; }
.illus-panel{ display:flex; align-items:center; justify-content:center; }
.logo-cloud{ display:flex; flex-wrap:wrap; gap:10px; padding:16px; }
.logo-cloud span{ border:1px solid var(--line); border-radius:999px; padding:8px 12px; background:#fff; box-shadow:var(--shadow-sm); }

.hero{ padding:56px 16px 28px; text-align:center; }
.hero h1{ font-size:42px; line-height:1.15; margin:0 0 10px; }
.highlight{ color:var(--primary); }
.lead{ font-size:18px; color:#475467; max-width:850px; margin:10px auto 24px; }
.cta-row{ display:flex; gap:12px; justify-content:center; }
.pill-stats{ margin:26px auto 0; display:flex; gap:10px; justify-content:center; flex-wrap:wrap; padding:0; list-style:none; }
.pill-stats li{ background:#fff; border:1px solid var(--line); border-radius:999px; padding:8px 12px; color:#0f1222; }

.feature-grid{ display:grid; grid-template-columns:repeat(auto-fit, minmax(240px,1fr)); gap:16px; margin-top:18px; }
.feature-grid.big .card{ min-height:140px; }
.card{ background:#fff; border:1px solid var(--line); border-radius:14px; padding:14px; box-shadow:var(--shadow-sm); }

.problems, .benefits, .cs-grid, .price-grid{ display:grid; gap:16px; grid-template-columns:repeat(auto-fit, minmax(240px,1fr)); }
.benefit, .price-card{ background:#fff; border:1px solid var(--line); border-radius:14px; padding:14px; box-shadow:var(--shadow-sm); }

.price-grid .price-card{ text-align:center; position:relative; }
.price-grid .price-card.popular{ border-color:#1a73e8; box-shadow:0 10px 30px rgba(26,115,232,.15); }
.price-card .badge{ position:absolute; top:-10px; right:12px; background:#1a73e8; color:#fff; border-radius:999px; padding:6px 10px; font-size:12px; }
.price{ font-weight:800; font-size:34px; margin:4px 0; }
.price span{ font-size:14px; font-weight:600; color:#475467; }

.logo-grid{ display:grid; gap:10px; grid-template-columns:repeat(auto-fit, minmax(140px,1fr)); margin-top:18px; }
.logo-grid span{ display:flex; align-items:center; justify-content:center; padding:10px; border:1px solid var(--line); background:#fff; border-radius:12px; }

.faq{ border:1px solid var(--line); border-radius:12px; padding:10px 12px; background:#fff; margin:8px 0; }
.faq summary{ cursor:pointer; font-weight:600; }

.contact-form .form-row{ display:grid; grid-template-columns:1fr 1fr; gap:12px; }

/* ---------- Forms */
label{ display:flex; flex-direction:column; gap:6px; font-weight:600; }
input, select, textarea{
  border:1px solid var(--line); border-radius:10px; padding:10px 12px; background:#fff; color:#0f1222;
}
input:focus,select:focus,textarea:focus{ outline:2px solid rgba(26,115,232,.35); outline-offset:1px; }
.inline{ display:flex; align-items:center; gap:8px; font-weight:500; }
.small{ font-size:13px; }
.muted{ color:#667085; }
.tiny{ font-size:12px; }

/* Keep dialogs above everything and allow clicking inside */
.modal[open] { z-index: 99999 !important; }
.modal[open] .modal-card { pointer-events: auto !important; }

/* If any page overlay/backdrop exists, don't let it intercept clicks */
#overlay, .overlay, .page-overlay, .app-overlay, .backdrop {
  pointer-events: none !important;
}

/* ---------- Modals (native <dialog>) */
.modal::backdrop{ background: rgba(0,0,0,.55); }
.modal{ border:none; padding:0; }
.modal-card{
  width:min(560px, 92vw); background:#fff; border:1px solid var(--line);
  border-radius:16px; box-shadow:var(--shadow); padding:16px; display:flex; flex-direction:column; gap:12px;
}
.modal-header{ display:flex; align-items:center; justify-content:space-between; margin-bottom:4px; }
.icon-btn{ border:1px solid var(--line); background:#fff; width:34px; height:34px; border-radius:8px; cursor:pointer; }
.btn-row{ display:flex; gap:10px; flex-wrap:wrap; }

/* ---------- Footer */
.site-footer{ margin-top:40px; border-top:1px solid var(--line); background:#fff; }
.footer-grid{ display:grid; grid-template-columns:1.2fr 1fr 1fr 1fr; gap:16px; padding:20px 16px; max-width:var(--max); margin:0 auto; }
.site-footer nav a{ display:block; color:#0f1222; text-decoration:none; margin:6px 0; }
.site-footer nav a:hover{ text-decoration:underline; }

/* ---------- Utilities */
.route[hidden]{ display:none !important; }
.two-col > :first-child > h2, .two-col > :first-child > h3{ margin-top:0; }

/* ---------- Responsive */
@media (max-width: 980px){
  .nav-center{ display:none; }
  .nav-hamburger{ display:inline-flex; align-items:center; justify-content:center; }
  .two-col{ grid-template-columns:1fr; }
  .contact-form .form-row{ grid-template-columns:1fr; }
  .footer-grid{ grid-template-columns:1fr 1fr; }
}
@media (max-width: 640px){
  .footer-grid{ grid-template-columns:1fr; }
  .hero h1{ font-size:32px; }
}
