/* Mobile-first, responsive, no horizontal scroll, accessible UI */

/* ---------------------------
   Modernized theme & tokens
   --------------------------- */
:root{
  --bg-900:hsl(219, 70%, 8%); --bg-800:#081424;
  --text:#F6FBFF; --muted:#9AA6B9;
  --accent-a:#7C5CFF; --accent-b:#00D4FF;
  --accent-grad:linear-gradient(90deg,var(--accent-a),var(--accent-b));
  --max-w:1200px; --pad:18px; --radius:14px;
  --shadow-soft:0 8px 30px rgba(2,6,23,0.45);
  --shadow-strong:0 20px 60px rgba(2,6,23,0.65);
}

/* reset */
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;overflow-x:hidden}
body{
  font-family:Inter,system-ui,-apple-system,"Segoe UI",Roboto,Arial;
  color:var(--text); font-size:16px; line-height:1.45;
  background:
    radial-gradient(circle 600px at 15% 20%, rgba(124,92,255,0.15), transparent 25%),
    radial-gradient(circle 700px at 85% 15%, rgba(0,212,255,0.12), transparent 28%),
    radial-gradient(circle 500px at 50% 85%, rgba(124,92,255,0.08), transparent 30%),
    linear-gradient(180deg,var(--bg-900),var(--bg-800));
  background-attachment:fixed;
  -webkit-font-smoothing:antialiased;
}

/* container */
.container{max-width:var(--max-w); margin:0 auto; padding:0 clamp(14px,2.2vw,var(--pad))}

/* header */
.site-header{position:sticky;top:14px;z-index:80}
.header-inner{display:flex;align-items:center;gap:12px;padding:12px;border-radius:12px;background:linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.01));border:1px solid rgba(255,255,255,0.05);backdrop-filter:blur(6px)}
.logo{font-weight:800;font-size:1.05rem;background:linear-gradient(90deg,rgba(255,255,255,0.98),rgba(255,255,255,0.88));-webkit-background-clip:text;background-clip:text;color:transparent}

