:root{
  --bg:#1B1612; --bg-raised:#231C17; --bg-card:#1F1915; --bg-well:#17120E;
  --fg:#EFE6D6; --fg-muted:rgba(239,230,214,.65); --fg-dim:rgba(239,230,214,.28);
  --terracotta:#D88A5C; --terra-10:rgba(216,138,92,.10); --terra-18:rgba(216,138,92,.18);
  --gold:#C9961A; --gold-bright:#E0AB2A;
  --rule:rgba(239,230,214,.08); --rule-strong:rgba(239,230,214,.16);
  --green:#7FB069; --red:#D9705B;
  --font-display:'Lora',Georgia,'Times New Roman',serif;
  --font-text:'Inter',-apple-system,BlinkMacSystemFont,system-ui,sans-serif;
  --r-sm:6px; --r-md:10px; --r-lg:14px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:
    radial-gradient(1200px 600px at 80% -10%, var(--terra-10), transparent 60%),
    var(--bg);
  color:var(--fg); font-family:var(--font-text); font-weight:400;
  line-height:1.6; -webkit-font-smoothing:antialiased; min-height:100vh;
}
a{color:var(--terracotta);text-decoration:none}
a:hover{color:var(--gold-bright)}
h1,h2,h3{font-family:var(--font-display);font-weight:600;line-height:1.15;margin:0 0 .4em}
.wrap{max-width:1040px;margin:0 auto;padding:0 24px}
.eyebrow{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--fg-dim);font-weight:600}

/* top bar */
.topbar{display:flex;align-items:center;justify-content:space-between;
  padding:16px 24px;border-bottom:1px solid var(--rule);position:sticky;top:0;
  background:rgba(27,22,18,.86);backdrop-filter:blur(8px);z-index:50}
.brand{display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-size:18px;color:var(--fg)}
.brand .mark{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;
  background:var(--terra-18);border:1px solid var(--terra-18);color:var(--terracotta);font-style:italic;font-size:16px}
.brand .sub{color:var(--terracotta);font-style:italic}
.topbar .who{font-size:13px;color:var(--fg-muted);display:flex;align-items:center;gap:14px}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-text);font-weight:600;
  font-size:14px;padding:10px 18px;border-radius:var(--r-sm);border:1px solid transparent;cursor:pointer;
  transition:.15s;text-decoration:none}
.btn-primary{background:var(--terracotta);color:#231811;border-color:var(--terracotta)}
.btn-primary:hover{background:var(--gold-bright);border-color:var(--gold-bright);color:#231811}
.btn-ghost{background:transparent;color:var(--fg);border-color:var(--rule-strong)}
.btn-ghost:hover{border-color:var(--terracotta);color:var(--terracotta)}
.btn-sm{padding:7px 12px;font-size:13px}
.btn-link{background:none;border:none;color:var(--fg-muted);cursor:pointer;font:inherit;padding:0}
.btn-link:hover{color:var(--terracotta)}

/* auth card */
.auth-shell{min-height:100vh;display:grid;place-items:center;padding:32px}
.auth-card{width:100%;max-width:400px;background:var(--bg-card);border:1px solid var(--rule);
  border-radius:var(--r-lg);padding:36px 32px;box-shadow:0 30px 80px rgba(0,0,0,.45)}
.auth-card h1{font-size:26px;margin-bottom:6px}
.auth-card .lede{color:var(--fg-muted);font-size:14px;margin:0 0 26px}
.field{margin-bottom:16px}
.field label{display:block;font-size:12px;letter-spacing:.04em;color:var(--fg-muted);margin-bottom:6px}
.field input{width:100%;padding:11px 13px;border-radius:var(--r-sm);border:1px solid var(--rule-strong);
  background:var(--bg-well);color:var(--fg);font:inherit}
.field input:focus{outline:none;border-color:var(--terracotta);box-shadow:0 0 0 3px var(--terra-10)}
.alert{background:rgba(217,112,91,.12);border:1px solid rgba(217,112,91,.4);color:#F0B6A6;
  padding:10px 13px;border-radius:var(--r-sm);font-size:13px;margin-bottom:18px}
.notice{background:var(--terra-10);border:1px solid var(--terra-18);color:var(--fg);
  padding:12px 15px;border-radius:var(--r-sm);font-size:13.5px;margin-bottom:20px}
.notice code{background:var(--bg-well);padding:2px 7px;border-radius:4px;color:var(--gold-bright);font-size:13px}

/* page */
main.page{padding:40px 0 80px}
.page-head{margin-bottom:30px}
.page-head h1{font-size:30px}
.page-head p{color:var(--fg-muted);margin:0}

/* module list */
.mods{display:flex;flex-direction:column;gap:12px;margin-top:8px}
.mod{display:grid;grid-template-columns:46px 1fr auto;gap:18px;align-items:center;
  background:var(--bg-card);border:1px solid var(--rule);border-radius:var(--r-md);padding:18px 20px}
.mod.locked{opacity:.5}
.mod .n{font-family:var(--font-display);font-size:22px;color:var(--terracotta)}
.mod .t{font-family:var(--font-display);font-size:19px}
.mod .s{font-size:13px;color:var(--fg-muted)}
.mod .actions{display:flex;align-items:center;gap:10px}
.badge{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;
  padding:4px 9px;border-radius:100px;border:1px solid var(--rule-strong);color:var(--fg-muted)}
.badge.completed{color:var(--green);border-color:rgba(127,176,105,.4);background:rgba(127,176,105,.1)}
.badge.in_progress{color:var(--gold-bright);border-color:rgba(224,171,42,.4);background:rgba(224,171,42,.1)}
.badge.available{color:var(--terracotta);border-color:var(--terra-18);background:var(--terra-10)}

.locked-note{background:var(--bg-card);border:1px dashed var(--rule-strong);border-radius:var(--r-md);
  padding:26px;text-align:center;color:var(--fg-muted)}

/* table */
.tablewrap{overflow-x:auto;border:1px solid var(--rule);border-radius:var(--r-md);background:var(--bg-card)}
table{width:100%;border-collapse:collapse;font-size:14px;min-width:760px}
th,td{padding:12px 14px;text-align:left;border-bottom:1px solid var(--rule);white-space:nowrap}
th{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--fg-dim);font-weight:600}
tr:last-child td{border-bottom:none}
td .muted{color:var(--fg-muted)}
td form{display:inline}
.pill{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding:3px 9px;border-radius:100px}
.pill.paid{color:var(--green);background:rgba(127,176,105,.12)}
.pill.pending{color:var(--gold-bright);background:rgba(224,171,42,.12)}
.pill.refunded{color:var(--red);background:rgba(217,112,91,.12)}
.foot{margin-top:50px;color:var(--fg-dim);font-size:12px;text-align:center}
.tabs{display:flex;gap:8px;margin-bottom:24px}
.tabs a{font-size:13px;padding:7px 14px;border-radius:100px;border:1px solid var(--rule-strong);color:var(--fg-muted)}
.tabs a.active{color:var(--terracotta);border-color:var(--terra-18);background:var(--terra-10)}
