/* ── RESET ─────────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
:root {
  --navy:#1B3A6B; --navy-dk:#0F2347; --navy-mid:#2A4E8A;
  --orange:#E87722; --orange-lt:#F5A04A;
  --cream:#F7F5F2; --white:#FFFFFF;
  --dgray:#1E2530; --mgray:#5A6474; --lgray:#E2E5EA; --border:#D4D8DF;
  --ins-red:#C0392B; --ins-grn:#2E7D32; --ins-yel:#D4860A; --ins-blu:#1565C0;
  --radius:12px; --radius-sm:8px;
  --shadow-sm:0 1px 4px rgba(0,0,0,.07);
  --shadow:0 3px 16px rgba(0,0,0,.09);
  --shadow-lg:0 8px 32px rgba(0,0,0,.14);
}
body { font-family:'Segoe UI',system-ui,-apple-system,sans-serif; font-size:15px; color:var(--dgray); background:var(--cream); line-height:1.6; -webkit-font-smoothing:antialiased; }
a { color:var(--navy); text-decoration:none; }
a:hover { text-decoration:underline; }

/* ── LOGO ──────────────────────────────────────────────────────────── */
.excellence-logo    { height:36px; width:auto; display:block; object-fit:contain; }
.excellence-logo-sm { height:26px; width:auto; display:block; object-fit:contain; }

/* ── BUTTONS ───────────────────────────────────────────────────────── */
.btn { display:inline-flex; align-items:center; justify-content:center; gap:6px; padding:10px 22px; border-radius:var(--radius-sm); font-size:14px; font-weight:600; cursor:pointer; border:1.5px solid transparent; transition:all .15s ease; font-family:inherit; white-space:nowrap; line-height:1; }
.btn:hover { opacity:.88; transform:translateY(-1px); }
.btn:active { transform:scale(.98) translateY(0); }
.btn-primary { background:var(--navy); color:var(--white); border-color:var(--navy); box-shadow:0 2px 8px rgba(27,58,107,.3); }
.btn-orange  { background:var(--orange); color:var(--white); border-color:var(--orange); box-shadow:0 2px 8px rgba(232,119,34,.3); }
.btn-outline { background:transparent; color:var(--navy); border-color:var(--navy); }
.btn-ghost   { background:transparent; color:var(--mgray); border-color:var(--lgray); }
.btn-full    { display:flex; width:100%; }
.btn-large   { padding:14px 28px; font-size:16px; }
.btn-sm      { padding:7px 14px; font-size:13px; }
.btn-logout  { font-size:13px; color:rgba(255,255,255,.65); background:none; border:1px solid rgba(255,255,255,.2); border-radius:6px; padding:5px 12px; cursor:pointer; font-family:inherit; transition:all .15s; }
.btn-logout:hover { border-color:rgba(255,255,255,.5); color:white; }
.btn-copy    { font-size:12px; padding:5px 12px; border-radius:6px; background:var(--lgray); border:1px solid var(--border); cursor:pointer; font-weight:500; }

