:root{--bg:#E7E1D5;--gold:#A18556;--white:#FFFFFF;--black:#000000;}


/* ===== Modern baseline ===== */
*{box-sizing:border-box}
html,body{height:100%}
body{font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility}
a{text-decoration:none}
.container{max-width:1100px;margin:0 auto}
.grid{display:grid;gap:16px}
.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
@media(max-width:900px){.grid-2{grid-template-columns:1fr}}


*{box-sizing:border-box}
body{margin:0;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Arial,Helvetica,sans-serif;
background:radial-gradient(circle at 10% 10%, rgba(161,133,86,.10), transparent 40%),
radial-gradient(circle at 90% 20%, rgba(0,0,0,.05), transparent 45%), var(--bg);
color:var(--black);min-height:100vh;}
a{color:var(--black);text-decoration:none}
.container{max-width:1100px;margin:0 auto;padding:18px;}
.shell{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;}
.card{width:100%;max-width:540px;background:var(--white);border-radius:16px;box-shadow:0 18px 45px rgba(0,0,0,.18);
border:1px solid rgba(0,0,0,.08);overflow:hidden;}
.card-header{padding:22px 22px 14px 22px;border-bottom:1px solid rgba(0,0,0,.08);
background:linear-gradient(135deg, rgba(161,133,86,.16), rgba(231,225,213,0));}
.brand{display:flex;gap:12px;align-items:center;}
.logo{width:44px;height:44px;border-radius:12px;background:var(--gold);display:flex;align-items:center;justify-content:center;
color:var(--white);font-weight:800;letter-spacing:.5px;}
.brand h1{margin:0;font-size:14px;letter-spacing:.10em;text-transform:uppercase;}
.brand p{margin:3px 0 0 0;font-size:12px;opacity:.75;}
.card-body{padding:18px 22px 22px 22px;}
label{display:block;font-size:12px;margin-top:10px;margin-bottom:6px;opacity:.85}
input,select,textarea{width:100%;padding:11px 12px;border-radius:10px;border:1px solid rgba(0,0,0,.18);background:var(--white);outline:none}
input:focus,select:focus,textarea:focus{border-color:rgba(161,133,86,.9);box-shadow:0 0 0 4px rgba(161,133,86,.18)}
.row{display:flex;gap:10px;flex-wrap:wrap}
.row>div{flex:1;min-width:180px}
.actions{margin-top:16px;display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.btn{appearance:none;border:none;background:var(--gold);color:var(--white);padding:11px 14px;border-radius:12px;font-weight:700;cursor:pointer}
.btn.block{width:100%}
.btn.secondary{background:transparent;color:var(--black);border:1px solid rgba(0,0,0,.18)}
.helper{margin-top:14px;font-size:12px;opacity:.8;display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap}
.topbar{background:rgba(255,255,255,.65);backdrop-filter:blur(8px);border-bottom:1px solid rgba(0,0,0,.08)}
.topbar .container{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.nav{display:flex;gap:10px;flex-wrap:wrap}
.nav a{display:inline-block;padding:10px 12px;border-radius:999px;border:1px solid rgba(0,0,0,.12);background:var(--white);font-size:12px}
.pill{padding:8px 12px;border-radius:999px;border:1px solid rgba(0,0,0,.12);background:var(--white);font-size:12px}
.grid{display:grid;gap:14px;grid-template-columns:repeat(12,1fr)}
.card-lg{grid-column:span 12;background:var(--white);border-radius:16px;border:1px solid rgba(0,0,0,.08);
box-shadow:0 14px 35px rgba(0,0,0,.12);padding:18px}
@media (min-width:920px){.card-lg.half{grid-column:span 6}}
.small{font-size:12px;opacity:.8}
.alert{padding:10px 12px;border-radius:12px;border:1px solid rgba(0,0,0,.12);background:rgba(231,225,213,.6);margin-bottom:12px}
.table{width:100%;border-collapse:separate;border-spacing:0 10px}
.table th{font-size:12px;text-align:left;opacity:.8}
.table td{background:var(--white);border:1px solid rgba(0,0,0,.08);padding:10px;border-left:none;border-right:none}
.table tr td:first-child{border-left:1px solid rgba(0,0,0,.08);border-top-left-radius:12px;border-bottom-left-radius:12px}
.table tr td:last-child{border-right:1px solid rgba(0,0,0,.08);border-top-right-radius:12px;border-bottom-right-radius:12px}
.seats{margin-top:10px;display:grid;grid-template-columns:repeat(3,1fr);gap:10px;align-items:center;justify-items:center}
.seat{padding:10px 0;border-radius:12px;border:1px solid rgba(0,0,0,.12);text-align:center;cursor:pointer;background:var(--white);user-select:none}
.seat.taken{opacity:.45;cursor:not-allowed}
.seat.selected{outline:3px solid rgba(161,133,86,.35);border-color:rgba(161,133,86,.9)}
.qrbox{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.qr{width:200px;height:200px;border:1px solid rgba(0,0,0,.12);border-radius:16px;background:var(--white);display:flex;align-items:center;justify-content:center;overflow:hidden}
code{font-size:12px}


.seat.pos-top{grid-column:2;}
.seat.pos-left{grid-column:1;}
.seat.pos-right{grid-column:3;}

.badge{display:inline-block;padding:6px 10px;border-radius:999px;border:1px solid rgba(0,0,0,.12);background:var(--white);font-size:12px}

.alert.success{border-color:rgba(0,0,0,.12);background:#E7E1D5}

.kpi{display:flex;gap:16px;flex-wrap:wrap;margin-top:6px}
.kpi .k{font-size:12px;opacity:.7}
.kpi .v{font-size:22px;font-weight:800;margin-top:2px}
.scroll{overflow:auto}
.alert{padding:10px 12px;border-radius:14px;background:#E7E1D5;border:1px solid rgba(0,0,0,.08);margin-top:10px}


/* ===== UI/UX polish v19 ===== */
:root{
  --radius:18px;
  --shadow: 0 18px 45px rgba(0,0,0,.18);
  --line: rgba(0,0,0,.08);
  --muted: rgba(0,0,0,.65);
}
/* Make typography consistent */
h1,h2,h3{letter-spacing:-.02em}
p{color:var(--muted);line-height:1.45}

/* Topbar */
.topbar{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.70);backdrop-filter: blur(10px);
  border-bottom:1px solid var(--line);}
.topbar-inner{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 18px;}
.brand-text{display:flex;flex-direction:column;gap:2px}
.brand-title{font-size:12px;letter-spacing:.14em;text-transform:uppercase;font-weight:800}
.brand-sub{font-size:12px;opacity:.75}

/* Nav pills */
.nav{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.nav-link{display:inline-flex;align-items:center;gap:8px;
  padding:9px 12px;border-radius:999px;border:1px solid var(--line);
  background:rgba(255,255,255,.85);font-weight:700;font-size:13px}
.nav-link:hover{background:rgba(231,225,213,.70)}

.nav-link__icon{width:20px;height:20px;object-fit:contain;flex:0 0 20px;display:block}
.luxury-action__icon--img{padding:0;background:transparent}
.luxury-action__icon--img img{width:44px;height:44px;object-fit:contain;display:block}
.nav-link--admin{border-color:rgba(161,133,86,.35)}
.nav-link--danger{border-color:rgba(0,0,0,.18)}
.nav-link--danger:hover{background:rgba(0,0,0,.06)}

/* Hamburger */
.nav-toggle{display:none; width:44px;height:44px;border-radius:12px;border:1px solid var(--line);
  background:rgba(255,255,255,.85);align-items:center;justify-content:center;gap:5px}
.nav-toggle span{display:block;width:18px;height:2px;background:var(--black);border-radius:2px;opacity:.9}

/* Cards */
.card{border-radius:var(--radius);box-shadow:var(--shadow)}
.card-header{border-bottom:1px solid var(--line)}
.section{margin-top:18px}
.section-title{display:flex;align-items:flex-end;justify-content:space-between;gap:12px}
.badge{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;background:rgba(161,133,86,.14);
  border:1px solid rgba(161,133,86,.30);font-weight:800;font-size:12px}

/* Link buttons inside content */
.links{display:flex;flex-wrap:wrap;gap:10px;margin-top:10px}
.links a{display:inline-flex;align-items:center;justify-content:center;
  padding:10px 12px;border-radius:14px;border:1px solid var(--line);
  background:rgba(231,225,213,.55);font-weight:800}
.links a:hover{background:rgba(161,133,86,.12)}

/* Tables responsive */
.table{width:100%;border-collapse:separate;border-spacing:0 10px}
.table th{font-size:12px;text-transform:uppercase;letter-spacing:.12em;opacity:.7;text-align:left;padding:6px 10px}
.table td{background:rgba(255,255,255,.9);border:1px solid var(--line);padding:12px 10px}
.table tr td:first-child{border-top-left-radius:14px;border-bottom-left-radius:14px}
.table tr td:last-child{border-top-right-radius:14px;border-bottom-right-radius:14px}

/* Forms */
input,select,textarea{border-radius:14px}
button,.btn{border-radius:14px}

/* Mobile layout */
@media (max-width: 820px){
  .topbar-inner{flex-wrap:wrap}
  .nav-toggle{display:inline-flex}
  .nav{display:none; width:100%; justify-content:flex-start; padding:10px 0 2px 0}
  .nav.nav--open{display:flex}
  .nav-link{font-size:14px}
  .container{padding:14px}
}

/* Tiny screens */
@media (max-width: 420px){
  .logo{width:40px;height:40px;border-radius:12px}
  .brand-title{font-size:11px}
}

/* Make old underlined links look like buttons when inside cards */
.card a{color:var(--black)}


/* Mobile nav as sheet */
@media (max-width: 820px){
  .nav.nav--open{
    display:flex;
    flex-direction:column;
    align-items:stretch;
    gap:10px;
    padding:12px 0 4px;
    background:rgba(255,255,255,.75);
    border-top:1px solid rgba(0,0,0,.06);
  }
  .nav-link{justify-content:center; padding:12px 14px}
}

/* Better cards spacing */
.card{overflow:hidden}
.card-body{padding:18px}
.card-header{padding:16px 18px}
@media(max-width:820px){
  .card-body{padding:16px}
  .card-header{padding:14px 16px}
}



/* ===== Packages table: perfect mobile layout ===== */
.table-wrap{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:6px}
.table-packages{min-width:640px}
.td-actions{background:transparent !important;border:none !important;white-space:nowrap}
.td-actions .btn{width:110px}

@media (max-width: 520px){
  /* Switch to cards instead of wide table */
  .table-wrap{overflow:visible}
  .table-packages{min-width:0}
  .table-packages thead{display:none}
  .table-packages, .table-packages tbody, .table-packages tr, .table-packages td{display:block;width:100%}
  .table-packages tr{
    background:rgba(255,255,255,.92);
    border:1px solid rgba(0,0,0,.08);
    border-radius:16px;
    padding:12px;
    margin:10px 0;
  }
  .table-packages td{
    border:none !important;
    background:transparent !important;
    padding:6px 0 !important;
  }
  .table-packages td::before{
    content:attr(data-label);
    display:block;
    font-size:11px;
    letter-spacing:.12em;
    text-transform:uppercase;
    opacity:.65;
    margin-bottom:2px;
    font-weight:800;
  }
  .table-packages .td-actions{padding-top:10px !important}
  .table-packages .td-actions .btn{width:100%}
}


/* ===== Purchases table: perfect mobile layout ===== */
.table-purchases{min-width:760px}
.code-clip{display:inline-block;max-width:220px;overflow:hidden;text-overflow:ellipsis;vertical-align:middle}
@media (max-width: 520px){
  .table-purchases{min-width:0}
  .table-purchases thead{display:none}
  .table-purchases, .table-purchases tbody, .table-purchases tr, .table-purchases td{display:block;width:100%}
  .table-purchases tr{
    background:rgba(255,255,255,.92);
    border:1px solid rgba(0,0,0,.08);
    border-radius:16px;
    padding:12px;
    margin:10px 0;
  }
  .table-purchases td{
    border:none !important;
    background:transparent !important;
    padding:6px 0 !important;
  }
  .table-purchases td::before{
    content:attr(data-label);
    display:block;
    font-size:11px;
    letter-spacing:.12em;
    text-transform:uppercase;
    opacity:.65;
    margin-bottom:2px;
    font-weight:800;
  }
  .code-clip{max-width:100%}
}


/* ===== Generic responsive-card tables (ALL modules) ===== */
.table-responsive-card{width:100%}
@media (max-width: 520px){
  table.table-responsive-card thead{display:none}
  table.table-responsive-card, 
  table.table-responsive-card tbody, 
  table.table-responsive-card tr, 
  table.table-responsive-card td{display:block;width:100%}
  table.table-responsive-card tr{
    background:rgba(255,255,255,.92);
    border:1px solid rgba(0,0,0,.08);
    border-radius:16px;
    padding:12px;
    margin:10px 0;
  }
  table.table-responsive-card td{
    border:none !important;
    background:transparent !important;
    padding:6px 0 !important;
    word-break:break-word;
  }
  table.table-responsive-card td::before{
    content:attr(data-label);
    display:block;
    font-size:11px;
    letter-spacing:.12em;
    text-transform:uppercase;
    opacity:.65;
    margin-bottom:2px;
    font-weight:800;
  }
  /* action cells */
  table.table-responsive-card td.td-actions .btn{width:100%}
}


/* ===== Reformer seat selector (beautiful) ===== */
.seats{
  display:flex;
  justify-content:center;
  gap:26px;
  margin:10px 0 0;
}
.seats-col{display:flex;flex-direction:column;gap:14px}
.seat{
  appearance:none;
  border:0;
  background:transparent;
  padding:0;
  cursor:pointer;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:8px;
}
.seat:focus{outline:none}
.seat .reformer{
  width:52px;
  height:92px;
  border-radius:18px;
  border:2px solid rgba(0,0,0,.72);
  background:
    radial-gradient(circle at 10px 12px, rgba(0,0,0,.75) 0 2px, transparent 3px),
    radial-gradient(circle at 10px 28px, rgba(0,0,0,.75) 0 2px, transparent 3px),
    radial-gradient(circle at 10px 44px, rgba(0,0,0,.75) 0 2px, transparent 3px),
    radial-gradient(circle at 10px 60px, rgba(0,0,0,.75) 0 2px, transparent 3px),
    radial-gradient(circle at 42px 12px, rgba(0,0,0,.75) 0 2px, transparent 3px),
    radial-gradient(circle at 42px 28px, rgba(0,0,0,.75) 0 2px, transparent 3px),
    radial-gradient(circle at 42px 44px, rgba(0,0,0,.75) 0 2px, transparent 3px),
    radial-gradient(circle at 42px 60px, rgba(0,0,0,.75) 0 2px, transparent 3px),
    linear-gradient(to bottom, rgba(0,0,0,.08), rgba(0,0,0,.02));
  position:relative;
  box-shadow: 0 10px 24px rgba(0,0,0,.10);
}
/* headrest */
.seat .reformer::before{
  content:"";
  position:absolute;
  top:-12px;
  left:50%;
  transform:translateX(-50%);
  width:22px;
  height:18px;
  border-radius:10px 10px 6px 6px;
  border:2px solid rgba(0,0,0,.72);
  background:rgba(255,255,255,.70);
}
/* footbar */
.seat .reformer::after{
  content:"";
  position:absolute;
  bottom:-10px;
  left:50%;
  transform:translateX(-50%);
  width:26px;
  height:14px;
  border-radius:8px;
  border:2px solid rgba(0,0,0,.72);
  background:rgba(255,255,255,.70);
}

.seat-num{
  font-weight:900;
  font-size:14px;
  width:30px;height:30px;
  border-radius:999px;
  display:grid;place-items:center;
  border:1px solid rgba(0,0,0,.10);
  background:rgba(255,255,255,.85);
}

.seat:hover .reformer{transform:translateY(-1px); transition:transform .12s ease}
.seat.selected .reformer{
  border-color: rgba(161,133,86,.95);
  box-shadow: 0 16px 34px rgba(161,133,86,.18);
}
.seat.selected .seat-num{background:rgba(161,133,86,.14);border-color:rgba(161,133,86,.35)}

.seat.taken{cursor:not-allowed; opacity:.35}
.seat.taken .reformer{filter:grayscale(1)}
.seat.taken .seat-num{opacity:.6}

/* Keep it neat on small phones */
@media (max-width: 360px){
  .seats{gap:18px}
  .seat .reformer{width:46px;height:82px}
}


/* ===== Reformer layout refinements (aligned columns) ===== */
.seats{
  align-items:flex-start;
  gap:34px;
}
.seats-col{
  width:140px;
}
.seat{
  width:100%;
}
.seat .reformer{
  width:72px;
  height:120px;
  border-radius:22px;
  background:
    radial-gradient(circle at 14px 18px, rgba(0,0,0,.72) 0 2px, transparent 3px),
    radial-gradient(circle at 14px 38px, rgba(0,0,0,.72) 0 2px, transparent 3px),
    radial-gradient(circle at 14px 58px, rgba(0,0,0,.72) 0 2px, transparent 3px),
    radial-gradient(circle at 14px 78px, rgba(0,0,0,.72) 0 2px, transparent 3px),
    radial-gradient(circle at 58px 18px, rgba(0,0,0,.72) 0 2px, transparent 3px),
    radial-gradient(circle at 58px 38px, rgba(0,0,0,.72) 0 2px, transparent 3px),
    radial-gradient(circle at 58px 58px, rgba(0,0,0,.72) 0 2px, transparent 3px),
    radial-gradient(circle at 58px 78px, rgba(0,0,0,.72) 0 2px, transparent 3px),
    linear-gradient(to bottom, rgba(0,0,0,.10), rgba(0,0,0,.03));
  box-shadow: 0 14px 30px rgba(0,0,0,.12);
}
.seat .reformer::before{
  top:-14px;
  width:28px;height:20px;
}
.seat .reformer::after{
  bottom:-12px;
  width:32px;height:16px;
}
.seat-num{
  margin-top:-2px;
  width:34px;height:34px;
  font-size:14px;
  box-shadow: 0 10px 18px rgba(0,0,0,.08);
}
@media (max-width: 520px){
  .seats{gap:22px}
  .seats-col{width:120px}
  .seat .reformer{width:66px;height:112px}
}


/* ===== Brand bg variable ===== */
body{
  background-image: var(--brand-bg), radial-gradient(circle at 20% 10%, rgba(255,255,255,.65), rgba(231,225,213,.85));
  background-size: cover, auto;
  background-position: center, center;
  background-attachment: fixed, fixed;
}
body::before{
  content:"";
  position:fixed; inset:0;
  background: rgba(231,225,213,.55);
  pointer-events:none;
  z-index:-1;
}
@media(max-width:820px){
  body{background-attachment: scroll, scroll;}
}
.brand-badge--img{padding:6px}
.brand-logo{height:44px; width:auto; display:block; border-radius:12px}
@media(max-width:520px){
  .brand-logo{height:38px}
}


/* ===== Schedule accordion ===== */
.class-item{border:1px solid rgba(0,0,0,.08);border-radius:18px;padding:10px 12px;margin-top:12px;background:rgba(255,255,255,.72);backdrop-filter: blur(6px);}
.class-item[open]{background:rgba(255,255,255,.86);}
.class-summary{cursor:pointer;list-style:none;display:flex;gap:12px;align-items:center;justify-content:space-between;}
.class-summary::-webkit-details-marker{display:none;}
.class-title{font-weight:800;font-size:18px;line-height:1.15;}
.class-summary__left{min-width:0}
.class-summary__right{display:flex;gap:10px;align-items:center;flex-shrink:0}
.pill{display:inline-flex;align-items:center;justify-content:center;padding:8px 12px;border-radius:999px;border:1px solid rgba(0,0,0,.10);background:#fff;font-weight:700}
.class-body{padding-top:10px}
.seats--compact{margin-top:8px}
@media(max-width:520px){
  .class-title{font-size:17px}
  .pill{padding:7px 10px}
  .class-summary__right{gap:8px}
}


/* ===== Visual refresh v23 ===== */
:root{
  --surface: rgba(255,255,255,.78);
  --surface-strong: rgba(255,255,255,.90);
  --line-soft: rgba(0,0,0,.08);
  --shadow-soft: 0 18px 45px rgba(0,0,0,.10);
  --shadow-hover: 0 26px 55px rgba(0,0,0,.14);
}

body{
  background:
    radial-gradient(circle at 0% 0%, rgba(255,255,255,.55), transparent 28%),
    radial-gradient(circle at 100% 0%, rgba(161,133,86,.10), transparent 22%),
    radial-gradient(circle at 50% 100%, rgba(161,133,86,.10), transparent 25%),
    var(--bg);
}

.card-lg,.card,.class-item{
  background: var(--surface);
  backdrop-filter: blur(10px);
  box-shadow: var(--shadow-soft);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease, background .18s ease;
}
@media (hover:hover){
  .card-lg:hover,.card:hover,.class-item:hover{
    transform: translateY(-2px);
    box-shadow: var(--shadow-hover);
  }
}

.topbar{
  background: rgba(255,255,255,.74);
  backdrop-filter: blur(12px);
  border-bottom:1px solid var(--line-soft);
}
.topbar-inner{padding-top:12px;padding-bottom:12px}
.nav-link, .nav a{
  transition: transform .14s ease, background .14s ease, border-color .14s ease, box-shadow .14s ease;
}
.nav-link:hover, .nav a:hover{
  transform: translateY(-1px);
  box-shadow: 0 8px 20px rgba(0,0,0,.06);
}
.btn{
  background: linear-gradient(180deg, rgba(161,133,86,1) 0%, rgba(147,120,74,1) 100%);
  box-shadow: 0 10px 22px rgba(161,133,86,.20);
  transition: transform .15s ease, box-shadow .15s ease, opacity .15s ease;
}
.btn:hover{ transform: translateY(-1px); box-shadow: 0 14px 28px rgba(161,133,86,.24); }
.btn:active{ transform: translateY(0); }
input,select,textarea{
  border-radius:14px;
  border:1px solid rgba(0,0,0,.10);
  background: rgba(255,255,255,.9);
  transition: border-color .15s ease, box-shadow .15s ease, background .15s ease;
}
input:focus,select:focus,textarea:focus{
  outline:none;
  border-color: rgba(161,133,86,.55);
  box-shadow: 0 0 0 4px rgba(161,133,86,.10);
  background:#fff;
}
.page-hero{
  display:flex;align-items:center;justify-content:space-between;gap:18px;
  margin-bottom:16px;padding:18px 20px;border:1px solid var(--line-soft);
  border-radius:20px;background:linear-gradient(135deg, rgba(255,255,255,.84), rgba(231,225,213,.78));
  box-shadow: var(--shadow-soft);
}
.eyebrow{
  display:inline-block;
  font-size:11px; letter-spacing:.16em; text-transform:uppercase;
  font-weight:800; opacity:.65; margin-bottom:8px;
}
.class-item{border-radius:20px}
.class-summary__right .badge{background:#fff}
.pill{
  background: linear-gradient(180deg, rgba(255,255,255,.92), rgba(245,241,233,.92));
  border-color: rgba(161,133,86,.22);
  font-weight:800;
}
.links{
  display:flex; flex-wrap:wrap; gap:10px;
}
.links a{
  display:inline-flex; align-items:center; justify-content:center;
  padding:12px 14px; border-radius:14px; border:1px solid rgba(0,0,0,.08);
  background:linear-gradient(180deg, rgba(255,255,255,.95), rgba(245,241,233,.95));
  box-shadow:0 10px 24px rgba(0,0,0,.05);
  font-weight:800;
  transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}
.links a:hover{ transform:translateY(-1px); box-shadow:0 16px 28px rgba(0,0,0,.08); border-color: rgba(161,133,86,.35); }
.badge{
  background:rgba(255,255,255,.92);
  box-shadow: 0 8px 18px rgba(0,0,0,.05);
}
.alert{
  border-radius:16px;
  background: linear-gradient(135deg, rgba(231,225,213,.95), rgba(255,255,255,.92));
}
.preview-row{margin-top:12px}
.preview-logo{
  height:58px; width:auto; border-radius:16px; padding:8px; border:1px solid rgba(0,0,0,.08); background:#fff;
}
.preview-bg{
  width:100%; max-width:420px; border-radius:18px; border:1px solid rgba(0,0,0,.08); display:block;
}
.settings-grid{
  display:grid; gap:16px; grid-template-columns:repeat(2,minmax(0,1fr));
}
.settings-card{
  padding:20px;
}
.settings-card__head{
  display:flex; justify-content:space-between; align-items:flex-start; gap:12px; margin-bottom:12px;
}
.settings-card h3{margin:0; font-size:22px}
.two-cols{
  display:grid; gap:12px; grid-template-columns:repeat(2,minmax(0,1fr));
}
.sticky-actions{
  position:sticky; bottom:12px; z-index:5;
  display:flex; justify-content:center; margin-top:18px;
}
.sticky-actions .btn{
  min-width:260px; padding:14px 20px; border-radius:18px;
}
@media(max-width:900px){
  .settings-grid{grid-template-columns:1fr}
}
@media(max-width:680px){
  .two-cols{grid-template-columns:1fr}
  .settings-card{padding:16px}
  .page-hero{padding:16px}
  .sticky-actions{bottom:10px}
  .sticky-actions .btn{width:100%}
}
@media(max-width:520px){
  .container{padding:12px}
  .card-lg{padding:16px}
  .class-summary{align-items:flex-start}
  .class-summary__right{flex-direction:column; align-items:flex-end}
  .brand-title{font-size:11px}
  .page-hero h2{font-size:28px; line-height:1.05}
}



/* ===================================================================
   FINAL BRAND / UX OVERRIDE
   =================================================================== */
:root{
  --bg:#E7E1D5;
  --gold:#A18556;
  --white:#FFFFFF;
  --black:#000000;
  --glass: rgba(255,255,255,.74);
  --glass-strong: rgba(255,255,255,.88);
  --line: rgba(0,0,0,.08);
  --shadow: 0 18px 48px rgba(0,0,0,.10);
  --shadow-lg: 0 24px 60px rgba(0,0,0,.14);
}

/* Force branded background to show globally */
html, body{min-height:100%;}
body{
  margin:0;
  color:var(--black);
  font-family: Inter, system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  background-color: var(--bg);
  background-image:
    linear-gradient(rgba(231,225,213,.74), rgba(231,225,213,.82)),
    var(--brand-bg),
    radial-gradient(circle at 12% 10%, rgba(255,255,255,.55), transparent 32%),
    radial-gradient(circle at 88% 12%, rgba(161,133,86,.16), transparent 24%);
  background-size: cover, cover, auto, auto;
  background-position: center center, center center, center center, center center;
  background-repeat: no-repeat;
  background-attachment: fixed;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
@media (max-width: 900px){
  body{background-attachment: scroll;}
}

.container{
  max-width: 1180px;
  margin: 0 auto;
  padding: 18px;
}

h1,h2,h3{
  margin:0;
  letter-spacing:-.03em;
  line-height:1.05;
}
h2{font-size: clamp(28px, 4vw, 42px);}
h3{font-size: clamp(20px, 2.4vw, 28px);}
.small{font-size:13px; opacity:.78; line-height:1.45;}
a{text-decoration:none; color:var(--black);}

/* Topbar */
.topbar{
  position: sticky;
  top: 0;
  z-index: 60;
  backdrop-filter: blur(14px);
  background: rgba(255,255,255,.58);
  border-bottom:1px solid var(--line);
}
.topbar-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding: 14px 18px;
}
.brand--header{display:flex; align-items:center; gap:14px; min-width:0;}
.logo{
  width:54px; height:54px;
  border-radius:18px;
  display:flex; align-items:center; justify-content:center;
  background: linear-gradient(180deg, #b29361 0%, #9b7c49 100%);
  color:#fff; font-weight:900; font-size:24px;
  box-shadow: 0 14px 30px rgba(161,133,86,.26);
  overflow:hidden; flex-shrink:0;
}
.logo--img{
  padding:6px;
  background: rgba(255,255,255,.86);
  border:1px solid rgba(0,0,0,.06);
}
.logo-img{
  width:100%; height:100%; object-fit:contain; display:block;
  border-radius:14px;
}
.brand-title{
  font-size:13px;
  letter-spacing:.18em;
  text-transform:uppercase;
  font-weight:900;
  line-height:1.15;
}
.brand-sub{
  margin-top:3px;
  font-size:13px;
  opacity:.76;
  line-height:1.2;
}

.nav-toggle{
  display:none;
  width:48px; height:48px;
  border-radius:16px;
  border:1px solid var(--line);
  background: rgba(255,255,255,.88);
  align-items:center; justify-content:center;
  gap:4px;
  box-shadow: 0 10px 24px rgba(0,0,0,.06);
}
.nav-toggle span{
  display:block; width:18px; height:2px; border-radius:2px;
  background: var(--black);
}
.nav{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  flex-wrap:wrap;
  gap:10px;
}
.nav-link{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:42px;
  padding:10px 14px;
  border-radius:999px;
  border:1px solid rgba(0,0,0,.10);
  background: linear-gradient(180deg, rgba(255,255,255,.92), rgba(246,242,235,.92));
  box-shadow: 0 10px 24px rgba(0,0,0,.05);
  font-size:13px;
  font-weight:800;
  transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease, background .16s ease;
}
.nav-link:hover{
  transform: translateY(-1px);
  box-shadow: 0 16px 28px rgba(0,0,0,.08);
  border-color: rgba(161,133,86,.35);
}
.nav-link--admin{border-color: rgba(161,133,86,.32);}
.nav-link--danger{border-color: rgba(0,0,0,.16);}

/* Cards */
.card, .card-lg, .class-item{
  background: var(--glass);
  border:1px solid var(--line);
  border-radius:24px;
  box-shadow: var(--shadow);
  backdrop-filter: blur(10px);
}
.card{max-width:560px;}
.card-lg{
  padding:20px;
}
@media (hover:hover){
  .card-lg:hover, .class-item:hover{
    transform: translateY(-2px);
    box-shadow: var(--shadow-lg);
  }
}
.grid{display:grid; gap:18px; grid-template-columns: repeat(12,minmax(0,1fr));}
.card-lg.half{grid-column: span 6;}
.card-lg{grid-column: span 12;}
@media (max-width:920px){
  .card-lg.half{grid-column: span 12;}
}
.row{display:flex; gap:12px; flex-wrap:wrap;}
.row>div{flex:1 1 220px; min-width:0;}

.page-hero{
  display:flex; align-items:center; justify-content:space-between; gap:14px;
  margin-bottom:18px; padding:18px 20px;
  border-radius:24px;
  border:1px solid var(--line);
  background: linear-gradient(135deg, rgba(255,255,255,.84), rgba(243,238,229,.78));
  box-shadow: var(--shadow);
}
.eyebrow{
  display:inline-block;
  margin-bottom:8px;
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  font-weight:900;
  opacity:.65;
}

/* Forms */
label{
  display:block; margin:14px 0 6px;
  font-size:12px; font-weight:700; opacity:.8;
}
input, select, textarea{
  width:100%;
  padding:13px 14px;
  border-radius:16px;
  border:1px solid rgba(0,0,0,.10);
  background: rgba(255,255,255,.92);
  outline:none;
  transition: border-color .16s ease, box-shadow .16s ease, background .16s ease;
}
input:focus, select:focus, textarea:focus{
  border-color: rgba(161,133,86,.54);
  box-shadow: 0 0 0 4px rgba(161,133,86,.10);
  background:#fff;
}
textarea{min-height:120px; resize:vertical;}

/* Buttons */
.btn{
  appearance:none;
  border:none;
  color:#fff;
  cursor:pointer;
  padding:13px 16px;
  border-radius:16px;
  font-weight:900;
  background: linear-gradient(180deg, #b29260 0%, #9a7b49 100%);
  box-shadow: 0 14px 28px rgba(161,133,86,.24);
  transition: transform .15s ease, box-shadow .15s ease, opacity .15s ease;
}
.btn:hover{transform:translateY(-1px); box-shadow:0 18px 30px rgba(161,133,86,.28);}
.btn.secondary{
  color:var(--black);
  background: linear-gradient(180deg, rgba(255,255,255,.92), rgba(246,242,235,.92));
  border:1px solid rgba(0,0,0,.10);
}
.btn.block{width:100%;}

.badge, .pill{
  display:inline-flex; align-items:center; justify-content:center;
  min-height:38px; padding:8px 12px;
  border-radius:999px;
  border:1px solid rgba(161,133,86,.24);
  background: rgba(255,255,255,.90);
  box-shadow: 0 10px 22px rgba(0,0,0,.05);
  font-size:13px; font-weight:900;
}

/* Links-as-actions */
.links{
  display:flex; flex-wrap:wrap; gap:10px;
}
.links a{
  display:inline-flex; align-items:center; justify-content:center;
  min-height:44px;
  padding:12px 14px;
  border-radius:16px;
  border:1px solid rgba(0,0,0,.08);
  background: linear-gradient(180deg, rgba(255,255,255,.94), rgba(245,241,233,.92));
  box-shadow: 0 10px 24px rgba(0,0,0,.05);
  font-weight:900;
  transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}
.links a:hover{
  transform: translateY(-1px);
  box-shadow: 0 16px 28px rgba(0,0,0,.08);
  border-color: rgba(161,133,86,.34);
}

/* Alerts */
.alert{
  padding:14px 16px;
  border-radius:18px;
  border:1px solid rgba(0,0,0,.08);
  background: linear-gradient(135deg, rgba(231,225,213,.96), rgba(255,255,255,.92));
  box-shadow: 0 12px 24px rgba(0,0,0,.05);
  margin-bottom:14px;
}

/* Settings page */
.settings-form{padding-bottom:90px;}
.settings-grid{
  display:grid;
  gap:18px;
  grid-template-columns: repeat(2,minmax(0,1fr));
}
.settings-card{padding:20px;}
.settings-card__head{margin-bottom:8px;}
.settings-card h3{margin:0; font-size:24px;}
.two-cols{
  display:grid; gap:12px;
  grid-template-columns: repeat(2,minmax(0,1fr));
}
.preview-row{margin-top:12px;}
.preview-logo{
  height:60px; width:auto;
  border-radius:16px; border:1px solid rgba(0,0,0,.08);
  background:#fff; padding:8px; display:block;
}
.preview-bg{
  width:100%; max-width:420px;
  border-radius:18px; border:1px solid rgba(0,0,0,.08);
  display:block;
}
.sticky-actions{
  position:sticky;
  bottom:10px;
  z-index:8;
  display:flex;
  justify-content:center;
  margin-top:18px;
}
.sticky-actions .btn{
  min-width:280px;
  padding:15px 18px;
  border-radius:20px;
}

/* Schedule / reservations */
.class-item{padding:12px 14px; border-radius:22px;}
.class-summary{
  display:flex; align-items:center; justify-content:space-between; gap:14px;
  cursor:pointer; list-style:none;
}
.class-summary::-webkit-details-marker{display:none;}
.class-title{font-size:20px; font-weight:900; line-height:1.08;}
.class-body{padding-top:12px;}
.class-summary__right{display:flex; align-items:center; gap:10px; flex-shrink:0;}
.reserve-form .actions{margin-top:14px;}

/* Tables */
.table{width:100%; border-collapse:separate; border-spacing:0 10px;}
.table th{
  font-size:11px; letter-spacing:.16em; text-transform:uppercase;
  opacity:.62; padding:6px 10px; text-align:left;
}
.table td{
  background: rgba(255,255,255,.88);
  border:1px solid var(--line);
  padding:12px 10px;
}
.table tr td:first-child{border-top-left-radius:14px; border-bottom-left-radius:14px;}
.table tr td:last-child{border-top-right-radius:14px; border-bottom-right-radius:14px;}

/* Mobile */
@media (max-width: 860px){
  .topbar-inner{flex-wrap:wrap;}
  .nav-toggle{display:inline-flex;}
  .nav{
    display:none;
    width:100%;
    justify-content:flex-start;
    flex-direction:column;
    align-items:stretch;
    gap:10px;
    padding:12px 0 4px;
  }
  .nav.nav--open{display:flex;}
  .nav-link{justify-content:center;}
  .settings-grid{grid-template-columns:1fr;}
  .two-cols{grid-template-columns:1fr;}
}
@media (max-width: 520px){
  .container{padding:12px;}
  .card-lg{padding:16px;}
  .logo{width:48px; height:48px; border-radius:16px;}
  .brand-title{font-size:11px; letter-spacing:.14em;}
  .brand-sub{font-size:12px;}
  .page-hero{padding:16px;}
  .page-hero h2{font-size:28px;}
  .class-summary{align-items:flex-start;}
  .class-summary__right{flex-direction:column; align-items:flex-end;}
  .sticky-actions .btn{width:100%; min-width:0;}
}



/* ===== Premium mobile menu refinement ===== */
.nav-toggle--premium{
  position:relative;
  width:52px;
  height:52px;
  border-radius:18px;
  background:linear-gradient(180deg, rgba(255,255,255,.96), rgba(244,240,233,.92));
  border:1px solid rgba(0,0,0,.08);
  box-shadow:0 14px 26px rgba(0,0,0,.06);
}
.nav-toggle--premium span{
  width:18px;
  height:3px;
  border-radius:999px;
  background:linear-gradient(180deg, rgba(0,0,0,.88), rgba(0,0,0,.72));
  display:block;
  margin:0 auto;
}
.nav-toggle--premium span + span{ margin-top:4px; }

@media (max-width: 860px){
  .nav{
    margin-top:8px;
    padding:14px;
    border-radius:24px;
    background:linear-gradient(180deg, rgba(255,255,255,.92), rgba(245,241,233,.90));
    border:1px solid rgba(0,0,0,.06);
    box-shadow:0 18px 40px rgba(0,0,0,.08);
  }
  .nav-link{
    width:100%;
    justify-content:flex-start;
    min-height:54px;
    border-radius:18px;
    font-size:17px;
    padding:14px 16px;
    background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,245,239,.96));
  }
  .nav-link--admin{
    border-color:rgba(161,133,86,.26);
  }
  .nav-link--danger{
    background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(250,244,240,.96));
  }
  .brand--header{
    gap:12px;
  }
  .topbar-inner{
    padding-top:16px;
    padding-bottom:12px;
  }
}

@media (max-width:520px){
  .brand-title{font-size:10px; letter-spacing:.12em;}
  .brand-sub{font-size:11px;}
}



/* ===================================================================
   iOS APP-LIKE FINAL THEME
   =================================================================== */
:root{
  --ios-bg: #F5F5F7;
  --ios-card: rgba(255,255,255,.78);
  --ios-card-strong: rgba(255,255,255,.88);
  --ios-line: rgba(0,0,0,.07);
  --ios-text-soft: rgba(0,0,0,.62);
  --ios-shadow: 0 10px 30px rgba(0,0,0,.06), 0 2px 8px rgba(0,0,0,.03);
  --ios-shadow-lg: 0 18px 50px rgba(0,0,0,.10), 0 4px 14px rgba(0,0,0,.04);
}

/* Apple-like overall mood */
body{
  background-color: var(--ios-bg) !important;
  background-image:
    linear-gradient(rgba(245,245,247,.70), rgba(245,245,247,.86)),
    var(--brand-bg) !important;
  background-size: cover, cover !important;
  background-position: center center, center center !important;
  color: #111111;
}

.topbar{
  background: rgba(255,255,255,.54) !important;
  backdrop-filter: blur(22px) saturate(140%);
  border-bottom: 1px solid rgba(255,255,255,.55);
  box-shadow: 0 1px 0 rgba(0,0,0,.03);
}
.topbar-inner{
  padding-top: 14px;
  padding-bottom: 14px;
}
.brand--header{
  gap: 14px;
}
.logo, .logo--img{
  width: 58px !important;
  height: 58px !important;
  border-radius: 20px !important;
  box-shadow: 0 10px 22px rgba(0,0,0,.06);
}
.logo--img{
  background: rgba(255,255,255,.92) !important;
}
.brand-title{
  font-size: 13px !important;
  letter-spacing: .16em !important;
}
.brand-sub{
  color: var(--ios-text-soft);
}

.nav-toggle--ios{
  width: 54px !important;
  height: 54px !important;
  border-radius: 18px !important;
  background: rgba(255,255,255,.82) !important;
  border: 1px solid rgba(255,255,255,.65) !important;
  box-shadow: var(--ios-shadow) !important;
  display:inline-flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:4px;
}
.nav-toggle--ios span{
  width: 18px !important;
  height: 3px !important;
  border-radius: 999px !important;
  background: #222 !important;
  display:block !important;
  margin:0 !important;
}

/* iOS card treatment */
.card, .card-lg, .class-item, .page-hero{
  background: var(--ios-card) !important;
  backdrop-filter: blur(18px) saturate(145%);
  border: 1px solid rgba(255,255,255,.55) !important;
  box-shadow: var(--ios-shadow) !important;
  border-radius: 28px !important;
}
.card-lg{
  padding: 22px !important;
}
.card h2, .card-lg h2{
  letter-spacing: -0.04em;
}
.small{
  color: var(--ios-text-soft);
}

/* Buttons and pills more app-like */
.btn, .links a, .nav-link, .pill, .badge{
  border-radius: 18px !important;
}
.btn{
  background: linear-gradient(180deg, #B19160 0%, #9A7B49 100%) !important;
  box-shadow: 0 10px 24px rgba(161,133,86,.18) !important;
}
.links a{
  background: rgba(255,255,255,.84) !important;
  border: 1px solid rgba(255,255,255,.65) !important;
  box-shadow: var(--ios-shadow) !important;
}
.badge, .pill, .nav-link{
  background: rgba(255,255,255,.84) !important;
  border: 1px solid rgba(255,255,255,.62) !important;
  box-shadow: var(--ios-shadow) !important;
}

/* Inputs */
input, select, textarea{
  border-radius: 18px !important;
  background: rgba(255,255,255,.84) !important;
  border: 1px solid rgba(255,255,255,.72) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.65), 0 2px 8px rgba(0,0,0,.02);
}

/* Home cards prettier */
.links{
  display:grid !important;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 12px !important;
}
@media (max-width: 560px){
  .links{
    grid-template-columns: 1fr !important;
  }
}

/* iOS mobile menu as floating sheet */
@media (max-width: 860px){
  .topbar-inner{
    align-items: center;
  }
  .nav{
    position: fixed;
    left: 14px;
    right: 14px;
    top: 88px;
    max-height: calc(100vh - 120px);
    overflow: auto;
    display: none;
    gap: 12px !important;
    padding: 14px !important;
    border-radius: 28px !important;
    background: rgba(255,255,255,.72) !important;
    backdrop-filter: blur(24px) saturate(160%);
    border: 1px solid rgba(255,255,255,.55) !important;
    box-shadow: var(--ios-shadow-lg) !important;
  }
  .nav.nav--open{
    display: flex !important;
    flex-direction: column;
    align-items: stretch;
  }
  .nav-link{
    width: 100%;
    justify-content: flex-start !important;
    min-height: 56px !important;
    font-size: 18px !important;
    padding: 16px 18px !important;
    border-radius: 20px !important;
    background: rgba(255,255,255,.86) !important;
  }
}

/* Schedule / modules */
.class-item{
  padding: 14px 16px !important;
}
.class-title{
  font-size: 22px !important;
}
.reserve-form .actions{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
}
@media (max-width: 520px){
  .container{ padding: 12px !important; }
  .card-lg{ padding: 18px !important; }
  .logo, .logo--img{ width:52px !important; height:52px !important; }
  .brand-title{ font-size: 11px !important; letter-spacing: .13em !important; }
  .brand-sub{ font-size: 12px !important; }
  .page-hero{
    padding: 18px !important;
  }
  h2{ font-size: 30px !important; }
  .nav{ top: 84px; }
}

/* hide any older menu style edge cases */
@media (max-width: 860px){
  .topbar .nav a{ width:100%; }
}



/* ===================================================================
   HORIZONTAL REFORMER SELECTOR
   =================================================================== */
.studio-scene{
  margin-top:10px;
  padding:14px 14px 16px;
  border-radius:24px;
  background:linear-gradient(180deg, rgba(255,255,255,.78), rgba(247,243,236,.72));
  border:1px solid rgba(0,0,0,.06);
}
.studio-line{
  position:relative;
  text-align:center;
  margin:6px 0 12px;
}
.studio-line::before{
  content:"";
  position:absolute;
  left:0; right:0; top:50%;
  height:1px;
  background:rgba(0,0,0,.10);
}
.studio-line span{
  position:relative;
  display:inline-block;
  padding:0 12px;
  background:linear-gradient(180deg, rgba(255,255,255,.95), rgba(247,243,236,.88));
  font-size:12px;
  letter-spacing:.18em;
  text-transform:uppercase;
  opacity:.6;
  font-weight:800;
}
.seats-horizontal{
  display:grid;
  grid-template-columns:repeat(4, minmax(0,1fr));
  gap:18px 16px;
  align-items:start;
  justify-items:center;
  padding:4px 0 8px;
}
.seat-h{
  appearance:none;
  border:0;
  background:transparent;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:10px;
  cursor:pointer;
  padding:0;
  width:100%;
}
.seat-h.pos-3{grid-column:1}
.seat-h.pos-6{grid-column:3}
.seat-h.pos-7{grid-column:4}
.reformer-h{
  position:relative;
  width:100%;
  max-width:132px;
  aspect-ratio: 1.25 / 1;
  display:block;
  transition:transform .16s ease, filter .16s ease;
}
.r-bed{
  position:absolute;
  inset:18% 10% 24% 10%;
  border-radius:18px;
  background:linear-gradient(180deg, #f7f2ea 0%, #ece4d7 100%);
  border:2px solid rgba(89,73,55,.45);
  box-shadow:0 12px 26px rgba(0,0,0,.08);
}
.r-head{
  position:absolute;
  top:8%;
  left:50%;
  transform:translateX(-50%);
  width:28%;
  height:18%;
  border-radius:10px;
  background:linear-gradient(180deg, #f8f4ee 0%, #e9decd 100%);
  border:2px solid rgba(89,73,55,.45);
  z-index:2;
}
.r-foot{
  position:absolute;
  bottom:12%;
  left:50%;
  transform:translateX(-50%);
  width:46%;
  height:14%;
  border-radius:12px;
  background:linear-gradient(180deg, #e2d4be 0%, #cdb392 100%);
  border:2px solid rgba(89,73,55,.45);
  z-index:2;
}
.reformer-h::before,
.reformer-h::after{
  content:"";
  position:absolute;
  top:26%;
  bottom:30%;
  width:6%;
  border-radius:999px;
  background:
    radial-gradient(circle at center 10px, rgba(89,73,55,.55) 0 2px, transparent 3px),
    radial-gradient(circle at center calc(50% - 8px), rgba(89,73,55,.55) 0 2px, transparent 3px),
    radial-gradient(circle at center calc(100% - 10px), rgba(89,73,55,.55) 0 2px, transparent 3px);
  opacity:.9;
}
.reformer-h::before{left:13%}
.reformer-h::after{right:13%}
.seat-num-h{
  width:38px;
  height:38px;
  border-radius:999px;
  display:grid;
  place-items:center;
  background:rgba(255,255,255,.92);
  border:1px solid rgba(0,0,0,.08);
  box-shadow:0 8px 18px rgba(0,0,0,.05);
  font-weight:900;
  font-size:16px;
}
.seat-h:hover .reformer-h{transform:translateY(-2px)}
.seat-h.selected .r-bed,
.seat-h.selected .r-head{
  border-color:rgba(161,133,86,.90);
  box-shadow:0 0 0 5px rgba(161,133,86,.10), 0 16px 30px rgba(161,133,86,.15);
}
.seat-h.selected .r-foot{
  background:linear-gradient(180deg, #d8bf9d 0%, #b99667 100%);
  border-color:rgba(161,133,86,.90);
}
.seat-h.selected .seat-num-h{
  background:rgba(161,133,86,.12);
  border-color:rgba(161,133,86,.32);
}
.seat-h.taken{
  cursor:not-allowed;
  opacity:.45;
}
.seat-h.taken .r-bed,
.seat-h.taken .r-head,
.seat-h.taken .r-foot{
  filter:grayscale(1);
}
.studio-tip{
  margin-top:10px;
  padding:12px 14px;
  border-radius:18px;
  background:rgba(255,255,255,.72);
  border:1px solid rgba(0,0,0,.06);
  color:rgba(0,0,0,.66);
  font-size:13px;
  line-height:1.45;
}
@media (max-width: 860px){
  .reformer-h{max-width:118px}
}
@media (max-width: 640px){
  .seats-horizontal{
    grid-template-columns:repeat(2, minmax(0,1fr));
    gap:18px 14px;
  }
  .seat-h.pos-1{grid-column:1}
  .seat-h.pos-2{grid-column:2}
  .seat-h.pos-4{grid-column:1}
  .seat-h.pos-5{grid-column:2}
  .seat-h.pos-3{grid-column:1}
  .seat-h.pos-6{grid-column:2}
  .seat-h.pos-7{grid-column:1 / span 2; justify-self:center; max-width:160px}
  .studio-line{margin-bottom:10px}
}



/* ===================================================================
   REFORMER SELECTOR FIXED LAYOUT
   =================================================================== */
.seats-horizontal{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr);
  gap:20px 28px;
  align-items:start;
  justify-items:center;
  padding:6px 0 10px;
}
.seat-col{
  width:100%;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:26px;
}
.seat-col--right{
  padding-top:0;
}
.seat-col--left{
  padding-top:86px; /* right side has one extra reformer at window side */
}
.seat-h{
  width:100%;
  max-width:210px;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:10px;
}

/* More realistic horizontal pilates reformer */
.reformer-h--pilates{
  position:relative;
  width:100%;
  max-width:170px;
  aspect-ratio: 1.75 / 1;
  display:block;
  filter: drop-shadow(0 16px 22px rgba(0,0,0,.10));
}
.reformer-h--pilates .r-body{
  position:absolute;
  inset:24% 12% 24% 12%;
  border-radius:28px;
  background:linear-gradient(180deg, #f8f4ed 0%, #ece3d4 100%);
  border:3px solid rgba(144,126,102,.75);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    inset 0 -8px 20px rgba(0,0,0,.04);
}
.reformer-h--pilates .r-head{
  position:absolute;
  top:12%;
  left:33%;
  width:28%;
  height:18%;
  border-radius:14px;
  background:linear-gradient(180deg, #f5efe7 0%, #e4d8c6 100%);
  border:3px solid rgba(144,126,102,.75);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.9);
}
.reformer-h--pilates .r-rail{
  position:absolute;
  left:16%;
  right:16%;
  height:3px;
  background:rgba(171,156,132,.75);
  border-radius:999px;
}
.reformer-h--pilates .r-rail--top{ top:42%; }
.reformer-h--pilates .r-rail--bottom{ top:60%; }
.reformer-h--pilates .r-bar{
  position:absolute;
  right:7%;
  top:40%;
  width:12%;
  height:22%;
  border-radius:10px;
  background:linear-gradient(180deg, #cfb693 0%, #b69368 100%);
  border:3px solid rgba(144,126,102,.72);
}
.reformer-h--pilates .r-wheel{
  position:absolute;
  width:7%;
  aspect-ratio:1/1;
  border-radius:999px;
  background:rgba(144,126,102,.78);
  box-shadow:0 0 0 3px rgba(255,255,255,.35);
}
.reformer-h--pilates .r-wheel--a{ right:11%; top:31%; }
.reformer-h--pilates .r-wheel--b{ right:11%; top:61%; }

.seat-num-h{
  width:42px;
  height:42px;
  font-size:18px;
  background:rgba(255,255,255,.95);
}
.seat-h.selected .r-body,
.seat-h.selected .r-head{
  border-color:rgba(161,133,86,.95);
  box-shadow:
    0 0 0 6px rgba(161,133,86,.10),
    inset 0 1px 0 rgba(255,255,255,.95);
}
.seat-h.selected .r-bar{
  background:linear-gradient(180deg, #e0c9a7 0%, #c39d6c 100%);
  border-color:rgba(161,133,86,.95);
}
.seat-h.taken .reformer-h--pilates{
  opacity:.50;
  filter:grayscale(1) drop-shadow(0 12px 18px rgba(0,0,0,.06));
}

@media (max-width: 760px){
  .seat-col--left{ padding-top:70px; }
  .seat-h{ max-width:180px; }
  .reformer-h--pilates{ max-width:150px; }
}
@media (max-width: 560px){
  .seats-horizontal{
    grid-template-columns:minmax(0,1fr) minmax(0,1fr);
    gap:18px 10px;
  }
  .seat-col{ gap:18px; }
  .seat-col--left{ padding-top:58px; }
  .seat-h{ max-width:150px; }
  .reformer-h--pilates{ max-width:132px; }
  .studio-scene{ padding:12px 8px 14px; }
}



/* ===================================================================
   EXACT USER REFORMER LAYOUT
   =================================================================== */
.studio-scene--friendly{
  margin-top:10px;
  padding:16px 14px 18px;
  border-radius:26px;
  background:linear-gradient(180deg, rgba(255,255,255,.84), rgba(247,243,236,.80));
  border:1px solid rgba(0,0,0,.06);
}
.reformer-layout{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr);
  gap:18px 30px;
  align-items:start;
  justify-items:center;
  padding:8px 0 10px;
}
.reformer-col{
  width:100%;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:14px;
}
.reformer-col--left{padding-top:72px;}
.reformer-col--right{padding-top:0;}
.reformer-seat{
  appearance:none;
  border:0;
  background:transparent;
  width:100%;
  max-width:200px;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:8px;
  padding:0;
  cursor:pointer;
  transition:transform .16s ease;
}
.reformer-card{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:2px;
  border-radius:20px;
  background:transparent;
  transition:transform .18s ease, filter .18s ease, background .18s ease, box-shadow .18s ease;
}
.reformer-real-img{
  width:100%;
  max-width:165px;
  height:auto;
  display:block;
  filter:drop-shadow(0 10px 16px rgba(0,0,0,.10));
  transition:filter .18s ease, transform .18s ease, opacity .18s ease;
}
.reformer-seat:hover .reformer-real-img{transform:scale(1.02)}
.reformer-seat.selected .reformer-card{
  background:rgba(255,251,244,.92);
  box-shadow:0 0 0 3px rgba(161,133,86,.14), 0 14px 28px rgba(161,133,86,.12);
}
.reformer-seat.selected .reformer-real-img{
  filter:drop-shadow(0 0 14px rgba(161,133,86,.42)) drop-shadow(0 12px 18px rgba(0,0,0,.10));
  transform:scale(1.03);
}
.reformer-seat.taken .reformer-real-img{
  opacity:.35;
  filter:grayscale(1) drop-shadow(0 8px 12px rgba(0,0,0,.04));
}
.seat-num-h{
  width:42px;
  height:42px;
  border-radius:999px;
  display:grid;
  place-items:center;
  background:#fff;
  border:1px solid rgba(0,0,0,.08);
  box-shadow:0 8px 16px rgba(0,0,0,.05);
  font-weight:900;
  font-size:18px;
  transition:all .18s ease;
}
.reformer-seat.selected .seat-num-h{
  background:rgba(161,133,86,.12);
  border-color:rgba(161,133,86,.32);
}
.studio-line{
  position:relative;
  text-align:center;
  margin:4px 0 12px;
}
.studio-line::before{
  content:"";
  position:absolute;
  left:0; right:0; top:50%;
  height:1px;
  background:rgba(0,0,0,.10);
}
.studio-line span{
  position:relative;
  display:inline-block;
  padding:0 12px;
  background:linear-gradient(180deg, rgba(255,255,255,.96), rgba(247,243,236,.88));
  font-size:12px;
  letter-spacing:.18em;
  text-transform:uppercase;
  opacity:.6;
  font-weight:800;
}
.studio-tip{
  margin-top:10px;
  padding:12px 14px;
  border-radius:18px;
  background:rgba(255,255,255,.74);
  border:1px solid rgba(0,0,0,.06);
  color:rgba(0,0,0,.66);
  font-size:13px;
  line-height:1.45;
}
@media (max-width:760px){
  .reformer-col--left{padding-top:60px;}
  .reformer-real-img{max-width:144px;}
}
@media (max-width:560px){
  .reformer-layout{gap:12px 6px;}
  .reformer-col{gap:10px;}
  .reformer-col--left{padding-top:42px;}
  .reformer-real-img{max-width:126px;}
  .studio-scene--friendly{padding:12px 8px 14px;}
}



/* ===================================================================
   EXACT 0-1 / 1-1 REFORMER GRID
   =================================================================== */
.reformer-layout--exact{
  display:grid !important;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr) !important;
  gap:14px 26px !important;
  align-items:start;
  justify-items:center;
  padding:8px 0 10px;
}
.reformer-layout--exact .layout-spacer{
  width:100%;
  min-height:1px;
  grid-column:1;
  grid-row:1;
}
.reformer-layout--exact .seat-r1{grid-column:2; grid-row:1;}
.reformer-layout--exact .seat-l2{grid-column:1; grid-row:2;}
.reformer-layout--exact .seat-r2{grid-column:2; grid-row:2;}
.reformer-layout--exact .seat-l3{grid-column:1; grid-row:3;}
.reformer-layout--exact .seat-r3{grid-column:2; grid-row:3;}
.reformer-layout--exact .seat-l4{grid-column:1; grid-row:4;}
.reformer-layout--exact .seat-r4{grid-column:2; grid-row:4;}

.reformer-layout--exact .reformer-seat{
  appearance:none;
  border:0;
  background:transparent;
  width:100%;
  max-width:200px;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:8px;
  padding:0;
  cursor:pointer;
  transition:transform .16s ease;
}
.reformer-layout--exact .reformer-card{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:2px;
  border-radius:20px;
  background:transparent;
  transition:transform .18s ease, filter .18s ease, background .18s ease, box-shadow .18s ease;
}
.reformer-layout--exact .reformer-real-img{
  width:100%;
  max-width:165px;
  height:auto;
  display:block;
  filter:drop-shadow(0 10px 16px rgba(0,0,0,.10));
  transition:filter .18s ease, transform .18s ease, opacity .18s ease;
}
.reformer-layout--exact .reformer-seat:hover .reformer-real-img{transform:scale(1.02);}
.reformer-layout--exact .reformer-seat.selected .reformer-card{
  background:rgba(255,251,244,.92);
  box-shadow:0 0 0 3px rgba(161,133,86,.14), 0 14px 28px rgba(161,133,86,.12);
}
.reformer-layout--exact .reformer-seat.selected .reformer-real-img{
  filter:drop-shadow(0 0 14px rgba(161,133,86,.42)) drop-shadow(0 12px 18px rgba(0,0,0,.10));
  transform:scale(1.03);
}
.reformer-layout--exact .reformer-seat.taken .reformer-real-img{
  opacity:.35;
  filter:grayscale(1) drop-shadow(0 8px 12px rgba(0,0,0,.04));
}
@media (max-width:760px){
  .reformer-layout--exact{
    gap:12px 16px !important;
  }
  .reformer-layout--exact .reformer-real-img{
    max-width:144px;
  }
}
@media (max-width:560px){
  .reformer-layout--exact{
    gap:10px 4px !important;
  }
  .reformer-layout--exact .reformer-real-img{
    max-width:126px;
  }
}



/* ===================================================================
   PREMIUM BACKGROUND OVERRIDE
   =================================================================== */
body::before {
  content: "";
  position: fixed;
  inset: 0;
  background:
    linear-gradient(
      180deg,
      rgba(231,225,213,var(--bg-tint-opacity, 0.12)) 0%,
      rgba(255,255,255,calc(var(--bg-tint-opacity, 0.12) * 0.45)) 40%,
      rgba(231,225,213,calc(var(--bg-tint-opacity, 0.12) * 1.1)) 100%
    ),
    var(--brand-bg);
  background-position: center center, center center;
  background-size: cover, cover;
  background-repeat: no-repeat, no-repeat;
  opacity: 1;
  z-index: -2;
  filter: blur(3px) saturate(1.03);
  transform: scale(1.02);
}

body::after {
  content: "";
  position: fixed;
  inset: 0;
  background: rgba(255,255,255,var(--bg-overlay-opacity, 0.35));
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  z-index: -1;
  pointer-events: none;
}

.card,
.card-lg,
.class-item,
.studio-scene,
.studio-scene--friendly,
.page-hero {
  background: rgba(255,255,255,0.75) !important;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,0.4) !important;
  box-shadow:
    0 10px 30px rgba(0,0,0,0.08),
    0 2px 8px rgba(0,0,0,0.04) !important;
  border-radius: 24px;
}

.reformer-seat.selected .reformer-real-img {
  filter:
    drop-shadow(0 0 18px rgba(161,133,86,0.45))
    drop-shadow(0 12px 20px rgba(0,0,0,0.12)) !important;
  transform: scale(1.04);
}



/* ===================================================================
   FINAL BG CONTROLS OVERRIDE
   =================================================================== */
body{
  background-color: #f4f1ea !important;
}

body::before{
  content:"" !important;
  position:fixed !important;
  inset:0 !important;
  background-image:
    linear-gradient(
      180deg,
      rgba(231,225,213,var(--bg-tint-opacity, 0.00)) 0%,
      rgba(255,255,255,calc(var(--bg-tint-opacity, 0.00) * 0.40)) 42%,
      rgba(231,225,213,calc(var(--bg-tint-opacity, 0.00) * 1.05)) 100%
    ),
    var(--brand-bg) !important;
  background-position:center center, center center !important;
  background-size:cover, cover !important;
  background-repeat:no-repeat, no-repeat !important;
  opacity:1 !important;
  z-index:-2 !important;
  filter: blur(2px) saturate(1.02) !important;
  transform: scale(1.01) !important;
}

body::after{
  content:"" !important;
  position:fixed !important;
  inset:0 !important;
  background: rgba(255,255,255,var(--bg-overlay-opacity, 0.10)) !important;
  backdrop-filter: blur(6px) !important;
  -webkit-backdrop-filter: blur(6px) !important;
  z-index:-1 !important;
  pointer-events:none !important;
}

@media (max-width: 768px){
  body::before{
    filter: blur(1px) saturate(1.02) !important;
    transform: scale(1.005) !important;
  }
  body::after{
    backdrop-filter: blur(3px) !important;
    -webkit-backdrop-filter: blur(3px) !important;
  }
}


/* ===================================================================
   BACKGROUND MAX VISIBLE (ULTRA CLEAR)
   =================================================================== */
body::before{
  content:"";
  position:fixed;
  inset:0;

  background:
    linear-gradient(
      180deg,
      rgba(231,225,213,0.08) 0%,
      rgba(255,255,255,0.03) 40%,
      rgba(231,225,213,0.08) 100%
    ),
    var(--brand-bg);

  background-position:center;
  background-size:cover;
  background-repeat:no-repeat;

  z-index:-2;
  filter: blur(1px) saturate(1.05);
  transform: scale(1.005);
}

body::after{
  background: rgba(255,255,255,0.04) !important;
  backdrop-filter: blur(2px) !important;
}



/* ===================================================================
   ELAINE LUXURY WELLNESS OVERRIDE
   =================================================================== */
:root{
  --elaine-ivory:#F7F4F1;
  --elaine-beige:#EFE8E2;
  --elaine-nude:#E6DDD6;
  --elaine-taupe-light:#CFC5BD;
  --elaine-taupe:#A89C92;
  --elaine-mocha:#8D7F75;
  --elaine-text:#2B2B2B;
  --elaine-gold:#C6A77D;
  --elaine-gold-deep:#B8956A;
  --elaine-glass:rgba(255,255,255,0.60);
  --elaine-line:rgba(255,255,255,0.40);
  --elaine-shadow:0 18px 40px rgba(141,127,117,0.12),0 4px 12px rgba(43,43,43,0.04);
}
body{
  color:var(--elaine-text) !important;
}

/* top bar */
.luxury-topbar{
  background:rgba(247,244,241,0.52) !important;
  backdrop-filter:blur(12px) saturate(110%) !important;
  border-bottom:1px solid rgba(255,255,255,0.32) !important;
  box-shadow:0 8px 26px rgba(141,127,117,0.06) !important;
}
.topbar .container.topbar-inner{
  padding-top:16px;
  padding-bottom:16px;
}
.brand--header{
  gap:14px !important;
}
.logo.logo--img,
.logo{
  width:56px !important;
  height:56px !important;
  border-radius:18px !important;
  background:rgba(255,255,255,0.78) !important;
  box-shadow:0 12px 28px rgba(141,127,117,0.10) !important;
}
.logo-img{border-radius:14px}
.brand-title{
  color:var(--elaine-text) !important;
  letter-spacing:.11em !important;
  font-size:15px !important;
  font-weight:800 !important;
}
.brand-sub{
  color:var(--elaine-mocha) !important;
  font-size:12px !important;
}
.nav-toggle--ios{
  background:rgba(255,255,255,0.80) !important;
  border:1px solid rgba(255,255,255,0.55) !important;
  box-shadow:var(--elaine-shadow) !important;
}
.nav-toggle--ios span{
  background:var(--elaine-mocha) !important;
}
.nav-link{
  background:rgba(255,255,255,0.78) !important;
  border:1px solid rgba(255,255,255,0.45) !important;
  box-shadow:0 10px 22px rgba(141,127,117,0.08) !important;
  color:var(--elaine-text) !important;
  font-weight:700 !important;
}
.nav-link:hover{
  border-color:rgba(198,167,125,0.36) !important;
}

/* cards */
.card,
.card-lg,
.class-item,
.studio-scene,
.studio-scene--friendly,
.page-hero{
  background:var(--elaine-glass) !important;
  border:1px solid var(--elaine-line) !important;
  box-shadow:var(--elaine-shadow) !important;
  backdrop-filter:blur(10px) !important;
  -webkit-backdrop-filter:blur(10px) !important;
}
.alert{
  background:rgba(255,255,255,0.58) !important;
  border:1px solid rgba(255,255,255,0.34) !important;
}

/* buttons become branded */
.btn,
.links a,
.pill,
.badge{
  background:rgba(255,255,255,0.82) !important;
  color:var(--elaine-text) !important;
  border:1px solid rgba(255,255,255,0.42) !important;
  box-shadow:0 10px 20px rgba(141,127,117,0.08) !important;
}
.btn:hover,
.links a:hover{
  background:#F1EAE4 !important;
}
.btn.secondary{
  background:rgba(255,255,255,0.72) !important;
}

/* home screen */
.luxury-home{
  max-width:1020px !important;
}
.luxury-panel{
  padding:18px;
  border-radius:34px;
  background:rgba(255,255,255,0.50);
  border:1px solid rgba(255,255,255,0.38);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  box-shadow:0 18px 50px rgba(141,127,117,0.14);
}
.luxury-hero{
  overflow:hidden;
}
.luxury-hero__inner{
  padding:6px 8px 10px;
}
.luxury-title{
  margin:0 0 8px 0;
  color:var(--elaine-text);
  font-family: "Iowan Old Style","Palatino Linotype","Book Antiqua",Georgia,serif;
  font-size: clamp(42px, 8vw, 70px);
  line-height:.95;
  letter-spacing:-.04em;
  font-weight:500;
}
.luxury-subtitle{
  margin:0 0 22px 0;
  color:var(--elaine-mocha);
  font-size: clamp(18px, 3vw, 24px);
}
.luxury-actions{
  display:flex;
  flex-direction:column;
  gap:14px;
}
.luxury-action{
  display:grid;
  grid-template-columns:52px 1fr 34px;
  align-items:center;
  gap:14px;
  padding:16px 18px;
  min-height:80px;
  border-radius:999px;
  background:rgba(255,255,255,0.66);
  border:1px solid rgba(255,255,255,0.46);
  box-shadow:0 12px 24px rgba(141,127,117,0.08);
  transition:transform .16s ease, box-shadow .16s ease, background .16s ease;
}
.luxury-action:hover{
  transform:translateY(-1px);
  box-shadow:0 18px 28px rgba(141,127,117,0.12);
}
.luxury-action--featured{
  background:linear-gradient(135deg, rgba(198,167,125,0.88), rgba(184,149,106,0.76)) !important;
  border-color:rgba(255,255,255,0.40) !important;
}
.luxury-action--featured .luxury-action__text,
.luxury-action--featured .luxury-action__icon,
.luxury-action--featured .luxury-action__arrow{
  color:#fff !important;
}
.luxury-action__icon{
  width:44px;
  height:44px;
  display:grid;
  place-items:center;
  border-radius:14px;
  color:var(--elaine-mocha);
  font-size:26px;
}
.luxury-action__text{
  color:var(--elaine-text);
  font-family:"Iowan Old Style","Palatino Linotype","Book Antiqua",Georgia,serif;
  font-size: clamp(24px, 4.2vw, 34px);
  line-height:1.1;
}
.luxury-action__arrow{
  color:rgba(141,127,117,0.92);
  font-size:44px;
  line-height:1;
  text-align:right;
}
.luxury-note{
  margin-top:26px;
  padding:10px 6px 4px;
  text-align:center;
}
.luxury-note p{
  margin:0;
  color:var(--elaine-mocha);
  font-family:"Iowan Old Style","Palatino Linotype","Book Antiqua",Georgia,serif;
  font-size: clamp(24px, 4vw, 34px);
  line-height:1.28;
}
.luxury-note span{
  display:block;
  margin-top:18px;
  color:var(--elaine-mocha);
  font-size: clamp(16px, 2.5vw, 22px);
}

@media (max-width: 900px){
  .nav{
    background:rgba(247,244,241,0.92) !important;
    border:1px solid rgba(255,255,255,0.52) !important;
    box-shadow:0 24px 40px rgba(141,127,117,0.16) !important;
  }
  .nav-link{
    min-height:56px !important;
    font-size:16px !important;
  }
}
@media (max-width: 640px){
  .container{padding:16px !important;}
  .luxury-panel{padding:14px; border-radius:28px;}
  .luxury-hero__inner{padding:2px;}
  .luxury-title{
    font-size: clamp(34px, 8vw, 56px);
  }
  .luxury-subtitle{
    font-size: 16px;
    margin-bottom:18px;
  }
  .luxury-action{
    grid-template-columns:44px 1fr 24px;
    min-height:70px;
    padding:14px 16px;
    gap:10px;
  }
  .luxury-action__icon{
    width:38px;height:38px;font-size:22px;
  }
  .luxury-action__text{
    font-size: clamp(18px, 6vw, 30px);
  }
  .luxury-action__arrow{
    font-size:34px;
  }
  .luxury-note{
    margin-top:18px;
  }
  .luxury-note p{
    font-size: clamp(18px, 6vw, 28px);
  }
  .luxury-note span{
    font-size:14px;
  }
}



/* ===================================================================
   RESERVATIONS PAGE - QR COMPLETE FIX
   Basado en v43. Solo corrige el QR en móvil.
   =================================================================== */

/* desktop/tablet */
.qrbox{
  justify-content:flex-end;
}
.qr{
  width:200px;
  height:200px;
  flex:0 0 200px;
}
.qr img{
  width:100% !important;
  height:100% !important;
  object-fit:contain !important;
  display:block;
}

/* móvil: apilar info y QR para que salga completo */
@media (max-width: 720px){
  .row{
    flex-direction:column !important;
    align-items:stretch !important;
  }

  .row > div{
    min-width:0 !important;
    width:100% !important;
  }

  .qrbox{
    width:100% !important;
    justify-content:center !important;
    align-items:center !important;
    margin-top:10px !important;
    flex:0 0 auto !important;
  }

  .qr{
    width:min(220px, 72vw) !important;
    height:min(220px, 72vw) !important;
    flex:0 0 auto !important;
    margin:0 auto !important;
    border-radius:22px !important;
    background:rgba(255,255,255,.92) !important;
    box-shadow:0 12px 28px rgba(141,127,117,.10) !important;
    overflow:hidden !important;
  }

  .qr img{
    width:100% !important;
    height:100% !important;
    object-fit:contain !important;
  }

  .badge{
    margin-top:6px;
    margin-right:6px;
  }
}



/* ===================================================================
   MOBILE MENU PREMIUM POLISH
   Basado en la v50. Solo mejora visual del menú móvil abierto.
   =================================================================== */
@media (max-width: 900px){
  body.drawer-open{overflow:hidden;}

  /* overlay suave detrás */
  body.drawer-open::after{
    content:"";
    position:fixed;
    inset:0;
    background:rgba(43,43,43,.08);
    backdrop-filter:blur(4px);
    -webkit-backdrop-filter:blur(4px);
    z-index:88;
    pointer-events:none;
  }

  .nav-mobile-premium.nav--open{
    position:fixed !important;
    left:14px !important;
    right:14px !important;
    top:108px !important;
    bottom:14px !important;
    z-index:89 !important;
    display:flex !important;
    flex-direction:column !important;
    gap:12px !important;
    overflow:auto !important;
    padding:16px !important;
    background:rgba(247,244,241,.86) !important;
    border:1px solid rgba(255,255,255,.44) !important;
    border-radius:32px !important;
    box-shadow:0 24px 60px rgba(141,127,117,.18) !important;
    backdrop-filter:blur(14px) saturate(108%) !important;
    -webkit-backdrop-filter:blur(14px) saturate(108%) !important;
  }

  .nav-mobile-premium.nav--open .nav-link{
    width:100% !important;
    min-height:74px !important;
    display:grid !important;
    grid-template-columns:42px 1fr 24px !important;
    align-items:center !important;
    gap:14px !important;
    padding:0 18px !important;
    border-radius:999px !important;
    background:rgba(255,255,255,.92) !important;
    border:1px solid rgba(255,255,255,.56) !important;
    box-shadow:0 12px 22px rgba(141,127,117,.08) !important;
    color:#2B2B2B !important;
    font-size:17px !important;
    font-weight:800 !important;
    text-transform:none !important;
    letter-spacing:0 !important;
  }

  .nav-mobile-premium.nav--open .nav-link__icon{
    width:42px !important;
    height:42px !important;
    padding:8px !important;
    display:block !important;
    border-radius:14px !important;
    background:linear-gradient(180deg, rgba(255,255,255,.96), rgba(241,234,228,.92)) !important;
    box-shadow:0 8px 18px rgba(141,127,117,.08) !important;
  }


  .nav-mobile-premium.nav--open .nav-link span{
    min-width:0;
  }
  .nav-mobile-premium.nav--open .nav-link::after{
    content:"›";
    color:#B8956A;
    font-size:34px;
    line-height:1;
    text-align:right;
  }

  .nav-mobile-premium.nav--open .nav-link:hover{
    background:#F8F4F1 !important;
  }

  /* admin links a little differentiated */
  .nav-mobile-premium.nav--open .nav-link--admin .nav-link__icon{
    background:linear-gradient(180deg, rgba(255,255,255,.96), rgba(239,231,222,.98)) !important;
  }

  /* footer card */
  .nav-mobile-premium.nav--open::after{
    content:"Tu momento es ahora ✨\AUn espacio diseñado para ti\A\ACancelación: 24h antes · Créditos expiran: 60 días";
    white-space:pre-line;
    display:block;
    margin-top:auto;
    padding:20px 16px 14px;
    text-align:center;
    background:rgba(255,255,255,.54);
    border:1px solid rgba(255,255,255,.34);
    border-radius:26px;
    color:#8D7F75;
    font-family:"Iowan Old Style","Palatino Linotype","Book Antiqua",Georgia,serif;
    font-size:17px;
    line-height:1.35;
    box-shadow:0 10px 20px rgba(141,127,117,.07);
  }

  .nav-toggle--ios,
  [data-nav-toggle]{
    position:relative;
    z-index:90 !important;
  }
}

@media (max-width: 560px){
  .nav-mobile-premium.nav--open{
    left:12px !important;
    right:12px !important;
    top:102px !important;
    bottom:12px !important;
    padding:14px !important;
    border-radius:28px !important;
  }
  .nav-mobile-premium.nav--open .nav-link{
    min-height:70px !important;
    grid-template-columns:38px 1fr 20px !important;
    gap:12px !important;
    padding:0 16px !important;
    font-size:16px !important;
  }
  .nav-mobile-premium.nav--open .nav-link__icon{
    width:38px !important;
    height:38px !important;
    padding:7px !important;
  }
  .nav-mobile-premium.nav--open .nav-link::after{
    font-size:30px;
  }
  .nav-mobile-premium.nav--open::after{
    font-size:15px;
  }
}



/* ===================================================================
   MOBILE MENU FULL VERTICAL FIT FIX
   Fuerza el menú abierto a mostrarse en columna y ajustado a pantalla
   =================================================================== */
@media (max-width: 900px){
  .nav-mobile-premium,
  .nav-mobile-premium.nav--open{
    flex-wrap: nowrap !important;
  }

  .nav-mobile-premium.nav--open{
    display:flex !important;
    flex-direction:column !important;
    align-items:stretch !important;
    justify-content:flex-start !important;
    gap:12px !important;
    width:auto !important;
    max-width:none !important;
    overflow-x:hidden !important;
    overflow-y:auto !important;
  }

  .nav-mobile-premium.nav--open .nav-link{
    width:100% !important;
    max-width:100% !important;
    flex:0 0 auto !important;
    white-space:normal !important;
  }
}

@media (max-width: 560px){
  .nav-mobile-premium.nav--open{
    left:10px !important;
    right:10px !important;
    top:98px !important;
    bottom:10px !important;
    gap:10px !important;
    padding:12px !important;
  }

  .nav-mobile-premium.nav--open .nav-link{
    min-height:64px !important;
    grid-template-columns:34px 1fr 18px !important;
    gap:10px !important;
    padding:0 14px !important;
    font-size:15px !important;
    border-radius:22px !important;
  }

  .nav-mobile-premium.nav--open .nav-link__icon{
    width:34px !important;
    height:34px !important;
    padding:6px !important;
    border-radius:12px !important;
  }

  .nav-mobile-premium.nav--open .nav-link::after{
    font-size:26px !important;
  }

  .nav-mobile-premium.nav--open::after{
    font-size:14px !important;
    padding:16px 12px 14px !important;
    border-radius:20px !important;
  }
}



/* ===================================================================
   MOBILE MENU PANEL FULLSCREEN FIT FIX
   Corrige que el panel abierto se vea completo en celular
   =================================================================== */
@media (max-width: 900px){
  .nav-mobile-premium.nav--open{
    top: 96px !important;
    bottom: 8px !important;
    left: 8px !important;
    right: 8px !important;
    height: auto !important;
    max-height: calc(100dvh - 104px) !important;
    min-height: calc(100dvh - 104px) !important;
    box-sizing: border-box !important;
    padding-bottom: 18px !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
  }
}

@media (max-width: 560px){
  .nav-mobile-premium.nav--open{
    top: 90px !important;
    bottom: 6px !important;
    left: 6px !important;
    right: 6px !important;
    max-height: calc(100dvh - 96px) !important;
    min-height: calc(100dvh - 96px) !important;
    padding: 12px !important;
    padding-bottom: 20px !important;
    border-radius: 24px !important;
  }

  .nav-mobile-premium.nav--open .nav-link{
    min-height: 60px !important;
  }
}

@supports not (height: 100dvh){
  @media (max-width: 900px){
    .nav-mobile-premium.nav--open{
      max-height: calc(100vh - 104px) !important;
      min-height: calc(100vh - 104px) !important;
    }
  }
  @media (max-width: 560px){
    .nav-mobile-premium.nav--open{
      max-height: calc(100vh - 96px) !important;
      min-height: calc(100vh - 96px) !important;
    }
  }
}



/* ===================================================================
   REFINED ICON LANGUAGE
   Iconos más alineados al estilo boutique / luxury wellness
   =================================================================== */

/* home quick actions */
.luxury-action__icon{
  color:#B8956A !important;
  background:linear-gradient(180deg, rgba(255,255,255,.78), rgba(241,234,228,.76));
  box-shadow:0 10px 18px rgba(141,127,117,.08);
  border:1px solid rgba(255,255,255,.34);
}

/* mobile menu icon refinement */
@media (max-width: 900px){
  .nav-mobile-premium.nav--open .nav-link::before{
    color:#B8956A !important;
    background:linear-gradient(180deg, rgba(255,255,255,.96), rgba(244,238,232,.94)) !important;
    border:1px solid rgba(255,255,255,.44);
    box-shadow:0 8px 18px rgba(141,127,117,.07);
    font-weight:700;
  }

  /* cleaner set of symbols */
  .nav-mobile-premium.nav--open .nav-link:nth-child(1)::before{content:"◈";}
  .nav-mobile-premium.nav--open .nav-link:nth-child(2)::before{content:"✦";}
  .nav-mobile-premium.nav--open .nav-link:nth-child(3)::before{content:"◌";}
  .nav-mobile-premium.nav--open .nav-link:nth-child(4)::before{content:"✧";}
  .nav-mobile-premium.nav--open .nav-link:nth-child(5)::before{content:"◎";}
  .nav-mobile-premium.nav--open .nav-link:nth-last-child(1)::before{content:"◯";}
}


/* ===== Admin redesign v58 ===== */
body.admin-ui{background:linear-gradient(180deg, rgba(231,225,213,.78), rgba(255,255,255,.94));}
.admin-ui .luxury-topbar .brand-sub{font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:rgba(0,0,0,.56);}
.admin-shell{max-width:1400px;margin:0 auto;padding:18px 18px 30px;display:grid;grid-template-columns:300px minmax(0,1fr);gap:20px;align-items:start;}
.admin-sidebar{position:sticky;top:92px;display:flex;flex-direction:column;gap:14px;}
.admin-sidebar-card,.admin-sidebar-foot,.admin-page-header{background:rgba(255,255,255,.84);border:1px solid rgba(0,0,0,.08);box-shadow:0 18px 45px rgba(0,0,0,.06);backdrop-filter:blur(10px);}
.admin-sidebar-card{padding:20px;border-radius:24px;}
.admin-sidebar-card h1{margin:6px 0 8px;font-size:24px;}
.admin-sidebar-card p{margin:0;color:rgba(0,0,0,.68);line-height:1.5;}
.admin-sidebar-kicker,.admin-page-kicker,.admin-nav-label{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);font-weight:800;}
.admin-nav{display:flex;flex-direction:column;gap:12px;}
.admin-nav-group{background:rgba(255,255,255,.74);border:1px solid rgba(0,0,0,.07);border-radius:22px;padding:14px;display:flex;flex-direction:column;gap:8px;box-shadow:0 10px 26px rgba(0,0,0,.05);}
.admin-nav-link{display:flex;flex-direction:column;gap:2px;padding:12px 14px;border-radius:16px;color:var(--black);text-decoration:none;border:1px solid transparent;transition:all .18s ease;background:rgba(231,225,213,.25);}
.admin-nav-link span{font-weight:800;}
.admin-nav-link small{color:rgba(0,0,0,.58);font-size:12px;line-height:1.35;}
.admin-nav-link:hover,.admin-nav-link.is-active{background:linear-gradient(180deg, rgba(161,133,86,.17), rgba(231,225,213,.46));border-color:rgba(161,133,86,.35);transform:translateY(-1px);}
.admin-sidebar-foot{padding:14px;border-radius:22px;display:grid;gap:10px;}
.admin-pill{padding:10px 12px;border-radius:999px;background:rgba(231,225,213,.55);border:1px solid rgba(161,133,86,.22);font-size:13px;font-weight:700;}
.admin-main{min-width:0;}
.admin-page-header{padding:22px 24px;border-radius:26px;display:flex;align-items:center;justify-content:space-between;gap:18px;margin-bottom:18px;}
.admin-page-header h2{margin:6px 0 8px;font-size:30px;line-height:1.1;}
.admin-page-header p{margin:0;color:rgba(0,0,0,.65);max-width:760px;}
.admin-page-actions{display:flex;gap:10px;flex-wrap:wrap;}
.admin-main .container{max-width:none;margin:0;padding-top:0 !important;}
.admin-main .grid{gap:18px;}
.admin-main .card-lg,.admin-main .card,.admin-main .class-item{border-radius:24px;border:1px solid rgba(0,0,0,.07);box-shadow:0 18px 42px rgba(0,0,0,.06);}
.admin-main h2{margin-top:0;}
.admin-main table{overflow:hidden;border-radius:18px;}
.admin-main .table thead th{background:rgba(231,225,213,.68);color:#4f4227;border-bottom:1px solid rgba(161,133,86,.22);}
.admin-main .table tbody tr:nth-child(even){background:rgba(250,248,245,.7);}
.admin-main .actions{gap:10px;}
.admin-dashboard-grid{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:18px;}
.admin-stat-card,.admin-shortcuts,.admin-note-card{background:rgba(255,255,255,.86);border:1px solid rgba(0,0,0,.08);border-radius:24px;padding:20px;box-shadow:0 18px 42px rgba(0,0,0,.06);}
.admin-stat-card{grid-column:span 3;}
.admin-stat-label{font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:rgba(0,0,0,.55);font-weight:800;}
.admin-stat-value{font-size:34px;line-height:1;font-weight:900;margin:10px 0 6px;}
.admin-stat-help{color:rgba(0,0,0,.62);font-size:14px;line-height:1.45;}
.admin-shortcuts{grid-column:span 8;}
.admin-shortcuts-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:14px;}
.admin-shortcut{display:flex;flex-direction:column;gap:5px;padding:16px;border-radius:18px;background:linear-gradient(180deg, rgba(231,225,213,.50), rgba(255,255,255,.95));border:1px solid rgba(161,133,86,.18);color:var(--black);text-decoration:none;}
.admin-shortcut strong{font-size:16px;}
.admin-shortcut span{font-size:13px;color:rgba(0,0,0,.62);line-height:1.4;}
.admin-note-card{grid-column:span 4;}
.admin-note-list{display:grid;gap:10px;margin-top:12px;}
.admin-note-item{padding:12px 14px;border-radius:16px;background:rgba(231,225,213,.45);font-size:14px;line-height:1.45;}
.admin-hero-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px;}
@media (max-width:1100px){.admin-shell{grid-template-columns:1fr;}.admin-sidebar{position:static;}.admin-page-header{flex-direction:column;align-items:flex-start;}.admin-stat-card,.admin-shortcuts,.admin-note-card{grid-column:span 12;}}
@media (max-width:700px){.admin-shell{padding:14px;}.admin-shortcuts-grid{grid-template-columns:1fr;}.admin-page-header h2{font-size:24px;}.admin-page-actions,.admin-hero-actions{width:100%;}.admin-page-actions .btn,.admin-hero-actions .btn{width:100%;}}


.admin-nav-link{display:grid;grid-template-columns:44px minmax(0,1fr);align-items:center;column-gap:12px;}
.admin-nav-icon{width:32px;height:32px;object-fit:contain;opacity:.95;filter:drop-shadow(0 4px 10px rgba(161,133,86,.18));}
.admin-nav-text{min-width:0;display:flex;flex-direction:column;gap:2px;}
.btn-icon{display:inline-flex;align-items:center;gap:10px;}
.btn-icon img{width:18px;height:18px;object-fit:contain;}
.admin-shortcut{position:relative;overflow:hidden;align-items:flex-start;}
.admin-shortcut-icon{width:42px;height:42px;object-fit:contain;filter:drop-shadow(0 6px 14px rgba(161,133,86,.16));margin-bottom:2px;}
@media (max-width:700px){
  .admin-nav-group{padding:12px;}
  .admin-nav-link{grid-template-columns:38px minmax(0,1fr);padding:11px 12px;}
  .admin-nav-icon{width:28px;height:28px;}
  .admin-shortcuts-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;}
  .admin-shortcut{align-items:center;text-align:center;padding:16px 12px;min-height:148px;}
  .admin-shortcut-icon{width:48px;height:48px;margin-bottom:6px;}
  .admin-shortcut strong{font-size:15px;line-height:1.2;}
  .admin-shortcut span{display:none;}
  .admin-page-actions .btn{justify-content:center;}
}

@media (max-width: 640px){
  .luxury-action__icon--img img{width:38px;height:38px;}
}


/* ===== Client mobile cleanup v58b ===== */
.client-home-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:22px;}
.client-home-card{display:flex;flex-direction:column;align-items:flex-start;gap:8px;padding:18px;border-radius:24px;background:rgba(255,255,255,.92);border:1px solid rgba(255,255,255,.6);box-shadow:0 16px 34px rgba(141,127,117,.10);color:var(--black);min-height:148px;}
.client-home-card--primary{background:linear-gradient(180deg, rgba(255,255,255,.96), rgba(245,239,233,.96));}
.client-home-card__icon{width:64px;height:64px;border-radius:18px;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(243,236,229,.95));box-shadow:0 10px 24px rgba(141,127,117,.08);}
.client-home-card__icon img{width:40px;height:40px;object-fit:contain;display:block;}
.client-home-card__title{font-weight:800;font-size:18px;line-height:1.1;color:#2B2B2B;}
.client-home-card__meta{font-size:13px;line-height:1.35;color:rgba(0,0,0,.58);}
/* ===== Client home icons premium v58e ===== */
.client-luxury-actions .luxury-action{
  grid-template-columns:64px 1fr 24px;
  gap:16px;
  min-height:88px;
}
.client-luxury-actions .luxury-action__icon--img{
  position:relative;
  width:64px;
  height:64px;
  border-radius:22px;
  background:transparent;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:0;
  flex:0 0 64px;
  box-shadow:none;
  overflow:visible;
}
.client-luxury-actions .luxury-action__icon--img::before{
  content:"";
  position:absolute;
  inset:6px;
  border-radius:18px;
  background:
    radial-gradient(circle at 30% 28%, rgba(255,255,255,.92) 0%, rgba(255,255,255,.76) 34%, rgba(246,240,233,.40) 68%, rgba(199,168,124,.14) 100%);
  border:1px solid rgba(255,255,255,.54);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.78),
    0 8px 24px rgba(179,155,126,.12);
}
.client-luxury-actions .luxury-action__icon--img::after{
  content:"";
  position:absolute;
  width:44px;
  height:44px;
  left:2px;
  top:10px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(205,176,126,.18) 0%, rgba(205,176,126,.10) 45%, rgba(205,176,126,0) 78%);
  filter:blur(3px);
  z-index:0;
}
.client-luxury-actions .luxury-action__icon--img img{
  position:relative;
  z-index:1;
  width:36px;
  height:36px;
  object-fit:contain;
  display:block;
  filter: drop-shadow(0 3px 8px rgba(174,143,92,.12));
}
.client-luxury-actions .luxury-action__text{
  font-size:17px;
  line-height:1.08;
}
.client-luxury-actions .luxury-action--featured .luxury-action__icon--img::before{
  background:
    radial-gradient(circle at 32% 28%, rgba(255,255,255,.40) 0%, rgba(255,255,255,.24) 34%, rgba(255,255,255,.10) 68%, rgba(255,255,255,.05) 100%);
  border-color:rgba(255,255,255,.30);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.24),
    0 10px 24px rgba(119,91,56,.14);
}
.client-luxury-actions .luxury-action--featured .luxury-action__icon--img::after{
  background:radial-gradient(circle, rgba(255,236,190,.26) 0%, rgba(255,236,190,.14) 45%, rgba(255,236,190,0) 78%);
}
@media (max-width:560px){
  .client-luxury-actions .luxury-action{
    grid-template-columns:58px 1fr 20px;
    gap:14px;
    min-height:82px;
    padding:14px 18px;
  }
  .client-luxury-actions .luxury-action__icon--img{
    width:58px;
    height:58px;
    border-radius:20px;
    flex-basis:58px;
  }
  .client-luxury-actions .luxury-action__icon--img::before{
    inset:5px;
    border-radius:16px;
  }
  .client-luxury-actions .luxury-action__icon--img img{
    width:32px;
    height:32px;
  }
  .client-luxury-actions .luxury-action__text{
    font-size:16px;
  }
}

@media (max-width:900px){
  .nav-mobile-premium.nav--open{background:rgba(247,244,241,.96)!important;backdrop-filter:blur(14px)!important;-webkit-backdrop-filter:blur(14px)!important;}
  .nav-mobile-premium.nav--open .nav-link{display:flex!important;align-items:center!important;justify-content:space-between!important;min-height:58px!important;padding:0 18px!important;border-radius:18px!important;background:rgba(255,255,255,.96)!important;font-size:16px!important;font-weight:800!important;color:#2B2B2B!important;box-shadow:0 10px 22px rgba(141,127,117,.07)!important;}
  .nav-mobile-premium.nav--open .nav-link__icon{display:none!important;}
  .nav-mobile-premium.nav--open .nav-link::before{content:none!important;display:none!important;}
  .nav-mobile-premium.nav--open .nav-link::after{content:"›"!important;font-size:24px!important;color:#B8956A!important;line-height:1!important;}
  .nav-mobile-premium.nav--open::after{display:none!important;content:none!important;}
}
@media (max-width:560px){
  .client-home-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;}
  .client-home-card{padding:16px;min-height:136px;border-radius:22px;}
  .client-home-card__icon{width:58px;height:58px;border-radius:16px;}
  .client-home-card__icon img{width:36px;height:36px;}
  .client-home-card__title{font-size:16px;}
  .client-home-card__meta{font-size:12px;}
}


@media (max-width:900px){
  .nav-mobile-premium.nav--open{
    background:rgba(247,244,241,.96)!important;
    backdrop-filter:blur(14px)!important;
    -webkit-backdrop-filter:blur(14px)!important;
  }
  .nav-mobile-premium.nav--open .nav-link{
    display:grid!important;
    grid-template-columns:42px minmax(0,1fr) 18px!important;
    align-items:center!important;
    gap:12px!important;
    min-height:64px!important;
    padding:0 16px!important;
    border-radius:20px!important;
    background:rgba(255,255,255,.96)!important;
    font-size:16px!important;
    font-weight:800!important;
    color:#2B2B2B!important;
    box-shadow:0 10px 22px rgba(141,127,117,.07)!important;
  }
  .nav-mobile-premium.nav--open .nav-link__icon{
    display:block!important;
    width:42px!important;
    height:42px!important;
    padding:8px!important;
    border-radius:14px!important;
    background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(243,236,229,.96))!important;
    box-shadow:0 8px 18px rgba(141,127,117,.08)!important;
    object-fit:contain!important;
  }
  .nav-mobile-premium.nav--open .nav-link span{
    display:block!important;
    min-width:0;
  }
  .nav-mobile-premium.nav--open .nav-link::before{
    content:none!important;
    display:none!important;
  }
  .nav-mobile-premium.nav--open .nav-link::after{
    content:"›"!important;
    font-size:24px!important;
    color:#B8956A!important;
    line-height:1!important;
    text-align:right!important;
  }
  .nav-mobile-premium.nav--open::after{
    display:none!important;
    content:none!important;
  }
}

@media (max-width:560px){
  .client-luxury-actions .luxury-action__icon--img{
    width:54px;
    height:54px;
    border-radius:16px;
    flex-basis:54px;
  }
  .client-luxury-actions .luxury-action__icon--img img{width:32px;height:32px;}
  .client-luxury-actions .luxury-action__text{font-size:16px;}
  .nav-mobile-premium.nav--open .nav-link{
    grid-template-columns:38px minmax(0,1fr) 16px!important;
    min-height:60px!important;
    border-radius:18px!important;
    padding:0 14px!important;
  }
  .nav-mobile-premium.nav--open .nav-link__icon{
    width:38px!important;
    height:38px!important;
    padding:7px!important;
    border-radius:12px!important;
  }
}

/* ===== Client nav icons only on mobile + refined premium look v58d ===== */
/* Desktop/tablet: keep header nav elegant and text-only */
@media (min-width:901px){
  .topbar .nav-link__icon,
  .luxury-topbar .nav-link__icon{
    display:none !important;
  }
  .topbar .nav-link,
  .luxury-topbar .nav-link{
    gap:0 !important;
    padding-left:16px;
    padding-right:16px;
  }
}

/* Mobile: show icons only inside the opened drawer/sheet */
@media (max-width:900px){
  .nav-mobile-premium .nav-link__icon{
    display:none;
  }
  .nav-mobile-premium.nav--open{
    background:rgba(247,244,241,.94)!important;
    backdrop-filter:blur(16px)!important;
    -webkit-backdrop-filter:blur(16px)!important;
    border:1px solid rgba(255,255,255,.52)!important;
  }
  .nav-mobile-premium.nav--open .nav-link{
    display:grid!important;
    grid-template-columns:46px minmax(0,1fr) 18px!important;
    align-items:center!important;
    gap:14px!important;
    min-height:66px!important;
    padding:0 16px!important;
    border-radius:20px!important;
    background:rgba(255,255,255,.92)!important;
    border:1px solid rgba(161,133,86,.10)!important;
    box-shadow:0 12px 28px rgba(141,127,117,.08)!important;
  }
  .nav-mobile-premium.nav--open .nav-link__icon{
    display:block!important;
    width:42px!important;
    height:42px!important;
    padding:0!important;
    border-radius:0!important;
    background:transparent!important;
    box-shadow:none!important;
    filter:drop-shadow(0 6px 14px rgba(161,133,86,.16))!important;
    object-fit:contain!important;
  }
  .nav-mobile-premium.nav--open .nav-link span{
    font-weight:800!important;
    letter-spacing:.01em;
  }
  .nav-mobile-premium.nav--open .nav-link::after{
    content:"›"!important;
    font-size:24px!important;
    color:#B8956A!important;
    line-height:1!important;
    text-align:right!important;
  }
}

@media (max-width:560px){
  .nav-mobile-premium.nav--open .nav-link{
    grid-template-columns:42px minmax(0,1fr) 16px!important;
    min-height:62px!important;
    border-radius:18px!important;
    padding:0 14px!important;
  }
  .nav-mobile-premium.nav--open .nav-link__icon{
    width:38px!important;
    height:38px!important;
  }
}
