/* ===========================================================
   EMSR THEME — unified design system (Public + Admin + Booking)
   Single-file master stylesheet
   v1.2 (adds cards/forms/buttons/tables/admin layout/booking verify UI)
   =========================================================== */

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

:root{
  --emsr-gold:#d4af37;
  --emsr-gold2:#ffd700;
  --emsr-red:#ff1a2f;

  --emsr-bg:#050505;
  --emsr-surface:rgba(18,18,18,.88);
  --emsr-surface2:rgba(0,0,0,.55);
  --emsr-line:rgba(255,255,255,.10);
  --emsr-line2:rgba(255,255,255,.14);

  --emsr-txt:rgba(255,255,255,.92);
  --emsr-muted:rgba(255,255,255,.60);

  --emsr-r-lg:26px;
  --emsr-r-md:16px;
  --emsr-r-sm:12px;

  --emsr-shadow:0 20px 70px rgba(0,0,0,.45);

  /* wallpaper hook */
  --emsr-wallpaper:none;

  /* for sticky filter bars under navbar */
  --nav-padding-top: 86px;
}

/* base */
html,body{height:100%;}
body{
  margin:0;
  font-family:'Montserrat',system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--emsr-txt);
  background: var(--emsr-bg);
  overflow-x:hidden;
}

/* wallpaper + overlay */
body::before{
  content:"";
  position:fixed;
  inset:0;
  background-image:var(--emsr-wallpaper);
  background-size:cover;
  background-position:center;
  background-attachment:fixed;
  opacity:1;
  z-index:-2;
}
body::after{
  content:"";
  position:fixed;
  inset:0;
  background:rgba(5,5,5,.78);
  backdrop-filter: blur(1.5px);
  z-index:-1;
}

/* links */
a{color:inherit;text-decoration:none;}
a:hover{color:#fff;}

/* ===========================================================
   NAVBAR (Public, minimal & fast)
   =========================================================== */
.emsr-navbar{
  position:sticky; top:0; z-index:1000;
  border-bottom:1px solid rgba(255,255,255,.08);
  background:rgba(0,0,0,.55);
  backdrop-filter:blur(14px);
}
.emsr-navbar .nav-wrap{
  max-width:1600px;
  margin:0 auto;
  padding:10px 18px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
}

.emsr-brand{display:flex;align-items:center;gap:10px;}
.emsr-brand img{
  width:36px;height:36px;border-radius:999px;object-fit:contain;
  border:1px solid rgba(212,175,55,.35);
}
.emsr-brand .t1{
  font-weight:1000;letter-spacing:.14em;text-transform:uppercase;
  color:var(--emsr-gold);font-size:.86rem;line-height:1;
}
.emsr-brand .t2{
  font-size:.75rem;color:rgba(255,255,255,.60);
  line-height:1.2;margin-top:2px;
}

.emsr-nav{display:flex;align-items:center;gap:8px;flex-wrap:wrap;}
.emsr-nav a{
  height:40px;
  display:inline-flex;align-items:center;gap:8px;
  padding:0 12px;border-radius:999px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.03);
  color:rgba(255,255,255,.86);
  font-weight:900;letter-spacing:.08em;text-transform:uppercase;font-size:.70rem;
}
.emsr-nav a:hover{background:rgba(255,255,255,.06);color:#fff;border-color:rgba(255,255,255,.16);}
.emsr-nav a.active{
  border-color:rgba(212,175,55,.35);
  background:rgba(212,175,55,.14);
}

/* ===========================================================
   FOOTER (Public)
   =========================================================== */
.emsr-footer{
  border-top:1px solid rgba(255,255,255,.08);
  background:rgba(0,0,0,.55);
  backdrop-filter:blur(14px);
  padding:22px 18px;
}
.emsr-footer-inner{
  max-width:1600px;margin:0 auto;
  display:flex;flex-direction:column;align-items:center;gap:12px;
  text-align:center;
}
.emsr-footer-socials{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;}
.emsr-footer-socials a{
  width:44px;height:44px;border-radius:999px;
  display:inline-flex;align-items:center;justify-content:center;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.04);
  color:rgba(255,255,255,.90);
  transition:transform .16s, background .16s, border-color .16s;
}
.emsr-footer-socials a:hover{
  transform:translateY(-2px);
  background:rgba(255,255,255,.07);
  border-color:rgba(255,255,255,.18);
}
.emsr-copyright{
  margin:0;
  color:rgba(255,255,255,.70);
  font-weight:800;
  letter-spacing:.06em;
}

