/* ==========================================================================
   GEOMINE 2026 — main stylesheet
   Loaded on every page via base.html. Page-specific tweaks should be added
   here (with semantic class names) rather than inlined in templates.
   ========================================================================== */

/* ---- Variables & reset ---- */
:root{
  --purple:#2d0a5b;
  --gold:#f3be27;
  --gold2:#d9a10b;
  --ink:#1d2433;
  --muted:#667085;
  --line:#dfe4ec;
  --bg:#f6f8fb;
  --shadow:0 12px 34px rgba(21,17,50,.09);
  --green:#027a48;
  --green-bg:#ecfdf3;
  --green-border:#abefc6;
  --red:#b42318;
  --red-bg:#fef3f2;
  --red-border:#fecdca;
  --amber:#b54708;
  --amber-bg:#fffaeb;
  --amber-border:#fde7a3;
  --blue:#175cd3;
  --blue-bg:#eff8ff;
}
*{box-sizing:border-box}
body{margin:0;font-family:Arial,Helvetica,sans-serif;background:var(--bg);color:var(--ink);line-height:1.6}
a{text-decoration:none;color:var(--purple)}

/* ---- Layout primitives ---- */
.container{width:min(100% - 32px,1180px);margin:auto}
section{padding:36px 0}
.divider{margin:18px 0;border:0;border-top:1px solid var(--line)}
.text-center{text-align:center}
.muted{color:var(--muted)}

