@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800;900&display=swap');

* { box-sizing: border-box; margin: 0; padding: 0; }
body { font-family: 'Outfit', sans-serif; background: #fff; color: #1a1a2e; }
a { color: inherit; text-decoration: none; }
::selection { background: #ffe066; }
.container { max-width: 1200px; margin: 0 auto; padding: 0 32px; }

/* NAV */
nav { position: fixed; top: 0; width: 100%; z-index: 90; height: 68px; background: rgba(255,255,255,.88); backdrop-filter: blur(20px); border-bottom: 1px solid #f0f0f0; display: flex; align-items: center; justify-content: center; }
.nav-inner { width: 100%; max-width: 1200px; padding: 0 32px; display: flex; align-items: center; justify-content: space-between; }
.brand { font-size: 28px; font-weight: 900; letter-spacing: -1.5px; }
.brand i { font-style: normal; color: #e8a800; }
.nav-links { display: flex; gap: 24px; align-items: center; }
.nav-links a { font-size: 14px; color: #666; font-weight: 500; transition: color .2s; }
.nav-links a:hover { color: #1a1a2e; }
.btn-login { font-weight: 600; color: #1a1a2e !important; }
.btn-try { background: #1a1a2e; color: #fff !important; padding: 10px 24px; border-radius: 99px; font-size: 13px; font-weight: 700; transition: all .2s; }
.btn-try:hover { background: #333; }
/* Dropdown */
.nav-dd { position: relative; }
.nav-dd > a::after { content: ' ▾'; font-size: 10px; }
.nav-dd .dd-menu { display: none; position: absolute; top: 100%; left: -16px; background: #fff; border: 1px solid #eee; border-radius: 12px; padding: 12px 0; min-width: 200px; box-shadow: 0 12px 32px rgba(0,0,0,.08); }
.nav-dd:hover .dd-menu { display: block; }
.dd-menu a { display: block; padding: 10px 20px; font-size: 13px; color: #555; font-weight: 500; transition: background .15s; }
.dd-menu a:hover { background: #f8f8f8; color: #1a1a2e; }
/* Mobile */
.hamburger { display: none; background: none; border: none; font-size: 26px; cursor: pointer; color: #1a1a2e; }
.mob-menu { display: none; position: fixed; top: 68px; left: 0; right: 0; background: #fff; padding: 24px 32px; flex-direction: column; gap: 12px; border-bottom: 1px solid #eee; z-index: 89; box-shadow: 0 8px 20px rgba(0,0,0,.05); }
.mob-menu.open { display: flex; }
.mob-menu a { font-size: 15px; font-weight: 500; padding: 10px 0; color: #333; border-bottom: 1px solid #f5f5f5; }

/* SECTION HELPERS */
.sec-head { text-align: center; margin-bottom: 52px; }
.badge-sm { display: inline-block; padding: 6px 16px; border-radius: 99px; font-size: 12px; font-weight: 700; letter-spacing: .5px; margin-bottom: 16px; }
.badge-blue { background: #eff6ff; color: #2563eb; }
.badge-green { background: #f0fdf4; color: #16a34a; }
.badge-amber { background: #fffbeb; color: #d97706; }
.badge-pink { background: #fdf2f8; color: #db2777; }
.badge-purple { background: #f5f3ff; color: #7c3aed; }
.sec-head h2 { font-size: clamp(28px, 3.5vw, 42px); font-weight: 900; letter-spacing: -2px; line-height: 1.12; }
.sec-head p { font-size: 16px; color: #666; margin-top: 12px; max-width: 560px; margin-left: auto; margin-right: auto; }

/* BUTTONS */
.btn { padding: 14px 32px; border-radius: 99px; font-size: 15px; font-weight: 700; border: none; cursor: pointer; font-family: inherit; transition: all .3s; display: inline-block; text-align: center; }
.btn-dark { background: #1a1a2e; color: #fff; }
.btn-dark:hover { background: #333; transform: translateY(-2px); box-shadow: 0 8px 24px rgba(0,0,0,.1); }
.btn-white { background: #fff; color: #1a1a2e; }
.btn-white:hover { background: #f5f5f5; }
.btn-outline { background: none; border: 2px solid #e0e0e0; color: #1a1a2e; }
.btn-outline:hover { border-color: #1a1a2e; }
.btn-gold { background: linear-gradient(135deg, #f5c842, #e8a800); color: #111; }
.btn-gold:hover { box-shadow: 0 8px 24px rgba(232,168,0,.2); }

/* PAGE HERO (sub pages) */
.page-hero { padding: 140px 32px 80px; text-align: center; background: linear-gradient(180deg, #f8f8f8, #fff); }
.page-hero h1 { font-size: clamp(32px, 4.5vw, 52px); font-weight: 900; letter-spacing: -2.5px; line-height: 1.08; margin-bottom: 16px; }
.page-hero h1 em { font-style: normal; background: linear-gradient(135deg, #e8a800, #f5c842); -webkit-background-clip: text; -webkit-text-fill-color: transparent; }
.page-hero p { font-size: 17px; color: #666; max-width: 560px; margin: 0 auto 32px; line-height: 1.7; }

/* FEATURE ROWS (zigzag) */
.feat-row { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; padding: 80px 0; border-bottom: 1px solid #f0f0f0; }
.feat-row:last-child { border-bottom: none; }
.feat-row.rev { direction: rtl; }
.feat-row.rev > * { direction: ltr; }
.feat-row h3 { font-size: 28px; font-weight: 800; letter-spacing: -1px; margin-bottom: 12px; line-height: 1.15; }
.feat-row p { font-size: 15px; color: #666; line-height: 1.7; margin-bottom: 20px; }
.feat-row ul { list-style: none; }
.feat-row ul li { padding: 8px 0; font-size: 14px; color: #555; display: flex; align-items: center; gap: 10px; }
.feat-row ul li::before { content: '✓'; color: #16a34a; font-weight: 700; }

/* VISUAL MOCKUPS */
.vis-card { background: #fafafa; border: 1px solid #e8e8e8; border-radius: 16px; padding: 24px; }

/* CTA BANNER */
.cta-banner { padding: 100px 32px; text-align: center; background: linear-gradient(135deg, #1a1a2e 0%, #2d1b69 100%); color: #fff; }
.cta-banner h2 { font-size: clamp(28px, 4vw, 44px); font-weight: 900; letter-spacing: -2px; margin-bottom: 16px; }
.cta-banner p { color: rgba(255,255,255,.6); font-size: 16px; margin-bottom: 32px; }
.cta-banner .btns { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }
.trust-row { display: flex; gap: 40px; justify-content: center; margin-top: 40px; flex-wrap: wrap; }
.trust-item { font-size: 13px; color: rgba(255,255,255,.5); display: flex; align-items: center; gap: 8px; }
.trust-item strong { color: rgba(255,255,255,.8); }

/* MEGA FOOTER */
.mega-footer { background: #fafafa; border-top: 1px solid #eee; padding: 60px 0 0; }
.footer-grid { display: grid; grid-template-columns: 2fr repeat(4, 1fr); gap: 32px; margin-bottom: 48px; }
.footer-brand .brand { font-size: 22px; margin-bottom: 12px; }
.footer-brand p { font-size: 13px; color: #888; line-height: 1.6; max-width: 260px; }
.footer-socials { display: flex; gap: 12px; margin-top: 16px; }
.footer-socials a { width: 32px; height: 32px; border-radius: 8px; background: #eee; display: grid; place-items: center; font-size: 14px; transition: background .2s; }
.footer-socials a:hover { background: #ddd; }
.footer-col h4 { font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; color: #999; margin-bottom: 16px; }
.footer-col a { display: block; font-size: 13px; color: #666; padding: 5px 0; transition: color .2s; }
.footer-col a:hover { color: #1a1a2e; }
.footer-bottom { border-top: 1px solid #eee; padding: 20px 0; text-align: center; font-size: 12px; color: #999; }
.footer-bottom a { color: #e8a800; font-weight: 600; }

/* SCROLL REVEAL */
.rv { opacity: 0; transform: translateY(28px); transition: all .7s ease; }
.rv.vis { opacity: 1; transform: none; }

/* RESPONSIVE */
@media (max-width: 900px) {
  .nav-links { display: none; }
  .hamburger { display: block; }
  .feat-row, .feat-row.rev { grid-template-columns: 1fr; direction: ltr; gap: 32px; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .page-hero { padding: 120px 20px 60px; }
}
@media (max-width: 600px) {
  .footer-grid { grid-template-columns: 1fr; }
  .trust-row { flex-direction: column; align-items: center; }
}
