/* vps-admin — esthétique CL Corporate Affairs (navy / or, Garamond + Montserrat) */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
:root{
  --navy:#0d1b2a; --navy-2:#070f1a; --panel:#101f31; --panel-2:#16273b;
  --gold:#b89a5a; --gold-light:#d4b87a; --white:#ffffff;
  --muted:rgba(255,255,255,0.55); --faint:rgba(255,255,255,0.32);
  --line:rgba(184,154,90,0.22); --ok:#5fae7a; --err:#d98a8a;
}
html,body{min-height:100%;}
body{font-family:'Montserrat',sans-serif;color:var(--white);background:var(--navy);line-height:1.5;}
.bg{position:fixed;inset:0;z-index:-1;
  background:
    radial-gradient(ellipse at 50% -10%, rgba(184,154,90,0.10) 0%, transparent 55%),
    linear-gradient(to bottom, var(--navy) 0%, var(--navy-2) 100%);}

/* TOPBAR */
.topbar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;
  padding:1.1rem 2.2rem;border-bottom:1px solid var(--line);background:rgba(7,15,26,0.6);
  backdrop-filter:blur(6px);}
.brand{font-family:'Cormorant Garamond',serif;font-size:1.6rem;font-weight:600;
  color:var(--gold-light);letter-spacing:0.06em;}
.brand span{color:var(--white);}
.topbar nav{display:flex;gap:0.4rem;flex-wrap:wrap;}
.topbar nav a{color:var(--muted);text-decoration:none;font-size:0.78rem;letter-spacing:0.12em;
  text-transform:uppercase;padding:0.5rem 0.95rem;border:1px solid transparent;border-radius:2px;
  transition:color .25s,border-color .25s;}
.topbar nav a:hover{color:var(--gold-light);}
.topbar nav a.active{color:var(--gold-light);border-color:var(--line);}
.topbar nav a.logout{color:var(--faint);}

/* LAYOUT */
.wrap{max-width:1040px;margin:0 auto;padding:2.4rem 1.6rem 4rem;}
h1{font-family:'Cormorant Garamond',serif;font-weight:300;font-size:clamp(2rem,4vw,3rem);
  margin-bottom:0.4rem;}
h1 em{font-style:italic;color:var(--gold-light);}
.subtitle{color:var(--muted);font-size:0.92rem;margin-bottom:2.2rem;}
h2{font-family:'Cormorant Garamond',serif;font-weight:500;font-size:1.5rem;color:var(--gold-light);
  margin:0 0 1rem;letter-spacing:0.02em;}
.divider{width:48px;height:1px;background:var(--gold);margin:0 0 2rem;}

/* PANELS */
.grid{display:grid;gap:1.4rem;}
.grid-2{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));}
.panel{background:var(--panel);border:1px solid var(--line);border-radius:4px;padding:1.5rem 1.6rem;}
.panel.tight{padding:1.1rem 1.3rem;}

/* TABLES */
table{width:100%;border-collapse:collapse;font-size:0.86rem;}
th,td{text-align:left;padding:0.6rem 0.7rem;border-bottom:1px solid rgba(255,255,255,0.07);}
th{color:var(--faint);font-weight:500;text-transform:uppercase;font-size:0.68rem;letter-spacing:0.1em;}
td code{color:var(--gold-light);font-size:0.82rem;}

/* BADGES */
.badge{display:inline-block;padding:0.18rem 0.6rem;border-radius:999px;font-size:0.68rem;
  letter-spacing:0.06em;text-transform:uppercase;}
.badge-on{background:rgba(95,174,122,0.16);color:var(--ok);}
.badge-off{background:rgba(217,138,138,0.16);color:var(--err);}
.dot{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:0.4rem;}
.dot-on{background:var(--ok);} .dot-off{background:var(--err);}

/* FORMS */
label{display:block;font-size:0.74rem;letter-spacing:0.08em;text-transform:uppercase;
  color:var(--muted);margin:0.9rem 0 0.35rem;}
input[type=text],input[type=number],select,textarea{width:100%;background:var(--navy-2);
  border:1px solid var(--line);color:var(--white);padding:0.6rem 0.7rem;border-radius:3px;
  font-family:inherit;font-size:0.9rem;}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--gold-light);}
.row{display:flex;gap:0.9rem;flex-wrap:wrap;}
.row>*{flex:1;min-width:160px;}
.check{display:flex;align-items:center;gap:0.5rem;margin-top:0.8rem;}
.check input{width:auto;}
.check label{margin:0;text-transform:none;letter-spacing:0;font-size:0.85rem;color:var(--white);}
.hint{font-size:0.76rem;color:var(--faint);margin-top:0.4rem;}

