:root { --bg: #050712; --bg-elevated: #0c0f1f; --bg-alt: #0f1424; --border-subtle: rgba(255, 255, 255, 0.04); --text: #f7f7ff; --muted: #a0a4c0; --accent: #5b8dff; --accent-soft: rgba(91, 141, 255, 0.16); --accent-strong: #99c2ff; --danger: #ff6b7a; --radius-lg: 18px; --radius-md: 12px; --shadow-soft: 0 26px 80px rgba(0, 0, 0, 0.7); --font-sans: system-ui, -apple-system, BlinkMacSystemFont, "SF Pro Text", "Inter", "Segoe UI", sans-serif; } *, *::before, *::after { box-sizing: border-box; } html, body { margin: 0; padding: 0; } body { min-height: 100vh; background: radial-gradient(circle at top, #202446 0, var(--bg) 55%); color: var(--text); font-family: var(--font-sans); -webkit-font-smoothing: antialiased; overflow-wrap: break-word; } a { color: var(--accent-strong); text-decoration: none; } a:hover { text-decoration: underline; } .skip-link { position: absolute; top: 0.75rem; left: 0.75rem; padding: 0.5rem 0.9rem; border-radius: 999px; background: #0f172a; color: #e5e7eb; text-decoration: none; border: 1px solid rgba(148, 163, 184, 0.8); transform: translateY(-150%); transition: transform 0.12s ease; z-index: 50; font-size: 0.85rem; } .skip-link:focus { transform: translateY(0); outline: 2px solid var(--accent-strong); outline-offset: 2px; } .container { width: 100%; max-width: 1120px; margin: 0 auto; padding: 0 20px; } .container--wide { max-width: 1320px; padding: 0 24px; } .site-header { position: sticky; top: 0; z-index: 20; backdrop-filter: blur(18px); background: linear-gradient(to bottom, rgba(3, 6, 24, 0.92), rgba(3, 6, 24, 0.88)); border-bottom: 1px solid var(--border-subtle); } .header-inner { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 14px 0; flex-wrap: wrap; } .header-inner .logo, .header-inner .nav, .header-inner .btn-primary { flex-shrink: 0; } .logo { display: inline-flex; align-items: center; gap: 10px; color: var(--text); text-decoration: none; white-space: nowrap; } .logo-image { display: block; width: 32px; height: 32px; border-radius: 10px; } .logo-image.small { width: 24px; height: 24px; } .logo-mark { display: inline-flex; align-items: center; justify-content: center; width: 32px; height: 32px; border-radius: 10px; background: radial-gradient(circle at 0 0, #9e9cff, #5b8dff); color: #050712; font-weight: 700; font-size: 18px; letter-spacing: 0.03em; box-shadow: 0 10px 40px rgba(0, 0, 0, 0.7); } .logo-mark.small { width: 24px; height: 24px; font-size: 14px; } .logo-text { font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; font-size: 14px; white-space: nowrap; } .nav { display: flex; align-items: center; gap: 10px; font-size: 14px; } .nav a { display: inline-flex; align-items: center; min-height: 48px; color: var(--muted); padding: 10px 12px; border-radius: 999px; text-decoration: none; white-space: nowrap; transition: background 0.15s ease, color 0.15s ease, transform 0.1s ease; } .nav a:hover { color: var(--text); background: rgba(255, 255, 255, 0.06); transform: translateY(-1px); } .nav a.active, [aria-current="page"] { color: var(--text); background: var(--accent-soft); } .btn { display: inline-flex; align-items: center; justify-content: center; min-height: 48px; padding: 10px 16px; border-radius: 999px; border: 1px solid transparent; font-size: 14px; font-weight: 500; cursor: pointer; text-decoration: none; white-space: nowrap; transition: background 0.15s ease, color 0.15s ease, transform 0.1s ease, box-shadow 0.15s ease, border-color 0.15s ease; } .btn-large { min-height: 52px; padding: 12px 22px; font-size: 15px; } .btn-primary { background: linear-gradient(135deg, var(--accent), #7e9cff); color: #050712; box-shadow: 0 14px 40px rgba(37, 99, 235, 0.6); } .btn-primary:hover { transform: translateY(-1px); box-shadow: 0 20px 60px rgba(37, 99, 235, 0.7); text-decoration: none; } .btn-ghost { border-color: rgba(255, 255, 255, 0.18); background: rgba(5, 7, 18, 0.6); color: var(--text); } .btn-ghost:hover { background: rgba(15, 23, 42, 0.9); } .hero { padding: 48px 0 32px; } .hero-inner { display: grid; grid-template-columns: minmax(0, 1.5fr) minmax(0, 1.2fr); gap: 32px; align-items: center; } .hero-copy h1 { font-size: clamp(32px, 5vw, 42px); line-height: 1.1; margin: 0 0 16px; } .hero-copy p { margin: 0 0 24px; color: var(--muted); font-size: 15px; max-width: 560px; } .hero-actions { display: flex; flex-wrap: wrap; gap: 12px; margin-bottom: 14px; } .hero-note { font-size: 13px; color: var(--muted); } .hero-panel { display: flex; justify-content: flex-end; } .card { background: radial-gradient(circle at top left, rgba(148, 163, 253, 0.18), transparent 55%), var(--bg-elevated); border-radius: var(--radius-lg); border: 1px solid var(--border-subtle); padding: 22px 22px 20px; box-shadow: var(--shadow-soft); } .highlight-card { width: 100%; max-width: 420px; } .card h2, .card h3 { margin-top: 0; margin-bottom: 12px; } .card p { margin-top: 0; margin-bottom: 10px; color: var(--muted); } .partner-header { display: flex; align-items: center; gap: 16px; margin-bottom: 10px; } .partner-logo { width: 56px; height: 56px; object-fit: contain; border-radius: 12px; background: #000; } .partner-tagline { margin: 2px 0 0; font-size: 13px; color: var(--muted); } .steps-list { padding-left: 20px; margin: 0 0 16px; color: var(--muted); font-size: 14px; } .stat-row { display: flex; flex-wrap: wrap; gap: 18px; border-top: 1px solid var(--border-subtle); padding-top: 12px; margin-top: 8px; } .stat-label { display: block; font-size: 11px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--muted); margin-bottom: 4px; } .stat-value { font-size: 14px; } .status-live { color: #4ade80; } .section { padding: 32px 0; } .section-alt { background: radial-gradient(circle at top, #111827 0, #020617 70%); border-top: 1px solid var(--border-subtle); border-bottom: 1px solid var(--border-subtle); } .grid-3 { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 20px; } .split { display: grid; grid-template-columns: minmax(0, 1.4fr) minmax(0, 1.1fr); gap: 28px; align-items: flex-start; } .partner-cards { display: flex; flex-direction: column; gap: 24px; margin-top: 24px; } .partner-card { display: flex; gap: 24px; align-items: stretch; padding: 0; } .partner-card-logo-wrap { flex-shrink: 0; width: 160px; min-width: 160px; display: flex; align-items: center; justify-content: center; padding: 28px; background: rgba(0, 0, 0, 0.2); border-radius: var(--radius-lg) 0 0 var(--radius-lg); } .partner-card-logo { width: 100px; height: auto; max-height: 100%; object-fit: contain; } .partner-card-content { padding: 24px 24px 24px 0; flex: 1; min-width: 0; } .partner-card-content h3 { margin-top: 0; margin-bottom: 12px; } .partner-card-content .btn { margin-top: 16px; } .partners-intro { margin-bottom: 0; } .page-hero { padding: 40px 0 20px; } .page-hero h1 { font-size: clamp(26px, 4vw, 34px); margin-bottom: 12px; } .page-hero p { margin: 0; color: var(--muted); } .narrow { max-width: 720px; } .list-check, .list-bullet { margin: 0; padding-left: 18px; color: var(--muted); font-size: 14px; } .list-check li::marker { content: "✓ "; color: #4ade80; } .list-bullet li::marker { color: var(--accent-strong); } .link-arrow { display: inline-flex; align-items: center; gap: 6px; font-size: 14px; } .link-arrow::after { content: "↗"; font-size: 13px; } .site-footer { border-top: 1px solid var(--border-subtle); padding: 20px 0 26px; background: radial-gradient(circle at bottom, #111827 0, #020617 65%); margin-top: 30px; } .footer-inner { display: flex; align-items: center; justify-content: space-between; gap: 18px; flex-wrap: wrap; } .footer-brand { display: inline-flex; align-items: center; gap: 8px; white-space: nowrap; } .footer-brand .logo-text { font-size: 13px; } .footer-nav { display: flex; gap: 10px; font-size: 13px; flex-wrap: wrap; } .footer-nav a { display: inline-flex; align-items: center; min-height: 48px; padding: 10px 8px; color: var(--muted); white-space: nowrap; } .footer-note { flex-basis: 100%; margin: 8px 0 0; font-size: 12px; color: var(--muted); } .legal-copy h2 { margin-top: 22px; margin-bottom: 10px; } .legal-copy p { color: var(--muted); font-size: 14px; } #landing-page-hub .hub-section-intro { max-width: 42rem; color: var(--muted); font-size: 15px; line-height: 1.6; margin: 0 0 28px 0; } .hub-groups { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 20px; margin-top: 0; } .hub-group-card .hub-group-intro { font-size: 14px; color: var(--muted); line-height: 1.5; margin: 0 0 14px 0; } .hub-group-card h3 { margin: 0 0 8px 0; } main .breadcrumb { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; list-style: none; padding: 0; margin: 0 0 28px 0; font-size: 13px; color: var(--muted); } main .breadcrumb a { color: var(--muted); } main .breadcrumb a:hover { color: var(--text); } .tutor-landing-page { padding-bottom: 48px; } .landing-hero { padding: 36px 0 44px; } .landing-hero-inner { max-width: 800px; } .landing-eyebrow { font-size: 13px; color: var(--muted); margin: 0 0 10px 0; text-transform: uppercase; letter-spacing: 0.06em; } .landing-hero h1 { font-size: clamp(28px, 4.2vw, 40px); line-height: 1.15; margin: 0 0 20px 0; font-weight: 600; } .landing-lead { font-size: 17px; line-height: 1.65; color: var(--muted); margin-bottom: 28px; } .landing-lead p { margin: 0 0 16px 0; } .landing-lead p:last-child { margin-bottom: 0; } .landing-hero-actions { display: flex; flex-wrap: wrap; align-items: center; gap: 16px 24px; } .landing-back-link { font-size: 14px; color: var(--muted); } .landing-back-link:hover { color: var(--accent-strong); } .landing-summary { padding: 0 0 40px; border-bottom: 1px solid var(--border-subtle); } .landing-summary-inner { max-width: 800px; } .landing-route-summary { font-size: 16px; line-height: 1.6; color: var(--muted); margin-bottom: 28px; } .landing-route-summary p { margin: 0 0 12px 0; } .landing-route-summary p:last-child { margin-bottom: 0; } .quick-facts-cards { display: flex; flex-wrap: wrap; gap: 12px 20px; margin-bottom: 20px; } .quick-fact-card { display: flex; flex-direction: column; gap: 4px; padding: 12px 16px; background: var(--bg-elevated); border: 1px solid var(--border-subtle); border-radius: var(--radius-md); } .quick-fact-label { font-size: 11px; text-transform: uppercase; letter-spacing: 0.06em; color: var(--muted); } .quick-fact-value { font-size: 14px; color: var(--text); } .page-focus-line { font-size: 13px; color: var(--muted); margin: 0; } .landing-jump-links { padding: 20px 0 32px; border-bottom: 1px solid var(--border-subtle); } .landing-jump-links:has(.container:empty) { display: none; } .jump-links-inner { display: flex; flex-wrap: wrap; align-items: baseline; gap: 12px 20px; } .jump-links-label { font-size: 13px; color: var(--muted); } .jump-links-list { display: flex; flex-wrap: wrap; gap: 8px 16px; } .jump-links-list a { font-size: 14px; padding: 6px 12px; background: var(--bg-elevated); border: 1px solid var(--border-subtle); border-radius: 999px; } .jump-links-list a:hover { background: var(--accent-soft); border-color: transparent; } .landing-grid { display: grid; grid-template-columns: 1fr 300px; gap: 48px 56px; padding: 40px 0 48px; align-items: start; } .landing-main { min-width: 0; } .landing-content { max-width: 52rem; } .landing-section { margin-bottom: 40px; } .landing-section:last-of-type { margin-bottom: 0; } .landing-section h2 { font-size: 20px; margin: 0 0 16px 0; padding-top: 0; font-weight: 600; } .landing-section h2:first-child { margin-top: 0; } .landing-section p { margin: 0 0 16px 0; color: var(--muted); font-size: 16px; line-height: 1.65; } .landing-section p:last-child { margin-bottom: 0; } .landing-section .steps-list { margin: 0 0 0 20px; padding: 0; } .landing-section .steps-list li { margin-bottom: 10px; font-size: 15px; line-height: 1.5; color: var(--muted); } .landing-section .steps-list li:last-child { margin-bottom: 0; } .landing-faq .faq-list { display: flex; flex-direction: column; gap: 20px; } .faq-item { padding: 20px 0; border-bottom: 1px solid var(--border-subtle); } .faq-item:last-child { border-bottom: none; padding-bottom: 0; } .faq-item h3 { font-size: 16px; font-weight: 600; margin: 0 0 10px 0; } .faq-item .faq-answer { font-size: 15px; line-height: 1.6; color: var(--muted); } .faq-item .faq-answer p { margin: 0 0 8px 0; } .faq-item .faq-answer p:last-child { margin-bottom: 0; } .landing-aside { position: relative; } .landing-aside-sticky { position: sticky; top: 100px; display: flex; flex-direction: column; gap: 24px; } .landing-side-cta { display: flex; flex-direction: column; gap: 12px; align-items: stretch; } .landing-side-cta .btn { width: 100%; justify-content: center; } .landing-aside-back { font-size: 13px; color: var(--muted); text-align: center; } .landing-aside-back:hover { color: var(--accent-strong); } .landing-related-aside h3 { font-size: 14px; font-weight: 600; margin: 0 0 12px 0; } .landing-related-aside ul { list-style: none; padding: 0; margin: 0 0 12px 0; } .landing-related-aside li { margin-bottom: 8px; } .landing-related-aside li:last-child { margin-bottom: 0; } .landing-related-aside a { font-size: 14px; } .landing-aside-facts h3 { font-size: 14px; font-weight: 600; margin: 0 0 10px 0; } .landing-aside-facts ul { list-style: none; padding: 0; margin: 0; } .landing-aside-facts li { font-size: 13px; color: var(--muted); margin-bottom: 6px; } .aside-fact-label { color: var(--text); margin-right: 6px; } .landing-related { padding: 40px 0; background: radial-gradient(circle at top, #111827 0, #020617 70%); border-top: 1px solid var(--border-subtle); border-bottom: 1px solid var(--border-subtle); } .landing-related-inner h2 { font-size: 20px; margin: 0 0 24px 0; } .related-groups { display: flex; flex-direction: column; gap: 24px; } .related-group h3 { font-size: 15px; font-weight: 600; margin: 0 0 12px 0; color: var(--muted); } .guardrail-note { font-size: 13px; color: var(--muted); margin: 0 0 20px 0; } .related-cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 12px; } .related-card { display: block; padding: 14px 18px; background: var(--bg-elevated); border: 1px solid var(--border-subtle); border-radius: var(--radius-md); font-size: 14px; color: var(--text); transition: background 0.15s ease, border-color 0.15s ease; } .related-card:hover { background: var(--accent-soft); border-color: transparent; text-decoration: none; } .landing-final-cta { padding: 44px 0; } .landing-final-cta-inner { display: flex; flex-direction: column; align-items: center; gap: 16px; } @media (max-width: 1024px) { .landing-grid { grid-template-columns: 1fr; } .landing-aside { order: -1; } .landing-aside-sticky { position: static; flex-direction: row; flex-wrap: wrap; gap: 16px; } .landing-side-cta { flex: 1; min-width: 200px; } .landing-related-aside { flex: 1; min-width: 200px; } .landing-aside-facts { flex: 1; min-width: 200px; } } @media (max-width: 768px) { .landing-hero { padding: 28px 0 36px; } .landing-summary { padding-bottom: 32px; } .landing-grid { padding: 32px 0 40px; } .related-cards { grid-template-columns: 1fr; } .landing-aside-sticky { flex-direction: column; } .quick-facts-cards { gap: 10px; } .quick-fact-card { min-width: 0; } } @media (max-width: 390px) { .container { padding-left: 16px; padding-right: 16px; } .container--wide { padding-left: 16px; padding-right: 16px; } .landing-hero { padding: 24px 0 28px; } .landing-hero h1 { font-size: clamp(24px, 6vw, 28px); } .landing-lead { font-size: 16px; } .landing-hero-actions { flex-direction: column; align-items: stretch; gap: 12px; } .landing-hero-actions .btn { width: 100%; justify-content: center; } .related-cards { gap: 10px; } .related-card { padding: 12px 14px; } .footer-inner { flex-direction: column; align-items: flex-start; gap: 12px; } .footer-nav { gap: 10px; } .jump-links-inner { flex-direction: column; align-items: flex-start; } .jump-links-list { width: 100%; } } @media (max-width: 900px) { .hero-inner, .split, .grid-3 { grid-template-columns: minmax(0, 1fr); } .partner-card { flex-direction: column; } .partner-card-logo-wrap { width: 100%; min-height: 80px; border-radius: var(--radius-lg) var(--radius-lg) 0 0; } .partner-card-content { padding: 0 24px 24px; } .hero { padding-top: 32px; } .hero-panel { justify-content: flex-start; } } @media (max-width: 1120px) { .header-inner { gap: 12px; padding: 12px 0; } .header-inner .nav { order: 3; flex-basis: 100%; justify-content: flex-start; flex-wrap: wrap; gap: 8px; } .site-header .btn { margin-left: auto; padding-inline: 14px; } } @media (max-width: 640px) { .footer-inner { flex-direction: column; align-items: flex-start; gap: 12px; } .footer-note { margin-top: 4px; } .header-inner { padding: 10px 0; } } :focus-visible { outline: 2px solid var(--accent-strong); outline-offset: 2px; }