/* ?? RED HEART */
.emsr-heart-red{
  color: var(--emsr-red, #ff1a2f) !important;
  text-shadow: 0 0 14px rgba(255, 26, 47, .45);
  animation: emsrHeartPulse 1.6s ease-in-out infinite;
  display:inline-block;
}
@keyframes emsrHeartPulse{
  0%,100%{ transform:scale(1); opacity:1; }
  50%{ transform:scale(1.12); opacity:.95; }
}
@media (prefers-reduced-motion: reduce){
  .emsr-heart-red{ animation:none; }
}

/* Scrollbars */
*{scrollbar-width:thin;scrollbar-color:rgba(212,175,55,.55) rgba(255,255,255,.08);}
*::-webkit-scrollbar{width:10px;height:10px;}
*::-webkit-scrollbar-track{background:rgba(255,255,255,.06);}
*::-webkit-scrollbar-thumb{
  background:rgba(212,175,55,.55);
  border-radius:999px;
  border:2px solid rgba(0,0,0,.55);
}
*::-webkit-scrollbar-thumb:hover{background:rgba(212,175,55,.85);}

/* ===========================================================
   GLOBAL LAYOUT + UTILITIES
   =========================================================== */
.emsr-container{
  max-width:1600px;
  margin:0 auto;
  padding:20px 18px 90px;
}
.emsr-center{display:flex;align-items:center;justify-content:center;}
.emsr-muted{color:var(--emsr-muted);}
.emsr-gold{color:var(--emsr-gold);}
.emsr-spacer{height:14px;}
.emsr-stack{display:flex;flex-direction:column;gap:12px;}
.emsr-row{display:flex;gap:12px;flex-wrap:wrap;}
.emsr-row > *{flex:1;min-width:220px;}

.emsr-glass{
  border:1px solid var(--emsr-line);
  background:rgba(0,0,0,.45);
  backdrop-filter:blur(14px);
  border-radius:var(--emsr-r-lg);
  box-shadow:var(--emsr-shadow);
}

.emsr-card{
  border:1px solid var(--emsr-line);
  background:rgba(255,255,255,.03);
  border-radius:var(--emsr-r-lg);
  box-shadow:0 12px 50px rgba(0,0,0,.35);
  overflow:hidden;
}
.emsr-card__head{
  padding:14px 18px;
  border-bottom:1px solid rgba(255,255,255,.08);
  background:rgba(0,0,0,.35);
  display:flex;align-items:center;justify-content:space-between;gap:10px;
}
.emsr-card__body{padding:16px 18px;}

.emsr-title{
  margin:0;
  font-size:1.15rem;
  font-weight:900;
  letter-spacing:.04em;
}
.emsr-h1{
  margin:0 0 18px;
  text-align:center;
  font-size:1.55rem;
  font-weight:1000;
  letter-spacing:.06em;
}

/* Pills/Badges */
.emsr-pill{
  display:inline-flex;align-items:center;gap:8px;
  height:34px;padding:0 10px;border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.04);
  color:rgba(255,255,255,.86);
  font-weight:900;letter-spacing:.08em;text-transform:uppercase;font-size:.64rem;
}
.emsr-badge{
  display:inline-flex;align-items:center;gap:6px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);
  border-radius:999px;padding:2px 8px;
  font-size:.75rem;font-weight:900;
}
.emsr-dot{width:9px;height:9px;border-radius:999px;display:inline-block;}
.emsr-dot.ok{background:#22c55e;}
.emsr-dot.off{background:#64748b;}
.emsr-dot.hot{background:var(--emsr-red);box-shadow:0 0 18px rgba(255,26,47,.35);}

/* ===========================================================
   FORMS (Public + Admin + Booking)
   =========================================================== */
label{
  display:block;
  margin:12px 0 6px;
  font-weight:900;
  letter-spacing:.03em;
  color:rgba(255,255,255,.86);
}
.emsr-input,
.emsr-select,
.emsr-textarea,
input[type="text"],
input[type="email"],
input[type="tel"],
input[type="number"],
input[type="date"],
input[type="time"],
input[type="password"],
select,
textarea{
  width:100%;
  box-sizing:border-box;

  border-radius:var(--emsr-r-md);
  border:1px solid rgba(255,255,255,.14);
  background:rgba(0,0,0,.30);
  color:#fff;

  padding:12px 14px;
  font-size:.95rem;
  outline:none;
}
textarea,
.emsr-textarea{
  min-height:140px;
  resize:vertical;
}
.emsr-input:focus,
.emsr-select:focus,
.emsr-textarea:focus,
input:focus,
select:focus,
textarea:focus{
  border-color:rgba(212,175,55,.40);
  box-shadow:0 0 0 4px rgba(212,175,55,.12);
}
::placeholder{color:rgba(255,255,255,.35);}

/* File input nicer */
input[type="file"]{
  padding:12px 14px;
  border-radius:var(--emsr-r-md);
  border:1px dashed rgba(255,255,255,.20);
  background:rgba(0,0,0,.22);
}

/* ===========================================================
   BUTTONS
   =========================================================== */
.emsr-btn,
button,
input[type="submit"]{
  height:46px;
  padding:0 14px;
  border-radius:var(--emsr-r-md);
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.04);
  color:#fff;
  font-weight:900;
  letter-spacing:.10em;
  text-transform:uppercase;
  font-size:.72rem;

  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;

  transition:transform .16s, background .16s, border-color .16s, filter .16s;
  cursor:pointer;
}
.emsr-btn:hover,
button:hover,
input[type="submit"]:hover{
  transform:translateY(-1px);
  background:rgba(255,255,255,.07);
  border-color:rgba(255,255,255,.18);
}
.emsr-btn:disabled,
button:disabled,
input[type="submit"]:disabled{
  opacity:.55;
  cursor:not-allowed;
  transform:none;
}

.emsr-btn--gold{
  background:linear-gradient(135deg, rgba(212,175,55,.95), rgba(255,215,0,.90));
  border-color:rgba(212,175,55,.95);
  color:#000;
}
.emsr-btn--gold:hover{filter:brightness(1.05);color:#000;}

.emsr-btn--danger{
  background:rgba(220,38,38,.20);
  border-color:rgba(220,38,38,.35);
}
.emsr-btn--danger:hover{
  background:rgba(220,38,38,.28);
  border-color:rgba(220,38,38,.45);
}

/* Small buttons */
.emsr-btn--sm{height:40px;font-size:.68rem;padding:0 12px;border-radius:14px;}
.emsr-btn--xs{height:34px;font-size:.64rem;padding:0 10px;border-radius:999px;letter-spacing:.08em;}

/* ===========================================================
   ALERTS (OK/ERR/INFO)
   =========================================================== */
.emsr-alert{
  border-radius:var(--emsr-r-md);
  padding:12px 14px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.04);
}
.emsr-alert--ok{
  background:rgba(34,197,94,.12);
  border-color:rgba(34,197,94,.35);
}
.emsr-alert--err{
  background:rgba(255,26,47,.12);
  border-color:rgba(255,26,47,.35);
}
.emsr-alert--info{
  background:rgba(212,175,55,.12);
  border-color:rgba(212,175,55,.30);
}
.emsr-help{
  margin-top:8px;
  color:rgba(255,255,255,.60);
  font-size:.82rem;
  line-height:1.35;
}

/* ===========================================================
   TABLES
   =========================================================== */
.emsr-tablewrap{
  border:1px solid rgba(255,255,255,.12);
  border-radius:var(--emsr-r-lg);
  overflow:hidden;
  background:rgba(0,0,0,.45);
}
table.emsr-table{
  width:100%;
  border-collapse:collapse;
}
table.emsr-table th{
  position:sticky;top:0;z-index:1;
  padding:12px 12px;
  font-size:.72rem;text-transform:uppercase;letter-spacing:1px;
  color:rgba(255,255,255,.65);
  background:rgba(0,0,0,.75);
  border-bottom:1px solid rgba(255,255,255,.10);
  text-align:left;
}
table.emsr-table td{
  padding:12px 12px;
  border-bottom:1px solid rgba(255,255,255,.06);
  vertical-align:middle;
}
table.emsr-table tr:hover{background:rgba(255,255,255,.04);}

/* ===========================================================
   BOOKING/VERIFY UI (Stepper + code box)
   =========================================================== */
.emsr-stepper{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  justify-content:center;
  margin:10px 0 18px;
}
.emsr-step{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:10px 12px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.04);
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-size:.66rem;
  color:rgba(255,255,255,.78);
}
.emsr-step .n{
  width:26px;height:26px;border-radius:999px;
  display:inline-flex;align-items:center;justify-content:center;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(0,0,0,.35);
  color:rgba(255,255,255,.86);
}
.emsr-step.is-active{
  border-color:rgba(212,175,55,.30);
  background:rgba(212,175,55,.12);
  color:#fff;
}
.emsr-step.is-done{
  border-color:rgba(34,197,94,.30);
  background:rgba(34,197,94,.10);
  color:#fff;
}
.emsr-code{
  letter-spacing:.28em;
  font-weight:1000;
  text-align:center;
  font-size:1.2rem;
}

