@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@400;600;700&family=Rajdhani:wght@300;400;500;600;700&family=Exo+2:wght@300;400;500;700&display=swap');

:root {
  --royal-deep: #050d2a;
  --royal-dark: #0a1640;
  --royal-mid:  #1a3a8f;
  --royal-blue: #2456cc;
  --sky-mid:    #1e3a6e;
  --sky-light:  #3a6dbb;
  --gold:       #f0c040;
  --gold-light: #ffd966;
  --gold-dim:   #c9921a;
  --white:      #f0f4ff;
  --white-dim:  #b8c4e0;
  --accent-glow: rgba(240,192,64,0.25);
  --blue-glow:   rgba(36,86,204,0.35);
  --card-bg:    rgba(10,22,64,0.85);
  --glass:      rgba(26,58,143,0.15);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--royal-deep);color:var(--white);font-family:'Exo 2',sans-serif;font-size:16px;line-height:1.6;min-height:100vh;overflow-x:hidden;display:flex;flex-direction:column}
body::before{content:'';position:fixed;inset:0;background:radial-gradient(ellipse at 20% 20%,rgba(36,86,204,.18) 0%,transparent 50%),radial-gradient(ellipse at 80% 80%,rgba(240,192,64,.08) 0%,transparent 50%),radial-gradient(ellipse at 50% 0%,rgba(26,58,143,.3) 0%,transparent 60%);pointer-events:none;z-index:0}
#particles{position:fixed;inset:0;z-index:0;pointer-events:none}
.page-content{position:relative;z-index:1;padding-top:70px;flex:1}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(5,13,42,.92);backdrop-filter:blur(20px);border-bottom:1px solid rgba(240,192,64,.3);padding:0 2rem;height:70px;display:flex;align-items:center;justify-content:space-between}
.nav-brand{display:flex;align-items:center;gap:12px;text-decoration:none}
.nav-logo{width:42px;height:42px;background:linear-gradient(135deg,var(--royal-mid),var(--gold));border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;box-shadow:0 0 20px var(--accent-glow);animation:pulse-glow 3s ease-in-out infinite}
@keyframes pulse-glow{0%,100%{box-shadow:0 0 20px var(--accent-glow)}50%{box-shadow:0 0 40px var(--accent-glow),0 0 60px rgba(240,192,64,.1)}}
.nav-title{font-family:'Cinzel',serif;font-size:1.1rem;font-weight:700;background:linear-gradient(135deg,var(--white),var(--gold));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:1px}
.nav-links{display:flex;align-items:center;gap:.25rem;list-style:none}
.nav-links a{color:var(--white-dim);text-decoration:none;font-family:'Rajdhani',sans-serif;font-size:.9rem;font-weight:500;letter-spacing:1px;text-transform:uppercase;padding:8px 14px;border-radius:6px;transition:all .3s;position:relative}
.nav-links a:hover,.nav-links a.active{color:var(--gold);background:rgba(240,192,64,.08)}
.nav-links a.active::after{content:'';position:absolute;bottom:2px;left:50%;transform:translateX(-50%);width:20px;height:2px;background:var(--gold);border-radius:2px}
.nav-social{display:flex;align-items:center;gap:8px}
.nav-social a{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--glass);color:var(--white-dim);text-decoration:none;font-size:14px;transition:all .3s;border:1px solid rgba(240,192,64,.15)}
.nav-social a:hover{background:rgba(240,192,64,.15);color:var(--gold);border-color:var(--gold);transform:translateY(-2px)}
.btn-nav-login{background:linear-gradient(135deg,var(--royal-mid),var(--royal-blue));color:var(--white)!important;border:1px solid var(--gold)!important;border-radius:8px!important;padding:8px 18px!important;font-weight:600!important}
.btn-nav-login:hover{background:linear-gradient(135deg,var(--gold-dim),var(--gold))!important;color:var(--royal-deep)!important}

