/* =========================
   SwiftGraphix — Memberships & Pricing (SaaS-ready)
   Dark SaaS aesthetic aligned with your public automotive styles
   ========================= */

@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;600;700;800;900&display=swap');

:root{
  --bg: #0B0F14;
  --bg-elev: #10161D;
  --surface: #0F1621;
  --line: #18212B;

  --text: #E7EDF6;
  --muted: #A6B3C2;

  --brand: #0CA8FF;
  --brand-600:#0895E0;
  --brand-700:#067AB8;
  --brand-soft: rgba(12,168,255,.12);

  --radius: 14px;
  --shadow-sm: 0 6px 16px rgba(0,0,0,.45);
  --shadow-md: 0 16px 32px rgba(0,0,0,.55);

  --space-1: .25rem;
  --space-2: .5rem;
  --space-3: .75rem;
  --space-4: 1rem;
  --space-5: 1.5rem;
  --space-6: 2rem;
  --space-7: 3rem;
  --space-8: 4rem;

  --h1: clamp(2.2rem, 2vw + 1.7rem, 3.2rem);
  --h2: clamp(1.6rem, 1.2vw + 1.2rem, 2.2rem);
  --h3: clamp(1.2rem, .6vw + 1rem, 1.5rem);
  --p:  clamp(1rem, .2vw + .95rem, 1.125rem);

  --container: min(1200px, 92vw);

  --dur-quick: .18s;
  --dur-med: .35s;
  --e-out: cubic-bezier(.16,1,.3,1);
}

*{ box-sizing:border-box; }
html,body{ height:100%; }
body{
  margin:0;
  background: var(--bg);
  color: var(--text);
  font-family: Poppins, system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, sans-serif;
  -webkit-font-smoothing: antialiased;
}
img{ max-width:100%; display:block; }
.container{ width: var(--container); margin-inline:auto; }

a{ color: var(--brand); text-decoration:none; }
a:hover{ color: var(--brand-600); }
:focus-visible{ outline: 3px solid rgba(12,168,255,.35); outline-offset: 2px; border-radius: 6px; }

.muted{ color: var(--muted); }

/* =========================
   Header / Nav
   ========================= */
.header{
  position: sticky; top: 0; z-index: 1000;
  backdrop-filter: saturate(140%) blur(8px);
  background: rgba(15,22,33,.85);
  border-bottom: 1px solid var(--line);
  transition: box-shadow .2s ease, background-color .2s ease;
}
.header.is-scrolled{ box-shadow: var(--shadow-sm); background: rgba(15,22,33,.95); }

.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  width: var(--container);
  margin-inline:auto;
  padding: .7rem 0;
}
.logo img{ height: 44px; }

.nav{ display:flex; align-items:center; }
.nav ul{
  list-style:none;
  display:flex;
  gap:28px;
  margin:0;
  padding:0;
}
.nav ul li a{
  color: var(--muted);
  font-weight:600;
  font-size: 15.5px;
  padding:.35rem 0;
  position:relative;
}
.nav ul li a:hover{ color: var(--text); }
.nav ul li a[aria-current="page"]{ color: var(--text); }
.nav ul li a::after{
  content:"";
  position:absolute;
  left:0; right:100%;
  bottom:-6px;
  height:2px;
  background: linear-gradient(90deg, var(--brand), var(--brand-600));
  transition: right var(--dur-med) var(--e-out);
  border-radius: 2px;
}
.nav ul li a:hover::after,
.nav ul li a[aria-current="page"]::after{ right:0; }

.menu-toggle{
  display:none;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  cursor:pointer;
  padding:8px;
  width:40px;
  height:40px;
  border-radius:10px;
  border:1px solid var(--line);
  background: var(--surface);
}
.menu-toggle span{
  height:3px;
  width:22px;
  background: var(--text);
  margin:3px 0;
  border-radius:2px;
  transition: transform .25s ease, opacity .25s ease;
}
.menu-toggle.open span:nth-child(1){ transform: rotate(45deg) translate(4px,4px); }
.menu-toggle.open span:nth-child(2){ opacity:0; }
.menu-toggle.open span:nth-child(3){ transform: rotate(-45deg) translate(4px,-4px); }

