:root {
  --navy:#0b1929; --navy-mid:#112240; --navy-card:#0f1e36;
  --navy-light:#1a3050; --navy-hover:#1e3a5f;
  --gold:#c9a84c; --gold-l:#e8c97a; --gold-d:#8a6f32; --gold-bg:rgba(201,168,76,.08);
  --ice:#e2eaf5; --ice-dim:#8fa3bc; --ice-muted:#5a7494;
  --d1:#2b7fc4; --d2:#3a9c42; --d3:#8b35c4; --d4:#d94040; --d5:#e86e1a;
  --success:#27ae60; --warning:#f39c12; --danger:#e74c3c;
  --radius:8px; --radius-lg:12px; --radius-xl:18px;
  --shadow:0 2px 12px rgba(0,0,0,.35);
  --transition:all .2s cubic-bezier(.4,0,.2,1);
}
*{box-sizing:border-box;margin:0;padding:0;}
html,body{height:100%;overflow:hidden;}
body{font-family:'DM Sans',sans-serif;background:var(--navy);color:var(--ice);font-size:13px;display:flex;}

#sidebar{width:240px;flex-shrink:0;background:var(--navy-mid);border-right:1px solid var(--navy-light);display:flex;flex-direction:column;height:100vh;overflow-y:auto;position:relative;z-index:10;}
.sidebar-logo{padding:20px 18px 16px;border-bottom:1px solid var(--navy-light);}
.logo-mark{display:flex;align-items:center;gap:10px;margin-bottom:4px;}
.logo-diamond{width:28px;height:28px;background:var(--gold);clip-path:polygon(50% 0%,100% 50%,50% 100%,0% 50%);flex-shrink:0;}
.logo-title{font-family:'Playfair Display',serif;font-size:15px;font-weight:700;color:var(--ice);line-height:1.2;}
.logo-sub{font-family:'IBM Plex Mono',monospace;font-size:9px;color:var(--gold);letter-spacing:.1em;text-transform:uppercase;margin-top:2px;}

.nav-section{padding:8px 0;border-bottom:1px solid var(--navy-light);}
.nav-label{font-family:'IBM Plex Mono',monospace;font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--ice-muted);padding:6px 18px 4px;}
.nav-item{display:flex;align-items:center;gap:10px;padding:9px 18px;cursor:pointer;transition:var(--transition);border-left:2px solid transparent;font-size:12.5px;color:var(--ice-dim);user-select:none;}
.nav-item:hover{background:var(--navy-hover);color:var(--ice);}
.nav-item.active{background:var(--gold-bg);color:var(--gold-l);border-left-color:var(--gold);}
.nav-icon{width:16px;height:16px;flex-shrink:0;opacity:.7;}
.nav-item.active .nav-icon{opacity:1;}
.nav-item .badge{margin-left:auto;font-family:'IBM Plex Mono',monospace;font-size:9px;padding:2px 5px;border-radius:10px;background:var(--navy-light);color:var(--ice-dim);}
.nav-item.active .badge{background:var(--gold-d);color:var(--gold-l);}

.phase-nav{display:flex;align-items:center;gap:10px;padding:8px 18px;cursor:pointer;transition:var(--transition);border-left:2px solid transparent;font-size:12px;color:var(--ice-dim);}
.phase-nav:hover{background:var(--navy-hover);color:var(--ice);}
.phase-nav.active{border-left-color:var(--phase-color);color:var(--ice);background:rgba(255,255,255,.04);}
.phase-dot{width:8px;height:8px;border-radius:50%;background:var(--phase-color);flex-shrink:0;opacity:.5;}
.phase-nav.active .phase-dot{opacity:1;}
.phase-nav.done .phase-dot{background:var(--success);opacity:1;}
.phase-progress{margin-left:auto;font-family:'IBM Plex Mono',monospace;font-size:9px;color:var(--ice-muted);}

.sidebar-bottom{margin-top:auto;padding:16px 18px;border-top:1px solid var(--navy-light);}
.teacher-card{display:flex;align-items:center;gap:10px;}
.teacher-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--d1),var(--d3));display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;color:white;flex-shrink:0;}
.teacher-name{font-size:12px;font-weight:500;color:var(--ice);}
.teacher-subject{font-size:10px;color:var(--ice-muted);}

#main{flex:1;display:flex;flex-direction:column;height:100vh;overflow:hidden;}
#topbar{height:56px;flex-shrink:0;background:var(--navy-card);border-bottom:1px solid var(--navy-light);display:flex;align-items:center;padding:0 28px;gap:16px;}
.topbar-title{font-family:'Playfair Display',serif;font-size:17px;font-weight:700;color:var(--ice);flex:1;}
.topbar-breadcrumb{font-family:'IBM Plex Mono',monospace;font-size:10px;color:var(--ice-muted);margin-top:2px;letter-spacing:.05em;}
.topbar-actions{display:flex;align-items:center;gap:10px;}
.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:var(--radius);font-size:12px;font-weight:500;cursor:pointer;transition:var(--transition);border:none;font-family:'DM Sans',sans-serif;}
.btn-primary{background:var(--gold);color:#0b1929;}
.btn-primary:hover{background:var(--gold-l);}
.btn-ghost{background:transparent;color:var(--ice-dim);border:1px solid var(--navy-light);}
.btn-ghost:hover{background:var(--navy-hover);color:var(--ice);border-color:var(--navy-hover);}
.phase-badge{font-family:'IBM Plex Mono',monospace;font-size:10px;padding:4px 10px;border-radius:20px;font-weight:500;letter-spacing:.05em;}

#content{flex:1;overflow-y:auto;padding:28px;}

.dashboard-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;margin-bottom:20px;}
.stat-card{background:var(--navy-mid);border:1px solid var(--navy-light);border-radius:var(--radius-lg);padding:18px 20px;}
.stat-label{font-family:'IBM Plex Mono',monospace;font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--ice-muted);margin-bottom:8px;}
.stat-value{font-family:'Playfair Display',serif;font-size:28px;font-weight:700;color:var(--ice);line-height:1;margin-bottom:4px;}
.stat-sub{font-size:11px;color:var(--ice-dim);}
.stat-card.accent{border-top:2px solid var(--gold);}

