:root {
  --ink: #17352f;
  --forest: #214f42;
  --forest-dark: #153a31;
  --sage: #9ab09a;
  --mist: #eef2e9;
  --paper: #f9f7f0;
  --sun: #e58a48;
  --line: #d9dfd4;
  --white: #fffefa;
  color: var(--ink);
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  line-height: 1.5;
}

* { box-sizing: border-box; }
html { background: var(--paper); }
body { margin: 0; background: var(--paper); color: var(--ink); }
a { color: inherit; }
.site-header { align-items: center; display: grid; grid-template-columns: 1fr auto 1fr; margin: 0 auto; max-width: 1240px; padding: 24px 32px; }
.brand { align-items: center; display: inline-flex; font-size: 21px; font-weight: 800; gap: 9px; text-decoration: none; width: max-content; }
.brand em { color: var(--sun); font-style: normal; }
.brand-mark { color: var(--forest); font-size: 17px; transform: scaleX(1.25); }
nav { display: flex; gap: 34px; }
nav a { color: #47645d; font-size: 14px; font-weight: 650; padding: 8px 0; text-decoration: none; }
nav a[aria-current="page"] { border-bottom: 2px solid var(--sun); color: var(--forest-dark); }
.header-cta { background: var(--forest); border-radius: 999px; color: white; font-size: 13px; font-weight: 750; justify-self: end; padding: 11px 20px; text-decoration: none; }
main { min-height: calc(100vh - 180px); }
.hero, .page-hero, .feature-grid, .section-heading, .route-grid, .steps-list, .callout, .quote-grid, .values-grid { margin-left: auto; margin-right: auto; max-width: 1180px; }
.hero { align-items: center; display: grid; gap: 64px; grid-template-columns: 1.05fr .95fr; min-height: 650px; padding: 74px 32px 92px; }
.eyebrow { color: var(--sun); font-size: 12px; font-weight: 850; letter-spacing: .15em; margin: 0 0 20px; text-transform: uppercase; }
h1, h2, h3, p { margin-top: 0; }
h1 { color: var(--forest-dark); font-family: Georgia, "Times New Roman", serif; font-size: clamp(58px, 7vw, 94px); font-weight: 500; letter-spacing: -.055em; line-height: .94; margin-bottom: 28px; }
h1 em, h2 em { color: var(--sun); font-style: italic; }
.lede { color: #536c65; font-size: 18px; line-height: 1.75; max-width: 610px; }
.actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 34px; }
.button { border-radius: 999px; display: inline-block; font-size: 14px; font-weight: 800; padding: 14px 24px; text-decoration: none; }
.button-primary { background: var(--forest); color: white; }
.button-secondary { border: 1px solid var(--forest); color: var(--forest); }
.summit-card { background: linear-gradient(155deg, #f0d7b5 0%, #dfe5d6 58%, #b7c8b7 100%); border-radius: 180px 180px 24px 24px; box-shadow: 0 30px 70px rgba(28, 65, 54, .16); height: 510px; overflow: hidden; position: relative; }
.sun { background: #f1ac66; border-radius: 50%; height: 112px; position: absolute; right: 70px; top: 72px; width: 112px; }
.mountain { bottom: 116px; clip-path: polygon(50% 0, 100% 100%, 0 100%); position: absolute; }
.mountain-back { background: #8ba18e; height: 250px; left: -70px; width: 460px; }
.mountain-front { background: linear-gradient(135deg, #f7f6ed 0 25%, #58766a 26% 100%); height: 335px; right: -100px; width: 560px; }
.summit-card-copy { backdrop-filter: blur(8px); background: rgba(255, 254, 250, .88); bottom: 0; left: 0; padding: 22px 30px 25px; position: absolute; right: 0; }
.summit-card-copy span, .summit-card-copy small { color: #6f807a; display: block; font-size: 11px; font-weight: 750; letter-spacing: .08em; text-transform: uppercase; }
.summit-card-copy strong { display: block; font-family: Georgia, serif; font-size: 25px; margin: 3px 0 14px; }
.progress-track { background: #dbe2d9; border-radius: 10px; height: 7px; margin-bottom: 10px; overflow: hidden; }
.progress-track span { background: var(--sun); border-radius: inherit; height: 100%; }
.stats { background: var(--forest); color: white; display: grid; grid-template-columns: repeat(3, 1fr); padding: 34px max(32px, calc((100vw - 1116px) / 2)); }
.stats div { border-right: 1px solid rgba(255,255,255,.18); display: flex; flex-direction: column; padding: 8px 50px; text-align: center; }
.stats div:last-child { border: 0; }
.stats strong { font-family: Georgia, serif; font-size: 34px; font-weight: 500; }
.stats span { color: #c3d1ca; font-size: 11px; letter-spacing: .08em; text-transform: uppercase; }
.section-heading { padding: 110px 32px 54px; text-align: center; }
.section-heading h2, .callout h2 { font-family: Georgia, serif; font-size: clamp(36px, 5vw, 54px); font-weight: 500; letter-spacing: -.035em; line-height: 1.1; margin-bottom: 18px; }
.section-heading > p:last-child { color: #667a74; margin: auto; max-width: 580px; }
.feature-grid { display: grid; gap: 20px; grid-template-columns: repeat(3, 1fr); padding: 0 32px 120px; }
.feature-card { background: var(--white); border: 1px solid var(--line); border-radius: 16px; padding: 30px; }
.feature-number { color: var(--sun); font-family: Georgia, serif; font-size: 28px; }
.feature-card h3 { font-family: Georgia, serif; font-size: 25px; margin: 42px 0 10px; }
.feature-card p, .values-grid p, .route-copy p, .steps-list p { color: #647871; }
.page-hero { padding: 110px 32px 74px; text-align: center; }
.page-hero h1 { font-size: clamp(56px, 7vw, 84px); }
.page-hero .lede { margin-left: auto; margin-right: auto; }
.page-hero.compact { padding-bottom: 55px; }
.steps-list { border-top: 1px solid var(--line); padding: 0 32px 90px; }
.steps-list article { align-items: start; border-bottom: 1px solid var(--line); display: grid; gap: 42px; grid-template-columns: 90px 1fr; padding: 42px 0; }
.steps-list article > span { color: var(--sun); font-family: Georgia, serif; font-size: 34px; }
.steps-list h2, .values-grid h2 { font-family: Georgia, serif; font-size: 32px; font-weight: 500; margin-bottom: 8px; }
.callout { align-items: center; background: var(--mist); border-radius: 20px; display: flex; justify-content: space-between; margin-bottom: 110px; padding: 48px 54px; }
.callout h2 { margin: 0; max-width: 600px; }
.route-grid { display: grid; gap: 22px; grid-template-columns: repeat(3, 1fr); padding: 0 32px 120px; }
.route-card { background: var(--white); border: 1px solid var(--line); border-radius: 18px; overflow: hidden; }
.route-art { align-items: end; background-color: var(--sage); display: flex; height: 245px; overflow: hidden; padding: 18px; position: relative; }
.route-art::before, .route-art::after { bottom: -30px; clip-path: polygon(50% 0, 100% 100%, 0 100%); content: ""; height: 210px; position: absolute; width: 330px; }
.route-art::before { background: rgba(255,255,255,.52); left: -70px; }
.route-art::after { background: var(--forest); right: -80px; }
.route-rainier { background: #b9c9ba; }
.route-whitney { background: #e2cbb1; }
.route-cadillac { background: #aebebc; }
.route-art span { background: rgba(255,255,255,.88); border-radius: 99px; font-size: 10px; font-weight: 800; letter-spacing: .1em; padding: 7px 11px; position: relative; text-transform: uppercase; z-index: 1; }
.route-copy { padding: 25px 26px 28px; }
.route-meta { color: var(--sun) !important; font-size: 10px; font-weight: 850; letter-spacing: .1em; text-transform: uppercase; }
.route-copy h2 { font-family: Georgia, serif; font-size: 30px; font-weight: 500; margin-bottom: 10px; }
.route-copy a { color: var(--forest); font-size: 13px; font-weight: 800; text-decoration: none; }
.route-copy a span { color: var(--sun); margin-left: 5px; }
.quote-grid { display: grid; gap: 22px; grid-template-columns: 1.15fr .85fr; padding: 0 32px 80px; }
blockquote { background: var(--forest); border-radius: 18px; color: white; margin: 0; padding: 50px; }
blockquote:nth-child(2) { background: var(--sun); }
blockquote p { font-family: Georgia, serif; font-size: 29px; line-height: 1.35; }
blockquote footer { font-size: 11px; font-weight: 800; letter-spacing: .1em; opacity: .7; text-transform: uppercase; }
.values-grid { display: grid; gap: 40px; grid-template-columns: repeat(3, 1fr); padding: 0 32px 120px; }
.values-grid article > span { color: var(--sun); font-size: 26px; }
.values-grid h2 { margin-top: 22px; }
.error-page { min-height: 650px; }
.site-footer { align-items: center; border-top: 1px solid var(--line); color: #70827c; display: grid; font-size: 12px; gap: 20px; grid-template-columns: 1fr auto 1fr; margin: 0 auto; max-width: 1180px; padding: 34px 32px; }
.site-footer p { margin: 0; }
.site-footer > span { justify-self: end; }
.footer-brand { color: var(--ink); font-size: 17px; }

@media (max-width: 850px) {
  .site-header { grid-template-columns: 1fr auto; padding: 20px; }
  nav { display: none; }
  .hero { gap: 48px; grid-template-columns: 1fr; padding: 70px 22px; }
  .summit-card { height: 440px; margin: auto; max-width: 520px; width: 100%; }
  .stats { grid-template-columns: 1fr; padding: 18px 22px; }
  .stats div { border-bottom: 1px solid rgba(255,255,255,.18); border-right: 0; padding: 18px; }
  .feature-grid, .route-grid, .values-grid, .quote-grid { grid-template-columns: 1fr; padding-left: 22px; padding-right: 22px; }
  .callout { align-items: flex-start; flex-direction: column; gap: 28px; margin-left: 22px; margin-right: 22px; padding: 34px; }
  .site-footer { grid-template-columns: 1fr; padding: 30px 22px; text-align: left; }
  .site-footer > span { justify-self: start; }
}

@media (max-width: 520px) {
  .header-cta { font-size: 11px; padding: 10px 14px; }
  h1 { font-size: 54px; }
  .hero { min-height: auto; }
  .summit-card { border-radius: 120px 120px 20px 20px; height: 380px; }
  .steps-list article { gap: 12px; grid-template-columns: 1fr; }
}

/* Account, database status, and focused-group screens */
.account-actions { align-items: center; display: flex; gap: 14px; justify-content: end; }
.text-link { color: var(--forest); font-size: 12px; font-weight: 800; text-decoration: none; }
.button-reset { border: 0; cursor: pointer; font: inherit; }
.data-status { color: #667a74; font-size: 12px; margin: 0 32px 24px; text-align: center; }
.data-status.warning { color: #936216; }
.auth-layout { align-items: start; display: grid; gap: clamp(50px, 8vw, 110px); grid-template-columns: 1fr minmax(340px, 480px); min-height: 720px; padding: 100px 32px 120px; }
.auth-intro { padding-top: 34px; }
.auth-intro h1 { font-size: clamp(54px, 6vw, 78px); }
.auth-points { color: #587069; display: grid; gap: 13px; list-style: none; margin: 38px 0 0; padding: 0; }
.auth-points li::before { color: var(--sun); content: "◆"; font-size: 10px; margin-right: 12px; }
.auth-panel { background: var(--white); border: 1px solid var(--line); border-radius: 20px; box-shadow: 0 22px 70px rgba(23,59,50,.08); padding: 34px; }
.auth-tabs { border-bottom: 1px solid var(--line); display: flex; gap: 26px; margin-bottom: 28px; }
.auth-tabs a { color: #71837d; font-size: 12px; font-weight: 850; padding: 0 0 13px; text-decoration: none; text-transform: uppercase; }
.auth-tabs a[aria-current="page"] { border-bottom: 2px solid var(--sun); color: var(--forest); }
.auth-panel form { display: grid; gap: 20px; }
.auth-panel label { color: var(--forest); display: grid; font-size: 11px; font-weight: 850; gap: 8px; letter-spacing: .05em; text-transform: uppercase; }
.auth-panel input, .auth-panel select { background: #fbfcfa; border: 1px solid #ccd7d2; border-radius: 10px; color: var(--ink); font: inherit; font-size: 15px; padding: 13px 14px; text-transform: none; width: 100%; }
.auth-panel input:focus, .auth-panel select:focus { border-color: var(--sun); outline: 3px solid rgba(224,155,45,.16); }
.optional-group { border-top: 1px solid var(--line); display: grid; gap: 18px; margin-top: 5px; padding-top: 22px; }
.optional-group > p { color: #71837d; font-size: 12px; margin: 0; }
.form-message { color: #667a74; font-size: 13px; margin: 0; min-height: 20px; }
.form-message.error { color: #a13d2d; }
.form-message.success { color: #287151; }
.auth-panel button:disabled { cursor: wait; opacity: .65; }
.forgot-password-link { color: var(--forest); font-size: 13px; font-weight: 750; justify-self: end; margin-top: -10px; text-decoration-color: var(--sun); text-underline-offset: 4px; }
.auth-back-link { color: #587069; font-size: 13px; font-weight: 750; justify-self: center; text-decoration-color: #b5c2bd; text-underline-offset: 4px; }
.forgot-password-link:hover, .auth-back-link:hover { color: #b36f0b; }
.dashboard-hero { padding-bottom: 44px; }
.dashboard-panel { min-height: 360px; padding: 0 32px 120px; }
.team-grid { display: grid; gap: 22px; grid-template-columns: repeat(3, 1fr); }
.team-card, .empty-state { background: var(--white); border: 1px solid var(--line); border-radius: 18px; padding: 30px; }
.team-card > span { color: var(--sun); font-size: 10px; font-weight: 850; letter-spacing: .1em; text-transform: uppercase; }
.team-card h2, .empty-state h2 { font-family: Georgia, serif; font-size: 31px; font-weight: 500; }
.team-card dl { border-top: 1px solid var(--line); display: grid; gap: 12px; margin: 25px 0 0; padding-top: 20px; }
.team-card dl div { align-items: center; display: flex; justify-content: space-between; }
.team-card dt { color: #71837d; font-size: 12px; }
.team-card dd { color: var(--forest); font-size: 13px; font-weight: 800; margin: 0; text-transform: capitalize; }
.empty-state { margin: auto; max-width: 680px; text-align: center; }
.empty-state p:last-child { color: #667a74; }

@media (max-width: 850px) {
  .account-actions .text-link { display: none; }
  .auth-layout { grid-template-columns: 1fr; padding: 60px 22px 90px; }
  .auth-intro { padding-top: 0; }
  .team-grid { grid-template-columns: 1fr; }
  .dashboard-panel { padding-left: 22px; padding-right: 22px; }
}

@media (max-width: 520px) {
  .auth-panel { padding: 25px 20px; }
  .account-actions { gap: 6px; }
}

/* Signed-in application shell */
body:has(.app-shell) > .site-header, body:has(.app-shell) > .site-footer { display: none; }
body:has(.app-shell) { background: #f3f3ed; }
.app-shell { display: grid; grid-template-columns: 250px minmax(0, 1fr); min-height: 100vh; }
.app-sidebar { background: var(--forest); color: #fff; display: flex; flex-direction: column; min-height: 100vh; padding: 30px 22px 24px; position: sticky; top: 0; }
.app-home { align-items: center; color: #fff; display: flex; font-family: Georgia, serif; font-size: 20px; gap: 11px; margin: 0 10px 48px; text-decoration: none; }
.app-home .brand-mark { color: var(--sun); font-size: 18px; }
.app-sidebar nav { display: grid; gap: 6px; }
.app-sidebar nav a, .sidebar-footer a { align-items: center; border-radius: 10px; color: #bcd0c8; display: flex; font-size: 13px; font-weight: 700; gap: 13px; padding: 12px 13px; text-decoration: none; }
.app-sidebar nav a span, .sidebar-footer a span { color: #e4aa4b; font-size: 17px; text-align: center; width: 19px; }
.app-sidebar a[aria-current="page"], .app-sidebar nav a:hover, .sidebar-footer a:hover { background: rgba(255,255,255,.1); color: #fff; }
.sidebar-footer { border-top: 1px solid rgba(255,255,255,.12); margin-top: auto; padding-top: 18px; }
.sidebar-footer p { color: #77958a; font-size: 10px; letter-spacing: .08em; margin: 20px 13px 0; text-transform: uppercase; }
.app-main { min-width: 0; }
.app-topbar { align-items: center; background: rgba(250,250,246,.94); border-bottom: 1px solid #dfe3da; display: flex; justify-content: space-between; padding: 20px clamp(24px, 4vw, 54px); position: sticky; top: 0; z-index: 3; }
.app-topbar .eyebrow { margin: 0 0 4px; }
.app-topbar h1 { font-family: Georgia, serif; font-size: 25px; font-weight: 500; margin: 0; }
.profile-chip { align-items: center; color: var(--ink); display: flex; gap: 11px; text-decoration: none; }
.profile-chip > span:first-child, .profile-avatar { align-items: center; background: #dfeae5; border: 1px solid #bfd1c9; border-radius: 50%; color: var(--forest); display: flex; font-size: 12px; font-weight: 850; height: 42px; justify-content: center; width: 42px; }
.profile-chip > span:last-child { display: grid; gap: 2px; }
.profile-chip strong { font-size: 12px; }
.profile-chip small { color: #71837d; font-size: 10px; }
.dashboard-content, .settings-content { margin: 0 auto; max-width: 1280px; padding: 42px clamp(24px, 4vw, 54px) 80px; }
.dashboard-welcome { align-items: end; background: linear-gradient(120deg, #fbfcf8 0%, #edf1e8 100%); border: 1px solid #d9dfd5; border-radius: 20px; display: flex; justify-content: space-between; overflow: hidden; padding: 36px 38px; position: relative; }
.dashboard-welcome::after { border: 30px solid rgba(35,91,76,.06); border-radius: 50%; content: ""; height: 170px; position: absolute; right: 90px; top: -100px; width: 170px; }
.dashboard-welcome h2, .settings-intro h2 { font-family: Georgia, serif; font-size: clamp(32px, 4vw, 48px); font-weight: 500; margin: 4px 0 12px; }
.dashboard-welcome p:last-child, .settings-intro > p:last-child { color: #61766f; line-height: 1.7; margin: 0; max-width: 650px; }
.dashboard-welcome .button { position: relative; z-index: 1; }
.dashboard-metrics { display: grid; gap: 16px; grid-template-columns: repeat(3, 1fr); margin: 20px 0 48px; }
.dashboard-metrics article { background: #fbfcf8; border: 1px solid #d9dfd5; border-radius: 15px; display: grid; padding: 22px 24px; }
.dashboard-metrics span { color: #6b7c76; font-size: 11px; font-weight: 800; text-transform: uppercase; }
.dashboard-metrics strong { color: var(--forest); font-family: Georgia, serif; font-size: 35px; font-weight: 500; margin: 8px 0 3px; }
.dashboard-metrics small { color: #87948f; font-size: 11px; }
.dashboard-section { margin-top: 46px; scroll-margin-top: 110px; }
.section-title { align-items: end; display: flex; justify-content: space-between; margin-bottom: 18px; }
.section-title h2 { font-family: Georgia, serif; font-size: 30px; font-weight: 500; margin: 3px 0 0; }
.quiet-action { background: transparent; border: 0; color: #81908b; font-size: 12px; font-weight: 800; }
.dashboard-panel { min-height: 0; padding: 0; }
.team-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.team-card { background: #fbfcf8; }
.team-card-top { align-items: center; display: flex; justify-content: space-between; }
.team-card-top > span:first-child { color: var(--sun); font-size: 10px; font-weight: 850; letter-spacing: .1em; text-transform: uppercase; }
.status-dot { color: #39745e; font-size: 10px; }
.status-dot::before { background: #59a083; border-radius: 50%; content: ""; display: inline-block; height: 6px; margin-right: 5px; width: 6px; }
.team-card > button { background: none; border: 0; border-top: 1px solid var(--line); color: #87948f; font-size: 11px; font-weight: 800; margin-top: 20px; padding: 17px 0 0; text-align: left; width: 100%; }
.dashboard-empty { align-items: center; display: grid; gap: 24px; grid-template-columns: auto 1fr auto; margin: 0; max-width: none; text-align: left; }
.empty-icon { align-items: center; background: #edf2ee; border-radius: 50%; color: var(--forest); display: flex; font-size: 30px; height: 68px; justify-content: center; width: 68px; }
.dashboard-empty h2 { margin: 3px 0 6px; }
.dashboard-empty p { margin: 0; }
.roadmap-grid { display: grid; gap: 16px; grid-template-columns: repeat(2, minmax(0, 1fr)); }
.roadmap-grid article { background: #fbfcf8; border: 1px solid #d9dfd5; border-radius: 16px; display: grid; gap: 18px; grid-template-columns: auto 1fr; padding: 25px; }
.roadmap-icon { align-items: center; background: #f7ead2; border-radius: 11px; color: #a66b16; display: flex; font-size: 22px; height: 48px; justify-content: center; width: 48px; }
.roadmap-grid small { color: #b2761f; font-size: 9px; font-weight: 850; letter-spacing: .1em; text-transform: uppercase; }
.roadmap-grid h3 { font-family: Georgia, serif; font-size: 23px; font-weight: 500; margin: 5px 0 7px; }
.roadmap-grid p { color: #687a74; font-size: 13px; line-height: 1.6; margin: 0; }
.settings-intro { margin-bottom: 38px; }
.settings-layout { align-items: start; display: grid; gap: 34px; grid-template-columns: 190px minmax(0, 760px); }
.settings-nav { display: grid; gap: 5px; position: sticky; top: 120px; }
.settings-nav a { border-left: 2px solid transparent; color: #71817c; font-size: 12px; font-weight: 750; padding: 9px 13px; text-decoration: none; }
.settings-nav a[aria-current="page"] { border-color: var(--sun); color: var(--forest); }
.settings-panels { display: grid; gap: 20px; }
.settings-card { background: #fbfcf8; border: 1px solid #d9dfd5; border-radius: 18px; padding: 30px; scroll-margin-top: 110px; }
.settings-card-heading { align-items: start; border-bottom: 1px solid var(--line); display: flex; justify-content: space-between; margin-bottom: 26px; padding-bottom: 20px; }
.settings-card-heading h2 { font-family: Georgia, serif; font-size: 27px; font-weight: 500; margin: 4px 0 0; }
.status-pill { background: #e2efe8; border-radius: 999px; color: #317055; font-size: 9px; font-weight: 850; padding: 6px 9px; text-transform: uppercase; }
.status-pill.muted { background: #eceee9; color: #78847f; }
.settings-card form, .placeholder-settings { display: grid; gap: 19px; }
.settings-card label { color: var(--forest); display: grid; font-size: 10px; font-weight: 850; gap: 8px; letter-spacing: .05em; text-transform: uppercase; }
.settings-card input, .settings-card select { background: #fff; border: 1px solid #ccd7d2; border-radius: 9px; color: var(--ink); font: inherit; padding: 12px 13px; text-transform: none; width: 100%; }
.settings-card form .button { justify-self: start; }
.avatar-row { align-items: center; display: flex; gap: 14px; margin-bottom: 4px; }
.profile-avatar { flex: 0 0 54px; font-size: 15px; height: 54px; width: 54px; }
.avatar-row p { color: #788781; font-size: 11px; margin: 4px 0 0; }
.placeholder-settings { grid-template-columns: 1fr 1fr; }
.setting-row { align-items: center; display: flex; justify-content: space-between; padding: 9px 0; }
.setting-row + .setting-row { border-top: 1px solid var(--line); margin-top: 10px; padding-top: 20px; }
.setting-row strong { font-size: 13px; }
.setting-row p, .settings-note { color: #74837e; font-size: 12px; margin: 5px 0 0; }
.fake-toggle { background: #d9ded9; border-radius: 999px; height: 22px; position: relative; width: 38px; }
.fake-toggle::after { background: #fff; border-radius: 50%; box-shadow: 0 1px 3px rgba(0,0,0,.15); content: ""; height: 16px; left: 3px; position: absolute; top: 3px; width: 16px; }
@media (max-width: 900px) {
  .app-shell { grid-template-columns: 76px minmax(0, 1fr); }
  .app-sidebar { padding-left: 12px; padding-right: 12px; }
  .app-home span:last-child, .app-sidebar nav a:not([aria-current])::after, .app-sidebar nav a { font-size: 0; }
  .app-sidebar nav a, .sidebar-footer a { justify-content: center; }
  .app-sidebar nav a span, .sidebar-footer a span { font-size: 18px; }
  .sidebar-footer p { display: none; }
  .team-grid { grid-template-columns: 1fr; }
}
@media (max-width: 700px) {
  .app-shell { display: block; }
  .app-sidebar { bottom: 0; flex-direction: row; min-height: auto; padding: 8px; position: fixed; top: auto; width: 100%; z-index: 10; }
  .app-home, .sidebar-footer { display: none; }
  .app-sidebar nav { display: flex; justify-content: space-around; width: 100%; }
  .app-sidebar nav a { padding: 10px; }
  .app-sidebar nav a:nth-child(n+4) { display: none; }
  .app-topbar { padding: 16px 20px; }
  .profile-chip > span:last-child { display: none; }
  .dashboard-content, .settings-content { padding: 30px 20px 100px; }
  .dashboard-welcome { align-items: start; display: grid; gap: 24px; padding: 28px; }
  .dashboard-metrics { grid-template-columns: 1fr; }
  .roadmap-grid { grid-template-columns: 1fr; }
  .dashboard-empty { grid-template-columns: 1fr; text-align: center; }
  .empty-icon { margin: auto; }
  .settings-layout { grid-template-columns: 1fr; }
  .settings-nav { display: flex; overflow-x: auto; position: static; }
  .placeholder-settings { grid-template-columns: 1fr; }
}
