/* ============================================================
   FlipMap - core.css (Discord Dark / Shinra theme)
   Mirrors abyssal-engine/css/core.css token set so the look
   matches across shinra.cc subdomains.
   ============================================================ */
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:'Eurostile Extended','Eurostile','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);
}

/* Eurostile Extended: Square Enix Shinra Electric Power Company branding.
   Used everywhere headers/buttons reach for var(--font-display). Self-hosted
   licensed family; see flipmap/fonts/. font-display:swap keeps text visible
   while the OTF downloads. */
@font-face {
  font-family: 'Eurostile';
  src: url('../fonts/fonnts.com-Eurostile.otf') format('opentype');
  font-weight: 400; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'Eurostile';
  src: url('../fonts/fonnts.com-Eurostile_Bold.otf') format('opentype');
  font-weight: 700; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'Eurostile Extended';
  src: url('../fonts/fonnts.com-Eurostile_Extd.otf') format('opentype');
  font-weight: 400; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'Eurostile Extended';
  src: url('../fonts/fonnts.com-Eurostile_Extd_Medium.otf') format('opentype');
  font-weight: 500; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'Eurostile Extended';
  src: url('../fonts/fonnts.com-Eurostile_Extd_Black.otf') format('opentype');
  font-weight: 900; 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.6;min-height:100vh;display:flex;flex-direction:column;}
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:0.8em;}
b,strong{color:var(--text-primary);font-weight:700;}
hr{border:0;border-top:1px solid var(--border-thin);margin:1.5em 0;}

.container{margin:0 auto;max-width:1400px;padding:0 30px;width:100%;}

/* Header */
#header-wrapper{background:var(--bg-darkest);padding:0.9em 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:var(--font-display);font-size:2.0em;margin:0;letter-spacing:0.12em;font-weight:900;text-transform:uppercase;}
#header h1 .accent{color:var(--accent-abyssal);font-weight:800;}
.header-actions{display:flex;align-items:center;gap:0.5em;}
.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 a{color:var(--text-faint);text-decoration:none;font-size:0.9em;}
.user-bar a:hover{color:var(--accent-red);}

.cog-icon{display:inline-block;font-size:1.1em;line-height:1;}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:0.5em;padding:0.7em 1.4em;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-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-abyssal{background:var(--accent-abyssal);color:#fff;} .btn-abyssal:hover{background:#5a4d8c;color:#fff;}
.btn-sm{padding:0.4em 0.8em;font-size:0.72em;}
.btn[disabled]{opacity:0.4;cursor:not-allowed;pointer-events:none;}

/* Focus indicators - must be visible against the dark theme.
   Default browser outline is often invisible on near-black bg. */
:focus-visible{outline:2px solid var(--accent-abyssal);outline-offset:2px;border-radius:3px;}
.btn:focus-visible{outline-color:var(--accent-amber);}

/* Skip-to-content link for keyboard users (sr-only until focused) */
.skip-link{position:absolute;left:-9999px;top:0;background:var(--accent-abyssal);color:#fff;padding:0.6em 1em;font-family:var(--font-display);font-size:0.85em;letter-spacing:0.08em;text-decoration:none;border-radius:0 0 var(--radius-sm) 0;z-index:10000;}
.skip-link:focus{left:0;}

/* App */
#app{padding:2em 0 5em;flex:1;}
.hidden{display:none!important;}

/* Forms */
.form-group{margin-bottom:1.1em;}
.form-group label{display:block;font-family:var(--font-display);font-size:0.78em;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.55em 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;}

/* Alerts */
.alert{padding:0.7em 0.9em;border-radius:var(--radius-sm);font-size:0.85em;margin-bottom:1em;}
.alert-error{background:rgba(237,66,69,0.12);border:1px solid rgba(237,66,69,0.4);color:#ffb3b5;}
.alert-success{background:rgba(87,242,135,0.12);border:1px solid rgba(87,242,135,0.4);color:#a8f5be;}
.alert-info{background:rgba(88,101,242,0.12);border:1px solid rgba(88,101,242,0.4);color:#b6bff7;}

/* Login layout */
.login-page{display:flex;align-items:center;justify-content:center;min-height:80vh;padding:2em 1em;}
.login-box{background:var(--bg-dark);border:1px solid var(--border-thin);border-radius:var(--radius-lg);padding:2.5em;max-width:420px;width:100%;box-shadow:var(--shadow-high);}

/* Spinner */
.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);}}

/* Scrollbar */
::-webkit-scrollbar{width:8px;height: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);}

/* Footer */
.site-footer{padding:1em 0;border-top:1px solid var(--border-thin);background:var(--bg-darkest);text-align:center;font-size:0.75em;color:var(--text-faint);display:flex;justify-content:center;align-items:center;gap:1em;flex-wrap:wrap;}
.site-footer a{color:var(--text-muted);text-decoration:none;}
.site-footer a:hover{color:var(--accent-abyssal);}
