/* AwardsDay — academic / ceremony aesthetic
   navy + gold on parchment. Fraunces display, IBM Plex Sans body. */
:root{
  --navy:#16243f; --navy-2:#1f3257; --gold:#b8893a; --gold-soft:#d8b76a;
  --parchment:#f6f1e7; --paper:#fffdf8; --ink:#23272e; --muted:#6b6a63;
  --line:#e3dccb; --green:#2f7d5b; --red:#a8432f;
  --shadow:0 1px 2px rgba(22,36,63,.06),0 8px 24px rgba(22,36,63,.07);
}
*{box-sizing:border-box}
html,body{margin:0}
body{
  font-family:"IBM Plex Sans",ui-sans-serif,system-ui,sans-serif;
  color:var(--ink); background:var(--parchment);
  background-image:radial-gradient(circle at 1px 1px, rgba(22,36,63,.035) 1px, transparent 0);
  background-size:22px 22px; line-height:1.5; font-size:15px;
}
h1,h2,h3,.display{font-family:"Fraunces",Georgia,serif; letter-spacing:-.01em}
a{color:var(--navy-2)}
.wrap{max-width:1180px; margin:0 auto; padding:0 22px}

/* ---- top bar ---- */
header.top{background:var(--navy); color:#f3ede0; border-bottom:3px solid var(--gold)}
header.top .wrap{display:flex; align-items:center; gap:26px; min-height:64px; flex-wrap:wrap}
.brand{font-family:"Fraunces",serif; font-weight:600; font-size:20px; color:#fff;
  display:flex; align-items:center; gap:10px}
.brand .seal{width:30px;height:30px;border:2px solid var(--gold-soft);border-radius:50%;
  display:grid;place-items:center;font-size:13px;color:var(--gold-soft)}
nav.main{display:flex; gap:4px; flex-wrap:wrap; margin-left:auto}
nav.main a{color:#cdd6e6; text-decoration:none; padding:7px 12px; border-radius:7px;
  font-size:14px; font-weight:500}
nav.main a:hover{background:var(--navy-2); color:#fff}
nav.main a.active{background:var(--gold); color:var(--navy); font-weight:600}

/* ---- page ---- */
main{padding:30px 0 70px}
.pagehead{display:flex; align-items:flex-end; justify-content:space-between; gap:16px;
  margin-bottom:22px; flex-wrap:wrap}
.pagehead h1{margin:0; font-size:30px; color:var(--navy)}
.pagehead p{margin:6px 0 0; color:var(--muted); max-width:60ch}
.kicker{font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:var(--gold);
  font-weight:600; margin-bottom:4px}

/* ---- cards / stats ---- */
.stats{display:grid; grid-template-columns:repeat(auto-fit,minmax(160px,1fr)); gap:14px; margin-bottom:26px}
.stat{background:var(--paper); border:1px solid var(--line); border-radius:12px; padding:18px 20px;
  box-shadow:var(--shadow)}
.stat .num{font-family:"Fraunces",serif; font-size:38px; color:var(--navy); line-height:1}
.stat .lbl{color:var(--muted); font-size:13px; margin-top:4px}
.card{background:var(--paper); border:1px solid var(--line); border-radius:12px;
  padding:20px 22px; box-shadow:var(--shadow); margin-bottom:20px}
.card h2{margin:0 0 14px; font-size:19px; color:var(--navy)}
.grid2{display:grid; grid-template-columns:2fr 1fr; gap:20px; align-items:start}
@media(max-width:820px){.grid2{grid-template-columns:1fr}}

/* ---- tables ---- */
table{width:100%; border-collapse:collapse}
th,td{text-align:left; padding:9px 10px; border-bottom:1px solid var(--line); vertical-align:top}
th{font-size:12px; letter-spacing:.04em; text-transform:uppercase; color:var(--muted);
  font-weight:600; background:#faf6ec}
tbody tr:hover{background:#fbf8f0}
td.num,th.num{text-align:right; font-variant-numeric:tabular-nums}

/* ---- forms / buttons ---- */
input,select{font:inherit; padding:8px 10px; border:1px solid var(--line); border-radius:8px;
  background:#fff; color:var(--ink)}
input:focus,select:focus{outline:2px solid var(--gold-soft); outline-offset:0; border-color:var(--gold)}
label.fld{display:block; font-size:13px; color:var(--muted); margin-bottom:5px; font-weight:500}
.row{display:flex; gap:10px; flex-wrap:wrap; align-items:flex-end}
.btn{font:inherit; font-weight:600; font-size:14px; padding:9px 16px; border-radius:8px;
  border:1px solid var(--navy); background:var(--navy); color:#fff; cursor:pointer; text-decoration:none;
  display:inline-block}
.btn:hover{background:var(--navy-2)}
.btn.gold{background:var(--gold); border-color:var(--gold); color:var(--navy)}
.btn.gold:hover{background:var(--gold-soft)}
.btn.ghost{background:transparent; color:var(--navy); border-color:var(--line)}
.btn.ghost:hover{background:#f1ebdc}
.btn.sm{padding:5px 10px; font-size:13px}
.btn.danger{background:#fff; color:var(--red); border-color:#e7c4ba}
.btn.danger:hover{background:#fbeae5}

.pill{display:inline-block; padding:2px 9px; border-radius:999px; font-size:12px; font-weight:600;
  background:#eef2f8; color:var(--navy-2); border:1px solid #dde5f1}
.pill.pin{background:#fdf0e6;color:#9a5a1e;border-color:#f2d8bf}
.pill.certificate{background:#eaf3ee;color:#2f7d5b;border-color:#cce4d6}
.pill.cord{background:#f0eafa;color:#5b3f9a;border-color:#ddd0f0}
.pill.medallion{background:#fbf3da;color:#8a6d12;border-color:#eddfae}
.pill.money{background:#e9f5f0;color:#1f6b54;border-color:#c9e7dc}
.pill.trophy,.pill.other{background:#eef0f2;color:#555;border-color:#dfe2e6}
.muted{color:var(--muted)} .right{text-align:right}
.inactive{opacity:.5}

/* ---- assignment grid ---- */
.gridscroll{overflow:auto; border:1px solid var(--line); border-radius:12px; box-shadow:var(--shadow);
  background:var(--paper)}
table.matrix{border-collapse:separate; border-spacing:0; font-size:13px}
table.matrix th.sticky{position:sticky; left:0; z-index:3; background:#faf6ec; min-width:190px}
table.matrix thead th{position:sticky; top:0; z-index:2; background:#faf6ec;
  white-space:nowrap; height:150px}
table.matrix thead th .rot{transform:rotate(-60deg); transform-origin:left bottom;
  display:inline-block; width:20px; margin-left:14px; font-weight:600; color:var(--navy)}
table.matrix td{text-align:center; border-bottom:1px solid var(--line); border-right:1px solid #f0ead9; padding:0}
table.matrix td.namecell{position:sticky; left:0; background:var(--paper); text-align:left;
  padding:8px 10px; font-weight:600; z-index:1; min-width:190px}
table.matrix td.namecell small{display:block; font-weight:400; color:var(--muted)}
.cell{width:100%; height:36px; border:0; background:transparent; cursor:pointer; font-size:15px}
.cell.on{background:var(--gold); color:var(--navy); font-weight:700}
.cell:hover{background:#f4ead2}
.cell.on:hover{background:var(--gold-soft)}
.rowtot{font-weight:700; color:var(--navy); background:#faf6ec}

/* ---- print ---- */
.printbar{margin-bottom:18px}
@media print{
  header.top,nav.main,.printbar,.noprint{display:none!important}
  body{background:#fff} main{padding:0}
  .card{box-shadow:none;border:none;page-break-inside:avoid}
}
/* certificate sheets */
.cert{background:#fff; border:2px solid var(--navy); padding:42px; margin:0 0 24px;
  text-align:center; position:relative; page-break-inside:avoid}
.cert::after{content:""; position:absolute; inset:10px; border:1px solid var(--gold); pointer-events:none}
.cert .org{font-size:12px; letter-spacing:.22em; text-transform:uppercase; color:var(--gold); font-weight:700}
.cert .pres{margin:18px 0 6px; color:var(--muted); font-style:italic}
.cert .name{font-family:"Fraunces",serif; font-size:34px; color:var(--navy); margin:4px 0}
.cert .for{margin:10px 0 4px; color:var(--muted)}
.cert .title{font-family:"Fraunces",serif; font-size:24px; color:var(--gold); margin:2px 0 10px}
.cert .school{color:var(--muted); font-size:14px}
@media print{.cert{page-break-after:always; margin:0}}

/* ---- account / auth chrome ---- */
nav.main a.account{display:inline-flex;align-items:center;gap:7px;background:var(--navy-2);color:#fff;
  padding:5px 12px;border-radius:999px;margin-left:6px}
nav.main a.account img{width:22px;height:22px;border-radius:50%;object-fit:cover}
.actingbar{background:#3a2c10;color:#f3e2b8;border-bottom:2px solid var(--gold);
  display:flex;align-items:center;justify-content:center;gap:14px;padding:8px 16px;font-size:14px}
.actingbar strong{color:#fff}

/* ---- login / no-access ---- */
.authwrap{max-width:440px;margin:9vh auto;padding:0 22px;text-align:center}
.authcard{background:var(--paper);border:1px solid var(--line);border-radius:16px;
  padding:40px 34px;box-shadow:var(--shadow)}
.authcard .seal{display:inline-grid;place-items:center;width:54px;height:54px;border-radius:50%;
  border:2px solid var(--gold-soft);color:var(--gold);font-size:24px;margin-bottom:14px}
.authcard h1{font-size:26px;color:var(--navy);margin:0 0 6px}
.authcard p{color:var(--muted);margin:0 0 22px}
.authcard p.tagline{font-family:'Fraunces',serif;font-size:15px;color:var(--navy);margin:0 0 18px;line-height:1.4}
.gbtn{display:inline-flex;align-items:center;gap:10px;background:#fff;color:#3c4043;
  border:1px solid #dadce0;border-radius:8px;padding:11px 18px;font-weight:600;font-size:15px;
  text-decoration:none}
.gbtn:hover{background:#f7f8f8;box-shadow:0 1px 3px rgba(60,64,67,.15)}
.gbtn svg{width:18px;height:18px}
.authnote{margin-top:18px;font-size:13px;color:var(--muted)}
.badge-pending{display:inline-block;background:#fbf3da;color:#8a6d12;border:1px solid #eddfae;
  padding:2px 9px;border-radius:999px;font-size:12px;font-weight:600}

/* ---- super admin ---- */
.statusdot{display:inline-block;padding:2px 9px;border-radius:999px;font-size:12px;font-weight:600;border:1px solid}
.statusdot.approved{background:#eaf3ee;color:#2f7d5b;border-color:#cce4d6}
.statusdot.pending{background:#fbf3da;color:#8a6d12;border-color:#eddfae}
.statusdot.denied{background:#fbeae5;color:#a8432f;border-color:#e7c4ba}
