@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@400;600;700&family=Cormorant+Garamond:ital,wght@0,300;0,400;0,600;1,300;1,400&display=swap');
:root{--gold:#c9a84c;--gold-light:#e0c070;--dark:#0d0a06;--dark2:#1a1209;--dark3:#251a0e;--maroon:#7a1a1a;--text:#e8dcc8;--text-muted:#9a8a6a;--border:#3a2a1a;--card:#1e1509;--success:#2d6a2d;--danger:#8b1a1a;--warn:#6a5a1a}
*{margin:0;padding:0;box-sizing:border-box}body{background:var(--dark);color:var(--text);font-family:'Cormorant Garamond',Georgia,serif;font-size:17px;line-height:1.7}
a{color:var(--gold);text-decoration:none}a:hover{color:var(--gold-light)}
h1,h2,h3,h4{font-family:'Cinzel',serif;color:var(--gold);letter-spacing:.05em;line-height:1.3}
.site-header{background:var(--dark2);border-bottom:1px solid var(--border);padding:0 2rem;display:flex;align-items:center;justify-content:space-between;height:70px;position:sticky;top:0;z-index:100}
.logo-wrap .brand{font-family:'Cinzel',serif;font-size:1.3rem;color:var(--gold)}.logo-wrap .sub{font-size:.72rem;color:var(--text-muted);letter-spacing:.25em;text-transform:uppercase}
.nav-links{display:flex;gap:1.5rem;align-items:center}.nav-links a{font-family:'Cinzel',serif;font-size:.82rem;letter-spacing:.08em;color:var(--text-muted);transition:.2s}.nav-links a:hover,.nav-links a.active{color:var(--gold)}
.btn{display:inline-block;padding:.5rem 1.3rem;border-radius:2px;font-family:'Cinzel',serif;font-size:.78rem;letter-spacing:.1em;cursor:pointer;border:none;transition:.2s;text-transform:uppercase;text-decoration:none}
.btn-gold{background:var(--gold);color:var(--dark);font-weight:700}.btn-gold:hover{background:var(--gold-light);color:var(--dark)}
.btn-outline{background:transparent;border:1px solid var(--gold);color:var(--gold)}.btn-outline:hover{background:var(--gold);color:var(--dark)}
.btn-danger{background:var(--danger);color:#fff;border:none}.btn-sm{padding:.3rem .8rem;font-size:.72rem}.btn-success{background:var(--success);color:#a0f0a0;border:none}
.container{max-width:1200px;margin:0 auto;padding:0 1.5rem}
.hero{background:linear-gradient(160deg,#0d0a06 0%,#1a120a 60%,#0d0a06 100%);padding:6rem 1.5rem 5rem;text-align:center}
.hero h1{font-size:3.2rem;margin-bottom:1rem}.hero .sub{font-size:1.1rem;color:var(--text-muted);max-width:580px;margin:.5rem auto 2.5rem;font-style:italic}
.section{padding:4rem 0}.section-title{text-align:center;margin-bottom:3rem}.section-title h2{font-size:2rem;margin-bottom:.5rem}.section-title p{color:var(--text-muted)}
.divider{width:80px;height:1px;background:var(--gold);margin:.8rem auto;opacity:.6}
.grid-3{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:1.5rem}
.grid-4{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:1.2rem}
.card{background:var(--card);border:1px solid var(--border);border-radius:4px;overflow:hidden;transition:.25s}
.card:hover{border-color:var(--gold);box-shadow:0 8px 30px rgba(201,168,76,.1)}
.card-img{width:100%;height:270px;object-fit:cover;display:block}
.card-img-ph{width:100%;height:270px;background:var(--dark3);display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:3rem;font-family:'Cinzel',serif}
.card-body{padding:1.3rem}.card-cat{font-size:.75rem;color:var(--text-muted);letter-spacing:.2em;text-transform:uppercase;margin-bottom:.3rem}
.card-title{font-family:'Cinzel',serif;font-size:1rem;color:var(--gold);margin-bottom:.5rem}
.card-price{font-size:1.2rem;color:var(--gold-light);font-family:'Cinzel',serif;font-weight:600}
.card-avail{font-size:.8rem;color:var(--text-muted);margin-top:.3rem}
.badge{display:inline-block;padding:.18rem .55rem;border-radius:2px;font-size:.72rem;letter-spacing:.05em;text-transform:uppercase}
.badge-ok{background:#1a3a1a;color:#80c880;border:1px solid #2d6a2d}.badge-warn{background:#3a3010;color:#c8c080;border:1px solid #5a4a10}
.badge-danger{background:#3a1010;color:#c88080;border:1px solid #6a2020}.badge-info{background:var(--dark3);color:var(--text-muted);border:1px solid var(--border)}
.badge-pending{background:#2a1a3a;color:#a080c8}.badge-approved{background:#1a3a1a;color:#80c880}.badge-returned{background:var(--dark3);color:var(--text-muted)}.badge-rejected{background:#3a1010;color:#c88080}
.form-group{margin-bottom:1.1rem}.form-label{display:block;font-family:'Cinzel',serif;font-size:.75rem;letter-spacing:.12em;color:var(--text-muted);margin-bottom:.35rem;text-transform:uppercase}
.form-control{width:100%;background:var(--dark3);border:1px solid var(--border);color:var(--text);padding:.6rem .9rem;border-radius:2px;font-family:inherit;font-size:1rem;transition:.2s}
.form-control:focus{outline:none;border-color:var(--gold)}.form-control::placeholder{color:var(--text-muted);opacity:.5}
select.form-control option{background:var(--dark2)}
.alert{padding:.75rem 1.1rem;border-radius:2px;margin-bottom:1rem;font-size:.92rem}
.alert-success{background:#0e2a0e;border:1px solid #2d6a2d;color:#90d890}.alert-danger{background:#2a0e0e;border:1px solid #6a1a1a;color:#d89090}
.alert-info{background:var(--dark3);border:1px solid var(--border);color:var(--text-muted)}
.page-wrap{min-height:calc(100vh - 70px);padding:2.5rem 0}
.auth-box{max-width:400px;margin:3rem auto;background:var(--card);border:1px solid var(--border);border-radius:4px;padding:2.5rem;text-align:center}
.auth-box h2{margin-bottom:.3rem}.auth-box .sub-text{color:var(--text-muted);margin-bottom:2rem;font-size:.93rem;font-style:italic}
.otp-group{display:flex;gap:.4rem;justify-content:center;margin:1.2rem 0}
.otp-input{width:48px;height:52px;text-align:center;font-size:1.4rem;font-family:'Cinzel',serif;background:var(--dark3);border:1px solid var(--border);color:var(--gold);border-radius:2px;transition:.2s}
.otp-input:focus{outline:none;border-color:var(--gold)}
.site-footer{background:var(--dark2);border-top:1px solid var(--border);padding:2rem 1.5rem;text-align:center;color:var(--text-muted);font-size:.85rem}
table{width:100%;border-collapse:collapse}th{background:var(--dark2);color:var(--gold);font-family:'Cinzel',serif;font-size:.75rem;letter-spacing:.1em;padding:.65rem 1rem;text-align:left;border-bottom:1px solid var(--border)}
td{padding:.65rem 1rem;border-bottom:1px solid var(--border);font-size:.9rem;vertical-align:middle}tr:hover td{background:rgba(201,168,76,.04)}.table-wrap{overflow-x:auto;background:var(--card);border:1px solid var(--border);border-radius:4px}
.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:1rem;margin-bottom:2rem}
.stat-card{background:var(--card);border:1px solid var(--border);border-radius:4px;padding:1.5rem;text-align:center}
.stat-card .num{font-family:'Cinzel',serif;font-size:2.5rem;color:var(--gold);line-height:1}
.stat-card .lbl{font-size:.72rem;color:var(--text-muted);letter-spacing:.15em;text-transform:uppercase;margin-top:.4rem}
.admin-header{background:var(--dark2);border-bottom:1px solid var(--border);padding:.8rem 2rem;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50}
.admin-logo{font-family:'Cinzel',serif;color:var(--gold);font-size:1rem;letter-spacing:.1em}
.admin-logo span{display:block;font-size:.65rem;color:var(--text-muted);letter-spacing:.2em}
.admin-nav{display:flex;gap:.4rem;align-items:center}.admin-nav a{font-size:.75rem;font-family:'Cinzel',serif;letter-spacing:.06em;color:var(--text-muted);padding:.35rem .75rem;border-radius:2px;transition:.2s}
.admin-nav a:hover,.admin-nav a.active{background:var(--dark3);color:var(--gold)}
.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;flex-wrap:wrap;gap:.5rem}.page-header h1{font-size:1.4rem}
.img-thumb{width:55px;height:55px;object-fit:cover;border-radius:2px;border:1px solid var(--border)}
.filter-bar{background:var(--card);border:1px solid var(--border);border-radius:4px;padding:1rem 1.2rem;margin-bottom:1.5rem;display:flex;gap:1rem;flex-wrap:wrap;align-items:flex-end}
.filter-bar .form-group{margin-bottom:0;flex:1;min-width:140px}
.upload-area{border:2px dashed var(--border);border-radius:4px;padding:2rem;text-align:center;cursor:pointer;color:var(--text-muted);transition:.2s}
.upload-area:hover{border-color:var(--gold)}
.img-preview{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.8rem}
.img-preview img{width:80px;height:80px;object-fit:cover;border-radius:2px;border:1px solid var(--border)}
.booking-card{background:var(--card);border:1px solid var(--border);border-radius:4px;padding:1.3rem;margin-bottom:1rem}
.booking-card h4{font-size:1rem;margin-bottom:.5rem;color:var(--gold);font-family:'Cinzel',serif}
.booking-meta{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.3rem .8rem;font-size:.85rem;color:var(--text-muted);margin:.6rem 0}
.booking-meta strong{color:var(--text)}
@media(max-width:768px){.hero h1{font-size:2rem}.grid-3,.grid-4{grid-template-columns:1fr}.stat-grid{grid-template-columns:repeat(2,1fr)}.admin-header{flex-direction:column;gap:.5rem;padding:.8rem 1rem;height:auto}.nav-links{gap:.8rem}}
/* ===== FILTER BAR ===== */
.filter-bar{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:1.5rem;align-items:center}
.filter-bar .form-control{flex:1;min-width:160px}
.checkbox-label{display:flex;align-items:center;gap:.5rem;color:var(--text);cursor:pointer;font-family:var(--font-body)}
.checkbox-label input{accent-color:var(--gold);width:16px;height:16px}
.cat-pills{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.25rem}
.cat-pill{padding:.35rem .9rem;border-radius:20px;border:1px solid var(--border);color:var(--muted);
  font-family:var(--font-body);font-size:.82rem;text-decoration:none;transition:all .2s}
.cat-pill:hover,.cat-pill.active{background:var(--gold);color:#000;border-color:var(--gold)}
.result-count{color:var(--muted);font-size:.875rem;margin-bottom:1.25rem}

/* ===== COSTUME CARD ===== */
.costume-card{display:flex;flex-direction:column;text-decoration:none;color:inherit}
.card-img{position:relative;aspect-ratio:3/4;overflow:hidden;background:#111}
.card-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.costume-card:hover .card-img img{transform:scale(1.05)}
.no-img{display:flex;align-items:center;justify-content:center;height:100%;color:var(--muted);font-size:.8rem}
.card-body{padding:.9rem;flex:1;display:flex;flex-direction:column;gap:.35rem}
.card-title{font-family:var(--font-heading);font-size:1rem;color:var(--text);margin:0}
.cat-tag{font-size:.72rem;color:var(--gold);letter-spacing:.05em;text-transform:uppercase}
.price{font-family:var(--font-heading);color:var(--gold);font-size:1.05rem;margin:0}
.price span{font-size:.8rem;color:var(--muted)}
.price-hidden{color:var(--muted)!important;font-size:.85rem}
.card-desc{font-size:.82rem;color:var(--muted);margin:0;line-height:1.5}

/* ===== AVAILABILITY BADGES ===== */
.badge-available,.badge-rented,.badge-maintenance,.badge-pending,.badge-approved,.badge-rejected,.badge-returned{
  display:inline-block;padding:.2rem .65rem;border-radius:20px;font-size:.72rem;
  font-family:var(--font-body);font-weight:600;letter-spacing:.04em;text-transform:capitalize}
.badge-available{background:rgba(39,174,96,.15);color:#27ae60;border:1px solid rgba(39,174,96,.3)}
.badge-rented{background:rgba(231,76,60,.15);color:#e74c3c;border:1px solid rgba(231,76,60,.3)}
.badge-maintenance{background:rgba(243,156,18,.15);color:#f39c12;border:1px solid rgba(243,156,18,.3)}
.badge-pending{background:rgba(243,156,18,.15);color:#f39c12;border:1px solid rgba(243,156,18,.3)}
.badge-approved{background:rgba(39,174,96,.15);color:#27ae60;border:1px solid rgba(39,174,96,.3)}
.badge-rejected{background:rgba(231,76,60,.15);color:#e74c3c;border:1px solid rgba(231,76,60,.3)}
.badge-returned{background:rgba(149,165,166,.15);color:#95a5a6;border:1px solid rgba(149,165,166,.3)}
.badge-btn{background:transparent;border:none;cursor:pointer;padding:.2rem .65rem;border-radius:20px;font-size:.72rem;font-weight:600}

/* Card image overlay badge */
.card-img .badge-available,.card-img .badge-rented,.card-img .badge-maintenance{
  position:absolute;top:.6rem;right:.6rem}

/* ===== PAGINATION ===== */
.pagination{display:flex;gap:.4rem;flex-wrap:wrap;justify-content:center;margin-top:2rem}
.page-btn{padding:.4rem .85rem;border:1px solid var(--border);border-radius:4px;
  color:var(--muted);text-decoration:none;font-family:var(--font-body);font-size:.875rem;transition:all .2s}
.page-btn:hover,.page-btn.active{background:var(--gold);color:#000;border-color:var(--gold)}

/* ===== EMPTY STATE ===== */
.empty-state{text-align:center;padding:4rem 2rem;color:var(--muted)}
.empty-state a{color:var(--gold)}

/* ===== HERO SM ===== */
.hero-sm{padding:3rem 1rem 2.5rem;text-align:center;background:linear-gradient(to bottom,rgba(13,10,6,0),rgba(13,10,6,.5)),var(--dark)}
.hero-sm .hero-title{font-size:clamp(1.6rem,4vw,2.5rem);color:var(--gold);font-family:var(--font-heading);margin-bottom:.5rem}
.hero-sm .hero-sub{color:var(--muted);font-family:var(--font-body);font-size:1.05rem}

/* ===== COSTUME DETAIL ===== */
.costume-detail{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start}
@media(max-width:768px){.costume-detail{grid-template-columns:1fr}}
.gallery-main img{width:100%;border-radius:8px;aspect-ratio:3/4;object-fit:cover;border:1px solid var(--border)}
.gallery-thumbs{display:flex;gap:.5rem;margin-top:.5rem;flex-wrap:wrap}
.thumb{width:70px;height:90px;object-fit:cover;border-radius:4px;cursor:pointer;border:2px solid transparent;transition:border-color .2s}
.thumb:hover{border-color:var(--gold)}
.breadcrumb-nav{font-size:.8rem;color:var(--muted);margin-bottom:1rem}
.breadcrumb-nav a{color:var(--muted);text-decoration:none}
.breadcrumb-nav a:hover{color:var(--gold)}
.costume-title{font-family:var(--font-heading);color:var(--gold);font-size:clamp(1.4rem,3vw,2rem);margin:0 0 .75rem}
.detail-price{font-family:var(--font-heading);font-size:1.6rem;color:var(--gold);margin:.75rem 0}
.detail-price span{font-size:.9rem;color:var(--muted);font-family:var(--font-body)}
.deposit-note{font-size:.85rem;color:var(--muted);margin:.25rem 0 1rem}
.costume-desc{color:var(--text);font-family:var(--font-body);line-height:1.8;margin:1rem 0}
.size-info{font-size:.88rem;color:var(--muted);margin:.35rem 0}
.booking-form-wrap{margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--border)}
.booking-form-wrap h2{font-family:var(--font-heading);color:var(--gold);font-size:1.25rem;margin-bottom:1rem}
.booking-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
@media(max-width:500px){.booking-form .form-row{grid-template-columns:1fr}}
.req{color:#e74c3c}.opt{color:var(--muted);font-size:.8rem}

/* ===== ALERTS ===== */
.alert{padding:.85rem 1.1rem;border-radius:6px;margin-bottom:1.25rem;font-family:var(--font-body);font-size:.9rem}
.alert-success{background:rgba(39,174,96,.1);border:1px solid rgba(39,174,96,.3);color:#27ae60}
.alert-error{background:rgba(231,76,60,.1);border:1px solid rgba(231,76,60,.3);color:#e74c3c}

/* ===== DASHBOARD ===== */
.dash-header{display:flex;justify-content:space-between;align-items:flex-start;
  flex-wrap:wrap;gap:1rem;margin-bottom:2rem}
.page-title{font-family:var(--font-heading);color:var(--gold);font-size:clamp(1.4rem,3vw,2rem);margin:0}
.welcome{color:var(--muted);font-family:var(--font-body);margin:.25rem 0 0}
.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:1rem;margin-bottom:2rem}

/* ===== BOOKING LIST ===== */
.booking-list{display:flex;flex-direction:column;gap:1rem}
.booking-card{display:grid;grid-template-columns:100px 1fr auto;gap:1.25rem;align-items:start;
  background:var(--card);border:1px solid var(--border);border-radius:8px;padding:1.25rem;
  transition:border-color .2s}
.booking-card:hover{border-color:var(--gold)}
@media(max-width:600px){.booking-card{grid-template-columns:1fr}}
.booking-img img{width:100px;height:120px;object-fit:cover;border-radius:6px}
.no-img-sm{width:100px;height:120px;display:flex;align-items:center;justify-content:center;
  background:#111;border-radius:6px;color:var(--muted);font-size:.75rem}
.booking-info h3{font-family:var(--font-heading);color:var(--gold);font-size:1rem;margin:0 0 .4rem}
.booking-info h3 a{color:inherit;text-decoration:none}
.booking-dates{font-size:.85rem;color:var(--muted);margin:.2rem 0}
.booking-event{font-size:.85rem;color:var(--text);margin:.2rem 0}
.booking-price{font-family:var(--font-heading);color:var(--gold);margin:.4rem 0 0;font-size:.95rem}
.admin-note{font-size:.8rem;color:var(--muted);background:rgba(201,168,76,.08);
  padding:.4rem .6rem;border-radius:4px;margin-top:.4rem}
.booking-status{text-align:right}
.booking-date-created{font-size:.75rem;color:var(--muted);margin-top:.4rem}

/* ===== PROFILE ===== */
.back-link{display:inline-block;color:var(--muted);text-decoration:none;font-size:.85rem;margin-bottom:1.5rem}
.back-link:hover{color:var(--gold)}
.profile-intro{color:var(--muted);font-family:var(--font-body);margin-bottom:1.5rem}
.profile-form .form-group small{display:block;margin-top:.25rem;font-size:.78rem;color:var(--muted)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
@media(max-width:500px){.form-row{grid-template-columns:1fr}}
.form-actions{display:flex;gap:1rem;margin-top:1.5rem;flex-wrap:wrap}

/* ===== ADMIN ===== */
.admin-header{background:var(--card);border-bottom:1px solid var(--border);
  position:sticky;top:0;z-index:100}
.admin-header-inner{max-width:1400px;margin:0 auto;padding:.9rem 1.5rem;
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}
.admin-logo{font-family:var(--font-heading);color:var(--gold);text-decoration:none;font-size:1.1rem}
.admin-nav{display:flex;gap:1.25rem;flex-wrap:wrap}
.admin-nav a{color:var(--muted);text-decoration:none;font-family:var(--font-body);
  font-size:.875rem;transition:color .2s;padding:.25rem 0;border-bottom:2px solid transparent}
.admin-nav a:hover,.admin-nav a.active{color:var(--gold);border-bottom-color:var(--gold)}
.nav-logout{color:#e74c3c!important}
.nav-logout:hover{border-bottom-color:#e74c3c!important}
.admin-main{min-height:calc(100vh - 60px);background:var(--dark)}
.admin-container{max-width:1400px;margin:0 auto;padding:2rem 1.5rem}
.admin-page-header{display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:1rem;margin-bottom:2rem}
.admin-page-header h1{font-family:var(--font-heading);color:var(--gold);font-size:1.6rem;margin:0}
.admin-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem;margin-bottom:2rem}
.stat-card{background:var(--card);border:1px solid var(--border);border-radius:8px;
  padding:1.25rem 1rem;text-align:center;transition:border-color .2s}
.stat-card:hover{border-color:var(--gold)}
.stat-card.stat-green{border-color:rgba(39,174,96,.3)}
.stat-card.stat-amber{border-color:rgba(243,156,18,.3)}
.stat-card.stat-red{border-color:rgba(231,76,60,.3)}
.stat-num{font-family:var(--font-heading);font-size:2rem;color:var(--gold);line-height:1}
.stat-label{font-size:.78rem;color:var(--muted);margin-top:.4rem;text-transform:uppercase;letter-spacing:.06em}
.admin-two-col{display:grid;grid-template-columns:2fr 1fr;gap:1.5rem;align-items:start}
@media(max-width:900px){.admin-two-col{grid-template-columns:1fr}}
.admin-card{background:var(--card);border:1px solid var(--border);border-radius:8px;overflow:hidden}
.admin-card-head{display:flex;justify-content:space-between;align-items:center;
  padding:1rem 1.25rem;border-bottom:1px solid var(--border)}
.admin-card-head h2{font-family:var(--font-heading);color:var(--gold);font-size:1rem;margin:0}
.table-wrap{overflow-x:auto}
.admin-table{width:100%;border-collapse:collapse;font-family:var(--font-body);font-size:.85rem}
.admin-table th{padding:.7rem 1rem;text-align:left;color:var(--muted);
  font-weight:600;border-bottom:1px solid var(--border);white-space:nowrap;font-size:.78rem;letter-spacing:.05em}
.admin-table td{padding:.75rem 1rem;border-bottom:1px solid rgba(255,255,255,.04);color:var(--text);vertical-align:middle}
.admin-table tr:last-child td{border-bottom:none}
.admin-table tr:hover td{background:rgba(201,168,76,.04)}
.btn-sm{padding:.3rem .75rem;border-radius:4px;background:transparent;border:1px solid var(--gold);
  color:var(--gold);font-size:.78rem;text-decoration:none;cursor:pointer;font-family:var(--font-body);
  transition:all .2s;display:inline-block}
.btn-sm:hover{background:var(--gold);color:#000}
.city-list{list-style:none;padding:0;margin:0}
.city-list li{display:flex;justify-content:space-between;padding:.65rem 1.25rem;
  border-bottom:1px solid var(--border);font-family:var(--font-body);font-size:.875rem}
.city-list li:last-child{border-bottom:none}
.city-name{color:var(--text)}
.city-cnt{color:var(--muted);font-size:.8rem}
.status-tabs{display:flex;gap:0;flex-wrap:wrap;margin-bottom:1.25rem;
  border-bottom:1px solid var(--border)}
.status-tab{padding:.6rem 1.1rem;color:var(--muted);text-decoration:none;
  font-family:var(--font-body);font-size:.85rem;border-bottom:2px solid transparent;transition:all .2s}
.status-tab:hover,.status-tab.active{color:var(--gold);border-bottom-color:var(--gold)}

/* Image manager */
.img-manager{display:flex;flex-wrap:wrap;gap:.75rem;padding:1.25rem}
.img-thumb-wrap{position:relative;display:flex;flex-direction:column;align-items:center;gap:.35rem}
.img-thumb{width:110px;height:140px;object-fit:cover;border-radius:6px;border:2px solid var(--border)}
.img-primary-badge{font-size:.7rem;background:var(--gold);color:#000;padding:.1rem .4rem;border-radius:4px}
.btn-img-action{font-size:.7rem;background:transparent;border:1px solid var(--gold);color:var(--gold);
  padding:.15rem .5rem;border-radius:4px;cursor:pointer}
.btn-img-delete{font-size:.7rem;background:transparent;border:1px solid #e74c3c;color:#e74c3c;
  padding:.15rem .5rem;border-radius:4px;cursor:pointer}

/* Buttons */
.btn{display:inline-block;padding:.6rem 1.4rem;border-radius:4px;font-family:var(--font-heading);
  font-size:.85rem;letter-spacing:.08em;text-decoration:none;cursor:pointer;
  border:1px solid transparent;transition:all .25s;text-align:center}
.btn-gold{background:var(--gold);color:#0d0a06;border-color:var(--gold)}
.btn-gold:hover{background:var(--gold-light,#d4b060);border-color:var(--gold-light,#d4b060)}
.btn-outline{background:transparent;color:var(--gold);border-color:var(--gold)}
.btn-outline:hover{background:var(--gold);color:#0d0a06}
.btn-lg{padding:.85rem 2rem;font-size:.95rem}

/* ===== SITE HEADER ===== */
.site-header{position:sticky;top:0;z-index:200;background:var(--dark);
  border-bottom:1px solid var(--border);backdrop-filter:blur(8px)}
.header-inner{display:flex;align-items:center;justify-content:space-between;
  padding:.9rem 1rem;gap:1rem;max-width:1300px;margin:0 auto}
.site-logo{display:flex;align-items:center;gap:.6rem;text-decoration:none;flex-shrink:0}
.logo-diamond{color:var(--gold);font-size:1.1rem}
.logo-text{font-family:var(--font-heading);font-size:1rem;color:var(--gold);line-height:1.2}
.logo-text em{display:block;font-style:normal;font-size:.7rem;color:var(--muted);letter-spacing:.1em;text-transform:uppercase}
.site-nav{display:flex;align-items:center;gap:1.5rem}
.nav-link{color:var(--muted);text-decoration:none;font-family:var(--font-body);font-size:.875rem;
  transition:color .2s;position:relative;padding:.2rem 0}
.nav-link::after{content:'';position:absolute;bottom:-2px;left:0;right:0;height:2px;
  background:var(--gold);transform:scaleX(0);transition:transform .2s}
.nav-link:hover,.nav-link.active{color:var(--gold)}
.nav-link:hover::after,.nav-link.active::after{transform:scaleX(1)}
.nav-logout{color:#c0392b!important}
.nav-cta{padding:.45rem 1.1rem!important}

/* ===== HAMBURGER ===== */
.hamburger{display:none;flex-direction:column;justify-content:center;
  gap:5px;background:transparent;border:none;cursor:pointer;padding:6px;
  border-radius:4px;flex-shrink:0}
.hamburger span{display:block;width:22px;height:2px;background:var(--gold);
  transition:all .3s;transform-origin:center}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ===== CONTAINER ===== */
.container{max-width:1300px;margin:0 auto;padding:0 1.5rem}

/* ===== HERO ===== */
.hero{text-align:center;padding:5rem 1.5rem 4rem;background:linear-gradient(135deg,#0d0a06 0%,#1a1208 50%,#0d0a06 100%)}
.hero-title{font-family:var(--font-heading);color:var(--gold);font-size:clamp(2rem,5vw,3.5rem);margin:0 0 1rem;line-height:1.2}
.hero-sub{font-family:var(--font-body);color:var(--muted);font-size:clamp(.95rem,2vw,1.2rem);max-width:560px;margin:0 auto 2rem}
.hero-btns{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.gold-divider{width:60px;height:2px;background:linear-gradient(to right,transparent,var(--gold),transparent);margin:1rem auto}
.section-title{font-family:var(--font-heading);color:var(--gold);font-size:clamp(1.2rem,3vw,1.8rem);margin:0 0 1.5rem}

/* ===== GRID ===== */
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}

/* ===== FOOTER ===== */
.site-footer{background:var(--card);border-top:1px solid var(--border);
  padding:2rem 1rem;text-align:center;color:var(--muted);font-family:var(--font-body);font-size:.85rem}

/* ===== MOBILE RESPONSIVE ===== */
@media (max-width:900px){
  .grid-4{grid-template-columns:repeat(3,1fr)}
  .grid-3{grid-template-columns:repeat(2,1fr)}
  .admin-two-col{grid-template-columns:1fr}
}

@media (max-width:768px){
  /* Hamburger visible */
  .hamburger{display:flex}

  /* Mobile nav drawer */
  .site-nav{
    display:none;
    position:absolute;
    top:100%;
    left:0;right:0;
    background:var(--card);
    border-top:1px solid var(--border);
    border-bottom:1px solid var(--border);
    flex-direction:column;
    align-items:stretch;
    padding:.5rem 0;
    gap:0;
    box-shadow:0 8px 24px rgba(0,0,0,.5);
    z-index:300
  }
  .site-header{position:relative}
  .site-nav.nav-open{display:flex}
  .nav-link{padding:.85rem 1.25rem;border-bottom:1px solid rgba(255,255,255,.06);font-size:.95rem}
  .nav-link::after{display:none}
  .nav-link:last-child{border-bottom:none}
  .nav-cta{margin:.5rem 1rem;text-align:center;border-radius:4px}

  /* Grids */
  .grid-4{grid-template-columns:repeat(2,1fr);gap:1rem}
  .grid-3{grid-template-columns:1fr}

  /* Hero */
  .hero{padding:3rem 1rem 2.5rem}
  .hero-btns{flex-direction:column;align-items:center}
  .hero-btns .btn{width:100%;max-width:280px}

  /* Filter bar */
  .filter-bar{flex-direction:column;align-items:stretch}
  .filter-bar .form-control,.filter-bar .btn,.filter-bar .btn-outline{width:100%}
  .checkbox-label{padding:.5rem 0}

  /* Costume detail */
  .costume-detail{grid-template-columns:1fr;gap:1.5rem}

  /* Gallery */
  .gallery-main img{aspect-ratio:4/3;max-height:320px}
  .gallery-thumbs{justify-content:center}

  /* Booking card */
  .booking-card{grid-template-columns:80px 1fr;gap:1rem}
  .booking-img img{width:80px;height:100px}
  .booking-status{grid-column:2;text-align:left}

  /* Dashboard stats */
  .stats-row{grid-template-columns:repeat(2,1fr)}
  .dash-header{flex-direction:column;align-items:flex-start}

  /* Profile */
  .form-row{grid-template-columns:1fr}
  .form-actions{flex-direction:column}
  .form-actions .btn{width:100%;text-align:center;justify-content:center}

  /* Auth box */
  .auth-box{padding:1.5rem 1.25rem}

  /* Admin */
  .admin-header-inner{flex-wrap:wrap;gap:.75rem}
  .admin-nav{gap:.6rem;font-size:.78rem;flex-wrap:wrap}
  .admin-stats{grid-template-columns:repeat(2,1fr)}
  .admin-page-header{flex-direction:column;align-items:flex-start;gap:.75rem}

  /* Table */
  .table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .admin-table{min-width:700px}

  /* Container */
  .container{padding:0 1rem}

  /* Hero SM */
  .hero-sm{padding:2rem 1rem}

  /* Cat pills scroll */
  .cat-pills{overflow-x:auto;flex-wrap:nowrap;padding-bottom:.5rem;
    scrollbar-width:none;-ms-overflow-style:none}
  .cat-pills::-webkit-scrollbar{display:none}
  .cat-pill{flex-shrink:0}

  /* OTP inputs on mobile */
  .otp-input{width:44px;height:54px;font-size:1.3rem}

  /* Pagination */
  .pagination{gap:.3rem}
  .page-btn{padding:.35rem .65rem;font-size:.8rem}
}

@media (max-width:480px){
  .grid-4{grid-template-columns:1fr}
  .stats-row{grid-template-columns:repeat(2,1fr)}
  .logo-text em{display:none}
  .booking-card{grid-template-columns:1fr}
  .booking-img img{width:100%;height:180px;border-radius:6px}
  .no-img-sm{width:100%;height:120px}
  .booking-status{grid-column:1;text-align:left}
  .admin-stats{grid-template-columns:1fr 1fr}
  .stat-num{font-size:1.6rem}
  .hero-title{font-size:1.75rem}
  .otp-input{width:40px;height:50px;font-size:1.2rem;gap:.4rem}
}

/* Touch targets */
@media (hover:none){
  .btn,.btn-sm,.nav-link,.page-btn,.cat-pill{min-height:44px;display:inline-flex;align-items:center;justify-content:center}
  .card-img img{transition:none}
}
