/* ═══════════════════════════════════════════════════════════════════
   QONSISTIC — SHARED STYLESHEET
   Covers: reset, design tokens, nav, footer, utilities, cookies banner,
           and responsive overrides for ALL screen sizes.
   ═══════════════════════════════════════════════════════════════════ */

/* ── RESET ─────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

/* ── DESIGN TOKENS ─────────────────────────────────────────────── */
:root{
  --navy:#1a2332;
  --teal:#05b9fa;
  --green:#449d75;
  --orange:#f65009;
  --white:#ffffff;
  --border:#e8e6e2;
  --border2:#d4d1cc;
  --text:#1a2332;
  --text2:#4a5568;
  --text3:#718096;
  --text4:#a0aec0;
  --font:'Inter',sans-serif;
  --mono:'SF Mono','Fira Mono','Courier New',monospace;
}

/* ── BASE ───────────────────────────────────────────────────────── */
html{scroll-behavior:smooth;max-width:100%;overflow-x:hidden}
body{
  font-family:var(--font);
  color:var(--text);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  max-width:100%;
  font-size:15px;
  line-height:1.6;
  background-color:#f8f9fb;
  background-image:
    radial-gradient(ellipse 80% 50% at 50% -5%,rgba(5,185,250,.07) 0%,transparent 60%),
    radial-gradient(circle,rgba(26,35,50,.07) 1px,transparent 1px);
  background-size:100% 100%,22px 22px;
  background-attachment:fixed,fixed;
}
a{text-decoration:none;color:inherit}
button{font-family:var(--font);cursor:pointer;border:none;background:none}
section,.logos-bar,footer{background:var(--white)}

