
:root{
  --bg:#111827;
  --panel:#0b1224;
  --text:#F3F4F6;
  --muted:#9CA3AF;
  --muted2:#6B7280;
  --brand:#6C63FF;
  --brand2:#1E2A78;
  --border:rgba(255,255,255,.08);
  --shadow: 0 18px 60px rgba(0,0,0,.35);
  --radius:18px;
  --radius2:24px;
  --max:1120px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background: radial-gradient(1200px 600px at 20% -10%, rgba(108,99,255,.25), transparent 60%),
              radial-gradient(900px 500px at 90% 10%, rgba(30,42,120,.35), transparent 55%),
              var(--bg);
  color:var(--text);
  font-family:Inter, ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  line-height:1.6;
}
img{max-width:100%;height:auto}
a{color:inherit}
.container{max-width:var(--max);margin:0 auto;padding:0 20px}
.narrow{max-width:860px}
.section{padding:72px 0}
.section-head{margin-bottom:28px}
.eyebrow{letter-spacing:.12em;text-transform:uppercase;color:rgba(243,244,246,.75);font-weight:600;font-size:.82rem}
.lead{font-size:1.2rem;color:rgba(243,244,246,.9)}
.muted{color:var(--muted)}
.tiny{font-size:.92rem}
.sr-only{position:absolute;left:-9999px}
.skip-link{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-link:focus{left:20px;top:20px;width:auto;height:auto;padding:10px 12px;background:var(--panel);border:1px solid var(--border);border-radius:12px;z-index:9999}

.site-header{
  position:sticky;top:0;z-index:1000;
  backdrop-filter:saturate(140%) blur(10px);
  background:rgba(17,24,39,.72);
  border-bottom:1px solid var(--border);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 0}
.brand-link{display:flex;align-items:center;gap:10px;text-decoration:none}
.brand-mark{
  display:inline-flex;align-items:center;justify-content:center;
  width:42px;height:42px;border-radius:14px;
  background:linear-gradient(135deg, rgba(108,99,255,.22), rgba(30,42,120,.22));
  border:1px solid var(--border);
  font-family:Sora, system-ui, sans-serif;
  color:rgba(243,244,246,.95);
}
.brand-name{font-family:Sora, system-ui, sans-serif;font-weight:700;letter-spacing:.02em;font-size:1.15rem;}
.custom-logo{max-height:46px;width:auto}
.nav{position:relative}
.nav-toggle{
  display:none;
  background:transparent;border:1px solid var(--border);color:var(--text);
  border-radius:14px;padding:10px 12px;cursor:pointer;
}
.nav-toggle-lines{
  display:block;width:22px;height:14px;position:relative;
}
.nav-toggle-lines:before,.nav-toggle-lines:after,.nav-toggle-lines span{
  content:"";position:absolute;left:0;right:0;height:2px;background:rgba(243,244,246,.85);border-radius:999px
}
.nav-toggle-lines:before{top:0}
.nav-toggle-lines:after{bottom:0}
.nav-toggle-lines span{top:6px}
.nav-panel{display:flex;align-items:center;gap:14px}
.menu{display:flex;gap:18px;list-style:none;margin:0;padding:0}
.menu a{color:rgba(243,244,246,.85);text-decoration:none;font-weight:500}
.menu a:hover{color:#fff}
.nav-cta{display:flex;gap:10px;align-items:center}

.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:12px 18px;border-radius:14px;
  text-decoration:none;font-weight:600;
  border:1px solid var(--border);
  transition:transform .15s ease, background .15s ease, border-color .15s ease;
  white-space:nowrap;
}
.btn:hover{transform:translateY(-1px)}
.btn-primary{
  background:linear-gradient(135deg, rgba(108,99,255,.95), rgba(108,99,255,.72));
  border-color:rgba(108,99,255,.35);
  box-shadow:0 12px 30px rgba(108,99,255,.18);
}
.btn-primary:hover{box-shadow:0 18px 44px rgba(108,99,255,.22)}
.btn-secondary{
  background:rgba(255,255,255,.06);
}
.btn-secondary:hover{background:rgba(255,255,255,.09)}
.hero{padding-top:92px}
.grid-hero{
  display:grid;grid-template-columns:1.05fr .95fr;gap:42px;align-items:center;
}
.hero h1{
  font-family:Sora, system-ui, sans-serif;
  font-size:3.25rem;line-height:1.05;margin:10px 0 14px;
}
.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin:22px 0 10px}
.hero-bullets{display:flex;flex-wrap:wrap;gap:10px;list-style:none;padding:0;margin:18px 0 0}
.hero-bullets li{
  font-size:.95rem;color:rgba(243,244,246,.85);
  padding:8px 12px;border-radius:999px;border:1px solid var(--border);
  background:rgba(255,255,255,.04)
}