/* Sticky filter bar helper (under navbar) */
.emsr-stickybar{
  position:sticky;
  top:var(--nav-padding-top);
  z-index:900;
  margin-bottom:14px;
}

/* ===========================================================
   ADMIN LAYOUT + SIDEBAR SCROLL FIX
   =========================================================== */
.admin-layout{display:flex;min-height:100vh;}
.admin-sidebar{
  width:270px;
  position:fixed;left:0;top:0;bottom:0;
  background:rgba(0,0,0,.72);
  border-right:1px solid rgba(255,255,255,.08);
  backdrop-filter:blur(14px);
  z-index:1000;
  overflow:hidden; /* IMPORTANT: only inner scroll */
}
.admin-main{
  margin-left:270px;
  flex:1;
  padding:26px 22px 100px;
  min-height:100vh;
}
@media (max-width:992px){
  .admin-sidebar{position:relative;width:100%;height:auto;}
  .admin-main{margin-left:0;padding:16px 14px 80px;}
}

.sb-shell{height:100%;display:flex;flex-direction:column;}
.sb-header{
  padding:16px 16px 12px;
  border-bottom:1px solid rgba(255,255,255,.08);
  position:sticky;top:0;z-index:2;
  background:rgba(0,0,0,.78);
  backdrop-filter:blur(14px);
}
.sb-scroll{
  flex:1 1 auto;
  overflow-y:auto;
  padding:12px 10px 16px;
}
.sb-footer{
  border-top:1px solid rgba(255,255,255,.08);
  padding:12px 12px;
  background:rgba(0,0,0,.65);
}