/* nav */
.nav-desktop{margin-left:auto;display:none;gap:10px}
.nav-link{color:var(--muted);text-decoration:none;padding:8px;border-radius:8px;font-weight:700}
.nav-link:hover{color:var(--text);background:rgba(255,255,255,0.02)}
.nav-toggle{margin-left:auto;background:transparent;border:1px solid rgba(255,255,255,0.04);padding:8px;border-radius:8px;color:var(--text);cursor:pointer}
/* ensure hamburger is visible on light header backgrounds */
.header-inner .nav-toggle{color:#ffffff;background:linear-gradient(90deg,var(--accent-a),var(--accent-b));border:0;padding:8px;border-radius:8px}
.header-inner .nav-toggle:focus{outline:2px solid rgba(124,92,255,0.18)}

/* simple mobile menu (visible overlay + blue panel) */
.nav-mobile{display:none;position:fixed;inset:0;z-index:999;background:hsl(0, 0%, 100%);align-items:flex-start}
body.nav-open{overflow:hidden}
body.nav-open .nav-mobile{display:flex}
.nav-mobile-inner{width:100%;max-width:420px;height:100vh;margin-left:auto;padding:20px;background:hsl(219, 70%, 8%);color:#061022;overflow:auto;box-shadow:0 12px 40px rgba(2,6,23,0.45);display:flex;flex-direction:column;gap:14px;border-left:6px solid rgba(124,92,255,0.12)}
.nav-mobile .nav-close{align-self:flex-end;background:var(--accent-grad);color:#ffffff;border:0;padding:10px 12px;border-radius:8px;font-weight:800}
.nav-mobile .nav-link{display:block;padding:12px 0;color:#ffffff;text-decoration:none;font-weight:700}
.nav-mobile .nav-link:hover{background:rgba(124,92,255,0.06);border-radius:8px;padding-left:8px}
.nav-mobile .nav-note{color:var(--muted);font-size:0.95rem}

/* small screen: show nav-toggle */
@media (min-width:700px){
  .nav-toggle{display:none}
}



/* mobile menu */
.mobile-menu{display:flex;flex-direction:column;gap:10px}
.mobile-menu .nav-link{padding:12px; text-align:center; background:rgba(255,255,255,0.1); border-radius:8px}
.mobile-menu .nav-link:hover{background:rgba(255,255,255,0.2)}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:10px;padding:10px 14px;border-radius:12px;font-weight:700;text-decoration:none;border:0;cursor:pointer; animation: buttonAnimation 0.6s ease;}
.btn-primary{background:var(--accent-grad);color:#061022;box-shadow:0 8px 30px rgba(124,92,255,0.18)}
.btn-ghost{background:transparent;border:1px solid rgba(255,255,255,0.04);color:var(--text)}
.btn-large{padding:14px 26px;border-radius:16px;font-size:1.05rem}
/* larger hero variant for stronger CTA */
.hero .btn-large{padding:16px 34px;font-size:1.15rem;border-radius:18px}
@media (min-width:900px){
  .hero .btn-large{padding:38px 40px;font-size:1.6rem}
}

/* reveal animation for buttons */
@keyframes buttonAnimation {
  0% { transform: scale(1); }
  100% { transform: scale(1.05); }
}
.btn[data-animate]{transform:scale(0.8);opacity:0;transition:transform .6s ease, opacity .6s ease}
.btn[data-animate].reveal{transform:scale(1);opacity:1}

/* hero */
.section{padding-block:clamp(24px,4vw,56px)}
.hero{position:relative;min-height:clamp(56vh,70vh,82vh);display:flex;align-items:center;justify-content:center;padding:36px 0;overflow:hidden}
.hero-inner{position:relative;z-index:3;display:flex;flex-direction:column;gap:14px;text-align:left;max-width:980px;padding-inline:6px}
.hero-title{font-size:clamp(1.8rem,5.4vw,3.2rem);font-weight:900;color:#fff;margin:0;line-height:1.02}
.subtitle{color:var(--muted);font-weight:600;max-width:820px}
.hero-cta{display:flex;gap:12px;justify-content:flex-start;flex-wrap:wrap}
.small-note{color:var(--muted);font-size:0.9rem}

/* features */
.feature-grid{display:grid;grid-template-columns:1fr;gap:16px}
.feature-card{display:flex;flex-direction:column;gap:10px;padding:18px;border-radius:20px;background:linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.01));border:1px solid rgba(255,255,255,0.04);backdrop-filter:blur(8px);box-shadow:var(--shadow-soft);transition:transform .22s ease,box-shadow .22s ease;min-height:160px}
.feature-card--accent{background:linear-gradient(180deg, rgba(124,92,255,0.06), rgba(255,255,255,0.01));border:1px solid rgba(124,92,255,0.14)}
.feature-icon{width:56px;height:56px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;background:rgba(255,255,255,0.02);color:var(--accent-b)}
.feature-title{font-size:1.05rem;font-weight:800;color:var(--text);margin:0}
.feature-desc{color:var(--muted);font-size:0.97rem;margin:0;font-weight:600}
.feature-meta{margin-top:auto;font-size:0.82rem;color:rgba(255,255,255,0.75);font-weight:700}
.feature-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-strong)}

/* how-it-works section */
.how-it-works{color:var(--text);padding-block:clamp(36px,6vw,64px);border-radius:10px}
.how-it-works .how-intro{color:rgba(255,255,255,0.9);margin-bottom:18px}
.how-grid{display:flex;gap:22px;align-items:center;justify-content:space-between;flex-wrap:wrap}
.how-step{flex:1;min-width:220px;max-width:360px;text-align:center;padding:18px}
.how-icon-box{width:160px;height:160px;margin:0 auto 14px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.02));border:1px solid rgba(255,255,255,0.04);box-shadow:0 8px 30px rgba(2,6,23,0.04)}
.how-step h3{margin:0 0 8px 0;font-size:1.05rem;font-weight:800}
.how-step p{margin:0;color:rgba(255,255,255,0.92)}
.how-arrow{width:44px;height:44px;display:flex;align-items:center;justify-content:center;font-size:28px;color:rgba(255,255,255,0.7);flex:0 0 44px}

@media (max-width:900px){
  .how-grid{flex-direction:column;gap:16px}
  .how-arrow{display:none}
  .how-icon-box{width:140px;height:140px}
}

