    :root {
      color-scheme: light;
      --background: #f8fafc;
      --foreground: #0f172a;
      --card: #ffffff;
      --card-foreground: #0f172a;
      --primary: #2563eb;
      --primary-foreground: #ffffff;
      --secondary: #eff6ff;
      --secondary-foreground: #1e3a8a;
      --muted: #f1f5f9;
      --muted-foreground: #64748b;
      --accent: #dbeafe;
      --accent-foreground: #1d4ed8;
      --border: #e2e8f0;
      --input: #e2e8f0;
      --ring: rgba(37, 99, 235, .18);
      --radius: 14px;
      --shadow: 0 12px 28px rgba(15, 23, 42, .06);
    }

    * { box-sizing: border-box; }

    body {
      margin: 0;
      color: var(--foreground);
      font-family: Inter, "Source Sans 3", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
      background:
        radial-gradient(circle at top right, rgba(37,99,235,.08), transparent 22%),
        linear-gradient(180deg, #f8fbff 0%, #f8fafc 36%, #f8fafc 100%);
      min-height: 100vh;
    }

    .shell {
      width: min(1760px, calc(100vw - 24px));
      margin: 0 auto;
      padding: 16px 0 32px;
    }

    .hero,
    .card {
      background: var(--card);
      border: 1px solid var(--border);
      border-radius: calc(var(--radius) + 4px);
      box-shadow: var(--shadow);
    }

    .hero {
      padding: 28px;
      display: grid;
      grid-template-columns: 1.25fr .75fr;
      gap: 20px;
      margin-bottom: 18px;
      position: relative;
      overflow: hidden;
    }

    .hero::before {
      content: "";
      position: absolute;
      inset: 0 auto auto 0;
      height: 3px;
      width: 100%;
      background: linear-gradient(90deg, var(--primary), rgba(37,99,235,0));
    }

    .eyebrow {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      margin-bottom: 10px;
      color: var(--primary);
      font-size: 11px;
      font-weight: 700;
      letter-spacing: .18em;
      text-transform: uppercase;
    }

    .eyebrow::before {
      content: "";
      width: 24px;
      height: 1px;
      background: currentColor;
    }

    h1, h2, h3 { margin: 0; }
    h1 { font-size: clamp(30px, 4vw, 42px); line-height: 1.08; letter-spacing: -.02em; }
    h2 { font-size: 22px; line-height: 1.2; }
    h3 { font-size: 17px; line-height: 1.3; }

    .muted { color: var(--muted-foreground); }
    .small { font-size: 13px; }
    .hero-copy { margin-top: 12px; max-width: 860px; line-height: 1.75; }

    .quick-entry-row {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      margin-top: 10px;
    }

    .quick-entry-row button {
      width: auto;
      padding: 8px 12px;
      font-size: 12px;
      letter-spacing: 0;
      text-transform: none;
    }

    .subtle-note {
      color: var(--muted-foreground);
      font-size: 12px;
      line-height: 1.6;
      margin-top: -4px;
    }

    .hero-panel {
      border-left: 1px solid var(--border);
      padding-left: 24px;
      display: flex;
      flex-direction: column;
      justify-content: space-between;
      min-width: 0;
    }

    .hero-account-block {
      display: flex;
      flex-direction: column;
      justify-content: space-between;
      gap: 14px;
      min-height: 118px;
      padding-top: 4px;
      padding-bottom: 4px;
      width: max-content;
      max-width: 100%;
      margin-left: auto;
      align-items: flex-start;
    }

    .hero-account-meta {
      width: max-content;
      max-width: 100%;
      margin-left: 0;
      text-align: left;
    }

    .hero-account-actions {
      display: flex;
      justify-content: flex-start;
      width: 100%;
      margin-left: 0;
      margin-top: 0;
    }

    .hero-account-actions button {
      width: auto;
      padding: 9px 14px;
      font-size: 14px;
      letter-spacing: 0;
      text-transform: none;
      font-weight: 700;
    }

    .panel-label {
      color: var(--muted-foreground);
      font-size: 13px;
      font-weight: 700;
      letter-spacing: .12em;
      text-transform: uppercase;
      margin-bottom: 10px;
    }

    #welcomeText {
      font-size: 15px;
      line-height: 1.7;
    }

    .scope-badge {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      padding: 8px 12px;
      border-radius: 999px;
      border: 1px solid rgba(37,99,235,.16);
      background: rgba(37,99,235,.06);
      color: var(--primary);
      font-size: 12px;
      font-weight: 700;
      margin-left: auto;
    }

    #message { margin-bottom: 14px; }
    .msg {
      padding: 12px 14px;
      border-radius: 12px;
      border: 1px solid transparent;
      font-size: 14px;
    }
    .msg.ok {
      background: #eef6ff;
      color: var(--primary);
      border-color: rgba(37,99,235,.10);
    }
    .msg.err {
      background: #fff3f2;
      color: #b42318;
      border-color: rgba(180,35,24,.10);
    }

    .auth-grid {
      display: grid;
      grid-template-columns: .95fr 1.05fr;
      gap: 18px;
      margin-bottom: 18px;
    }

    .card {
      padding: 20px;
      position: relative;
      overflow: hidden;
    }

    .card::before {
      content: "";
      position: absolute;
      inset: 0 auto auto 0;
      width: 100%;
      height: 2px;
      background: linear-gradient(90deg, rgba(37,99,235,.9), rgba(37,99,235,0));
    }

    .info-list {
      display: grid;
      gap: 12px;
      margin-top: 16px;
    }

    .info-item {
      display: flex;
      gap: 10px;
      align-items: flex-start;
      line-height: 1.65;
      color: #334155;
    }

    .info-item::before {
      content: "";
      width: 8px;
      height: 8px;
      border-radius: 2px;
      background: var(--primary);
      margin-top: 8px;
      flex: 0 0 auto;
    }

    .tab-row {
      display: inline-grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 4px;
      margin-bottom: 14px;
      padding: 4px;
      border-radius: 14px;
      background: var(--muted);
      border: 1px solid var(--border);
      width: 100%;
    }

    .tab-row button {
      flex: 1;
      background: transparent;
      color: var(--muted-foreground);
      border-color: transparent;
      box-shadow: none;
      text-transform: none;
      letter-spacing: 0;
      font-weight: 600;
      padding: 11px 12px;
    }

    .tab-row button:hover {
      transform: none;
      filter: none;
      box-shadow: none;
    }

    .tab-row button:not(.secondary) {
      background: var(--card);
      color: var(--foreground);
      border-color: var(--border);
      box-shadow: 0 1px 2px rgba(15, 23, 42, 0.06);
    }

    .subcard {
      background: linear-gradient(180deg, rgba(255,255,255,.92), rgba(248,250,252,.92));
      border: 1px solid var(--border);
      border-radius: var(--radius);
      padding: 18px;
    }

    .section-kicker {
      color: var(--muted-foreground);
      font-size: 12px;
      font-weight: 700;
      letter-spacing: .12em;
      text-transform: uppercase;
      margin-bottom: 8px;
    }

    .grid { display: grid; gap: 12px; }
    .grid-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }

    label {
      display: grid;
      gap: 6px;
      color: #334155;
      font-size: 14px;
    }

    input, select, textarea, button {
      width: 100%;
      font-size: 15px;
      font-family: inherit;
      border-radius: 12px;
      border: 1px solid var(--input);
      padding: 12px 14px;
    }

    input, select, textarea {
      background: #fff;
      color: var(--foreground);
      outline: none;
      transition: border-color .18s ease, box-shadow .18s ease, background-color .18s ease;
    }

    input:focus, select:focus, textarea:focus {
      border-color: var(--primary);
      box-shadow: 0 0 0 4px var(--ring);
    }

    textarea {
      resize: vertical;
      min-height: 104px;
    }

    .password-input-wrap {
      position: relative;
    }

    .password-input-wrap input {
      padding-right: 46px;
    }

    .password-toggle {
      position: absolute;
      top: 50%;
      right: 8px;
      transform: translateY(-50%);
      width: 32px;
      height: 32px;
      padding: 0;
      border-radius: 999px;
      border: 1px solid rgba(37,99,235,.12);
      background: #fff;
      color: #64748b;
      box-shadow: none;
      font-size: 15px;
      line-height: 1;
      display: inline-flex;
      align-items: center;
      justify-content: center;
    }

    .password-toggle:hover {
      transform: translateY(-50%);
      filter: none;
      box-shadow: none;
      background: #eff6ff;
      color: #1d4ed8;
    }

    button {
      border: 1px solid transparent;
      background: linear-gradient(180deg, #2563eb, #1d4ed8);
      color: var(--primary-foreground);
      font-weight: 700;
      letter-spacing: .04em;
      text-transform: uppercase;
      cursor: pointer;
      transition: transform .16s ease, filter .16s ease, box-shadow .16s ease;
    }

    button:hover {
      transform: translateY(-1px);
      filter: brightness(1.02);
      box-shadow: 0 10px 22px rgba(37,99,235,.16);
    }

    button:disabled {
      cursor: not-allowed;
      transform: none;
      filter: saturate(.88);
      box-shadow: none;
      opacity: .72;
    }

    button.secondary {
      background: var(--secondary);
      color: var(--secondary-foreground);
      border-color: rgba(37,99,235,.12);
      box-shadow: none;
    }

    .auth-card {
      display: grid;
      align-content: start;
    }

    .quick-start {
      display: grid;
      gap: 10px;
      margin-top: 14px;
    }

    .quick-step {
      display: flex;
      gap: 10px;
      align-items: flex-start;
      color: #334155;
      line-height: 1.65;
      font-size: 14px;
    }

    .quick-step-index {
      width: 22px;
      height: 22px;
      border-radius: 999px;
      background: rgba(37,99,235,.10);
      color: var(--primary);
      display: inline-flex;
      align-items: center;
      justify-content: center;
      font-size: 12px;
      font-weight: 700;
      flex: 0 0 auto;
      margin-top: 1px;
    }

    .auth-helper {
      color: var(--muted-foreground);
      font-size: 13px;
      line-height: 1.6;
      margin-top: -2px;
    }

    .auth-switch-note {
      margin-top: -2px;
      color: var(--muted-foreground);
      font-size: 13px;
      line-height: 1.6;
    }

    .text-link {
      display: inline;
      width: auto;
      padding: 0;
      border: 0;
      background: transparent;
      color: var(--primary);
      font-size: inherit;
      font-weight: 600;
      letter-spacing: 0;
      text-transform: none;
      box-shadow: none;
      cursor: pointer;
      vertical-align: baseline;
    }

    .text-link:hover {
      transform: none;
      filter: none;
      box-shadow: none;
      text-decoration: underline;
    }

    .hidden { display: none !important; }
    .row { display: flex; gap: 10px; flex-wrap: wrap; }
    .row > * { flex: 1; }
    .check { display: flex; align-items: center; gap: 10px; }
    .check input { width: auto; accent-color: var(--primary); }

    .workspace-shell {
      display: grid;
      grid-template-columns: 236px minmax(0, 1fr);
      gap: 18px;
      align-items: start;
    }

    .workspace-nav {
      position: sticky;
      top: 16px;
      padding: 16px;
      background: var(--card);
      border: 1px solid var(--border);
      border-radius: calc(var(--radius) + 4px);
      box-shadow: var(--shadow);
      display: grid;
      gap: 10px;
    }

    .workspace-nav-title {
      color: #0f172a;
      font-size: 15px;
      font-weight: 700;
    }

    .workspace-nav-note {
      color: var(--muted-foreground);
      font-size: 12px;
      line-height: 1.7;
    }

    .workspace-nav-list {
      display: grid;
      gap: 6px;
    }

    .workspace-nav-btn {
      width: 100%;
      padding: 11px 12px;
      border-radius: 12px;
      border: 1px solid transparent;
      background: transparent;
      color: #475569;
      box-shadow: none;
      text-align: left;
      display: grid;
      gap: 4px;
      letter-spacing: 0;
      text-transform: none;
      font-weight: 600;
    }

    .workspace-nav-btn:hover {
      transform: none;
      filter: none;
      box-shadow: none;
      background: #f8fafc;
    }

    .workspace-nav-btn.active {
      background: linear-gradient(180deg, rgba(239,246,255,.86), rgba(255,255,255,.98));
      border-color: rgba(37,99,235,.16);
      color: #1d4ed8;
    }

    .workspace-nav-btn .title {
      font-size: 14px;
      font-weight: 700;
      color: inherit;
    }

    .workspace-nav-btn .desc {
      font-size: 12px;
      line-height: 1.6;
      color: #64748b;
      font-weight: 500;
    }

    .workspace-main {
      display: grid;
      gap: 18px;
    }

    .workspace-section-hero {
      padding: 14px 16px;
      border-radius: 16px;
      border: 1px solid rgba(37,99,235,.10);
      background: linear-gradient(180deg, rgba(248,251,255,.96), rgba(255,255,255,.98));
      display: grid;
      gap: 12px;
    }

    .workspace-section-hero-top {
      display: flex;
      justify-content: space-between;
      gap: 12px;
      align-items: flex-start;
      flex-wrap: wrap;
    }

    .workspace-section-hero-title {
      color: #0f172a;
      font-size: 18px;
      font-weight: 700;
      line-height: 1.3;
    }

    .workspace-section-hero-body {
      color: #64748b;
      font-size: 13px;
      line-height: 1.7;
      max-width: 920px;
    }

    .workspace-section-hero-actions {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
    }

    .workspace-section-hero-actions button {
      width: auto;
      padding: 9px 12px;
      font-size: 13px;
      letter-spacing: 0;
      text-transform: none;
    }

    .workspace-section {
      display: none;
      gap: 18px;
    }

    .workspace-section.active {
      display: grid;
    }

    .workspace-two-col {
      display: grid;
      grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
      gap: 18px;
      align-items: start;
    }

    .dashboard-hub-card {
      display: grid;
      gap: 12px;
    }

    .dashboard-head {
      display: flex;
      justify-content: space-between;
      gap: 12px;
      align-items: flex-start;
      flex-wrap: wrap;
    }

    .dashboard-state-grid {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 10px;
    }

    .dashboard-state-card {
      padding: 12px;
      border-radius: 14px;
      border: 1px solid rgba(37,99,235,.10);
      background: linear-gradient(180deg, rgba(248,251,255,.96), rgba(255,255,255,.98));
      display: grid;
      gap: 8px;
    }

    .dashboard-state-title {
      color: var(--muted-foreground);
      font-size: 12px;
      font-weight: 700;
      letter-spacing: .08em;
      text-transform: uppercase;
    }

    .dashboard-state-value {
      color: #0f172a;
      font-size: 15px;
      font-weight: 700;
      line-height: 1.4;
    }

    .dashboard-state-note {
      color: #64748b;
      font-size: 12px;
      line-height: 1.6;
    }

    .dashboard-primary-card {
      padding: 14px;
      border-radius: 16px;
      border: 1px solid rgba(37,99,235,.14);
      background: linear-gradient(180deg, rgba(239,246,255,.82), rgba(255,255,255,.98));
      display: grid;
      gap: 10px;
    }

    .dashboard-primary-title {
      color: #0f172a;
      font-size: 16px;
      font-weight: 700;
    }

    .dashboard-primary-body {
      color: #334155;
      font-size: 14px;
      line-height: 1.8;
    }

    .dashboard-action-bar {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
    }

    .dashboard-action-bar button {
      width: auto;
      padding: 9px 12px;
      font-size: 13px;
      letter-spacing: 0;
      text-transform: none;
    }

    .left-col, .right-col { display: grid; gap: 18px; }

    .compact-entry-card {
      padding-bottom: 18px;
    }

    .compact-entry-card #entryInlineNote {
      margin-top: 8px !important;
    }

    .compact-entry-card .tips {
      margin-top: 8px;
      padding: 8px 10px;
      font-size: 12px;
    }

    .compact-entry-card .tab-row {
      margin-top: 10px !important;
      margin-bottom: 10px !important;
      max-width: 360px !important;
    }

    .compact-entry-card .tab-row button {
      padding: 9px 10px;
      font-size: 13px;
    }

    .compact-entry-card #checkinForm {
      gap: 10px;
      margin-top: 8px !important;
    }

    .entry-core-grid {
      display: grid;
      grid-template-columns: minmax(128px, .9fr) minmax(0, 1.25fr) minmax(120px, .85fr);
      gap: 10px;
      align-items: end;
    }

    .entry-distance-row {
      max-width: 190px;
    }

    .compact-entry-card .quick-entry-row {
      margin-top: 0;
    }

    .compact-entry-card .quick-entry-row button {
      padding: 7px 10px;
      font-size: 12px;
    }

    .compact-entry-card .form-group-title {
      margin-bottom: -4px;
    }

    .compact-entry-card .inline-note {
      font-size: 12px;
      line-height: 1.6;
    }

    .compact-entry-card button[type="submit"] {
      padding-top: 11px;
      padding-bottom: 11px;
    }

    .tips {
      margin-top: 12px;
      padding: 10px 12px;
      border-radius: 12px;
      background: #f8fbff;
      border: 1px solid rgba(37,99,235,.10);
      color: #4b5f71;
      font-size: 13px;
      line-height: 1.6;
    }

    .onboarding-banner {
      margin-top: 12px;
      padding: 12px 14px;
      border-radius: 14px;
      border: 1px solid rgba(37,99,235,.12);
      background: linear-gradient(180deg, rgba(239,246,255,.90), rgba(255,255,255,.98));
    }

    .onboarding-title {
      color: #0f172a;
      font-size: 15px;
      font-weight: 700;
      margin-bottom: 6px;
    }

    .onboarding-body {
      color: var(--muted-foreground);
      font-size: 13px;
      line-height: 1.7;
    }

    .onboarding-actions {
      display: flex;
      gap: 8px;
      margin-top: 12px;
      flex-wrap: wrap;
    }

    .onboarding-actions button {
      width: auto;
      padding: 9px 12px;
      font-size: 13px;
      letter-spacing: 0;
      text-transform: none;
    }

    .onboarding-grid {
      display: grid;
      gap: 10px;
      margin-top: 12px;
      grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .onboarding-step-card {
      padding: 12px;
      border-radius: 12px;
      border: 1px solid rgba(37,99,235,.10);
      background: rgba(255,255,255,.92);
      display: grid;
      gap: 6px;
    }

    .onboarding-step-index {
      width: 22px;
      height: 22px;
      border-radius: 999px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      background: #dbeafe;
      color: #1d4ed8;
      font-size: 12px;
      font-weight: 700;
    }

    .onboarding-step-title {
      color: #0f172a;
      font-size: 13px;
      font-weight: 700;
    }

    .onboarding-step-body {
      color: #64748b;
      font-size: 12px;
      line-height: 1.7;
    }

    .onboarding-step-state {
      color: #1d4ed8;
      font-size: 12px;
      font-weight: 700;
    }

    .form-group-title {
      margin-bottom: -2px;
      color: var(--muted-foreground);
      font-size: 12px;
      font-weight: 700;
      letter-spacing: .08em;
      text-transform: uppercase;
    }

    .inline-note {
      color: var(--muted-foreground);
      font-size: 13px;
      line-height: 1.6;
    }

    .form-optional {
      border: 1px dashed rgba(37,99,235,.16);
      border-radius: 14px;
      padding: 12px 14px;
      background: linear-gradient(180deg, rgba(248,251,255,.96), rgba(255,255,255,.98));
    }

    .form-optional summary {
      cursor: pointer;
      color: var(--primary);
      font-size: 13px;
      font-weight: 700;
      list-style: none;
    }

    .form-optional summary::-webkit-details-marker {
      display: none;
    }

    .form-optional-body {
      display: grid;
      gap: 12px;
      margin-top: 12px;
    }

    .edit-banner {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 10px;
      padding: 10px 12px;
      border-radius: 12px;
      background: #eef6ff;
      border: 1px solid rgba(37,99,235,.12);
      color: #1d4ed8;
      font-size: 13px;
      line-height: 1.6;
      box-shadow: 0 10px 22px rgba(37,99,235,.08);
    }

    .edit-banner button {
      width: auto;
      padding: 8px 12px;
      font-size: 13px;
      letter-spacing: 0;
      text-transform: none;
    }

    .stats {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 12px;
    }

    .analysis-list {
      display: grid;
      gap: 12px;
      margin-top: 12px;
    }

    .analysis-item {
      border: 1px solid var(--border);
      border-radius: 14px;
      padding: 16px;
      background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,250,252,.98));
    }

    .analysis-conclusion {
      margin-top: 12px;
      padding: 12px 14px;
      border-radius: 12px;
      border: 1px solid rgba(37,99,235,.12);
      background: linear-gradient(180deg, rgba(239,246,255,.92), rgba(248,250,252,.98));
    }

    .analysis-conclusion-title {
      color: var(--muted-foreground);
      font-size: 12px;
      font-weight: 700;
      letter-spacing: .08em;
      text-transform: uppercase;
      margin-bottom: 6px;
    }

    .analysis-conclusion-body {
      color: #1e293b;
      line-height: 1.7;
      font-size: 14px;
    }

    .analysis-grid {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 10px 16px;
      margin-top: 12px;
      padding: 12px 14px;
      border-radius: 12px;
      background: #f8fafc;
      border: 1px solid var(--border);
    }

    .analysis-metric {
      display: grid;
      gap: 4px;
    }

    .analysis-metric .label {
      color: var(--muted-foreground);
      font-size: 12px;
    }

    .analysis-metric .value {
      color: #0f172a;
      font-size: 14px;
      font-weight: 600;
    }

    .analysis-summary {
      margin-top: 12px;
      padding: 12px 14px;
      border: 1px solid rgba(37,99,235,.10);
      background: #f8fbff;
      border-radius: 12px;
      line-height: 1.7;
      color: #334155;
    }

    .analysis-detail-card {
      margin-top: 12px;
      padding: 16px;
      border-radius: 16px;
      border: 1px solid rgba(37,99,235,.14);
      background: linear-gradient(180deg, rgba(248,251,255,.96), rgba(255,255,255,.99));
      box-shadow: 0 12px 28px rgba(15,23,42,.05);
    }

    .analysis-detail-layout {
      display: grid;
      grid-template-columns: minmax(0, 1.05fr) minmax(0, 1.25fr);
      gap: 16px;
      margin-top: 12px;
    }

    .analysis-detail-preview {
      display: grid;
      gap: 10px;
    }

    .analysis-detail-preview img {
      width: 100%;
      border-radius: 14px;
      border: 1px solid var(--border);
      background: #f8fafc;
      object-fit: contain;
      max-height: 460px;
    }

    .analysis-detail-empty {
      min-height: 220px;
      display: grid;
      place-items: center;
      border-radius: 14px;
      border: 1px dashed rgba(37,99,235,.16);
      background: #f8fafc;
      color: #64748b;
      font-size: 13px;
      text-align: center;
      padding: 16px;
      line-height: 1.7;
    }

    .analysis-detail-stack {
      display: grid;
      gap: 12px;
    }

    .analysis-detail-section {
      padding: 12px 14px;
      border-radius: 14px;
      border: 1px solid rgba(37,99,235,.10);
      background: #fff;
    }

    .analysis-detail-meta {
      display: grid;
      gap: 8px;
    }

    .analysis-detail-meta-line {
      color: #475569;
      font-size: 13px;
      line-height: 1.7;
    }

    .analysis-detail-actions {
      display: flex;
      flex-wrap: wrap;
      gap: 10px;
      margin-top: 12px;
    }

    .analysis-detail-actions button {
      width: auto;
      min-width: 150px;
    }

    .upload-guide {
      margin-top: 12px;
      padding: 12px 14px;
      border-radius: 14px;
      border: 1px solid rgba(37,99,235,.12);
      background: linear-gradient(180deg, rgba(239,246,255,.84), rgba(255,255,255,.98));
    }

    .upload-guide-title {
      color: #0f172a;
      font-size: 14px;
      font-weight: 700;
      margin-bottom: 8px;
    }

    .upload-guide-grid {
      display: grid;
      gap: 10px;
      grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .upload-guide-item {
      padding: 12px;
      border-radius: 12px;
      border: 1px solid rgba(37,99,235,.10);
      background: rgba(255,255,255,.92);
      color: #475569;
      font-size: 13px;
      line-height: 1.7;
    }

    .upload-guide-item strong {
      display: block;
      margin-bottom: 4px;
      color: #0f172a;
      font-size: 13px;
    }

    .upload-guide-footnote {
      margin-top: 10px;
      color: #64748b;
      font-size: 12px;
      line-height: 1.7;
    }

    .analysis-overview {
      display: grid;
      grid-template-columns: repeat(4, minmax(0, 1fr));
      gap: 10px;
      margin-top: 12px;
    }

    .analysis-overview-card {
      padding: 12px;
      border-radius: 12px;
      border: 1px solid rgba(37,99,235,.10);
      background: linear-gradient(180deg, rgba(248,251,255,.96), rgba(255,255,255,.98));
    }

    .analysis-overview-card strong {
      display: block;
      margin-top: 6px;
      color: #0f172a;
      font-size: 20px;
      line-height: 1;
    }

    .analysis-overview-card .muted {
      line-height: 1.6;
    }

    .analysis-status-pill {
      display: inline-flex;
      align-items: center;
      padding: 6px 10px;
      border-radius: 999px;
      font-size: 12px;
      font-weight: 700;
      border: 1px solid transparent;
    }

    .analysis-status-pill.saved {
      background: #ecfdf5;
      color: #047857;
      border-color: rgba(16,185,129,.16);
    }

    .analysis-status-pill.todo {
      background: #fff7ed;
      color: #c2410c;
      border-color: rgba(249,115,22,.16);
    }

    .analysis-status-pill.processing {
      background: #eff6ff;
      color: #1d4ed8;
      border-color: rgba(37,99,235,.14);
    }

    .analysis-status-pill.failed {
      background: #fef2f2;
      color: #b91c1c;
      border-color: rgba(239,68,68,.16);
    }

    .analysis-meta-line {
      margin-top: 6px;
      color: #64748b;
      font-size: 12px;
      line-height: 1.6;
    }

    .analysis-reason {
      margin-top: 12px;
      padding: 12px 14px;
      border-radius: 12px;
      background: #fff;
      border: 1px dashed rgba(37,99,235,.14);
    }

    .analysis-reason-title {
      color: var(--muted-foreground);
      font-size: 12px;
      font-weight: 700;
      letter-spacing: .08em;
      text-transform: uppercase;
      margin-bottom: 6px;
    }

    .analysis-reason-body {
      color: #475569;
      font-size: 13px;
      line-height: 1.7;
    }

    .analysis-toolbar {
      margin-top: 16px;
    }

    .analysis-filter-bar {
      margin-top: 10px;
    }

    .analysis-next-step {
      margin-top: 12px;
      padding: 12px 14px;
      border-radius: 12px;
      border: 1px dashed rgba(37,99,235,.16);
      background: #ffffff;
    }

    .analysis-next-step-title {
      color: var(--muted-foreground);
      font-size: 12px;
      font-weight: 700;
      letter-spacing: .08em;
      text-transform: uppercase;
      margin-bottom: 6px;
    }

    .analysis-next-step-body {
      color: #334155;
      font-size: 13px;
      line-height: 1.7;
    }

    .ai-grid {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 12px;
      margin-top: 12px;
      align-items: stretch;
    }

    .ai-strip {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      margin-top: 12px;
    }

    .ai-pill {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      padding: 8px 12px;
      border-radius: 999px;
      background: #f8fbff;
      border: 1px solid rgba(37,99,235,.12);
      color: #1d4ed8;
      font-size: 12px;
      font-weight: 700;
    }

    .ai-card {
      border: 1px solid var(--border);
      border-radius: 16px;
      padding: 16px;
      background: linear-gradient(180deg, rgba(239,246,255,.72), rgba(255,255,255,.98));
      box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
      min-height: 176px;
      display: grid;
      align-content: start;
    }

    .ai-card h3 {
      font-size: 16px;
      margin-bottom: 8px;
      line-height: 1.35;
    }

    .ai-card p {
      margin: 0;
      color: #475569;
      line-height: 1.75;
      font-size: 14px;
    }

    .ai-card .section-kicker {
      margin-bottom: 10px;
    }

    .coach-box {
      margin-top: 16px;
      padding: 14px;
      border-radius: 16px;
      border: 1px solid rgba(37,99,235,.12);
      background: linear-gradient(180deg, rgba(248,251,255,.96), rgba(255,255,255,.98));
    }

    .coach-answer {
      margin-top: 10px;
      padding: 14px;
      border-radius: 14px;
      background: linear-gradient(180deg, rgba(248,251,255,.96), rgba(255,255,255,.98));
      border: 1px solid rgba(37,99,235,.12);
      color: #475569;
      line-height: 1.7;
      display: grid;
      gap: 10px;
    }

    .coach-answer-title {
      color: #0f172a;
      font-size: 15px;
      font-weight: 700;
    }

    .coach-answer-summary {
      padding: 12px 14px;
      border-radius: 12px;
      background: #eff6ff;
      border: 1px solid rgba(37,99,235,.12);
      color: #1d4ed8;
      font-size: 14px;
      line-height: 1.7;
      font-weight: 700;
    }

    .coach-answer-section {
      padding: 12px 14px;
      border-radius: 12px;
      background: #fff;
      border: 1px solid var(--border);
    }

    .coach-answer-section-title {
      color: #0f172a;
      font-size: 13px;
      font-weight: 700;
      margin-bottom: 8px;
    }

    .coach-answer-list {
      display: grid;
      gap: 6px;
      margin: 0;
      padding-left: 18px;
      color: #475569;
    }

    .coach-answer-paragraphs {
      display: grid;
      gap: 8px;
      color: #475569;
    }

    .coach-plan-week {
      padding: 12px 14px;
      border-radius: 12px;
      border: 1px solid rgba(37,99,235,.12);
      background: #fff;
    }

    .coach-plan-week-title {
      color: #0f172a;
      font-size: 13px;
      font-weight: 700;
      margin-bottom: 8px;
    }

    .coach-plan-days {
      display: grid;
      gap: 6px;
      color: #475569;
      font-size: 13px;
    }

    .question-chip-row {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      margin-top: 10px;
    }

    .question-chip {
      width: auto;
      padding: 8px 12px;
      border-radius: 999px;
      border: 1px solid rgba(37,99,235,.12);
      background: #fff;
      color: #1d4ed8;
      font-size: 12px;
      font-weight: 700;
      letter-spacing: 0;
      text-transform: none;
      box-shadow: none;
    }

    .question-chip:hover {
      transform: none;
      box-shadow: none;
      background: #eff6ff;
    }

    .coach-helper-row {
      display: grid;
      grid-template-columns: minmax(0, 1fr) auto;
      gap: 10px;
      margin-top: 10px;
      align-items: end;
    }

    .coach-helper-row label {
      margin-bottom: 0;
    }

    .coach-helper-row button {
      width: auto;
      padding: 10px 12px;
      font-size: 13px;
      letter-spacing: 0;
      text-transform: none;
    }

    .coach-plan-row {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      margin-top: 10px;
    }

    .coach-plan-row button {
      width: auto;
      padding: 9px 12px;
      font-size: 13px;
      letter-spacing: 0;
      text-transform: none;
    }

    .coach-context-note {
      margin-top: 10px;
      color: var(--muted-foreground);
      font-size: 12px;
      line-height: 1.7;
    }

    .coach-reference-card {
      margin-top: 10px;
      padding: 12px 14px;
      border-radius: 12px;
      border: 1px solid rgba(37,99,235,.12);
      background: linear-gradient(180deg, rgba(248,251,255,.96), rgba(255,255,255,.98));
      color: #475569;
      font-size: 13px;
      line-height: 1.7;
    }

    .coach-reference-title {
      color: #0f172a;
      font-size: 13px;
      font-weight: 700;
      margin-bottom: 6px;
    }

    .coach-reference-list {
      display: grid;
      gap: 4px;
    }

    .active-plan-card {
      margin-top: 10px;
      padding: 14px;
      border-radius: 14px;
      border: 1px solid rgba(37,99,235,.14);
      background: linear-gradient(180deg, rgba(239,246,255,.86), rgba(255,255,255,.98));
      display: grid;
      gap: 10px;
    }

    .active-plan-head {
      display: flex;
      justify-content: space-between;
      gap: 10px;
      align-items: flex-start;
      flex-wrap: wrap;
    }

    .active-plan-title {
      color: #0f172a;
      font-size: 15px;
      font-weight: 700;
    }

    .active-plan-meta {
      color: var(--muted-foreground);
      font-size: 12px;
      line-height: 1.7;
    }

    .active-plan-summary {
      padding: 12px 14px;
      border-radius: 12px;
      background: #fff;
      border: 1px solid rgba(37,99,235,.10);
      color: #1d4ed8;
      font-size: 14px;
      line-height: 1.7;
      font-weight: 700;
    }

    .active-plan-note {
      color: #475569;
      font-size: 13px;
      line-height: 1.7;
    }

    .execution-state-card {
      padding: 12px 14px;
      border-radius: 12px;
      border: 1px solid rgba(37,99,235,.12);
      background: #fff;
      display: grid;
      gap: 10px;
    }

    .execution-state-head {
      display: flex;
      justify-content: space-between;
      gap: 8px;
      align-items: center;
      flex-wrap: wrap;
    }

    .execution-state-title {
      color: #0f172a;
      font-size: 13px;
      font-weight: 700;
    }

    .execution-state-summary {
      color: #1d4ed8;
      font-size: 14px;
      line-height: 1.7;
      font-weight: 700;
    }

    .execution-state-list {
      display: grid;
      gap: 6px;
      color: #475569;
      font-size: 13px;
      line-height: 1.7;
    }

    .status-pill-success {
      background: #ecfdf5;
      color: #047857;
      border-color: rgba(16,185,129,.16);
    }

    .status-pill-warn {
      background: #fff7ed;
      color: #c2410c;
      border-color: rgba(249,115,22,.16);
    }

    .status-pill-neutral {
      background: #eff6ff;
      color: #1d4ed8;
      border-color: rgba(37,99,235,.12);
    }

    .status-pill-danger {
      background: #fef2f2;
      color: #b91c1c;
      border-color: rgba(239,68,68,.16);
    }

    .feedback-card {
      display: grid;
      gap: 12px;
    }

    .feedback-grid {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 12px;
    }

    .feedback-item {
      padding: 12px;
      border-radius: 14px;
      border: 1px solid rgba(37,99,235,.10);
      background: linear-gradient(180deg, rgba(248,251,255,.96), rgba(255,255,255,.98));
      display: grid;
      gap: 8px;
    }

    .feedback-item-head {
      display: flex;
      justify-content: space-between;
      gap: 8px;
      align-items: flex-start;
      flex-wrap: wrap;
    }

    .feedback-item-title {
      color: #0f172a;
      font-size: 14px;
      font-weight: 700;
    }

    .feedback-item-summary {
      color: #334155;
      font-size: 13px;
      line-height: 1.7;
    }

    .feedback-item-detail {
      color: #64748b;
      font-size: 12px;
      line-height: 1.7;
    }

    .feedback-action-bar {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
    }

    .feedback-action-bar button {
      width: auto;
      padding: 9px 12px;
      font-size: 13px;
      letter-spacing: 0;
      text-transform: none;
    }

    .active-plan-actions {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
    }

    .active-plan-actions button {
      width: auto;
      padding: 9px 12px;
      font-size: 13px;
      letter-spacing: 0;
      text-transform: none;
    }

    .coach-answer-actions {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
    }

    .coach-answer-actions button {
      width: auto;
      padding: 9px 12px;
      font-size: 13px;
      letter-spacing: 0;
      text-transform: none;
    }

    .plan-center-card {
      display: grid;
      gap: 14px;
    }

    .plan-center-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 12px;
    }

    .plan-center-form {
      padding: 12px;
      border-radius: 14px;
      border: 1px solid rgba(37,99,235,.10);
      background: linear-gradient(180deg, rgba(248,251,255,.96), rgba(255,255,255,.98));
      display: grid;
      gap: 10px;
    }

    .plan-library {
      display: grid;
      gap: 10px;
    }

    .plan-library-item {
      padding: 12px;
      border-radius: 14px;
      border: 1px solid var(--border);
      background: #fff;
      display: grid;
      gap: 10px;
    }

    .plan-library-head {
      display: flex;
      justify-content: space-between;
      gap: 10px;
      align-items: flex-start;
      flex-wrap: wrap;
    }

    .plan-library-title {
      color: #0f172a;
      font-size: 15px;
      font-weight: 700;
    }

    .plan-library-meta {
      color: var(--muted-foreground);
      font-size: 12px;
      line-height: 1.7;
    }

    .plan-library-summary {
      color: #334155;
      font-size: 13px;
      line-height: 1.7;
    }

    .plan-library-actions {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
    }

    .plan-library-actions button {
      width: auto;
      padding: 8px 12px;
      font-size: 13px;
      letter-spacing: 0;
      text-transform: none;
    }

    .admin-tools {
      margin-top: 14px;
      padding-top: 14px;
      border-top: 1px solid var(--border);
    }

    .ops-list {
      display: grid;
      gap: 10px;
      margin-top: 14px;
    }

    .ops-item {
      display: flex;
      justify-content: space-between;
      align-items: center;
      gap: 12px;
      padding: 12px 14px;
      border-radius: 12px;
      border: 1px solid rgba(37,99,235,.10);
      background: linear-gradient(180deg, rgba(248,251,255,.96), rgba(255,255,255,.98));
    }

    .ops-item strong {
      display: block;
      color: #0f172a;
      font-size: 14px;
      margin-bottom: 4px;
    }

    .ops-item .small {
      line-height: 1.6;
    }

    .ops-item button {
      width: auto;
      padding: 8px 12px;
      font-size: 13px;
      letter-spacing: 0;
      text-transform: none;
      flex-shrink: 0;
    }

    .admin-user-list {
      margin-top: 12px;
      padding: 12px 14px;
      border-radius: 12px;
      border: 1px dashed rgba(37,99,235,.14);
      background: #f8fafc;
      color: #475569;
      font-size: 13px;
      line-height: 1.7;
    }

    .admin-overview-grid {
      display: grid;
      grid-template-columns: minmax(0, 1.15fr) minmax(0, 1fr);
      gap: 14px;
      margin-top: 14px;
    }

    .admin-overview-section {
      padding: 14px;
      border-radius: 16px;
      border: 1px solid rgba(37,99,235,.10);
      background: linear-gradient(180deg, rgba(248,251,255,.92), rgba(255,255,255,.98));
    }

    .admin-overview-section .section-kicker {
      margin-bottom: 6px;
    }

    .admin-overview-section .section-note {
      color: var(--muted-foreground);
      font-size: 13px;
      line-height: 1.7;
    }

    .admin-summary-grid {
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .admin-overview-card-state {
      display: inline-flex;
      align-items: center;
      padding: 4px 8px;
      border-radius: 999px;
      background: #eff6ff;
      color: #1d4ed8;
      border: 1px solid rgba(37,99,235,.12);
      font-size: 11px;
      font-weight: 700;
      margin-top: 8px;
    }

    .admin-overview-card-trend {
      margin-top: 8px;
      color: #64748b;
      font-size: 12px;
      line-height: 1.6;
    }

    .admin-user-profile-grid {
      display: grid;
      grid-template-columns: minmax(0, 1.15fr) minmax(0, 1fr);
      gap: 14px;
      margin-top: 14px;
    }

    .admin-timeline {
      display: grid;
      gap: 10px;
      margin-top: 12px;
    }

    .admin-timeline-item {
      padding: 12px 14px;
      border-radius: 14px;
      border: 1px solid rgba(37,99,235,.10);
      background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,250,252,.98));
    }

    .admin-timeline-title {
      color: #0f172a;
      font-size: 14px;
      font-weight: 700;
    }

    .admin-timeline-meta {
      margin-top: 6px;
      color: #64748b;
      font-size: 12px;
      line-height: 1.6;
    }

    .admin-timeline-body {
      margin-top: 8px;
      color: #334155;
      font-size: 13px;
      line-height: 1.7;
    }

    .admin-related-list {
      display: grid;
      gap: 10px;
      margin-top: 12px;
    }

    .admin-related-item {
      padding: 12px 14px;
      border-radius: 14px;
      border: 1px dashed rgba(37,99,235,.14);
      background: #fff;
    }

    .admin-related-item strong {
      display: block;
      color: #0f172a;
      font-size: 13px;
      margin-bottom: 6px;
    }

    .admin-related-item .muted {
      line-height: 1.7;
    }

    .chip-row {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      margin-top: 12px;
    }

    .chip {
      display: inline-flex;
      align-items: center;
      padding: 5px 10px;
      border-radius: 999px;
      background: #eff6ff;
      color: #1d4ed8;
      border: 1px solid rgba(37,99,235,.12);
      font-size: 12px;
      font-weight: 700;
    }

    .analysis-actions {
      display: flex;
      gap: 10px;
      margin-top: 14px;
      flex-wrap: wrap;
    }

    .analysis-actions button {
      width: auto;
      min-width: 160px;
    }

    .stat {
      border: 1px solid var(--border);
      background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,250,252,.98));
      border-radius: 14px;
      padding: 16px;
    }

    .stat strong {
      display: block;
      margin-top: 8px;
      font-size: clamp(22px, 2.4vw, 30px);
      line-height: 1;
      color: var(--foreground);
      font-weight: 700;
    }

    .goal-progress-card {
      margin-top: 12px;
      padding: 14px 16px;
      border-radius: 16px;
      border: 1px solid rgba(37,99,235,.12);
      background: linear-gradient(180deg, rgba(239,246,255,.72), rgba(255,255,255,.98));
    }

    .progress-track {
      margin-top: 12px;
      width: 100%;
      height: 10px;
      border-radius: 999px;
      background: #dbeafe;
      overflow: hidden;
    }

    .progress-bar {
      height: 100%;
      width: 0%;
      border-radius: inherit;
      background: linear-gradient(90deg, #2563eb, #60a5fa);
      transition: width .24s ease;
    }

    .goal-progress-meta {
      display: flex;
      justify-content: space-between;
      gap: 12px;
      align-items: center;
    }

    .calendar-head {
      display: flex;
      justify-content: space-between;
      align-items: center;
      gap: 12px;
      margin-bottom: 12px;
    }

    .calendar-head .nav { display: flex; gap: 8px; }
    .calendar-head button { width: auto; padding: 8px 12px; }

    .calendar-legend {
      display: flex;
      flex-wrap: wrap;
      gap: 10px;
      margin-bottom: 10px;
      color: var(--muted-foreground);
      font-size: 12px;
    }

    .legend-chip {
      display: inline-flex;
      align-items: center;
      gap: 6px;
    }

    .legend-dot {
      width: 10px;
      height: 10px;
      border-radius: 999px;
      background: #bfdbfe;
      border: 1px solid rgba(37,99,235,.18);
    }

    .legend-dot.today {
      background: #2563eb;
    }

    .legend-dot.selected {
      background: #1e40af;
    }

    .calendar-summary-card {
      margin-top: 12px;
      padding: 12px 14px;
      border-radius: 12px;
      border: 1px solid rgba(37,99,235,.10);
      background: #f8fbff;
      color: #475569;
      line-height: 1.7;
      font-size: 13px;
    }

    .day-count {
      margin-top: auto;
      align-self: flex-end;
      min-width: 18px;
      height: 18px;
      padding: 0 4px;
      border-radius: 999px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      background: rgba(37,99,235,.10);
      color: #1d4ed8;
      font-size: 11px;
      font-weight: 700;
    }

    .calendar-weekdays,
    .calendar-grid {
      display: grid;
      grid-template-columns: repeat(7, minmax(0, 1fr));
      gap: 8px;
    }

    .calendar-weekdays div {
      text-align: center;
      color: var(--muted-foreground);
      font-size: 12px;
      letter-spacing: .08em;
      text-transform: uppercase;
      padding: 4px 0;
    }

    .day {
      min-height: 64px;
      border: 1px solid var(--border);
      border-radius: 14px;
      display: flex;
      align-items: center;
      justify-content: center;
      position: relative;
      background: #fff;
    }

    .day.clickable {
      cursor: pointer;
      transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease, background-color .16s ease;
    }

    .day.clickable:hover {
      transform: translateY(-1px);
      box-shadow: 0 10px 22px rgba(37,99,235,.10);
      border-color: rgba(37,99,235,.22);
    }

    .day.empty {
      background: #fafbfc;
      border-style: dashed;
    }

    .day .num {
      width: 36px;
      height: 36px;
      display: flex;
      align-items: center;
      justify-content: center;
      border-radius: 999px;
      font-weight: 600;
    }

    .day.checked .num {
      border: 2px solid var(--primary);
      color: var(--primary);
      font-weight: 800;
    }

    .day.today {
      background: rgba(37,99,235,.05);
    }

    .day.today:not(.checked) .num {
      background: rgba(37,99,235,.08);
      color: var(--primary);
    }

    .day.selected {
      border-color: rgba(37,99,235,.38);
      background: rgba(37,99,235,.08);
      box-shadow: 0 12px 24px rgba(37,99,235,.10);
    }

    .day.selected .num {
      background: var(--primary);
      color: #fff;
      border-color: var(--primary);
    }

    .day .dot {
      position: absolute;
      bottom: 8px;
      width: 6px;
      height: 6px;
      border-radius: 999px;
      background: var(--primary);
    }

    .list {
      display: grid;
      gap: 12px;
      margin-top: 12px;
    }

    .item {
      border: 1px solid var(--border);
      border-radius: 14px;
      padding: 12px 14px;
      background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,250,252,.98));
      box-shadow: 0 1px 2px rgba(15,23,42,.04);
      transition: border-color .18s ease, box-shadow .18s ease, background-color .18s ease;
    }

    .item.editing {
      border-color: rgba(37,99,235,.28);
      box-shadow: 0 12px 24px rgba(37,99,235,.10);
      background: linear-gradient(180deg, rgba(239,246,255,.86), rgba(255,255,255,.98));
    }

    .item-top {
      display: flex;
      justify-content: space-between;
      align-items: flex-start;
      gap: 8px;
    }

    .item-heading {
      display: grid;
      gap: 6px;
      min-width: 0;
    }

    .item-meta {
      display: flex;
      flex-wrap: wrap;
      gap: 6px;
    }

    .meta-chip {
      display: inline-flex;
      align-items: center;
      padding: 4px 8px;
      border-radius: 999px;
      background: #f8fafc;
      border: 1px solid #e2e8f0;
      color: #475569;
      font-size: 12px;
      line-height: 1.4;
    }

    .item-note {
      margin-top: 8px;
      color: #64748b;
      line-height: 1.65;
      font-size: 13px;
    }

    .item-user {
      margin-top: 8px;
      color: var(--primary);
      font-size: 12px;
      font-weight: 600;
    }

    .item-actions {
      display: flex;
      gap: 8px;
      margin-top: 10px;
      flex-wrap: wrap;
    }

    .item-actions button {
      width: auto;
      padding: 8px 12px;
      font-size: 13px;
      letter-spacing: 0;
      text-transform: none;
    }

    .filter-bar {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 10px;
      margin-top: 14px;
      margin-bottom: 4px;
    }

    .filter-bar label {
      gap: 5px;
      font-size: 13px;
      color: var(--muted-foreground);
    }

    .filter-bar select {
      padding: 10px 12px;
      font-size: 14px;
    }

    .danger-btn {
      background: #fff1f2;
      color: #b42318;
      border: 1px solid rgba(180,35,24,.14);
      box-shadow: none;
    }

    .danger-btn:hover {
      transform: translateY(-1px);
      filter: none;
      box-shadow: 0 10px 20px rgba(180,35,24,.08);
    }

    .pill {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      padding: 4px 10px;
      border-radius: 999px;
      font-size: 12px;
      font-weight: 700;
      background: rgba(37,99,235,.08);
      color: var(--primary);
      border: 1px solid rgba(37,99,235,.12);
    }

    .footer-note {
      margin-top: 6px;
      color: var(--muted-foreground);
      font-size: 12px;
      line-height: 1.6;
    }

    .empty-state {
      padding: 18px 16px;
      border-radius: 14px;
      border: 1px dashed rgba(37,99,235,.18);
      background: linear-gradient(180deg, rgba(248,251,255,.96), rgba(255,255,255,.98));
    }

    .empty-state-title {
      color: #0f172a;
      font-size: 15px;
      font-weight: 700;
      margin-bottom: 6px;
    }

    .empty-state-body {
      color: var(--muted-foreground);
      font-size: 13px;
      line-height: 1.7;
    }

    .loading-stack {
      display: grid;
      gap: 10px;
    }

    .loading-card {
      padding: 12px 14px;
      border-radius: 14px;
      border: 1px solid rgba(37,99,235,.10);
      background: linear-gradient(180deg, rgba(248,251,255,.96), rgba(255,255,255,.98));
    }

    .loading-line {
      height: 10px;
      border-radius: 999px;
      background: linear-gradient(90deg, rgba(226,232,240,.9), rgba(241,245,249,1), rgba(226,232,240,.9));
      background-size: 200% 100%;
      animation: loadingShimmer 1.3s linear infinite;
    }

    .loading-line + .loading-line {
      margin-top: 8px;
    }

    .loading-line.short { width: 36%; }
    .loading-line.mid { width: 58%; }
    .loading-line.long { width: 82%; }

    @keyframes loadingShimmer {
      0% { background-position: 200% 0; }
      100% { background-position: -200% 0; }
    }

    @media (max-width: 1180px) {
      .auth-grid,
      .workspace-shell,
      .workspace-two-col {
        grid-template-columns: 1fr;
      }
      .workspace-nav {
        position: static;
      }
      .hero {
        grid-template-columns: 1fr;
      }
      .hero-panel {
        border-left: 0;
        padding-left: 0;
        border-top: 1px solid var(--border);
        padding-top: 14px;
      }
    }

    @media (max-width: 760px) {
      .shell { width: calc(100vw - 20px); }
      .hero, .card { padding: 16px; }
      #authIntroCard { padding: 16px; }
      #authIntroCard .quick-start { gap: 8px; }
      #authIntroCard .quick-step { padding: 10px 12px; }
      .grid-2, .grid-3, .stats, .ai-grid, .filter-bar, .analysis-grid, .upload-guide-grid, .onboarding-grid, .analysis-overview, .plan-center-grid, .feedback-grid, .dashboard-state-grid, .admin-overview-grid, .admin-summary-grid, .analysis-detail-layout, .admin-user-profile-grid { grid-template-columns: 1fr; }
      .workspace-nav-list { display: flex; gap: 8px; overflow-x: auto; padding-bottom: 2px; }
      .workspace-nav-btn { min-width: 140px; }
      .entry-core-grid { grid-template-columns: 1fr; }
      .coach-helper-row, .coach-plan-row { grid-template-columns: 1fr; }
      .coach-plan-row { display: grid; }
      .coach-plan-row button, .coach-helper-row button { width: 100%; }
      .active-plan-actions, .feedback-action-bar, .dashboard-action-bar, .workspace-section-hero-actions { display: grid; }
      .active-plan-actions button, .coach-answer-actions button, .feedback-action-bar button, .dashboard-action-bar button, .workspace-section-hero-actions button { width: 100%; }
      .calendar-head { flex-direction: column; align-items: flex-start; }
      .operator-box { text-align: left; }
      .day { min-height: 54px; border-radius: 12px; }
      .day .num { width: 30px; height: 30px; font-size: 14px; }
      .calendar-weekdays, .calendar-grid { gap: 6px; }
      .item { padding: 10px 12px; }
      .item-actions { flex-direction: column; }
      .item-actions button { width: 100%; }
      .goal-progress-meta { flex-direction: column; align-items: flex-start; }
    }
  
