/* CSS Cog: core.css */
/* ================================================================
   FABULA SHEET - Lexicon Theme / Discord Dark Variant
   Author: Steven J. Cook
   Date:   2026-04-22
   Time:   02:15 UTC
   Model:  Claude Opus 4.7
   Chat:   Abyssal Engine Web App Development
   Revision: 2.2.0
   Changes:
     v2.2.0 - Added --bg-main and --bg-card aliases. Multiple CSS
              cogs (combat.css, modals.css, npc.css, tracker.css)
              were using these names but neither was defined in
              :root, so every modal / card using them fell back
              to transparent. That caused the tracker to bleed
              through the character sheet modal and other panels
              to look washed out. --bg-main aliases --bg-medium
              (the body background) and --bg-card aliases --bg-dark
              (the card body background), matching what the rest
              of the codebase assumed.
     v2.1.0 - Added @font-face for Ritual of the Witch (header
              logo only). Scoped to #header h1 with Cinzel fallback.
     v2.0.0 - Initial Lexicon Theme / Discord Dark Variant.
   ================================================================ */
html,body,div,span,h1,h2,h3,h4,h5,h6,p,a,code,em,img,strong,b,i,ol,ul,li,fieldset,form,label,legend,table,caption,tbody,tfoot,thead,tr,th,td,article,aside,details,figcaption,figure,footer,header,nav,section,summary{margin:0;padding:0;border:0;font-size:100%;font:inherit;vertical-align:baseline;}
ol,ul{list-style:none;}html{box-sizing:border-box;}*,*:before,*:after{box-sizing:inherit;}
:root{--bg-darkest:#1e1f22;--bg-dark:#2b2d31;--bg-medium:#313338;--bg-light:#383a40;--bg-lighter:#404249;--bg-hover:#4e505860;--bg-main:#313338;--bg-card:#2b2d31;--text-primary:#f2f3f5;--text-secondary:#b5bac1;--text-muted:#949ba4;--text-faint:#6d6f78;--accent-blue:#5865f2;--accent-blue-hover:#4752c4;--accent-green:#57f287;--accent-crimson:#cc3340;--accent-abyssal:#6e5fa8;--accent-amber:#f0b232;--accent-red:#ed4245;--accent-cyan:#00b4d8;--border-thin:#3f4147;--code-bg:#1e1f22;--code-border:#3f4147;--font-display:'Cinzel',serif;--font-body:'EB Garamond',serif;--font-code:'Fira Code',monospace;--radius-sm:6px;--radius-md:8px;--radius-lg:10px;--shadow-low:0 1px 3px rgba(0,0,0,0.4);--shadow-med:0 4px 12px rgba(0,0,0,0.5);--shadow-high:0 8px 24px rgba(0,0,0,0.6);
--status-green:#4a7a3b;--status-blue:#3b6a7a;--inflict-color:#6b8e23;}

/* Ritual of the Witch: header logo only */
@font-face {
    font-family: 'Ritual of the Witch';
    src: url('../fonts/ritual-of-the-witch.ttf') format('truetype');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

body{background:var(--bg-medium);color:var(--text-secondary);font-family:var(--font-body);font-size:12pt;line-height:1.85em;}
a{color:var(--accent-blue);text-decoration:underline;transition:color 0.2s;}a:hover{color:var(--accent-cyan);text-decoration:none;}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:700;letter-spacing:0.06em;color:var(--text-primary);margin:0 0 0.5em 0;}
h1{font-size:2.4em;}h2{font-size:1.8em;}h3{font-size:1.35em;}h4{font-size:1.1em;}
p{margin-bottom:1em;}b,strong{color:var(--text-primary);font-weight:700;}
code{font-family:var(--font-code);font-size:0.88em;background:var(--code-bg);border:1px solid var(--code-border);border-radius:4px;padding:0.15em 0.45em;color:var(--accent-crimson);}
hr{border:0;border-top:1px solid var(--border-thin);margin:1.5em 0;}
.container{margin:0 auto;max-width:1400px;padding:0 30px;}
#header-wrapper{background:var(--bg-darkest);padding:1em 0;border-bottom:2px solid var(--border-thin);}
#header{display:flex;align-items:center;justify-content:space-between;max-width:1400px;margin:0 auto;padding:0 30px;}
#header h1{font-family:'Ritual of the Witch',var(--font-display);font-size:2.0em;margin:0;letter-spacing:0.12em;}
#header h1 .accent{color:var(--accent-abyssal);font-weight:800;}
.user-bar{display:flex;align-items:center;gap:0.75em;font-family:var(--font-display);font-size:0.75em;color:var(--text-muted);}
.user-bar img{width:28px;height:28px;border-radius:50%;}
.user-bar a{color:var(--text-faint);text-decoration:none;font-size:0.9em;}.user-bar a:hover{color:var(--accent-red);}
.header-actions{display:flex;align-items:center;gap:0.5em;}
.login-page{display:flex;align-items:center;justify-content:center;min-height:80vh;text-align:center;}
.login-box{background:var(--bg-dark);border:1px solid var(--border-thin);border-radius:var(--radius-lg);padding:3em;max-width:420px;box-shadow:var(--shadow-high);}
.login-box h2{margin-bottom:0.5em;}.login-box p{color:var(--text-muted);margin-bottom:2em;}
.btn{display:inline-flex;align-items:center;gap:0.5em;padding:0.7em 1.5em;border-radius:var(--radius-md);font-family:var(--font-display);font-weight:700;font-size:0.85em;letter-spacing:0.08em;text-transform:uppercase;text-decoration:none;cursor:pointer;border:none;transition:all 0.2s;}
.btn-discord{background:#5865f2;color:#fff;}.btn-discord:hover{background:#4752c4;color:#fff;}
.btn-primary{background:var(--accent-blue);color:#fff;}.btn-primary:hover{background:var(--accent-blue-hover);color:#fff;}
.btn-danger{background:var(--accent-red);color:#fff;}.btn-danger:hover{background:#c03537;color:#fff;}
.btn-ghost{background:transparent;border:1px solid var(--border-thin);color:var(--text-muted);}.btn-ghost:hover{background:var(--bg-hover);color:var(--text-primary);}
.btn-amber{background:var(--accent-amber);color:#000;}.btn-amber:hover{background:#d9a02e;color:#000;}
.btn-sm{padding:0.4em 0.8em;font-size:0.75em;}
#app{padding:2em 0 4em;}.hidden{display:none!important;}

.active-selector{display:flex;align-items:center;justify-content:center;gap:0.75em;margin-bottom:1em;padding:0.75em;background:var(--bg-dark);border:1px solid var(--border-thin);border-radius:var(--radius-md);}
.active-selector label{font-family:var(--font-display);font-size:0.8em;text-transform:uppercase;letter-spacing:0.1em;color:var(--text-muted);}
.active-selector select{background:var(--bg-darkest);color:var(--text-primary);border:1px solid var(--border-thin);border-radius:var(--radius-sm);padding:0.4em 0.8em;font-family:var(--font-body);font-size:1em;min-width:200px;}

.form-group{margin-bottom:1.25em;}
.form-group label{display:block;font-family:var(--font-display);font-size:0.85em;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;color:var(--text-muted);margin-bottom:0.4em;}
.form-input,.form-select{width:100%;padding:0.6em 0.8em;background:var(--bg-darkest);border:1px solid var(--border-thin);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font-body);font-size:1em;transition:border-color 0.2s;}
.form-input:focus,.form-select:focus{outline:none;border-color:var(--accent-blue);}
textarea.form-input{min-height:80px;resize:vertical;}

.spinner{display:inline-block;width:24px;height:24px;border:3px solid var(--bg-lighter);border-top:3px solid var(--accent-blue);border-radius:50%;animation:spin 0.8s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}
::-webkit-scrollbar{width:8px;}::-webkit-scrollbar-track{background:var(--bg-darkest);}::-webkit-scrollbar-thumb{background:var(--bg-lighter);border-radius:4px;}::-webkit-scrollbar-thumb:hover{background:var(--text-faint);}