/* HERO */
.hero{min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:80px 2rem 4rem;position:relative}
.hero-badge{display:inline-block;background:rgba(240,192,64,.12);border:1px solid rgba(240,192,64,.4);color:var(--gold);font-family:'Rajdhani',sans-serif;font-size:.8rem;font-weight:600;letter-spacing:3px;text-transform:uppercase;padding:6px 20px;border-radius:100px;margin-bottom:1.5rem;animation:fade-up .6s ease both}
.hero h1{font-family:'Cinzel',serif;font-size:clamp(2.5rem,7vw,6rem);font-weight:700;line-height:1.1;margin-bottom:1rem;animation:fade-up .8s ease .1s both}
.hero h1 .line1{display:block;background:linear-gradient(135deg,var(--white) 0%,var(--sky-light) 50%,var(--white) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero h1 .line2{display:block;background:linear-gradient(135deg,var(--gold-dim),var(--gold),var(--gold-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-sub{font-size:1.2rem;color:var(--white-dim);max-width:600px;margin:0 auto 2.5rem;animation:fade-up .8s ease .2s both}
.hero-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;animation:fade-up .8s ease .3s both}
@keyframes fade-up{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 32px;border-radius:10px;font-family:'Rajdhani',sans-serif;font-size:1rem;font-weight:600;letter-spacing:1px;text-transform:uppercase;text-decoration:none;border:none;cursor:pointer;transition:all .3s;position:relative;overflow:hidden}
.btn-primary{background:linear-gradient(135deg,var(--royal-mid),var(--royal-blue));color:var(--white);box-shadow:0 4px 20px var(--blue-glow);border:1px solid rgba(240,192,64,.3)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 30px var(--blue-glow)}
.btn-gold{background:linear-gradient(135deg,var(--gold-dim),var(--gold));color:var(--royal-deep);box-shadow:0 4px 20px var(--accent-glow);font-weight:700}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 8px 30px rgba(240,192,64,.4)}
.btn-outline{background:transparent;color:var(--white);border:1px solid rgba(240,192,64,.4)}
.btn-outline:hover{background:rgba(240,192,64,.08);border-color:var(--gold);color:var(--gold)}
.btn-danger{background:linear-gradient(135deg,#8f1a1a,#cc2424);color:var(--white)}
.btn-sm{padding:8px 18px;font-size:.85rem}
.full-width{width:100%}

/* CARDS */
.card{background:var(--card-bg);border:1px solid rgba(240,192,64,.15);border-radius:16px;padding:2rem;transition:all .3s;backdrop-filter:blur(10px);position:relative;overflow:hidden}
.card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--gold),transparent);opacity:0;transition:opacity .3s}
.card:hover{border-color:rgba(240,192,64,.35);transform:translateY(-4px)}
.card:hover::before{opacity:1}
.card-icon{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:24px;margin-bottom:1.25rem;background:linear-gradient(135deg,var(--royal-mid),var(--sky-mid));border:1px solid rgba(240,192,64,.2);box-shadow:0 4px 15px var(--blue-glow)}
.card h3{font-family:'Cinzel',serif;font-size:1.1rem;color:var(--gold);margin-bottom:.75rem}
.card p{color:var(--white-dim);font-size:.95rem}

/* SECTIONS */
section{padding:5rem 2rem}
.section-header{text-align:center;padding:4rem 1.5rem 0;margin-bottom:3rem}
.section-tag{display:inline-block;font-family:'Rajdhani',sans-serif;font-size:.75rem;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:var(--gold);margin-bottom:1rem}
.section-tag::before,.section-tag::after{content:'—';margin:0 8px;opacity:.5}
.section-title{font-family:'Cinzel',serif;font-size:clamp(1.8rem,4vw,3rem);background:linear-gradient(135deg,var(--white),var(--sky-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:1rem}
.section-desc{color:var(--white-dim);max-width:600px;margin:0 auto}
.grid-3{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;max-width:1100px;margin:0 auto}

/* MEMBER CARDS */
.member-card{background:var(--card-bg);border:1px solid rgba(240,192,64,.2);border-radius:20px;padding:2rem;text-align:center;transition:all .4s;position:relative;overflow:hidden}
.member-card:hover{transform:translateY(-6px);box-shadow:0 20px 50px rgba(36,86,204,.2);border-color:rgba(240,192,64,.5)}
.member-avatar{width:90px;height:90px;border-radius:50%;margin:0 auto 1rem;background:linear-gradient(135deg,var(--royal-mid),var(--sky-mid));border:3px solid var(--gold);display:flex;align-items:center;justify-content:center;font-size:36px;box-shadow:0 0 30px var(--accent-glow)}
.member-name{font-family:'Cinzel',serif;font-size:1.15rem;color:var(--white);margin-bottom:.4rem}
.member-position{display:inline-block;font-family:'Rajdhani',sans-serif;font-size:.8rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;padding:5px 14px;border-radius:100px;margin-bottom:.75rem;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.5)}
.member-bio{color:var(--white-dim);font-size:.9rem}

/* FORMS */
.form-group{margin-bottom:1.25rem}
.form-group label{display:block;font-family:'Rajdhani',sans-serif;font-size:.85rem;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--gold);margin-bottom:8px}
.form-group input,.form-group textarea,.form-group select{width:100%;background:rgba(10,22,64,.7);border:1px solid rgba(240,192,64,.2);border-radius:10px;color:var(--white);padding:12px 16px;font-family:'Exo 2',sans-serif;font-size:.95rem;transition:all .3s;outline:none}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(240,192,64,.1);background:rgba(10,22,64,.9)}
.form-group textarea{resize:vertical;min-height:120px}
.form-group select option{background:var(--royal-dark)}

/* AUTH */
.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:80px 2rem 4rem}
.auth-box{background:var(--card-bg);border:1px solid rgba(240,192,64,.25);border-radius:20px;padding:2.5rem;width:100%;max-width:440px;backdrop-filter:blur(20px);position:relative;overflow:hidden}
.auth-box::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--royal-mid),var(--gold),var(--royal-mid))}
.auth-logo{text-align:center;margin-bottom:2rem}
.auth-logo .star-icon{font-size:48px;display:block;margin-bottom:.5rem;animation:spin-slow 8s linear infinite}
@keyframes spin-slow{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
.auth-logo h2{font-family:'Cinzel',serif;font-size:1.4rem;background:linear-gradient(135deg,var(--white),var(--gold));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.auth-footer{text-align:center;margin-top:1.5rem;font-size:.9rem;color:var(--white-dim)}
.auth-footer a{color:var(--gold);text-decoration:none}

/* ALERTS */
.alert{padding:12px 16px;border-radius:10px;font-size:.9rem;margin-bottom:1rem;display:flex;align-items:center;gap:8px}
.alert-success{background:rgba(40,167,69,.15);border:1px solid rgba(40,167,69,.3);color:#7dda8c}
.alert-error{background:rgba(220,53,69,.15);border:1px solid rgba(220,53,69,.3);color:#f08080}
.alert-info{background:rgba(36,86,204,.15);border:1px solid rgba(36,86,204,.3);color:var(--sky-light)}

/* SCRIPT BOX */
.script-box{background:rgba(5,13,42,.8);border:1px solid rgba(240,192,64,.3);border-radius:14px;padding:2rem;position:relative;margin-bottom:1.5rem}
.script-mood{display:inline-block;background:rgba(240,192,64,.1);border:1px solid rgba(240,192,64,.3);color:var(--gold);font-family:'Rajdhani',sans-serif;font-size:.75rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;padding:3px 12px;border-radius:100px;margin-bottom:1rem}
.script-character{font-family:'Cinzel',serif;font-size:.85rem;color:var(--sky-light);margin-bottom:.75rem}
.script-text{font-size:1.05rem;color:var(--white);line-height:1.8;font-style:italic;padding-left:1rem}

/* UPLOAD */
.upload-zone{border:2px dashed rgba(240,192,64,.3);border-radius:12px;padding:2rem;text-align:center;cursor:pointer;transition:all .3s;position:relative}
.upload-zone:hover,.upload-zone.dragover{border-color:var(--gold);background:rgba(240,192,64,.05)}
.upload-zone input[type="file"]{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}
.upload-icon{font-size:32px;margin-bottom:.5rem;color:var(--gold)}
.upload-text{color:var(--white-dim);font-size:.9rem}

/* ADMIN */
.admin-layout{display:flex;min-height:100vh;padding-top:70px}
.admin-sidebar{width:260px;background:rgba(5,13,42,.95);border-right:1px solid rgba(240,192,64,.15);padding:2rem 0;position:fixed;top:70px;left:0;bottom:0;overflow-y:auto}
.admin-sidebar-header{padding:0 1.5rem 1.5rem;border-bottom:1px solid rgba(240,192,64,.1);margin-bottom:1rem}
.admin-sidebar-header h3{font-family:'Cinzel',serif;font-size:.9rem;color:var(--gold);letter-spacing:2px;text-transform:uppercase}
.admin-nav a{display:flex;align-items:center;gap:10px;padding:12px 1.5rem;color:var(--white-dim);text-decoration:none;font-family:'Rajdhani',sans-serif;font-size:.95rem;font-weight:500;transition:all .25s;border-left:3px solid transparent}
.admin-nav a:hover,.admin-nav a.active{color:var(--gold);background:rgba(240,192,64,.06);border-left-color:var(--gold)}
.admin-main{flex:1;margin-left:260px;padding:2rem;min-height:100vh}
.admin-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid rgba(240,192,64,.15)}
.admin-header h1{font-family:'Cinzel',serif;font-size:1.6rem;background:linear-gradient(135deg,var(--white),var(--gold));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

/* TABLES */
.table-wrap{overflow-x:auto;border-radius:12px;border:1px solid rgba(240,192,64,.15)}
table{width:100%;border-collapse:collapse;font-size:.9rem}
thead{background:rgba(5,13,42,.9)}
thead th{padding:12px 16px;text-align:left;font-family:'Rajdhani',sans-serif;font-size:.8rem;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--gold);border-bottom:1px solid rgba(240,192,64,.15)}
tbody tr{border-bottom:1px solid rgba(240,192,64,.06);transition:background .2s}
tbody tr:hover{background:rgba(36,86,204,.08)}
tbody td{padding:12px 16px;color:var(--white-dim);vertical-align:middle}

/* BADGES */
.badge{display:inline-block;padding:3px 10px;border-radius:100px;font-size:.75rem;font-weight:600;font-family:'Rajdhani',sans-serif;letter-spacing:1px;text-transform:uppercase}
.badge-pending{background:rgba(255,193,7,.15);color:#ffc107;border:1px solid rgba(255,193,7,.3)}
.badge-accepted{background:rgba(40,167,69,.15);color:#7dda8c;border:1px solid rgba(40,167,69,.3)}
.badge-rejected{background:rgba(220,53,69,.15);color:#f08080;border:1px solid rgba(220,53,69,.3)}
.badge-admin{background:rgba(240,192,64,.15);color:var(--gold);border:1px solid rgba(240,192,64,.3)}
.badge-member{background:rgba(36,86,204,.15);color:var(--sky-light);border:1px solid rgba(36,86,204,.3)}
.badge-user{background:rgba(120,120,120,.15);color:#aaa;border:1px solid rgba(120,120,120,.3)}

/* STATS */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.25rem;margin-bottom:2rem}
.stat-card{background:var(--card-bg);border:1px solid rgba(240,192,64,.15);border-radius:14px;padding:1.5rem;display:flex;align-items:center;gap:1rem}
.stat-icon{font-size:28px;width:50px;height:50px;display:flex;align-items:center;justify-content:center;background:rgba(36,86,204,.2);border-radius:12px;border:1px solid rgba(36,86,204,.3)}
.stat-info .stat-number{font-size:1.8rem;font-weight:700;color:var(--gold);line-height:1}
.stat-info .stat-label{font-size:.8rem;color:var(--white-dim);font-family:'Rajdhani',sans-serif;letter-spacing:1px;text-transform:uppercase}

/* MODAL */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(5,13,42,.85);backdrop-filter:blur(8px);z-index:2000;align-items:center;justify-content:center;padding:2rem}
.modal-overlay.open{display:flex}
.modal{background:var(--royal-dark);border:1px solid rgba(240,192,64,.3);border-radius:20px;padding:2rem;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;position:relative}
.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}
.modal-header h3{font-family:'Cinzel',serif;color:var(--gold)}
.modal-close{background:none;border:none;color:var(--white-dim);font-size:20px;cursor:pointer;padding:4px 8px;border-radius:6px;transition:all .2s}
.modal-close:hover{color:var(--white);background:rgba(255,255,255,.1)}

/* SPINNER */
.spinner{display:inline-block;width:18px;height:18px;border:2px solid rgba(240,192,64,.3);border-top-color:var(--gold);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* FOOTER */
footer{background:rgba(5,13,42,.95);border-top:1px solid rgba(240,192,64,.15);padding:3rem 2rem 1.5rem;position:relative}
.footer-content{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:2rem;margin-bottom:2rem}
.footer-brand h3{font-family:'Cinzel',serif;font-size:1.2rem;color:var(--gold);margin-bottom:.75rem}
.footer-brand p{color:var(--white-dim);font-size:.9rem}
.footer-links h4{font-family:'Rajdhani',sans-serif;font-size:.8rem;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--gold);margin-bottom:1rem}
.footer-links ul{list-style:none}
.footer-links li{margin-bottom:.5rem}
.footer-links a{color:var(--white-dim);text-decoration:none;font-size:.9rem;transition:color .2s}
.footer-links a:hover{color:var(--gold)}
.footer-social{display:flex;gap:10px;flex-wrap:wrap;margin-top:1rem}
.footer-social a{width:38px;height:38px;border-radius:50%;background:var(--glass);border:1px solid rgba(240,192,64,.2);display:flex;align-items:center;justify-content:center;color:var(--white-dim);text-decoration:none;font-size:16px;transition:all .3s}
.footer-social a:hover{background:rgba(240,192,64,.15);color:var(--gold);border-color:var(--gold);transform:translateY(-2px)}
.footer-bottom{max-width:1100px;margin:0 auto;padding-top:1.5rem;border-top:1px solid rgba(240,192,64,.08);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.5rem}
.footer-bottom p{color:var(--white-dim);font-size:.8rem}

/* REVEAL — pure CSS, works for dynamically-inserted elements */
@keyframes reveal-in{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}
.reveal{animation:reveal-in .6s ease both}
/* Keep .visible for any legacy JS-driven reveals */
.reveal.visible{opacity:1;transform:translateY(0)}

/* UTIL */
.hidden{display:none!important}
.text-gold{color:var(--gold)}
.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}
.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}
.text-center{text-align:center}
.flex{display:flex}.flex-center{display:flex;align-items:center;justify-content:center}
.gap-1{gap:.5rem}.gap-2{gap:1rem}

/* RESPONSIVE */
@media(max-width:768px){.nav-links{display:none}.admin-sidebar{transform:translateX(-100%)}.admin-main{margin-left:0}}
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:var(--royal-deep)}
::-webkit-scrollbar-thumb{background:rgba(240,192,64,.3);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--gold)}
::selection{background:rgba(240,192,64,.25);color:var(--white)}
