@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,400;9..144,500;9..144,600;9..144,700&family=Inter:wght@400;500;600;700&display=swap');

:root {
  --green-900:#11241a; --green-800:#16301f; --green-700:#1f3d2c; --green-600:#2a5038;
  --green-500:#3a6b4c; --green-400:#5c8a6c;
  --brass:#a9854b; --brass-light:#c4a572;
  --ivory:#f6f4ec; --cream:#fbfaf4; --paper:#ffffff;
  --ink:#1b251f; --ink-2:#5d6b62; --ink-3:#8a958c;
  --line:#e6e3d8; --line-2:#efece2;
  --success:#2f7d4f; --success-bg:#e8f3ec; --success-line:#bfe0cb;
  --warn:#a9763a; --warn-bg:#f8efdf; --warn-line:#ecd5ad;
  --info:#2f5d8a; --info-bg:#e8f0f8; --info-line:#c2d6ea;
  --danger:#9a3b32; --danger-bg:#f8e9e7; --danger-line:#e6c4bf;
  --sidebar-w:264px; --radius:14px; --radius-sm:9px;
  --shadow-sm:0 1px 2px rgba(27,37,31,.05);
  --shadow:0 4px 16px rgba(27,37,31,.07);
  --shadow-lg:0 14px 44px rgba(17,36,26,.16);
}
* { box-sizing:border-box; }
html { -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; }
body { margin:0; font-family:'Inter', system-ui, sans-serif; background:var(--ivory); color:var(--ink); font-size:15px; line-height:1.5; }
a { color:inherit; text-decoration:none; }
h1,h2,h3 { font-family:'Fraunces', Georgia, serif; font-weight:600; letter-spacing:-.01em; color:var(--green-800); margin:0; }

.app-layout { display:flex; min-height:100vh; }