@media (max-width:880px){
  .menu-toggle{ display:flex; }
  .nav{
    position:absolute;
    top:100%;
    left:0;
    width:100%;
    display:none;
    flex-direction:column;
    background: var(--surface);
    border-bottom:1px solid var(--line);
    box-shadow: var(--shadow-sm);
    animation: fadeInNav .25s ease;
  }
  .nav.active{ display:flex; }
  .nav ul{ flex-direction:column; gap:0; width:100%; }
  .nav ul li a{
    display:block;
    padding:.9rem 1.1rem;
    width:100%;
    border-top:1px solid var(--line);
  }
}
@keyframes fadeInNav{
  from{ opacity:0; transform:translateY(-4px); }
  to{ opacity:1; transform:translateY(0); }
}

/* =========================
   Buttons
   ========================= */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.5rem;
  padding:.85rem 1.1rem;
  border-radius:12px;
  font-weight:700;
  border:1px solid transparent;
  transition:.18s transform,.18s filter,.18s box-shadow,.18s background;
}
.btn:hover{ transform:translateY(-2px); }
.btn:active{ transform:translateY(0); }

.btn-primary{
  background: linear-gradient(180deg,var(--brand),var(--brand-600));
  color:#fff;
  box-shadow: 0 10px 24px rgba(12,168,255,.25);
}
.btn-primary:hover,
.btn-primary:focus{ color:#fff; filter:saturate(110%); }

.btn-secondary{
  background:transparent;
  border-color: rgba(12,168,255,.35);
  color: var(--text);
}
.btn-secondary:hover{ background: rgba(12,168,255,.08); }

.btn-ghost{
  background: rgba(255,255,255,.06);
  color: var(--text);
  border:1px solid var(--line);
}
.btn-lg{ padding:1rem 1.35rem; border-radius:14px; }

.btn.magnetic{ transition: transform var(--dur-quick) var(--e-out), box-shadow var(--dur-quick); will-change: transform; }
.btn.magnetic:hover{ transform: translateY(-3px) scale(1.02); }

.btn.shimmer{
  background-image:
    linear-gradient(180deg,var(--brand),var(--brand-600)),
    linear-gradient(90deg, rgba(255,255,255,.22), rgba(255,255,255,0), rgba(255,255,255,.22));
  background-size: 100% 100%, 200% 100%;
  background-position: 0 0, -200% 0;
}
.btn.shimmer:hover{ animation: shine 1.4s linear forwards; }
@keyframes shine{ to{ background-position: 0 0, 200% 0; } }

/* =========================
   Sections
   ========================= */
.section{
  padding: var(--space-8) 0;
  background: var(--bg);
  border-top:1px solid var(--line);
}
.section.alt{ background: var(--bg-elev); }
.section-sub{
  color: var(--muted);
  text-align:center;
  margin:0 0 var(--space-6);
}
h2{ font-size: var(--h2); margin:0 0 .4rem; text-align:center; }
h3{ font-size: var(--h3); margin:0 0 .35rem; }

/* =========================
   Hero
   ========================= */
.hero{
  position:relative;
  overflow:hidden;
  padding: clamp(3rem,6vw,6rem) 0;
  background:
    radial-gradient(900px 500px at 85% -10%, rgba(12,168,255,.18), transparent 60%),
    linear-gradient(180deg, #0B0F14, #10161D);
}
.hero-grid{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:var(--space-7);
  align-items:center;
}
@media (max-width:980px){
  .hero-grid{ grid-template-columns:1fr; gap:var(--space-6); }
}
.hero-copy .eyebrow{
  display:inline-block;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
  color: var(--brand);
  background: var(--brand-soft);
  border:1px solid rgba(12,168,255,.25);
  padding:.35rem .65rem;
  border-radius:999px;
  margin-bottom: var(--space-4);
}
.hero h1{
  font-size:var(--h1);
  line-height:1.1;
  margin:0 0 var(--space-4);
}
.hero p{
  font-size:var(--p);
  color: var(--muted);
  margin:0 0 var(--space-5);
}
.cta-row{ display:flex; gap:.8rem; flex-wrap:wrap; }
.hero-bullets{
  display:flex;
  gap:1rem;
  list-style:none;
  padding:0;
  margin: var(--space-5) 0 0;
  flex-wrap:wrap;
}
.hero-bullets li{
  color:var(--muted);
  font-size:.98rem;
  padding-left:.9rem;
  position:relative;
}
.hero-bullets li::before{
  content:"";
  position:absolute;
  left:0;
  top:.5rem;
  width:.5rem;
  height:.5rem;
  border-radius:999px;
  background:var(--brand);
}

.glass{
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.08);
  border-radius:18px;
  padding:.9rem;
  box-shadow: var(--shadow-md);
}

/* Pricing snapshot card in hero */
.pricing-snapshot{
  background: rgba(15,22,33,.65);
  border:1px solid rgba(255,255,255,.06);
  border-radius:16px;
  padding: 1.1rem;
}
.snap-row{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:1rem;
}
.snap-title{ font-weight:900; letter-spacing:.02em; }
.snap-price{
  font-weight:900;
  font-size: 1.3rem;
}
.snap-price span{
  color: var(--muted);
  font-weight:700;
  font-size: .9rem;
}
.snap-sub{
  color: var(--muted);
  margin:.6rem 0 1rem;
  line-height:1.5;
}
.snap-grid{
  display:grid;
  grid-template-columns: repeat(2,1fr);
  gap:.7rem;
}
.snap-card{
  background: rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.06);
  border-radius:14px;
  padding:.75rem;
}
.snap-k{
  color: var(--muted);
  font-size:.85rem;
  font-weight:700;
}
.snap-v{
  font-weight:900;
  margin-top:.15rem;
}
.snap-actions{
  display:flex;
  gap:.6rem;
  flex-wrap:wrap;
  margin-top:1rem;
}

