/* ============================================================
   assets/css/app.css  —  MAVENCO Appraisal System Styles
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Playfair+Display:wght@700&display=swap');

:root {
  --navy:   #1B2B4B;
  --navy2:  #2C3E70;
  --gold:   #C9922A;
  --gold-l: #F5DFA8;
  --cream:  #F8F9FC;
  --white:  #FFFFFF;
  --mid:    #6B7A99;
  --border: #DDE3EF;
  --green:  #2E7D52;
  --red:    #B03A2E;
  --warn:   #856404;
  --warn-bg:#FFF3CD;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
body { font-family: 'Inter', sans-serif; background: var(--cream); color: var(--navy); font-size: 14px; }
a { color: var(--navy); text-decoration: none; }
a:hover { opacity: .8; }
code { font-family: monospace; background: #EEF2FF; padding: 2px 6px; border-radius: 4px; font-size: 12px; }

/* ── AUTH ── */
.auth-body { background: linear-gradient(135deg, var(--navy) 0%, #2C3E70 100%); min-height:100vh; display:flex; align-items:center; justify-content:center; padding:20px; }
.auth-screen { width:100%; display:flex; align-items:center; justify-content:center; }
.auth-card { background:var(--white); border-radius:16px; padding:44px 40px; width:100%; max-width:480px; box-shadow:0 24px 80px rgba(0,0,0,.3); }
.auth-logo { text-align:center; margin-bottom:28px; }
.coop-name { font-family:'Playfair Display',serif; font-size:28px; color:var(--navy); }
.coop-name span { color:var(--gold); }
.gold-bar { display:block; width:48px; height:3px; background:var(--gold); margin:8px auto; border-radius:2px; }
.coop-full { font-size:12px; color:var(--mid); line-height:1.5; margin-top:4px; }
.auth-subtitle { font-size:11px; text-transform:uppercase; letter-spacing:2px; color:var(--mid); margin-top:6px; }
.auth-tabs { display:flex; margin-bottom:24px; border-bottom:2px solid var(--border); }
.auth-tab { flex:1; text-align:center; padding:10px; font-weight:600; font-size:14px; color:var(--mid); border-bottom:2px solid transparent; margin-bottom:-2px; }
.auth-tab.active { color:var(--navy); border-color:var(--gold); }
.register-note { background:#EEF7FF; border:1px solid #BDD8FF; border-radius:8px; padding:12px 14px; font-size:12px; color:#1a4a7a; margin-bottom:16px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }

/* ── TOP BAR ── */
.topbar { background:var(--navy); color:var(--white); display:flex; align-items:center; gap:16px; padding:0 24px; height:58px; position:sticky; top:0; z-index:100; box-shadow:0 2px 12px rgba(0,0,0,.2); }
.topbar-brand { font-family:'Playfair Display',serif; font-size:20px; white-space:nowrap; }
.topbar-brand span { color:var(--gold); }
.topbar-brand small { font-family:'Inter',sans-serif; font-size:11px; opacity:.5; font-weight:400; margin-left:4px; }
.topbar-links { display:flex; gap:4px; flex:1; }
.topbar-links a { color:rgba(255,255,255,.7); padding:6px 12px; border-radius:6px; font-size:13px; font-weight:500; transition:all .15s; }
.topbar-links a:hover, .topbar-links a.active { background:rgba(255,255,255,.12); color:var(--white); }
.topbar-right { display:flex; align-items:center; gap:12px; margin-left:auto; }
.user-badge { display:flex; align-items:center; gap:10px; background:rgba(255,255,255,.1); border-radius:30px; padding:5px 12px 5px 6px; }
.user-avatar { width:30px; height:30px; border-radius:50%; background:var(--gold); display:flex; align-items:center; justify-content:center; font-size:12px; font-weight:700; color:var(--navy); }
.user-info .uname { font-size:13px; font-weight:600; }
.user-info .urole { font-size:11px; opacity:.6; }
.btn-logout { background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.2); color:var(--white); padding:6px 12px; border-radius:6px; font-size:12px; cursor:pointer; transition:background .2s; white-space:nowrap; }
.btn-logout:hover { background:rgba(255,255,255,.2); }

/* ── LAYOUT ── */
.main-content { max-width:1100px; margin:0 auto; padding:28px 24px; }
.page-header { display:flex; align-items:flex-start; justify-content:space-between; margin-bottom:24px; gap:16px; }
.page-title { font-size:24px; font-weight:700; margin-bottom:4px; }
.page-sub { font-size:13px; color:var(--mid); }

/* ── STATS ── */
.stat-row { display:grid; grid-template-columns:repeat(auto-fit,minmax(160px,1fr)); gap:14px; margin-bottom:24px; }
.stat-card { background:var(--white); border:1px solid var(--border); border-radius:12px; padding:18px 20px; }
.stat-card.accent { background:var(--navy); border-color:var(--navy); }
.stat-card.accent .slabel, .stat-card.accent .ssub { color:rgba(255,255,255,.6); }
.stat-card.accent .svalue { color:var(--gold); }
.slabel { font-size:11px; text-transform:uppercase; letter-spacing:1px; color:var(--mid); }
.svalue { font-size:32px; font-weight:700; margin:4px 0; }
.ssub { font-size:12px; color:var(--mid); }
.ssub a { color:var(--gold); }

/* ── CARD ── */
.card { background:var(--white); border:1px solid var(--border); border-radius:12px; margin-bottom:20px; overflow:hidden; }
.card-header { padding:16px 22px; border-bottom:1px solid var(--border); display:flex; align-items:center; justify-content:space-between; }
.card-header h3 { font-size:15px; font-weight:600; }
.card-body { padding:22px; }

/* ── TABLE ── */
.table-wrap { overflow-x:auto; }
table { width:100%; border-collapse:collapse; }
th { text-align:left; font-size:11px; color:var(--mid); text-transform:uppercase; letter-spacing:1px; padding:10px 14px 10px; white-space:nowrap; }
td { padding:12px 14px; font-size:13px; border-top:1px solid var(--border); vertical-align:middle; }
tr:hover td { background:#F7F9FF; }
.empty-row { text-align:center; color:var(--mid); padding:32px !important; }
.sub-head { background:#F0F4FF; font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:1px; color:var(--navy); padding:8px 14px !important; }
.score-pill { display:inline-block; width:28px; height:28px; border-radius:50%; color:#fff; font-size:13px; font-weight:700; text-align:center; line-height:28px; }

/* ── BADGES ── */
.badge { display:inline-block; padding:3px 10px; border-radius:20px; font-size:11px; font-weight:600; }
.badge-draft, .badge-pending { background:var(--warn-bg); color:var(--warn); }
.badge-submitted { background:#D1ECF1; color:#0C5460; }
.badge-approved, .badge-active { background:#D4EDDA; color:#155724; }
.badge-rejected, .badge-disabled { background:#F8D7DA; color:#721C24; }

/* ── BUTTONS ── */
.btn { display:inline-block; padding:8px 16px; border-radius:7px; font-size:13px; font-weight:500; cursor:pointer; border:none; font-family:'Inter',sans-serif; transition:all .15s; text-align:center; }
.btn-sm { padding:5px 11px; font-size:12px; }
.btn-fill { background:var(--navy); color:var(--white); }
.btn-fill:hover { background:var(--navy2); color:var(--white); }
.btn-outline { background:transparent; color:var(--navy); border:1.5px solid var(--border); }
.btn-outline:hover { border-color:var(--navy); }
.btn-gold { background:var(--gold); color:var(--white); }
.btn-gold:hover { background:#B07E22; }
.btn-green { background:var(--green); color:var(--white); }
.btn-green:hover { background:#25644A; }
.btn-danger { background:var(--red); color:var(--white); }
.btn-danger:hover { background:#8E2E24; }
.btn-primary { width:100%; padding:13px; background:var(--navy); color:var(--white); border:none; border-radius:8px; font-size:15px; font-weight:600; cursor:pointer; font-family:'Inter',sans-serif; }
.btn-primary:hover { background:var(--navy2); }

/* ── FORMS ── */
.form-group { margin-bottom:16px; }
.form-group label { display:block; font-size:11px; font-weight:600; color:var(--mid); text-transform:uppercase; letter-spacing:1px; margin-bottom:5px; }
.form-group input, .form-group select, .form-group textarea {
  width:100%; padding:10px 12px; border:1.5px solid var(--border);
  border-radius:8px; font-size:14px; font-family:'Inter',sans-serif;
  background:var(--white); color:var(--navy); transition:border-color .2s;
}
.form-group input:focus, .form-group select:focus, .form-group textarea:focus { outline:none; border-color:var(--gold); }
.form-group input[readonly] { background:#F5F5F5; }
.req { color:var(--red); }
.form-meta { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.inline-select { padding:4px 8px; border:1px solid var(--border); border-radius:5px; font-size:12px; }
.form-actions { display:flex; gap:10px; justify-content:flex-end; margin-top:24px; flex-wrap:wrap; }

/* ── ALERTS ── */
.alert { padding:12px 16px; border-radius:8px; font-size:13px; margin-bottom:16px; }
.alert-success { background:#D4EDDA; color:#155724; border:1px solid #C3E6CB; }
.alert-error   { background:#F8D7DA; color:#721C24; border:1px solid #F5C6CB; }
.alert-warning { background:var(--warn-bg); color:var(--warn); border:1px solid #FFEEBA; }
.alert-info    { background:#D1ECF1; color:#0C5460; border:1px solid #BEE5EB; }

/* ── APPRAISAL FORM ── */
.form-header-bar { background:var(--navy); color:var(--white); padding:22px 24px; }
.form-header-bar h2 { font-family:'Playfair Display',serif; font-size:20px; margin-bottom:4px; }
.form-header-bar p { font-size:12px; opacity:.6; }
.section-heading { font-size:16px; font-weight:700; margin:24px 0 4px; color:var(--navy); }
.section-heading .section-weight { font-size:11px; background:var(--gold-l); color:#7B5700; padding:2px 8px; border-radius:4px; margin-left:8px; font-weight:500; }
.section-desc { font-size:13px; color:var(--mid); margin-bottom:18px; line-height:1.5; }
.section-divider { border:none; border-top:1px solid var(--border); margin:28px 0; }
.sub-section-heading { font-size:14px; font-weight:700; margin:22px 0 10px; color:var(--navy); border-left:3px solid var(--gold); padding-left:10px; }
.criteria-block { background:#F8F9FD; border:1px solid var(--border); border-radius:10px; padding:18px; margin-bottom:16px; }
.criteria-name { font-size:14px; font-weight:600; margin-bottom:4px; }
.criteria-weight-tag { font-size:10px; background:var(--gold-l); color:#7B5700; padding:2px 7px; border-radius:4px; margin-left:8px; font-weight:500; }
.criteria-desc { font-size:12px; color:var(--mid); margin-bottom:12px; line-height:1.5; }
.score-level-table { margin-bottom:12px; }
.level-row { display:flex; align-items:flex-start; gap:10px; font-size:12px; margin-bottom:5px; }
.level-num { width:22px; height:22px; border-radius:50%; color:#fff; font-size:11px; font-weight:700; text-align:center; line-height:22px; flex-shrink:0; }
.score-buttons { display:flex; gap:8px; margin-bottom:12px; }
.score-btn { width:52px; height:44px; border-radius:8px; font-size:15px; font-weight:700; cursor:pointer; border:2px solid var(--border); background:var(--white); color:var(--navy); transition:all .15s; }
.score-btn:hover { transform:translateY(-2px); box-shadow:0 4px 10px rgba(0,0,0,.1); }
.score-btn.selected-5 { background:#2E7D52; color:#fff; border-color:#2E7D52; }
.score-btn.selected-4 { background:#2980B9; color:#fff; border-color:#2980B9; }
.score-btn.selected-3 { background:#7F8C8D; color:#fff; border-color:#7F8C8D; }
.score-btn.selected-2 { background:#D4A017; color:#fff; border-color:#D4A017; }
.score-btn.selected-1 { background:#B03A2E; color:#fff; border-color:#B03A2E; }
.comments-field label { font-size:11px; color:var(--mid); margin-bottom:4px; display:block; }
.comments-field textarea { width:100%; padding:8px 10px; border:1.5px solid var(--border); border-radius:7px; font-size:12px; font-family:'Inter',sans-serif; resize:vertical; min-height:52px; background:var(--white); }
.comments-field textarea:focus { outline:none; border-color:var(--gold); }
.essay-field { margin-bottom:18px; }
.essay-field label { font-size:13px; font-weight:600; display:block; margin-bottom:6px; }
.essay-field textarea { width:100%; padding:10px; border:1.5px solid var(--border); border-radius:8px; font-size:13px; font-family:'Inter',sans-serif; resize:vertical; }
.essay-field textarea:focus { outline:none; border-color:var(--gold); }
.essay-view { margin-bottom:18px; }
.essay-view p { color:var(--mid); font-size:13px; margin-top:4px; line-height:1.6; }

/* ── COLLATION BOX ── */
.collation-box { background:var(--navy); color:var(--white); border-radius:12px; padding:24px; margin:24px 0; }
.collation-box h3 { font-family:'Playfair Display',serif; font-size:18px; color:var(--gold); margin-bottom:20px; }
.collation-grid { display:grid; grid-template-columns:1fr 1fr; gap:24px; margin-bottom:16px; }
.col-section { font-size:11px; text-transform:uppercase; letter-spacing:1.5px; color:rgba(255,255,255,.5); margin-bottom:8px; }
.col-row { display:flex; justify-content:space-between; padding:6px 0; border-bottom:1px solid rgba(255,255,255,.08); font-size:12px; }
.col-row span:first-child { opacity:.7; }
.col-row span:last-child { font-weight:600; }
.col-row.total { border-top:1px solid rgba(255,255,255,.25); border-bottom:none; margin-top:4px; padding-top:10px; }
.col-row.total span { font-weight:700; color:var(--white); }
.final-grade-box { text-align:center; padding:20px; background:rgba(201,146,42,.15); border-radius:10px; border:2px solid var(--gold); margin-top:16px; }
.fg-label { font-size:11px; opacity:.6; text-transform:uppercase; letter-spacing:2px; }
.fg-score { font-size:52px; font-weight:700; color:var(--gold); line-height:1; }
.fg-rating { font-size:14px; opacity:.8; margin-top:4px; }

/* ── VIEW PAGE ── */
.grade-banner { display:flex; align-items:center; background:var(--navy); color:var(--white); border-radius:12px; padding:18px 24px; margin-bottom:20px; gap:0; flex-wrap:wrap; }
.gb-item { flex:1; min-width:120px; text-align:center; padding:8px 16px; }
.gb-label { display:block; font-size:10px; text-transform:uppercase; letter-spacing:1.5px; opacity:.6; margin-bottom:4px; }
.gb-val { font-size:22px; font-weight:700; }
.gb-big { font-size:36px; color:var(--gold); }
.gb-divider { width:1px; background:rgba(255,255,255,.15); height:50px; align-self:center; }
.score-table td { vertical-align:top; }
.text-mid { color:var(--mid); }

/* ── TOAST ── */
.toast { position:fixed; bottom:20px; right:20px; background:var(--navy); color:var(--white); padding:12px 18px; border-radius:10px; font-size:14px; font-weight:500; z-index:999; transform:translateY(80px); opacity:0; transition:all .3s; box-shadow:0 8px 32px rgba(0,0,0,.2); }
.toast.show { transform:translateY(0); opacity:1; }
.toast.success { border-left:4px solid var(--green); }
.toast.error   { border-left:4px solid var(--red); }

/* ── RESPONSIVE ── */
@media(max-width:700px){
  .main-content { padding:16px; }
  .form-meta, .form-row, .collation-grid { grid-template-columns:1fr; }
  .stat-row { grid-template-columns:1fr 1fr; }
  .topbar-links { display:none; }
  .grade-banner { flex-direction:column; }
  .gb-divider { display:none; }
  .page-header { flex-direction:column; }
}