.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;}
.section-title{font-family:'Playfair Display',serif;font-size:16px;font-weight:700;color:var(--ice);}
.section-action{font-size:11px;color:var(--gold);cursor:pointer;}
.section-action:hover{color:var(--gold-l);}

.phase-overview-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:20px;}
.phase-overview-card{background:var(--navy-card);border:1px solid var(--navy-light);border-radius:var(--radius-lg);padding:16px 18px;cursor:pointer;transition:var(--transition);border-left:3px solid var(--phase-color);}
.phase-overview-card:hover{background:var(--navy-hover);transform:translateY(-1px);}
.phase-overview-card.active-phase{border-color:var(--phase-color);background:linear-gradient(135deg,rgba(255,255,255,.03),transparent);}
.poc-header{display:flex;align-items:center;gap:10px;margin-bottom:8px;}
.poc-day{font-family:'IBM Plex Mono',monospace;font-size:9px;padding:2px 7px;border-radius:10px;background:var(--phase-color);color:white;letter-spacing:.05em;}
.poc-title{font-size:12.5px;font-weight:600;color:var(--ice);flex:1;}
.poc-dim{font-size:10px;color:var(--ice-muted);}
.poc-progress{display:flex;align-items:center;gap:8px;margin-top:8px;}
.poc-bar{flex:1;height:3px;background:var(--navy-light);border-radius:2px;overflow:hidden;}
.poc-fill{height:100%;background:var(--phase-color);border-radius:2px;transition:width .6s ease;}
.poc-pct{font-family:'IBM Plex Mono',monospace;font-size:9px;color:var(--ice-muted);}

.activity-feed{background:var(--navy-card);border:1px solid var(--navy-light);border-radius:var(--radius-lg);padding:0;overflow:hidden;}
.activity-item{display:flex;align-items:flex-start;gap:12px;padding:12px 18px;border-bottom:1px solid var(--navy-light);font-size:12px;}
.activity-item:last-child{border-bottom:none;}
.activity-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:3px;}
.activity-text{color:var(--ice-dim);line-height:1.5;flex:1;}
.activity-text strong{color:var(--ice);}
.activity-time{font-family:'IBM Plex Mono',monospace;font-size:9px;color:var(--ice-muted);white-space:nowrap;}

.phase-hero{background:var(--navy-card);border:1px solid var(--navy-light);border-radius:var(--radius-xl);padding:24px 28px;margin-bottom:20px;position:relative;overflow:hidden;}
.phase-hero::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--phase-color);}
.phase-hero-day{font-family:'IBM Plex Mono',monospace;font-size:10px;color:var(--phase-color);letter-spacing:.12em;text-transform:uppercase;margin-bottom:6px;}
.phase-hero-title{font-family:'Playfair Display',serif;font-size:22px;font-weight:700;color:var(--ice);margin-bottom:4px;}
.phase-hero-dim{font-size:12px;color:var(--ice-dim);}
.phase-hero-orient{margin-top:12px;padding:12px 14px;background:rgba(255,255,255,.03);border-left:3px solid var(--phase-color);border-radius:0 var(--radius) var(--radius) 0;font-size:12.5px;color:var(--ice-dim);line-height:1.7;}
.phase-hero-orient strong{color:var(--ice);}
.phase-hero-footer{display:flex;align-items:center;gap:16px;margin-top:16px;}
.hero-stat{display:flex;align-items:center;gap:6px;}
.hero-stat-val{font-family:'IBM Plex Mono',monospace;font-size:11px;color:var(--phase-color);font-weight:500;}
.hero-stat-lbl{font-size:11px;color:var(--ice-muted);}

.two-col{display:grid;grid-template-columns:1.4fr 1fr;gap:16px;}
.card{background:var(--navy-card);border:1px solid var(--navy-light);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:14px;}
.card-header{padding:12px 16px;border-bottom:1px solid var(--navy-light);display:flex;align-items:center;justify-content:space-between;}
.card-title{font-family:'IBM Plex Mono',monospace;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--ice-dim);}
.card-body{padding:14px 16px;}

.task-item{display:flex;align-items:flex-start;gap:12px;padding:10px 0;border-bottom:1px solid rgba(255,255,255,.04);cursor:pointer;}
.task-item:last-child{border-bottom:none;}
.task-check{width:18px;height:18px;border-radius:4px;border:1.5px solid var(--navy-light);flex-shrink:0;margin-top:1px;display:flex;align-items:center;justify-content:center;transition:var(--transition);}
.task-item.done .task-check{background:var(--success);border-color:var(--success);}
.task-check-mark{width:10px;height:10px;opacity:0;transition:var(--transition);}
.task-item.done .task-check-mark{opacity:1;}
.task-content{flex:1;}
.task-name{font-size:12.5px;font-weight:500;color:var(--ice);margin-bottom:3px;line-height:1.4;}
.task-desc{font-size:11px;color:var(--ice-dim);line-height:1.5;}
.task-item.done .task-name{color:var(--ice-dim);text-decoration:line-through;}
.task-tag{font-family:'IBM Plex Mono',monospace;font-size:9px;padding:2px 6px;border-radius:4px;border:1px solid;margin-top:4px;display:inline-block;}
.task-log-btn{font-size:10px;color:var(--gold);cursor:pointer;padding:3px 8px;border:1px solid var(--gold-d);border-radius:4px;white-space:nowrap;flex-shrink:0;transition:var(--transition);}
.task-log-btn:hover{background:var(--gold-bg);color:var(--gold-l);}

