*{box-sizing:border-box;margin:0;padding:0}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;background:#F8FAFC;color:#0F172A;line-height:1.5}
a{text-decoration:none;color:inherit}

/* NAV - logo 46px, links 16px */
.nav{background:#1B2E4B;padding:0 2rem;height:64px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100}
.nav-logo img{height:56px;object-fit:contain}
.nav-links{display:flex;align-items:center;gap:2rem}
.nav-links a{color:#CBD5E1;font-size:17px;transition:color 0.2s}
.nav-links a:hover,.nav-links a.active{color:#fff;font-weight:500}
.nav-btn{background:#2563EB;color:#fff;border:none;padding:9px 20px;border-radius:7px;font-size:13px;font-weight:500;cursor:pointer;transition:background 0.2s}
.nav-btn:hover{background:#1D4ED8}

/* HERO */
.hero-wrapper{position:relative;overflow:hidden;background:#1B2E4B}
.hero-video{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;opacity:0.18;z-index:0}
.hero-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#1B2E4B 0%,#0F1E30 50%,#162440 100%);z-index:0}
.hero{position:relative;z-index:1;padding:6rem 2rem 5rem;text-align:center}
.hero-eyebrow{color:#BFDBFE;font-size:12px;letter-spacing:2px;margin-bottom:1.25rem;text-transform:uppercase;font-weight:500}
.hero-h1{color:#fff;font-size:46px;font-weight:600;line-height:1.12;margin-bottom:1.25rem;max-width:750px;margin-left:auto;margin-right:auto}
.hero-h1 span{color:#93C5FD}
.hero-sub{color:#94A3B8;font-size:18px;max-width:620px;margin:0 auto 2.5rem;line-height:1.65}
.hero-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.trial-note{color:#64748B;font-size:12px;margin-top:12px}

/* PAGE HERO */
.page-hero{background:linear-gradient(160deg,#1B2E4B 0%,#162440 100%);padding:4rem 2rem 3.5rem;text-align:center}
.page-hero .hero-eyebrow{color:#BFDBFE;font-size:12px;letter-spacing:2px;text-transform:uppercase;font-weight:500;margin-bottom:1rem}
.page-hero h1{color:#fff;font-size:36px;font-weight:600;margin-bottom:0.85rem}
.page-hero p{color:#94A3B8;font-size:16px;max-width:560px;margin:0 auto}

/* BUTTONS */
.btn-primary{background:#2563EB;color:#fff;border:none;padding:14px 28px;border-radius:9px;font-size:15px;font-weight:500;cursor:pointer;display:inline-block;transition:background 0.2s}
.btn-primary:hover{background:#1D4ED8}
.btn-secondary{background:transparent;color:#E2E8F0;border:1.5px solid #334E6E;padding:14px 28px;border-radius:9px;font-size:15px;cursor:pointer;display:inline-block;transition:all 0.2s}
.btn-secondary:hover{border-color:#93C5FD;color:#fff}
.btn-outline{background:transparent;color:#2563EB;border:1.5px solid #2563EB;padding:11px 22px;border-radius:9px;font-size:14px;font-weight:500;cursor:pointer;display:inline-block;transition:all 0.2s}
.btn-outline:hover{background:#2563EB;color:#fff}

/* SECTIONS */
.section{padding:5rem 2rem}
.section-inner{max-width:1100px;margin:0 auto}
.section-label{font-size:11px;color:#2563EB;letter-spacing:2px;text-transform:uppercase;margin-bottom:0.6rem;font-weight:600}
.section-h2{font-size:30px;font-weight:600;margin-bottom:0.85rem;line-height:1.2}
.section-h2-lg{font-size:32px;font-weight:600;margin-bottom:0.85rem;line-height:1.2}
.section-sub{color:#475569;font-size:16px;max-width:560px;line-height:1.65;margin-bottom:3rem}

/* FEATURE CARDS - white bg so transparent PNGs render correctly */
.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:20px}
.feature-card{background:#fff;border:1px solid #E2E8F0;border-radius:14px;padding:1.75rem;transition:box-shadow 0.2s}
.feature-card:hover{box-shadow:0 4px 24px rgba(0,0,0,0.08)}
.feature-icon{width:168px;height:168px;border-radius:12px;background:#fff;display:flex;align-items:center;justify-content:center;margin-bottom:1.1rem}
.feature-icon img{width:126px;height:126px;object-fit:contain;background:#fff;border-radius:8px}
.feature-card h3{font-size:15px;font-weight:600;margin-bottom:7px;color:#0F172A}
.feature-card p{font-size:13px;color:#64748B;line-height:1.55}
.feature-tag{font-size:11px;color:#1D4ED8;background:#EFF6FF;padding:3px 9px;border-radius:5px;display:inline-block;margin-top:10px;font-weight:500}
.feature-tag-pro{font-size:11px;color:#6D28D9;background:#F5F3FF;padding:3px 9px;border-radius:5px;display:inline-block;margin-top:10px;font-weight:500}

/* HOW IT WORKS */
.how-section{background:#F1F5F9}
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:0}
.step{text-align:center;padding:2.5rem 2rem;position:relative}
.step-num{width:48px;height:48px;background:#1B2E4B;color:#93C5FD;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:600;margin:0 auto 1.1rem}
.step h3{font-size:17px;font-weight:600;margin-bottom:9px;color:#0F172A}
.step p{font-size:13px;color:#64748B;line-height:1.55}
.step-arrow{position:absolute;right:-14px;top:2.5rem;color:#CBD5E1;font-size:22px;z-index:1}

/* PRICING */
.pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-top:2.5rem}
.pricing-card{background:#fff;border:1px solid #E2E8F0;border-radius:14px;padding:2rem;position:relative}
.pricing-card.featured{border:2px solid #2563EB;box-shadow:0 8px 32px rgba(37,99,235,0.12)}
.popular-badge{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:#2563EB;color:#fff;font-size:11px;padding:4px 14px;border-radius:5px;white-space:nowrap;font-weight:500}
.tier-name{font-size:16px;font-weight:600;margin-bottom:5px}
.tier-desc{font-size:12px;color:#64748B;margin-bottom:1.5rem;line-height:1.5}
.tier-price{font-size:34px;font-weight:700;margin-bottom:4px;line-height:1}
.tier-price span{font-size:15px;color:#64748B;font-weight:400}
.tier-billing{font-size:12px;color:#94A3B8;margin-bottom:1.75rem}
.tier-features{list-style:none;margin-bottom:1.75rem}
.tier-features li{font-size:13px;color:#475569;padding:6px 0;border-bottom:1px solid #F1F5F9;display:flex;align-items:center;gap:9px;line-height:1.4}
.tier-features li:last-child{border-bottom:none}
.check{color:#10B981;font-size:15px;flex-shrink:0}
.cross{color:#CBD5E1;font-size:15px;flex-shrink:0}
.tier-btn{width:100%;padding:11px;border-radius:9px;font-size:14px;font-weight:500;cursor:pointer;border:none;transition:all 0.2s}
.tier-btn-primary{background:#2563EB;color:#fff}
.tier-btn-primary:hover{background:#1D4ED8}
.tier-btn-secondary{background:transparent;border:1.5px solid #E2E8F0;color:#0F172A}
.tier-btn-secondary:hover{border-color:#2563EB;color:#2563EB}

/* FAQ - collapsible using details/summary */
.faq-item{border-bottom:1px solid #F1F5F9}
.faq-item summary{font-size:15px;font-weight:600;padding:1.25rem 0;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;color:#0F172A;user-select:none}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:'+';font-size:22px;color:#2563EB;flex-shrink:0;margin-left:1rem;font-weight:300;line-height:1}
.faq-item[open] summary::after{content:'\2212'}
.faq-a{font-size:13px;color:#64748B;line-height:1.65;padding-bottom:1.25rem}
.faq-a a{color:#2563EB}

/* ACCOUNT/SUPPORT HUBS */
.hub-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px;margin-top:2.5rem}
.hub-card{background:#fff;border:1px solid #E2E8F0;border-radius:14px;padding:2rem;text-align:center;transition:box-shadow 0.2s}
.hub-card:hover{box-shadow:0 4px 24px rgba(0,0,0,0.08)}
.hub-card h3{font-size:17px;font-weight:600;margin-bottom:8px}
.hub-card p{font-size:13px;color:#64748B;line-height:1.55;margin-bottom:1.5rem}
.hub-icon{width:56px;height:56px;border-radius:14px;background:#EFF6FF;display:flex;align-items:center;justify-content:center;margin:0 auto 1.1rem;font-size:24px}

/* LEGAL */
.legal-content{max-width:720px;margin:0 auto;padding:4rem 2rem}
.legal-content h1{font-size:28px;font-weight:600;margin-bottom:0.5rem}
.legal-content .date{font-size:13px;color:#94A3B8;margin-bottom:2.5rem}
.legal-content h2{font-size:17px;font-weight:600;margin:2rem 0 0.75rem}
.legal-content p{font-size:14px;color:#475569;line-height:1.75;margin-bottom:1rem}
.legal-content ul{font-size:14px;color:#475569;line-height:1.75;margin-bottom:1rem;padding-left:1.5rem}
.legal-content li{margin-bottom:0.4rem}
.legal-content a{color:#2563EB}

/* DOWNLOAD */
.sysreq-table{width:100%;border-collapse:collapse;margin:1.5rem 0}
.sysreq-table th{background:#1B2E4B;color:#fff;padding:10px 14px;text-align:left;font-size:13px;font-weight:500}
.sysreq-table td{padding:10px 14px;font-size:13px;color:#475569;border-bottom:1px solid #F1F5F9}
.sysreq-table tr:nth-child(even) td{background:#F8FAFC}
.download-box{background:#1B2E4B;border-radius:16px;padding:2.5rem;color:#fff;text-align:center;margin-bottom:2.5rem}
.download-box h2{font-size:22px;font-weight:600;margin-bottom:0.5rem}
.download-box p{color:#94A3B8;font-size:14px;margin-bottom:1.75rem}
.version-badge{display:inline-block;background:#142540;color:#93C5FD;font-size:12px;padding:4px 12px;border-radius:5px;margin-bottom:1rem;font-weight:500}

/* CTA BANNER */
.cta-banner{background:linear-gradient(160deg,#1B2E4B 0%,#162440 100%);padding:5rem 2rem;text-align:center}
.cta-banner h2{color:#fff;font-size:30px;font-weight:600;margin-bottom:0.85rem}
.cta-banner p{color:#94A3B8;font-size:16px;margin-bottom:2.5rem}

/* FOOTER - full white text */
.footer{background:#0D1B2E;padding:3.5rem 2rem 2rem}
.footer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:2.5rem;max-width:1100px;margin:0 auto 2.5rem}
.footer-brand p{color:#fff;font-size:12px;line-height:1.65;margin-top:8px}
.footer-col h4{color:#64748B;font-size:10px;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:14px;font-weight:600}
.footer-col a{display:block;color:#fff;font-size:13px;margin-bottom:9px;transition:color 0.2s}
.footer-col a:hover{color:#93C5FD}
.footer-bottom{border-top:1px solid #1E3A5F;padding-top:2rem;max-width:1100px;margin:0 auto}
.footer-bottom p{color:#fff;font-size:11px;line-height:1.7}

@media(max-width:768px){
  .hero-h1{font-size:28px}
  .nav-links{display:none}
  .page-hero h1{font-size:26px}
  .section{padding:3.5rem 1.5rem}
  .step-arrow{display:none}
}