/* ---- Topbar / header / nav ---- */
.topbar{background:var(--purple);color:#fff;padding:10px 0;font-size:13px}
.topbar .container,.header-inner{display:flex;gap:14px;flex-wrap:wrap;align-items:center;justify-content:space-between}
.header{background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:10}
.header-inner{padding:16px 0}
.brand{display:flex;align-items:center;gap:12px}
.brand img{height:42px;width:auto;display:block}
.brand-text strong{display:block;color:var(--purple);font-size:26px;line-height:1.1}
.brand-text span{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.1em}
.nav a{font-weight:700;color:#344054;font-size:14px;margin-left:14px}
.nav a:hover{color:var(--gold2)}

/* ---- Buttons ---- */
.btn{display:inline-block;border:0;border-radius:999px;padding:11px 16px;font-weight:800;cursor:pointer;font-size:14px;text-align:center}
.btn-primary{background:var(--gold);color:#241a0a}
.btn-secondary{background:#fff;color:var(--purple);border:1px solid var(--line)}
.btn-danger{background:var(--red-bg);color:var(--red);border:1px solid var(--red-border)}
.btn-green{background:var(--green-bg);color:var(--green);border:1px solid var(--green-border)}
.btn-block{display:block;width:100%}
.btn-sm{padding:7px 12px;font-size:12px}

/* ---- Page hero ---- */
.page-hero{background:linear-gradient(180deg,#f6f2ff,#f7f9fc);border-bottom:1px solid var(--line);padding:38px 0 30px}
.page-hero h1{margin:6px 0 10px;color:var(--purple);font-size:clamp(30px,4vw,46px)}
.page-hero p{margin:0;color:var(--muted);max-width:850px}
.breadcrumbs{font-size:14px;color:var(--muted)}

/* ---- Cards & form scaffolding ---- */
.card,.form-card,.panel{background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);padding:28px}
.form-card{max-width:520px;margin:auto}
h2,h3{color:var(--purple)}

label{display:block;font-weight:700;color:var(--purple);font-size:14px;margin-bottom:6px}
input,textarea,select{width:100%;padding:11px 12px;border:1px solid var(--line);border-radius:12px;font:inherit;background:#fff}
textarea{min-height:120px}
.field{margin-bottom:16px}
.help{font-size:12px;color:var(--muted);margin-top:4px}
.errorlist{color:var(--red);font-size:13px;list-style:none;padding:0;margin:6px 0}

/* ---- Messages ---- */
.messages{list-style:none;padding:0;margin:0 0 18px 0}
.messages li{background:var(--green-bg);color:var(--green);border:1px solid var(--green-border);border-radius:12px;padding:12px 16px;margin-bottom:8px}
.messages .error,.messages .warning{background:var(--red-bg);color:var(--red);border-color:var(--red-border)}

/* ---- Footer ---- */
.footer{background:var(--purple);color:#fff;margin-top:48px;padding:34px 0}
.footer p{color:rgba(255,255,255,.85);margin:0}

/* ---- KPI / stat grid ---- */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;margin-bottom:22px}
.kpi-card{background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);padding:22px;text-align:center}
.kpi-num{font-size:28px;font-weight:800;color:var(--purple)}
.kpi-label{color:var(--muted)}

/* ---- Status pills ---- */
.pill{display:inline-block;border-radius:999px;padding:5px 10px;font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.04em}
.pill-green{background:var(--green-bg);color:var(--green);border:1px solid var(--green-border)}
.pill-red{background:var(--red-bg);color:var(--red);border:1px solid var(--red-border)}
.pill-amber{background:var(--amber-bg);color:var(--amber);border:1px solid var(--amber-border)}
.pill-blue{background:var(--blue-bg);color:var(--blue)}

/* ---- Tables (cards-with-table pattern) ---- */
.table-card{background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);overflow:auto;padding:0}
.table-card table{width:100%;border-collapse:collapse}
.table-card th{background:#faf5e6;color:var(--purple);font-size:12px;text-transform:uppercase;letter-spacing:.08em;padding:13px 15px;text-align:left}
.table-card td{padding:13px 15px;border-top:1px solid var(--line);font-size:14px}
.table-card .empty{padding:40px;text-align:center;color:var(--muted)}

/* ---- Inline tables (no card wrapper, e.g. co-author formset) ---- */
.inline-table{width:100%;border-collapse:collapse}
.inline-table th{background:#faf5e6;color:var(--purple);font-size:12px;text-transform:uppercase;letter-spacing:.08em;padding:8px;text-align:left}
.inline-table td{padding:8px;border-top:1px solid var(--line);vertical-align:top}

/* ---- Submissions: dashboard top bar ---- */
.toolbar{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;margin-bottom:18px}

/* ---- Submissions: detail two-column ---- */
.detail-grid{display:grid;grid-template-columns:2fr 1fr;gap:22px}
@media (max-width:900px){.detail-grid{grid-template-columns:1fr}}

/* ---- Author payment-status text ---- */
.txt-green{color:var(--green);font-weight:700}
.txt-amber{color:var(--amber);font-weight:700}

/* ---- Review form (Appendix H) ---- */
.meta-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;margin-bottom:18px}
.meta{background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px}
.meta strong{display:block;color:var(--gold2);font-size:12px;text-transform:uppercase;letter-spacing:.08em;margin-bottom:4px}
.meta .v{font-weight:700;color:var(--ink)}
.score-row{display:grid;grid-template-columns:2fr repeat(4,1fr);gap:10px;align-items:center;border-bottom:1px solid var(--line);padding:12px 0}
.check-row{display:grid;grid-template-columns:2fr 1fr 1fr;gap:10px;align-items:center;border-bottom:1px solid var(--line);padding:12px 0}
.criterion{font-weight:700;color:var(--ink)}
.score-head{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:800;padding-bottom:8px}
.score-head>div{text-align:center}
.score-head>div:first-child{text-align:left}
.radio-cell{display:flex;align-items:center;gap:8px;cursor:pointer;justify-content:center}
.radio-cell input{width:auto;margin:0}
.notice{background:#fff9e8;border:1px solid #f2e0a9;border-radius:18px;padding:18px}
.recommendation-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}
.recommendation-grid label{display:flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px;cursor:pointer;font-weight:700}
.recommendation-grid input{width:auto;margin:0}
@media(max-width:900px){
  .score-row,.check-row{grid-template-columns:1fr}
  .score-head{display:none}
  .radio-cell{justify-content:flex-start}
}

/* ---- User chip with expertise tooltip ----
   DISABLED — currently rendering as plain text.
   To re-enable the hover tooltip, uncomment the block below.

.user-chip{
  position:relative;
  display:inline;
  border-bottom:1px dotted var(--gold2);
  cursor:help;
}
.user-chip-plain{border-bottom-color:var(--line);cursor:default}
.user-chip:hover::after{
  content:attr(data-tooltip);
  position:absolute;
  bottom:calc(100% + 6px);
  left:0;
  background:var(--ink);
  color:#fff;
  padding:8px 12px;
  border-radius:8px;
  font-size:12px;
  font-weight:500;
  line-height:1.4;
  white-space:normal;
  width:max-content;
  max-width:280px;
  z-index:100;
  box-shadow:0 4px 12px rgba(0,0,0,.25);
  pointer-events:none;
}
.user-chip:hover::before{
  content:"";
  position:absolute;
  bottom:100%;
  left:14px;
  border:5px solid transparent;
  border-top-color:var(--ink);
  z-index:100;
  pointer-events:none;
}
*/

/* ---- Misc utilities ---- */
.mt-0{margin-top:0}
.mt-24{margin-top:24px}
.mb-0{margin-bottom:0}
.mb-18{margin-bottom:18px}
.mb-22{margin-bottom:22px}
.actions-right{display:flex;gap:12px;flex-wrap:wrap;justify-content:flex-end}
.whitespace-pre{white-space:pre-wrap}