.sb-cat{
  margin:16px 10px 8px;
  color:rgba(255,255,255,.50);
  font-size:.72rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  font-weight:1000;
}
.sb-link{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:10px 12px;
  border-radius:14px;
  color:rgba(255,255,255,.86);
  border:1px solid transparent;
}
.sb-link:hover{background:rgba(255,255,255,.06);color:#fff;}
.sb-link.is-active{
  background:rgba(212,175,55,.14);
  border-color:rgba(212,175,55,.22);
}
.sb-left{display:flex;align-items:center;gap:10px;}
.sb-left i{color:var(--emsr-gold);min-width:18px;text-align:center;}
.sb-mini{font-size:.72rem;color:rgba(255,255,255,.55);}

.sb-stats{
  margin:14px 10px 8px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.04);
  border-radius:18px;
  padding:10px 10px 6px;
}
.sb-stats .grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:8px;}
.sb-stats .box{
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.25);
  border-radius:16px;
  padding:8px 10px;
}
.sb-stats .k{font-size:.70rem;color:rgba(255,255,255,.55);text-transform:uppercase;letter-spacing:.12em;font-weight:1000;}
.sb-stats .v{font-weight:1000;font-size:.95rem;margin-top:2px;}
.sb-stats b{color:var(--emsr-gold);}

/* ===========================================================
   RESPONSIVE TWEAKS
   =========================================================== */
@media (max-width:640px){
  .emsr-navbar .nav-wrap{padding:10px 12px;}
  .emsr-container{padding:16px 12px 80px;}
  .emsr-h1{font-size:1.35rem;}
  .emsr-row > *{min-width:160px;}
}
