/* License Verification Server dashboard — "Notary Seal" theme. Author: Jeremiah Buttler */
:root{
  /* 8pt spacing scale */
  --s1:4px; --s2:8px; --s3:12px; --s4:16px; --s5:20px; --s6:24px; --s8:32px;
  --radius:12px; --radius-sm:8px; --radius-pill:999px;

  /* surfaces — faintly warm "paper" */
  --bg:#f3f1ef; --surface:#ffffff; --line:#e7e2dd; --border:#d9d3cc;
  --input:#faf8f6; --btn:#ece8e4; --btn-hover:#ddd7d0;

  /* brand */
  --accent:#c0272d; --accent2:#8f0000;
  --gold:#e8b04b; --gold-deep:#a9791f;

  /* ink */
  --fg:#1f1b18; --fg-white:#ffffff; --dim:#6b635c;

  --success:#2a7a4a; --warning:#d97706;
  --shadow:0 1px 2px rgba(31,27,24,.06), 0 6px 16px rgba(31,27,24,.06);
}
*{box-sizing:border-box}
body{margin:0;font-family:"Segoe UI",system-ui,Arial,sans-serif;
  background:var(--bg);color:var(--fg);line-height:1.5}
a{color:var(--accent2);text-decoration:none}
a:hover{text-decoration:underline}
code{font-family:"Cascadia Code",Consolas,monospace;font-size:.88em;
  background:#ede9e5;border-radius:3px;padding:1px 5px}
code.dim{color:var(--dim);font-size:.85em}

/* ---- top chrome: a wax-seal banner ---- */
.topbar{display:flex;align-items:center;justify-content:space-between;
  background:linear-gradient(180deg,#c0272d 0%,#a81f25 100%);color:#fff;
  padding:0 var(--s6);height:56px;border-bottom:3px solid var(--gold)}
.topbar .brand{display:flex;align-items:center;gap:var(--s3);
  color:#fff;text-decoration:none}
.topbar .brand:hover{text-decoration:none}
.topbar .brand .seal{width:30px;height:30px;display:block;flex-shrink:0;
  filter:drop-shadow(0 1px 1px rgba(0,0,0,.25))}
.topbar .brand-text{display:flex;flex-direction:column;line-height:1.15}
.topbar .brand-name{font-weight:700;font-size:1.05rem;letter-spacing:.01em;line-height:1.2}
.topbar .brand-url{font-size:.65rem;font-weight:400;
  color:rgba(255,255,255,.62);letter-spacing:.02em;line-height:1}
.topbar-user{display:flex;align-items:center;gap:var(--s4)}
.topbar-user .username-link{color:#fde68a;font-weight:600;font-size:.85rem;
  opacity:.95;border-bottom:1px solid transparent}
.topbar-user .username-link:hover{opacity:1;text-decoration:none;
  border-bottom-color:#fde68a}
.topbar-user .logout{color:#fff;opacity:.78;font-size:.85rem}
.topbar-user .logout:hover{opacity:1;text-decoration:none}

/* ---- sidebar layout ---- */
.app-body{display:flex;min-height:calc(100vh - 56px)}
.sidebar{width:180px;background:#1a1210;flex-shrink:0;padding:8px 0}
.sidebar-section{font-size:.62rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.08em;color:#5a4a44;padding:12px 16px 4px;margin-top:4px}
.sidebar-section:first-child{margin-top:0;padding-top:10px}
.sidebar a{display:block;padding:8px 16px;font-size:.84rem;
  color:#c8bdb8;text-decoration:none;transition:background .12s;
  border-left:3px solid transparent;line-height:1.3}
.sidebar a:hover{background:rgba(255,255,255,.07);color:#fff;text-decoration:none}
.sidebar a.active{background:rgba(192,39,45,.18);color:#fff;border-left-color:var(--gold)}
.content-area{flex:1;min-width:0;display:flex;flex-direction:column}

.wrap{max-width:1000px;margin:var(--s6) auto var(--s8);padding:0 var(--s5)}
.breadcrumb{font-size:.82rem;color:var(--dim);margin-bottom:var(--s3)}
.breadcrumb a{color:var(--dim);border-bottom:1px solid var(--border);text-decoration:none}
.breadcrumb a:hover{color:var(--accent2);border-bottom-color:var(--accent2);text-decoration:none}
.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--s5);align-items:start}
h1{font-size:1.6rem;font-weight:700;margin:0 0 var(--s5);letter-spacing:-.01em}
h2{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;
  margin:0 0 var(--s4);color:var(--dim)}
h3{font-size:.97rem;font-weight:600;margin:var(--s5) 0 var(--s2);
  color:var(--fg);letter-spacing:-.005em}
h3:first-child{margin-top:0}
.muted{color:var(--dim)}
.error{color:var(--accent);font-weight:600}

.card{background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius);padding:var(--s6);margin-bottom:var(--s6);
  box-shadow:var(--shadow)}

/* ---- stat tiles ---- */
.stats{display:flex;gap:var(--s4);margin-bottom:var(--s6);flex-wrap:wrap}
.stat{flex:1;min-width:120px;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius);padding:var(--s5);text-align:left;
  box-shadow:var(--shadow);position:relative;overflow:hidden}
.stat::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;
  background:var(--gold)}
.stat .num{display:block;font-size:2rem;font-weight:700;line-height:1.1;
  color:var(--accent)}
.stat span:last-child{color:var(--dim);font-size:.74rem;text-transform:uppercase;
  letter-spacing:.06em}
/* tiles that link to a detail page */
a.stat{display:block;text-decoration:none;color:inherit;
  transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease}
a.stat:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg,0 6px 20px rgba(0,0,0,.18));
  border-color:var(--gold)}
a.stat:focus-visible{outline:2px solid var(--gold);outline-offset:2px}

table{width:100%;border-collapse:collapse}
th,td{text-align:left;padding:var(--s3) var(--s3);border-bottom:1px solid var(--line);
  vertical-align:top}
thead th{font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;color:var(--dim)}
tbody tr:hover{background:#faf8f6}
tr.inactive{opacity:.5}
table.kv th{width:150px;color:var(--dim);font-weight:600}

label{display:block;font-size:.78rem;font-weight:600;color:var(--dim);
  margin-bottom:var(--s1);text-transform:uppercase;letter-spacing:.03em}
input,select{width:100%;padding:10px var(--s3);background:var(--input);
  border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--fg);
  font-size:.95rem}
input:focus,select:focus{outline:none;border-color:var(--accent);
  box-shadow:0 0 0 3px rgba(192,39,45,.12)}

.grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--s4) var(--s4);align-items:end}
.grid .wide{grid-column:1 / -1}
.grid .full-row{grid-column:1 / -1}
.grid button{grid-column:1 / -1}
.grid textarea{width:100%;padding:10px var(--s3);background:var(--input);
  border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--fg);
  font-size:.95rem;font-family:inherit;resize:vertical}