/* =========================
   Tabs
   ========================= */
.tabs{
  display:flex;
  gap:.6rem;
  justify-content:center;
  flex-wrap:wrap;
  margin: 0 0 var(--space-6);
}
.tab{
  border:1px solid var(--line);
  background: rgba(255,255,255,.04);
  color: var(--muted);
  padding:.7rem 1rem;
  border-radius:999px;
  font-weight:800;
  cursor:pointer;
  transition: background var(--dur-quick), color var(--dur-quick), transform var(--dur-quick);
}
.tab:hover{ transform: translateY(-2px); color: var(--text); }
.tab.active{
  background: var(--brand-soft);
  border-color: rgba(12,168,255,.28);
  color: var(--text);
}

.tab-panel{ display:none; }
.tab-panel.active{ display:block; }

.panel-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap: 1.25rem;
  margin-bottom: var(--space-5);
}
@media (max-width:900px){
  .panel-head{ flex-direction:column; }
}
.panel-note{
  background: rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.06);
  border-radius: 14px;
  padding: .85rem 1rem;
  min-width: 260px;
}
.note-pill{
  display:inline-block;
  font-weight:900;
  color: var(--text);
  background: rgba(12,168,255,.10);
  border: 1px solid rgba(12,168,255,.22);
  padding:.35rem .6rem;
  border-radius:999px;
}
.note-sub{ color: var(--muted); margin-top:.5rem; }

/* =========================
   Cards / Pricing
   ========================= */
.card-grid{
  display:grid;
  grid-template-columns: repeat(3,1fr);
  gap: var(--space-5);
}
@media (max-width:980px){
  .card-grid{ grid-template-columns:1fr; }
}
.card{
  position:relative;
  background: var(--surface);
  border:1px solid var(--line);
  border-radius: var(--radius);
  padding: var(--space-5);
  display:flex;
  flex-direction:column;
  gap:.9rem;
  align-items:flex-start;
  transition: transform var(--dur-med) var(--e-out), box-shadow var(--dur-med), border-color var(--dur-med);
}
.card:hover{
  transform: translateY(-6px);
  box-shadow:var(--shadow-md);
  border-color: rgba(12,168,255,.35);
}
.card p{ margin:0; color: var(--muted); }

.price-grid{ grid-template-columns: repeat(3,1fr); }
@media (max-width:980px){ .price-grid{ grid-template-columns:1fr; } }

.price-card .price{
  font-weight:900;
  font-size: 1.85rem;
  margin:.2rem 0 .3rem;
}
.price-card .price span{
  color: var(--muted);
  font-weight:700;
  font-size: 1rem;
}
.plan-title{ margin:0; font-size: 1.2rem; }
.plan-desc{ color: var(--muted); line-height:1.55; }
.list{
  list-style:none;
  padding:0;
  margin:0;
  display:grid;
  gap:.45rem;
  color:var(--muted);
}
.list li{
  position:relative;
  padding-left: 1.05rem;
}
.list li::before{
  content:"";
  position:absolute;
  left:0;
  top:.55rem;
  width:.45rem;
  height:.45rem;
  border-radius:999px;
  background: var(--brand);
}
.plan-actions{
  display:flex;
  gap:.6rem;
  flex-wrap:wrap;
  margin-top:.25rem;
}
.plan-foot{
  margin-top:.4rem;
  font-size:.92rem;
  line-height:1.5;
}