/* reveal animation */
[data-animate]{opacity:0;transform:translateY(16px);transition:opacity .6s ease, transform .6s cubic-bezier(.2,.9,.2,1)}
.reveal{opacity:1;transform:none}
.container-contact{
  max-width:var(--max-w);
  margin:0 auto;
  padding:18px clamp(14px,2.2vw,var(--pad));
  border:1px solid rgba(213, 217, 224, 0.85);
  background:linear-gradient(180deg, rgba(255,255,255,0.01), rgba(255,255,255,0.00));
  box-shadow:0 10px 30px rgba(2,6,23,0.04);
  border-radius:20px;
  z-index:10;
}
.section.contact{padding-block:clamp(20px,3.6vw,44px)}
/* about / contact */
.about .lead{color:var(--muted);font-weight:600}
.card.info{background:linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.01));border-radius:14px;padding:16px;margin-top:12px;border:1px solid rgba(255,255,255,0.03)}
.contact-form{max-width:920px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.form-row{display:grid;grid-template-columns:1fr;gap:12px}
.field{display:flex;flex-direction:column;color:var(--muted);font-weight:700}
.label-text{font-size:0.9rem;margin-bottom:6px}
.field input,.field textarea{padding:12px;border-radius:12px;background:rgba(255,255,255,0.02);border:1px solid rgba(255,255,255,0.03);color:var(--text);font-size:0.95rem}
.form-actions{display:flex;gap:12px;align-items:center}

/* footer */
.site-footer{border-top:1px solid rgba(255,255,255,0.03);color:var(--muted);padding:20px 0;background:linear-gradient(180deg, rgba(255,255,255,0.005), transparent)}
.footer-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.brand{font-weight:700;color:var(--text)}
.footer-nav{display:flex;gap:12px;flex-wrap:wrap}
.footer-legal{margin-top:10px;color:var(--muted);font-size:0.9rem;line-height:1.3}
.footer-actions{display:flex;align-items:center;gap:12px}
.footer-social{display:flex;gap:8px;align-items:center}
.social-btn{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:10px;background:rgba(255,255,255,0.02);color:var(--text);text-decoration:none;border:1px solid rgba(255,255,255,0.03);transition:transform .12s ease,background .12s ease}
.social-btn svg{width:20px;height:20px;display:block;fill:currentColor}
.social-btn:hover{transform:translateY(-3px);background:var(--accent-grad);color:#061022}
.social-btn:focus{outline:2px solid rgba(124,92,255,0.18);outline-offset:2px}

/* small screens */
@media (min-width:700px){
  .nav-desktop{display:flex}
  .nav-toggle{display:none}
  .feature-grid{grid-template-columns:repeat(2,1fr)}
  .form-row{grid-template-columns:repeat(2,1fr)}
  .hero-title{font-size:clamp(2.6rem,5.6vw,3.8rem)}
}

/* wide */
@media (min-width:1100px){
  .feature-grid{grid-template-columns:repeat(3,1fr)}
  .container{max-width:1200px}
}

/* accessibility / reduce motion */
@media (max-width:900px),(prefers-reduced-motion:reduce){
  .parallax,.parallax__layer{display:none}
  *{transition:none!important;animation:none!important}
}

/* blog */
.post-meta{color:var(--muted);margin-bottom:12px;font-size:0.95rem}
.post-list{display:grid;grid-template-columns:1fr;gap:24px}
.post-list article{background:linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.01));border:1px solid rgba(255,255,255,0.04);padding:22px;border-radius:12px;box-shadow:var(--shadow-soft);transition:transform .18s ease,box-shadow .18s ease}
.post-list article:hover{transform:translateY(-6px);box-shadow:var(--shadow-strong)}
.post-list h2{margin:0 0 10px 0;font-size:1.25rem}
.post-excerpt{color:var(--muted);margin-top:8px;margin-bottom:0}
.post-content{max-width:780px}
.post-content p{margin:0 0 2rem 0;line-height:1.85;color:var(--text);font-size:1.05rem}
.post-content p + p{margin-top:1rem}
.post-tags{margin-top:10px;display:flex;gap:8px;flex-wrap:wrap}
.post-tags .tag{background:rgba(255,255,255,0.03);padding:6px 10px;border-radius:999px;font-size:0.85rem;color:var(--muted)}

/* post article card */
.post-article{background:transparent;padding:clamp(12px,3vw,28px);border-radius:18px;max-width:1000px;margin:22px auto}
.post-article .post-meta{margin-bottom:14px;color:var(--muted)}
.post-article h1{font-size:clamp(1.8rem,4.6vw,2.6rem);margin:0 0 8px 0;line-height:1.06}
.post-article h2{font-size:clamp(1.15rem,3.2vw,1.4rem);margin-top:1.4rem;margin-bottom:0.6rem}
.post-article p{margin:0 0 1.4rem 0;line-height:1.85;font-size:1.04rem;color:var(--text)}
.post-article ul, .post-article ol{margin:0 0 1.2rem 1.35rem}
.post-article details{margin-bottom:1rem}

/* text panel: rounded card for content blocks */
.text-panel{background:linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.01));border:1px solid rgba(124,92,255,0.08);padding:18px;border-radius:14px;box-shadow:0 10px 30px rgba(2,6,23,0.05);margin:18px 0}
.text-panel p{margin:0 0 1rem 0}

/* callouts */
.callout{background:linear-gradient(90deg,var(--accent-a),var(--accent-b));color:#061022;padding:12px 14px;border-radius:12px;font-weight:700;margin:8px 0}

/* blockquote */
.post-article blockquote{background:rgba(124,92,255,0.03);border-left:4px solid rgba(124,92,255,0.18);padding:12px 16px;border-radius:10px;margin:0 0 1.6rem 0;color:var(--muted)}

/* FAQ styles: modern panels with border and chevron */
.faq .faq-intro{margin-bottom:14px;color:var(--muted)}
.faq details{background:linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.01));border:1px solid rgba(255,255,255,0.04);padding:14px;border-radius:12px;margin:12px 0;box-shadow:0 8px 30px rgba(2,6,23,0.04)}
.faq summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:12px;font-weight:800;color:var(--text);padding:0}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:'▾';color:var(--muted);font-size:1.05rem;transition:transform .18s ease}
.faq details[open] summary::after{transform:rotate(180deg)}
.faq p{margin:0;color:var(--muted);padding-top:8px;line-height:1.6}
@media (prefers-reduced-motion: no-preference){ .faq details{transition:box-shadow .18s ease;} .faq details[open]{box-shadow:var(--shadow-soft)} }

@media (min-width:900px){
  .post-list{grid-template-columns:repeat(2,1fr)}
}

/* final safety */
html,body{max-width:100%;overflow-x:hidden}