.hero-visual{position:relative}
.mock{
  border-radius:var(--radius2);
  border:1px solid var(--border);
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  box-shadow:var(--shadow);
  overflow:hidden;
}
.mock-top{
  display:flex;align-items:center;gap:8px;
  padding:12px 14px;border-bottom:1px solid var(--border);
  background:rgba(0,0,0,.18)
}
.dot{width:10px;height:10px;border-radius:999px;background:rgba(243,244,246,.25)}
.mock-title{margin-left:auto;color:rgba(243,244,246,.7);font-size:.9rem}
.mock-body{padding:18px;display:grid;gap:14px}
.mock-card{
  display:grid;grid-template-columns:repeat(3,1fr);gap:12px
}
.mock-kpi{
  padding:14px;border-radius:16px;background:rgba(17,24,39,.55);
  border:1px solid var(--border)
}
.kpi-title{font-size:.85rem;color:rgba(243,244,246,.68);font-weight:600}
.kpi-value{margin-top:6px;font-weight:700}
.mock-code pre{
  margin:0;padding:14px;border-radius:16px;
  background:rgba(0,0,0,.35);border:1px solid var(--border);
  overflow:auto;color:rgba(243,244,246,.85);font-size:.9rem
}
.glow{
  position:absolute;inset:-20% -20% auto auto;width:420px;height:420px;border-radius:999px;
  background:radial-gradient(circle at 30% 30%, rgba(108,99,255,.35), transparent 60%);
  filter:blur(22px);
  z-index:-1;
}

.strip{padding:28px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:rgba(0,0,0,.12)}
.strip-inner{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap}
.strip-title{margin:0;font-weight:700;font-family:Sora, system-ui, sans-serif}
.strip-sub{margin:0;color:rgba(243,244,246,.75)}

.card{
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease, background .18s ease;

  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:26px;
  box-shadow:0 18px 44px rgba(0,0,0,.25);
}
.card.highlight{
  background:linear-gradient(135deg, rgba(108,99,255,.16), rgba(30,42,120,.16));
  border-color:rgba(108,99,255,.22);
}
.cards-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.list-cards{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:26px}
.grid-2{display:grid;grid-template-columns:1.05fr .95fr;gap:20px;align-items:start}
.section h2{font-family:Sora, system-ui, sans-serif;margin:0 0 12px}
.section h3{font-family:Sora, system-ui, sans-serif;margin:0 0 10px}
.bullets{margin:12px 0 0;padding-left:18px;color:rgba(243,244,246,.82)}
.checklist{list-style:none;margin:12px 0 0;padding:0;display:grid;gap:10px}
.checklist li{
  padding-left:30px;position:relative;color:rgba(243,244,246,.86)
}
.checklist li:before{
  content:"";position:absolute;left:0;top:.35em;width:18px;height:18px;border-radius:6px;
  background:rgba(108,99,255,.18);border:1px solid rgba(108,99,255,.35)
}
.checklist li:after{
  content:"";position:absolute;left:6px;top:.55em;width:6px;height:10px;border-right:2px solid rgba(243,244,246,.85);border-bottom:2px solid rgba(243,244,246,.85);
  transform:rotate(45deg)
}

.steps{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-top:24px}
.step{
  transition:transform .18s ease, background .18s ease, border-color .18s ease;
padding:18px;border-radius:18px;border:1px solid var(--border);background:rgba(255,255,255,.03)}
.step-num{
  width:34px;height:34px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;
  background:rgba(108,99,255,.18);border:1px solid rgba(108,99,255,.35);
  font-family:Sora, system-ui, sans-serif;font-weight:700;margin-bottom:10px
}

