:root {
  color-scheme: light;
  --ink: #111827;
  --muted: #667085;
  --line: #e5e7eb;
  --soft: #f6f8fb;
  --panel: rgba(255,255,255,.92);
  --brand: #0f766e;
  --brand-2: #2563eb;
  --dark: #0b1220;
  --dark-2: #111827;
  --danger: #b42318;
  --ok: #147d52;
  --warn: #b7791f;
  --shadow: 0 24px 80px rgba(15,23,42,.13);
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}
* { box-sizing: border-box; }
body { margin: 0; background: #eef2f7; color: var(--ink); }
button, input, select, textarea { font: inherit; }
button { cursor: pointer; }
code { background: #eef2f7; border-radius: 6px; padding: 2px 6px; }
a { color: var(--brand-2); }
.boot { min-height: 100vh; display: grid; place-items: center; font-weight: 850; }
.brand { display: flex; align-items: center; gap: 12px; }
.brand > div:last-child { display: grid; gap: 4px; min-width: 0; }
.brand strong { display: block; line-height: 1.1; }
.brand span, .microcopy, .subtle { color: var(--muted); line-height: 1.35; }
.mark { width: 42px; height: 42px; border-radius: 10px; display: grid; place-items: center; background: linear-gradient(135deg, var(--brand), var(--brand-2)); color: #fff; font-weight: 950; }
.public-shell { min-height: 100vh; display: grid; grid-template-columns: 1.06fr .94fr; background: radial-gradient(circle at 20% 10%, rgba(15,118,110,.22), transparent 32%), linear-gradient(135deg, #f8fafc, #e9eef7); }
.public-hero { min-height: 100vh; padding: 56px; display: flex; flex-direction: column; justify-content: center; gap: 26px; background: #0b1220; color: #fff; position: relative; overflow: hidden; }
.public-hero:before { content: ""; position: absolute; inset: 0; opacity: .5; background-image: linear-gradient(rgba(255,255,255,.08) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.08) 1px, transparent 1px); background-size: 54px 54px; mask-image: radial-gradient(circle at 40% 40%, #000, transparent 75%); }
.public-hero > * { position: relative; z-index: 1; }
.public-hero h1 { margin: 0; font-size: clamp(44px, 5.5vw, 76px); line-height: .96; max-width: 820px; letter-spacing: 0; }
.public-hero p { max-width: 690px; color: rgba(255,255,255,.78); font-size: 18px; line-height: 1.7; }
.hero-grid, .glass-list { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; max-width: 720px; }
.hero-grid div, .glass-list span { border: 1px solid rgba(255,255,255,.16); background: rgba(255,255,255,.08); backdrop-filter: blur(18px); border-radius: 12px; padding: 16px; font-weight: 800; }
.landing-shell { min-height: 100vh; color: #fff; background: radial-gradient(circle at 18% 8%, rgba(15,118,110,.28), transparent 34%), radial-gradient(circle at 82% 2%, rgba(37,99,235,.22), transparent 30%), linear-gradient(180deg, #07111f 0%, #0b1220 42%, #eef2f7 42%, #eef2f7 100%); }
.landing-hero { min-height: 100vh; padding: 26px 32px 70px; position: relative; overflow: hidden; }
.landing-hero:before { content: ""; position: absolute; inset: 0; background-image: linear-gradient(rgba(255,255,255,.055) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.055) 1px, transparent 1px); background-size: 46px 46px; mask-image: linear-gradient(#000, transparent 88%); pointer-events: none; }
.landing-hero > * { position: relative; z-index: 1; }
.landing-nav { max-width: 1240px; margin: 0 auto 56px; display: flex; align-items: center; justify-content: space-between; gap: 18px; }
.landing-nav .brand span, .landing-nav .brand strong { color: #fff; }
.landing-nav .brand span { color: rgba(255,255,255,.62); }
.landing-hero-grid { max-width: 1240px; margin: 0 auto; display: grid; grid-template-columns: minmax(0, .95fr) minmax(480px, 1.05fr); gap: 34px; align-items: center; }
.landing-copy { display: grid; gap: 22px; }
.landing-copy .eyebrow { color: #8ee7d3; }
.landing-copy h1 { margin: 0; max-width: 850px; font-size: clamp(44px, 6vw, 82px); line-height: .95; letter-spacing: 0; }
.landing-copy p { margin: 0; max-width: 760px; color: rgba(255,255,255,.74); font-size: 18px; line-height: 1.7; }
.landing-actions { display: flex; flex-wrap: wrap; gap: 12px; }
.landing-actions .btn { min-width: 132px; }
.landing-microcopy { display: flex; flex-wrap: wrap; gap: 8px; color: rgba(255,255,255,.72); }
.landing-microcopy span { border: 1px solid rgba(255,255,255,.13); background: rgba(255,255,255,.06); border-radius: 999px; padding: 8px 11px; font-size: 13px; font-weight: 800; }
.trust-row { display: flex; flex-wrap: wrap; gap: 10px; }
.trust-row span { border: 1px solid rgba(142,231,211,.28); background: rgba(15,118,110,.18); color: #b8fff0; border-radius: 999px; padding: 8px 11px; font-size: 13px; font-weight: 900; }
.product-mockup { border: 1px solid rgba(255,255,255,.16); border-radius: 18px; padding: 14px; background: rgba(255,255,255,.08); backdrop-filter: blur(22px); box-shadow: 0 30px 90px rgba(0,0,0,.28); min-width: 0; }
.mockup-top { display: flex; align-items: center; gap: 8px; padding: 8px 8px 14px; color: rgba(255,255,255,.76); font-size: 13px; font-weight: 900; }
.mockup-top span { width: 10px; height: 10px; border-radius: 999px; background: rgba(255,255,255,.28); }
.mockup-top strong { margin-left: 6px; }
.mockup-metrics { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 10px; }
.mockup-metrics .metric { background: rgba(255,255,255,.94); border-color: rgba(255,255,255,.5); padding: 14px; box-shadow: none; }
.mockup-metrics .metric strong { font-size: 28px; }
.mockup-main { margin-top: 10px; display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.mockup-panel { border: 1px solid rgba(255,255,255,.5); border-radius: 14px; padding: 16px; background: rgba(255,255,255,.94); color: var(--ink); min-height: 190px; }
.mockup-panel h3 { margin: 0 0 14px; }
.mockup-tags { display: flex; flex-wrap: wrap; gap: 8px; }
.mockup-tags span { border-radius: 999px; padding: 8px 10px; background: #e6f4f1; color: var(--brand); font-weight: 900; font-size: 12px; }
.mockup-bars { display: grid; gap: 12px; margin-top: 24px; }
.mockup-bars i { display: block; height: 9px; border-radius: 999px; background: linear-gradient(90deg, var(--brand), var(--brand-2)); }
.mockup-panel p { margin: 9px 0; padding: 10px; border: 1px solid var(--line); border-radius: 10px; color: #344054; font-weight: 800; }
.landing-section { width: min(1240px, calc(100% - 48px)); margin: 0 auto 18px; padding: 28px; color: var(--ink); background: rgba(255,255,255,.92); border: 1px solid rgba(255,255,255,.8); border-radius: 18px; box-shadow: 0 20px 60px rgba(15,23,42,.08); }
.landing-section h2 { margin: 0; font-size: clamp(30px, 3.5vw, 48px); line-height: 1.05; letter-spacing: 0; }
.landing-section p { color: var(--muted); line-height: 1.6; }
.section-head, .timeline-section, .choose-section { display: flex; align-items: flex-start; justify-content: space-between; gap: 22px; }
.timeline-section > div:first-child, .choose-section > div:first-child { max-width: 650px; }
.countdown-card { min-width: min(460px, 100%); display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.countdown-card div { border: 1px solid var(--line); border-radius: 14px; padding: 14px; background: #f8fafc; display: grid; gap: 5px; }
.countdown-card span { color: var(--muted); font-size: 12px; font-weight: 900; text-transform: uppercase; letter-spacing: .05em; }
.countdown-card strong { font-size: 20px; }
.countdown-card .days { background: #0b1220; color: #fff; border-color: #0b1220; }
.countdown-card .days span { color: rgba(255,255,255,.62); }
.countdown-card .days strong { font-size: 34px; }
.countdown-card p { grid-column: 1 / -1; margin: 0; font-size: 12px; }
.flow-grid, .feature-grid, .persona-grid, .coach-grid, .industry-guide-grid { display: grid; gap: 12px; margin-top: 22px; }
.preview-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 12px; margin-top: 22px; }
.flow-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.feature-grid { grid-template-columns: repeat(5, minmax(0, 1fr)); }
.persona-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.coach-grid, .industry-guide-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); padding: 14px; margin-top: 0; }
.flow-grid article, .feature-grid article, .persona-grid article, .comparison-card, .preview-grid article, .coach-grid article, .industry-guide-grid article { border: 1px solid var(--line); border-radius: 14px; padding: 16px; background: #fff; min-width: 0; }
.flow-grid span { width: 34px; height: 34px; border-radius: 999px; display: grid; place-items: center; background: #111827; color: #fff; font-weight: 950; }
.flow-grid h3, .feature-grid h3, .persona-grid h3, .comparison-card h3, .coach-grid h3, .industry-guide-grid h3 { margin: 0 0 7px; }
.flow-grid p, .feature-grid p, .persona-grid p, .coach-grid p, .industry-guide-grid p { margin: 0; color: var(--muted); line-height: 1.55; }
.industry-guide-grid strong { display: block; margin-top: 10px; color: #344054; font-size: 13px; line-height: 1.45; }
.comparison-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-top: 22px; }
.comparison-card p { display: flex; align-items: center; gap: 10px; margin: 10px 0; color: #344054; font-weight: 850; }
.comparison-card b { width: 24px; height: 24px; border-radius: 999px; display: grid; place-items: center; }
.comparison-card.winner { border-color: rgba(15,118,110,.28); background: linear-gradient(180deg, #f3fbf8, #fff); }
.comparison-card.winner b { background: #e6f4f1; color: var(--brand); }
.comparison-card.muted b { background: #f1f5f9; color: var(--danger); }
.choose-list { display: flex; flex-wrap: wrap; gap: 10px; max-width: 560px; }
.choose-list span { border-radius: 999px; padding: 10px 12px; background: #0b1220; color: #fff; font-weight: 850; }
.auth-card.landing-auth-card { margin: 30px auto 70px; color: var(--ink); }
.auth-card { width: min(520px, calc(100vw - 32px)); margin: auto; background: var(--panel); border: 1px solid rgba(255,255,255,.7); border-radius: 14px; padding: 28px; box-shadow: var(--shadow); }
.auth-notice { margin: 14px 0 16px; border: 1px solid #fedf89; background: #fff7e6; color: #93370d; border-radius: 12px; padding: 12px 14px; font-weight: 800; line-height: 1.45; }
.auth-only-shell { min-height: 100vh; display: grid; place-items: center; padding: 28px; background: radial-gradient(circle at 20% 12%, rgba(15,118,110,.18), transparent 32%), radial-gradient(circle at 82% 0%, rgba(37,99,235,.14), transparent 30%), linear-gradient(135deg, #eef4f8 0%, #f8fafc 54%, #eef2f7 100%); }
.auth-only-card { width: min(520px, calc(100vw - 32px)); background: rgba(255,255,255,.94); border: 1px solid rgba(255,255,255,.82); border-radius: 18px; padding: 30px; box-shadow: 0 28px 70px rgba(15,23,42,.16); }
.auth-only-brand { display: flex; align-items: center; gap: 14px; padding-bottom: 20px; margin-bottom: 20px; border-bottom: 1px solid var(--line); }
.auth-only-brand strong { display: block; font-size: 22px; line-height: 1.05; }
.auth-only-brand span { display: block; margin-top: 5px; color: var(--muted); font-weight: 750; }
.auth-only-card h1 { margin: 0 0 10px; font-size: clamp(30px, 4vw, 42px); letter-spacing: 0; line-height: 1.05; }
.auth-only-card .subtle { font-size: 17px; line-height: 1.55; margin-bottom: 18px; }
.auth-context { display: grid; gap: 4px; border: 1px solid var(--line); background: #f8fafc; border-radius: 12px; padding: 12px 14px; margin: 10px 0; }
.auth-context span { color: var(--muted); font-size: 11px; font-weight: 950; text-transform: uppercase; letter-spacing: .06em; }
.auth-context strong { color: var(--ink); font-size: 15px; overflow-wrap: anywhere; }
.link-button { margin-top: 16px; border: 0; background: transparent; color: var(--brand); font-weight: 850; padding: 0; cursor: pointer; }
.onboarding-card { width: min(980px, calc(100vw - 32px)); margin: auto; background: var(--panel); border: 1px solid rgba(255,255,255,.7); border-radius: 14px; padding: 28px; box-shadow: var(--shadow); }
.auth-card h2, .onboarding-card h1 { margin: 12px 0 8px; font-size: 30px; }
.tabs { display: grid; grid-template-columns: repeat(3, 1fr); gap: 6px; padding: 5px; background: #eef2f7; border-radius: 10px; }
.tabs button { border: 0; border-radius: 8px; padding: 9px; color: var(--muted); font-weight: 850; background: transparent; }
.tabs button.active { background: #fff; color: var(--ink); box-shadow: 0 6px 18px rgba(15,23,42,.08); }
.oauth-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin: 18px 0; }
.divider { text-align: center; color: var(--muted); margin: 14px 0; font-size: 13px; }
.form { display: grid; gap: 12px; margin-top: 18px; }
label { color: #344054; font-size: 13px; font-weight: 800; }
input, select, textarea { width: 100%; min-width: 0; border: 1px solid var(--line); background: #fff; color: var(--ink); border-radius: 10px; padding: 11px 12px; outline: 0; }
input:focus, select:focus, textarea:focus { border-color: var(--brand); box-shadow: 0 0 0 4px rgba(15,118,110,.12); }
textarea { min-height: 92px; resize: vertical; }
.btn { border: 1px solid transparent; border-radius: 10px; min-height: 42px; padding: 10px 14px; display: inline-flex; align-items: center; justify-content: center; gap: 8px; background: var(--brand); color: #fff; font-weight: 850; text-decoration: none; }
.btn.secondary { background: #fff; color: var(--ink); border-color: var(--line); }
.btn.ghost { background: transparent; color: var(--ink); }
.btn.danger { background: var(--danger); color: #fff; }
.btn.small { min-height: 34px; padding: 7px 10px; font-size: 13px; }
.onboarding-shell { min-height: 100vh; display: grid; place-items: center; padding: 24px; background: linear-gradient(135deg, #f8fafc, #e8f2ef); }
.steps { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 24px; }
.steps span { border-radius: 999px; padding: 7px 10px; background: #eef2f7; color: var(--muted); font-size: 12px; font-weight: 850; }
.steps .done { background: #e6f4f1; color: var(--brand); }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.form-grid > div { display: grid; gap: 7px; }
.full { grid-column: 1 / -1; }
.onboarding-summary { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin: 22px 0; }
.onboarding-summary div { background: #f8fafc; border: 1px solid var(--line); border-radius: 12px; padding: 16px; display: grid; gap: 4px; }
.onboarding-summary strong { font-size: 24px; }
.app-shell { min-height: 100vh; display: grid; grid-template-columns: 280px 1fr; }
.sidebar { position: sticky; top: 0; height: 100vh; padding: 20px; background: linear-gradient(180deg, #0b1220, #111827); color: #fff; display: flex; flex-direction: column; gap: 16px; }
.sidebar .brand { align-items: flex-start; gap: 10px; padding: 4px 4px 16px; border-bottom: 1px solid rgba(255,255,255,.1); }
.sidebar .brand .mark { width: 36px; height: 36px; border-radius: 9px; flex: 0 0 auto; }
.sidebar .brand div:last-child { display: grid; gap: 4px; min-width: 0; }
.sidebar .brand strong { display: block; color: #fff; line-height: 1.1; font-size: 16px; letter-spacing: 0; }
.sidebar .brand span { color: rgba(255,255,255,.62); display: block; font-size: 12px; line-height: 1.25; }
.nav { display: grid; gap: 6px; }
.nav button { border: 0; border-radius: 10px; padding: 11px 12px; text-align: left; background: transparent; color: rgba(255,255,255,.68); font-weight: 800; }
.nav button.active, .nav button:hover { background: rgba(255,255,255,.1); color: #fff; }
.plan-card, .user-tile { border: 1px solid rgba(255,255,255,.12); border-radius: 12px; padding: 12px; background: rgba(255,255,255,.07); display: grid; gap: 6px; }
.plan-card { margin-top: auto; }
.plan-card span, .plan-card small { color: rgba(255,255,255,.68); }
.role-badge, .chip { display: inline-flex; width: fit-content; border-radius: 999px; padding: 5px 9px; font-size: 12px; font-weight: 850; background: #e6f4f1; color: var(--brand); }
.access-banner { margin: 14px 28px 0; border: 1px solid rgba(15,118,110,.18); border-radius: 12px; padding: 12px 14px; font-weight: 850; background: #f3fbfa; color: #0f766e; }
.access-banner.warn { background: #fff7e6; border-color: #fedf89; color: #93370d; }
.access-banner.danger { background: #fff1f0; border-color: #fecaca; color: #b42318; }
.access-banner.ok { background: #ecfdf3; border-color: #bbf7d0; color: #0f766e; }
.main { min-width: 0; }
.topbar { position: sticky; top: 0; z-index: 3; height: 74px; padding: 0 28px; display: flex; align-items: center; justify-content: space-between; gap: 16px; background: rgba(255,255,255,.78); backdrop-filter: blur(18px); border-bottom: 1px solid rgba(229,231,235,.8); }
.mobile-menu { display: none; }
.actions { display: flex; align-items: center; flex-wrap: wrap; gap: 10px; }
.page { padding: 28px; display: grid; gap: 20px; }
.page-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 18px; }
.page h1 { margin: 0; font-size: 32px; letter-spacing: 0; }
.hero-band { padding: 24px; border: 1px solid rgba(255,255,255,.8); border-radius: 16px; background: linear-gradient(135deg, rgba(255,255,255,.86), rgba(235,245,243,.84)); box-shadow: 0 16px 50px rgba(15,23,42,.07); }
.hero-band p { max-width: 760px; color: var(--muted); line-height: 1.6; }
.eyebrow { color: var(--brand); font-size: 12px; font-weight: 950; text-transform: uppercase; letter-spacing: .08em; }
.metrics { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 14px; }
.metric, .panel, .template-card { background: var(--panel); border: 1px solid rgba(255,255,255,.78); border-radius: 14px; box-shadow: 0 12px 34px rgba(15,23,42,.07); }
.metric { padding: 18px; }
.metric span, .metric p { color: var(--muted); margin: 0; }
.metric strong { display: block; margin: 7px 0; font-size: 32px; }
.grid { display: grid; gap: 16px; }
.grid.two { grid-template-columns: minmax(0,1fr) minmax(330px,.55fr); }
.panel { overflow: hidden; }
.panel.glass { background: rgba(255,255,255,.68); backdrop-filter: blur(20px); }
.panel-head { padding: 16px; border-bottom: 1px solid var(--line); display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.panel h2, .template-card h3 { margin: 0; }
.panel-body { padding: 16px; }
.journey { padding: 16px; display: flex; flex-wrap: wrap; gap: 8px; }
.journey span { border: 1px solid var(--line); border-radius: 999px; padding: 8px 11px; background: #fff; font-weight: 800; color: #344054; }
.framework-card-grid, .framework-library-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; margin-top: 18px; padding: 16px; }
.framework-card-grid { padding: 0; }
.framework-select-card, .framework-library-card { border: 1px solid var(--line); border-radius: 14px; background: rgba(255,255,255,.9); padding: 16px; text-align: left; display: grid; gap: 12px; box-shadow: 0 10px 28px rgba(15,23,42,.05); }
.framework-select-card { min-height: 176px; }
.framework-select-card.selected { border-color: var(--brand); box-shadow: 0 0 0 4px rgba(15,118,110,.12), 0 16px 36px rgba(15,23,42,.08); }
.framework-select-card > div, .framework-library-card > div { display: flex; justify-content: space-between; align-items: flex-start; gap: 10px; }
.framework-select-card p, .framework-library-card p { color: var(--muted); line-height: 1.5; margin: 0; }
.framework-select-card footer { display: flex; gap: 8px; flex-wrap: wrap; margin-top: auto; }
.framework-select-card footer span { border-radius: 999px; background: #f1f5f9; padding: 6px 9px; font-size: 12px; font-weight: 850; color: #475467; }
.framework-library-card dl { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; margin: 0; }
.framework-library-card dt { color: var(--muted); font-size: 12px; font-weight: 800; }
.framework-library-card dd { margin: 3px 0 0; font-weight: 850; }
.onboarding-actions { margin-top: 18px; justify-content: flex-end; }
.generation-panel { margin-top: 22px; display: grid; gap: 12px; }
.generation-step { border: 1px solid var(--line); background: #fff; border-radius: 14px; padding: 14px; display: grid; grid-template-columns: 34px 1fr auto; align-items: center; gap: 12px; }
.generation-step span { width: 18px; height: 18px; border-radius: 999px; border: 3px solid rgba(15,118,110,.18); border-top-color: var(--brand); animation: spin 1s linear infinite; }
.generation-step em { color: var(--muted); font-style: normal; font-size: 12px; font-weight: 850; }
@keyframes spin { to { transform: rotate(360deg); } }
.roadmap-list { padding: 12px; display: grid; gap: 10px; }
.roadmap-list button { border: 1px solid var(--line); background: #fff; border-radius: 12px; padding: 12px; display: grid; grid-template-columns: 34px 1fr auto; align-items: center; gap: 12px; text-align: left; }
.roadmap-list button:hover { border-color: var(--brand); box-shadow: 0 0 0 4px rgba(15,118,110,.1); }
.roadmap-list span { width: 28px; height: 28px; border-radius: 999px; display: grid; place-items: center; background: #e6f4f1; color: var(--brand); font-weight: 950; }
.roadmap-list em { color: var(--muted); font-style: normal; font-size: 12px; font-weight: 850; }
.command-page { gap: 18px; }
.command-hero { padding: 26px; border: 1px solid rgba(255,255,255,.84); border-radius: 16px; color: #fff; background: linear-gradient(135deg, #0b1220 0%, #123735 58%, #0f766e 100%); box-shadow: var(--shadow); position: relative; overflow: hidden; }
.command-hero:before { content: ""; position: absolute; inset: 0; background-image: linear-gradient(rgba(255,255,255,.07) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.07) 1px, transparent 1px); background-size: 42px 42px; opacity: .55; }
.command-hero > * { position: relative; z-index: 1; }
.command-hero .eyebrow, .command-hero p { color: rgba(255,255,255,.78); }
.command-hero h1 { font-size: clamp(34px, 4.5vw, 56px); max-width: 780px; line-height: 1; }
.command-hero p { max-width: 760px; margin-bottom: 0; font-size: 16px; }
.command-metrics { grid-template-columns: repeat(4, minmax(160px, 1fr)); }
.command-grid.grid.two { grid-template-columns: minmax(0, 1.1fr) minmax(340px, .75fr); }
.do-next-panel { display: flex; align-items: center; justify-content: space-between; gap: 18px; padding: 20px; border-radius: 16px; background: #fff; border: 1px solid rgba(15,118,110,.22); box-shadow: 0 18px 50px rgba(15,23,42,.08); }
.do-next-panel h2 { margin: 4px 0 6px; font-size: 30px; }
.do-next-panel p { margin: 0; color: var(--muted); line-height: 1.55; }
.action-metrics .metric:first-child { border-color: rgba(15,118,110,.32); background: linear-gradient(180deg, #f3fbf8, #fff); }
.welcome-panel { display: grid; grid-template-columns: minmax(0, .8fr) minmax(320px, .6fr); gap: 16px; padding: 18px; }
.welcome-copy h2 { margin: 6px 0 8px; font-size: 30px; }
.welcome-copy p { color: var(--muted); line-height: 1.6; margin: 0; }
.welcome-stats { display: grid; gap: 10px; }
.welcome-stats div { border: 1px solid var(--line); border-radius: 12px; background: #f8fafc; padding: 12px; display: grid; gap: 4px; }
.welcome-stats span { color: var(--muted); font-size: 12px; font-weight: 900; text-transform: uppercase; letter-spacing: .05em; }
.welcome-stats strong { line-height: 1.35; }
.tour-strip { grid-column: 1 / -1; display: grid; grid-template-columns: repeat(6, minmax(0, 1fr)); gap: 10px; }
.tour-strip button { border: 1px solid var(--line); border-radius: 12px; padding: 12px; background: #fff; display: grid; gap: 4px; text-align: left; }
.tour-strip button:hover { border-color: var(--brand); box-shadow: 0 0 0 4px rgba(15,118,110,.09); }
.tour-strip span { color: var(--muted); font-size: 12px; line-height: 1.45; }
.stage-roadmap { padding: 16px; display: grid; grid-template-columns: repeat(auto-fit, minmax(185px, 1fr)); gap: 10px; }
.stage-roadmap div { border: 1px solid var(--line); border-radius: 12px; padding: 12px; background: #fff; min-height: 118px; display: grid; align-content: start; gap: 8px; position: relative; min-width: 0; }
.stage-roadmap div:after { content: ""; position: absolute; top: 26px; left: calc(100% - 3px); width: 16px; height: 2px; background: #d9e2ec; }
.stage-roadmap div:last-child:after { display: none; }
.stage-roadmap div.complete { border-color: rgba(15,118,110,.34); background: linear-gradient(180deg, #f2fbf8, #fff); }
.stage-roadmap div.complete:after { background: var(--brand); }
.stage-roadmap span { width: 28px; height: 28px; border-radius: 999px; display: grid; place-items: center; background: #e6f4f1; color: var(--brand); font-weight: 950; }
.stage-roadmap strong { font-size: 12px; color: #344054; text-transform: uppercase; letter-spacing: .05em; }
.stage-roadmap p { margin: 0; color: var(--ink); font-weight: 850; line-height: 1.35; overflow-wrap: anywhere; }
.next-actions, .quick-win-list { padding: 12px; display: grid; gap: 10px; }
.action-card { width: 100%; border: 1px solid var(--line); background: #fff; border-radius: 12px; padding: 12px; display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 8px 12px; text-align: left; align-items: center; }
.action-card:hover { border-color: var(--brand); box-shadow: 0 0 0 4px rgba(15,118,110,.09); transform: translateY(-1px); }
.action-card div { min-width: 0; display: grid; gap: 4px; }
.action-card span, .action-card small { color: var(--muted); font-size: 12px; line-height: 1.45; }
.action-card em { width: fit-content; border-radius: 999px; padding: 5px 8px; font-style: normal; font-size: 12px; font-weight: 950; }
.action-card em.critical { background: #7f1d1d; color: #fff; }
.action-card em.high { background: #fff1f0; color: var(--danger); }
.action-card em.medium { background: #fff7e6; color: #93370d; }
.action-card em.low { background: #e8f5ee; color: #0e5f3d; }
.action-card small { grid-column: 1 / -1; font-weight: 850; }
.clock-card { padding: 16px; display: grid; grid-template-columns: 170px 1fr; gap: 16px; align-items: center; }
.clock { aspect-ratio: 1; border-radius: 999px; display: grid; place-items: center; align-content: center; gap: 2px; background: conic-gradient(var(--clock-tone) 72%, #e8edf3 0); color: #111827; box-shadow: inset 0 0 0 12px #fff, 0 18px 34px rgba(15,23,42,.1); }
.clock.green { --clock-tone: #0f766e; }
.clock.yellow { --clock-tone: #d69e2e; }
.clock.orange { --clock-tone: #ea580c; }
.clock.red { --clock-tone: #b42318; }
.clock strong { font-size: 40px; line-height: 1; }
.clock span { color: var(--muted); font-size: 12px; font-weight: 900; text-transform: uppercase; letter-spacing: .05em; }
.clock-meta { display: grid; gap: 10px; }
.clock-meta p { margin: 0; border: 1px solid var(--line); border-radius: 12px; padding: 10px; display: grid; gap: 3px; background: #fff; }
.clock-meta b { font-size: 12px; text-transform: uppercase; letter-spacing: .05em; color: #475467; }
.clock-meta span { color: var(--muted); line-height: 1.45; }
.pace-card { grid-column: 1 / -1; display: grid; gap: 8px; }
.pace-card p { margin: 0; border: 1px solid var(--line); border-radius: 12px; padding: 10px; background: #fff; display: grid; gap: 3px; }
.pace-card b { font-size: 12px; text-transform: uppercase; letter-spacing: .05em; color: #475467; }
.pace-card span { color: var(--muted); }
.risk-education { padding: 12px; display: grid; gap: 10px; }
.exposure-card { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 10px; }
.exposure-card p { margin: 0; border: 1px solid var(--line); border-radius: 12px; padding: 12px; background: #fff; display: grid; gap: 3px; }
.exposure-card strong { font-size: 18px; }
.exposure-card span { color: var(--muted); font-size: 12px; font-weight: 850; }
.risk-education details { border: 1px solid var(--line); border-radius: 12px; background: #fff; padding: 11px 12px; }
.risk-education summary { cursor: pointer; font-weight: 900; }
.risk-education p { color: var(--muted); line-height: 1.55; margin: 8px 0 0; }
.momentum-grid { padding: 12px; display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; }
.momentum-grid div { border: 1px solid var(--line); border-radius: 12px; background: #fff; padding: 14px; display: grid; gap: 6px; }
.momentum-grid span { color: var(--muted); font-size: 12px; font-weight: 900; text-transform: uppercase; letter-spacing: .05em; }
.momentum-grid strong { font-size: 24px; }
.momentum-grid p { margin: 0; color: var(--muted); line-height: 1.45; }
.workflow-panel { align-self: start; }
.how-works { padding: 12px; display: grid; grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)); gap: 10px; }
.how-works button { border: 1px solid var(--line); background: #fff; border-radius: 12px; padding: 12px; text-align: left; display: grid; grid-template-columns: 34px minmax(0, 1fr); gap: 6px 10px; align-content: start; min-height: 94px; }
.how-works button:hover { border-color: var(--brand); box-shadow: 0 0 0 4px rgba(15,118,110,.09); }
.how-works span { width: 30px; height: 30px; border-radius: 999px; display: grid; place-items: center; color: #fff; background: #111827; font-weight: 950; grid-row: 1 / span 2; }
.how-works strong { line-height: 1.25; min-width: 0; }
.how-works p { margin: 0; color: var(--muted); line-height: 1.4; font-size: 13px; min-width: 0; overflow-wrap: anywhere; }
.source-badge { display: inline-flex; width: fit-content; border-radius: 999px; padding: 4px 8px; background: #e6f4f1; color: var(--brand); font-size: 12px; font-weight: 850; margin-top: 6px; }
.source-badge.custom { background: #eef2ff; color: #3446a1; }
.source-badge.framework { background: #f1f5f9; color: #334155; }
.risk-badge, .priority-badge { display: inline-flex; width: fit-content; border-radius: 999px; padding: 5px 8px; font-size: 12px; font-weight: 900; margin: 3px 0; }
.risk-badge.critical, .priority-badge.critical { background: #7f1d1d; color: #fff; }
.risk-badge.high, .priority-badge.high { background: #fff1f0; color: var(--danger); }
.risk-badge.medium, .priority-badge.medium { background: #fff7e6; color: #93370d; }
.risk-badge.low, .priority-badge.low { background: #e8f5ee; color: #0e5f3d; }
.framework-strip { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; }
.framework-chip-card { border: 1px solid var(--line); background: #fff; border-radius: 14px; padding: 12px; display: grid; grid-template-columns: 1fr auto; gap: 8px; align-items: center; }
.framework-chip-card div { display: grid; gap: 3px; }
.framework-chip-card span, .framework-chip-card small { color: var(--muted); font-size: 12px; }
.framework-chip-card.active { border-color: rgba(15,118,110,.35); background: #f3fbf8; }
.framework-chip-card.inactive { opacity: .78; }
.quick-filters { display: flex; gap: 8px; flex-wrap: wrap; }
.quick-filters button { border: 1px solid var(--line); border-radius: 999px; background: #fff; padding: 8px 11px; color: #475467; font-weight: 850; }
.quick-filters button.active, .quick-filters button:hover { background: #111827; color: #fff; border-color: #111827; }
.action-center { gap: 14px; }
.action-summary { display: grid; grid-template-columns: repeat(6, minmax(130px, 1fr)); gap: 10px; }
.action-summary .metric { min-height: 112px; }
.recommended-actions-panel { overflow: hidden; }
.recommended-action-list { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 10px; padding: 12px; }
.recommended-action-card { border: 1px solid rgba(15,118,110,.18); background: linear-gradient(180deg, #f3fbfa, #fff); border-radius: 14px; padding: 13px; display: grid; gap: 10px; text-align: left; min-width: 0; }
.recommended-action-card:hover { border-color: var(--brand); box-shadow: 0 0 0 4px rgba(15,118,110,.08); transform: translateY(-1px); }
.recommended-action-card strong { display: block; color: var(--ink); font-size: 15px; line-height: 1.3; }
.recommended-action-card span, .recommended-action-card small { color: var(--muted); line-height: 1.45; }
.recommended-action-card dl { margin: 0; display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 6px; }
.recommended-action-card div { min-width: 0; }
.recommended-action-card dt { color: var(--muted); font-size: 10px; font-weight: 950; text-transform: uppercase; letter-spacing: .05em; }
.recommended-action-card dd { margin: 2px 0 0; font-weight: 900; color: var(--ink); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.guidance { margin-top: 10px; border: 1px solid rgba(15,118,110,.18); border-radius: 14px; background: #f3fbfa; max-width: 100%; overflow: hidden; container-type: inline-size; box-shadow: inset 0 1px 0 rgba(255,255,255,.82); }
.guidance > summary { padding: 11px 13px; font-weight: 950; cursor: pointer; font-size: 14px; color: #0f3f3b; background: linear-gradient(180deg, #f3fbfa, #edf8f6); border-bottom: 1px solid rgba(15,118,110,.12); }
.guidance-grid { padding: 0 11px 11px; display: grid; grid-template-columns: minmax(0, 1fr); gap: 10px; }
.guidance-grid section, .guide-card { background: rgba(255,255,255,.95); border: 1px solid rgba(15,118,110,.14); border-radius: 12px; min-width: 0; overflow: hidden; }
.guidance-grid h4, .guide-card > summary { margin: 0; font-size: 15px; line-height: 1.25; color: var(--ink); font-weight: 900; }
.guide-card > summary { min-height: 48px; cursor: pointer; list-style: none; display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 0 14px; background: rgba(255,255,255,.72); }
.guide-card > summary::-webkit-details-marker { display: none; }
.guide-card > summary::after { content: "›"; width: 22px; height: 22px; border-radius: 999px; display: grid; place-items: center; color: #0f766e; background: #e7f6f3; transform: rotate(0deg); transition: transform .16s ease; flex: 0 0 auto; }
.guide-card[open] > summary::after { transform: rotate(90deg); }
.guide-card[open] > summary { border-bottom: 1px solid rgba(15,118,110,.1); }
.guide-content { padding: 12px 14px 14px; animation: guideReveal .16s ease; }
.guide-card.evidence-layer[open] { overflow: visible; }
.guide-card.evidence-layer .guide-content { padding: 10px 12px 12px; }
@keyframes guideReveal { from { opacity: 0; transform: translateY(-4px); } to { opacity: 1; transform: translateY(0); } }
.guidance-grid p, .guidance-grid ul, .guidance-grid ol { margin: 0; color: var(--muted); font-size: 14px; line-height: 1.55; text-align: left; text-wrap: pretty; hyphens: auto; overflow-wrap: normal; word-break: normal; }
.guide-panel-body p, .guide-panel-body ul, .guide-panel-body ol { margin: 0; color: var(--muted); font-size: 14px; line-height: 1.55; text-align: left; text-wrap: pretty; hyphens: auto; overflow-wrap: normal; word-break: normal; }
.guidance-grid ul, .guidance-grid ol { padding-left: 18px; }
.guide-panel-body ul, .guide-panel-body ol { padding-left: 18px; }
.guidance-grid li { margin: 4px 0; padding-left: 2px; }
.guide-panel-body li { margin: 4px 0; padding-left: 2px; }
.check-grid { display: grid; grid-template-columns: minmax(0, 1fr); gap: 10px; }
.check-grid strong { display: block; margin-bottom: 5px; font-size: 12px; color: #344054; line-height: 1.3; }
.check-layer, .evidence-layer, .legal-layer { grid-column: 1 / -1; }
.evidence-cards { display: grid; grid-template-columns: minmax(0, 1fr); gap: 10px; }
.evidence-cards article { border: 1px solid var(--line); border-radius: 10px; padding: 10px; background: #f8fafc; display: grid; gap: 5px; min-width: 0; }
.evidence-cards strong { color: var(--ink); }
.evidence-cards p { font-size: 13px; overflow-wrap: normal; word-break: normal; }
.evidence-guide-list { display: grid; gap: 0; border: 1px solid #e3ebf1; border-radius: 12px; overflow: visible; background: #fff; }
.evidence-guide-note { color: #667085; font-size: 12px; line-height: 1.3; padding: 8px 10px; margin: 0; background: #f8fafc; border-bottom: 1px solid #e3ebf1; }
.evidence-guide-row { display: grid; grid-template-columns: 24px minmax(0, 1fr); gap: 9px; padding: 8px 10px; background: #fff; }
.evidence-guide-row + .evidence-guide-row { border-top: 1px solid #edf2f7; }
.evidence-guide-number { width: 22px; height: 22px; border-radius: 999px; background: #e7f6f3; color: #0f766e; display: grid; place-items: center; font-size: 12px; font-weight: 950; }
.evidence-guide-copy { display: grid; gap: 2px; min-width: 0; }
.evidence-guide-copy strong { color: var(--ink); font-size: 13px; line-height: 1.25; min-width: 0; overflow-wrap: anywhere; }
.evidence-guide-copy p { color: #475467; font-size: 12px; line-height: 1.3; }
.evidence-guide-copy small { color: #667085; font-size: 12px; line-height: 1.25; }
.evidence-guide-copy small b { color: #475467; }
.evidence-guide-copy small span { color: #98a2b3; }
.legal-layer details { border: 1px solid var(--line); border-radius: 10px; padding: 8px 10px; background: #f8fafc; }
.legal-layer summary { cursor: pointer; font-weight: 850; color: #344054; }
.guide-card.legal-layer .guide-content { background: #f8fafc; }
@container (min-width: 760px) {
  .guidance-grid { grid-template-columns: repeat(2, minmax(260px, 1fr)); }
  .check-grid, .evidence-cards { grid-template-columns: repeat(2, minmax(240px, 1fr)); }
}
.suggestion-list { display: grid; gap: 10px; padding: 12px; }
.suggestion-list div, .suggestion-list button { border: 1px solid var(--line); background: #fff; border-radius: 12px; padding: 12px; display: grid; gap: 4px; text-align: left; }
.suggestion-list span { color: var(--muted); }
.empty.guided { display: grid; justify-items: center; gap: 12px; margin: 16px; }
.toolbar { display: grid; grid-template-columns: 1fr 220px; gap: 10px; }
.toolbar.wide { grid-template-columns: minmax(220px, 1fr) repeat(9, minmax(130px, 160px)); }
.table-wrap { overflow-x: auto; }
table { width: 100%; border-collapse: collapse; min-width: 860px; }
th, td { padding: 13px 14px; border-bottom: 1px solid #edf0f4; text-align: left; vertical-align: top; font-size: 14px; }
th { background: #f8fafc; color: var(--muted); text-transform: uppercase; letter-spacing: .05em; font-size: 12px; }
.table-actions { display: flex; gap: 6px; flex-wrap: wrap; min-width: 220px; }
.mini-status { display: grid; gap: 4px; min-width: 130px; }
.mini-status span { display: inline-flex; width: fit-content; max-width: 180px; padding: 4px 8px; border-radius: 999px; background: #eef6f5; color: #0f766e; font-size: 12px; font-weight: 850; line-height: 1.2; }
.billing-list { display: grid; gap: 8px; }
.billing-list p { display: flex; justify-content: space-between; gap: 16px; border-bottom: 1px solid #edf2f7; padding: 8px 0; margin: 0; }
.billing-list p:last-child { border-bottom: 0; }
.billing-list strong { color: var(--ink); }
.billing-list span { color: var(--muted); text-align: right; }
.toggle-row { min-height: 42px; border: 1px solid var(--line); border-radius: 10px; padding: 10px 12px; background: #f8fafc; display: flex; align-items: center; gap: 8px; color: #344054; font-weight: 850; }
.toggle-row input { width: auto; }
.priority-high { color: var(--danger); font-weight: 900; }
.priority-medium { color: var(--warn); font-weight: 900; }
.priority-low { color: var(--ok); font-weight: 900; }
.progress { height: 9px; background: #e7edf3; border-radius: 999px; overflow: hidden; margin-bottom: 10px; }
.progress span, .progress i { display: block; height: 100%; background: linear-gradient(90deg, var(--brand), var(--brand-2)); }
.journey-page-grid { padding: 14px; display: grid; gap: 12px; }
.journey-page-grid article { border: 1px solid var(--line); border-radius: 14px; background: #fff; padding: 14px; display: grid; grid-template-columns: 42px minmax(0, 1fr) auto; gap: 14px; align-items: center; }
.journey-page-grid article.complete { background: linear-gradient(180deg, #f3fbf8, #fff); border-color: rgba(15,118,110,.28); }
.journey-page-grid article > span { width: 38px; height: 38px; border-radius: 999px; display: grid; place-items: center; color: #fff; background: #111827; font-weight: 950; }
.journey-page-grid h3 { margin: 0 0 4px; }
.journey-page-grid p { margin: 0 0 8px; color: var(--muted); line-height: 1.45; }
.journey-page-grid small { color: var(--muted); font-weight: 800; }
.score-ring { width: 148px; height: 148px; border-radius: 50%; display: grid; place-items: center; margin: 8px auto 18px; background: conic-gradient(var(--brand) calc(var(--score) * 1%), #e8edf3 0); }
.score-ring div { width: 110px; height: 110px; background: #fff; border-radius: 50%; display: grid; place-items: center; font-size: 30px; font-weight: 950; }
.panel-body p { display: flex; justify-content: space-between; gap: 12px; }
.heatmap { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; }
.heatmap div { border-radius: 12px; padding: 14px; display: grid; gap: 6px; min-height: 88px; min-width: 0; }
.heatmap strong, .heatmap span { overflow-wrap: anywhere; }
.heatmap .hot { background: #fff1f0; color: #912018; }
.heatmap .warm { background: #fff7e6; color: #93370d; }
.heatmap .cool { background: #e8f5ee; color: #0e5f3d; }
.template-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; }
.template-card { padding: 18px; display: grid; gap: 12px; }
.template-card p { color: var(--muted); line-height: 1.55; }
.report-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; }
.report-card button { margin-top: auto; }
.report-preview { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 6px; }
.report-preview span { border-radius: 10px; padding: 8px; background: #f8fafc; color: #344054; font-size: 12px; font-weight: 850; line-height: 1.35; }
.task-board-panel { overflow: hidden; }
.task-compact-list { display: grid; gap: 10px; padding: 12px; }
.task-compact-card { display: grid; grid-template-columns: minmax(0, 1.65fr) minmax(260px, .72fr) minmax(132px, .34fr); gap: 14px; align-items: center; padding: 16px 18px; border: 1px solid #e5e9ef; border-radius: 14px; background: #fff; box-shadow: 0 7px 22px rgba(15,23,42,.04); min-height: 148px; }
.task-compact-card:hover { border-color: rgba(15,118,110,.24); box-shadow: 0 12px 30px rgba(15,23,42,.065); }
.task-compact-main, .task-compact-meta, .task-compact-actions { min-width: 0; }
.task-title-block { display: grid; gap: 5px; margin-bottom: 14px; }
.task-title-block .eyebrow { color: var(--brand); font-size: 12px; line-height: 1.25; letter-spacing: .14em; }
.task-title-block h3 { margin: 0; font-size: 22px; line-height: 1.18; letter-spacing: 0; }
.task-title-block p { margin: 0; color: var(--muted); font-size: 15px; line-height: 1.42; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; max-width: 760px; }
.task-title-block p strong { color: #344054; }
.task-pill-row { display: flex; gap: 8px; flex-wrap: wrap; }
.task-pill-row .priority-badge, .task-pill-row .source-badge { padding: 7px 10px; font-size: 12px; }
.task-compact-meta { display: flex; flex-wrap: wrap; gap: 8px; align-content: center; min-width: 0; }
.meta-chip { max-width: 100%; min-width: 0; display: inline-flex; align-items: center; gap: 4px; border-radius: 999px; background: #f8fafc; border: 1px solid #e6ebf1; color: #475467; padding: 7px 10px; font-size: 13px; line-height: 1.2; font-weight: 750; overflow: hidden; }
.meta-chip b { color: #667085; font-size: 11px; text-transform: uppercase; letter-spacing: .04em; flex: 0 0 auto; }
.meta-chip span { min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.meta-chip.wide { flex: 1 1 100%; border-radius: 12px; align-items: flex-start; }
.meta-chip.wide span { white-space: normal; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; line-height: 1.28; overflow: hidden; }
.task-compact-actions { display: grid; gap: 7px; justify-items: stretch; min-width: 0; align-content: center; }
.task-compact-actions .btn { min-height: 36px; padding: 7px 10px; font-size: 13px; border-radius: 10px; font-weight: 820; }
.task-compact-actions .btn.ghost { border-color: transparent; color: #475467; }
.task-compact-actions .primary-action { background: var(--brand); color: #fff; border-color: var(--brand); }
.status-select-wrap, .status-pill { height: 34px; border-radius: 999px; border: 1px solid #dbe3ed; background: #f8fafc; display: flex; align-items: center; gap: 7px; padding: 0 10px; color: #344054; font-size: 13px; font-weight: 850; min-width: 0; }
.status-select-wrap i, .status-pill i { width: 8px; height: 8px; border-radius: 999px; background: #98a2b3; flex: 0 0 auto; }
.status-select-wrap select { width: 100%; height: 32px; min-height: 0; border: 0; background: transparent; padding: 0 14px 0 0; color: inherit; font-size: 13px; font-weight: 850; outline: 0; appearance: auto; }
.status-select-wrap.to-do i, .status-pill.suggested i { background: #98a2b3; }
.status-select-wrap.in-progress i { background: #2563eb; }
.status-select-wrap.blocked i { background: #b42318; }
.status-select-wrap.completed i { background: #0f766e; }
.status-select-wrap.to-do { background: #f8fafc; }
.status-select-wrap.in-progress { background: #eff6ff; border-color: #bfdbfe; color: #1d4ed8; }
.status-select-wrap.blocked { background: #fff1f0; border-color: #fecaca; color: #b42318; }
.status-select-wrap.completed { background: #ecfdf3; border-color: #bbf7d0; color: #0f766e; }
@media (min-width: 1500px) {
  .task-compact-card { grid-template-columns: minmax(620px, 1.6fr) minmax(360px, .72fr) minmax(150px, .3fr); }
}
.guide-overlay { position: fixed; inset: 0; z-index: 25; background: rgba(15,23,42,.28); display: flex; justify-content: flex-end; }
.guide-panel { width: min(40vw, 620px); min-width: 440px; height: 100vh; background: #f3fbfa; border-left: 1px solid rgba(15,118,110,.2); box-shadow: -24px 0 60px rgba(15,23,42,.2); display: grid; grid-template-rows: auto 1fr; }
.guide-panel-head { padding: 18px 18px 14px; background: linear-gradient(180deg, #f7f8ff, #f3fbfa); border-bottom: 1px solid rgba(15,118,110,.16); display: flex; justify-content: space-between; gap: 12px; align-items: start; }
.guide-panel-head h2 { margin: 4px 0 6px; font-size: 24px; line-height: 1.15; }
.guide-panel-head p { margin: 0; color: var(--muted); line-height: 1.45; }
.guide-panel-body { overflow: auto; padding: 12px; display: grid; gap: 8px; align-content: start; }
.guide-panel-body .guide-card { background: rgba(255,255,255,.97); border-color: rgba(15,118,110,.16); box-shadow: 0 1px 2px rgba(15,23,42,.035); }
.guide-panel-body .evidence-cards, .guide-panel-body .check-grid { grid-template-columns: 1fr; }
.task-priority-group { display: grid; gap: 0; }
.task-priority-group + .task-priority-group { border-top: 1px solid var(--line); }
.dropzone { border: 1px dashed #94a3b8; border-radius: 12px; padding: 18px; background: #f8fafc; display: grid; gap: 10px; }
.empty { margin: 16px; padding: 28px; text-align: center; color: var(--muted); background: #f8fafc; border: 1px dashed #cbd5e1; border-radius: 12px; }
.modal-backdrop { position: fixed; inset: 0; z-index: 20; display: grid; place-items: center; padding: 18px; background: rgba(15,23,42,.5); }
.modal { width: min(760px, 100%); max-height: 90vh; overflow: auto; background: #fff; border-radius: 14px; box-shadow: var(--shadow); }
.modal .panel-head { position: sticky; top: 0; background: #fff; z-index: 1; }
.activity-list { padding: 10px 16px; }
.activity-list p { display: grid; gap: 2px; border-bottom: 1px solid var(--line); padding: 10px 0; }
.activity-list span, .limit-list { color: var(--muted); }
.toast { position: fixed; right: 20px; bottom: 20px; z-index: 30; max-width: 380px; background: #111827; color: #fff; border-radius: 12px; padding: 12px 14px; box-shadow: var(--shadow); }
@media (max-width: 1080px) {
  .public-shell, .app-shell, .grid.two { grid-template-columns: 1fr; }
  .public-hero { min-height: auto; padding: 36px; }
  .landing-hero { min-height: auto; padding: 22px 24px 52px; }
  .landing-nav { margin-bottom: 34px; }
  .landing-hero-grid { grid-template-columns: 1fr; }
  .product-mockup { max-width: 820px; }
  .section-head, .timeline-section, .choose-section { flex-direction: column; }
  .flow-grid, .feature-grid, .persona-grid, .preview-grid, .coach-grid, .industry-guide-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .countdown-card { width: 100%; }
  .sidebar { position: fixed; inset: 0 auto 0 0; width: 286px; z-index: 10; transform: translateX(-105%); transition: transform .2s ease; }
  .sidebar.open { transform: translateX(0); }
  .mobile-menu { display: inline-flex; }
  .metrics, .command-metrics, .action-summary, .recommended-action-list, .template-grid, .report-grid, .framework-card-grid, .framework-library-grid, .framework-strip, .stage-roadmap, .how-works, .tour-strip { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .command-grid.grid.two { grid-template-columns: 1fr; }
  .welcome-panel { grid-template-columns: 1fr; }
  .task-compact-card { grid-template-columns: minmax(0, 1.45fr) minmax(220px, .72fr) minmax(120px, .36fr); align-items: center; }
  .task-compact-actions { grid-template-columns: 1fr; }
  .guide-panel { width: min(520px, 92vw); min-width: 0; }
  .stage-roadmap div:after { display: none; }
}
@media (max-width: 680px) {
  .public-hero, .page, .topbar { padding-left: 16px; padding-right: 16px; }
  .public-hero h1 { font-size: 40px; }
  .landing-shell { background: linear-gradient(180deg, #07111f 0%, #0b1220 35%, #eef2f7 35%, #eef2f7 100%); }
  .landing-hero { padding: 18px 16px 38px; }
  .landing-nav { align-items: flex-start; }
  .landing-copy h1 { font-size: 42px; }
  .landing-copy p { font-size: 16px; }
  .landing-actions .btn, .landing-nav .btn { width: 100%; }
  .landing-microcopy { display: grid; }
  .product-mockup { padding: 10px; border-radius: 14px; }
  .mockup-metrics, .mockup-main, .comparison-grid, .flow-grid, .feature-grid, .persona-grid, .preview-grid, .coach-grid, .industry-guide-grid, .countdown-card, .exposure-card, .report-preview, .action-summary, .recommended-action-list { grid-template-columns: 1fr; }
  .mockup-panel { min-height: auto; }
  .landing-section { width: calc(100% - 24px); padding: 18px; border-radius: 14px; }
  .landing-section h2 { font-size: 30px; }
  .choose-list { display: grid; width: 100%; }
  .auth-card.landing-auth-card { margin: 22px auto 46px; }
  .topbar, .page-head { height: auto; flex-direction: column; align-items: stretch; }
  .topbar { padding-top: 14px; padding-bottom: 14px; }
  .hero-grid, .glass-list, .oauth-grid, .metrics, .command-metrics, .template-grid, .report-grid, .framework-card-grid, .framework-library-grid, .framework-strip, .guidance-grid, .check-grid, .evidence-cards, .toolbar, .toolbar.wide, .form-grid, .onboarding-summary, .heatmap, .stage-roadmap, .momentum-grid, .how-works, .clock-card, .tour-strip, .journey-page-grid article { grid-template-columns: 1fr; }
  .command-hero { padding: 22px; }
  .do-next-panel { flex-direction: column; align-items: stretch; }
  .clock { width: 170px; justify-self: center; }
  .task-compact-meta, .task-compact-actions { grid-template-columns: 1fr; }
  .task-compact-card { grid-template-columns: 1fr; align-items: stretch; }
  .guide-panel { width: 100vw; }
  .actions .btn, .actions select, .actions input { width: 100%; }
  table { min-width: 760px; }
}