.price-card.featured{
  border-color: rgba(12,168,255,.35);
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}
.badge{
  position:absolute;
  top:-10px;
  right:12px;
  font-size:.75rem;
  font-weight:900;
  letter-spacing:.02em;
  padding:.25rem .55rem;
  border-radius: 8px;
  background: var(--brand);
  color:#0B0F14;
  box-shadow: 0 6px 14px rgba(12,168,255,.25);
}

.callout{
  width:100%;
  background: rgba(12,168,255,.08);
  border:1px solid rgba(12,168,255,.18);
  border-radius: 14px;
  padding: .85rem 1rem;
}
.callout-title{ font-weight:900; }
.callout-text{ color: var(--muted); margin-top:.35rem; line-height:1.55; }

/* =========================
   Comparison Table
   ========================= */
.compare-wrap{
  margin-top: var(--space-7);
  background: rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.06);
  border-radius: 18px;
  padding: 1.25rem;
}
.compare-title{
  margin: 0 0 1rem;
  font-size: 1.1rem;
  font-weight: 900;
}
.compare{
  display:grid;
  gap: .55rem;
}
.compare-row{
  display:grid;
  grid-template-columns: 1.4fr .8fr .9fr;
  gap: .75rem;
  align-items:center;
  background: rgba(15,22,33,.55);
  border:1px solid rgba(255,255,255,.06);
  border-radius: 12px;
  padding: .75rem .9rem;
}
.compare-head{
  background: rgba(12,168,255,.10);
  border-color: rgba(12,168,255,.18);
  font-weight: 900;
}
.compare .c0{ color: var(--text); font-weight: 800; }
.compare .c1, .compare .c2{ color: var(--muted); font-weight: 700; }
.compare-head .c1, .compare-head .c2{ color: var(--text); }

@media (max-width:760px){
  .compare-row{
    grid-template-columns: 1fr;
    gap:.35rem;
  }
  .compare .c1, .compare .c2{
    padding-left:.25rem;
  }
}
.compare-foot{
  margin-top: .85rem;
  color: var(--muted);
  font-size: .92rem;
}

/* =========================
   FAQ
   ========================= */
.faq-grid{
  display:grid;
  grid-template-columns: repeat(2,1fr);
  gap: var(--space-5);
}
@media (max-width:980px){
  .faq-grid{ grid-template-columns:1fr; }
}
.faq details{
  background: var(--surface);
  border:1px solid var(--line);
  border-radius: var(--radius);
  padding: var(--space-4) var(--space-5);
}
.faq summary{
  cursor:pointer;
  font-weight:800;
  color:var(--text);
  outline:none;
  list-style:none;
}
.faq summary::-webkit-details-marker{ display:none; }
.faq details[open]{ box-shadow: var(--shadow-sm); }
.faq p{ color:var(--muted); margin:.65rem 0 0; line-height:1.6; }

/* =========================
   CTA
   ========================= */
.cta{
  padding: var(--space-8) 0;
  background:
    radial-gradient(800px 500px at 50% 0%, rgba(12,168,255,.14), transparent 70%),
    linear-gradient(180deg, #0B0F14, #10161D);
}
.cta-inner{
  display:grid;
  gap: var(--space-4);
  justify-items:center;
  text-align:center;
}
.cta h2{ margin:0; }
.cta p{ color:var(--muted); margin:0 0 .5rem; }

/* =========================
   Footer
   ========================= */
.footer-section{
  background: var(--bg-elev);
  color: var(--text);
  padding: 60px 20px;
  font-size:14px;
  border-top:1px solid var(--line);
}
.footer-container{
  display:flex;
  justify-content:space-between;
  flex-wrap:wrap;
  max-width:var(--container);
  margin:0 auto;
  gap:20px;
}
.footer-column{ flex:1; min-width:260px; text-align:left; }
.footer-column h3{ color:var(--brand); font-size:18px; margin-bottom:15px; }
.footer-column p, .footer-column a{ color:var(--muted); line-height:1.8; }
.footer-column ul{ list-style:none; padding:0; margin:0; }
.footer-column ul li{ margin-bottom:10px; }
.footer-column ul li a{ color: var(--brand); font-size:16px; display:inline-block; }
.footer-column ul li a:hover{ color: var(--brand-600); text-decoration:underline; }
.footer-bottom{
  text-align:center;
  margin-top:28px;
  padding-top:18px;
  border-top:1px solid var(--line);
  color:#8FA0AF;
}
.social-icons a{
  display:inline-block;
  margin:0 10px;
  font-size:18px;
  color: var(--brand);
}
.social-icons a:hover{ color: var(--brand-600); }

/* Reduced motion safety */
@media (prefers-reduced-motion: reduce){
  *{ animation: none !important; transition: none !important; }
}