.pricing .price{margin:8px 0 0;font-size:1.1rem}
.plugin-note{margin-top:18px;display:flex;align-items:center;justify-content:space-between;gap:18px}
.plugin-note .price{margin:0}

.accordion{display:grid;gap:12px;margin-top:18px}
.faq{
  border:1px solid var(--border);
  border-radius:16px;
  padding:14px 16px;
  background:rgba(255,255,255,.03);
}
.faq summary{cursor:pointer;font-weight:700;font-family:Sora, system-ui, sans-serif}
.faq p{margin:10px 0 0;color:rgba(243,244,246,.85)}
.cta-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:12px}

.final-cta{
  background:radial-gradient(900px 500px at 20% 10%, rgba(108,99,255,.22), transparent 55%),
             radial-gradient(900px 500px at 80% 10%, rgba(30,42,120,.28), transparent 55%),
             rgba(0,0,0,.10);
  border-top:1px solid var(--border);
}
.grid-cta{display:grid;grid-template-columns:1.1fr .9fr;gap:18px;align-items:center}
.cta-card{border-color:rgba(108,99,255,.22)}

.content :is(h2,h3){margin-top:26px}
.content a{text-decoration:underline;text-underline-offset:4px}

.site-footer{padding:64px 0;border-top:1px solid var(--border);background:rgba(0,0,0,.14)}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:18px}
.footer-links{list-style:none;margin:12px 0 0;padding:0;display:grid;gap:10px}
.footer-links a{color:rgba(243,244,246,.75);text-decoration:none}
.footer-links a:hover{color:#fff}
.footer-bottom{margin-top:34px;border-top:1px solid var(--border);padding-top:18px}
.site-footer h3{margin:0 0 12px;padding:0}
.footer-title{margin:0 0 12px;padding:0}
.footer-brand{padding-top:0}
.footer-grid > *{align-self:start}

.post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;padding:24px 0}
.card-link{text-decoration:none;display:block}
.card-title{margin:0 0 10px;font-family:Sora, system-ui, sans-serif}
.card-excerpt{margin:0;color:rgba(243,244,246,.78)}
.card-meta{display:block;margin-top:14px;color:rgba(243,244,246,.6);font-size:.9rem}
.page-header{padding:30px 0 10px}
.page-title{margin:0;font-family:Sora, system-ui, sans-serif}
.featured{margin:18px 0}
.empty-state{padding:70px 0}

@media (max-width: 980px){
  .grid-hero{grid-template-columns:1fr;gap:24px}
  .hero h1{font-size:2.5rem}
  .cards-3{grid-template-columns:1fr;gap:14px}
  .list-cards{grid-template-columns:1fr}
  .grid-2{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr;gap:10px}
  .grid-cta{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr;gap:14px}
  .post-grid{grid-template-columns:1fr}
  .section{padding:48px 0}
  .hero{padding-top:56px}
}

@media (max-width: 760px){
  .nav-toggle{display:inline-flex;align-items:center;gap:10px}
  .nav-panel{
    position:absolute;right:0;top:56px;
    width:min(92vw, 420px);
    flex-direction:column;align-items:stretch;gap:10px;
    padding:14px;border-radius:18px;
    background:rgba(17,24,39,.92);
    border:1px solid var(--border);
    box-shadow:var(--shadow);
    display:none;
  }
  .nav-panel.is-open{display:flex}
  .menu{flex-direction:column;gap:10px}
  .nav-cta{flex-direction:column;align-items:stretch}
  .btn{width:100%}
}

/* Reveal micro-animation */
.reveal{opacity:0;transform:translateY(10px);transition:opacity .5s ease, transform .5s ease}
.is-visible{opacity:1;transform:none}

.brand-name--fallback{font-size:1.18rem}


@media (hover:hover) and (pointer:fine){
  .card:hover{
    transform:translateY(-6px);
    box-shadow:0 22px 60px rgba(0,0,0,.34);
    border-color:rgba(108,99,255,.22);
  }
  .step:hover{
    transform:translateY(-4px);
    border-color:rgba(108,99,255,.18);
    background:rgba(255,255,255,.045);
  }
}



  50%{background-position:100% 50%}
  100%{background-position:0% 50%}
}