/* ===== Sidebar ===== */
.sidebar { width:var(--sidebar-w); background:linear-gradient(185deg, var(--green-700) 0%, var(--green-800) 60%, var(--green-900) 100%);
  color:#fff; display:flex; flex-direction:column; position:fixed; top:0; left:0; bottom:0; z-index:100; overflow-y:auto; }
.sidebar-logo { padding:22px 20px 20px; }
.sidebar-logo .chip { background:var(--cream); border-radius:12px; padding:16px 18px; display:block; box-shadow:0 2px 10px rgba(0,0,0,.18); }
.sidebar-logo img { width:100%; display:block; }
.sidebar-nav { flex:1; padding:8px 0; }
.sidebar-label { font-size:10.5px; font-weight:700; text-transform:uppercase; letter-spacing:.12em; color:rgba(255,255,255,.4); padding:16px 24px 9px; }
.sidebar-nav a { display:flex; align-items:center; gap:13px; padding:11px 24px; color:rgba(255,255,255,.72);
  font-size:14px; font-weight:500; border-left:3px solid transparent; transition:background .15s, color .15s, border-color .15s; }
.sidebar-nav a:hover { color:#fff; background:rgba(255,255,255,.06); }
.sidebar-nav a.active { color:#fff; background:rgba(255,255,255,.09); border-left-color:var(--brass-light); }
.sidebar-nav a svg { width:19px; height:19px; fill:none; stroke:currentColor; stroke-width:1.7; stroke-linecap:round; stroke-linejoin:round; opacity:.78; flex-shrink:0; }
.sidebar-nav a.active svg { opacity:1; color:var(--brass-light); }
.sidebar-user { margin:10px 14px 16px; padding:13px 14px; background:rgba(0,0,0,.16); border:1px solid rgba(255,255,255,.07); border-radius:12px; display:flex; align-items:center; gap:11px; }
.sidebar-user .avatar { width:36px; height:36px; border-radius:10px; background:var(--brass); display:flex; align-items:center; justify-content:center; font-size:13px; font-weight:700; color:#fff; flex-shrink:0; }
.sidebar-user .ud { flex:1; min-width:0; }
.sidebar-user .un { font-size:13px; font-weight:600; color:#fff; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.sidebar-user .ur { font-size:11px; color:rgba(255,255,255,.5); text-transform:capitalize; margin-top:1px; }
.sidebar-user button { background:none; border:none; color:rgba(255,255,255,.55); cursor:pointer; padding:6px; border-radius:7px; display:flex; transition:.15s; }
.sidebar-user button:hover { color:#fff; background:rgba(255,255,255,.12); }
.sidebar-user button svg { width:18px; height:18px; fill:none; stroke:currentColor; stroke-width:1.8; stroke-linecap:round; stroke-linejoin:round; }

/* ===== Main ===== */
.main { flex:1; margin-left:var(--sidebar-w); padding:40px 48px 96px; max-width:calc(100% - var(--sidebar-w)); min-height:100vh; }
.main-inner { max-width:980px; }
.main-inner.wide { max-width:1500px; }
.page-header { margin-bottom:30px; }
.page-header .crumb { font-size:12.5px; font-weight:500; color:var(--ink-3); margin-bottom:12px; letter-spacing:.01em; }
.page-header .crumb a { color:var(--green-600); }
.page-header .crumb a:hover { color:var(--green-700); }
.page-header h1 { font-size:32px; line-height:1.12; }
.page-header .subtitle { font-size:15px; color:var(--ink-2); margin-top:9px; line-height:1.6; max-width:660px; }

/* ===== Toast ===== */
.toast { background:var(--success-bg); border:1px solid var(--success-line); color:var(--success); padding:13px 18px; border-radius:12px; font-size:14px; font-weight:500; margin-bottom:24px; display:flex; align-items:center; gap:10px; }

/* ===== Form cards ===== */
.form-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(300px,1fr)); gap:20px; }
.form-card { position:relative; background:var(--paper); border:1px solid var(--line); border-radius:var(--radius); padding:24px 24px 20px;
  display:flex; flex-direction:column; min-height:184px; box-shadow:var(--shadow-sm); transition:box-shadow .18s, transform .18s, border-color .18s; }
.form-card::before { content:''; position:absolute; left:0; top:20px; bottom:20px; width:3px; border-radius:3px; background:var(--green-600); opacity:.0; transition:opacity .18s; }
.form-card:hover { box-shadow:var(--shadow); transform:translateY(-2px); border-color:#d8d4c6; }
.form-card:hover::before { opacity:.85; }
.form-card.is-soon { opacity:.72; }
.form-card .top { display:flex; align-items:flex-start; justify-content:space-between; gap:12px; margin-bottom:9px; }
.form-card h3 { font-size:18px; line-height:1.25; }
.form-card p { margin:0; font-size:13.5px; color:var(--ink-2); line-height:1.55; flex:1; }
.form-card .foot { margin-top:18px; }
.form-card .act, .form-card .act.ghost, .form-card .act.disabled { width:100%; text-align:center; display:block; }

/* ===== Pills ===== */
.pill { font-size:11.5px; font-weight:600; padding:5px 11px; border-radius:30px; white-space:nowrap; letter-spacing:.01em; border:1px solid transparent; }
.pill.not_started { background:var(--line-2); color:var(--ink-2); border-color:var(--line); }
.pill.in_progress { background:var(--warn-bg); color:var(--warn); border-color:var(--warn-line); }
.pill.submitted { background:var(--info-bg); color:var(--info); border-color:var(--info-line); }
.pill.approved { background:var(--success-bg); color:var(--success); border-color:var(--success-line); }
.pill.sent_back { background:var(--danger-bg); color:var(--danger); border-color:var(--danger-line); }
.pill.soon { background:var(--line-2); color:var(--ink-3); }

/* ===== Buttons ===== */
.act { background:var(--green-700); color:#fff; border:none; padding:11px 20px; border-radius:var(--radius-sm); font-family:inherit; font-weight:600; cursor:pointer; font-size:14px; white-space:nowrap; transition:background .15s, box-shadow .15s; box-shadow:var(--shadow-sm); }
.act:hover { background:var(--green-600); }
.act.ghost { background:#fff; color:var(--green-700); border:1px solid var(--line); box-shadow:none; }
.act.ghost:hover { border-color:var(--green-500); background:var(--cream); }
.act.disabled { background:var(--line-2); color:var(--ink-3); cursor:default; box-shadow:none; }

/* ===== Admin overview ===== */
.metrics { display:grid; grid-template-columns:repeat(auto-fit, minmax(200px,1fr)); gap:18px; margin-bottom:26px; }
.metric { background:var(--paper); border:1px solid var(--line); border-radius:var(--radius); padding:22px 24px; box-shadow:var(--shadow-sm); position:relative; overflow:hidden; }
.metric .ic { width:40px; height:40px; border-radius:11px; background:var(--cream); display:flex; align-items:center; justify-content:center; margin-bottom:16px; }
.metric .ic svg { width:21px; height:21px; stroke:var(--green-600); fill:none; stroke-width:1.7; stroke-linecap:round; stroke-linejoin:round; }
.metric .n { font-family:'Fraunces', serif; font-size:34px; font-weight:600; color:var(--green-800); line-height:1; }
.metric .l { font-size:13px; color:var(--ink-2); margin-top:7px; font-weight:500; }
.metric.alert { border-color:var(--warn-line); }
.metric.alert .ic { background:var(--warn-bg); }
.metric.alert .ic svg { stroke:var(--brass); }
.metric.alert .n { color:var(--brass); }

/* dashboard two-column */
.dash-grid { display:grid; grid-template-columns:1.7fr 1fr; gap:22px; align-items:start; }
.side-stack { display:flex; flex-direction:column; gap:22px; }
.panel { background:var(--paper); border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow-sm); overflow:hidden; }
.panel-head { padding:17px 22px; border-bottom:1px solid var(--line-2); display:flex; align-items:center; justify-content:space-between; }
.panel-head h2 { font-size:17px; }
.panel-head a { font-size:13px; font-weight:600; color:var(--green-600); }
.panel-head a:hover { color:var(--green-700); }
.q-item { display:flex; align-items:center; gap:14px; padding:15px 22px; border-bottom:1px solid var(--line-2); transition:background .12s; }
.q-item:last-child { border-bottom:none; }
.q-item:hover { background:var(--cream); }
.q-item .q-main { flex:1; min-width:0; }
.q-item .q-school { font-weight:600; font-size:14px; }
.q-item .q-form { font-size:12.5px; color:var(--ink-2); margin-top:2px; }
.q-item .q-go { font-size:13px; font-weight:600; color:var(--green-600); white-space:nowrap; }
.panel-empty { padding:34px 22px; text-align:center; color:var(--ink-2); font-size:13.5px; }
.mini { padding:16px 22px; display:flex; align-items:center; gap:14px; border-bottom:1px solid var(--line-2); }
.mini:last-child { border-bottom:none; }
.mini .mn { font-family:'Fraunces', serif; font-size:22px; font-weight:600; color:var(--green-700); min-width:34px; }
.mini .ml { font-size:13.5px; color:var(--ink); }
.mini .ml span { display:block; font-size:12px; color:var(--ink-3); }
.quick { padding:14px 16px; display:flex; flex-direction:column; gap:9px; }
.quick a { display:flex; align-items:center; gap:11px; padding:11px 14px; border-radius:var(--radius-sm); font-size:14px; font-weight:500; color:var(--ink); border:1px solid var(--line); transition:.13s; }
.quick a:hover { border-color:var(--green-500); background:var(--cream); color:var(--green-700); }
.quick a svg { width:18px; height:18px; stroke:var(--green-600); fill:none; stroke-width:1.7; stroke-linecap:round; stroke-linejoin:round; }
.quick a.soon { opacity:.55; pointer-events:none; }
.quick a .tag { margin-left:auto; font-size:11px; color:var(--ink-3); }
@media (max-width:1040px){ .dash-grid { grid-template-columns:1fr; } }
.subtable { width:100%; border-collapse:collapse; background:var(--paper); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-sm); }
.subtable th { text-align:left; font-size:11px; text-transform:uppercase; letter-spacing:.06em; color:var(--ink-3); font-weight:700; padding:14px 18px; background:var(--cream); border-bottom:1px solid var(--line); }
.subtable td { padding:15px 18px; border-bottom:1px solid var(--line-2); font-size:14px; }
.subtable tr:last-child td { border-bottom:none; }
.subtable tbody tr { transition:background .12s; }
.subtable tbody tr:hover { background:var(--cream); }
.subtable .review-link { color:var(--green-600); font-weight:600; }
.subtable .review-link:hover { color:var(--green-700); }
.empty { background:var(--paper); border:1px dashed var(--line); border-radius:var(--radius); padding:54px; text-align:center; color:var(--ink-2); }

/* ===== Cards (generic) ===== */
.cards { display:grid; grid-template-columns:repeat(auto-fill, minmax(240px,1fr)); gap:20px; }
.card { background:var(--paper); border:1px solid var(--line); border-radius:var(--radius); padding:24px; box-shadow:var(--shadow-sm); }
.card h3 { font-size:17px; margin-bottom:7px; }
.card p { margin:0; font-size:13.5px; color:var(--ink-2); line-height:1.55; }
.card .soon-tag { display:inline-block; margin-top:16px; font-size:11.5px; font-weight:600; color:var(--warn); background:var(--warn-bg); border:1px solid var(--warn-line); padding:4px 11px; border-radius:30px; }

.loading { padding:64px 0; text-align:center; color:var(--ink-3); font-size:14px; }

/* ===== Form renderer ===== */
.intro { background:var(--cream); border:1px solid var(--line); border-left:3px solid var(--brass); border-radius:var(--radius-sm); padding:17px 20px; font-size:14px; line-height:1.6; color:#41514a; margin:0 0 26px; }
.banner { border-radius:var(--radius-sm); padding:14px 18px; font-size:14px; margin:0 0 22px; font-weight:500; line-height:1.5; }
.banner.submitted { background:var(--info-bg); border:1px solid var(--info-line); color:var(--info); }
.banner.approved { background:var(--success-bg); border:1px solid var(--success-line); color:var(--success); }
.banner.sent_back { background:var(--danger-bg); border:1px solid var(--danger-line); color:var(--danger); }
.section { background:var(--paper); border:1px solid var(--line); border-radius:var(--radius); padding:26px 28px; margin-bottom:22px; box-shadow:var(--shadow-sm); }
.section h2 { font-size:20px; margin-bottom:5px; color:var(--green-800); }
.section .help { font-size:13px; color:var(--ink-2); line-height:1.6; margin:0 0 18px; }
.field { margin-bottom:19px; }
.field:last-child { margin-bottom:0; }
.field > label { display:block; font-size:13px; font-weight:600; color:#33433a; margin-bottom:7px; line-height:1.45; }
.req { color:var(--danger); }
input[type=text], input[type=email], input[type=password], input[type=number], input[type=date], textarea, select {
  width:100%; padding:11px 13px; border:1px solid var(--line); border-radius:var(--radius-sm); font-size:14.5px; font-family:inherit; color:var(--ink); background:#fff; transition:border-color .15s, box-shadow .15s; }
input::placeholder, textarea::placeholder { color:var(--ink-3); }
textarea { min-height:104px; resize:vertical; line-height:1.5; }
input:focus, textarea:focus, select:focus { outline:none; border-color:var(--green-500); box-shadow:0 0 0 3px rgba(58,107,76,.13); }
.radios, .checks { display:flex; flex-wrap:wrap; gap:9px 20px; }
.radios label, .checks label { font-weight:400; font-size:14px; display:flex; align-items:center; gap:7px; cursor:pointer; }
/* Yes/No segmented control */
.yesno { display:inline-flex; border:1px solid var(--line); border-radius:var(--radius-sm); overflow:hidden; background:#fff; }
.yesno label { font-size:13.5px; font-weight:600; padding:8px 22px; cursor:pointer; color:var(--ink-2); border-left:1px solid var(--line); transition:background .15s, color .15s; }
.yesno label:first-child { border-left:none; }
.yesno label input { position:absolute; opacity:0; width:0; height:0; }
.yesno label:has(input:checked) { background:var(--green-700); color:#fff; }
.single-check { display:flex; align-items:flex-start; gap:10px; font-weight:400; font-size:14px; line-height:1.5; cursor:pointer; }
.single-check input { margin-top:3px; }
input[type=file] { font-size:13px; }
input[type=file]::file-selector-button { font-family:inherit; font-weight:600; font-size:13px; color:var(--green-700); background:var(--cream); border:1px solid var(--line); border-radius:7px; padding:8px 14px; margin-right:12px; cursor:pointer; }
.filelist { display:flex; flex-direction:column; gap:7px; margin-top:10px; }
.file-chip { display:flex; align-items:center; gap:10px; padding:9px 12px; background:var(--cream); border:1px solid var(--line); border-radius:8px; }
.file-chip .fc-ic { width:17px; height:17px; fill:none; stroke:var(--green-600); stroke-width:1.6; stroke-linecap:round; stroke-linejoin:round; flex-shrink:0; }
.file-chip .fc-name { font-size:13.5px; font-weight:500; color:var(--green-700); flex:1; min-width:0; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.file-chip .fc-name:hover { text-decoration:underline; }
.file-chip .fc-size { font-size:12px; color:var(--ink-3); }
.file-chip .fc-rm { background:none; border:none; color:var(--ink-3); font-size:20px; line-height:1; cursor:pointer; padding:0 4px; border-radius:5px; }
.file-chip .fc-rm:hover { color:var(--danger); }
.file-progress { font-size:12.5px; color:var(--ink-2); padding:6px 2px; }
.file-progress.err { color:var(--danger); }
table.grid { width:100%; border-collapse:collapse; font-size:13px; border-radius:8px; overflow:hidden; }
table.grid th { text-align:left; padding:8px 10px; background:var(--cream); border:1px solid var(--line); font-size:11.5px; font-weight:700; text-transform:uppercase; letter-spacing:.04em; color:var(--ink-2); }
table.grid td { padding:0; border:1px solid var(--line); }
table.grid td input { border:none; border-radius:0; padding:9px 10px; }
table.grid td input:focus { box-shadow:inset 0 0 0 2px rgba(58,107,76,.2); }
.addrow { margin-top:10px; font-size:13px; font-weight:600; color:var(--green-700); background:var(--cream); border:1px solid var(--line); border-radius:8px; padding:8px 14px; cursor:pointer; }
.addrow:hover { border-color:var(--green-500); }

/* Sticky action bars */
.bar, .review-bar { position:fixed; bottom:0; left:var(--sidebar-w); right:0; background:rgba(255,255,255,.92); backdrop-filter:blur(8px); border-top:1px solid var(--line); padding:15px 48px; z-index:50; box-shadow:0 -6px 24px rgba(17,36,26,.06); }
.bar .inner, .review-bar .inner { width:100%; max-width:980px; margin:0 auto; display:flex; align-items:center; gap:13px; }
.save { background:#fff; border:1px solid var(--line); color:var(--green-700); padding:11px 22px; border-radius:var(--radius-sm); font-family:inherit; font-weight:600; cursor:pointer; font-size:14px; }
.save:hover { border-color:var(--green-500); background:var(--cream); }
.submit, .btn-approve { background:var(--green-700); border:none; color:#fff; padding:11px 26px; border-radius:var(--radius-sm); font-family:inherit; font-weight:600; cursor:pointer; font-size:14px; box-shadow:var(--shadow-sm); }
.submit:hover, .btn-approve:hover { background:var(--green-600); }
.btn-approve { background:var(--success); }
.btn-approve:hover { background:#27693f; }
.btn-sendback { background:#fff; border:1px solid var(--danger-line); color:var(--danger); padding:11px 22px; border-radius:var(--radius-sm); font-family:inherit; font-weight:600; cursor:pointer; font-size:14px; }
.btn-sendback:hover { background:var(--danger-bg); }
.submit:disabled, .save:disabled, .btn-approve:disabled, .btn-sendback:disabled { opacity:.5; cursor:default; }
.status-msg { font-size:13px; color:var(--ink-2); margin-left:auto; font-weight:500; }

/* ===== Login ===== */
.login-wrap { min-height:100vh; display:grid; grid-template-columns:1.05fr 1fr; }
.login-brand { background:linear-gradient(190deg, var(--green-700), var(--green-900)); color:#fff; padding:56px 60px; display:flex; flex-direction:column; justify-content:space-between; position:relative; overflow:hidden; }
.login-brand::after { content:''; position:absolute; right:-120px; bottom:-120px; width:380px; height:380px; border-radius:50%; background:rgba(255,255,255,.04); }
.login-brand .logo-chip { background:var(--cream); border-radius:14px; padding:20px 24px; align-self:flex-start; box-shadow:0 8px 30px rgba(0,0,0,.22); }
.login-brand .logo-chip img { width:210px; display:block; }
.login-brand .pitch h2 { color:#fff; font-size:34px; line-height:1.2; max-width:420px; }
.login-brand .pitch p { color:rgba(255,255,255,.72); font-size:15px; line-height:1.65; max-width:400px; margin-top:16px; }
.login-brand .foot { font-size:12.5px; color:rgba(255,255,255,.5); position:relative; }
.login-form-side { display:flex; align-items:center; justify-content:center; padding:40px; background:var(--ivory); }
.login-card { width:100%; max-width:380px; }
.login-card h1 { font-size:27px; margin-bottom:6px; }
.login-card .lead { font-size:14px; color:var(--ink-2); margin-bottom:28px; }
.login-card label { display:block; font-size:13px; font-weight:600; color:#33433a; margin-bottom:7px; }
.login-card input { margin-bottom:18px; }
.login-card .btn-primary { width:100%; padding:13px; background:var(--green-700); color:#fff; border:none; border-radius:var(--radius-sm); font-family:inherit; font-size:15px; font-weight:600; cursor:pointer; transition:background .15s; }
.login-card .btn-primary:hover { background:var(--green-600); }
.login-card .btn-primary:disabled { opacity:.6; cursor:default; }
.login-msg { margin-top:14px; font-size:13.5px; text-align:center; color:var(--danger); min-height:18px; }
.login-card .apply-line { margin-top:24px; padding-top:22px; border-top:1px solid var(--line); text-align:center; font-size:14px; color:var(--ink-2); }
.login-card .apply-line a { color:var(--green-700); font-weight:600; }
.login-card .help-line { margin-top:18px; text-align:center; font-size:12.5px; color:var(--ink-3); line-height:1.55; }
.login-card .help-line a { color:var(--green-600); }

@media (max-width:900px){ .login-wrap{ grid-template-columns:1fr; } .login-brand{ padding:36px 32px; } .login-brand .pitch{ display:none; } }
@media (max-width:780px){
  .sidebar { position:static; width:100%; flex-direction:row; flex-wrap:wrap; align-items:center; }
  .sidebar-logo { padding:12px; } .sidebar-logo .chip{ padding:8px 12px; } .sidebar-logo img{ width:120px; }
  .sidebar-nav { display:flex; flex-wrap:wrap; padding:4px; flex:1; } .sidebar-label{ display:none; }
  .sidebar-nav a { padding:9px 14px; border-left:none; }
  .sidebar-user { margin:8px; }
  .main { margin-left:0; max-width:100%; padding:24px 18px 100px; }
  .bar, .review-bar { left:0; padding:14px 18px; }
}