.grid .check-row{display:flex;align-items:center}
.grid .check-row label{display:flex;align-items:center;gap:var(--s2);
  font-weight:500;cursor:pointer}
.grid .check-row input{width:auto;margin:0}

/* ---- search / filter bar ---- */
.filter-bar{display:grid;grid-template-columns:repeat(4,1fr);
  gap:var(--s3) var(--s4);align-items:end}
.filter-bar .filter-actions{display:flex;gap:var(--s3);align-items:center}
.btn-link{color:var(--accent);text-decoration:none;font-size:.9rem;font-weight:600}
.btn-link:hover{text-decoration:underline}
.form-hint{font-size:.88rem;color:var(--dim);margin-bottom:var(--s3)}
.card-head-row{display:flex;justify-content:space-between;align-items:center}
@media(max-width:760px){.filter-bar{grid-template-columns:1fr 1fr}}

button{padding:10px var(--s4);border:1px solid var(--border);
  border-radius:var(--radius-sm);background:var(--btn);color:var(--fg);
  font-size:.92rem;font-weight:600;cursor:pointer;transition:background .12s}
button:hover{background:var(--btn-hover)}
button.primary{background:var(--accent);color:var(--fg-white);border-color:var(--accent2)}
button.primary:hover{background:var(--accent2)}
button.danger{background:var(--accent);color:#fff;border-color:var(--accent2)}
button.link-danger{background:none;border:none;color:var(--accent);padding:0;cursor:pointer}
button.link-danger:hover{text-decoration:underline;background:none}

.actions{display:flex;gap:var(--s3);margin-top:var(--s4);flex-wrap:wrap;align-items:center}
.actions form{margin:0}

.badge{display:inline-block;padding:3px 10px;border-radius:var(--radius-pill);
  font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em}
.badge.active{background:#e3f4ea;color:var(--success)}
.badge.revoked{background:#fbe3e3;color:var(--accent2)}
.badge.suspended{background:#fff0d9;color:var(--warning)}
.badge.trial{background:#fdf2db;color:var(--gold-deep)}

/* ---- Store hub: link-style segmented-pill tab strip ---- */
.hub-tabs{display:inline-flex;gap:2px;background:var(--btn);padding:4px;
  border-radius:var(--radius-pill);margin-bottom:var(--s5);flex-wrap:wrap}
.hub-tab{padding:7px 18px;font-size:.88rem;font-weight:600;color:var(--dim);
  border-radius:var(--radius-pill);text-decoration:none;
  transition:background .12s,color .12s}
.hub-tab:hover{color:var(--fg);text-decoration:none}
.hub-tab.active{background:var(--surface);color:var(--accent);
  box-shadow:0 1px 3px rgba(0,0,0,.1)}
.hub-tab:focus-visible{outline:2px solid var(--accent);outline-offset:2px}

/* ---- sign-in ---- */
.login-card{max-width:360px;margin:8vh auto;background:var(--surface);
  border:1px solid var(--line);border-radius:var(--radius);
  padding:var(--s8) var(--s6);box-shadow:var(--shadow);text-align:center}
.login-card .seal{width:64px;height:64px;display:block;margin:0 auto var(--s4);
  filter:drop-shadow(0 2px 4px rgba(143,0,0,.2))}
.login-card h1{font-size:1.3rem;color:var(--accent);margin:0 0 var(--s1)}
.login-card .slogan{color:var(--gold-deep);font-size:.78rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.08em;margin:0 0 var(--s5)}
.login-card form{margin-top:var(--s4);text-align:left}
.login-card label{text-align:left}
.login-card button{width:100%;margin-top:var(--s4)}

/* ---- user management + profile ---- */
.role-badge{display:inline-block;padding:2px 8px;border-radius:var(--radius-pill);
  font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em}
.role-badge.admin{background:#fde8e8;color:var(--accent2)}
.role-badge.viewer{background:#e8f0fd;color:#33408f}
.user-form{display:flex;gap:var(--s3);flex-wrap:wrap;align-items:flex-end}
.user-form input,.user-form select{width:auto;min-width:140px}
.inline-form{display:inline}
.success{color:var(--success);font-weight:600}
.profile-card{max-width:640px}
.error-box{background:#fbe3e3;border-radius:var(--radius-sm);padding:var(--s3) var(--s4)}
.forgot-link{color:var(--dim);font-size:.82rem}
.forgot-link:hover{color:var(--accent2)}

/* ---- feature list ---- */
.feature-groups{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));
  gap:var(--s5)}
.feature-card{margin-bottom:0}
.feature-card h2{display:flex;align-items:center;gap:var(--s2)}
.feature-card h2::before{content:"";width:10px;height:10px;border-radius:2px;
  background:var(--gold);transform:rotate(45deg)}
.feature-list{list-style:none;margin:0;padding:0}
.feature-list li{padding:var(--s2) 0;border-top:1px solid var(--line);
  font-size:.9rem;line-height:1.45;color:var(--dim)}
.feature-list li:first-child{border-top:none}
.feature-list li strong{color:var(--fg);font-weight:600}

/* ---- project log ---- */
.log-brief.card{max-width:860px}
.log-entries{display:flex;flex-direction:column;gap:0}
.log-entry.card{margin-bottom:var(--s4)}
.log-entry-header{display:flex;align-items:baseline;gap:var(--s3);margin-bottom:var(--s3)}
.log-date{font-size:.72rem;font-weight:700;color:var(--dim);text-transform:uppercase;
  letter-spacing:.05em;white-space:nowrap}
.log-title{font-size:1rem;font-weight:700;color:var(--fg)}
.log-detail{margin:0;display:grid;grid-template-columns:max-content 1fr;gap:var(--s1) var(--s4)}
.log-detail dt{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;
  color:var(--dim);padding-top:3px;white-space:nowrap}
.log-detail dd{margin:0;font-size:.9rem;color:var(--dim);line-height:1.5}
.log-detail dd strong{color:var(--fg)}

/* ---- financial / revenue ---- */
.stat--money .num{color:var(--success);font-size:1.6rem}

/* bar chart — pure CSS horizontal bars */
.bar-chart{display:flex;flex-direction:column;gap:6px;margin-top:var(--s3)}
.bar-row{display:grid;grid-template-columns:60px 1fr 80px;gap:var(--s3);align-items:center}
.bar-label{font-size:.72rem;color:var(--dim);text-align:right;white-space:nowrap}
.bar-track{background:var(--line);border-radius:var(--radius-pill);height:14px;overflow:hidden}
.bar-fill{height:100%;background:var(--gold);border-radius:var(--radius-pill);
  transition:width .3s ease;min-width:2px}
.bar-fill.bar-fill--accent{background:var(--accent)}
.bar-value{font-size:.78rem;color:var(--fg);font-weight:600}

.fin-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--s5);align-items:start}

.foot{text-align:center;color:var(--dim);font-size:.75rem;padding:var(--s6) 0;
  border-top:1px solid var(--line);margin-top:auto}
.foot a{color:var(--dim);text-decoration:underline}
.foot a:hover{color:var(--accent)}

/* Terms & Conditions / legal pages */
.legal-doc{max-width:46rem;margin:0 auto}
.legal-doc>p{color:var(--fg);line-height:1.6}
.legal-section{margin-bottom:var(--s8);padding-top:var(--s5);border-top:1px solid var(--line)}
.legal-section:first-of-type{border-top:none;padding-top:0}
.legal-section h2{margin-top:0;font-size:1.05rem;color:var(--accent)}
.legal-section p{line-height:1.6;margin:var(--s2) 0}
.legal-section ul{margin:var(--s2) 0;padding-left:1.2rem;line-height:1.55}
.legal-section li{margin:.25rem 0}
.terms-accept{display:flex;gap:var(--s2);align-items:flex-start;
  font-size:.85rem;color:var(--fg);line-height:1.5;margin:var(--s3) 0}
.terms-accept input{margin-top:.2rem;flex:0 0 auto}

/* Caps Lock warning shown by password fields (see capslock.js) */
.caps-warn{display:flex;align-items:center;gap:6px;margin-top:var(--s2);
  font-size:.8rem;font-weight:600;color:var(--accent)}
.caps-warn[hidden]{display:none}

/* ---- responsive / mobile ---- */

/* 768px — sidebar collapses to horizontal scrollable strip; tables gain scroll */
@media(max-width:768px){
  .app-body{flex-direction:column}
  .sidebar{width:100%;flex-direction:row;display:flex;overflow-x:auto;
    white-space:nowrap;border-bottom:1px solid #3a2820;padding:0}
  .sidebar-section{display:none}
  .sidebar a{display:inline-block;border-left:none;
    border-bottom:3px solid transparent;padding:10px 14px}
  .sidebar a.active{border-bottom-color:var(--gold);border-left:none;background:none}
  .card{overflow-x:auto}
  table{min-width:480px}
  .card-head-row{flex-wrap:wrap;gap:var(--s3)}
}

/* 540px — log detail grid stacks label above value */
@media(max-width:540px){
  .log-detail{grid-template-columns:1fr}
  .log-detail dt{padding-top:var(--s3)}
  .log-detail dt:first-child{padding-top:0}
}

/* Error pages (403, 404) */
.error-page{display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:var(--s6) var(--s4);min-height:40vh}
.error-code{font-size:5rem;font-weight:700;color:var(--accent);line-height:1}
.error-page h1{margin:var(--s3) 0 var(--s2)}
.error-page p{color:var(--muted);margin-bottom:var(--s5)}
.error-home-btn{display:inline-block;padding:10px var(--s5);background:var(--accent);
  color:var(--fg-white);border-radius:4px;text-decoration:none;font-weight:600}
.error-home-btn:hover{background:var(--accent2)}

/* 480px — form grids collapse to single column; login card gets margin; topbar trimmed */
@media(max-width:480px){
  .grid{grid-template-columns:1fr}
  .grid .wide,.grid .full-row{grid-column:1}
  .detail-grid{grid-template-columns:1fr}
  .fin-grid{grid-template-columns:1fr}
  .filter-bar{grid-template-columns:1fr}
  .login-card{margin-left:var(--s4);margin-right:var(--s4)}
  .topbar .brand-url{display:none}
  .topbar-user .username-link{display:none}
}