@media (max-width:760px){
       }


.footer-title{margin:0;font-family:Sora, system-ui, sans-serif;font-weight:700}
.footer-brand .footer-logo{margin-top:12px}


/* --- Premium header improvements --- */
.menu a{
 position:relative;
 padding-bottom:4px;
}
.menu a::after{
 content:"";
 position:absolute;
 left:0;
 bottom:-2px;
 width:0;
 height:2px;
 background:linear-gradient(90deg,var(--brand),#8b84ff);
 transition:width .25s ease;
}
.menu a:hover::after{
 width:100%;
}

.site-header{
 padding:6px 0;
}

.brand-link{
 align-items:center;
}

.header-inner{
 min-height:64px;
}


/* --- Process Timeline (High-ticket style) --- */
.process-timeline{
  margin-top:26px;
  display:grid;
  gap:16px;
  position:relative;
}
.process-timeline::before{
  content:"";
  position:absolute;
  left:22px;
  top:8px;
  bottom:8px;
  width:2px;
  background:linear-gradient(180deg, rgba(108,99,255,.95), rgba(255,107,107,.65));
  opacity:.55;
  border-radius:2px;
}
.process-step{
  position:relative;
  padding-left:72px;
}
.process-step::before{
  content:"";
  position:absolute;
  left:12px;
  top:22px;
  width:20px;
  height:20px;
  border-radius:999px;
  background:rgba(108,99,255,.15);
  border:1px solid rgba(108,99,255,.45);
  box-shadow:0 10px 30px rgba(108,99,255,.18);
}
.process-step::after{
  content:"";
  position:absolute;
  left:18px;
  top:28px;
  width:8px;
  height:8px;
  border-radius:999px;
  background:linear-gradient(135deg, var(--brand), #8b84ff);
}
.process-stepnum{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-size:.78rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:rgba(255,255,255,.72);
  margin:0 0 10px;
}
.process-stepnum::before{
  content:"";
  width:12px;
  height:12px;
  border-radius:6px;
  background:linear-gradient(135deg, var(--brand), #8b84ff);
  box-shadow:0 10px 24px rgba(108,99,255,.25);
}
.process-step.card{
  border:1px solid rgba(255,255,255,.08);
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
}
.process-step.card:hover{
  border-color:rgba(108,99,255,.45);
  transform:translateY(-4px);
  box-shadow:0 24px 60px rgba(0,0,0,.40);
}

/* Staggered reveal for steps */
.process-step.reveal{opacity:0;transform:translateY(14px) scale(.995)}
.process-step.is-visible{opacity:1;transform:none}
.process-step:nth-child(1){transition-delay:0ms}
.process-step:nth-child(2){transition-delay:60ms}
.process-step:nth-child(3){transition-delay:120ms}
.process-step:nth-child(4){transition-delay:180ms}
.process-step:nth-child(5){transition-delay:240ms}


  .process-step::after{display:none;}
  .process-step::before{display:none;}
}


/* Remove dot/bullet before STEP label */
.process-stepnum::before,
.process-stepnum::after,
.process-step .process-stepnum::before,
.process-step .process-stepnum::after{
  content: none !important;
  display: none !important;
}
.process-stepnum{
  list-style: none !important;
  padding-left: 0 !important;
  margin-left: 0 !important;
}


/* --- Premium process timeline improvements --- */
.process-timeline{
  margin-top: 30px;
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 18px;
  position: relative;
  padding-top: 18px;
}

/* animated master line behind cards */
.process-timeline::before{
  content:"";
  position:absolute;
  left: 2%;
  right: 2%;
  top: 52px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg,
    rgba(108,99,255,.12),
    rgba(108,99,255,.95),
    rgba(193,255,114,.70),
    rgba(108,99,255,.95),
    rgba(108,99,255,.12)
  );
  background-size: 220% 100%;
  animation: lahiLineMove 3.2s linear infinite;
  opacity: .9;
  pointer-events:none;
}

.process-step.card{
  position: relative;
  overflow: hidden;
  min-height: 260px;
  padding-top: 22px;
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}

.process-step.card:hover{
  transform: translateY(-6px);
  border-color: rgba(108,99,255,.55);
  box-shadow: 0 24px 60px rgba(0,0,0,.38);
}

/* glowing node per step, aligned with master line */
.process-step.card::before{
  content:"";
  position:absolute;
  top: 52px;
  left: 18px;
  width: 12px;
  height: 12px;
  border-radius: 999px;
  background: radial-gradient(circle at 30% 30%, #ffffff, var(--brand));
  box-shadow: 0 0 0 5px rgba(108,99,255,.16), 0 14px 40px rgba(108,99,255,.28);
  transform: translateY(-50%);
  z-index: 2;
}

/* subtle inner glow */
.process-step.card::after{
  content:"";
  position:absolute;
  inset:-2px;
  background: radial-gradient(600px 200px at 20% 0%,
    rgba(108,99,255,.14),
    transparent 55%);
  opacity:.9;
  pointer-events:none;
}

/* STEP label styling */
.process-stepnum{
  letter-spacing: .18em;
  text-transform: uppercase;
  font-weight: 800;
  font-size: .78rem;
  margin: 0 0 10px;
  color: rgba(193,255,114,.95);
}

.process-step h3{
  margin: 0 0 10px;
}

.process-step p{
  margin: 0;
  color: rgba(255,255,255,.78);
  font-size: .95rem;
  line-height: 1.45;
}

/* Responsive: stack & hide master line */
@media (max-width: 960px){
  .process-timeline{
    grid-template-columns: 1fr;
    padding-top: 0;
  }
  .process-timeline::before{display:none;}
  .process-step.card::before{display:none;}
  .process-step.card{min-height:auto;}
}


/* --- Sticky shrinking header (agency style) --- */
.site-header{
  transition: padding .2s ease, background-color .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.site-header .header-inner{
  transition: min-height .2s ease;
}
.site-header .brand-text{
  transition: transform .2s ease, opacity .2s ease;
}
.site-header .custom-logo,
.site-header .logo-mark{
  transition: transform .2s ease;
}
.site-header.is-scrolled{
  padding: 2px 0;
  background: rgba(10, 14, 28, 0.78);
  border-bottom-color: rgba(255,255,255,0.10);
  box-shadow: 0 16px 40px rgba(0,0,0,.30);
  backdrop-filter: blur(14px);
}
.site-header.is-scrolled .header-inner{
  min-height: 54px;
}
.site-header.is-scrolled .custom-logo,
.site-header.is-scrolled .logo-mark{
  transform: scale(.92);
}
.site-header.is-scrolled .btn-primary{
  transform: translateY(-1px);
}


/* Equal height engineering process cards */
.process-timeline{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  align-items:stretch;
}

.process-step.card{
  height:100%;
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
  min-height:260px;
}

/* ensure titles align */
.process-step.card h3{
  min-height:48px;
}

/* ensure description area consistent */
.process-step.card p{
  flex-grow:1;
}



/* Process step icons (scan-friendly) */
.process-timeline .process-step.card h3{
  display:flex;
  align-items:center;
  gap:10px;
}
.process-timeline .process-step.card h3::before{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:34px;
  height:34px;
  border-radius:12px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow: 0 10px 30px rgba(0,0,0,.18);
  flex: 0 0 auto;
  font-size: 18px;
  line-height: 1;
}
.process-timeline .process-step.card:nth-child(1) h3::before{ content:"🔍"; }
.process-timeline .process-step.card:nth-child(2) h3::before{ content:"🏗️"; }
.process-timeline .process-step.card:nth-child(3) h3::before{ content:"⚙️"; }
.process-timeline .process-step.card:nth-child(4) h3::before{ content:"🧪"; }
.process-timeline .process-step.card:nth-child(5) h3::before{ content:"🚀"; }


/* --- Process timeline layout fix (no overlap, equal size) --- */
.process-timeline{
  width: 100%;
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 22px;
  align-items: stretch;
}

/* harden card box model so pseudo/glow never bleeds */
.process-step.card{
  margin: 0 !important;
  width: 100%;
  min-width: 0;
  overflow: hidden !important;
  border-radius: 22px;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  padding: 22px 22px 20px;
}

/* slightly tighter typography so 5 columns fits nicely */
.process-step.card h3{
  font-size: 1.35rem;
  line-height: 1.15;
  margin: 0 0 10px;
  min-height: 44px;
}
.process-step.card p{
  font-size: .92rem;
  line-height: 1.45;
}

/* keep the animated master line but ensure it stays behind cards */
.process-timeline::before{
  z-index: 0;
}
.process-step.card,
.process-step.card::before,
.process-step.card::after{
  z-index: 1;
}
.process-step.card::before{
  z-index: 2; /* node above the line */
}

/* Large desktop: keep 5 in one row */
@media (min-width: 1200px){
  .process-step.card{ min-height: 260px; }
}

/* Medium screens: allow horizontal scroll instead of overlap */
@media (max-width: 1199px) and (min-width: 961px){
  .process-timeline{
    grid-template-columns: repeat(5, minmax(240px, 1fr));
    overflow-x: auto;
    padding-bottom: 10px;
    scroll-snap-type: x mandatory;
  }
  .process-step.card{ scroll-snap-align: start; }
  .process-timeline::-webkit-scrollbar{ height: 10px; }
  .process-timeline::-webkit-scrollbar-thumb{ background: rgba(255,255,255,.14); border-radius: 999px; }
}

/* Mobile keeps existing stack */
@media (max-width: 960px){
  .process-timeline{ overflow: visible; }
}


/* Disable process step icons */
.process-timeline .process-step.card h3::before{
  content: none !important;
  display: none !important;
}
.process-timeline .process-step.card h3{
  display:block !important;
}


/* --- Premium FAQ accordion --- */
.faq-section .faq-grid{
  gap: 28px;
}
.faq-accordion{
  margin-top: 6px;
}

.faq-item{
  border: 1px solid rgba(255,255,255,0.10);
  background: rgba(255,255,255,0.03);
  border-radius: 18px;
  padding: 0;
  overflow: hidden;
  transition: border-color .25s ease, box-shadow .25s ease, transform .25s ease;
}
.faq-item + .faq-item{ margin-top: 14px; }

.faq-item:hover{
  border-color: rgba(108,99,255,.45);
  box-shadow: 0 18px 60px rgba(0,0,0,.30);
  transform: translateY(-1px);
}

.faq-item summary{
  cursor: pointer;
  list-style: none;
  padding: 18px 18px 18px 54px;
  position: relative;
  font-weight: 700;
  letter-spacing: .01em;
  outline: none;
}
.faq-item summary::-webkit-details-marker{ display:none; }

.faq-item summary::before{
  content:"";
  position:absolute;
  left: 18px;
  top: 50%;
  width: 10px;
  height: 10px;
  border-radius: 999px;
  transform: translateY(-50%);
  background: radial-gradient(circle at 30% 30%, #ffffff, var(--brand));
  box-shadow: 0 0 0 5px rgba(108,99,255,.14), 0 12px 30px rgba(108,99,255,.22);
}
.faq-item summary::after{
  content:"";
  position:absolute;
  right: 18px;
  top: 50%;
  width: 10px;
  height: 10px;
  border-right: 2px solid rgba(255,255,255,.75);
  border-bottom: 2px solid rgba(255,255,255,.75);
  transform: translateY(-60%) rotate(45deg);
  transition: transform .2s ease, opacity .2s ease;
  opacity: .9;
}

.faq-item[open] summary::after{
  transform: translateY(-40%) rotate(-135deg);
}

.faq-item p{
  margin: 0;
  padding: 0 18px 18px 54px;
  color: rgba(255,255,255,.78);
  line-height: 1.55;
  overflow: hidden;
  max-height: 0;
  opacity: 0;
  transform: translateY(-6px);
  transition: max-height .35s ease, opacity .25s ease, transform .25s ease;
}

.faq-item[open] p{
  max-height: 260px;
  opacity: 1;
  transform: translateY(0);
}

@media (prefers-reduced-motion: reduce){
  .faq-item, .faq-item p, .faq-item summary::after{ transition:none !important; animation:none !important; }
}