/* ── NAVBAR ─────────────────────────────────────────────────────── */
nav{
  position:fixed;top:0;left:0;right:0;z-index:300;
  background:rgba(255,255,255,.94);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--border);
  height:60px;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 40px;
}
.nav-brand{display:flex;align-items:center;gap:9px;text-decoration:none;flex-shrink:0}
.brand-logo{width:32px;height:32px;object-fit:contain;flex-shrink:0;mix-blend-mode:multiply;border-radius:0}
.brand-logo-wordmark{width:132px;height:auto;max-height:36px}
.nav-brand-name{font-size:20px;font-weight:700;color:var(--navy);letter-spacing:-0.03em;font-style:italic}
.nav-center{display:flex;gap:2px}
.nav-link{
  font-size:14px;color:var(--text2);
  padding:6px 13px;border-radius:6px;
  display:flex;align-items:center;gap:5px;
  transition:color .15s,background .15s;
  white-space:nowrap;cursor:pointer;user-select:none;text-decoration:none;
}
.nav-link:hover{color:var(--navy);background:rgba(0,0,0,.04)}
.nav-link .caret{width:10px;height:10px;opacity:.4;transition:transform .2s;flex-shrink:0}
.nav-dashboard{
  font-size:13.5px;font-weight:500;color:var(--text2);
  padding:6px 12px;border-radius:6px;border:1px solid var(--border);
  display:flex;align-items:center;gap:6px;
  transition:color .15s,border-color .15s,background .15s;text-decoration:none;
}
.nav-dashboard:hover{color:var(--navy);border-color:var(--border2);background:rgba(0,0,0,.02)}
.nav-dashboard svg{width:14px;height:14px;opacity:.45}
.nav-right{display:flex;align-items:center;gap:8px;flex-shrink:0}
.nav-login{
  font-size:13.5px;font-weight:500;color:var(--text2);
  padding:7px 16px;border-radius:7px;border:1px solid var(--border);
  transition:color .15s,border-color .15s;text-decoration:none;
}
.nav-login:hover{color:var(--navy);border-color:var(--border2)}
.nav-signup{
  background:var(--teal);color:var(--navy);
  font-size:13.5px;font-weight:500;padding:8px 18px;border-radius:7px;
  display:flex;align-items:center;gap:6px;
  transition:background .15s;text-decoration:none;
}
.nav-signup:hover{background:#04a3e0}

/* Dropdown menus */
.nav-item{position:relative}
.nav-dropdown{
  position:absolute;top:calc(100% + 10px);left:50%;
  transform:translateX(-50%) translateY(-5px);
  background:var(--white);border:1px solid var(--border);
  border-radius:14px;box-shadow:0 16px 48px rgba(0,0,0,.12);
  opacity:0;visibility:hidden;
  transition:opacity .17s ease,transform .17s ease,visibility .17s;
  z-index:200;overflow:hidden;pointer-events:none;
}
.nav-dropdown.al{left:0;transform:translateX(0) translateY(-5px)}
.nav-dropdown.ar{left:auto;right:0;transform:translateX(0) translateY(-5px)}
.nav-item.open>.nav-dropdown{opacity:1;visibility:visible;pointer-events:all}
.nav-item.open>.nav-dropdown:not(.al):not(.ar){transform:translateX(-50%) translateY(0)}
.nav-item.open>.nav-dropdown.al{transform:translateX(0) translateY(0)}
.nav-item.open>.nav-dropdown.ar{transform:translateX(0) translateY(0)}
.nav-item.open>.nav-link>.caret{transform:rotate(180deg)}
.dd-grid{display:grid;grid-template-columns:1fr 1fr;gap:2px;padding:8px}
.dd-col{padding:8px;display:flex;flex-direction:column;gap:2px;min-width:220px}
.dd-item{
  display:flex;align-items:center;gap:12px;
  padding:10px 12px;border-radius:9px;cursor:pointer;
  transition:background .12s;text-decoration:none;
}
.dd-item:hover{background:#f8f9fb}
.dd-icon{width:24px;height:24px;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:none}
.dd-icon svg{width:16px;height:16px;stroke:var(--navy);fill:none;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.dd-text h4{font-size:13px;font-weight:600;color:var(--navy);line-height:1.2;margin-bottom:1px}
.dd-text p{font-size:11.5px;color:var(--text3);line-height:1.35}
.dd-divider{border:none;border-top:1px solid var(--border);margin:0 8px}
.dd-footer{padding:11px 16px;display:flex;align-items:center;justify-content:space-between;gap:12px}
.dd-footer-link{font-size:12.5px;color:var(--teal);font-weight:500;display:flex;align-items:center;gap:4px;transition:color .15s;text-decoration:none}
.dd-footer-link:hover{color:var(--navy)}

/* Hamburger */
.nav-hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;border-radius:6px;border:none;background:none}
.nav-hamburger span{display:block;width:20px;height:2px;background:var(--navy);border-radius:2px;transition:all .25s}
.nav-hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Mobile drawer */
.nav-drawer{
  position:fixed;top:60px;left:0;right:0;
  background:var(--white);border-bottom:1px solid var(--border);
  box-shadow:0 16px 40px rgba(0,0,0,.1);z-index:190;
  padding:16px 20px 24px;max-height:calc(100vh - 60px);overflow-y:auto;
  transform:translateY(-6px);opacity:0;visibility:hidden;
  transition:opacity .2s,transform .2s,visibility .2s;
}
.nav-drawer.open{opacity:1;visibility:visible;transform:translateY(0)}
.d-sec{font-size:10.5px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text4);margin:16px 0 6px}
.d-sec:first-child{margin-top:4px}
.d-item{display:flex;align-items:center;gap:10px;padding:10px 0;font-size:14px;color:var(--text2);border-bottom:1px solid rgba(0,0,0,.04);text-decoration:none}
.d-main{display:flex;align-items:center;gap:10px;padding:12px 0;font-size:15px;font-weight:500;color:var(--navy);border-bottom:1px solid var(--border);text-decoration:none}
.d-auth{display:flex;flex-direction:column;gap:10px;margin-top:16px;padding-top:16px;border-top:1px solid var(--border)}
.d-login{padding:13px;border:1px solid var(--border);border-radius:8px;text-align:center;font-size:15px;font-weight:500;color:var(--navy);text-decoration:none}
.d-signup{padding:13px;background:var(--teal);border-radius:8px;text-align:center;font-size:15px;font-weight:600;color:var(--navy);text-decoration:none}

/* ── SHARED PAGE STYLES ─────────────────────────────────────────── */
.page-hero{padding-top:60px;background:var(--white)}
.page-hero-inner{max-width:1200px;margin:0 auto;padding:72px 96px 60px}
.page-tag{display:inline-block;font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--teal);margin-bottom:16px}
.page-h1{font-size:clamp(38px,5vw,64px);font-weight:700;color:var(--navy);letter-spacing:-0.04em;line-height:1.06;margin-bottom:22px}
.page-h1 span{color:var(--teal)}
.page-lead{font-size:18px;font-weight:300;color:var(--text2);max-width:600px;line-height:1.7;margin-bottom:36px}
.page-btns{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.btn-primary{background:var(--teal);color:var(--navy);font-size:15px;font-weight:600;padding:12px 26px;border-radius:8px;display:inline-flex;align-items:center;gap:8px;transition:background .15s;text-decoration:none}
.btn-primary:hover{background:#04a3e0}
.btn-outline{border:1px solid var(--border2);color:var(--navy);font-size:15px;font-weight:500;padding:12px 26px;border-radius:8px;display:inline-flex;align-items:center;gap:8px;transition:border-color .15s;text-decoration:none}
.btn-outline:hover{border-color:var(--navy)}
.sec-label{font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--teal);margin-bottom:14px;display:block}
.sec-badge{display:inline-block;border:1px solid var(--border2);border-radius:5px;padding:5px 12px;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--text2);margin-bottom:20px}
.sec-h2{font-size:clamp(28px,3.5vw,44px);font-weight:700;color:var(--navy);letter-spacing:-0.035em;line-height:1.1;margin-bottom:18px}
.sec-h2 span{color:var(--teal)}
.sec-p{font-size:16px;color:var(--text2);line-height:1.75;max-width:580px}
.section{padding:80px 96px;background:var(--white)}
.section.alt{background:#f8f9fb}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.card{background:var(--white);border:1px solid var(--border);border-radius:14px;padding:32px 28px;transition:box-shadow .2s,border-color .2s}
.card:hover{box-shadow:0 8px 32px rgba(0,0,0,.07);border-color:var(--border2)}
.card-h{font-size:18px;font-weight:700;color:var(--navy);margin-bottom:10px;letter-spacing:-0.02em}
.card-p{font-size:14px;color:var(--text2);line-height:1.7}
.card-icon{width:44px;height:44px;border-radius:10px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;margin-bottom:20px}
.card-icon svg{width:22px;height:22px;stroke:var(--navy);fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
.divider{border:none;border-top:1px solid var(--border);margin:0}
/* Fade-in — progressive enhancement. js-ready activates the hide state. */
.fade{opacity:0;transform:translateY(14px);transition:opacity .55s ease,transform .55s ease}
.fade.in{opacity:1;transform:none}

/* ── FOOTER ─────────────────────────────────────────────────────── */
footer{background:#f8f9fb;border-top:none;padding:72px 96px 0;position:relative;overflow:hidden}
footer::before{content:'';position:absolute;inset:0;background-image:radial-gradient(circle,rgba(26,35,50,.08) 1px,transparent 1px);background-size:20px 20px;pointer-events:none}
footer>*{position:relative;z-index:1}
.footer-nav{display:grid;grid-template-columns:1.6fr 1.4fr 1.4fr 1.4fr 1.4fr .8fr;gap:40px;padding-bottom:56px;border-bottom:1px solid var(--border);align-items:start}
.footer-brand-mark{display:flex;align-items:center;gap:9px;margin-bottom:12px}
.footer-brand-name{font-size:17px;font-weight:700;letter-spacing:-0.03em;font-style:italic;color:var(--navy)}
.footer-tagline{font-size:13px;color:var(--text3);line-height:1.65;max-width:200px;margin-bottom:20px}
.footer-socials{display:flex;align-items:center;gap:8px}
.social-btn{width:32px;height:32px;border-radius:7px;border:1px solid var(--border2);display:flex;align-items:center;justify-content:center;transition:border-color .15s,background .15s;text-decoration:none}
.social-btn:hover{border-color:var(--navy);background:#f5f4f2}
.social-btn svg{width:14px;height:14px;stroke:var(--text3);fill:none;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.social-btn:hover svg{stroke:var(--navy)}
.footer-col-heading{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text4);margin-bottom:18px}
.footer-links{display:flex;flex-direction:column;gap:12px}
.footer-link{font-size:14px;color:var(--text2);text-decoration:none;transition:color .15s}
.footer-link:hover{color:var(--navy)}
.pricing-note{font-size:14px;color:var(--text2)}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;padding:22px 0 28px;flex-wrap:wrap;gap:14px}
.footer-copy{font-size:13px;color:var(--text4)}
.footer-legal{display:flex;gap:24px;flex-wrap:wrap}
.footer-legal a{font-size:13px;color:var(--text4);text-decoration:none;transition:color .15s}
.footer-legal a:hover{color:var(--navy)}

/* ════════════════════════════════════════════════════════════════
   COOKIE CONSENT BANNER
   ════════════════════════════════════════════════════════════════ */
.cookie-banner{
  position:fixed;
  bottom:24px;
  left:50%;
  transform:translateX(-50%) translateY(120px);
  z-index:9999;
  width:calc(100% - 48px);
  max-width:680px;
  background:var(--white);
  border:1px solid var(--border);
  border-radius:16px;
  padding:24px 28px;
  box-shadow:0 16px 48px rgba(0,0,0,.10),0 2px 8px rgba(0,0,0,.06);
  display:flex;
  align-items:flex-start;
  gap:20px;
  opacity:0;
  pointer-events:none;
  transition:transform .5s cubic-bezier(.34,1.56,.64,1),opacity .4s ease;
}
.cookie-banner.show{
  opacity:1;
  pointer-events:all;
  transform:translateX(-50%) translateY(0);
}
.cookie-banner.hide{
  opacity:0;
  transform:translateX(-50%) translateY(130px);
  pointer-events:none;
  transition:transform .35s ease,opacity .3s ease;
}
.cookie-icon{display:none}
.cookie-body{flex:1;min-width:0}
.cookie-title{font-size:15px;font-weight:700;color:var(--navy);margin-bottom:6px;letter-spacing:-0.01em}
.cookie-text{font-size:13px;color:var(--text2);line-height:1.6;margin-bottom:16px}
.cookie-text a{color:var(--teal);text-decoration:underline;text-underline-offset:2px}
.cookie-text a:hover{color:var(--navy)}
.cookie-actions{display:flex;gap:10px;flex-wrap:wrap}
.cookie-btn-accept{
  background:var(--teal);color:var(--navy);
  font-size:13.5px;font-weight:600;
  padding:9px 20px;border-radius:8px;
  border:none;cursor:pointer;
  transition:background .15s,transform .15s;
  white-space:nowrap;
}
.cookie-btn-accept:hover{background:#04a3e0;transform:translateY(-1px)}
.cookie-btn-decline{display:none}
.cookie-btn-manage{
  background:none;color:var(--text3);
  font-size:12.5px;font-weight:500;
  padding:9px 12px;border-radius:8px;
  border:none;cursor:pointer;
  transition:color .15s;
  white-space:nowrap;
}
.cookie-btn-manage:hover{color:var(--navy)}
.cookie-close{
  position:absolute;top:14px;right:16px;
  background:none;border:none;cursor:pointer;
  color:var(--text3);
  font-size:18px;line-height:1;
  transition:color .15s;padding:4px;
}
.cookie-close:hover{color:var(--navy)}

/* Cookie preferences modal */
.cookie-modal-overlay{
  position:fixed;inset:0;
  background:rgba(0,0,0,.5);
  backdrop-filter:blur(4px);
  z-index:10000;
  display:flex;align-items:center;justify-content:center;
  padding:20px;
  opacity:0;pointer-events:none;
  transition:opacity .25s ease;
}
.cookie-modal-overlay.show{opacity:1;pointer-events:all}
.cookie-modal{
  background:var(--white);
  border-radius:20px;
  padding:32px;
  max-width:540px;width:100%;
  box-shadow:0 32px 80px rgba(0,0,0,.2);
  max-height:90vh;overflow-y:auto;
  transform:scale(.96);
  transition:transform .3s cubic-bezier(.34,1.56,.64,1);
}
.cookie-modal-overlay.show .cookie-modal{transform:scale(1)}
.cookie-modal-title{font-size:20px;font-weight:700;color:var(--navy);margin-bottom:8px;letter-spacing:-0.02em}
.cookie-modal-sub{font-size:13.5px;color:var(--text2);margin-bottom:24px;line-height:1.6}
.cookie-toggle-row{
  display:flex;align-items:flex-start;justify-content:space-between;gap:16px;
  padding:16px 0;border-bottom:1px solid var(--border);
}
.cookie-toggle-row:last-of-type{border-bottom:none}
.cookie-toggle-info{flex:1}
.cookie-toggle-info strong{font-size:14px;font-weight:600;color:var(--navy);display:block;margin-bottom:3px}
.cookie-toggle-info span{font-size:12.5px;color:var(--text3);line-height:1.5}
.cookie-toggle-wrap{flex-shrink:0;padding-top:2px}
.cookie-toggle-input{position:absolute;opacity:0;width:0;height:0}
.cookie-toggle-label{
  display:block;width:42px;height:24px;
  background:var(--border2);border-radius:12px;
  cursor:pointer;transition:background .2s;
  position:relative;
}
.cookie-toggle-label::after{
  content:'';position:absolute;
  top:3px;left:3px;
  width:18px;height:18px;
  background:#fff;border-radius:50%;
  transition:transform .2s;
  box-shadow:0 1px 4px rgba(0,0,0,.2);
}
.cookie-toggle-input:checked+.cookie-toggle-label{background:var(--teal)}
.cookie-toggle-input:checked+.cookie-toggle-label::after{transform:translateX(18px)}
.cookie-toggle-input:disabled+.cookie-toggle-label{opacity:.5;cursor:not-allowed}
.cookie-modal-actions{display:flex;gap:10px;margin-top:24px;flex-wrap:wrap}
.cookie-modal-save{
  flex:1;background:var(--teal);color:var(--navy);
  font-size:14px;font-weight:600;padding:11px 24px;
  border-radius:9px;border:none;cursor:pointer;
  transition:background .15s;
}
.cookie-modal-save:hover{background:#04a3e0}
.cookie-modal-cancel{
  background:none;border:1px solid var(--border2);color:var(--text2);
  font-size:14px;font-weight:500;padding:11px 20px;
  border-radius:9px;cursor:pointer;transition:border-color .15s,color .15s;
}
.cookie-modal-cancel:hover{border-color:var(--navy);color:var(--navy)}

/* ════════════════════════════════════════════════════════════════
   FULL RESPONSIVE OVERRIDES
   ════════════════════════════════════════════════════════════════ */

/* Large screens: prevent overflow */
@media(max-width:1400px){
  .section{padding:64px 64px}
  .page-hero-inner{padding:80px 64px 60px}
  footer{padding:60px 64px 0}
}

/* Medium-large: 1280px */
@media(max-width:1280px){
  .section{padding:56px 48px}
  .footer-nav{grid-template-columns:1.4fr 1fr 1fr 1fr 1fr;gap:32px}
}

/* Tablet landscape: 1024px */
@media(max-width:1024px){
  nav{padding:0 20px}
  .nav-center,.nav-right{display:none}
  .nav-hamburger{display:flex;flex-direction:column}

  .page-hero-inner{padding:40px 24px 28px}
  .section{padding:48px 24px}
  .grid-2{grid-template-columns:1fr;gap:40px}
  .grid-3{grid-template-columns:1fr}
  .grid-4{grid-template-columns:1fr 1fr}
  footer{padding:48px 24px 0}
  .footer-nav{grid-template-columns:1fr 1fr;gap:32px;padding-bottom:40px}

  /* Cookie banner */
  .cookie-banner{
    bottom:16px;
    width:calc(100% - 32px);
    padding:20px 20px;
    flex-direction:column;
    gap:14px;
  }
}

/* Tablet portrait: 768px */
@media(max-width:768px){
  .grid-4{grid-template-columns:1fr 1fr}
  .cookie-actions{flex-direction:column}
  .cookie-btn-accept{width:100%;text-align:center}
  .cookie-modal{padding:24px 20px}
  .page-hero-inner{padding:36px 24px 28px}
}

/* Mobile: 600px */
@media(max-width:600px){
  .footer-nav{grid-template-columns:1fr 1fr}
  .grid-4{grid-template-columns:1fr}
  .page-hero-inner{padding:30px 20px 24px}
  .cookie-banner{
    left:16px;right:16px;
    width:auto;
    transform:translateY(120px);
    bottom:16px;
  }
  .cookie-banner.show{transform:translateY(0)}
  .cookie-banner.hide{transform:translateY(130px)}
}

/* Mobile small: 480px */
@media(max-width:480px){
  nav{padding:0 16px}
  .nav-brand-name{font-size:17px}
  .nav-drawer{padding:12px 16px 20px}
  .d-item{font-size:13.5px}
  .page-hero-inner{padding:24px 16px 20px}
  .section{padding:36px 16px}
  .footer-nav{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;align-items:flex-start;gap:10px}
  .footer-legal{gap:16px}
}

/* ── SMOOTH SECTION TRANSITIONS ─────────────────────────────── */
.page-hero,.pricing-hero,.reviews-hero{
  position:relative;
}
.page-hero::after,.pricing-hero::after,.reviews-hero::after{
  content:'';
  display:block;
  height:40px;
  background:linear-gradient(to bottom,var(--white),transparent);
  margin-bottom:-40px;
  position:relative;
  z-index:1;
}
section,.logos-bar{
  background:var(--white);
  position:relative;
}
section+section{
  border-top:none;
}
.faq-section,.compare-section,.plans-grid,.legal-layout{
  position:relative;
}
.nav-right svg{
  width:10px;
}
