:root {
  --bg: #050607;
  --panel: rgba(15, 16, 18, .82);
  --panel-strong: rgba(25, 26, 30, .92);
  --surface: rgba(255, 255, 255, .045);
  --surface-2: rgba(255, 255, 255, .07);
  --line: rgba(255, 255, 255, .08);
  --line-strong: rgba(255, 255, 255, .14);
  --text: #f7f8f8;
  --muted: #8a8f98;
  --soft: #d0d6e0;
  --accent: #8b5cf6;
  --accent-2: #7170ff;
  --green: #10b981;
  --yellow: #f59e0b;
  --red: #ef4444;
  --radius: 18px;
  --shadow: 0 24px 80px rgba(0,0,0,.45), inset 0 1px 0 rgba(255,255,255,.06);
  --font-display: 'Playfair Display', Georgia, serif;
}
* { box-sizing: border-box; }
html, body { margin: 0; min-height: 100%; color: var(--text); background: radial-gradient(circle at 30% 10%, rgba(113,112,255,.22), transparent 30%), radial-gradient(circle at 75% 0%, rgba(236,72,153,.16), transparent 26%), var(--bg); font-family: 'Inter', system-ui, -apple-system, Segoe UI, Roboto, sans-serif; font-feature-settings: 'cv01','ss03'; }
body { overflow-x: hidden; }
a { color: inherit; text-decoration: none; }
button, input, textarea, select { font: inherit; }
button { cursor: pointer; }
#three-bg { position: fixed; inset: 0; width: 100vw; height: 100vh; z-index: 0; opacity: .72; pointer-events: none; }
body::after { content: ''; position: fixed; inset: 0; z-index: 1; pointer-events: none; background: linear-gradient(180deg, rgba(5,6,7,.25), rgba(5,6,7,.92)); }
.hidden { display: none !important; }
.glass-card, .glass-panel { background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius); box-shadow: var(--shadow); backdrop-filter: blur(22px); }
.eyebrow { color: #aeb4c0; text-transform: uppercase; letter-spacing: .16em; font-size: 11px; font-weight: 700; margin: 0 0 8px; }
.muted { color: var(--muted); line-height: 1.65; }
.primary-btn, .ghost-btn, .icon-btn { border: 1px solid var(--line); border-radius: 12px; color: var(--text); min-height: 42px; transition: .18s ease; }
.primary-btn { background: linear-gradient(135deg, #8b5cf6, #ec4899); border: 0; padding: 0 18px; font-weight: 700; box-shadow: 0 12px 40px rgba(139,92,246,.28); }
.primary-btn:hover { transform: translateY(-1px); filter: brightness(1.07); }
.ghost-btn { background: rgba(255,255,255,.035); padding: 0 14px; }
.ghost-btn:hover, .icon-btn:hover { background: rgba(255,255,255,.075); border-color: var(--line-strong); }
.icon-btn { width: 40px; height: 40px; display: grid; place-items: center; background: rgba(255,255,255,.04); font-size: 22px; }
.login-shell { position: relative; z-index: 2; min-height: 100vh; display: grid; grid-template-columns: minmax(320px, 560px) minmax(260px, 420px); gap: 24px; align-items: center; justify-content: center; padding: 36px; }
.login-card { padding: 42px; }
.login-card h1 { font-size: clamp(34px, 6vw, 66px); line-height: .96; letter-spacing: -1.2px; margin: 8px 0 20px; max-width: 760px; }
.brand-mark, .logo-orb { display: grid; place-items: center; background: linear-gradient(135deg, #8b5cf6, #ec4899 55%, #f59e0b); color: #fff; font-weight: 800; letter-spacing: -.05em; box-shadow: 0 18px 44px rgba(139,92,246,.36); }
.brand-mark { width: 64px; height: 64px; border-radius: 20px; margin-bottom: 26px; }
.login-form { display: grid; gap: 14px; margin-top: 28px; }
label { display: grid; gap: 8px; color: var(--soft); font-size: 13px; font-weight: 600; }
input, textarea, select { width: 100%; background: rgba(255,255,255,.04); border: 1px solid var(--line); color: var(--text); border-radius: 12px; padding: 13px 14px; outline: none; }
textarea { resize: vertical; }
input:focus, textarea:focus, select:focus { border-color: rgba(139,92,246,.72); box-shadow: 0 0 0 4px rgba(139,92,246,.14); }
select option { background: #101114; color: #fff; }
.form-error { min-height: 20px; color: #fca5a5; margin: 0; }
.login-preview { padding: 28px; align-self: stretch; min-height: 440px; display: flex; flex-direction: column; justify-content: space-between; }
.preview-header, .user-chip { display: inline-flex; align-items: center; gap: 9px; color: var(--soft); font-size: 13px; }
.live-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--green); box-shadow: 0 0 0 6px rgba(16,185,129,.12); }
.preview-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.preview-grid div, .metric-card, .department-card, .task-card, .integration-card, .activity-item, .kanban-col { background: var(--surface); border: 1px solid var(--line); border-radius: 16px; }
.preview-grid div { padding: 18px; }
.preview-grid strong { display: block; font-size: 32px; letter-spacing: -1px; }
.preview-grid span { color: var(--muted); font-size: 12px; }
.mini-chart { height: 150px; display: flex; align-items: end; gap: 12px; padding: 16px; border-radius: 20px; border: 1px solid var(--line); background: linear-gradient(180deg, rgba(139,92,246,.12), rgba(255,255,255,.03)); }
.mini-chart i { flex: 1; border-radius: 12px 12px 4px 4px; background: linear-gradient(180deg, #ec4899, #8b5cf6); box-shadow: 0 12px 26px rgba(139,92,246,.26); }
.app-shell { position: relative; z-index: 2; min-height: 100vh; display: grid; grid-template-columns: 300px minmax(0, 1fr); gap: 18px; padding: 18px; }
.sidebar { position: sticky; top: 18px; height: calc(100vh - 36px); padding: 18px; display: flex; flex-direction: column; overflow: hidden; }
.logo-row { display: flex; gap: 12px; align-items: center; padding: 8px 8px 20px; }
.logo-orb { width: 42px; height: 42px; border-radius: 14px; }
.logo-row b { display: block; }
.logo-row em { display: block; color: var(--muted); font-style: normal; font-size: 12px; }
.main-nav, .department-nav { display: grid; gap: 7px; }
.main-nav a, .department-nav a { color: var(--soft); border: 1px solid transparent; border-radius: 12px; padding: 11px 12px; display: flex; align-items: center; gap: 9px; font-size: 13px; }
.main-nav a.active, .department-nav a.active, .main-nav a:hover, .department-nav a:hover { background: rgba(255,255,255,.055); border-color: var(--line); color: var(--text); }
.sidebar-section { margin-top: 18px; min-height: 0; display: flex; flex-direction: column; }
.section-label { color: var(--muted); font-size: 11px; text-transform: uppercase; letter-spacing: .12em; margin: 4px 8px 10px; }
.department-nav { overflow: auto; padding-right: 3px; }
.department-nav .mini-dot { width: 9px; height: 9px; border-radius: 50%; flex: none; }
.logout-btn { margin-top: auto; }
.workspace { min-width: 0; display: grid; grid-template-rows: auto 1fr; gap: 18px; }
.topbar { min-height: 86px; padding: 18px 22px; display: flex; align-items: center; justify-content: space-between; gap: 16px; }
.topbar h2 { margin: 0; font-size: 28px; letter-spacing: -.5px; }
.topbar-actions { display: flex; align-items: center; gap: 12px; }
.user-chip { background: var(--surface); border: 1px solid var(--line); border-radius: 999px; padding: 11px 14px; }
.live-sync-chip { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--muted); }
.live-sync-chip.sync-error { border-color: rgba(239,68,68,.45); color: #fecaca; }
.live-sync-chip.sync-error .live-dot { background: #ef4444; box-shadow: 0 0 0 6px rgba(239,68,68,.13); }
.route-view { display: grid; gap: 18px; padding-bottom: 20px; }
.hero-panel { display: grid; grid-template-columns: minmax(0, 1.25fr) minmax(300px, .75fr); gap: 18px; }
.hero-copy, .focus-panel { padding: 26px; border-radius: 22px; border: 1px solid var(--line); background: linear-gradient(135deg, rgba(255,255,255,.07), rgba(255,255,255,.025)); box-shadow: var(--shadow); }
.hero-copy h1 { font-size: clamp(34px, 4vw, 58px); letter-spacing: -1.25px; line-height: .98; margin: 0 0 14px; }
.metric-grid { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 14px; }
.metric-card { padding: 18px; }
.metric-card strong { font-size: 32px; letter-spacing: -1px; }
.metric-card span { display: block; color: var(--muted); font-size: 12px; margin-top: 4px; }
.token-metric { background: linear-gradient(135deg, rgba(139,92,246,.17), rgba(236,72,153,.09)); border-color: rgba(139,92,246,.28); }
.token-panel { display: grid; grid-template-columns: minmax(0, 1fr) minmax(360px, .55fr); gap: 18px; }
.token-panel-main, .token-departments { padding: 22px; border: 1px solid var(--line); border-radius: 22px; background: linear-gradient(135deg, rgba(255,255,255,.065), rgba(255,255,255,.025)); box-shadow: var(--shadow); }
.token-panel-main h2 { font-size: clamp(32px, 4vw, 56px); margin: 0 0 10px; letter-spacing: -1.1px; }
.token-breakdown { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 10px; margin-top: 18px; }
.token-breakdown div { padding: 14px; border: 1px solid var(--line); border-radius: 15px; background: rgba(255,255,255,.04); }
.token-breakdown strong { display: block; font-size: 22px; }
.token-breakdown span, .token-row span { display: block; color: var(--muted); font-size: 11px; margin-top: 3px; }
.token-bars { display: grid; gap: 10px; }
.token-row { position: relative; overflow: hidden; display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 12px; align-items: center; padding: 12px; border: 1px solid var(--line); border-radius: 15px; background: rgba(255,255,255,.035); }
.token-row b, .token-row strong, .token-row span { position: relative; z-index: 1; }
.token-row i { position: absolute; inset: auto 0 0 0; height: 3px; width: calc(var(--p) * 1%); background: linear-gradient(90deg, var(--dept-color, #8b5cf6), #ec4899); }
.easy-summary-panel { padding: 22px; border: 1px solid rgba(139,92,246,.28); border-radius: 24px; background: linear-gradient(135deg, rgba(139,92,246,.16), rgba(56,189,248,.055) 52%, rgba(255,255,255,.035)); box-shadow: var(--shadow); }
.easy-summary-head { display: flex; justify-content: space-between; gap: 18px; align-items: start; }
.easy-summary-head h2 { margin: 0 0 8px; font-size: clamp(26px, 3vw, 42px); letter-spacing: -.8px; }
.summary-counter { min-width: 145px; padding: 16px; border: 1px solid var(--line); border-radius: 18px; background: rgba(255,255,255,.06); text-align: center; }
.summary-counter strong { display: block; font-size: 38px; line-height: 1; }
.summary-counter span { color: var(--muted); font-size: 12px; }
.summary-stats { display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 10px; margin: 16px 0; }
.summary-stats div { padding: 13px; border: 1px solid var(--line); border-radius: 15px; background: rgba(255,255,255,.045); }
.summary-stats strong { display: block; font-size: 23px; }
.summary-stats span { color: var(--muted); font-size: 11px; }
.summary-grid { display: grid; grid-template-columns: minmax(0, 1.15fr) minmax(0, .85fr); gap: 14px; align-items: start; }
.summary-card { padding: 16px; border: 1px solid var(--line); border-radius: 18px; background: rgba(7,9,13,.46); }
.summary-card h3 { margin: 0 0 10px; font-size: 19px; }
.direct-command-card { border-color: rgba(236,72,153,.25); }
.summary-task-list { display: grid; gap: 10px; margin-top: 12px; }
.summary-task-list.compact { max-height: 520px; overflow: auto; padding-right: 3px; }
.summary-task { border: 1px solid var(--line); border-left: 3px solid var(--dept-color, #8b5cf6); border-radius: 15px; padding: 12px; background: rgba(255,255,255,.04); }
.summary-task-top { display: flex; align-items: center; justify-content: space-between; gap: 8px; margin-bottom: 8px; }
.summary-task h4 { margin: 0 0 7px; font-size: 14px; line-height: 1.35; }
.summary-task p { margin: 0 0 9px; color: var(--soft); font-size: 12px; line-height: 1.45; }
.summary-task small { display: block; color: var(--muted); font-size: 11px; line-height: 1.4; }
.gap-list { display: grid; gap: 9px; padding-left: 18px; color: var(--soft); }
.gap-list li { line-height: 1.45; }
.progress-ring { --p: 0; width: 148px; height: 148px; border-radius: 50%; display: grid; place-items: center; background: conic-gradient(var(--accent) calc(var(--p) * 1%), rgba(255,255,255,.07) 0); margin: 16px auto; position: relative; }
.progress-ring::after { content: ''; position: absolute; inset: 12px; border-radius: 50%; background: rgba(8,9,10,.88); border: 1px solid var(--line); }
.progress-ring b { position: relative; z-index: 1; font-size: 30px; }
.grid-2 { display: grid; grid-template-columns: minmax(0, 1fr) minmax(320px, .45fr); gap: 18px; }
.department-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 14px; }
.department-card { padding: 18px; position: relative; overflow: hidden; min-height: 210px; }
.department-card::before { content: ''; position: absolute; inset: -80px -80px auto auto; width: 170px; height: 170px; border-radius: 50%; background: radial-gradient(circle, var(--dept-color), transparent 65%); opacity: .25; }
.department-head { display: flex; justify-content: space-between; align-items: start; gap: 12px; position: relative; }
.department-icon { width: 44px; height: 44px; border-radius: 15px; display: grid; place-items: center; background: rgba(255,255,255,.06); border: 1px solid var(--line); font-size: 22px; }
.department-card h3 { margin: 12px 0 7px; font-size: 19px; letter-spacing: -.25px; }
.pill { display: inline-flex; align-items: center; gap: 6px; border-radius: 999px; border: 1px solid var(--line); background: rgba(255,255,255,.035); padding: 6px 9px; color: var(--soft); font-size: 11px; }
.progress-bar { height: 8px; border-radius: 999px; background: rgba(255,255,255,.07); overflow: hidden; margin: 16px 0 10px; }
.progress-bar i { display: block; height: 100%; width: calc(var(--p) * 1%); border-radius: inherit; background: linear-gradient(90deg, var(--dept-color, #8b5cf6), #ec4899); }
.card-actions { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 15px; }
.kanban { display: grid; grid-template-columns: repeat(4, minmax(220px, 1fr)); gap: 14px; overflow-x: auto; padding-bottom: 4px; }
.kanban-col { padding: 12px; min-height: 360px; }
.kanban-col h3 { margin: 2px 4px 12px; font-size: 14px; color: var(--soft); display: flex; justify-content: space-between; }
.task-card { padding: 13px; margin-bottom: 10px; }
.task-card h4 { margin: 0 0 8px; font-size: 14px; line-height: 1.35; }
.task-meta { display: flex; flex-wrap: wrap; gap: 6px; color: var(--muted); font-size: 11px; }
.task-description { color: var(--muted); font-size: 12px; line-height: 1.45; }
.task-actions { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 10px; }
.task-actions button { min-height: 30px; padding: 0 8px; border-radius: 8px; font-size: 11px; }
.priority-Urgent { color: #fecaca; border-color: rgba(239,68,68,.36); }
.priority-High { color: #fed7aa; border-color: rgba(249,115,22,.36); }
.priority-Medium { color: #bfdbfe; border-color: rgba(96,165,250,.32); }
.priority-Low { color: #bbf7d0; border-color: rgba(34,197,94,.32); }
.detail-layout { display: grid; grid-template-columns: minmax(0, 1fr) 340px; gap: 18px; }
.dept-hero { padding: 26px; border: 1px solid var(--line); border-radius: 22px; background: linear-gradient(135deg, rgba(255,255,255,.075), rgba(255,255,255,.025)); }
.dept-hero h1 { margin: 10px 0 12px; font-size: clamp(32px, 4vw, 54px); letter-spacing: -1px; }
.output-list { display: grid; gap: 10px; margin: 18px 0 0; padding: 0; list-style: none; }
.output-list li { padding: 11px 12px; border-radius: 12px; background: rgba(255,255,255,.04); border: 1px solid var(--line); color: var(--soft); }
.side-card { padding: 18px; border: 1px solid var(--line); background: var(--surface); border-radius: 18px; }
.side-card h3 { margin-top: 0; }
.integration-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(290px, 1fr)); gap: 14px; }
.integration-card { padding: 20px; min-height: 180px; }
.integration-card h3 { margin: 12px 0 8px; }
.integration-logo { width: 48px; height: 48px; border-radius: 16px; display: grid; place-items: center; background: rgba(255,255,255,.055); border: 1px solid var(--line); font-weight: 800; }
.activity-list { display: grid; gap: 10px; }
.activity-item { padding: 14px 16px; display: flex; justify-content: space-between; gap: 12px; }
.activity-item time { color: var(--muted); font-family: 'JetBrains Mono', monospace; font-size: 11px; }
.task-dialog { width: min(720px, calc(100vw - 28px)); padding: 0; border: 0; background: transparent; color: var(--text); }
.task-dialog::backdrop { background: rgba(0,0,0,.72); backdrop-filter: blur(8px); }
.task-form { padding: 22px; display: grid; gap: 14px; }
.dialog-head { display: flex; justify-content: space-between; align-items: start; gap: 12px; }
.dialog-head h3 { margin: 0; font-size: 28px; }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.dialog-actions { display: flex; justify-content: flex-end; gap: 10px; }
.toast { position: fixed; right: 22px; bottom: 22px; z-index: 50; background: rgba(16,17,20,.94); border: 1px solid var(--line); border-radius: 14px; padding: 13px 16px; color: var(--text); box-shadow: var(--shadow); opacity: 0; transform: translateY(10px); pointer-events: none; transition: .2s ease; }
.toast.show { opacity: 1; transform: translateY(0); }
.empty { padding: 28px; text-align: center; color: var(--muted); border: 1px dashed var(--line-strong); border-radius: 18px; background: rgba(255,255,255,.025); }
.command-hero .hero-copy { min-height: 420px; }
.command-input { display: grid; gap: 12px; margin-top: 20px; }
.command-input textarea { min-height: 118px; font-size: 15px; line-height: 1.55; }
.command-layout { display: grid; grid-template-columns: minmax(0, 1fr) 360px; gap: 18px; }
.chat-panel { padding: 18px; border: 1px solid var(--line); border-radius: 20px; background: var(--surface); }
.panel-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 14px; }
.panel-head h3 { margin: 0; font-size: 24px; }
.chat-stream { display: grid; gap: 14px; max-height: 760px; overflow: auto; padding-right: 4px; }
.chat-message { display: grid; gap: 10px; padding: 14px; border: 1px solid var(--line); border-radius: 18px; background: rgba(255,255,255,.035); }
.chat-row { display: grid; grid-template-columns: 46px minmax(0, 1fr); gap: 10px; align-items: start; }
.user-row { direction: rtl; }
.user-row > * { direction: ltr; }
.chat-avatar, .master-orb { display: grid; place-items: center; border-radius: 15px; font-weight: 800; }
.chat-avatar { min-height: 38px; background: rgba(255,255,255,.07); border: 1px solid var(--line); color: var(--soft); font-size: 12px; }
.master-orb { width: 74px; height: 74px; background: radial-gradient(circle at 30% 20%, #fff, #ec4899 28%, #8b5cf6 62%, #38bdf8); box-shadow: 0 22px 52px rgba(139,92,246,.34); letter-spacing: -.05em; }
.master-orb.small { width: 38px; height: 38px; border-radius: 13px; font-size: 12px; }
.chat-bubble { border: 1px solid var(--line); border-radius: 16px; padding: 12px 14px; background: rgba(255,255,255,.045); }
.user-command { background: linear-gradient(135deg, rgba(139,92,246,.24), rgba(236,72,153,.14)); }
.chat-bubble p { margin: 0; line-height: 1.55; }
.chat-bubble time { display: block; margin-top: 8px; color: var(--muted); font-family: 'JetBrains Mono', monospace; font-size: 11px; }
.master-line, .assignment-top { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-bottom: 8px; }
.assignment-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(230px, 1fr)); gap: 10px; margin-top: 12px; }
.assignment-card { padding: 13px; border: 1px solid var(--line); border-left: 3px solid var(--dept-color, #8b5cf6); border-radius: 16px; background: rgba(255,255,255,.04); }
.assignment-card h4 { margin: 10px 0 6px; font-size: 15px; }
.master-card { display: grid; align-content: center; justify-items: start; gap: 12px; }
.command-stats { display: grid; grid-template-columns: auto 1fr; gap: 4px 10px; align-items: baseline; }
.command-stats strong { font-size: 34px; letter-spacing: -1px; }
.command-stats span { color: var(--muted); font-size: 12px; }
.quick-command-grid { display: grid; gap: 9px; }
.quick-command-grid .ghost-btn { min-height: auto; padding: 12px; text-align: left; line-height: 1.45; }
.learning-stat-grid { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 14px; }
.evidence-layout { display: grid; grid-template-columns: minmax(0, 1fr) minmax(360px, .44fr); gap: 18px; align-items: start; }
.evidence-main, .learning-side { display: grid; gap: 18px; }
.evidence-panel { padding: 18px; border: 1px solid var(--line); border-radius: 20px; background: linear-gradient(135deg, rgba(255,255,255,.06), rgba(255,255,255,.025)); box-shadow: var(--shadow); }
.evidence-panel h3 { margin: 0 0 10px; }
.evidence-panel select { min-width: min(100%, 360px); }
.selected-task-card { border: 1px solid rgba(255,255,255,.13); border-left: 4px solid var(--dept-color, #8b5cf6); border-radius: 18px; padding: 15px; margin-bottom: 14px; background: rgba(255,255,255,.045); }
.selected-task-card h3 { margin: 8px 0; font-size: 20px; }
.selected-task-card p { color: var(--muted); font-size: 12px; line-height: 1.5; white-space: pre-wrap; }
.task-evidence-badges { display: flex; flex-wrap: wrap; gap: 6px; margin: 9px 0; }
.work-log-list { display: grid; gap: 11px; }
.work-log-list.compact { max-height: 620px; overflow: auto; padding-right: 4px; }
.work-log-card { border: 1px solid var(--line); border-left: 4px solid #94a3b8; border-radius: 16px; padding: 13px; background: rgba(7,9,13,.48); }
.work-log-card.type-search { border-left-color: #38bdf8; }
.work-log-card.type-design { border-left-color: #ec4899; }
.work-log-card.type-asset { border-left-color: #a855f7; }
.work-log-card.type-decision { border-left-color: #f59e0b; }
.work-log-card h4 { margin: 9px 0 6px; font-size: 15px; }
.work-log-card p { margin: 0; color: var(--soft); font-size: 12px; line-height: 1.5; }
.work-log-card pre { white-space: pre-wrap; word-break: break-word; max-height: 260px; overflow: auto; color: var(--muted); font-family: 'Inter', sans-serif; font-size: 12px; line-height: 1.5; border: 1px solid var(--line); border-radius: 12px; padding: 10px; background: rgba(255,255,255,.035); }
.work-log-top, .work-log-foot { display: flex; justify-content: space-between; gap: 10px; align-items: center; flex-wrap: wrap; }
.work-log-foot { margin-top: 10px; color: var(--muted); font-size: 11px; }
.work-log-foot a { color: #93c5fd; text-decoration: none; }
.status-completed { color: #bbf7d0; border-color: rgba(34,197,94,.32); }
.status-planned { color: #bfdbfe; border-color: rgba(96,165,250,.32); }
.status-in_progress { color: #fed7aa; border-color: rgba(249,115,22,.36); }
.status-blocked { color: #fecaca; border-color: rgba(239,68,68,.36); }
.learning-form { display: grid; gap: 12px; }
.learning-form h3 { margin-bottom: 0; }
.learning-note-list { display: grid; gap: 10px; }
.learning-note { border: 1px solid var(--line); border-radius: 15px; padding: 12px; background: rgba(255,255,255,.035); }
.learning-note p { color: var(--soft); font-size: 12px; line-height: 1.45; margin: 8px 0; }
.learning-note small { display: block; color: var(--muted); font-size: 11px; line-height: 1.4; }
.learning-note time { display: block; color: var(--muted); font-family: 'JetBrains Mono', monospace; font-size: 10px; margin-top: 8px; }
.figma-hero .hero-copy { min-height: 360px; }
.figma-hero h1, .figma-screen-copy h3, .visual-spec-section h3 { font-family: var(--font-display); letter-spacing: -.03em; }
.figma-status-card h3 { margin: 0; text-transform: capitalize; }
.figma-token-panel { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 14px; }
.figma-token-panel article { padding: 16px; border: 1px solid var(--line); border-radius: 18px; background: rgba(255,255,255,.045); }
.figma-token-panel h3 { margin: 8px 0 0; font-size: 14px; line-height: 1.45; color: var(--soft); }
.visual-spec-section { overflow: hidden; }
.image-selection-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(330px, 1fr)); gap: 14px; margin-top: 14px; }
.image-selection-card { display: grid; grid-template-columns: 1fr; gap: 13px; border: 1px solid var(--line); border-radius: 18px; padding: 12px; background: rgba(255,255,255,.035); }
.image-selection-card img { width: 100%; height: 240px; object-fit: contain; border-radius: 15px; border: 1px solid rgba(255,255,255,.1); background: radial-gradient(circle at 50% 20%, rgba(214,168,95,.12), transparent 42%), #05060a; }
.image-selection-card h4 { margin: 9px 0 6px; font-size: 18px; }
.image-selection-card p { color: var(--soft); font-size: 12px; line-height: 1.5; }
.image-selection-card dl { display: grid; grid-template-columns: 82px 1fr; gap: 6px 10px; margin: 10px 0 0; font-size: 11px; }
.image-selection-card dt { color: var(--muted); }
.image-selection-card dd { margin: 0; color: var(--soft); }
.palette-detail-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 12px; }
.palette-card { display: grid; grid-template-columns: 58px 1fr; gap: 12px; align-items: start; border: 1px solid var(--line); border-radius: 16px; padding: 12px; background: rgba(255,255,255,.035); }
.palette-swatch { display: block; width: 58px; height: 58px; border-radius: 16px; border: 1px solid rgba(255,255,255,.2); box-shadow: inset 0 0 0 1px rgba(0,0,0,.18); }
.palette-card h4 { margin: 0 0 4px; }
.palette-card code, .font-row code { color: #f7efe2; background: rgba(255,255,255,.06); border: 1px solid var(--line); border-radius: 999px; padding: 4px 7px; font-family: 'JetBrains Mono', monospace; font-size: 10px; }
.palette-card p { margin: 8px 0 4px; color: var(--soft); font-size: 12px; }
.palette-card small { color: var(--muted); line-height: 1.45; }
.visual-system-grid { display: grid; grid-template-columns: minmax(0, .85fr) minmax(0, 1.15fr); gap: 18px; }
.font-stack-list { display: grid; gap: 10px; }
.font-row { display: flex; justify-content: space-between; gap: 12px; align-items: center; border: 1px solid var(--line); border-radius: 15px; padding: 12px; background: rgba(255,255,255,.035); }
.font-row h4 { margin: 0 0 4px; font-size: 20px; }
.font-row.display-font h4 { font-family: var(--font-display); font-size: 28px; }
.font-row p { margin: 0 0 5px; color: var(--soft); }
.font-row small { color: var(--muted); }
.icon-spec-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(135px, 1fr)); gap: 9px; }
.icon-spec { display: grid; gap: 5px; border: 1px solid var(--line); border-radius: 14px; padding: 10px; background: rgba(255,255,255,.035); }
.icon-spec span { width: 34px; height: 34px; border-radius: 12px; display: grid; place-items: center; background: linear-gradient(135deg, rgba(214,168,95,.32), rgba(139,92,246,.24)); color: #f7efe2; font-size: 11px; font-weight: 800; }
.icon-spec b { font-size: 12px; }
.icon-spec small { color: var(--muted); line-height: 1.35; }
.color-token-row { display: flex; gap: 8px; margin: 10px 0; flex-wrap: wrap; }
.color-token-row span { width: 34px; height: 34px; border-radius: 11px; border: 1px solid rgba(255,255,255,.22); box-shadow: inset 0 0 0 1px rgba(0,0,0,.18); }
.figma-embed { width: 100%; min-height: 520px; border: 1px solid var(--line); border-radius: 18px; background: rgba(255,255,255,.03); }
.figma-board { overflow: hidden; }
.figma-screen-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); gap: 16px; }
.figma-screen-card { display: grid; gap: 13px; border: 1px solid var(--line); border-radius: 22px; padding: 14px; background: radial-gradient(circle at top left, rgba(236,72,153,.12), transparent 38%), rgba(7,9,13,.52); }
.figma-screen-copy h3 { margin: 10px 0 6px; font-size: 20px; }
.figma-screen-copy p { color: var(--soft); font-size: 13px; line-height: 1.55; }
.figma-screen-copy ul { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 8px; padding: 0; list-style: none; margin: 12px 0 0; }
.figma-screen-copy li { border: 1px solid var(--line); border-radius: 12px; padding: 9px; color: var(--muted); background: rgba(255,255,255,.035); font-size: 11px; }
.figma-mockup { border: 1px solid rgba(255,255,255,.16); border-radius: 22px; overflow: hidden; background: #070910; box-shadow: 0 26px 70px rgba(0,0,0,.32); }
.figma-mockup.desktop { min-height: 330px; }
.figma-mockup.mobile { width: min(100%, 250px); margin: 0 auto; border-radius: 32px; min-height: 420px; }
.figma-mockup-bar { height: 40px; display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; gap: 8px; padding: 0 14px; background: rgba(255,255,255,.055); border-bottom: 1px solid var(--line); color: #f7efe2; }
.figma-mockup-bar span { width: 48px; height: 10px; border-radius: 999px; background: linear-gradient(90deg,#ec4899,#8b5cf6); opacity: .7; }
.figma-mockup-bar i { justify-self: end; width: 32px; height: 10px; border-radius: 999px; background: rgba(255,255,255,.16); }
.figma-mockup-body { padding: 14px; display: grid; gap: 12px; }
.mock-hero { min-height: 118px; border-radius: 18px; display: grid; align-items: end; padding: 16px; background: linear-gradient(135deg, rgba(214,168,95,.34), rgba(236,72,153,.16)), radial-gradient(circle at 72% 18%, rgba(255,255,255,.28), transparent 32%); }
.mock-hero small, .mock-hero em { display: block; color: rgba(255,255,255,.72); font-style: normal; font-size: 10px; letter-spacing: .14em; text-transform: uppercase; }
.mock-hero strong { display: block; margin: 5px 0; color: #fff; font-size: 22px; letter-spacing: -.03em; }
.mock-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; }
.mock-grid.mobile-grid { grid-template-columns: 1fr; }
.mock-grid span { min-height: 62px; border-radius: 14px; padding: 8px; display: grid; align-items: end; color: rgba(255,255,255,.78); font-size: 10px; line-height: 1.25; background: linear-gradient(135deg, rgba(255,255,255,.08), rgba(255,255,255,.025)); border: 1px solid rgba(255,255,255,.09); }
.mock-grid span:nth-child(2n) { background: linear-gradient(135deg, rgba(139,92,246,.18), rgba(255,255,255,.03)); }
.mock-cta { display: flex; justify-content: space-between; align-items: center; gap: 10px; border: 1px solid var(--line); border-radius: 15px; padding: 11px 12px; background: rgba(255,255,255,.045); }
.mock-cta b { font-size: 12px; color: var(--soft); }
.mock-cta button { border: 0; border-radius: 999px; padding: 8px 12px; color: #130d08; background: #f7efe2; font-size: 11px; font-weight: 800; }
.figma-handoff-grid { display: grid; grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr); gap: 18px; }
.component-chip-grid { display: flex; flex-wrap: wrap; gap: 8px; }
.component-chip-grid span { border: 1px solid var(--line); border-radius: 999px; padding: 9px 11px; color: var(--soft); background: rgba(255,255,255,.04); font-size: 12px; }
@media (max-width: 1100px) { .app-shell { grid-template-columns: 1fr; } .sidebar { position: relative; top: 0; height: auto; } .department-nav { max-height: 220px; } .hero-panel, .grid-2, .detail-layout, .command-layout, .token-panel, .summary-grid, .evidence-layout, .figma-handoff-grid, .visual-system-grid { grid-template-columns: 1fr; } .metric-grid, .learning-stat-grid, .token-breakdown, .summary-stats, .figma-token-panel { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 760px) { .login-shell { grid-template-columns: 1fr; padding: 18px; } .login-card { padding: 26px; } .topbar, .topbar-actions, .easy-summary-head { align-items: stretch; flex-direction: column; } .metric-grid, .token-breakdown, .summary-stats, .figma-token-panel { grid-template-columns: 1fr; } .form-grid { grid-template-columns: 1fr; } .app-shell { padding: 10px; } .kanban { grid-template-columns: minmax(260px, 1fr); } .figma-screen-grid { grid-template-columns: 1fr; } .image-selection-card { grid-template-columns: 1fr; } .image-selection-card img { min-height: 190px; } }
