@import url('https://fonts.googleapis.com/css2?family=Raleway:wght@300;400;500;600;700;800&display=swap');

:root {
  /* Astro UI / USSF palette */
  --astro-blue:    #4dacff;
  --astro-blue-dk: #2d7dd2;
  --astro-blue-lt: #90c9ff;
  --space-black:   #080f1a;
  --space-dark:    #0d1825;
  --space-navy:    #101e2e;
  --space-mid:     #152637;
  --space-light:   #1c3347;
  --nova-gold:     #4dacff;   /* remapped to Astro blue */
  --nova-amber:    #2d7dd2;   /* remapped to Astro blue-dk */
  --nova-teal:     #56f000;   /* Astro status green */
  --nova-blue:     #4dacff;
  --text-primary:  #e0eaf6;
  --text-secondary:#8aabcc;
  --text-muted:    #4d7a9a;
  --border:        rgba(77,172,255,0.13);
  --border-hover:  rgba(77,172,255,0.35);
  --card-bg:       rgba(10,22,38,0.92);
  --card-border:   rgba(77,172,255,0.10);
  --danger:        #ff3838;
  --sidebar-w:     220px;
  --radius:        8px;
  --radius-sm:     5px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px}
body{font-family:'Raleway',sans-serif;background:var(--space-black);color:var(--text-primary);min-height:100vh;overflow-x:hidden;position:relative}
body::before{content:'';position:fixed;inset:0;background-image:url('/assets/bg-nebula.jpg');background-size:cover;background-position:center top;opacity:.10;z-index:0;pointer-events:none}
.nova-layout{display:flex;min-height:100vh;position:relative;z-index:1}
/* SIDEBAR */
.sidebar{width:var(--sidebar-w);background:var(--space-dark);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;top:0;left:0;height:100vh;z-index:100;overflow-y:auto;transition:transform .3s ease}
.sidebar-logo{padding:24px 20px 20px;border-bottom:1px solid var(--border);display:flex;flex-direction:column;align-items:flex-start;gap:8px}
.logo-img{max-width:160px;height:auto;opacity:.92;filter:brightness(1.1)}
.nova-brand{font-family:'Raleway',sans-serif;font-size:10px;font-weight:800;letter-spacing:.3em;color:#4dacff;opacity:.9;text-transform:uppercase}
.nova-star{color:var(--nova-amber);animation:pulse 3s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.sidebar-nav{flex:1;padding:16px 0;overflow-y:auto}
.nav-section{padding:8px 0;border-bottom:1px solid var(--border);margin-bottom:4px}
.nav-label{display:block;font-size:9px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--text-muted);padding:8px 20px 4px}
.nav-link{display:flex;align-items:center;gap:10px;padding:9px 20px;color:var(--text-secondary);text-decoration:none;font-size:13px;font-weight:500;border-left:3px solid transparent;transition:all .2s;position:relative}
.nav-link:hover{color:var(--text-primary);background:rgba(240,165,0,.06);border-left-color:var(--nova-gold)}
.nav-link.active{color:var(--nova-gold);background:rgba(240,165,0,.1);border-left-color:var(--nova-gold);font-weight:600}
.nav-icon{font-size:12px;opacity:.7;width:16px;text-align:center}
.sidebar-user{display:flex;align-items:center;gap:10px;padding:16px;border-top:1px solid var(--border);background:var(--space-black)}
.user-avatar{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--nova-amber),var(--nova-gold));display:flex;align-items:center;justify-content:center;font-family:'Cinzel',serif;font-size:13px;font-weight:700;color:var(--space-black);flex-shrink:0}
.user-meta{flex:1;min-width:0}
.user-name{font-size:12px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-role{font-size:10px;color:var(--text-muted);margin-top:2px}
.logout-btn{color:var(--text-muted);font-size:18px;text-decoration:none;transition:color .2s;flex-shrink:0}
.logout-btn:hover{color:var(--nova-amber)}
/* MAIN CONTENT */
.main-content{margin-left:var(--sidebar-w);flex:1;display:flex;flex-direction:column;min-height:100vh}
.topbar{position:sticky;top:0;z-index:50;background:rgba(5,10,20,.95);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);padding:0 28px;height:62px;display:flex;align-items:center;gap:16px}
.sidebar-toggle{display:none;background:none;border:none;color:var(--text-primary);font-size:20px;cursor:pointer}
.page-title{font-family:'Raleway',sans-serif;font-size:15px;font-weight:700;letter-spacing:.04em;color:var(--text-primary);flex:1}
.topbar-actions{display:flex;align-items:center;gap:12px}
.cycle-badge{display:flex;align-items:center;gap:6px;background:rgba(45,212,191,.1);border:1px solid rgba(45,212,191,.3);color:var(--nova-teal);font-size:11px;font-weight:600;padding:4px 12px;border-radius:20px}
.cycle-dot{width:7px;height:7px;border-radius:50%;background:var(--nova-teal);animation:pulse 2s infinite}
.warn-badge{background:rgba(232,93,4,.15);border:1px solid rgba(232,93,4,.4);color:var(--nova-amber);font-size:11px;font-weight:600;padding:4px 12px;border-radius:20px;text-decoration:none}
.content-area{padding:28px;flex:1;max-width:1440px;width:100%}
/* CARDS */
.card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius);overflow:hidden;backdrop-filter:blur(8px);transition:border-color .2s}
.card:hover{border-color:var(--border-hover)}
.card-header{padding:13px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px;background:linear-gradient(135deg,rgba(77,172,255,.06) 0%,rgba(77,172,255,.01) 100%);position:relative}
.card-header::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,rgba(77,172,255,.5),rgba(77,172,255,.1),transparent)}
.card-header::after{content:'';position:absolute;bottom:-1px;left:0;width:40px;height:1px;background:#4dacff;opacity:.6}
.card-title{font-family:'Raleway',sans-serif;font-size:10.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#c8deff}
.card-header>.card-title{border-left:2px solid rgba(77,172,255,.6);padding-left:10px}
.card-body{padding:24px}
.card-footer{padding:14px 24px;border-top:1px solid var(--border);background:rgba(0,0,0,.2)}
/* STATS */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:24px}
.stat-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius);padding:22px 26px;transition:all .2s;position:relative;overflow:hidden}
.stat-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,#4dacff,rgba(77,172,255,.2))}
.stat-card:hover{transform:translateY(-2px);border-color:rgba(77,172,255,.3);box-shadow:0 8px 24px rgba(0,0,0,.3)}
.stat-value{font-family:'Raleway',sans-serif;font-size:26px;font-weight:700;color:#4dacff;line-height:1;letter-spacing:-.01em}
.stat-label{font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--text-muted);margin-top:8px}
.page-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.page-grid.three{grid-template-columns:1fr 1fr 1fr}
.page-grid.wide-left{display:grid;grid-template-columns:minmax(0,1fr) 300px;gap:24px;align-items:start}
/* Dashboard-specific layout */
.dash-grid{display:grid;grid-template-columns:minmax(0,1fr) 280px;gap:20px;align-items:start}
.dash-sidebar{display:flex;flex-direction:column;gap:16px;position:sticky;top:20px}
.full-width{grid-column:1/-1}
/* TABLES */
.table-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:13px}
thead tr{border-bottom:1px solid var(--border)}
thead th{padding:10px 16px;text-align:left;font-family:'Cinzel',serif;font-size:10px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--text-muted)}
tbody tr{border-bottom:1px solid rgba(74,158,218,.07);transition:background .15s}
tbody tr:hover{background:rgba(240,165,0,.04)}
tbody td{padding:11px 16px;color:var(--text-secondary);vertical-align:middle}
tbody td:first-child{color:var(--text-primary);font-weight:500}
/* FORMS */
.form-group{margin-bottom:18px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.form-row.three{grid-template-columns:1fr 1fr 1fr}
label{display:block;font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--text-muted);margin-bottom:6px}
input[type=text],input[type=email],input[type=password],input[type=date],input[type=number],input[type=tel],select,textarea{width:100%;background:rgba(19,40,64,.8);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-family:'Raleway',sans-serif;font-size:14px;padding:10px 14px;outline:none;transition:border-color .2s,box-shadow .2s;-webkit-appearance:none}
input:focus,select:focus,textarea:focus{border-color:var(--nova-gold);box-shadow:0 0 0 3px rgba(240,165,0,.12)}
select option{background:var(--space-navy)}
textarea{resize:vertical;min-height:120px}
.form-hint{font-size:11px;color:var(--text-muted);margin-top:4px}
/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;border-radius:var(--radius-sm);font-family:'Raleway',sans-serif;font-size:13px;font-weight:700;letter-spacing:.5px;cursor:pointer;border:none;text-decoration:none;transition:all .2s}
.btn-primary{background:linear-gradient(135deg,var(--nova-gold),var(--nova-amber));color:var(--space-black)}
.btn-primary:hover{opacity:.9;transform:translateY(-1px);box-shadow:0 4px 16px rgba(240,165,0,.3)}
.btn-secondary{background:transparent;border:1px solid var(--border);color:var(--text-secondary)}
.btn-secondary:hover{border-color:var(--nova-gold);color:var(--nova-gold)}
.btn-danger{background:rgba(231,76,60,.15);border:1px solid rgba(231,76,60,.4);color:#e74c3c}
.btn-danger:hover{background:rgba(231,76,60,.25)}
.btn-sm{padding:6px 12px;font-size:12px}
.btn-xs{padding:4px 9px;font-size:11px}
.actions-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
/* BADGES */
.badge{display:inline-block;padding:3px 10px;border-radius:12px;font-size:11px;font-weight:700;letter-spacing:.5px}
.badge-gold{background:rgba(240,165,0,.2);color:var(--nova-gold);border:1px solid rgba(240,165,0,.3)}
.badge-teal{background:rgba(45,212,191,.15);color:var(--nova-teal);border:1px solid rgba(45,212,191,.3)}
.badge-red{background:rgba(231,76,60,.15);color:#e74c3c;border:1px solid rgba(231,76,60,.3)}
.badge-blue{background:rgba(74,158,218,.15);color:var(--nova-blue);border:1px solid rgba(74,158,218,.3)}
.badge-muted{background:rgba(77,106,133,.2);color:var(--text-muted);border:1px solid var(--border)}
.badge-purple{background:rgba(155,89,182,.2);color:#c39bd3;border:1px solid rgba(155,89,182,.3)}
/* ALERTS */
.alert{display:flex;align-items:center;gap:10px;padding:12px 18px;border-radius:var(--radius-sm);margin-bottom:20px;font-size:13px;font-weight:500}
.alert-success{background:rgba(39,174,96,.12);border:1px solid rgba(39,174,96,.3);color:#2ecc71}
.alert-error{background:rgba(231,76,60,.12);border:1px solid rgba(231,76,60,.3);color:#e74c3c}
.alert-warning{background:rgba(240,165,0,.12);border:1px solid rgba(240,165,0,.3);color:var(--nova-gold)}
.alert-info{background:rgba(74,158,218,.12);border:1px solid rgba(74,158,218,.3);color:var(--nova-blue)}
/* LOGIN */
/* ── Login page – Astro UI / USSF palette ── */
.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;
  background:#080f1a}
.login-bg{position:fixed;inset:0;z-index:0;
  background-image:url('../assets/bg-nebula.jpg');
  background-size:cover;background-position:center center;
  opacity:.65}
.login-bg::after{content:'';position:absolute;inset:0;
  background:linear-gradient(160deg,rgba(4,12,28,.55) 0%,rgba(8,15,26,.7) 100%)}
.login-card{position:relative;z-index:1;width:440px;
  background:rgba(11,22,38,.88);
  border:1px solid rgba(77,172,255,.18);
  border-radius:12px;overflow:hidden;
  box-shadow:0 32px 80px rgba(0,0,0,.75),0 0 0 1px rgba(77,172,255,.06);
  backdrop-filter:blur(24px);
  animation:login-in .45s ease}
@keyframes login-in{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}
.login-header{background:rgba(6,16,30,.7);padding:36px 40px 26px;text-align:center;
  border-bottom:1px solid rgba(77,172,255,.12);position:relative}
.login-header::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,#4dacff,transparent)}
.login-logo{max-height:52px;width:auto;margin:0 auto 16px;display:block;
  filter:brightness(1.15) drop-shadow(0 0 8px rgba(77,172,255,.25))}
.login-logo-fallback{font-family:'Raleway',sans-serif;font-size:13px;font-weight:700;
  letter-spacing:.25em;color:#4dacff;text-transform:uppercase;margin-bottom:14px}
.login-system-name{font-family:'Cinzel',serif;font-size:21px;font-weight:700;
  color:#ffffff;letter-spacing:4px;margin-bottom:4px}
.login-system-name span{color:#4dacff;text-shadow:0 0 12px rgba(77,172,255,.6)}
.login-tagline{font-size:10px;letter-spacing:.25em;text-transform:uppercase;color:rgba(152,162,173,.8)}
.login-body{padding:30px 40px 22px}
.login-body label{color:rgba(152,162,173,.9);font-size:11px;letter-spacing:.08em;text-transform:uppercase}
.login-body input{background:rgba(255,255,255,.05);border-color:rgba(77,172,255,.2);color:#fff}
.login-body input:focus{border-color:#4dacff;box-shadow:0 0 0 3px rgba(77,172,255,.15)}
.login-body .btn-sign-in{width:100%;justify-content:center;padding:13px;
  background:#4dacff;color:#080f1a;font-weight:700;font-size:.95rem;border:none;border-radius:6px;
  cursor:pointer;transition:all .2s;letter-spacing:.03em}
.login-body .btn-sign-in:hover{background:#71bcff;transform:translateY(-1px);
  box-shadow:0 6px 20px rgba(77,172,255,.35)}
.login-footer{padding:18px 40px;border-top:1px solid rgba(77,172,255,.1);background:rgba(0,0,0,.25)}
.disclaimer{font-size:10px;color:var(--text-muted);line-height:1.6;text-align:center}
.login-extras{display:flex;justify-content:space-between;align-items:center;margin-top:12px}
.login-extras a{font-size:12px;color:var(--text-muted);text-decoration:none}
.login-extras a:hover{color:#4dacff}
.disclaimer{font-size:11px;color:rgba(152,162,173,.6);line-height:1.6;text-align:center;margin:0}
/* RATING */
.rating-group{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin:8px 0}
.rating-btn{padding:10px 6px;border:2px solid var(--border);border-radius:var(--radius-sm);background:transparent;color:var(--text-secondary);font-family:'Raleway',sans-serif;font-size:11px;font-weight:700;text-align:center;cursor:pointer;transition:all .2s}
.rating-btn:hover,.rating-btn.selected{border-color:var(--nova-gold);background:rgba(240,165,0,.1);color:var(--nova-gold)}
.rating-btn.r4.selected{border-color:#9b59b6;background:rgba(155,89,182,.1);color:#c39bd3}
.rating-btn .rating-num{font-family:'Cinzel',serif;font-size:18px;display:block}
.rating-btn .rating-label{display:block;margin-top:2px;font-size:9px;letter-spacing:.5px}
/* SLIDERS */
.slider-wrap{background:rgba(13,30,48,.6);border:1px solid var(--border);border-radius:var(--radius);padding:20px 24px;margin-bottom:16px}
.slider-header{display:flex;justify-content:space-between;margin-bottom:12px}
.slider-label{font-size:13px;font-weight:600;color:var(--text-primary)}
.slider-value{font-family:'Cinzel',serif;font-size:18px;color:var(--nova-gold)}
input[type=range]{-webkit-appearance:none;width:100%;height:6px;background:rgba(255,255,255,.1);border-radius:100px;outline:none;padding:0;border:none}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;border-radius:50%;background:linear-gradient(135deg,var(--nova-gold),var(--nova-amber));cursor:pointer;box-shadow:0 2px 8px rgba(240,165,0,.4)}
/* TRAINING */
.training-card{display:flex;align-items:center;gap:16px;padding:16px 20px;border:1px solid var(--border);border-radius:var(--radius);background:var(--card-bg);margin-bottom:10px;transition:all .2s}
.training-card:hover{border-color:var(--border-hover);transform:translateX(2px)}
.training-icon{width:44px;height:44px;border-radius:10px;background:rgba(240,165,0,.12);border:1px solid rgba(240,165,0,.2);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.training-info{flex:1}
.training-title{font-weight:600;font-size:14px;color:var(--text-primary)}
.training-meta{font-size:11px;color:var(--text-muted);margin-top:3px}
.training-due{font-size:11px;font-weight:600}
.training-due.urgent{color:var(--nova-amber)}
.training-due.overdue{color:#e74c3c}
.training-due.ok{color:var(--nova-teal)}
/* MODAL */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.75);z-index:1000;align-items:center;justify-content:center}
.modal-overlay.open{display:flex}
.modal{background:var(--space-navy);border:1px solid var(--border);border-radius:var(--radius);width:560px;max-width:95vw;max-height:90vh;overflow-y:auto;animation:modal-in .25s ease}
@keyframes modal-in{from{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}
.modal-header{padding:20px 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.modal-header h3{font-family:'Cinzel',serif;font-size:14px}
.modal-close{background:none;border:none;color:var(--text-muted);font-size:20px;cursor:pointer}
.modal-body{padding:24px}
.modal-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;gap:10px;justify-content:flex-end}
/* PROFILE */
.profile-header{display:flex;align-items:center;gap:24px;padding:28px;background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius);margin-bottom:20px}
.profile-avatar{width:70px;height:70px;border-radius:50%;background:linear-gradient(135deg,var(--nova-amber),var(--nova-gold));display:flex;align-items:center;justify-content:center;font-family:'Cinzel',serif;font-size:24px;font-weight:700;color:var(--space-black);flex-shrink:0}
.profile-info h2{font-family:'Cinzel',serif;font-size:22px;font-weight:700}
.profile-info p{color:var(--text-muted);font-size:13px;margin-top:4px}
.profile-badges{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
/* WORKFLOW */
.workflow-steps{display:flex;align-items:center;margin-bottom:24px;background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.workflow-step{flex:1;padding:14px 16px;text-align:center;font-size:11px;font-weight:600;letter-spacing:.5px;color:var(--text-muted);border-right:1px solid var(--border)}
.workflow-step:last-child{border-right:none}
.workflow-step.active{color:var(--nova-gold);background:rgba(240,165,0,.07)}
.workflow-step.done{color:var(--nova-teal)}
.workflow-step .step-num{display:block;font-family:'Cinzel',serif;font-size:16px;margin-bottom:2px}
/* QUIZ */
.quiz-question{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);padding:20px 24px;margin-bottom:16px}
.quiz-q-text{font-weight:600;color:var(--text-primary);margin-bottom:12px;font-size:14px}
.quiz-options{display:flex;flex-direction:column;gap:8px}
.quiz-option{display:flex;align-items:center;gap:10px;padding:10px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all .15s}
.quiz-option:hover,.quiz-option.selected{border-color:var(--nova-gold);background:rgba(240,165,0,.07)}
.quiz-option input{accent-color:var(--nova-gold)}
/* SECTION HEADERS */
.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.section-title{font-family:'Raleway',sans-serif;font-size:15px;font-weight:700;color:var(--text-primary);letter-spacing:.02em}
.section-sub{font-size:11px;color:var(--text-muted);margin-top:3px;letter-spacing:.03em}
/* UTILITIES */
.mt-0{margin-top:0}.mt-1{margin-top:8px}.mt-2{margin-top:16px}.mt-3{margin-top:24px}
.mb-1{margin-bottom:8px}.mb-2{margin-bottom:16px}.mb-3{margin-bottom:24px}
.text-muted{color:var(--text-muted);font-size:12px}.text-right{text-align:right}.text-center{text-align:center}
.text-gold{color:var(--nova-gold)}.text-teal{color:var(--nova-teal)}.text-red{color:#e74c3c}
.fw-bold{font-weight:700}.d-flex{display:flex}.align-center{align-items:center}
.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:16px}
/* RESPONSIVE */
@media(max-width:900px){
  .sidebar{transform:translateX(-100%)}.sidebar.open{transform:translateX(0)}
  .main-content{margin-left:0}.sidebar-toggle{display:block}
  .page-grid,.page-grid.wide-left,.dash-grid{grid-template-columns:1fr}
  .dash-sidebar{position:static}
  .form-row,.form-row.three{grid-template-columns:1fr}
  .rating-group{grid-template-columns:1fr 1fr}
}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--space-light);border-radius:10px}