.artefact-item{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.04);font-size:12px;}
.artefact-item:last-child{border-bottom:none;}
.artefact-status{width:20px;height:20px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:10px;}
.artefact-status.pending{background:var(--navy-light);color:var(--ice-muted);}
.artefact-status.submitted{background:var(--success);color:white;}
.artefact-name{flex:1;color:var(--ice-dim);}
.artefact-item.submitted .artefact-name{color:var(--ice);}

.dspec-box{background:rgba(230,81,0,.06);border:1px solid rgba(230,81,0,.25);border-radius:var(--radius);padding:12px 14px;margin-top:12px;}
.dspec-title{font-family:'IBM Plex Mono',monospace;font-size:9px;color:#e86e1a;letter-spacing:.1em;text-transform:uppercase;margin-bottom:8px;}
.dspec-levels{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;}
.dspec-level{padding:8px 10px;border-radius:6px;font-size:11px;line-height:1.5;}
.dspec-level strong{display:block;font-size:9px;font-family:'IBM Plex Mono',monospace;margin-bottom:4px;}

.llm-box{background:rgba(201,168,76,.06);border:1px solid rgba(201,168,76,.25);border-radius:var(--radius-lg);padding:14px 16px;margin-bottom:14px;}
.llm-title{font-family:'IBM Plex Mono',monospace;font-size:9px;color:var(--gold);letter-spacing:.1em;text-transform:uppercase;margin-bottom:8px;display:flex;justify-content:space-between;align-items:center;}
.llm-orientation{font-size:13px;color:var(--ice);line-height:1.6;margin-bottom:10px;}
.llm-list{margin:4px 0 10px 16px;font-size:11.5px;color:var(--ice-dim);line-height:1.7;}
.llm-list li{margin-bottom:2px;}

.log-tabs{display:flex;gap:4px;margin-bottom:16px;background:var(--navy-card);padding:4px;border-radius:var(--radius);border:1px solid var(--navy-light);width:fit-content;}
.log-tab{font-family:'IBM Plex Mono',monospace;font-size:10px;padding:6px 12px;border-radius:6px;cursor:pointer;color:var(--ice-muted);transition:var(--transition);letter-spacing:.05em;}
.log-tab:hover{color:var(--ice);}
.log-tab.active{background:var(--navy-light);color:var(--gold);}

.log-form{background:var(--navy-card);border:1px solid var(--navy-light);border-radius:var(--radius-lg);padding:20px;margin-bottom:16px;}
.form-row{margin-bottom:14px;}
.form-label{display:block;font-family:'IBM Plex Mono',monospace;font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--ice-muted);margin-bottom:6px;}
.form-label span{color:var(--gold);margin-left:4px;}
.form-input,.form-textarea,.form-select{width:100%;background:var(--navy);border:1px solid var(--navy-light);border-radius:var(--radius);padding:9px 12px;font-size:12.5px;color:var(--ice);font-family:'DM Sans',sans-serif;transition:var(--transition);outline:none;}
.form-input:focus,.form-textarea:focus,.form-select:focus{border-color:var(--gold-d);box-shadow:0 0 0 2px rgba(201,168,76,.12);}
.form-textarea{resize:vertical;min-height:80px;line-height:1.6;}
.form-select option{background:var(--navy-mid);}
.form-row-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;}

/* ─── AI Suggest widget (reusable on any input) ────────────────────────── */
.ai-suggest-wrap{position:relative;}
.ai-suggest-wrap > .form-input,
.ai-suggest-wrap > .form-textarea{padding-right:38px;}
.ai-suggest-btn{position:absolute;right:6px;top:6px;width:26px;height:26px;border-radius:4px;border:1px solid rgba(201,168,76,.4);background:var(--gold-bg);color:var(--gold);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:13px;padding:0;line-height:1;transition:var(--transition);font-family:inherit;}
.ai-suggest-btn:hover{background:rgba(201,168,76,.2);color:var(--gold-l);}
.ai-suggest-btn:disabled{opacity:.55;cursor:wait;}
.ai-suggest-btn svg{width:13px;height:13px;}
.ai-suggest-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--navy-card);border:1px solid rgba(201,168,76,.4);border-radius:var(--radius);box-shadow:0 10px 28px rgba(0,0,0,.55);z-index:1000;max-height:280px;overflow-y:auto;display:none;}
.ai-suggest-dropdown.open{display:block;}
.ai-suggest-dropdown-header{padding:8px 12px;font-family:'IBM Plex Mono',monospace;font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);border-bottom:1px solid var(--navy-light);display:flex;align-items:center;gap:6px;}
.ai-suggest-item{padding:10px 12px;cursor:pointer;font-size:12px;color:var(--ice);border-bottom:1px solid rgba(255,255,255,.04);line-height:1.4;}
.ai-suggest-item:last-child{border-bottom:none;}
.ai-suggest-item:hover{background:rgba(201,168,76,.1);color:var(--gold-l);}
.ai-suggest-status{padding:12px;font-size:11.5px;color:var(--ice-muted);font-style:italic;text-align:center;}
.ai-suggest-status.error{color:#ef5350;font-style:normal;}
.ai-suggest-status .pulse-dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--gold);margin-right:6px;animation:ai-pulse 1s ease-in-out infinite;}
@keyframes ai-pulse{0%,100%{opacity:.3;}50%{opacity:1;}}