/* ── CENTER PAGE ───────────────────────────────────────────────────── */
.center-page { min-height:100vh; display:flex; align-items:center; justify-content:center; padding:24px 20px; background:linear-gradient(145deg,#0F2347 0%,#1B3A6B 55%,#1E4580 100%); }

/* ── AUTH CARD ─────────────────────────────────────────────────────── */
.auth-card { background:var(--white); border-radius:16px; padding:44px 40px 40px; max-width:460px; width:100%; box-shadow:var(--shadow-lg); }
.auth-card.wide { max-width:680px; }
.auth-logo-wrap { margin-bottom:28px; padding-bottom:22px; border-bottom:1px solid var(--lgray); }
.auth-logo-wrap img { height:36px; width:auto; }
.auth-tag { display:inline-block; background:#EEF2FB; color:var(--navy); font-size:11px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; padding:4px 12px; border-radius:20px; margin-bottom:12px; }
.auth-title { font-size:24px; font-weight:700; color:var(--navy); margin-bottom:6px; line-height:1.25; }
.auth-sub   { font-size:14px; color:var(--mgray); margin-bottom:28px; line-height:1.55; }
.auth-form  { display:flex; flex-direction:column; gap:14px; }
.auth-form label { font-size:13px; font-weight:600; color:var(--navy); display:block; margin-bottom:5px; }
.auth-form input { padding:12px 14px; border:1.5px solid var(--border); border-radius:var(--radius-sm); font-size:16px; font-family:inherit; width:100%; transition:border-color .15s; color:var(--dgray); letter-spacing:.06em; }
.auth-form input:focus { outline:none; border-color:var(--navy); box-shadow:0 0 0 3px rgba(27,58,107,.08); }
.auth-divider { text-align:center; font-size:13px; color:var(--mgray); margin:18px 0 12px; position:relative; }
.auth-divider::before,.auth-divider::after { content:''; position:absolute; top:50%; width:38%; height:1px; background:var(--lgray); }
.auth-divider::before { left:0; } .auth-divider::after { right:0; }
.alert { padding:11px 14px; border-radius:var(--radius-sm); font-size:14px; margin-bottom:16px; border:1px solid; }
.alert-error { background:#FEF0F0; border-color:#F5BCBC; color:var(--ins-red); }

/* ── SETUP FORM ────────────────────────────────────────────────────── */
.setup-form { display:flex; flex-direction:column; gap:28px; }
.form-section { display:flex; flex-direction:column; gap:16px; }
.section-label { font-size:13px; font-weight:700; color:var(--navy); text-transform:uppercase; letter-spacing:.07em; padding-bottom:10px; border-bottom:2px solid var(--orange); display:flex; align-items:center; gap:8px; }
.section-num { width:22px; height:22px; background:var(--navy); color:white; border-radius:50%; font-size:11px; font-weight:700; display:inline-flex; align-items:center; justify-content:center; flex-shrink:0; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.form-group { display:flex; flex-direction:column; gap:5px; }
.form-group label { font-size:13px; font-weight:600; color:var(--mgray); }
.form-group input,.form-group textarea,.form-group select { padding:11px 13px; border:1.5px solid var(--border); border-radius:var(--radius-sm); font-size:14px; font-family:inherit; width:100%; color:var(--dgray); transition:border-color .15s; }
.form-group input:focus,.form-group textarea:focus { outline:none; border-color:var(--navy); box-shadow:0 0 0 3px rgba(27,58,107,.07); }
.form-group textarea { resize:vertical; min-height:70px; }
.form-group small { font-size:12px; color:var(--mgray); line-height:1.4; }
.req { color:var(--orange); }
.colour-grid { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.colour-option input[type="radio"] { display:none; }
.colour-card { border:2px solid var(--border); border-radius:var(--radius-sm); padding:14px 12px; display:flex; flex-direction:column; gap:4px; cursor:pointer; transition:all .15s; background:var(--white); }
.colour-card:hover { border-color:var(--navy); background:#F5F7FF; }
.colour-option input:checked + .colour-card { border-color:var(--navy); background:#EEF2FB; box-shadow:0 0 0 2px rgba(27,58,107,.12); }
.colour-swatch { width:28px; height:28px; border-radius:50%; margin-bottom:4px; border:2px solid rgba(0,0,0,.08); }
.red-swatch { background:var(--ins-red); } .yellow-swatch { background:var(--ins-yel); }
.green-swatch { background:var(--ins-grn); } .blue-swatch { background:var(--ins-blu); }
.colour-card strong { font-size:13.5px; font-weight:700; color:var(--navy); }
.colour-card span   { font-size:12px; color:var(--mgray); }

/* ── CODE REVEAL ───────────────────────────────────────────────────── */
.code-reveal { text-align:center; }
.check-icon { width:56px; height:56px; background:linear-gradient(135deg,#E8F5E9,#C8E6C9); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:24px; margin:0 auto 20px; box-shadow:0 4px 12px rgba(46,125,50,.2); }
.access-code-display { background:linear-gradient(135deg,#EEF2FB,#E4EBF8); border:2px dashed var(--navy); border-radius:var(--radius); padding:24px 20px; margin:24px 0; display:flex; flex-direction:column; gap:10px; align-items:center; }
.code-label { font-size:11px; text-transform:uppercase; letter-spacing:.1em; color:var(--mgray); font-weight:700; }
.code-value { font-size:42px; font-weight:800; font-family:'Courier New',monospace; color:var(--navy); letter-spacing:.18em; }
.code-instructions { background:#FFFBF7; border:1px solid #F5E8D0; border-radius:var(--radius-sm); padding:18px; margin:16px 0 24px; text-align:left; font-size:14px; line-height:1.75; }
.code-instructions ol { padding-left:20px; margin:8px 0; }
.code-tip { font-size:13px; color:var(--mgray); margin-top:10px; }

/* ── APP HEADER ────────────────────────────────────────────────────── */
.app-header { background:linear-gradient(135deg,var(--navy-dk) 0%,var(--navy) 100%); box-shadow:0 2px 12px rgba(0,0,0,.18); position:sticky; top:0; z-index:100; }
.header-inner { max-width:760px; margin:0 auto; padding:14px 24px; display:flex; justify-content:space-between; align-items:center; gap:16px; }
.header-inner.wide { max-width:1140px; }
.header-left { display:flex; align-items:center; gap:16px; }
.header-divider { width:1px; height:28px; background:rgba(255,255,255,.2); }
.header-program { display:flex; flex-direction:column; }
.header-program-name { font-size:13px; font-weight:700; color:rgba(255,255,255,.95); line-height:1.2; }
.header-program-sub  { font-size:11px; color:rgba(255,255,255,.5); letter-spacing:.04em; }
.header-right { display:flex; align-items:center; gap:10px; flex-shrink:0; }

/* Badges */
.phase-badge { display:inline-block; background:rgba(232,119,34,.22); color:#FFCC88; font-size:11px; font-weight:700; letter-spacing:.05em; padding:4px 11px; border-radius:20px; border:1px solid rgba(232,119,34,.3); }
.phase-badge.sm { background:#EEF2FB; color:var(--navy); border:1px solid #C8D5F0; font-size:11px; }
.day-badge { display:inline-block; background:rgba(255,255,255,.1); color:rgba(255,255,255,.7); font-size:11px; padding:4px 10px; border-radius:20px; border:1px solid rgba(255,255,255,.12); }

/* ── JOURNAL PAGE ──────────────────────────────────────────────────── */
.journal-page { min-height:100vh; background:var(--cream); }
.journal-main { max-width:760px; margin:0 auto; padding:28px 24px 80px; display:flex; flex-direction:column; gap:18px; }
.card { background:var(--white); border-radius:var(--radius); box-shadow:var(--shadow-sm); border:1px solid var(--lgray); }

.focus-card { background:linear-gradient(135deg,var(--navy) 0%,var(--navy-mid) 100%); border-radius:var(--radius); padding:22px 26px; border:none; box-shadow:0 4px 18px rgba(27,58,107,.22); }
.focus-label { font-size:10px; text-transform:uppercase; letter-spacing:.12em; color:rgba(255,255,255,.55); font-weight:700; margin-bottom:8px; }
.focus-text  { font-size:16px; color:var(--white); font-style:italic; line-height:1.65; }

.stats-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.stat-card { padding:18px 20px; }
.stat-label { font-size:11px; text-transform:uppercase; letter-spacing:.08em; color:var(--mgray); font-weight:600; margin-bottom:8px; }
.stat-value { font-size:18px; font-weight:700; color:var(--navy); }
.stat-value.large { font-size:36px; line-height:1; }
.stat-sub   { font-size:12px; color:var(--mgray); margin-top:4px; }

.colour-tag { display:inline-flex; align-items:center; gap:5px; padding:4px 11px; border-radius:20px; font-size:13px; font-weight:600; }
.colour-tag::before { content:''; width:8px; height:8px; border-radius:50%; display:inline-block; }
.colour-tag.fiery-red { background:#FEE8E6; color:var(--ins-red); border:1px solid #F5BCBC; } .colour-tag.fiery-red::before { background:var(--ins-red); }
.colour-tag.sunshine-yellow { background:#FFF8E1; color:var(--ins-yel); border:1px solid #FACF7A; } .colour-tag.sunshine-yellow::before { background:var(--ins-yel); }
.colour-tag.earth-green { background:#E8F5E9; color:var(--ins-grn); border:1px solid #A5D6A7; } .colour-tag.earth-green::before { background:var(--ins-grn); }
.colour-tag.cool-blue { background:#E3F2FD; color:var(--ins-blu); border:1px solid #90CAF9; } .colour-tag.cool-blue::before { background:var(--ins-blu); }
.colour-tag.sm { font-size:12px; padding:3px 9px; } .colour-tag.sm::before { width:6px; height:6px; }

.goals-card { padding:20px 22px; }
.goals-label { font-size:11px; text-transform:uppercase; letter-spacing:.08em; color:var(--mgray); font-weight:700; margin-bottom:14px; }
.goal-row { display:flex; gap:12px; align-items:flex-start; margin-bottom:12px; }
.goal-row:last-child { margin-bottom:0; }
.goal-level { font-size:10px; font-weight:800; color:var(--white); background:var(--navy); border-radius:4px; padding:3px 7px; flex-shrink:0; margin-top:1px; letter-spacing:.04em; }
.goal-row p { font-size:14px; color:var(--dgray); line-height:1.55; }

.last-session-card { padding:20px 22px; border-left:3px solid var(--orange); }
.last-label   { font-size:11px; text-transform:uppercase; letter-spacing:.08em; color:var(--orange); font-weight:700; margin-bottom:8px; }
.last-summary { font-size:14px; color:var(--dgray); line-height:1.65; }

.action-row { margin-top:4px; }
.action-row-secondary { display:flex; gap:10px; flex-wrap:wrap; }

.past-sessions { margin-top:4px; }
.past-title { font-size:14px; font-weight:700; color:var(--navy); margin-bottom:12px; text-transform:uppercase; letter-spacing:.07em; }
.session-accordion { background:var(--white); border-radius:var(--radius-sm); margin-bottom:8px; box-shadow:var(--shadow-sm); border:1px solid var(--lgray); overflow:hidden; transition:box-shadow .15s; }
.session-accordion[open] { box-shadow:var(--shadow); }
.session-summary-row { display:flex; align-items:center; gap:12px; padding:15px 18px; cursor:pointer; list-style:none; user-select:none; }
.session-summary-row::-webkit-details-marker { display:none; }
.session-summary-row:hover { background:#FAFBFF; }
.session-date  { font-size:14px; font-weight:600; color:var(--navy); }
.session-phase { font-size:12px; color:var(--mgray); flex:1; }
.accordion-arrow { font-size:11px; color:var(--mgray); transition:transform .2s; }
details[open] .accordion-arrow { transform:rotate(180deg); }
.session-content { padding:4px 18px 16px; border-top:1px solid var(--lgray); }
.session-summary-box { background:linear-gradient(135deg,#EEF2FB,#F0F4FF); border-radius:var(--radius-sm); padding:12px 14px; margin:12px 0; border-left:3px solid var(--navy); }
.summary-label { font-size:10px; text-transform:uppercase; letter-spacing:.1em; color:var(--navy); font-weight:700; margin-bottom:6px; }
.message-excerpt { padding:8px 0; border-top:1px solid var(--lgray); font-size:13px; color:var(--mgray); line-height:1.6; }

/* ── SESSION PAGE ──────────────────────────────────────────────────── */
.session-page { min-height:100vh; display:flex; flex-direction:column; background:var(--cream); }
.session-header { background:var(--white); border-bottom:1px solid var(--lgray); padding:12px 20px; display:flex; align-items:center; gap:14px; position:sticky; top:0; z-index:10; flex-shrink:0; box-shadow:var(--shadow-sm); }
.session-header-info { flex:1; }
.session-name  { font-size:14px; font-weight:700; color:var(--navy); }
.session-phase { font-size:12px; color:var(--mgray); }
.chat-container { flex:1; overflow-y:auto; padding:24px 20px; }
.chat-inner { max-width:700px; margin:0 auto; display:flex; flex-direction:column; gap:18px; min-height:100%; }
.chat-message { display:flex; flex-direction:column; }
.chat-message.user { align-items:flex-end; }
.chat-message.assistant { align-items:flex-start; }
.msg-label { font-size:10px; text-transform:uppercase; letter-spacing:.1em; color:var(--mgray); font-weight:700; margin-bottom:5px; }
.msg-bubble { max-width:80%; padding:14px 18px; font-size:15px; line-height:1.7; white-space:pre-wrap; border-radius:16px; }
.user .msg-bubble { background:linear-gradient(135deg,var(--navy) 0%,var(--navy-mid) 100%); color:var(--white); border-radius:16px 16px 4px 16px; box-shadow:0 3px 12px rgba(27,58,107,.22); }
.assistant .msg-bubble { background:var(--white); color:var(--dgray); border:1px solid var(--lgray); border-radius:16px 16px 16px 4px; box-shadow:var(--shadow-sm); }
.loading-dots { display:flex; gap:5px; padding:10px 0; }
.loading-dots span { width:8px; height:8px; border-radius:50%; background:var(--mgray); animation:blink 1.2s ease-in-out infinite; }
.loading-dots span:nth-child(2) { animation-delay:.2s; }
.loading-dots span:nth-child(3) { animation-delay:.4s; }
@keyframes blink { 0%,80%,100%{opacity:.2;transform:scale(.8)} 40%{opacity:1;transform:scale(1)} }
.chat-input-area { background:var(--white); border-top:1px solid var(--lgray); padding:14px 20px; display:flex; gap:10px; align-items:flex-end; position:sticky; bottom:0; flex-shrink:0; box-shadow:0 -2px 12px rgba(0,0,0,.06); }
.chat-input-area textarea { flex:1; padding:11px 15px; border:1.5px solid var(--border); border-radius:var(--radius-sm); font-size:15px; font-family:inherit; resize:none; max-height:120px; line-height:1.55; transition:border-color .15s; color:var(--dgray); }
.chat-input-area textarea:focus { outline:none; border-color:var(--navy); box-shadow:0 0 0 3px rgba(27,58,107,.07); }
.session-ended-bar { background:#E8F5E9; border-top:2px solid var(--ins-grn); padding:16px 24px; text-align:center; font-size:15px; font-weight:500; color:var(--ins-grn); }

/* ── FACILITATOR ───────────────────────────────────────────────────── */
.facilitator-page { min-height:100vh; background:#F0F2F7; }
.facilitator-main { max-width:1140px; margin:0 auto; padding:30px 24px 80px; }
.participants-table-wrap { background:var(--white); border-radius:var(--radius); box-shadow:var(--shadow); border:1px solid var(--lgray); overflow:hidden; overflow-x:auto; }
.participants-table { width:100%; border-collapse:collapse; }
.participants-table th { background:var(--navy); color:var(--white); padding:13px 18px; text-align:left; font-size:12px; font-weight:700; letter-spacing:.06em; text-transform:uppercase; }
.participants-table td { padding:13px 18px; border-bottom:1px solid var(--lgray); font-size:14px; vertical-align:middle; }
.participants-table tr:last-child td { border-bottom:none; }
.participants-table tr:hover td { background:#F8F9FF; }
.row-inactive td { opacity:.6; }
.td-name small { font-size:12px; color:var(--mgray); }
.td-summary { max-width:300px; font-size:13px; color:var(--mgray); line-height:1.5; }
.td-center { text-align:center; }
.td-actions { display:flex; gap:6px; }
.badge { display:inline-flex; align-items:center; padding:4px 11px; border-radius:20px; font-size:12px; font-weight:700; }
.badge-ok   { background:#E8F5E9; color:var(--ins-grn); border:1px solid #A5D6A7; }
.badge-warn { background:#FFF8E1; color:var(--ins-yel); border:1px solid #FACF7A; }
.section-title { font-size:17px; font-weight:700; color:var(--navy); margin-bottom:18px; margin-top:8px; }
.session-block { background:var(--white); border-radius:var(--radius); padding:22px 26px; margin-bottom:18px; box-shadow:var(--shadow-sm); border:1px solid var(--lgray); }
.session-block-header { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:16px; padding-bottom:14px; border-bottom:1px solid var(--lgray); }
.session-block-header strong { font-size:16px; color:var(--navy); font-weight:700; }
.session-date { font-size:13px; color:var(--mgray); margin-left:10px; }
.transcript { display:flex; flex-direction:column; gap:12px; margin-top:14px; }
.transcript-row { display:flex; gap:14px; align-items:flex-start; }
.transcript-label { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.07em; color:var(--mgray); min-width:100px; flex-shrink:0; padding-top:2px; }
.transcript-content { font-size:14px; line-height:1.65; color:var(--dgray); }
.transcript-row.user .transcript-label { color:var(--navy); }
.transcript-row.assistant .transcript-label { color:var(--orange); }
.empty-state { background:var(--white); border-radius:var(--radius); padding:48px; text-align:center; color:var(--mgray); font-size:15px; box-shadow:var(--shadow-sm); }
.muted { color:var(--mgray); font-size:13px; }
.participant-count { font-size:12px; color:rgba(255,255,255,.55); background:rgba(255,255,255,.1); padding:4px 12px; border-radius:20px; }
.back-link { font-size:13px; color:rgba(255,255,255,.7); font-weight:500; transition:color .15s; }
.back-link:hover { color:var(--white); text-decoration:none; }
.back-link-dark { font-size:13px; color:var(--navy); font-weight:500; display:inline-flex; align-items:center; gap:4px; }

/* ── FOOTER ────────────────────────────────────────────────────────── */
.app-footer { border-top:1px solid var(--lgray); padding:22px 24px; text-align:center; display:flex; flex-direction:column; align-items:center; gap:10px; background:var(--white); margin-top:auto; }
.footer-logo { height:22px; width:auto; opacity:.5; }
.footer-text { font-size:12px; color:var(--mgray); }

/* ── RESPONSIVE ────────────────────────────────────────────────────── */
@media (max-width:600px) {
  .auth-card { padding:28px 22px; }
  .form-row  { grid-template-columns:1fr; }
  .stats-row { grid-template-columns:1fr 1fr; }
  .msg-bubble { max-width:92%; font-size:14px; }
  .header-inner { padding:12px 16px; }
  .journal-main { padding:20px 16px 60px; }
  .excellence-logo { height:28px; }
}
