/* KPSC Meeting Portal — Navy & Gold theme */
:root {
  --navy:      #1e3a5f;
  --navy-dark: #13284a;
  --navy-mid:  #2c5282;
  --navy-light:#e8eef7;
  --gold:      #b8860b;
  --gold-light:#fdf6e3;
  --green:     #1a7a5e;
  --amber:     #b45309;
  --red:       #c0392b;
  --text:      #1a1a1a;
  --text2:     #4a4a4a;
  --text3:     #7a7a7a;
  --border:    rgba(0,0,0,0.08);
  --white:     #ffffff;
  --bg:        #f4f6fa;
}

*{box-sizing:border-box;margin:0;padding:0;}
body{font-family:'DM Sans',system-ui,sans-serif;background:var(--bg);color:var(--text);line-height:1.65;min-height:100vh;}

/* ── LOGIN ─────────────────────────────────────────────────────── */
.kl-hero{background:var(--navy-dark);background-image:
  radial-gradient(ellipse at 20% 50%,rgba(44,82,130,.35) 0%,transparent 60%),
  radial-gradient(ellipse at 80% 20%,rgba(184,134,11,.15) 0%,transparent 50%);
  padding:56px 24px 76px;text-align:center;position:relative;overflow:hidden;}
.kl-hero::before{content:'';position:absolute;inset:0;
  background-image:repeating-linear-gradient(90deg,rgba(255,255,255,.015) 0,rgba(255,255,255,.015) 1px,transparent 1px,transparent 48px);}
.kl-cross{display:inline-flex;align-items:center;justify-content:center;width:50px;height:50px;
  border:2px solid rgba(255,255,255,.25);border-radius:50%;margin-bottom:18px;font-size:20px;position:relative;z-index:1;}