/* ─── About HAA view (philosophy) ──────────────────────────────────────── */
.about-view{max-width:860px;margin:0 auto;}
.about-ticker{margin-bottom:18px;padding:14px 22px;border-left:3px solid var(--gold);background:var(--gold-bg);border-radius:0 var(--radius) var(--radius) 0;animation:about-ticker-fade .6s ease;}
.about-ticker-text{font-family:'Playfair Display',serif;font-size:16px;color:var(--gold-l);letter-spacing:.02em;line-height:1.45;font-style:italic;}
@keyframes about-ticker-fade{from{opacity:0;transform:translateY(-4px);}to{opacity:1;transform:translateY(0);}}
.about-hero{background:linear-gradient(135deg,var(--navy-card),var(--navy-mid));border:1px solid rgba(201,168,76,.25);border-radius:var(--radius-lg);padding:28px 30px;margin-bottom:28px;position:relative;overflow:hidden;}
.about-hero::before{content:'';position:absolute;top:-40px;right:-40px;width:200px;height:200px;background:radial-gradient(circle,rgba(201,168,76,.12),transparent 70%);pointer-events:none;}
.about-hero-title{font-family:'Playfair Display',serif;font-size:22px;font-weight:700;color:var(--ice);line-height:1.35;margin-bottom:16px;position:relative;}
.about-hero-body{font-size:13px;color:var(--ice-dim);line-height:1.7;max-width:680px;position:relative;}
.about-hero-body strong{color:var(--ice);}
.about-hero-body em{color:var(--gold-l);font-style:italic;}
.about-hero-cards{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:22px;position:relative;}
.about-hero-card{background:rgba(11,25,41,.55);border:1px solid var(--navy-light);border-radius:var(--radius);padding:12px 14px;}
.about-hero-card-k{font-family:'IBM Plex Mono',monospace;font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-bottom:4px;}
.about-hero-card-v{font-size:11.5px;color:var(--ice-dim);line-height:1.55;}
.about-markdown{color:var(--ice-dim);font-size:13px;line-height:1.75;}
.about-markdown h1{font-family:'Playfair Display',serif;font-size:22px;color:var(--ice);margin:28px 0 12px;font-weight:700;}
.about-markdown h2{font-family:'Playfair Display',serif;font-size:18px;color:var(--ice);margin:26px 0 10px;font-weight:700;border-bottom:1px solid var(--navy-light);padding-bottom:6px;}
.about-markdown h3{font-family:'DM Sans',sans-serif;font-size:14px;color:var(--gold-l);margin:22px 0 8px;font-weight:600;letter-spacing:.02em;}
.about-markdown p{margin:10px 0;}
.about-markdown strong{color:var(--ice);}
.about-markdown em{color:var(--gold-l);font-style:italic;}
.about-markdown blockquote{border-left:3px solid var(--gold);padding:10px 14px;margin:16px 0;background:var(--gold-bg);border-radius:0 4px 4px 0;color:var(--ice);font-style:italic;}
.about-markdown code{font-family:'IBM Plex Mono',monospace;font-size:11.5px;background:var(--navy);padding:2px 6px;border-radius:3px;color:var(--gold-l);}
.about-markdown hr{border:none;border-top:1px solid var(--navy-light);margin:28px 0;}
.about-markdown table{width:100%;border-collapse:collapse;margin:16px 0;font-size:12px;}
.about-markdown th,.about-markdown td{padding:10px 12px;text-align:left;border-bottom:1px solid var(--navy-light);vertical-align:top;}
.about-markdown th{background:var(--navy-card);color:var(--gold);font-family:'IBM Plex Mono',monospace;font-size:10px;letter-spacing:.08em;text-transform:uppercase;font-weight:500;}
.about-markdown tr:hover td{background:rgba(255,255,255,.02);}
.about-markdown a{color:var(--gold-l);text-decoration:none;border-bottom:1px dashed var(--gold-d);}
.about-markdown a:hover{color:var(--gold);}
.about-footer{margin-top:32px;padding-top:16px;border-top:1px solid var(--navy-light);font-family:'IBM Plex Mono',monospace;font-size:10px;color:var(--ice-muted);text-align:center;}
.about-footer code{background:var(--navy);padding:2px 6px;border-radius:3px;color:var(--gold-l);}

.log-entries{background:var(--navy-card);border:1px solid var(--navy-light);border-radius:var(--radius-lg);overflow:hidden;}
.log-entry-item{padding:12px 16px;border-bottom:1px solid var(--navy-light);font-size:12px;display:flex;align-items:flex-start;gap:10px;}
.log-entry-item:last-child{border-bottom:none;}
.log-entry-num{font-family:'IBM Plex Mono',monospace;font-size:9px;color:var(--ice-muted);width:20px;flex-shrink:0;margin-top:2px;}
.log-entry-body{flex:1;}
.log-entry-intent{font-weight:500;color:var(--ice);margin-bottom:3px;}
.log-entry-meta{font-size:11px;color:var(--ice-muted);}
.log-entry-type{font-family:'IBM Plex Mono',monospace;font-size:9px;padding:2px 6px;border-radius:4px;border:1px solid;flex-shrink:0;}

.rubric-header{background:var(--navy-card);border:1px solid var(--navy-light);border-radius:var(--radius-lg);padding:16px 20px;margin-bottom:16px;display:flex;align-items:center;justify-content:space-between;}
.score-display{font-family:'Playfair Display',serif;font-size:36px;font-weight:700;color:var(--gold);}
.score-max{font-size:18px;color:var(--ice-muted);}
.score-label{font-size:11px;color:var(--ice-dim);}

