/* ======================================================================
   REQUIEM — Requiem Staff Portal
   Shared design system (clean Material-dark, cinematic blurred hero).
   Loaded by templates that {% extends "base.html" %}.
   ====================================================================== */

:root{
  /* Surfaces */
  --bg:#070809;
  --paper:rgba(18,20,26,0.74);          /* translucent card over hero */
  --paper-solid:#15171d;
  --paper-2:#1c1f27;                     /* menus / raised */
  --elev:rgba(255,255,255,0.05);        /* MUI elevation overlay */

  /* Lines */
  --line:rgba(255,255,255,0.08);
  --line-strong:rgba(255,255,255,0.15);

  /* Text */
  --text:#e9ebef;
  --text-dim:#9aa1ab;
  --text-faint:#626974;

  /* Accent (light azure blue) */
  --accent:#6fd6ff;
  --accent-strong:#a6e4ff;
  --accent-soft:rgba(111,214,255,0.32);
  --accent-bg:rgba(111,214,255,0.13);
  --on-accent:#04141d;

  /* Status (MUI palette) */
  --ok:#66bb6a;     --ok-bg:rgba(102,187,106,0.12);
  --warn:#ffa726;   --warn-bg:rgba(255,167,38,0.12);
  --err:#ef5350;    --err-bg:rgba(239,83,80,0.12);

  /* Type */
  --sans:'Roboto','Helvetica','Arial',sans-serif;

  --radius:10px;
  --radius-sm:7px;
  --shadow:0 2px 4px -1px rgba(0,0,0,0.45),0 8px 24px -6px rgba(0,0,0,0.55);
  --shadow-lg:0 12px 40px -8px rgba(0,0,0,0.65);
  --appbar-h:64px;
}