/* BUTTONS */
button,.btn{font-family:'Montserrat',sans-serif;cursor:pointer;border:1px solid var(--gold);
  background:transparent;color:var(--gold-light);padding:0.6rem 1.4rem;border-radius:3px;
  font-size:0.78rem;letter-spacing:0.12em;text-transform:uppercase;transition:all .25s;margin-top:1.1rem;}
button:hover,.btn:hover{background:var(--gold);color:var(--navy);}
button.solid{background:var(--gold);color:var(--navy);}
button.ghost{border-color:var(--line);color:var(--muted);}
button.danger{border-color:rgba(217,138,138,0.5);color:var(--err);margin-top:0;padding:0.35rem 0.8rem;}
button.danger:hover{background:var(--err);color:var(--navy);}
button.mini{margin-top:0;padding:0.35rem 0.8rem;font-size:0.7rem;}

/* FLASHES */
.flashes{margin-bottom:1.8rem;display:grid;gap:0.6rem;}
.flash{padding:0.8rem 1rem;border-radius:3px;border-left:3px solid var(--gold);
  background:var(--panel-2);font-size:0.85rem;}
.flash-ok{border-color:var(--ok);}
.flash-error{border-color:var(--err);}
.flash-key{border-color:var(--gold-light);}
.flash-label{display:block;font-size:0.68rem;text-transform:uppercase;letter-spacing:0.1em;
  color:var(--gold-light);margin-bottom:0.3rem;}
.flash-msg{color:var(--white);word-break:break-all;white-space:pre-wrap;}

/* LOGIN / ENROLL */
.center-card{min-height:78vh;display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;}
.center-card .brand{font-size:2.2rem;margin-bottom:0.4rem;}
.center-card .tag{color:var(--muted);font-size:0.9rem;margin-bottom:2.4rem;letter-spacing:0.05em;}
.center-card .panel{max-width:420px;width:100%;text-align:left;}
.bigbtn{width:100%;text-align:center;margin-top:1.4rem;padding:0.9rem;font-size:0.82rem;}
.status-msg{margin-top:1rem;font-size:0.85rem;min-height:1.2em;}
.status-msg.err{color:var(--err);} .status-msg.ok{color:var(--ok);}

/* FOOT */
.foot{text-align:center;color:var(--faint);font-size:0.7rem;letter-spacing:0.06em;
  padding:1.6rem;border-top:1px solid var(--line);}
.footer-brand{font-family:'Cormorant Garamond',serif;color:var(--gold-light);}
.note{font-size:0.8rem;color:var(--muted);background:var(--panel-2);border-left:3px solid var(--gold);
  padding:0.7rem 0.9rem;border-radius:3px;margin-top:1rem;}

/* INFO / MODALE */
.info-btn{display:inline-flex;align-items:center;gap:0.4rem;cursor:pointer;background:transparent;
  border:1px solid var(--line);color:var(--gold-light);padding:0.4rem 0.9rem;border-radius:3px;
  font-size:0.74rem;letter-spacing:0.08em;text-transform:uppercase;margin:0;}
.info-btn:hover{background:var(--gold);color:var(--navy);}
dialog{border:1px solid var(--gold);border-radius:6px;background:var(--panel);color:var(--white);
  max-width:640px;width:92%;padding:0;box-shadow:0 20px 60px rgba(0,0,0,0.6);}
dialog::backdrop{background:rgba(5,12,20,0.75);backdrop-filter:blur(3px);}
.dialog-head{display:flex;align-items:center;justify-content:space-between;padding:1.2rem 1.5rem;
  border-bottom:1px solid var(--line);}
.dialog-head h2{margin:0;}
.dialog-body{padding:1.3rem 1.5rem;font-size:0.9rem;line-height:1.65;}
.dialog-body ol{margin:0 0 0 1.1rem;} .dialog-body li{margin-bottom:0.9rem;}
.dialog-body code,.cmd{background:var(--navy-2);border:1px solid var(--line);border-radius:3px;
  color:var(--gold-light);padding:0.12rem 0.4rem;font-size:0.82rem;word-break:break-all;}
.cmd-row{display:flex;gap:0.5rem;align-items:flex-start;margin-top:0.4rem;}
.cmd-row .cmd{flex:1;padding:0.5rem 0.6rem;white-space:pre-wrap;}
.x-close{cursor:pointer;background:transparent;border:none;color:var(--muted);font-size:1.4rem;
  line-height:1;margin:0;padding:0;}
.x-close:hover{color:var(--gold-light);background:transparent;}
.warn-line{color:var(--err);}