.dim-accordion{margin-bottom:10px;}
.dim-accordion-header{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--navy-card);border:1px solid var(--navy-light);border-radius:var(--radius-lg);cursor:pointer;transition:var(--transition);}
.dim-accordion-header:hover{background:var(--navy-hover);}
.dim-accordion-header.open{border-bottom-left-radius:0;border-bottom-right-radius:0;border-bottom-color:transparent;}
.dim-color-bar{width:4px;height:32px;border-radius:2px;flex-shrink:0;}
.dim-acc-name{font-size:13px;font-weight:600;color:var(--ice);}
.dim-acc-sub{font-size:10.5px;color:var(--ice-muted);}
.dim-acc-score{font-family:'IBM Plex Mono',monospace;font-size:12px;font-weight:500;text-align:right;}
.dim-acc-chevron{width:16px;height:16px;color:var(--ice-muted);transition:transform .2s;flex-shrink:0;}
.dim-accordion-header.open .dim-acc-chevron{transform:rotate(180deg);}
.dim-accordion-body{background:var(--navy-card);border:1px solid var(--navy-light);border-top:none;border-bottom-left-radius:var(--radius-lg);border-bottom-right-radius:var(--radius-lg);overflow:hidden;display:none;}
.dim-accordion-body.open{display:block;}
.sub-comp-row{padding:14px 16px;border-bottom:1px solid rgba(255,255,255,.04);}
.sub-comp-row:last-child{border-bottom:none;}
.sub-comp-header{display:flex;align-items:center;gap:8px;margin-bottom:10px;flex-wrap:wrap;}
.sub-comp-code{font-family:'IBM Plex Mono',monospace;font-size:10px;padding:2px 7px;border-radius:4px;font-weight:500;}
.sub-comp-name{font-size:12.5px;font-weight:500;color:var(--ice);}
.sub-comp-haa{font-size:10px;color:var(--ice-muted);margin-left:auto;}
.level-selector{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin-bottom:8px;}
.level-btn{padding:8px 6px;border-radius:6px;border:1px solid var(--navy-light);cursor:pointer;transition:var(--transition);text-align:center;}
.level-btn:hover{border-color:var(--ice-muted);}
.level-num{font-family:'IBM Plex Mono',monospace;font-size:11px;font-weight:700;margin-bottom:2px;display:block;}
.level-name-s{font-size:9px;color:var(--ice-muted);}
.level-btn.l1.sel{border-color:#D32F2F;background:rgba(211,47,47,.12);}
.level-btn.l1.sel .level-num{color:#ef5350;}
.level-btn.l2.sel{border-color:#E65100;background:rgba(230,81,0,.12);}
.level-btn.l2.sel .level-num{color:#ff7043;}
.level-btn.l3.sel{border-color:#1B5E20;background:rgba(27,94,32,.12);}
.level-btn.l3.sel .level-num{color:#66bb6a;}
.level-btn.l4.sel{border-color:#0D47A1;background:rgba(13,71,161,.12);}
.level-btn.l4.sel .level-num{color:#42a5f5;}

.dim-bar-chart{display:flex;flex-direction:column;gap:8px;}
.dim-bar-row{display:flex;align-items:center;gap:10px;}
.dim-bar-label{font-size:11px;color:var(--ice-dim);width:28px;flex-shrink:0;text-align:right;}
.dim-bar-track{flex:1;height:6px;background:var(--navy-light);border-radius:3px;overflow:hidden;}
.dim-bar-fill{height:100%;border-radius:3px;transition:width .8s cubic-bezier(.4,0,.2,1);}
.dim-bar-val{font-family:'IBM Plex Mono',monospace;font-size:10px;color:var(--ice-muted);width:28px;}

.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);display:flex;align-items:center;justify-content:center;z-index:1000;opacity:0;pointer-events:none;transition:opacity .2s;}
.modal-overlay.open{opacity:1;pointer-events:all;}
.modal{background:var(--navy-mid);border:1px solid var(--navy-light);border-radius:var(--radius-xl);padding:24px;width:560px;max-width:90vw;max-height:85vh;overflow-y:auto;transform:scale(.96);transition:transform .2s;}
.modal-overlay.open .modal{transform:scale(1);}
.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;}
.modal-title{font-family:'Playfair Display',serif;font-size:17px;font-weight:700;color:var(--ice);}
.modal-close{cursor:pointer;color:var(--ice-muted);font-size:20px;line-height:1;}
.modal-close:hover{color:var(--ice);}

.profile-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.profile-avatar-section{background:var(--navy-card);border:1px solid var(--navy-light);border-radius:var(--radius-lg);padding:28px;display:flex;flex-direction:column;align-items:center;gap:12px;}
.profile-avatar-lg{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,var(--d1),var(--d3));display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700;color:white;border:3px solid var(--navy-light);}
.profile-name-lg{font-family:'Playfair Display',serif;font-size:18px;font-weight:700;color:var(--ice);}
.profile-subject-lg{font-size:12px;color:var(--ice-muted);}
.profile-tag{font-family:'IBM Plex Mono',monospace;font-size:9px;padding:3px 9px;border-radius:10px;background:var(--gold-bg);color:var(--gold);border:1px solid var(--gold-d);}

::-webkit-scrollbar{width:5px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:var(--navy-light);border-radius:3px;}
::-webkit-scrollbar-thumb:hover{background:var(--ice-muted);}
.svg-icon{display:block;}

@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.fade-in{animation:fadeIn .3s ease forwards;}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}
.pulse{animation:pulse 2s infinite;}

.empty-state{text-align:center;padding:32px 20px;color:var(--ice-muted);font-size:12px;}
.empty-state-icon{font-size:28px;margin-bottom:10px;opacity:.4;}
.empty-state-text{line-height:1.6;}

.coach-box{background:rgba(58,156,66,.08);border:1px solid rgba(58,156,66,.3);border-radius:var(--radius);padding:12px 14px;font-size:12px;color:var(--ice);}
.coach-box .tag{display:inline-block;font-family:'IBM Plex Mono',monospace;font-size:9px;padding:2px 6px;border-radius:4px;background:rgba(58,156,66,.2);color:#7ccc80;margin-right:6px;}
.coach-box ul{margin:6px 0 0 18px;line-height:1.6;color:var(--ice-dim);}

.upload-zone{border:1.5px dashed var(--navy-light);border-radius:var(--radius-lg);padding:24px;text-align:center;color:var(--ice-muted);font-size:12px;cursor:pointer;transition:var(--transition);}
.upload-zone:hover{border-color:var(--gold-d);color:var(--ice-dim);}

.user-row{display:grid;grid-template-columns:2fr 2fr 1fr 1fr auto;gap:10px;padding:10px 14px;border-bottom:1px solid var(--navy-light);align-items:center;font-size:12px;}
.user-row:last-child{border-bottom:none;}
.user-row strong{color:var(--ice);}
.pill{font-family:'IBM Plex Mono',monospace;font-size:9px;padding:2px 7px;border-radius:10px;background:var(--navy-light);color:var(--ice-dim);}
.pill.admin{background:var(--gold-bg);color:var(--gold);border:1px solid var(--gold-d);}
.pill.suspended{background:rgba(231,76,60,.15);color:#ef5350;}
.pill.active{background:rgba(39,174,96,.15);color:#66bb6a;}

/* ── i18n language selector ────────────────────────────────────────────── */
.i18n-selector-slot{display:flex;justify-content:stretch;}
.i18n-selector{width:100%;background:var(--navy);border:1px solid var(--navy-light);color:var(--ice-dim);border-radius:var(--radius);padding:6px 8px;font-family:'DM Sans',sans-serif;font-size:11px;cursor:pointer;transition:var(--transition);}
.i18n-selector:hover{border-color:var(--gold-d);color:var(--ice);}
.i18n-selector:focus{outline:none;border-color:var(--gold);}
.i18n-selector option{background:var(--navy-mid);color:var(--ice);}
/* RTL — the sidebar + main layout is a plain flex row, so `direction: rtl`
   on <html> flips the visual order automatically. Swap the sidebar border
   so the divider ends up on the correct side. */
html[dir="rtl"] body{direction:rtl;text-align:right;}
html[dir="rtl"] #sidebar{border-right:none;border-left:1px solid var(--navy-light);}

/* ── Workspace (per-task draft + AI coach) ──────────────────────────── */
.workspace-section{margin-top:20px;}
.workspace-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;}
.workspace-title{font-family:'Playfair Display',serif;font-size:17px;font-weight:700;color:var(--ice);}
.workspace-subtitle{font-family:'IBM Plex Mono',monospace;font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--ice-muted);margin-top:2px;}

.workspace-task{background:var(--navy-card);border:1px solid var(--navy-light);border-radius:var(--radius-lg);margin-bottom:14px;overflow:hidden;transition:border-color .2s ease;}
.workspace-task.has-submission{border-color:rgba(102,187,106,.4);}
.workspace-task-head{padding:14px 18px;display:flex;align-items:flex-start;gap:12px;cursor:pointer;border-bottom:1px solid var(--navy-light);}
.workspace-task-head:hover{background:rgba(255,255,255,.02);}
.workspace-task-num{font-family:'IBM Plex Mono',monospace;font-size:10px;color:var(--gold);letter-spacing:.1em;flex-shrink:0;padding-top:1px;}
.workspace-task-body-head{flex:1;min-width:0;}
.workspace-task-name{font-family:'DM Sans',sans-serif;font-size:13.5px;font-weight:600;color:var(--ice);line-height:1.3;}
.workspace-task-desc{font-size:11.5px;color:var(--ice-dim);line-height:1.6;margin-top:4px;}
.workspace-task-tag{font-family:'IBM Plex Mono',monospace;font-size:9px;padding:2px 7px;border-radius:10px;background:rgba(201,168,76,.1);color:var(--gold-l);border:1px solid rgba(201,168,76,.3);flex-shrink:0;}
.workspace-task-tag.submitted{background:rgba(102,187,106,.15);color:#8ed69c;border-color:rgba(102,187,106,.4);}
.workspace-task-tag.no-ai{background:rgba(201,168,76,.12);color:var(--gold);border-color:rgba(201,168,76,.35);}
.workspace-chev{color:var(--ice-muted);transition:transform .2s ease;flex-shrink:0;margin-top:2px;}
.workspace-task.open .workspace-chev{transform:rotate(180deg);}
.workspace-task-body{display:none;padding:16px 18px 18px;}
.workspace-task.open .workspace-task-body{display:block;}

.workspace-cols{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.workspace-task.no-ai-task .workspace-cols{grid-template-columns:1fr;}
@media (max-width: 980px){ .workspace-cols{grid-template-columns:1fr;} }

.workspace-col-label{font-family:'IBM Plex Mono',monospace;font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--ice-muted);margin-bottom:6px;}
.workspace-draft{width:100%;min-height:180px;background:var(--navy);border:1px solid var(--navy-light);color:var(--ice);padding:10px 12px;border-radius:var(--radius);font-size:13px;line-height:1.6;font-family:'DM Sans',sans-serif;resize:vertical;transition:.2s;}
.workspace-draft:focus{outline:none;border-color:var(--gold-d);background:var(--navy-mid);}
.workspace-draft-status{font-family:'IBM Plex Mono',monospace;font-size:9px;color:var(--ice-muted);margin-top:4px;min-height:12px;letter-spacing:.05em;}
.workspace-draft-status.saving{color:var(--gold);}
.workspace-draft-status.saved{color:#66bb6a;}
.workspace-draft-status.error{color:#ef5350;}

.workspace-chat-col{display:flex;flex-direction:column;min-height:180px;}
.workspace-chat-messages{flex:1;background:var(--navy);border:1px solid var(--navy-light);border-radius:var(--radius);padding:12px;overflow-y:auto;max-height:320px;display:flex;flex-direction:column;gap:8px;margin-bottom:8px;}
.workspace-chat-empty{font-size:12px;color:var(--ice-muted);font-style:italic;text-align:center;padding:20px 10px;line-height:1.55;}
.workspace-msg{padding:9px 12px;border-radius:10px;font-size:12.5px;line-height:1.6;white-space:pre-wrap;word-wrap:break-word;max-width:92%;}
.workspace-msg.user{background:rgba(201,168,76,.1);border:1px solid rgba(201,168,76,.22);color:var(--ice);align-self:flex-end;border-bottom-right-radius:2px;}
.workspace-msg.bot{background:var(--navy-mid);border:1px solid var(--navy-light);color:var(--ice-dim);align-self:flex-start;border-bottom-left-radius:2px;}
.workspace-msg.bot.loading{color:var(--ice-muted);font-style:italic;}
.workspace-msg.bot.error{border-color:rgba(239,83,80,.4);color:#ef8b88;}
.workspace-msg-label{font-family:'IBM Plex Mono',monospace;font-size:8px;letter-spacing:.1em;text-transform:uppercase;color:var(--ice-muted);display:block;margin-bottom:3px;}
.workspace-chat-input-row{display:flex;gap:6px;}
.workspace-chat-input{flex:1;background:var(--navy);border:1px solid var(--navy-light);color:var(--ice);padding:9px 11px;border-radius:var(--radius);font-size:12.5px;font-family:'DM Sans',sans-serif;transition:.2s;}
.workspace-chat-input:focus{outline:none;border-color:var(--gold-d);background:var(--navy-mid);}
.workspace-chat-send{background:var(--gold);color:var(--navy);border:none;padding:0 14px;border-radius:var(--radius);font-family:'DM Sans',sans-serif;font-size:11.5px;font-weight:600;cursor:pointer;transition:.2s;}
.workspace-chat-send:hover{background:var(--gold-l);}
.workspace-chat-send:disabled{background:var(--navy-light);color:var(--ice-muted);cursor:not-allowed;}

.workspace-quality{margin-top:10px;padding:10px 12px;background:rgba(255,255,255,.02);border:1px solid var(--navy-light);border-radius:var(--radius);font-size:11.5px;color:var(--ice-dim);line-height:1.55;}
.workspace-quality.hidden{display:none;}
.workspace-quality-head{display:flex;align-items:center;gap:8px;margin-bottom:4px;font-family:'IBM Plex Mono',monospace;font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);}
.workspace-quality-pill{padding:1px 6px;border-radius:8px;font-size:9px;letter-spacing:.05em;background:var(--navy-light);color:var(--ice-dim);text-transform:uppercase;}
.workspace-quality-pill.strong{background:rgba(102,187,106,.15);color:#66bb6a;}
.workspace-quality-pill.partial{background:rgba(201,168,76,.12);color:var(--gold-l);}
.workspace-quality-pill.missing{background:rgba(239,83,80,.12);color:#ef8b88;}

.workspace-no-ai-note{padding:14px 16px;background:rgba(201,168,76,.06);border-left:3px solid var(--gold-d);border-radius:var(--radius);font-size:12px;color:var(--ice-dim);line-height:1.65;margin-top:4px;}

.workspace-footer{margin-top:12px;padding-top:12px;border-top:1px dashed rgba(255,255,255,.06);display:flex;gap:10px;justify-content:flex-end;align-items:center;}
.workspace-submit{background:var(--gold);color:var(--navy);border:none;padding:9px 18px;border-radius:var(--radius);font-family:'DM Sans',sans-serif;font-size:12px;font-weight:600;cursor:pointer;transition:.2s;}
.workspace-submit:hover{background:var(--gold-l);}
.workspace-submit:disabled{background:var(--navy-light);color:var(--ice-muted);cursor:not-allowed;}
.workspace-reset{background:transparent;color:var(--ice-muted);border:1px solid var(--navy-light);padding:8px 14px;border-radius:var(--radius);font-family:'DM Sans',sans-serif;font-size:11px;cursor:pointer;transition:.2s;}
.workspace-reset:hover{color:#ef8b88;border-color:rgba(239,83,80,.4);}
.workspace-submitted-badge{font-family:'IBM Plex Mono',monospace;font-size:9px;color:#66bb6a;letter-spacing:.08em;text-transform:uppercase;margin-right:auto;}

html[dir="rtl"] .workspace-msg.user{align-self:flex-start;border-bottom-right-radius:10px;border-bottom-left-radius:2px;}
html[dir="rtl"] .workspace-msg.bot{align-self:flex-end;border-bottom-left-radius:10px;border-bottom-right-radius:2px;}

/* ── Workspace editor mode (No-AI-coaching tasks) ──────────────────── */
.workspace-editor-col{display:flex;flex-direction:column;min-height:180px;}
.workspace-editor-panel{flex:1;background:var(--navy);border:1px solid var(--navy-light);border-radius:var(--radius);padding:10px 12px;overflow-y:auto;max-height:420px;font-size:12px;color:var(--ice-dim);}
.workspace-edit-thin{padding:14px 8px;color:var(--ice-muted);font-size:12px;line-height:1.6;text-align:center;}
.workspace-edit-feedback{display:flex;flex-direction:column;gap:12px;}
.edit-feedback-overall{padding:8px 10px;background:rgba(201,168,76,.06);border-left:2px solid var(--gold-d);border-radius:4px;font-size:12px;line-height:1.6;color:var(--ice);}
.edit-feedback-category{display:flex;flex-direction:column;gap:6px;}
.edit-feedback-category-head{font-family:'IBM Plex Mono',monospace;font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--ice);padding:4px 0 4px 8px;border-left:3px solid var(--navy-light);display:flex;align-items:center;gap:8px;}
.edit-feedback-card{background:var(--navy-card);border:1px solid var(--navy-light);border-radius:var(--radius);padding:8px 10px;font-size:11.5px;line-height:1.55;}
.edit-feedback-excerpt{font-style:italic;color:var(--ice-muted);border-left:2px solid rgba(255,255,255,.08);padding-left:8px;margin-bottom:5px;white-space:pre-wrap;word-wrap:break-word;}
.edit-feedback-suggestion{color:var(--ice);margin-bottom:3px;}
.edit-feedback-why{color:var(--ice-muted);font-size:10.5px;font-style:italic;}
.edit-feedback-revision{background:var(--navy-mid);border:1px solid rgba(201,168,76,.3);border-radius:var(--radius);padding:10px 12px;}
.edit-feedback-revision summary{cursor:pointer;font-family:'IBM Plex Mono',monospace;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-l);list-style:none;}
.edit-feedback-revision summary::-webkit-details-marker{display:none;}
.edit-feedback-revision summary::before{content:'+ ';color:var(--gold);}
.edit-feedback-revision[open] summary::before{content:'− ';}
.edit-feedback-revision-body{margin-top:10px;}
.edit-feedback-revision-text{background:var(--navy);border:1px solid var(--navy-light);border-radius:var(--radius);padding:10px 12px;font-size:12px;line-height:1.6;color:var(--ice);white-space:pre-wrap;word-wrap:break-word;max-height:320px;overflow-y:auto;}

/* ── Load example button + modal ──────────────────────────────────── */
.workspace-col-label-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px;gap:8px;}
.workspace-example-btn{background:transparent;border:1px solid var(--navy-light);color:var(--gold-l);padding:4px 10px;border-radius:var(--radius);font-family:'DM Sans',sans-serif;font-size:10px;cursor:pointer;transition:.2s;display:flex;align-items:center;gap:6px;}
.workspace-example-btn:hover{background:var(--gold-bg);border-color:var(--gold-d);color:var(--gold);}

/* Example modal uses the chat-modal shell + adds a few example-specific
   styles for the variant label and scrollable content area. */
.example-modal-overlay{position:fixed;inset:0;background:rgba(5,12,22,.72);backdrop-filter:blur(4px);display:none;align-items:center;justify-content:center;padding:24px;z-index:1000;opacity:0;transition:opacity .18s ease;}
.example-modal-overlay.open{display:flex;opacity:1;}
.example-modal-overlay .chat-modal{background:var(--navy-mid);border:1px solid rgba(201,168,76,.35);border-radius:var(--radius-lg);box-shadow:0 24px 60px rgba(0,0,0,.6);width:100%;max-width:720px;max-height:calc(100vh - 48px);display:flex;flex-direction:column;overflow:hidden;transform:translateY(6px);transition:transform .18s ease;}
.example-modal-overlay.open .chat-modal{transform:translateY(0);}
.example-modal-overlay .chat-modal-header{display:flex;align-items:flex-start;gap:14px;padding:20px 22px 14px;border-bottom:1px solid var(--navy-light);}
.example-modal-overlay .chat-modal-header-text{flex:1;min-width:0;}
.example-modal-overlay .chat-modal-kicker{font-family:'IBM Plex Mono',monospace;font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-bottom:4px;}
.example-modal-overlay .chat-modal-topic{font-family:'Playfair Display',serif;font-size:16px;font-weight:700;color:var(--ice);line-height:1.4;}
.example-modal-overlay .chat-modal-close{background:transparent;border:none;color:var(--ice-muted);font-size:24px;line-height:1;cursor:pointer;padding:4px 8px;transition:color .15s ease;flex-shrink:0;}
.example-modal-overlay .chat-modal-close:hover{color:var(--gold-l);}
.example-modal-overlay .chat-modal-body{flex:1;overflow-y:auto;padding:16px 22px;}
.example-modal-overlay .chat-modal-footer{border-top:1px solid var(--navy-light);padding:14px 22px 18px;background:var(--navy-card);}

.example-variant-label{font-family:'IBM Plex Mono',monospace;font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--ice-muted);margin-bottom:8px;}
.example-content{background:var(--navy);border:1px solid var(--navy-light);border-radius:var(--radius);padding:14px 16px;}
.example-content-text{font-size:13px;line-height:1.75;color:var(--ice);white-space:pre-wrap;word-wrap:break-word;}

.example-modal-actions{display:flex;gap:10px;justify-content:space-between;align-items:center;margin-bottom:8px;}
.example-modal-overlay .faq-chat-hint{text-align:center;}

@media (max-width: 640px) {
  .example-modal-overlay{padding:0;}
  .example-modal-overlay .chat-modal{max-width:100%;max-height:100vh;border-radius:0;border-left:none;border-right:none;}
  .example-modal-actions{flex-direction:column-reverse;}
  .example-modal-actions button{width:100%;}
}