.kl-denom{font-size:10px;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:8px;position:relative;z-index:1;}
.kl-name{font-family:'Lora',Georgia,serif;font-size:clamp(24px,5.5vw,36px);font-weight:600;color:#fff;line-height:1.2;margin-bottom:6px;position:relative;z-index:1;}
.kl-portal{font-size:12px;font-weight:500;letter-spacing:2px;text-transform:uppercase;color:var(--gold);margin-bottom:20px;position:relative;z-index:1;}
.kl-divider{width:36px;height:2px;background:var(--gold);margin:0 auto 20px;position:relative;z-index:1;}
.kl-tagline{font-size:clamp(13px,3vw,15px);color:rgba(255,255,255,.7);max-width:540px;margin:0 auto;font-weight:300;line-height:1.75;position:relative;z-index:1;}

.kl-body{max-width:480px;margin:0 auto;padding:0 20px 80px;}
.kl-card-wrap{margin:-40px auto 0;position:relative;z-index:10;}
.kl-card{background:var(--white);border-radius:16px;padding:32px 28px 24px;box-shadow:0 8px 40px rgba(0,0,0,.16),0 2px 8px rgba(0,0,0,.06);}
.kl-card-title{font-family:'Lora',serif;font-size:20px;font-weight:600;color:var(--navy);margin-bottom:22px;}
.kl-label{display:block;font-size:11px;font-weight:600;letter-spacing:.8px;text-transform:uppercase;color:var(--text3);margin-bottom:6px;}
.kl-input{width:100%;padding:11px 14px;border:1.5px solid #e0e0e0;border-radius:10px;font-size:14px;
  font-family:'DM Sans',sans-serif;color:var(--text);background:#fff;outline:none;
  transition:border-color .15s,box-shadow .15s;margin-bottom:16px;}
.kl-input:focus{border-color:var(--navy);box-shadow:0 0 0 3px rgba(30,58,95,.1);}
.kl-submit{width:100%;padding:13px;background:var(--navy);color:white;border:none;border-radius:10px;
  font-size:15px;font-weight:600;font-family:'DM Sans',sans-serif;cursor:pointer;transition:background .15s,transform .1s;margin-top:4px;}
.kl-submit:hover{background:var(--navy-dark);}
.kl-submit:active{transform:scale(.98);}
.kl-submit:disabled{opacity:.7;cursor:not-allowed;}
.kl-error{background:#FCEBEB;color:#A32D2D;font-size:12px;padding:9px 12px;border-radius:8px;margin-bottom:12px;}
.kl-hint{font-size:11px;color:var(--text3);text-align:center;margin-top:14px;line-height:1.6;}

/* ── APP SHELL ─────────────────────────────────────────────────── */
#kpsc-app{display:flex;flex-direction:column;min-height:100vh;}

.ka-header{background:var(--navy);color:#fff;padding:0 16px;height:54px;
  display:flex;align-items:center;gap:10px;position:sticky;top:0;z-index:100;
  box-shadow:0 2px 8px rgba(0,0,0,.2);}
.ka-back{background:none;border:none;color:rgba(255,255,255,.8);font-size:14px;cursor:pointer;
  padding:6px 8px;border-radius:6px;transition:background .15s;white-space:nowrap;}
.ka-back:hover{background:rgba(255,255,255,.1);}
.ka-title{flex:1;font-weight:600;font-size:15px;letter-spacing:.3px;}
.ka-right{display:flex;align-items:center;gap:10px;}
.ka-user{font-size:12px;color:rgba(255,255,255,.7);max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.ka-logout{background:none;border:none;color:rgba(255,255,255,.7);cursor:pointer;padding:4px;
  border-radius:6px;display:flex;align-items:center;transition:color .15s;}
.ka-logout:hover{color:#fff;}

.ka-main{flex:1;overflow-y:auto;padding-bottom:72px;}

.ka-nav{position:fixed;bottom:0;left:0;right:0;background:var(--white);
  border-top:1px solid var(--border);display:flex;z-index:100;
  box-shadow:0 -2px 12px rgba(0,0,0,.08);}
.ka-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;
  padding:8px 4px 10px;background:none;border:none;cursor:pointer;font-size:10px;
  font-family:'DM Sans',sans-serif;color:var(--text3);font-weight:500;transition:color .15s;}
.ka-nav-item svg{transition:color .15s;}
.ka-nav-item.active{color:var(--navy);}
.ka-nav-item.active svg{stroke:var(--navy);}

/* ── PAGES ─────────────────────────────────────────────────────── */
.k-page{max-width:720px;margin:0 auto;padding:20px 16px 32px;}
.k-loading{text-align:center;padding:48px;color:var(--text3);}
.k-empty{text-align:center;padding:40px 20px;color:var(--text3);font-size:14px;}
.k-error-box{background:#FCEBEB;color:#7f1d1d;border-left:4px solid var(--red);border-radius:0 10px 10px 0;padding:16px 18px;font-size:13.5px;line-height:1.65;}
.k-page-hint{font-size:13px;color:var(--text3);margin-bottom:20px;line-height:1.6;}

/* ── STATS ─────────────────────────────────────────────────────── */
.k-dash-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:28px;}
.k-stat{background:var(--white);border-radius:12px;padding:16px 14px;text-align:center;border:1px solid var(--border);}
.k-stat-highlight{border-color:var(--gold);background:var(--gold-light);}
.k-stat-val{font-size:28px;font-weight:700;color:var(--navy);line-height:1.1;margin-bottom:4px;}
.k-stat-highlight .k-stat-val{color:var(--amber);}
.k-stat-lbl{font-size:11px;color:var(--text3);font-weight:500;text-transform:uppercase;letter-spacing:.5px;}

/* ── SECTION HEADER ────────────────────────────────────────────── */
.k-section-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;}
.k-section-hdr h2{font-family:'Lora',serif;font-size:18px;font-weight:600;color:var(--navy);}

/* ── MEETING CARDS ─────────────────────────────────────────────── */
.k-meeting-list{display:flex;flex-direction:column;gap:10px;}
.k-meeting-card{background:var(--white);border:1px solid var(--border);border-radius:12px;padding:16px 18px;
  cursor:pointer;transition:border-color .15s,box-shadow .15s,transform .1s;}
.k-meeting-card:hover{border-color:var(--navy-mid);box-shadow:0 2px 12px rgba(30,58,95,.1);transform:translateY(-1px);}
.k-mc-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:8px;}
.k-mc-title{font-weight:600;font-size:14px;color:var(--text);line-height:1.3;}
.k-mc-badges{display:flex;gap:6px;flex-wrap:wrap;flex-shrink:0;}
.k-mc-meta{display:flex;gap:14px;font-size:12px;color:var(--text3);}

/* ── BADGES ────────────────────────────────────────────────────── */
.kbadge{display:inline-block;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:600;letter-spacing:.3px;}
.badge-gray  {background:#f0f0f0;  color:#666;}
.badge-blue  {background:#dbeafe;  color:#1e40af;}
.badge-amber {background:#fef3c7;  color:#92400e;}
.badge-green {background:#d1fae5;  color:#065f46;}
.badge-type  {background:var(--navy-light);color:var(--navy);}

/* ── BUTTONS ───────────────────────────────────────────────────── */
.kbtn{display:inline-flex;align-items:center;gap:6px;padding:9px 16px;border-radius:8px;
  border:1px solid var(--border);background:var(--white);color:var(--text);font-size:13px;
  font-family:'DM Sans',sans-serif;font-weight:500;cursor:pointer;transition:background .15s,border-color .15s,transform .1s;}
.kbtn:hover{background:#f0f0f0;}
.kbtn:active{transform:scale(.97);}
.kbtn:disabled{opacity:.6;cursor:not-allowed;}
.kbtn-primary{background:var(--navy);color:#fff;border-color:var(--navy);}
.kbtn-primary:hover{background:var(--navy-dark);border-color:var(--navy-dark);}
.kbtn-amber{background:#b45309;color:#fff;border-color:#b45309;}
.kbtn-amber:hover{background:#92400e;}
.kbtn-danger{background:var(--red);color:#fff;border-color:var(--red);}
.kbtn-danger:hover{background:#a93226;}
.kbtn-ghost{background:transparent;color:var(--text3);border-color:transparent;}
.kbtn-ghost:hover{background:#f0f0f0;}
.kbtn-record{background:var(--red);color:#fff;border-color:var(--red);}
.kbtn-record:hover{background:#a93226;}
.kbtn-sm{padding:6px 12px;font-size:12px;}
.kbtn-remove{color:var(--red);border-color:transparent;background:transparent;padding:4px 8px;}
.kbtn-remove:hover{background:#FCEBEB;}
.kbtn-link{background:none;border:none;color:var(--navy);text-decoration:underline;cursor:pointer;font-size:13px;padding:0;}

/* ── STEPPER ───────────────────────────────────────────────────── */
.k-stepper{display:flex;align-items:center;margin-bottom:28px;padding:16px 20px;
  background:var(--white);border-radius:12px;border:1px solid var(--border);}
.k-step{display:flex;flex-direction:column;align-items:center;gap:4px;flex:1;}
.k-step-dot{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:700;background:#e0e0e0;color:#888;transition:all .2s;}
.k-step.active .k-step-dot{background:var(--navy);color:#fff;box-shadow:0 0 0 4px rgba(30,58,95,.15);}
.k-step.done .k-step-dot{background:var(--green);color:#fff;}
.k-step-label{font-size:10px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;color:var(--text3);}
.k-step.active .k-step-label{color:var(--navy);}
.k-step.done .k-step-label{color:var(--green);}
.k-step-line{flex:1;height:2px;background:#e0e0e0;margin:0 4px;align-self:center;margin-top:-18px;}
.k-step-line.done{background:var(--green);}

/* ── FORM FIELDS ───────────────────────────────────────────────── */
.k-section{background:var(--white);border-radius:12px;padding:20px;margin-bottom:16px;border:1px solid var(--border);}
.k-sec-title{font-size:13px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;
  color:var(--navy);margin-bottom:16px;padding-bottom:10px;border-bottom:1px solid var(--border);}
.k-sub-title{font-size:13px;font-weight:600;color:var(--navy);margin:20px 0 10px;}
.k-label{display:block;font-size:11px;font-weight:600;letter-spacing:.8px;text-transform:uppercase;color:var(--text3);margin-bottom:6px;}
.k-input{width:100%;padding:10px 13px;border:1.5px solid #e0e0e0;border-radius:8px;font-size:14px;
  font-family:'DM Sans',sans-serif;color:var(--text);background:#fff;outline:none;
  transition:border-color .15s,box-shadow .15s;}
.k-input:focus{border-color:var(--navy);box-shadow:0 0 0 3px rgba(30,58,95,.1);}
.k-input[readonly],.k-input:disabled{background:#f8f9fa;color:var(--text3);}
.k-input-sm{padding:7px 10px;font-size:13px;}
.k-textarea{min-height:130px;resize:vertical;line-height:1.6;}
.k-field{margin-bottom:14px;}
.k-field-row{display:grid;grid-template-columns:1fr 160px;gap:14px;}
.k-field-sm{}

/* ── ATTENDANCE ────────────────────────────────────────────────── */
.k-att-group{margin-bottom:16px;}
.k-att-group-hdr{font-size:12px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;
  color:var(--navy);margin-bottom:8px;display:flex;align-items:center;gap:8px;}
.k-att-group-count{font-size:11px;color:var(--green);font-weight:600;text-transform:none;letter-spacing:0;}
.k-att-group-members{display:flex;flex-direction:column;gap:6px;}
.k-att-member{display:flex;align-items:center;gap:10px;padding:8px 12px;
  background:var(--bg);border-radius:8px;cursor:pointer;transition:background .15s;}
.k-att-member:hover{background:var(--navy-light);}
.k-att-member input[type=checkbox]{width:16px;height:16px;accent-color:var(--navy);flex-shrink:0;}
.k-att-name{flex:1;font-size:13px;font-weight:500;}
.k-att-pos{font-size:11px;color:var(--text3);background:#e8eef7;padding:2px 7px;border-radius:10px;}
.k-att-no-members{font-size:13px;color:var(--text3);padding:8px 0;}

/* ── RECORDER + LIVE TRANSCRIPT ─────────────────────────────── */
.k-rec-ui{margin-bottom:14px;}
.rec-card{border:1px solid var(--border);background:linear-gradient(135deg,#fff,#f8fafc);border-radius:12px;padding:12px 14px;}
.rec-card-live{border-color:#fecaca;background:linear-gradient(135deg,#fff,#fff7f7);}
.rec-card-paused{border-color:#fde68a;background:linear-gradient(135deg,#fff,#fffbeb);}
.rec-card-stopped{border-color:#d1d5db;background:#f9fafb;}
.rec-main{display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.rec-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:8px;font-size:11.5px;color:var(--text3);}
.rec-hint{font-size:11.5px;color:var(--text3);line-height:1.5;}
.rec-dot{display:inline-block;width:10px;height:10px;border-radius:50%;flex-shrink:0;}
.rec-dot-live{background:var(--red);animation:pulse 1s infinite;box-shadow:0 0 0 4px rgba(176,48,48,.12);}
.rec-dot-paused{background:var(--amber);}
.rec-dot-stopped{background:var(--text3);}
@keyframes pulse{0%,100%{opacity:1;}50%{opacity:.35;}}
.rec-timer{font-variant-numeric:tabular-nums;font-size:15px;font-weight:700;color:var(--navy);min-width:72px;}
.rec-rt{font-weight:700;}
.rec-rt-connected{color:var(--green);}.rec-rt-connecting,.rec-rt-reconnecting{color:var(--amber);}.rec-rt-error{color:var(--red);}
.k-live-transcript{border:1px solid var(--border);border-radius:12px;background:#fff;margin:12px 0 14px;overflow:hidden;}
.lt-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;padding:12px 14px;background:var(--navy-light);border-bottom:1px solid var(--border);}
.lt-title{font-size:13px;font-weight:800;color:var(--navy);letter-spacing:.2px;}
.lt-sub{font-size:11.5px;color:var(--text3);line-height:1.45;margin-top:2px;}
.lt-pill{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.6px;color:var(--navy);background:#fff;border:1px solid #cbd5e1;border-radius:999px;padding:4px 7px;}
.lt-list{height:210px;overflow-y:auto;padding:12px 14px;scroll-behavior:smooth;}
.lt-empty{height:100%;display:flex;align-items:center;justify-content:center;text-align:center;color:var(--text3);font-size:13px;}
.lt-entry{display:grid;grid-template-columns:54px 1fr;gap:9px;align-items:start;padding:8px 0;border-bottom:1px solid #f1f5f9;}
.lt-entry:last-child{border-bottom:0;}
.lt-entry-partial{opacity:.72;font-style:italic;}
.lt-time{font-size:11px;font-weight:800;color:var(--gold);font-variant-numeric:tabular-nums;}
.lt-text{font-size:13.5px;color:var(--text);line-height:1.55;}
.k-transcript-label{margin-top:10px;}

/* ── ROOM ACTIONS ──────────────────────────────────────────────── */
.k-room-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-bottom:16px;}
.k-processed-note{font-size:13px;color:var(--green);font-weight:500;}

/* ── MINUTES ───────────────────────────────────────────────────── */
.k-minutes-section{margin-top:8px;}
.k-summary{background:var(--navy-light);border-left:3px solid var(--navy);border-radius:0 8px 8px 0;
  padding:12px 16px;font-size:13.5px;color:var(--text2);line-height:1.7;margin-bottom:18px;}
.k-minutes-body{font-size:14px;line-height:1.75;color:var(--text);}
.k-minutes-body h1,.k-minutes-body h2{font-family:'Lora',serif;font-weight:600;color:var(--navy);margin:20px 0 10px;}
.k-minutes-body h1{font-size:19px;border-bottom:1px solid var(--border);padding-bottom:8px;}
.k-minutes-body h2{font-size:16px;}
.k-minutes-body h3,.k-minutes-body h4{font-size:14px;font-weight:600;color:var(--navy-mid);margin:14px 0 6px;}
.k-minutes-body p{margin-bottom:10px;}
.k-minutes-body ul{margin:8px 0 12px 22px;}
.k-minutes-body li{margin-bottom:5px;}

.k-res-list,.k-action-list,.k-flags-list{display:flex;flex-direction:column;gap:8px;}
.k-res-item{display:flex;align-items:flex-start;gap:10px;font-size:13.5px;padding:10px 12px;
  background:var(--bg);border-radius:8px;line-height:1.5;}
.k-action-item{padding:12px;background:var(--bg);border-radius:8px;}
.k-action-task{font-size:13.5px;font-weight:500;margin-bottom:6px;}
.k-action-meta{display:flex;gap:10px;align-items:center;flex-wrap:wrap;font-size:12px;color:var(--text3);}
.k-flag{padding:10px 14px;border-radius:8px;font-size:13px;border-left:3px solid;}
.k-flag-warning{background:#FEF3C7;border-color:var(--amber);color:#78350f;}
.k-flag-info{background:var(--navy-light);border-color:var(--navy);color:var(--navy);}
.k-flag-error{background:#FCEBEB;border-color:var(--red);color:#7f1d1d;}

/* ── MEMBERS ───────────────────────────────────────────────────── */
.k-mem-group{margin-bottom:20px;}
.k-mem-group-hdr{font-size:12px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;
  color:var(--navy);margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid var(--border);}
.k-mem-row{display:grid;grid-template-columns:110px 1fr 1fr 34px;gap:8px;align-items:center;margin-bottom:8px;}
.k-members-actions{margin-top:20px;padding-top:16px;border-top:1px solid var(--border);}

/* ── ARCHIVE SEARCH ────────────────────────────────────────────── */
.k-search-bar{margin-bottom:16px;}

/* ── TOAST ─────────────────────────────────────────────────────── */
.kpsc-toast{position:fixed;bottom:80px;left:50%;transform:translateX(-50%) translateY(16px);
  padding:10px 20px;border-radius:8px;font-size:13.5px;font-weight:500;
  box-shadow:0 4px 16px rgba(0,0,0,.18);z-index:9999;opacity:0;
  transition:opacity .22s,transform .22s;pointer-events:none;white-space:nowrap;}
.kpsc-toast-show{opacity:1;transform:translateX(-50%) translateY(0);}
.kpsc-toast-success{background:var(--green);color:#fff;}
.kpsc-toast-error  {background:var(--red);color:#fff;}
.kpsc-toast-info   {background:var(--navy);color:#fff;}

/* ── RESPONSIVE ────────────────────────────────────────────────── */
@media(max-width:560px){
  .kl-hero{padding:44px 20px 68px;}
  .kl-card{padding:28px 20px 20px;}
  .k-dash-stats{grid-template-columns:1fr 1fr;}.k-dash-stats .k-stat:last-child{grid-column:1/-1;}
  .k-field-row{grid-template-columns:1fr;}
  .k-mem-row{grid-template-columns:100px 1fr 28px;}.k-mem-pos{display:none;}
  .k-stepper{padding:12px 10px;}
  .k-step-label{font-size:9px;}
  .k-step-dot{width:24px;height:24px;font-size:11px;}
  .k-room-actions{flex-direction:column;align-items:stretch;}
  .k-room-actions .kbtn{justify-content:center;}
}

/* ── SETTINGS ──────────────────────────────────────────────────── */
.k-card-sub{font-size:13px;color:var(--text3);margin:0 0 16px;}
.k-settings-status{padding:10px 14px;border-radius:8px;font-size:13.5px;font-weight:500;margin-bottom:20px;}
.k-status-ai{background:#d1fae5;color:#065f46;border-left:3px solid var(--green);}
.k-status-rule{background:var(--surface2);color:var(--text2);border-left:3px solid var(--border);}
.k-form-group{margin-bottom:20px;}
.k-hint{font-size:12px;color:var(--text3);margin:4px 0 0;}
.k-settings-msg{padding:10px 14px;border-radius:8px;font-size:13.5px;margin-bottom:12px;}
.k-msg-ok{background:#d1fae5;color:#065f46;}
.k-msg-error{background:#FCEBEB;color:#7f1d1d;}
.k-about-row{display:flex;gap:16px;padding:8px 0;border-bottom:1px solid var(--border);font-size:13.5px;}
.k-about-row:last-child{border-bottom:none;}
.k-about-label{font-weight:600;color:var(--text2);min-width:80px;}
.kbtn-danger-outline{background:transparent;border:1.5px solid var(--red);color:var(--red);}
.kbtn-danger-outline:hover{background:var(--red);color:#fff;}