*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
body{
  background:var(--bg);
  color:var(--text);
  font-family:var(--sans);
  font-size:15px;
  line-height:1.6;
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

/* ---------- Cinematic hero background (CSS placeholder) ---------- */
.hero-bg{
  position:fixed; inset:0; z-index:-2; pointer-events:none;
  overflow:hidden; background:#06070e;
}
.hero-bg::before{ /* reference background image, darkened + blurred */
  content:''; position:absolute; inset:-28px;
  background:url('static_images/hero.jpg') center/cover no-repeat;
  filter:brightness(0.34) blur(14px);
}
.hero-bg::after{ /* dim + vignette so content stays legible */
  content:''; position:absolute; inset:0;
  background:
    radial-gradient(120% 100% at 50% 0%, transparent 45%, rgba(0,0,0,0.5) 100%),
    linear-gradient(rgba(4,5,10,0.28), rgba(4,5,10,0.52));
}

/* ---------- App bar ---------- */
.appbar{
  position:fixed; top:0; left:0; right:0; z-index:1100;
  height:var(--appbar-h);
  background:#000;
  background-image:linear-gradient(var(--elev),var(--elev));
  box-shadow:0 2px 4px -1px rgba(0,0,0,0.4),0 4px 14px rgba(0,0,0,0.4);
  backdrop-filter:blur(8px);
}
.appbar-inner{
  max-width:1180px; margin:0 auto; height:100%;
  padding:0 24px; display:flex; align-items:center; gap:18px;
}
.brand{
  font-family:var(--sans); font-weight:600; font-size:15px;
  letter-spacing:0.16em; color:#fff; opacity:0.55;
  text-decoration:none; transition:opacity 0.15s; white-space:nowrap;
}
.brand:hover{opacity:0.92;}
.appbar-spacer{flex:1 1 auto;}
.appbar-tag{
  font-size:12px; color:var(--accent); padding:4px 11px;
  border:1px solid var(--accent-soft); background:var(--accent-bg);
  border-radius:100px; white-space:nowrap;
}

/* ---------- Avatar + menu ---------- */
.menu{position:relative;}
.avatar{
  width:40px; height:40px; border-radius:50%;
  background:#3a404b; color:#fff; border:1px solid var(--line-strong);
  display:flex; align-items:center; justify-content:center;
  font-weight:600; font-size:16px; cursor:pointer; user-select:none;
  transition:background 0.15s,border-color 0.15s;
  overflow:hidden;
}
.avatar:hover{background:#454c58; border-color:var(--accent-soft);}
.avatar-img{width:100%; height:100%; object-fit:cover; border-radius:50%; display:block;}
.menu-panel{
  position:absolute; right:0; top:calc(100% + 10px); min-width:220px;
  background:var(--paper-2); border:1px solid var(--line-strong);
  border-radius:var(--radius); box-shadow:var(--shadow-lg);
  padding:6px; z-index:1200;
  opacity:0; transform:translateY(-6px) scale(0.98); transform-origin:top right;
  pointer-events:none; transition:opacity 0.14s ease,transform 0.14s ease;
}
.menu-panel.open{opacity:1; transform:translateY(0) scale(1); pointer-events:auto;}
.menu-head{
  padding:10px 12px 12px; font-size:12.5px; color:var(--text-faint);
  border-bottom:1px solid var(--line); margin-bottom:6px;
}
.menu-head b{color:var(--text); font-size:14px;}
.menu-item{
  display:block; padding:10px 12px; color:var(--text-dim);
  text-decoration:none; font-size:14px; border-radius:var(--radius-sm);
  transition:background 0.12s,color 0.12s;
}
.menu-item:hover{background:var(--accent-bg); color:var(--text);}
.menu-item.danger{color:var(--err);}
.menu-item.danger:hover{background:var(--err-bg);}
.menu-sep{height:1px; background:var(--line); margin:6px 4px;}

/* ---------- Page container ---------- */
.page{
  position:relative; z-index:1;
  max-width:1180px; margin:0 auto;
  padding:calc(var(--appbar-h) + 40px) 24px 96px;
}
.page.narrow{max-width:780px;}
/* Public/anonymous pages opt out of the staff app bar (see base.html block). */
.page.no-appbar{padding-top:40px;}

/* ---------- Headers ---------- */
.eyebrow{
  display:inline-block; font-size:12px; font-weight:600;
  letter-spacing:0.12em; text-transform:uppercase; color:var(--accent);
  margin-bottom:14px;
}
.page-title{
  font-family:var(--sans); font-weight:600; letter-spacing:-0.02em;
  font-size:clamp(28px,4vw,40px); line-height:1.1; margin:0 0 14px;
}
.page-title .hl{color:var(--accent);}
.lede{color:var(--text-dim); font-size:15.5px; max-width:560px; margin:0 0 38px;}

/* ---------- Panels ---------- */
.panel{
  background:var(--paper);
  backdrop-filter:blur(14px) saturate(118%);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  margin-bottom:26px;
}
.panel-head{
  display:flex; align-items:center; justify-content:space-between; gap:12px;
  padding:16px 22px; border-bottom:1px solid var(--line);
  font-size:14px; font-weight:600; color:var(--text);
}
.panel-head .meta{font-weight:400; font-size:13px; color:var(--text-faint);}
.panel-head .status{font-weight:500; font-size:12.5px; color:var(--ok);}
.panel-head .status::before{content:'●'; margin-right:6px; font-size:9px; vertical-align:middle;}
.panel-body{padding:26px 22px;}

/* ---------- Identity row ---------- */
.who{font-size:14px; color:var(--text-dim); margin-bottom:22px;}
.who b{color:var(--text);}
.who-row{
  padding:12px 15px; border:1px solid var(--line-strong); border-radius:var(--radius-sm);
  background:rgba(0,0,0,0.25); font-size:14px; color:var(--text-dim);
}
.who-row b{color:var(--text);}

/* ---------- Nav cards ---------- */
.card-grid{display:grid; grid-template-columns:repeat(auto-fit,minmax(210px,1fr)); gap:14px;}
a.card{
  display:block; text-decoration:none; color:var(--text);
  padding:20px; border:1px solid var(--line-strong); border-radius:var(--radius);
  background:rgba(0,0,0,0.22); transition:border-color 0.15s,background 0.15s,transform 0.15s;
}
a.card:hover{border-color:var(--accent-soft); background:var(--accent-bg); transform:translateY(-2px);}
a.card .ct{font-size:11px; font-weight:600; letter-spacing:0.1em; text-transform:uppercase; color:var(--accent);}
a.card .ch{font-size:17px; font-weight:600; margin:9px 0 5px;}
a.card .cd{color:var(--text-dim); font-size:13px; line-height:1.5;}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  font-family:var(--sans); font-size:14px; font-weight:600; letter-spacing:0.02em;
  padding:12px 22px; border-radius:var(--radius-sm); cursor:pointer;
  border:1px solid transparent; text-decoration:none; transition:filter 0.15s,background 0.15s,border-color 0.15s;
}
.btn-primary{background:var(--accent); color:var(--on-accent); border-color:var(--accent);}
.btn-primary:hover{filter:brightness(1.08);}
.btn-ghost{background:transparent; color:var(--text-dim); border-color:var(--line-strong);}
.btn-ghost:hover{color:var(--text); border-color:var(--accent-soft);}
.btn-danger{background:transparent; color:var(--err); border-color:var(--err-bg);}
.btn-danger:hover{background:var(--err-bg); border-color:var(--err);}
.btn-block{width:100%;}
.btn:disabled{opacity:0.5; cursor:not-allowed; filter:none;}

.submit-btn{ /* alias kept for form templates */
  width:100%; padding:13px; background:var(--accent); color:var(--on-accent);
  border:1px solid var(--accent); border-radius:var(--radius-sm);
  font-family:var(--sans); font-size:14px; font-weight:600; letter-spacing:0.02em;
  cursor:pointer; transition:filter 0.15s;
}
.submit-btn:hover{filter:brightness(1.08);}

/* ---------- Forms ---------- */
.form-group{margin-bottom:18px;}
label{
  display:block; font-size:13px; font-weight:500; color:var(--text-dim);
  margin-bottom:8px;
}
input[type="text"],input[type="password"],input[type="number"],input[type="date"],
input[type="email"],select,textarea{
  width:100%; padding:11px 13px; font-size:14px; font-family:var(--sans);
  color:var(--text); background:rgba(0,0,0,0.30);
  border:1px solid var(--line-strong); border-radius:var(--radius-sm);
  transition:border-color 0.15s,background 0.15s;
}
input:focus,select:focus,textarea:focus{
  outline:none; border-color:var(--accent); background:rgba(0,0,0,0.45);
}
input[type="date"]::-webkit-calendar-picker-indicator{filter:invert(0.7);}
textarea{resize:vertical; min-height:96px;}
select{appearance:none; -webkit-appearance:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239aa1ab' stroke-width='2'><path d='M6 9l6 6 6-6'/></svg>");
  background-repeat:no-repeat; background-position:right 12px center; padding-right:34px;}
.field-hint{font-size:12.5px; color:var(--text-faint); margin-top:6px;}
.note{font-size:12.5px; color:var(--text-faint); margin:-8px 0 20px;}

/* ---------- Role toggle (event form) ---------- */
.role-toggle{display:flex; gap:10px;}
.role-opt{cursor:pointer; flex:1;}
.role-opt input[type="radio"]{display:none;}
.role-opt span{
  display:block; padding:11px 14px; text-align:center; font-size:14px;
  border:1px solid var(--line-strong); border-radius:var(--radius-sm);
  background:rgba(0,0,0,0.25); color:var(--text-dim); transition:all 0.15s;
}
.role-opt:hover span{border-color:var(--accent-soft); color:var(--text);}
.role-opt input:checked+span{border-color:var(--accent); color:var(--accent); background:var(--accent-bg);}

/* ---------- Image drop zone (event / ticket forms) ---------- */
.image-drop-zone{
  border:1px dashed var(--line-strong); border-radius:var(--radius-sm);
  padding:36px 20px; text-align:center; cursor:pointer; background:rgba(0,0,0,0.22);
  transition:all 0.15s;
}
.image-drop-zone:hover,.image-drop-zone.drag-over{border-color:var(--accent); background:var(--accent-bg);}
.placeholder-text{color:var(--text-dim); pointer-events:none; font-size:13.5px;}
.placeholder-text strong{color:var(--text); font-weight:600;}
.placeholder-icon{font-size:32px; margin-bottom:10px; opacity:0.55;}
#preview-image{max-width:100%; max-height:320px; display:none; margin:0 auto; border-radius:var(--radius-sm);}
/* Visually hidden but still focusable, so the browser can anchor its native
   `required` validation bubble here. display:none makes the control
   "not focusable" and throws an error instead of submitting. */
#image{position:absolute; width:1px; height:1px; opacity:0; overflow:hidden; pointer-events:none;}

/* ---------- Submission "received" pages (event/death/promotion submitted) ---------- */
.eyebrow.ok{color:var(--ok); background:var(--ok-bg); border:1px solid rgba(102,187,106,0.32); padding:4px 11px; border-radius:100px;}
.submitted-body{padding:42px 28px 36px; text-align:center;}
.check-mark{
  width:72px; height:72px; margin:0 auto 24px;
  border:1px solid rgba(102,187,106,0.32); background:var(--ok-bg);
  border-radius:50%; display:flex; align-items:center; justify-content:center;
  animation:popIn 0.45s cubic-bezier(0.175,0.885,0.32,1.275);
}
.check-mark svg{width:32px; height:32px; stroke:var(--ok); stroke-width:2.5; fill:none; stroke-linecap:round; stroke-linejoin:round;}
.check-mark svg path{stroke-dasharray:32; stroke-dashoffset:32; animation:drawCheck 0.5s 0.25s ease-out forwards;}
.submitted-heading{font-size:22px; font-weight:600; letter-spacing:-0.01em; margin:0 0 10px; color:var(--text);}
.submitted-sub{color:var(--text-dim); font-size:14.5px; margin:0 auto 28px; max-width:440px; line-height:1.6;}
.submitted-meta{
  display:inline-flex; gap:8px; align-items:center;
  font-size:12px; color:var(--text-faint); letter-spacing:0.04em;
  padding:6px 12px; border:1px solid var(--line-strong); border-radius:100px;
  background:rgba(0,0,0,0.25); margin-bottom:32px;
}
.submitted-meta .dot{width:6px; height:6px; background:var(--ok); border-radius:50%; animation:pulse 2s infinite;}
.submitted-actions{display:flex; flex-direction:column; gap:10px; max-width:360px; margin:0 auto;}
@keyframes popIn{0%{transform:scale(0); opacity:0;} 80%{transform:scale(1.08);} 100%{transform:scale(1); opacity:1;}}
@keyframes drawCheck{to{stroke-dashoffset:0;}}
@keyframes pulse{0%,100%{opacity:1;} 50%{opacity:0.4;}}

/* ---------- Legal doc pages (privacy / ToS) ---------- */
.doc-updated{font-size:12.5px; color:var(--text-faint); letter-spacing:0.04em; margin-bottom:28px;}
.doc-body h2{font-size:24px; font-weight:600; margin:40px 0 14px; letter-spacing:-0.015em; color:var(--text);}
.doc-body h2:first-child{margin-top:0;}
.doc-body h2::before{content:'// '; color:var(--accent); font-weight:500; font-size:0.78em;}
.doc-body h3{font-size:18px; font-weight:600; margin:28px 0 10px; color:var(--text);}
.doc-body h4{font-size:12px; font-weight:600; text-transform:uppercase; letter-spacing:0.08em; color:var(--accent); margin:22px 0 8px;}
.doc-body p{color:var(--text-dim); margin:0 0 14px; line-height:1.7;}
.doc-body ul{color:var(--text-dim); padding-left:24px; margin:0 0 18px;}
.doc-body li{margin-bottom:9px; line-height:1.65;}
.doc-body li>p{margin:0 0 8px;}
.doc-body strong{color:var(--text); font-weight:600;}
.doc-body a{color:var(--accent); text-decoration:none; border-bottom:1px dashed var(--accent-soft);}
.doc-body a:hover{border-bottom-style:solid;}
.doc-footer{margin-top:32px; padding-top:20px; border-top:1px solid var(--line); display:flex; justify-content:space-between; flex-wrap:wrap; gap:12px; font-size:12px; color:var(--text-faint);}
.doc-footer a{color:var(--text-faint); text-decoration:none; margin-left:14px;}
.doc-footer a:hover{color:var(--accent);}

/* ---------- Tables ---------- */
.table-scroll{overflow-x:auto;}
table{width:100%; border-collapse:collapse; min-width:480px;}
th,td{text-align:left; padding:12px 14px; border-bottom:1px solid var(--line); font-size:13.5px; white-space:nowrap;}
th{
  font-size:12px; font-weight:600; color:var(--text-faint);
  background:rgba(255,255,255,0.02);
}
tbody tr:hover td{background:var(--accent-bg);}
td.reason{white-space:normal; max-width:380px; color:var(--text-dim); font-size:13.5px;}
.num{font-variant-numeric:tabular-nums;}
.username{font-weight:600;}
.empty{padding:30px 18px; text-align:center; color:var(--text-faint); font-size:13.5px;}

/* ---------- Badges / tags ---------- */
.badge{font-size:11.5px; font-weight:500; padding:3px 9px; border-radius:100px; border:1px solid var(--line-strong); color:var(--text-dim);}
.badge-ok{color:var(--ok); border-color:var(--ok); background:var(--ok-bg);}
.badge-warn{color:var(--warn); border-color:var(--warn); background:var(--warn-bg);}
.badge-err{color:var(--err); border-color:var(--err); background:var(--err-bg);}
.tag{
  margin-left:8px; padding:3px 10px; border-radius:100px; font-size:12px;
  color:var(--accent); border:1px solid var(--accent-soft); background:var(--accent-bg);
}

/* ---------- Discord identity cell ---------- */
.dc-user{display:inline-flex; align-items:center; gap:7px;}
.dc-av{width:18px; height:18px; border-radius:50%; object-fit:cover; flex:none; background:var(--paper-2);}

/* ---------- Notices ---------- */
.notice{padding:14px 16px; border:1px solid var(--accent-soft); background:var(--accent-bg); color:var(--accent-strong); border-radius:var(--radius-sm); font-size:14px; margin-bottom:22px;}
.notice-warn{border-color:var(--warn); background:var(--warn-bg); color:var(--warn);}

/* ---------- Flash messages ---------- */
.flashes{margin-bottom:22px; display:flex; flex-direction:column; gap:10px;}
.flash{padding:12px 16px; border-radius:var(--radius-sm); font-size:14px; border:1px solid var(--line-strong); background:var(--paper-solid);}
.flash.success{border-color:var(--ok); background:var(--ok-bg); color:var(--ok);}
.flash.error{border-color:var(--err); background:var(--err-bg); color:var(--err);}

/* ---------- Tabs ---------- */
.tab-nav{display:flex; flex-wrap:wrap; gap:4px; margin-bottom:22px; border-bottom:1px solid var(--line);}
.tab-btn{
  font-family:var(--sans); font-size:14px; font-weight:500;
  padding:11px 18px; background:none; border:none; border-bottom:2px solid transparent;
  color:var(--text-faint); cursor:pointer; transition:color 0.15s,border-color 0.15s; margin-bottom:-1px;
}
.tab-btn:hover{color:var(--text-dim);}
.tab-btn.active{color:var(--accent); border-bottom-color:var(--accent);}
.tab-badge{margin-left:7px; padding:1px 8px; border-radius:100px; font-size:11px; background:var(--accent); color:var(--on-accent);}
.tab-panel{display:none;}
.tab-panel.active{display:block;}

/* ---------- Toasts ---------- */
#toast-wrap{position:fixed; right:20px; bottom:20px; z-index:2000; display:flex; flex-direction:column; gap:10px;}
.toast{
  padding:12px 16px; border-radius:var(--radius-sm); font-size:14px; color:var(--text);
  background:var(--paper-2); border:1px solid var(--line-strong); box-shadow:var(--shadow-lg);
  opacity:0; transform:translateY(10px); transition:opacity 0.2s,transform 0.2s; max-width:340px;
}
.toast.show{opacity:1; transform:translateY(0);}
.toast.success{border-color:var(--ok);}
.toast.error{border-color:var(--err);}

/* ---------- Small util ---------- */
.muted-link{display:inline-block; margin-top:18px; font-size:13px; color:var(--text-faint); text-decoration:none;}
.muted-link:hover{color:var(--accent);}
.del-btn{font-size:12px; font-weight:500; padding:5px 11px; border:1px solid var(--line-strong); border-radius:var(--radius-sm); background:rgba(0,0,0,0.2); color:var(--err); cursor:pointer; transition:border-color 0.15s;}
.del-btn:hover{border-color:var(--err);}
.acts{display:flex; gap:6px; flex-wrap:wrap;}

@media(max-width:640px){
  .appbar-inner,.page{padding-left:16px; padding-right:16px;}
  .panel-body{padding:20px 16px;}
}
