:root {
  --pink:#ff6eb4; --pink-deep:#ff2d87; --pink-neon:#f7006e; --pink-soft:#fff0f7;
  --gold:#ff9f00; --gold-light:#ffbe00; --gold-bright:#ffd740; --black:#1a0a2e; --black-soft:#2d1b4e;
  --white:#fffcff; --white-off:#f9f0ff; --purple:#9b00ff; --purple-light:#c354ff; --purple-deep:#6600cc;
  --teal:#00d4c8; --teal-deep:#00a89f; --orange:#ff6b00; --red-bold:#ff1a1a;
  --grey:#7a6872; --grey-light:#f3eeff;
  --shadow-pink:0 8px 40px rgba(255,45,135,0.35);
  --shadow-gold:0 8px 40px rgba(255,159,0,0.38);
  --shadow-glow:0 0 30px rgba(155,0,255,0.35);
  --font-display:'Playfair Display',serif; --font-heading:'Cormorant Garamond',serif; --font-body:'Jost',sans-serif;
  --radius:16px; --radius-lg:24px; --transition:0.3s cubic-bezier(0.4,0,0.2,1);
  --sidebar-w:260px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;font-size:16px;}
body{font-family:var(--font-body);background:var(--white);color:var(--black);overflow-x:hidden;-webkit-font-smoothing:antialiased;}

/* ============================================================
   PAGE LOADER — standalone, no JS required for initial render
   ============================================================ */
#page-loader{
  position:fixed;inset:0;z-index:9999;
  background:linear-gradient(135deg,#1a0a2e 0%,#2d1050 50%,#1a0a2e 100%);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;
  transition:opacity .5s ease;
}
.loader-logo{
  font-family:var(--font-display);font-size:2.4rem;font-weight:900;
  background:linear-gradient(135deg,var(--pink),var(--gold));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  letter-spacing:.06em;animation:loaderPulse 1.6s ease-in-out infinite;
}
@keyframes loaderPulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(.97)}}
.loader-ring{
  width:48px;height:48px;border-radius:50%;
  border:3px solid rgba(255,110,180,.2);
  border-top-color:var(--pink-deep);
  animation:loaderSpin .9s linear infinite;
}
@keyframes loaderSpin{to{transform:rotate(360deg)}}

/* ============================================================
   AUTH SCREEN — fully standalone CSS, no JS needed to style
   ============================================================ */
#auth-screen{
  display:block; /* shown by default; JS hides it after auth check */
  min-height:100vh;background:linear-gradient(135deg,#1a0a2e 0%,#3a1040 50%,#1a0a2e 100%);
  position:relative;overflow:hidden;
}
.auth-bg{position:absolute;inset:0;pointer-events:none;overflow:hidden;}
.auth-bg-orb{position:absolute;border-radius:50%;filter:blur(80px);}
.auth-bg-orb.o1{width:500px;height:500px;background:rgba(155,0,255,.18);top:-100px;left:-100px;animation:orbFloat 12s ease-in-out infinite;}
.auth-bg-orb.o2{width:400px;height:400px;background:rgba(255,45,135,.15);bottom:-80px;right:-80px;animation:orbFloat 9s ease-in-out infinite reverse;}
.auth-bg-orb.o3{width:300px;height:300px;background:rgba(201,168,76,.12);top:40%;left:40%;animation:orbFloat 14s ease-in-out infinite 3s;}
@keyframes orbFloat{0%,100%{transform:translate(0,0)}33%{transform:translate(30px,-20px)}66%{transform:translate(-20px,30px)}}

.auth-container{
  position:relative;z-index:1;
  display:grid;grid-template-columns:1fr 1fr;
  min-height:100vh;max-width:1200px;margin:0 auto;align-items:center;padding:40px;gap:60px;
}
.auth-left{color:white;padding:20px 0;}
.auth-brand{display:flex;align-items:center;gap:14px;margin-bottom:40px;}
.auth-logo-mark{
  width:52px;height:52px;border-radius:14px;
  background:linear-gradient(135deg,var(--purple),var(--pink-deep));
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-size:1.5rem;font-weight:900;color:white;
  box-shadow:0 8px 24px rgba(155,0,255,.4);
}
.auth-brand-name{font-family:var(--font-display);font-size:1.3rem;font-weight:700;color:white;}
.auth-brand-sub{font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);margin-top:2px;}
.auth-left-headline{
  font-family:var(--font-heading);font-size:3.4rem;font-weight:300;line-height:1.1;
  color:white;margin-bottom:20px;
}
.auth-left-headline em{
  font-style:italic;
  background:linear-gradient(135deg,var(--pink),var(--gold));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.auth-left-sub{font-size:.95rem;color:rgba(255,255,255,.65);line-height:1.65;max-width:420px;margin-bottom:36px;}
.auth-perks{display:flex;flex-direction:column;gap:16px;}
.auth-perk{display:flex;align-items:center;gap:14px;}
.perk-icon{
  width:40px;height:40px;border-radius:10px;
  display:flex;align-items:center;justify-content:center;font-size:.95rem;flex-shrink:0;
}
.perk-icon.pink{background:rgba(255,110,180,.2);color:var(--pink);}
.perk-icon.gold{background:rgba(201,168,76,.2);color:var(--gold);}
.perk-icon.purple{background:rgba(155,0,255,.2);color:var(--purple-light);}
.perk-icon.green{background:rgba(34,197,94,.15);color:#4ade80;}
.perk-text strong{display:block;font-size:.88rem;font-weight:600;color:white;}
.perk-text span{font-size:.8rem;color:rgba(255,255,255,.5);}

.auth-right{display:flex;align-items:center;justify-content:center;}
.auth-card{
  background:rgba(255,255,255,.97);border-radius:24px;
  padding:36px;width:100%;max-width:440px;
  box-shadow:0 32px 80px rgba(0,0,0,.4);
}
.auth-tabs{display:flex;background:var(--white-off);border-radius:12px;padding:4px;margin-bottom:24px;gap:4px;}
.auth-tab{
  flex:1;padding:10px;border-radius:9px;border:none;background:transparent;
  font-family:var(--font-body);font-size:.88rem;font-weight:500;color:var(--grey);
  cursor:pointer;transition:all var(--transition);
}
.auth-tab.active{background:white;color:var(--black);font-weight:600;box-shadow:0 2px 8px rgba(0,0,0,.08);}
.auth-error{
  display:none;align-items:center;gap:8px;
  background:#fef2f2;border:1px solid #fecaca;color:#dc2626;
  border-radius:10px;padding:10px 14px;margin-bottom:16px;font-size:.84rem;
}
.auth-error.show{display:flex;}
.auth-success{
  display:none;align-items:center;gap:8px;
  background:#f0fdf4;border:1px solid #bbf7d0;color:#16a34a;
  border-radius:10px;padding:10px 14px;margin-bottom:16px;font-size:.84rem;
}
.auth-success.show{display:flex;}
.auth-form-title{font-family:var(--font-heading);font-size:1.7rem;font-weight:600;color:var(--black);margin-bottom:4px;}
.auth-form-sub{font-size:.84rem;color:var(--grey);margin-bottom:20px;}

.form-field{margin-bottom:16px;}
.form-field label{
  display:block;font-size:.78rem;font-weight:600;
  text-transform:uppercase;letter-spacing:.06em;color:var(--black-soft);margin-bottom:6px;
}
.field-wrap{position:relative;display:flex;align-items:center;}
.field-wrap input,.field-wrap select{
  width:100%;padding:11px 14px 11px 40px;
  border:1.5px solid #e5e7eb;border-radius:10px;
  font-family:var(--font-body);font-size:.9rem;color:var(--black);
  background:var(--white-off);outline:none;transition:border-color var(--transition);
}
.field-wrap input:focus,.field-wrap select:focus{border-color:var(--pink-deep);}
.field-icon{position:absolute;left:13px;color:var(--grey);font-size:.84rem;pointer-events:none;}
.toggle-pw{
  position:absolute;right:12px;background:none;border:none;
  color:var(--grey);font-size:.84rem;cursor:pointer;padding:4px;
  transition:color var(--transition);
}
.toggle-pw:hover{color:var(--pink-deep);}
.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:12px;}

.pw-strength{margin-top:8px;}
.pw-strength-bars{display:flex;gap:4px;margin-bottom:4px;}
.pw-bar{flex:1;height:4px;border-radius:2px;background:#e5e7eb;transition:background .3s;}
.pw-strength-label{font-size:.74rem;color:var(--grey);}

.forgot-link{
  display:block;text-align:right;font-size:.8rem;color:var(--pink-deep);
  cursor:pointer;margin-bottom:16px;font-weight:500;
}
.forgot-link:hover{text-decoration:underline;}

.btn-auth-submit{
  width:100%;padding:13px;border-radius:12px;
  background:linear-gradient(135deg,var(--purple),var(--pink-deep));
  color:white;font-family:var(--font-body);font-size:.95rem;font-weight:600;
  border:none;cursor:pointer;position:relative;overflow:hidden;
  transition:transform var(--transition),box-shadow var(--transition);
  margin-bottom:14px;
}
.btn-auth-submit:hover{transform:translateY(-2px);box-shadow:var(--shadow-pink);}
.btn-shimmer{
  position:absolute;top:0;left:-100%;width:60%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.25),transparent);
  animation:shimmerSlide 2.5s infinite;pointer-events:none;
}
@keyframes shimmerSlide{0%{left:-100%}100%{left:200%}}

.auth-footer-link{font-size:.82rem;color:var(--grey);text-align:center;}
.auth-footer-link a{color:var(--pink-deep);font-weight:600;cursor:pointer;}
.auth-footer-link a:hover{text-decoration:underline;}

/* Responsive auth */
@media(max-width:900px){
  .auth-container{grid-template-columns:1fr;padding:32px 24px;}
  .auth-left{display:none;}
  .auth-card{max-width:100%;}
}
@media(max-width:480px){
  .auth-card{padding:24px 20px;border-radius:16px;}
  .auth-left-headline{font-size:2.4rem;}
  .form-row-2{grid-template-columns:1fr;}
}
a{text-decoration:none;color:inherit;}
button{cursor:pointer;font-family:var(--font-body);border:none;}
::-webkit-scrollbar{width:6px;}
::-webkit-scrollbar-track{background:var(--white-off);}
::-webkit-scrollbar-thumb{background:var(--pink-deep);border-radius:3px;}

/* DASHBOARD */
#dashboard-screen{display:none;min-height:100vh;}
.announcement-bar{background:linear-gradient(90deg,var(--black) 0%,#3a1828 50%,var(--black) 100%);color:var(--pink);height:38px;overflow:hidden;display:flex;align-items:center;position:relative;z-index:200;}
.announcement-track{display:flex;gap:80px;white-space:nowrap;animation:scrollTrack 40s linear infinite;font-size:.78rem;font-weight:500;letter-spacing:.04em;}
.announcement-track span{color:var(--pink);}
.announcement-track span:nth-child(odd){color:#ffd740;}
@keyframes scrollTrack{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.db-navbar{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.95);backdrop-filter:blur(20px);border-bottom:1px solid rgba(244,184,200,.3);box-shadow:0 2px 20px rgba(232,117,138,.08);}
.db-nav-container{max-width:100%;padding:0 24px;height:68px;display:flex;align-items:center;gap:16px;}
.db-hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;padding:8px;}
.db-hamburger span{display:block;width:24px;height:2px;background:var(--black);border-radius:2px;transition:all var(--transition);}
.db-nav-logo{display:flex;align-items:center;gap:12px;}
.logo-mark{width:40px;height:40px;background:linear-gradient(135deg,var(--purple),var(--pink-deep));border-radius:10px;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:1.2rem;font-weight:900;color:white;}
.logo-main{font-family:var(--font-display);font-size:1.1rem;font-weight:700;display:block;}
.logo-sub{font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);display:block;}
.db-nav-spacer{flex:1;}
.db-nav-search{position:relative;display:flex;align-items:center;}
.db-nav-search input{padding:9px 14px 9px 38px;border:1.5px solid #e5e7eb;border-radius:50px;font-family:var(--font-body);font-size:.84rem;outline:none;width:220px;background:var(--white-off);transition:all var(--transition);}
.db-nav-search input:focus{border-color:var(--pink-deep);width:260px;}
.db-nav-search i{position:absolute;left:12px;color:var(--grey);font-size:.84rem;}
.db-nav-actions{display:flex;align-items:center;gap:10px;}
.db-notif-btn{position:relative;width:40px;height:40px;border-radius:50%;background:var(--white-off);border:1.5px solid #e5e7eb;display:flex;align-items:center;justify-content:center;color:var(--grey);transition:all var(--transition);font-size:.9rem;}
.db-notif-btn:hover{border-color:var(--pink-deep);color:var(--pink-deep);}
.notif-dot{position:absolute;top:8px;right:8px;width:8px;height:8px;background:var(--pink-neon);border-radius:50%;border:2px solid white;animation:notifPulse 2s infinite;}
.notif-badge{position:absolute;top:2px;right:2px;min-width:18px;height:18px;padding:0 4px;background:var(--pink-neon);color:white;border-radius:50px;font-size:.6rem;font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid white;animation:badgePop .3s cubic-bezier(.4,0,.2,1);}
@keyframes badgePop{0%{transform:scale(0)}80%{transform:scale(1.15)}100%{transform:scale(1)}}
.sidebar-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:50px;font-size:.65rem;font-weight:700;margin-left:auto;}
@keyframes notifPulse{0%,100%{box-shadow:0 0 0 0 rgba(176,77,101,.4)}50%{box-shadow:0 0 0 6px rgba(176,77,101,0)}}
.db-user-pill{display:flex;align-items:center;gap:10px;background:var(--white-off);border:1.5px solid rgba(244,184,200,.3);border-radius:50px;padding:6px 14px 6px 6px;cursor:pointer;transition:all var(--transition);}
.db-user-pill:hover{border-color:var(--pink-deep);}
.db-user-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--purple),var(--pink-deep));display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:700;color:white;flex-shrink:0;}
.db-user-name{font-size:.84rem;font-weight:600;color:var(--black-soft);}
.db-body{display:flex;min-height:calc(100vh - 106px);}
.db-sidebar{width:var(--sidebar-w);flex-shrink:0;background:white;border-right:1px solid rgba(244,184,200,.2);display:flex;flex-direction:column;position:sticky;top:106px;height:calc(100vh - 106px);overflow-y:auto;transition:transform var(--transition);}
.db-sidebar::-webkit-scrollbar{width:0;}
.sidebar-section-label{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--grey);padding:20px 20px 8px;}
.sidebar-nav{padding:0 10px;}
.sidebar-item{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:12px;cursor:pointer;font-size:.88rem;font-weight:500;color:var(--grey);transition:all var(--transition);margin-bottom:2px;position:relative;border:none;background:none;width:100%;text-align:left;}
.sidebar-item:hover{background:var(--pink-soft);color:var(--pink-deep);}
.sidebar-item.active{background:linear-gradient(135deg,var(--pink-soft),#fde8f0);color:var(--pink-deep);font-weight:600;}
.sidebar-item.active::before{content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:60%;background:var(--pink-deep);border-radius:0 2px 2px 0;}
.sidebar-item i{width:18px;text-align:center;font-size:.9rem;}
.sidebar-badge{margin-left:auto;background:var(--pink-neon);color:white;font-size:.65rem;font-weight:700;padding:2px 7px;border-radius:50px;min-width:20px;text-align:center;}
.sidebar-item.logout-item{color:#ef4444;}
.sidebar-item.logout-item:hover{background:#fef2f2;color:#dc2626;}
.sidebar-divider{height:1px;background:rgba(244,184,200,.2);margin:12px 20px;}
.sidebar-loyalty{margin:12px 10px;background:linear-gradient(135deg,#2a1018,#4a1830);border-radius:var(--radius);padding:16px;color:white;}
.sl-points{font-family:var(--font-heading);font-size:1.8rem;font-weight:700;color:#ffd740;}
.sl-label{font-size:.72rem;color:rgba(255,255,255,.6);text-transform:uppercase;letter-spacing:.08em;}
.sl-bar-wrap{background:rgba(255,255,255,.15);border-radius:4px;height:5px;margin-top:10px;}
.sl-bar{height:100%;background:linear-gradient(90deg,var(--orange),#ffd740);border-radius:4px;transition:width 1s ease;}
.sl-next{font-size:.72rem;color:rgba(255,255,255,.5);margin-top:5px;}
.db-main{flex:1;min-width:0;padding:32px;background:#fdf4f6;}
.db-panel{display:none;}
.db-panel.active{display:block;}

/* GREETING */
.db-greeting{margin-bottom:28px;}
.db-greeting h1{font-family:var(--font-heading);font-size:2rem;font-weight:700;color:var(--black);}
.db-greeting h1 span{background:linear-gradient(135deg,var(--purple),var(--pink-deep));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.db-greeting p{font-size:.9rem;color:var(--grey);margin-top:4px;}

/* STATS ROW */
.db-stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:28px;}
.db-stat-card{background:white;border-radius:var(--radius);padding:20px;border:1.5px solid rgba(244,184,200,.2);position:relative;overflow:hidden;transition:transform var(--transition),box-shadow var(--transition);}
.db-stat-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-pink);}
.db-stat-card::before{content:'';position:absolute;top:0;right:0;width:80px;height:80px;border-radius:50%;background:var(--pink-soft);transform:translate(20px,-20px);}
.db-stat-icon{width:42px;height:42px;border-radius:10px;margin-bottom:14px;display:flex;align-items:center;justify-content:center;font-size:1rem;position:relative;z-index:1;}
.db-stat-icon.pink{background:var(--pink-soft);color:var(--pink-deep);}
.db-stat-icon.gold{background:rgba(201,168,76,.1);color:var(--gold);}
.db-stat-icon.purple{background:rgba(124,58,110,.08);color:var(--purple);}
.db-stat-icon.green{background:rgba(34,197,94,.08);color:#16a34a;}
.db-stat-num{font-family:var(--font-heading);font-size:1.8rem;font-weight:700;color:var(--black);}
.db-stat-label{font-size:.78rem;color:var(--grey);margin-top:2px;}

/* HERO STRIP */
.dash-hero{position:relative;border-radius:var(--radius-lg);overflow:hidden;min-height:340px;display:flex;align-items:center;background:linear-gradient(135deg,#2a1018 0%,#4a1830 40%,#1a1020 100%);margin-bottom:28px;}
.dash-hero-bg{position:absolute;inset:0;overflow:hidden;}
.dash-hero-orb{position:absolute;border-radius:50%;filter:blur(60px);}
.dash-hero-orb.o1{width:300px;height:300px;background:rgba(232,117,138,.3);right:-60px;top:-60px;animation:orbFloat 10s ease-in-out infinite;}
.dash-hero-orb.o2{width:200px;height:200px;background:rgba(201,168,76,.2);bottom:-40px;left:40%;animation:orbFloat 8s ease-in-out infinite reverse;}
.dash-hero-content{position:relative;z-index:1;padding:48px;color:white;}
.dash-hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.08);border:1px solid rgba(244,184,200,.3);backdrop-filter:blur(10px);padding:7px 14px;border-radius:50px;color:var(--pink);font-size:.76rem;font-weight:500;letter-spacing:.06em;text-transform:uppercase;margin-bottom:16px;}
.badge-dot{width:8px;height:8px;background:#22c55e;border-radius:50%;animation:notifPulse 2s infinite;}
.dash-hero h2{font-family:var(--font-display);font-size:clamp(1.8rem,3.5vw,2.8rem);font-weight:900;line-height:1.08;margin-bottom:12px;}
.dash-hero h2 em{font-style:italic;background:linear-gradient(90deg,var(--pink),var(--purple-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.dash-hero p{color:rgba(255,255,255,.7);font-size:.96rem;max-width:400px;margin-bottom:24px;}
.dash-hero-cta{display:flex;gap:12px;flex-wrap:wrap;}
.btn-dash-primary{background:linear-gradient(135deg,var(--pink-deep),var(--pink-neon));color:white;padding:13px 28px;border-radius:50px;font-size:.9rem;font-weight:600;display:flex;align-items:center;gap:8px;box-shadow:0 8px 32px rgba(155,0,255,.35);transition:all var(--transition);position:relative;overflow:hidden;border:none;cursor:pointer;}
.btn-dash-primary:hover{transform:translateY(-2px);box-shadow:0 12px 40px rgba(176,77,101,.45);}
.btn-dash-secondary{background:rgba(255,255,255,.1);border:1.5px solid rgba(255,255,255,.25);color:white;padding:13px 24px;border-radius:50px;font-size:.9rem;font-weight:500;transition:all var(--transition);cursor:pointer;}
.btn-dash-secondary:hover{background:rgba(255,255,255,.2);}
.dash-hero-art{position:absolute;right:40px;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;gap:12px;align-items:center;}
.dash-hero-bubble{width:110px;height:110px;border-radius:50%;border:2px solid rgba(244,184,200,.2);display:flex;align-items:center;justify-content:center;font-size:2.6rem;animation:bubbleFloat 6s ease-in-out infinite;}
.dash-hero-bubble:nth-child(2){animation-delay:-2s;width:80px;height:80px;font-size:2rem;}
.dash-hero-bubble:nth-child(3){animation-delay:-4s;width:65px;height:65px;font-size:1.5rem;}
@keyframes bubbleFloat{0%,100%{transform:translateY(0) scale(1)}50%{transform:translateY(-14px) scale(1.04)}}

/* SECTION LABELS */
.dash-eyebrow{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--pink-deep);margin-bottom:6px;}
.dash-section-title{font-family:var(--font-heading);font-size:1.5rem;font-weight:700;color:var(--black);margin-bottom:4px;}
.dash-section-sub{font-size:.84rem;color:var(--grey);margin-bottom:18px;}

/* CATEGORY PILLS */
.section-eyebrow{display:block;font-size:0.78rem;font-weight:600;text-transform:uppercase;letter-spacing:0.14em;color:var(--pink-deep);margin-bottom:10px;}
.section-title{font-family:var(--font-heading);font-size:clamp(1.5rem,3vw,2.2rem);font-weight:700;color:var(--black);line-height:1.1;margin-bottom:8px;}
.db-categories-header .section-eyebrow{color:#a0607a;letter-spacing:0.18em;}
.db-categories-header .section-title{color:#1c1018;}
.categories-grid{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;margin-bottom:24px;}
.cat-card{position:relative;overflow:hidden;background:var(--white);border:1.5px solid rgba(244,184,200,0.3);border-radius:var(--radius);padding:16px 20px;display:flex;flex-direction:column;align-items:center;gap:8px;min-width:110px;cursor:pointer;transition:all var(--transition);font-family:var(--font-body);font-size:0.82rem;font-weight:500;color:var(--black-soft);}
.cat-icon{font-size:1.5rem;}
.cat-glow{position:absolute;inset:0;background:radial-gradient(circle at center,rgba(244,184,200,0.15),transparent 70%);opacity:0;transition:opacity var(--transition);}
.cat-card:hover,.cat-card.active{border-color:var(--purple);color:var(--purple);transform:translateY(-4px);box-shadow:var(--shadow-glow);background:var(--pink-soft);}
.cat-card:hover .cat-glow,.cat-card.active .cat-glow{opacity:1;}
.cat-card.active{background:linear-gradient(135deg,#f8f0ff,rgba(155,0,255,0.08));}
.cat-card[data-cat="new"] span{color:#c2637a;font-weight:600;}
.cat-card[data-cat="new"] .cat-icon{filter:drop-shadow(0 0 6px rgba(194,99,122,0.5));}
.cat-card[data-cat="luxury"] span{color:#b8945a;font-weight:600;}
.cat-card[data-cat="bridal"] span{color:#a0607a;font-weight:600;}
.cat-card[data-cat="most-booked"] span{color:#7c3a6e;font-weight:600;}

/* STYLE CARDS */
.styles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:24px;}
.style-card{background:white;border-radius:var(--radius-lg);overflow:hidden;box-shadow:0 4px 20px rgba(0,0,0,0.07);transition:all var(--transition);cursor:pointer;position:relative;}
.style-card:hover{transform:translateY(-8px);box-shadow:0 16px 48px rgba(232,117,138,0.2);}
.card-img-wrap{position:relative;aspect-ratio:3/4;background:linear-gradient(135deg,var(--pink-soft),#fce8ee);overflow:hidden;}
.card-img-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:4rem;opacity:0.4;}
.card-img,.card-img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform 0.6s ease;display:block;}
.card-img-no-image{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:rgba(255,255,255,0.25);font-size:0.72rem;letter-spacing:0.05em;background:linear-gradient(135deg,rgba(255,255,255,0.03),rgba(255,255,255,0.06));}
.card-img-no-image i{font-size:2rem;opacity:0.3;}
.style-card:hover .card-img,.style-card:hover .card-img-wrap img,.style-card:hover .card-img-placeholder{transform:scale(1.05);}
.card-badge{display:none;}
.card-badge.gold{display:none;}
.card-like{position:absolute;top:12px;right:12px;width:36px;height:36px;background:rgba(255,255,255,0.9);backdrop-filter:blur(10px);border-radius:50%;display:flex;align-items:center;justify-content:center;border:none;font-size:0.9rem;color:var(--grey);transition:all var(--transition);z-index:2;}
.card-like:hover,.card-like.liked{color:var(--pink-neon);transform:scale(1.15);}
.card-body{padding:14px 16px;}
.card-title{font-family:var(--font-heading);font-size:1rem;font-weight:600;color:var(--black);margin-bottom:8px;line-height:1.3;}
.card-meta{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;}
.card-rating{display:flex;align-items:center;gap:4px;font-size:0.78rem;color:var(--gold);}
.card-bookings{font-size:0.72rem;color:var(--grey);}
.card-price{font-family:var(--font-heading);font-size:1.1rem;font-weight:700;color:var(--pink-deep);margin-bottom:12px;}
.card-price .original{text-decoration:line-through;color:var(--grey);font-size:0.85rem;margin-left:6px;}
.btn-card-book{width:100%;background:linear-gradient(135deg,var(--teal-deep),var(--teal));color:white;border:none;padding:10px;border-radius:10px;font-size:0.82rem;font-weight:600;letter-spacing:0.02em;transition:all var(--transition);position:relative;overflow:hidden;}
.btn-card-book:hover{background:linear-gradient(135deg,var(--pink-deep),var(--pink-neon));transform:translateY(-1px);box-shadow:0 4px 16px rgba(255,45,135,0.4);}
.btn-load-more{display:block;width:100%;padding:14px;background:white;border:2px solid rgba(244,184,200,.4);border-radius:50px;font-weight:600;font-size:.9rem;color:var(--pink-deep);transition:all var(--transition);margin-bottom:28px;position:relative;overflow:hidden;}
.btn-load-more:hover{background:var(--pink-soft);border-color:var(--pink-deep);}

/* REVIEWS */
.reviews-track-wrap{overflow:hidden;margin-bottom:28px;}
.reviews-track{display:flex;gap:16px;animation:reviewsScroll 40s linear infinite;width:max-content;}
.reviews-track:hover{animation-play-state:paused;}
@keyframes reviewsScroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.review-card{background:white;border:1.5px solid rgba(244,184,200,.2);border-radius:var(--radius);padding:20px;width:280px;flex-shrink:0;}
.review-stars{color:var(--gold);font-size:.9rem;margin-bottom:8px;}
.review-text{font-size:.84rem;color:var(--grey);line-height:1.7;margin-bottom:14px;font-style:italic;}
.review-author{display:flex;align-items:center;gap:10px;}
.review-avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--purple),var(--pink-deep));display:flex;align-items:center;justify-content:center;font-weight:700;color:white;font-size:.84rem;flex-shrink:0;}
.review-name{font-weight:600;font-size:.84rem;}
.review-style{font-size:.72rem;color:var(--grey);}
.verified-badge{margin-left:auto;background:#f0fdf4;color:#16a34a;font-size:.72rem;font-weight:600;padding:3px 8px;border-radius:50px;}

/* BOOKING FORM */
.dash-booking-wrap{background:white;border-radius:var(--radius-lg);padding:32px;border:1.5px solid rgba(244,184,200,.2);margin-bottom:28px;}
.dash-booking-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.form-group{display:flex;flex-direction:column;gap:6px;}
.form-group label{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--black-soft);}
.form-group input,.form-group select{padding:11px 14px;border:1.5px solid #e5e7eb;border-radius:10px;font-family:var(--font-body);font-size:.9rem;outline:none;background:var(--white-off);transition:border-color var(--transition);}
.form-group input:focus,.form-group select:focus{border-color:var(--pink-deep);background:white;}
.form-group.full{grid-column:1 / -1;}
.btn-book-submit{grid-column:1 / -1;padding:14px;background:linear-gradient(135deg,var(--pink-deep),var(--pink-neon));color:white;border:none;border-radius:12px;font-size:.96rem;font-weight:700;display:flex;align-items:center;justify-content:center;gap:10px;position:relative;overflow:hidden;transition:all var(--transition);cursor:pointer;}
.btn-book-submit:hover{transform:translateY(-2px);box-shadow:var(--shadow-pink);}
.booking-note{grid-column:1 / -1;text-align:center;font-size:.8rem;color:var(--grey);}

/* ABOUT */
.dash-about{background:white;border-radius:var(--radius-lg);padding:32px;border:1.5px solid rgba(244,184,200,.2);margin-bottom:28px;display:grid;grid-template-columns:200px 1fr;gap:32px;align-items:center;}

/* ---- Home shortcuts grid ---- */
.home-shortcuts-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:8px;}
.home-shortcut{background:white;border:1.5px solid rgba(244,184,200,.25);border-radius:var(--radius);padding:20px 12px;display:flex;flex-direction:column;align-items:center;gap:10px;cursor:pointer;transition:all var(--transition);font-family:var(--font-body);font-size:.82rem;font-weight:500;color:var(--black-soft);}
.home-shortcut:hover{transform:translateY(-3px);box-shadow:var(--shadow-pink);border-color:var(--purple);}
.hs-icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;}
.hs-icon.purple{background:rgba(124,58,110,.08);color:var(--purple);}
.hs-icon.pink{background:var(--pink-soft);color:var(--pink-deep);}
.hs-icon.gold{background:rgba(201,168,76,.1);color:var(--gold);}
.hs-icon.green{background:rgba(34,197,94,.08);color:#16a34a;}
@media(max-width:768px){.home-shortcuts-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:480px){.home-shortcuts-grid{grid-template-columns:repeat(2,1fr);gap:10px;}}
.dash-about-visual{background:linear-gradient(135deg,var(--pink-soft),#fde8f0);border-radius:var(--radius);height:180px;display:flex;align-items:center;justify-content:center;font-size:4rem;}
.dash-about h3{font-family:var(--font-heading);font-size:1.6rem;font-weight:700;margin-bottom:10px;}
.dash-about h3 em{font-style:italic;color:var(--pink-deep);}
.dash-about p{font-size:.88rem;color:var(--grey);line-height:1.8;margin-bottom:16px;}
.dash-about-nums{display:flex;gap:24px;}
.dash-about-num strong{display:block;font-family:var(--font-heading);font-size:1.6rem;font-weight:700;color:var(--pink-deep);}
.dash-about-num span{font-size:.76rem;color:var(--grey);}

/* CONTACT */
.dash-contact-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:28px;}
.contact-card{background:white;border-radius:var(--radius);padding:20px;border:1.5px solid rgba(244,184,200,.2);text-align:center;transition:transform var(--transition),box-shadow var(--transition);}
.contact-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-pink);}
.contact-icon{width:48px;height:48px;border-radius:12px;background:var(--pink-soft);display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:var(--pink-deep);margin:0 auto 12px;}
.contact-card h4{font-weight:600;font-size:.88rem;margin-bottom:6px;}
.contact-card p{font-size:.8rem;color:var(--grey);line-height:1.6;}

/* BOOKINGS PANEL */
.bookings-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;flex-wrap:wrap;gap:12px;}
.bookings-filter{display:flex;gap:8px;flex-wrap:wrap;}
.filter-btn{padding:7px 16px;border-radius:50px;border:1.5px solid #e5e7eb;background:white;font-size:.8rem;font-weight:500;color:var(--grey);cursor:pointer;transition:all var(--transition);}
.filter-btn.active{background:var(--pink-soft);border-color:var(--pink-deep);color:var(--pink-deep);}
.btn-new-booking{background:linear-gradient(135deg,var(--pink-deep),var(--pink-neon));color:white;padding:10px 20px;border-radius:50px;font-size:.84rem;font-weight:600;display:flex;align-items:center;gap:8px;transition:all var(--transition);border:none;cursor:pointer;}
.btn-new-booking:hover{transform:translateY(-2px);box-shadow:var(--shadow-pink);}
.booking-card{background:white;border-radius:var(--radius);padding:20px;border:1.5px solid rgba(244,184,200,.2);margin-bottom:14px;display:flex;align-items:flex-start;gap:16px;transition:box-shadow var(--transition);}
.booking-card:hover{box-shadow:var(--shadow-pink);}
.booking-emoji{font-size:2.5rem;flex-shrink:0;margin-top:2px;}
.booking-info{flex:1;min-width:0;}
.booking-info h4{font-weight:600;font-size:.96rem;margin-bottom:6px;}
.booking-meta{font-size:.8rem;color:var(--grey);display:flex;gap:12px;flex-wrap:wrap;}
.booking-meta span{display:flex;align-items:center;gap:5px;}
.booking-notes{font-size:.78rem;color:var(--grey);margin-top:8px;font-style:italic;display:flex;gap:6px;align-items:flex-start;}
.booking-right{display:flex;flex-direction:column;align-items:flex-end;gap:8px;flex-shrink:0;}
.booking-status{padding:5px 12px;border-radius:50px;font-size:.75rem;font-weight:700;text-transform:capitalize;letter-spacing:.04em;display:flex;align-items:center;gap:5px;white-space:nowrap;}
.status-pending{background:#fffbeb;color:#d97706;}
.status-confirmed{background:#f0fdf4;color:#16a34a;}
.status-completed{background:var(--pink-soft);color:var(--pink-deep);}
.status-cancelled{background:#fef2f2;color:#dc2626;}
.btn-cancel-booking{background:none;border:1.5px solid #fee2e2;color:#dc2626;border-radius:50px;padding:4px 12px;font-size:.72rem;font-weight:600;cursor:pointer;transition:all var(--transition);white-space:nowrap;}
.btn-cancel-booking:hover{background:#fef2f2;}
.btn-rebook{background:none;border:1.5px solid rgba(244,184,200,.5);color:var(--pink-deep);border-radius:50px;padding:4px 12px;font-size:.72rem;font-weight:600;cursor:pointer;transition:all var(--transition);white-space:nowrap;}
.btn-rebook:hover{background:var(--pink-soft);}
.empty-state{text-align:center;padding:60px 20px;background:white;border-radius:var(--radius-lg);border:2px dashed rgba(244,184,200,.4);}
.empty-emoji{font-size:3.5rem;margin-bottom:16px;}
.empty-state h3{font-family:var(--font-heading);font-size:1.4rem;margin-bottom:8px;}
.empty-state p{font-size:.88rem;color:var(--grey);}

/* FAVOURITES */
.fav-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;}

/* LOYALTY */
.loyalty-hero{background:linear-gradient(135deg,#2a1018 0%,#4a1830 60%,#1a1020 100%);border-radius:var(--radius-lg);padding:36px;color:white;margin-bottom:24px;position:relative;overflow:hidden;}
.loyalty-hero-orb{position:absolute;border-radius:50%;filter:blur(50px);}
.loyalty-hero-orb.o1{width:250px;height:250px;background:rgba(232,117,138,.2);top:-60px;right:-60px;}
.loyalty-hero-orb.o2{width:150px;height:150px;background:rgba(201,168,76,.2);bottom:-30px;left:30%;}
.loyalty-top{display:flex;justify-content:space-between;align-items:flex-start;position:relative;z-index:1;}
.loyalty-pts-big{font-family:var(--font-display);font-size:4rem;font-weight:900;color:#ffd740;line-height:1;}
.loyalty-pts-label{font-size:.8rem;color:rgba(255,255,255,.6);letter-spacing:.1em;text-transform:uppercase;margin-top:4px;}
.loyalty-tier{background:linear-gradient(135deg,var(--gold),var(--gold-light));color:var(--black);padding:8px 18px;border-radius:50px;font-size:.84rem;font-weight:700;display:flex;align-items:center;gap:6px;}
.loyalty-bar-section{margin-top:24px;position:relative;z-index:1;}
.loyalty-bar-labels{display:flex;justify-content:space-between;font-size:.76rem;color:rgba(255,255,255,.6);margin-bottom:8px;}
.loyalty-bar-outer{background:rgba(255,255,255,.15);border-radius:6px;height:8px;}
.loyalty-bar-inner{height:100%;background:linear-gradient(90deg,var(--orange),#ffd740);border-radius:6px;transition:width 1.5s ease;}
.loyalty-perks-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:24px;}
.loyalty-perk-card{background:white;border-radius:var(--radius);padding:20px;border:1.5px solid rgba(244,184,200,.2);text-align:center;transition:transform var(--transition),box-shadow var(--transition);}
.loyalty-perk-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-pink);}
.lp-icon{font-size:2rem;margin-bottom:10px;}
.lp-title{font-weight:600;font-size:.9rem;margin-bottom:4px;}
.lp-desc{font-size:.78rem;color:var(--grey);line-height:1.6;}
.lp-req{font-size:.72rem;color:var(--pink-deep);font-weight:600;margin-top:8px;}
.loyalty-history h3{font-family:var(--font-heading);font-size:1.3rem;font-weight:700;margin-bottom:14px;}
.loyalty-txn{background:white;border-radius:10px;padding:14px 18px;border:1.5px solid rgba(244,184,200,.2);margin-bottom:8px;display:flex;align-items:center;gap:14px;}
.txn-icon{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:1rem;}
.txn-icon.earn{background:rgba(34,197,94,.1);color:#16a34a;}
.txn-icon.redeem{background:rgba(176,77,101,.1);color:var(--pink-neon);}
.txn-desc{flex:1;}
.txn-desc strong{display:block;font-size:.88rem;}
.txn-desc span{font-size:.76rem;color:var(--grey);}
.txn-pts{font-family:var(--font-heading);font-size:1.1rem;font-weight:700;}
.txn-pts.earn{color:#16a34a;}
.txn-pts.redeem{color:var(--pink-neon);}

/* MESSAGES */
.messages-layout{display:grid;grid-template-columns:280px 1fr;background:white;border-radius:var(--radius-lg);border:1.5px solid rgba(244,184,200,.2);overflow:hidden;height:580px;}
.msg-list{border-right:1px solid rgba(244,184,200,.2);overflow-y:auto;}
.msg-list-header{padding:18px;border-bottom:1px solid rgba(244,184,200,.2);}
.msg-list-header h3{font-weight:600;font-size:.96rem;}
.msg-thread{padding:14px 18px;border-bottom:1px solid rgba(244,184,200,.1);cursor:pointer;transition:background var(--transition);}
.msg-thread:hover{background:var(--white-off);}
.msg-thread.active{background:var(--pink-soft);}
.msg-thread-top{display:flex;justify-content:space-between;margin-bottom:4px;}
.msg-thread-name{font-weight:600;font-size:.86rem;}
.msg-thread-time{font-size:.72rem;color:var(--grey);}
.msg-thread-preview{font-size:.78rem;color:var(--grey);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.msg-unread-dot{display:inline-block;width:8px;height:8px;background:var(--pink-neon);border-radius:50%;margin-right:6px;}
.msg-chat{display:flex;flex-direction:column;height:100%;min-height:0;overflow:hidden;}
.msg-chat-header{padding:18px;border-bottom:1px solid rgba(244,184,200,.2);display:flex;align-items:center;gap:12px;}
.msg-chat-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--purple),var(--pink-deep));display:flex;align-items:center;justify-content:center;color:white;font-size:1rem;}
.msg-chat-name{font-weight:600;font-size:.96rem;}
.msg-chat-status{font-size:.75rem;color:#22c55e;}
.msg-chat-body{flex:1;min-height:0;padding:18px;overflow-y:auto;display:flex;flex-direction:column;gap:12px;scroll-behavior:smooth;}
/* ── Message bubble wrappers ── */
.msg-bubble-wrap{display:flex;flex-direction:column;max-width:72%;}
.msg-bubble-wrap.outgoing{align-self:flex-end;align-items:flex-end;}
.msg-bubble-wrap.incoming{align-self:flex-start;align-items:flex-start;}
/* Sender label (LuxeBraids) above first incoming in a group */
.msg-sender-label{font-size:.7rem;font-weight:600;color:var(--purple);margin-bottom:3px;padding:0 4px;letter-spacing:.02em;display:flex;align-items:center;gap:4px;}
/* Bubble itself */
.msg-bubble{max-width:100%;}
.msg-bubble-text{padding:10px 15px;border-radius:18px;font-size:.87rem;line-height:1.6;word-break:break-word;}
/* Incoming = admin reply — LEFT side, grey */
.msg-bubble-wrap.incoming .msg-bubble-text{background:var(--grey-light);color:var(--black-soft);border-radius:18px;border-bottom-left-radius:4px;}
/* Outgoing = client sent — RIGHT side, pink */
.msg-bubble-wrap.outgoing .msg-bubble-text{background:linear-gradient(135deg,var(--pink-deep),var(--pink-neon));color:white;border-radius:18px;border-bottom-right-radius:4px;box-shadow:0 2px 8px rgba(255,45,120,.22);}
/* Meta row: time + read receipt */
.msg-bubble-meta{display:flex;align-items:center;gap:6px;margin-top:4px;padding:0 4px;}
.msg-bubble-wrap.outgoing .msg-bubble-meta{justify-content:flex-end;}
.msg-bubble-wrap.incoming .msg-bubble-meta{justify-content:flex-start;}
.msg-bubble-time{font-size:.7rem;color:var(--grey);}
.msg-read-receipt{font-size:.68rem;display:flex;align-items:center;gap:3px;}
.msg-read-receipt.sent{color:var(--grey);}
.msg-read-receipt.read{color:#22c55e;}
/* Date separator */
.msg-date-separator{display:flex;align-items:center;gap:10px;margin:10px 0;color:var(--grey);font-size:.72rem;letter-spacing:.04em;}
.msg-date-separator::before,.msg-date-separator::after{content:'';flex:1;height:1px;background:var(--grey-light);}
.msg-date-separator span{background:var(--white-off);padding:2px 10px;border-radius:20px;border:1px solid var(--grey-light);}
.msg-chat-input{padding:10px 18px 14px;border-top:1px solid rgba(244,184,200,.2);display:flex;flex-direction:column;gap:4px;}
.msg-you-label{font-size:.7rem;font-weight:600;color:var(--pink-deep);display:flex;align-items:center;gap:4px;padding:0 4px;}
.msg-input-row{display:flex;gap:10px;}
.msg-chat-input input{flex:1;padding:11px 14px;border:1.5px solid #e5e7eb;border-radius:50px;font-family:var(--font-body);font-size:.88rem;outline:none;background:var(--white-off);transition:border-color var(--transition);}
.msg-chat-input input:focus{border-color:var(--pink-deep);}
.btn-msg-send{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--pink-deep),var(--pink-neon));color:white;border:none;display:flex;align-items:center;justify-content:center;transition:all var(--transition);cursor:pointer;}
.btn-msg-send:hover{transform:scale(1.1);}

/* PROFILE */
.profile-grid{display:grid;grid-template-columns:300px 1fr;gap:24px;}
.profile-card{background:white;border-radius:var(--radius-lg);padding:28px;border:1.5px solid rgba(244,184,200,.2);text-align:center;height:fit-content;}
.profile-avatar-wrap{position:relative;display:inline-block;margin-bottom:16px;}
.profile-avatar-big{width:90px;height:90px;border-radius:50%;background:linear-gradient(135deg,var(--purple),var(--pink-deep));display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:700;color:white;margin:0 auto;box-shadow:var(--shadow-pink);}
.profile-avatar-edit{position:absolute;bottom:0;right:0;width:28px;height:28px;background:white;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.8rem;color:var(--pink-deep);box-shadow:0 2px 8px rgba(0,0,0,.12);cursor:pointer;border:2px solid var(--pink-soft);}
.profile-name{font-family:var(--font-heading);font-size:1.4rem;font-weight:700;margin-bottom:4px;}
.profile-email{font-size:.84rem;color:var(--grey);margin-bottom:16px;}
.profile-tier-badge{display:inline-flex;align-items:center;gap:6px;background:linear-gradient(135deg,var(--gold),var(--gold-light));color:var(--black);padding:6px 16px;border-radius:50px;font-size:.8rem;font-weight:700;margin-bottom:20px;}
.profile-stats{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:20px;}
.profile-stat{background:var(--white-off);border-radius:10px;padding:12px;}
.profile-stat strong{display:block;font-family:var(--font-heading);font-size:1.3rem;font-weight:700;color:var(--pink-deep);}
.profile-stat span{font-size:.72rem;color:var(--grey);}
.btn-profile-logout{width:100%;padding:11px;background:#fef2f2;border:1.5px solid #fecaca;color:#dc2626;border-radius:10px;font-weight:600;font-size:.88rem;transition:all var(--transition);cursor:pointer;}
.btn-profile-logout:hover{background:#dc2626;color:white;}
.profile-form-wrap{background:white;border-radius:var(--radius-lg);padding:28px;border:1.5px solid rgba(244,184,200,.2);}
.profile-form-wrap h3{font-family:var(--font-heading);font-size:1.4rem;font-weight:700;margin-bottom:20px;}
.profile-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.profile-form-group{display:flex;flex-direction:column;gap:6px;}
.profile-form-group.full{grid-column:1 / -1;}
.profile-form-group label{font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--black-soft);}
.profile-form-group input,.profile-form-group select,.profile-form-group textarea{padding:11px 14px;border:1.5px solid #e5e7eb;border-radius:10px;font-family:var(--font-body);font-size:.9rem;outline:none;background:var(--white-off);transition:border-color var(--transition);resize:vertical;}
.profile-form-group input:focus,.profile-form-group select:focus,.profile-form-group textarea:focus{border-color:var(--pink-deep);background:white;}
.btn-save-profile{padding:12px 28px;background:linear-gradient(135deg,var(--pink-deep),var(--pink-neon));color:white;border:none;border-radius:10px;font-weight:600;font-size:.9rem;transition:all var(--transition);margin-top:4px;cursor:pointer;}
.btn-save-profile:hover{transform:translateY(-2px);box-shadow:var(--shadow-pink);}

/* MODALS */
/* ===== FULLSCREEN STYLE MODAL ===== */
.db-modal{position:fixed;inset:0;z-index:500;display:flex;flex-direction:column;opacity:0;visibility:hidden;transition:opacity .35s cubic-bezier(.4,0,.2,1),visibility .35s;}
.db-modal.open{opacity:1;visibility:visible;}
.db-modal-overlay{display:none;}
.db-modal-box{position:relative;z-index:1;width:100%;height:100%;display:flex;flex-direction:column;background:#0d0010;transform:translateY(40px);transition:transform .38s cubic-bezier(.4,0,.2,1);overflow:hidden;}
.db-modal.open .db-modal-box{transform:translateY(0);}

/* Top bar */
.db-modal-topbar{position:absolute;top:0;left:0;right:0;z-index:10;display:flex;align-items:center;justify-content:space-between;padding:16px 22px;background:linear-gradient(to bottom,rgba(0,0,0,.72) 0%,transparent 100%);}
.db-modal-topbar-title{font-family:var(--font-heading);font-size:1.05rem;font-weight:600;color:#fff;letter-spacing:.04em;opacity:.92;}
.db-modal-close{width:40px;height:40px;background:rgba(255,255,255,.14);backdrop-filter:blur(10px);border:1.5px solid rgba(255,255,255,.22);border-radius:50%;font-size:1rem;color:#fff;display:flex;align-items:center;justify-content:center;transition:all var(--transition);cursor:pointer;}
.db-modal-close:hover{background:rgba(255,45,135,.7);border-color:var(--pink-deep);transform:rotate(90deg);}

/* Scrollable body */
.modal-body-inner{display:flex;flex-direction:column;height:100%;overflow-y:auto;}

/* Gallery — strictly 75vh */
.modal-gallery{position:relative;flex:0 0 75vh;height:75vh;background:#1a0a2e;overflow:hidden;}
.modal-gallery-track{display:flex;height:100%;transition:transform .42s cubic-bezier(.4,0,.2,1);}
.modal-gallery-slide{flex:0 0 100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a0a2e 0%,#2d0a3a 100%);overflow:hidden;}
.modal-gallery-slide img{width:100%;height:100%;object-fit:cover;display:block;}
.modal-gallery-slide .gallery-emoji-ph{font-size:9rem;opacity:.35;}

/* Arrows */
.modal-gallery-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:5;width:44px;height:44px;background:rgba(255,215,64,.22);backdrop-filter:blur(8px);border:1.5px solid rgba(255,215,64,.7);border-radius:50%;color:var(--gold-bright);font-size:1.1rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .22s ease;}
.modal-gallery-arrow:hover{background:var(--gold-bright);border-color:var(--gold-bright);color:#1a0a2e;}
.modal-gallery-arrow.prev{left:14px;}
.modal-gallery-arrow.next{right:14px;}
.modal-gallery-arrow.hidden{opacity:0;pointer-events:none;}

/* Dots */
.modal-gallery-dots{position:absolute;bottom:14px;left:50%;transform:translateX(-50%);display:flex;gap:6px;z-index:5;}
.modal-gallery-dot{width:7px;height:7px;border-radius:50%;background:rgba(255,255,255,.38);cursor:pointer;transition:all .2s;}
.modal-gallery-dot.active{background:var(--pink-deep);width:20px;border-radius:4px;}

/* Count badge */
.modal-img-count{position:absolute;top:60px;right:14px;background:rgba(0,0,0,.55);backdrop-filter:blur(6px);color:#fff;font-size:.72rem;font-weight:600;padding:4px 10px;border-radius:20px;letter-spacing:.06em;z-index:5;}

/* Details section */
.modal-details{flex:1 1 auto;padding:26px 26px 0;background:#fff;min-height:25vh;overflow-y:auto;}
.modal-details h2{font-family:var(--font-heading);font-size:1.7rem;font-weight:700;margin-bottom:6px;}

/* Continue browsing bar */
.db-modal-continue-bar{flex:0 0 auto;background:#fff;border-top:1px solid rgba(244,184,200,.35);padding:13px 26px 17px;display:flex;align-items:center;justify-content:center;}
.btn-continue-browsing{display:inline-flex;align-items:center;gap:8px;padding:11px 28px;border-radius:50px;border:2px solid var(--pink-deep);background:transparent;color:var(--pink-deep);font-family:var(--font-body);font-size:.88rem;font-weight:600;letter-spacing:.04em;cursor:pointer;transition:all var(--transition);}
.btn-continue-browsing:hover{background:var(--pink-deep);color:#fff;transform:translateY(-1px);box-shadow:var(--shadow-pink);}
.modal-price{font-family:var(--font-heading);font-size:1.5rem;color:var(--pink-deep);font-weight:700;margin-bottom:16px;}
.modal-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px;}
.modal-tag{background:var(--pink-soft);color:var(--pink-deep);padding:3px 10px;border-radius:50px;font-size:.72rem;font-weight:600;}
.modal-desc{font-size:.86rem;color:var(--grey);line-height:1.8;margin-bottom:18px;}
.modal-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:20px;}
.modal-info-item{background:var(--white-off);border-radius:10px;padding:10px 12px;}
.modal-info-item label{display:block;font-size:.68rem;color:var(--grey);text-transform:uppercase;letter-spacing:.08em;margin-bottom:3px;}
.modal-info-item span{font-size:.86rem;font-weight:600;}
.btn-modal-book{width:100%;background:linear-gradient(135deg,var(--pink-deep),var(--pink-neon));color:white;border:none;padding:13px;border-radius:10px;font-size:.92rem;font-weight:700;transition:all var(--transition);cursor:pointer;}
.btn-modal-book:hover{transform:translateY(-2px);box-shadow:var(--shadow-pink);}
.confirm-modal{position:fixed;inset:0;z-index:600;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.6);backdrop-filter:blur(8px);padding:20px;opacity:0;visibility:hidden;transition:all var(--transition);}
.confirm-modal.open{opacity:1;visibility:visible;}
.confirm-content{background:white;border-radius:var(--radius-lg);padding:48px 36px;text-align:center;max-width:400px;width:100%;box-shadow:0 32px 80px rgba(0,0,0,.2);}
.confirm-icon{font-size:3rem;margin-bottom:16px;}
.confirm-content h3{font-family:var(--font-heading);font-size:1.7rem;margin-bottom:10px;}
.confirm-content p{font-size:.88rem;color:var(--grey);line-height:1.7;margin-bottom:24px;}
.btn-confirm-close{background:linear-gradient(135deg,var(--pink-deep),var(--pink-neon));color:white;border:none;padding:12px 28px;border-radius:50px;font-size:.92rem;font-weight:600;transition:all var(--transition);cursor:pointer;}
.btn-confirm-close:hover{transform:translateY(-2px);box-shadow:var(--shadow-pink);}

/* TOAST */
.toast-container{position:fixed;bottom:90px;right:20px;z-index:999;display:flex;flex-direction:column;gap:8px;}
.toast{background:var(--black);color:white;padding:12px 18px;border-radius:10px;font-size:.84rem;box-shadow:0 8px 32px rgba(0,0,0,.2);display:flex;align-items:center;gap:10px;animation:toastIn .4s ease;max-width:290px;border-left:3px solid var(--pink-deep);}
.toast.success{border-left-color:#22c55e;}
.toast.error{border-left-color:#ef4444;}
.toast.gold{border-left-color:var(--gold);}
@keyframes toastIn{from{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}

/* WHATSAPP */
.whatsapp-float{position:fixed;bottom:28px;right:24px;z-index:400;width:58px;height:58px;background:#25d366;border-radius:50%;display:flex;align-items:center;justify-content:center;color:white;font-size:1.5rem;box-shadow:0 8px 32px rgba(37,211,102,.4);transition:all var(--transition);}
.whatsapp-float:hover{transform:scale(1.1) translateY(-3px);}
.wa-tooltip{position:absolute;right:66px;background:var(--black);color:white;font-size:.72rem;font-weight:500;padding:5px 10px;border-radius:6px;white-space:nowrap;opacity:0;transform:translateX(8px);transition:all var(--transition);pointer-events:none;}
.whatsapp-float:hover .wa-tooltip{opacity:1;transform:translateX(0);}

/* REVEAL */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .5s ease,transform .5s ease;}
.reveal.revealed{opacity:1;transform:translateY(0);}

/* RESPONSIVE */
@media(max-width:1200px){
  .db-stats-row{grid-template-columns:repeat(2,1fr);}
  .dash-contact-grid{grid-template-columns:repeat(2,1fr);}
  .profile-grid{grid-template-columns:1fr;}
  .loyalty-perks-grid{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:1024px){
  .db-sidebar{position:fixed;left:0;top:0;bottom:0;z-index:300;transform:translateX(-100%);padding-top:106px;box-shadow:8px 0 32px rgba(0,0,0,.1);}
  .db-sidebar.open{transform:translateX(0);}
  .db-hamburger{display:flex;}
  .db-nav-search{display:none;}
  .dash-about{grid-template-columns:1fr;}
  .dash-about-visual{display:none;}
  .messages-layout{grid-template-columns:1fr;height:auto;}
  .msg-list{max-height:200px;border-right:none;border-bottom:1px solid rgba(244,184,200,.2);}
  .msg-chat{height:400px;min-height:0;}
  /* fullscreen modal — no grid override needed */
}
@media(max-width:768px){
  .db-main{padding:20px 16px;}
  .db-stats-row{grid-template-columns:repeat(2,1fr);gap:12px;}
  .dash-booking-grid{grid-template-columns:1fr;}
  .dash-contact-grid{grid-template-columns:1fr 1fr;}
  .styles-grid{grid-template-columns:repeat(2,1fr);gap:1px;background:rgba(0,0,0,0.08);}
  .styles-grid .style-card{border-radius:0;box-shadow:none;}
  .loyalty-perks-grid{grid-template-columns:1fr;}
  .profile-form-grid{grid-template-columns:1fr;}
  .form-row-2{grid-template-columns:1fr;}
  .dash-hero-art{display:none;}
  .categories-grid{display:grid;grid-template-columns:repeat(2,1fr);}
  .cat-card{min-width:unset;}
  .db-categories-header{flex-direction:column;align-items:flex-start;gap:16px;}
}
@media(max-width:480px){
  .db-stats-row{grid-template-columns:1fr 1fr;}
  .dash-contact-grid{grid-template-columns:1fr;}
  .dash-hero-content{padding:28px 20px;}
  .dash-hero h2{font-size:1.6rem;}
}

/* =================== FEMININE TEXT COLOR PALETTE — DASHBOARD =================== */

/* Greeting title gradient */
.db-greeting h1 {
  background: linear-gradient(135deg, #1c1018, #4a2038);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* Greeting name span stays pink→gold gradient (already set inline) */

/* Eyebrow labels */
.dash-eyebrow {
  background: linear-gradient(90deg, #c2637a, #b8945a);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* Section titles */
.dash-section-title {
  background: linear-gradient(135deg, #1c1018, #4a2038);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* Sidebar active item */
.sidebar-item.active {
  color: #c2637a;
}

/* Sidebar loyalty points */
.sl-points {
  background: linear-gradient(90deg, var(--gold-light), #f2c4ce);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* Stat numbers */
.db-stat-num {
  background: linear-gradient(135deg, #1c1018, #7c3a6e);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* Card titles and headings inside dashboard panels */
.booking-card-title,
.appt-style,
.db-panel h3 {
  background: linear-gradient(135deg, #1c1018, #4a2038);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* Price / cost text */
.appt-price,
.booking-price {
  background: linear-gradient(90deg, #c2637a, #b8945a);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  font-weight: 700;
}

/* Logo sub stays gold */
.logo-sub {
  color: var(--gold);
}


/* =================== DASHBOARD CATALOG SECTIONS =================== */

#db-catalog-container {
  margin: 24px 0 0;
}

.cat-section {
  padding: 80px 0 60px;
  position: relative;
  overflow: hidden;
}

.cat-section-inner {
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 40px;
}

.cat-section-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-bottom: 20px;
  flex-wrap: wrap;
  gap: 20px;
}

.cat-section-header-left { flex: 1; min-width: 260px; }

.cat-section-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 10px;
}

.cat-section-icon {
  font-size: 1.4rem;
  line-height: 1;
  filter: drop-shadow(0 2px 6px rgba(0,0,0,0.15));
}

.cat-section-eyebrow {
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  padding: 4px 14px;
  border-radius: 50px;
}

.cat-section-title {
  font-family: var(--font-heading);
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 700;
  line-height: 1.1;
  margin-bottom: 8px;
}

.title-underline {
  position: relative;
  display: inline-block;
  padding-bottom: 6px;
}

.title-underline::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 4px;
  border-radius: 3px;
  background: currentColor;
  opacity: 0.25;
}

.cat-section-subtitle {
  font-size: 0.92rem;
  line-height: 1.7;
  opacity: 0.72;
  max-width: 420px;
}

.cat-section-header-right {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 10px;
  flex-shrink: 0;
}

.cat-section-count {
  font-size: 0.78rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  padding: 5px 14px;
  border-radius: 50px;
  background: rgba(0,0,0,0.06);
}

.cat-section-divider {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 36px;
}

.divider-line {
  flex: 1;
  height: 1px;
  border-radius: 2px;
  background: currentColor;
  opacity: 0.15;
}

.divider-gem {
  font-size: 1.1rem;
  opacity: 0.55;
  filter: drop-shadow(0 1px 4px rgba(0,0,0,0.1));
}

.styles-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}

.style-card {
  background: white;
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: 0 4px 20px rgba(0,0,0,0.07);
  transition: all 0.3s cubic-bezier(0.4,0,0.2,1);
  cursor: pointer;
  position: relative;
}

.style-card:hover {
  transform: translateY(-10px);
  box-shadow: 0 20px 52px rgba(0,0,0,0.14);
}

.card-duration {
  position: absolute;
  bottom: 10px;
  left: 10px;
  background: rgba(0,0,0,0.48);
  backdrop-filter: blur(8px);
  color: rgba(255,255,255,0.9);
  font-size: 0.68rem;
  font-weight: 500;
  padding: 4px 10px;
  border-radius: 50px;
  display: flex;
  align-items: center;
  gap: 5px;
  letter-spacing: 0.02em;
}

.review-count { color: var(--grey); }

.btn-card-book {
  width: 100%;
  border: none;
  padding: 10px;
  border-radius: 10px;
  font-size: 0.82rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  transition: all var(--transition);
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  cursor: pointer;
}

/* ---- BADGE VARIANTS ---- */
.badge-new   { background: linear-gradient(135deg, #9b00ff, #ff2d87) !important; color: white !important; }
.badge-offer { background: linear-gradient(135deg, #ff6b00, #ffd740) !important; color: white !important; }
.badge-gold  { background: linear-gradient(135deg, #ff9f00, #ffd740) !important; color: #1a0a2e !important; }
.badge-kids  { background: linear-gradient(135deg, #c354ff, #ff6eb4) !important; color: white !important; }
.badge-mens  { background: linear-gradient(135deg, #00a89f, #00d4c8) !important; color: white !important; }

/* =================== THEME COLOURS — EXACT MATCH TO INDEX.CSS =================== */

/* THEME — ROSE (Trending) */
.theme-rose { background: linear-gradient(160deg, #fff0f8 0%, #ffe0f3 60%, #ffd0ee 100%); color: #2d0020; position: relative; }
.theme-rose .cat-section-eyebrow { background: linear-gradient(135deg, #ff2d87, #ff9fce); color: white; }
.theme-rose .cat-section-title { color: #2d0020; }
.theme-rose .title-underline { color: #ff2d87; }
.theme-rose .title-underline::after { background: linear-gradient(90deg, #ff2d87, #ff9fce); opacity: 1; height: 5px; }
.theme-rose .cat-section-subtitle { color: #8a2060; }
.theme-rose .cat-section-count { background: rgba(255,45,135,0.12); color: #ff2d87; }
.theme-rose .divider-line { background: #ff2d87; }
.theme-rose .style-card:hover { box-shadow: 0 20px 52px rgba(255,45,135,0.25); }
.theme-rose .btn-card-book { background: linear-gradient(135deg, #ff2d87, #f7006e); color: white; }
.theme-rose .btn-card-book:hover { box-shadow: 0 6px 24px rgba(255,45,135,0.5); transform: translateY(-2px); }

/* THEME — MAUVE (New Arrivals) */
.theme-mauve { background: linear-gradient(160deg, #f5eeff 0%, #ecd4ff 60%, #e0b8ff 100%); color: #1a0040; position: relative; }
.theme-mauve .cat-section-eyebrow { background: linear-gradient(135deg, #9b00ff, #c354ff); color: white; }
.theme-mauve .cat-section-title { color: #1a0040; }
.theme-mauve .title-underline { color: #9b00ff; }
.theme-mauve .title-underline::after { background: linear-gradient(90deg, #9b00ff, #c354ff); opacity: 1; height: 5px; }
.theme-mauve .cat-section-subtitle { color: #5a1a80; }
.theme-mauve .cat-section-count { background: rgba(155,0,255,0.12); color: #9b00ff; }
.theme-mauve .divider-line { background: #9b00ff; }
.theme-mauve .style-card:hover { box-shadow: 0 20px 52px rgba(155,0,255,0.25); }
.theme-mauve .btn-card-book { background: linear-gradient(135deg, #9b00ff, #6600cc); color: white; }
.theme-mauve .btn-card-book:hover { box-shadow: 0 6px 24px rgba(155,0,255,0.5); transform: translateY(-2px); }
.theme-mauve::before { content: ''; position: absolute; top: -60px; right: -60px; width: 220px; height: 220px; border-radius: 50%; background: radial-gradient(circle, rgba(155,0,255,0.12), transparent 70%); pointer-events: none; }
.theme-mauve::after  { content: ''; position: absolute; bottom: -40px; left: 10%; width: 160px; height: 160px; border-radius: 50%; background: radial-gradient(circle, rgba(195,84,255,0.10), transparent 70%); pointer-events: none; }

/* THEME — GOLD (Most Booked) */
.theme-gold { background: linear-gradient(160deg, #fffbee 0%, #fff3c0 60%, #ffe880 100%); color: #2d1800; position: relative; }
.theme-gold .cat-section-eyebrow { background: linear-gradient(135deg, #ff9f00, #ffd740); color: #1a0a2e; }
.theme-gold .cat-section-title { color: #2d1800; }
.theme-gold .title-underline { color: #ff9f00; }
.theme-gold .title-underline::after { background: linear-gradient(90deg, #ff9f00, #ffd740); opacity: 1; height: 5px; }
.theme-gold .cat-section-subtitle { color: #7a4800; }
.theme-gold .cat-section-count { background: rgba(255,159,0,0.15); color: #cc7000; }
.theme-gold .divider-line { background: #ff9f00; }
.theme-gold .style-card:hover { box-shadow: 0 20px 52px rgba(255,159,0,0.3); }
.theme-gold .btn-card-book { background: linear-gradient(135deg, #ff9f00, #ff6b00); color: white; }
.theme-gold .btn-card-book:hover { box-shadow: 0 6px 24px rgba(255,107,0,0.5); transform: translateY(-2px); }
.theme-gold::before { content: ''; position: absolute; top: -40px; right: 5%; width: 200px; height: 200px; border-radius: 50%; background: radial-gradient(circle, rgba(255,215,64,0.18), transparent 70%); pointer-events: none; }

/* THEME — PLUM (Luxury) */
.theme-plum { background: linear-gradient(160deg, #1a0a2e 0%, #2d1050 50%, #1a0a2e 100%); color: #fff0f5; position: relative; }
.theme-plum .cat-section-eyebrow { background: linear-gradient(135deg, #ffd740, #ff9f00); color: #1a0a2e; }
.theme-plum .cat-section-title { color: #fff0f5; }
.theme-plum .title-underline { color: #ffd740; }
.theme-plum .title-underline::after { background: linear-gradient(90deg, #ffd740, #ff6eb4); opacity: 1; height: 5px; }
.theme-plum .cat-section-subtitle { color: rgba(255,240,245,0.65); }
.theme-plum .cat-section-count { background: rgba(255,215,64,0.18); color: #ffd740; }
.theme-plum .divider-line { background: #ffd740; }
.theme-plum .style-card { background: rgba(255,255,255,0.07); border: 1px solid rgba(255,215,64,0.25); }
.theme-plum .style-card .card-title { background: linear-gradient(135deg, #fff0f5, #ffd740); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.theme-plum .style-card .card-price { background: linear-gradient(90deg, #ffd740, #ff6eb4); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.theme-plum .style-card .card-price .original { -webkit-text-fill-color: rgba(255,240,245,0.4); }
.theme-plum .style-card .card-rating { color: #ffd740; }
.theme-plum .style-card .card-bookings { color: rgba(255,240,245,0.55); }
.theme-plum .style-card:hover { background: rgba(255,255,255,0.12); box-shadow: 0 20px 52px rgba(255,26,26,0.35); }
.theme-plum .btn-card-book { background: linear-gradient(135deg, #ff1a1a, #cc0000); color: white; }
.theme-plum .btn-card-book:hover { box-shadow: 0 6px 24px rgba(255,26,26,0.5); transform: translateY(-2px); }
.theme-plum::before { content: ''; position: absolute; top: -80px; left: -80px; width: 300px; height: 300px; border-radius: 50%; background: radial-gradient(circle, rgba(155,0,255,0.15), transparent 70%); pointer-events: none; }

/* THEME — TEAL (Budget Friendly) */
.theme-teal { background: linear-gradient(160deg, #e8fffd 0%, #c0fff8 60%, #98fff0 100%); color: #002828; position: relative; }
.theme-teal .cat-section-eyebrow { background: linear-gradient(135deg, #00a89f, #00d4c8); color: white; }
.theme-teal .cat-section-title { color: #002828; }
.theme-teal .title-underline { color: #00a89f; }
.theme-teal .title-underline::after { background: linear-gradient(90deg, #00a89f, #00d4c8); opacity: 1; height: 5px; }
.theme-teal .cat-section-subtitle { color: #006060; }
.theme-teal .cat-section-count { background: rgba(0,168,159,0.12); color: #00a89f; }
.theme-teal .divider-line { background: #00a89f; }
.theme-teal .style-card:hover { box-shadow: 0 20px 52px rgba(0,168,159,0.28); }
.theme-teal .btn-card-book { background: linear-gradient(135deg, #00a89f, #007a74); color: white; }
.theme-teal .btn-card-book:hover { box-shadow: 0 6px 24px rgba(0,168,159,0.5); transform: translateY(-2px); }

/* THEME — BLUSH (Bridal & Events) */
.theme-blush { background: linear-gradient(160deg, #fff5fc 0%, #ffe8f8 50%, #ffd0f0 100%); color: #2d0028; position: relative; }
.theme-blush .cat-section-eyebrow { background: linear-gradient(135deg, #ff2d87, #ff9fce); color: white; }
.theme-blush .cat-section-title { color: #2d0028; }
.theme-blush .title-underline { color: #ff2d87; }
.theme-blush .title-underline::after { background: linear-gradient(90deg, #ff2d87, #ff9fce); opacity: 1; height: 5px; }
.theme-blush .cat-section-subtitle { color: #8a1060; }
.theme-blush .cat-section-count { background: rgba(255,45,135,0.12); color: #e00070; }
.theme-blush .divider-line { background: #ff2d87; }
.theme-blush .style-card:hover { box-shadow: 0 20px 52px rgba(255,45,135,0.28); }
.theme-blush .btn-card-book { background: linear-gradient(135deg, #ff2d87, #cc0050); color: white; }
.theme-blush .btn-card-book:hover { box-shadow: 0 6px 24px rgba(255,45,135,0.5); transform: translateY(-2px); }
.theme-blush::after { content: '💍'; position: absolute; top: 24px; right: 100px; font-size: 5rem; opacity: 0.1; pointer-events: none; }

/* THEME — LAVENDER (Kids Styles) */
.theme-lavender { background: linear-gradient(160deg, #f5eaff 0%, #ead4ff 60%, #e0c0ff 100%); color: #1a0040; }
.theme-lavender .cat-section-eyebrow { background: linear-gradient(135deg, #c354ff, #9b00ff); color: white; }
.theme-lavender .cat-section-title { color: #1a0040; }
.theme-lavender .title-underline { color: #c354ff; }
.theme-lavender .title-underline::after { background: linear-gradient(90deg, #c354ff, #e0a0ff); opacity: 1; height: 5px; }
.theme-lavender .cat-section-subtitle { color: #6a2090; }
.theme-lavender .cat-section-count { background: rgba(195,84,255,0.12); color: #c354ff; }
.theme-lavender .divider-line { background: #c354ff; }
.theme-lavender .style-card:hover { box-shadow: 0 20px 52px rgba(195,84,255,0.28); }
.theme-lavender .btn-card-book { background: linear-gradient(135deg, #c354ff, #9b00ff); color: white; }
.theme-lavender .btn-card-book:hover { box-shadow: 0 6px 24px rgba(195,84,255,0.5); transform: translateY(-2px); }

/* THEME — SLATE (Men's Braids) */
.theme-slate { background: linear-gradient(160deg, #e0fffe 0%, #c0fffb 60%, #98fff7 100%); color: #002020; }
.theme-slate .cat-section-eyebrow { background: linear-gradient(135deg, #007a74, #00d4c8); color: white; }
.theme-slate .cat-section-title { color: #002020; }
.theme-slate .title-underline { color: #00a89f; }
.theme-slate .title-underline::after { background: linear-gradient(90deg, #00a89f, #00d4c8); opacity: 1; height: 5px; }
.theme-slate .cat-section-subtitle { color: #004848; }
.theme-slate .cat-section-count { background: rgba(0,168,159,0.12); color: #007a74; }
.theme-slate .divider-line { background: #00a89f; }
.theme-slate .style-card:hover { box-shadow: 0 20px 52px rgba(0,168,159,0.25); }
.theme-slate .btn-card-book { background: linear-gradient(135deg, #00a89f, #007a74); color: white; }
.theme-slate .btn-card-book:hover { box-shadow: 0 6px 24px rgba(0,168,159,0.5); transform: translateY(-2px); }

/* THEME — AMBER (Quick Styles) */
.theme-amber { background: linear-gradient(160deg, #fffae0 0%, #fff0a0 60%, #ffe060 100%); color: #2d1800; }
.theme-amber .cat-section-eyebrow { background: linear-gradient(135deg, #ff6b00, #ff9f00); color: white; }
.theme-amber .cat-section-title { color: #2d1800; }
.theme-amber .title-underline { color: #ff6b00; }
.theme-amber .title-underline::after { background: linear-gradient(90deg, #ff6b00, #ffd740); opacity: 1; height: 5px; }
.theme-amber .cat-section-subtitle { color: #803000; }
.theme-amber .cat-section-count { background: rgba(255,107,0,0.12); color: #cc5000; }
.theme-amber .divider-line { background: #ff6b00; }
.theme-amber .style-card:hover { box-shadow: 0 20px 52px rgba(255,107,0,0.28); }
.theme-amber .btn-card-book { background: linear-gradient(135deg, #ff6b00, #cc4400); color: white; }
.theme-amber .btn-card-book:hover { box-shadow: 0 6px 24px rgba(255,107,0,0.5); transform: translateY(-2px); }

/* THEME — FOREST (Transformations) */
.theme-forest { background: linear-gradient(160deg, #fff0f0 0%, #ffe0e0 60%, #ffc8c8 100%); color: #2d0000; }
.theme-forest .cat-section-eyebrow { background: linear-gradient(135deg, #ff1a1a, #ff6060); color: white; }
.theme-forest .cat-section-title { color: #2d0000; }
.theme-forest .title-underline { color: #ff1a1a; }
.theme-forest .title-underline::after { background: linear-gradient(90deg, #ff1a1a, #ff8080); opacity: 1; height: 5px; }
.theme-forest .cat-section-subtitle { color: #801010; }
.theme-forest .cat-section-count { background: rgba(255,26,26,0.12); color: #cc0000; }
.theme-forest .divider-line { background: #ff1a1a; }
.theme-forest .style-card:hover { box-shadow: 0 20px 52px rgba(255,26,26,0.28); }
.theme-forest .btn-card-book { background: linear-gradient(135deg, #ff1a1a, #cc0000); color: white; }
.theme-forest .btn-card-book:hover { box-shadow: 0 6px 24px rgba(255,26,26,0.5); transform: translateY(-2px); }
.theme-forest .btn-card-book:hover { box-shadow:0 5px 20px rgba(74,128,96,0.35); transform:translateY(-2px); }

/* ---- RESPONSIVE (old rules removed — new ones appended below) ---- */



/* ---- OFFER TIMER (matches index.css exactly) ---- */
.offer-timer {
  display: flex;
  align-items: center;
  gap: 10px;
  background: linear-gradient(135deg, var(--black), var(--black-soft));
  color: white;
  padding: 10px 20px;
  border-radius: 50px;
  font-size: 0.82rem;
}
.timer-display {
  font-family: 'Courier New', monospace;
  color: var(--gold-light);
  font-weight: 700;
  font-size: 1rem;
  letter-spacing: 0.05em;
}

/* ---- RESPONSIVE ---- */
@media (max-width: 1024px) { .styles-grid { grid-template-columns: repeat(3, 1fr); } .cat-section-inner { padding: 0 24px; } }
@media (max-width: 768px)  { .cat-section { padding: 56px 0 40px; } .styles-grid { grid-template-columns: repeat(2, 1fr); gap: 1px; background: rgba(0,0,0,0.08); } .styles-grid .style-card { border-radius: 0; box-shadow: none; } .cat-section-header { flex-direction: column; align-items: flex-start; } .cat-section-header-right { align-items: flex-start; } }
@media (max-width: 480px)  { .styles-grid { grid-template-columns: repeat(2, 1fr); gap: 1px; } .cat-section-title { font-size: 1.8rem; } }

/* ===== HAIR TYPE FILTER BUTTONS ===== */
.ht-filter-btn {
  padding: 5px 14px;
  border-radius: 20px;
  border: 1px solid rgba(255,255,255,.15);
  background: rgba(255,255,255,.05);
  color: rgba(255,255,255,.6);
  font-size: .78rem;
  font-weight: 600;
  cursor: pointer;
  transition: all .2s;
  white-space: nowrap;
}
.ht-filter-btn:hover {
  border-color: rgba(255,159,0,.4);
  color: #ffa500;
  background: rgba(255,159,0,.08);
}
.ht-filter-btn.active {
  background: rgba(255,159,0,.15);
  border-color: rgba(255,159,0,.5);
  color: #ffa500;
}

/* =================== STYLE MODAL (matches index.html) =================== */
.style-modal {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: flex;
  flex-direction: column;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.35s cubic-bezier(0.4,0,0.2,1), visibility 0.35s;
}
.style-modal.open { opacity: 1; visibility: visible; }
.modal-overlay { display: none; }
.modal-content {
  position: relative;
  z-index: 1;
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  background: #0d0010;
  transform: translateY(40px);
  transition: transform 0.38s cubic-bezier(0.4,0,0.2,1);
  overflow: hidden;
}
.style-modal.open .modal-content { transform: translateY(0); }
.modal-topbar {
  position: absolute;
  top: 0; left: 0; right: 0;
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 24px;
  background: linear-gradient(to bottom, rgba(0,0,0,0.72) 0%, transparent 100%);
}
.modal-topbar-title {
  font-family: var(--font-heading);
  font-size: 1.05rem;
  font-weight: 600;
  color: #fff;
  letter-spacing: 0.04em;
  opacity: 0.92;
}
.modal-close {
  width: 40px; height: 40px;
  background: rgba(255,255,255,0.14);
  backdrop-filter: blur(10px);
  border: 1.5px solid rgba(255,255,255,0.22);
  border-radius: 50%;
  font-size: 1rem;
  color: #fff;
  display: flex; align-items: center; justify-content: center;
  transition: all var(--transition); cursor: pointer;
}
.modal-close:hover { background: rgba(255,45,135,0.7); border-color: var(--pink-deep); color: #fff; transform: rotate(90deg); }
.modal-body {
  display: flex; flex-direction: column;
  flex: 1 1 auto;
  overflow-y: auto; overflow-x: hidden;
  -webkit-overflow-scrolling: touch;
}
.modal-gallery { position: relative; flex: 0 0 auto; width: 100%; background: #1a0a2e; overflow: hidden; }
.modal-gallery-track { display: flex; transition: transform 0.42s cubic-bezier(0.4,0,0.2,1); }
.modal-gallery-slide { flex: 0 0 100%; display: flex; align-items: center; justify-content: center; background: linear-gradient(135deg, #1a0a2e 0%, #2d0a3a 100%); }
.modal-gallery-slide img { width: 100%; height: auto; max-height: 80vh; object-fit: contain; display: block; }
.modal-gallery-slide .gallery-emoji-placeholder { font-size: 9rem; opacity: 0.35; padding: 80px 0; }
.modal-gallery-arrow {
  position: absolute; top: 50%; transform: translateY(-50%); z-index: 5;
  width: 44px; height: 44px;
  background: rgba(255,215,64,0.22); backdrop-filter: blur(8px);
  border: 1.5px solid rgba(255,215,64,0.7); border-radius: 50%;
  color: var(--gold-bright); font-size: 1.1rem;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; transition: all 0.22s ease;
}
.modal-gallery-arrow:hover { background: var(--gold-bright); border-color: var(--gold-bright); color: #1a0a2e; }
.modal-gallery-arrow.prev { left: 14px; }
.modal-gallery-arrow.next { right: 14px; }
.modal-gallery-arrow.hidden { opacity: 0; pointer-events: none; }
.modal-gallery-dots { position: absolute; bottom: 14px; left: 50%; transform: translateX(-50%); display: flex; gap: 6px; z-index: 5; }
.modal-gallery-dot { width: 7px; height: 7px; border-radius: 50%; background: rgba(255,255,255,0.38); cursor: pointer; transition: all 0.2s; }
.modal-gallery-dot.active { background: var(--pink-deep); width: 20px; border-radius: 4px; }
.modal-img-count { position: absolute; top: 60px; right: 14px; background: rgba(0,0,0,0.55); backdrop-filter: blur(6px); color: #fff; font-size: 0.72rem; font-weight: 600; padding: 4px 10px; border-radius: 20px; letter-spacing: 0.06em; z-index: 5; }
.modal-details { flex: 0 0 auto; padding: 28px 28px 24px; background: #fff; }
.modal-details h2 { font-family: var(--font-heading); font-size: 1.75rem; font-weight: 700; color: var(--black); margin-bottom: 6px; }
.modal-price { font-family: var(--font-heading); font-size: 1.5rem; color: var(--pink-deep); font-weight: 700; margin-bottom: 16px; }
.modal-tags { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 16px; }
.modal-tag { background: #f8f0ff; color: var(--purple); padding: 4px 12px; border-radius: 50px; font-size: 0.75rem; font-weight: 600; }
.modal-desc { font-size: 0.88rem; color: var(--grey); line-height: 1.8; margin-bottom: 20px; }
.modal-info-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 24px; }
.modal-info-item { background: var(--white-off, #faf7fb); border-radius: 10px; padding: 12px; }
.modal-info-item label { display: block; font-size: 0.7rem; color: var(--grey); text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: 4px; }
.modal-info-item span { font-size: 0.88rem; font-weight: 600; color: var(--black); }
.btn-modal-book { width: 100%; background: linear-gradient(135deg, var(--purple, #6b2d8b), var(--pink-deep, #c0394d)); color: white; border: none; padding: 14px; border-radius: 12px; font-size: 0.95rem; font-weight: 700; transition: all var(--transition); position: relative; overflow: hidden; cursor: pointer; }
.btn-modal-book:hover { transform: translateY(-2px); box-shadow: 0 8px 30px rgba(255,45,135,0.4); }
.modal-continue-bar { flex: 0 0 auto; background: #fff; border-top: 1px solid rgba(244,184,200,0.35); padding: 14px 28px 18px; display: flex; align-items: center; justify-content: center; gap: 10px; }
.btn-continue-browsing { display: inline-flex; align-items: center; gap: 8px; padding: 11px 28px; border-radius: 50px; border: 2px solid var(--pink-deep, #c0394d); background: transparent; color: var(--pink-deep, #c0394d); font-family: var(--font-body); font-size: 0.88rem; font-weight: 600; letter-spacing: 0.04em; cursor: pointer; transition: all var(--transition); }
.btn-continue-browsing:hover { background: var(--pink-deep, #c0394d); color: #fff; transform: translateY(-1px); box-shadow: 0 6px 20px rgba(255,45,135,0.3); }

/* =================== BOOKING STEPS MODAL (matches index.html) =================== */
.booking-steps-modal { display: none; position: fixed; inset: 0; z-index: 10000; align-items: stretch; justify-content: stretch; }
.booking-steps-modal.open { display: flex; }
.bsm-overlay { position: absolute; inset: 0; background: rgba(26,10,46,0.7); backdrop-filter: blur(4px); }
.bsm-content { position: relative; z-index: 1; width: 100%; height: 100%; display: flex; flex-direction: column; background: #fff; overflow: hidden; }
.bsm-topbar { display: flex; align-items: center; justify-content: space-between; padding: 14px 20px; background: linear-gradient(135deg, #3d0a2a, #1a0a0f); border-bottom: 1px solid rgba(255,110,180,0.2); flex-shrink: 0; }
.bsm-topbar-title { font-family: var(--font-heading); font-size: 1.1rem; font-weight: 600; color: #fff; letter-spacing: 0.03em; flex: 1; text-align: center; }
.bsm-back, .bsm-close { background: rgba(255,255,255,0.1); border: 1px solid rgba(255,255,255,0.15); border-radius: 50%; width: 36px; height: 36px; display: flex; align-items: center; justify-content: center; color: #fff; font-size: 0.9rem; transition: background 0.2s; flex-shrink: 0; cursor: pointer; }
.bsm-back:hover, .bsm-close:hover { background: rgba(255,255,255,0.2); }
.bsm-progress { background: linear-gradient(135deg, #3d0a2a 0%, #2d0a22 100%); padding: 16px 24px 20px; flex-shrink: 0; }
.bsm-step-bar { display: flex; align-items: center; justify-content: center; gap: 0; max-width: 320px; margin: 0 auto; }
.bsm-step { display: flex; flex-direction: column; align-items: center; gap: 6px; }
.bsm-step-circle { width: 34px; height: 34px; border-radius: 50%; border: 2px solid rgba(255,255,255,0.25); display: flex; align-items: center; justify-content: center; font-size: 0.85rem; font-weight: 700; color: rgba(255,255,255,0.4); background: transparent; transition: all 0.3s ease; }
.bsm-step span { font-size: 0.7rem; color: rgba(255,255,255,0.4); font-weight: 500; letter-spacing: 0.05em; transition: color 0.3s ease; }
.bsm-step.active .bsm-step-circle { background: linear-gradient(135deg, #ff6eb4, #ff2d87); border-color: #ff6eb4; color: #fff; box-shadow: 0 0 16px rgba(255,45,135,0.5); }
.bsm-step.active span { color: #ff9fce; }
.bsm-step.done .bsm-step-circle { background: linear-gradient(135deg, #ff9f00, #ffbe00); border-color: #ffbe00; color: #fff; }
.bsm-step.done span { color: #ffce60; }
.bsm-step-line { flex: 1; height: 2px; background: rgba(255,255,255,0.15); margin: 0 8px; margin-bottom: 22px; transition: background 0.3s; min-width: 30px; }
.bsm-step-line.done { background: linear-gradient(90deg, #ff9f00, #ffbe00); }
.bsm-body { flex: 1; overflow-y: auto; padding: 24px 20px 32px; background: #fdf9fb; position: relative; }
.bsm-panel { display: none; animation: bsmSlideIn 0.35s ease; }
.bsm-panel.active { display: block; }
@keyframes bsmSlideIn { from { opacity: 0; transform: translateX(24px); } to { opacity: 1; transform: translateX(0); } }
.bsm-panel-header { text-align: center; margin-bottom: 28px; }
.bsm-panel-icon { font-size: 2.4rem; margin-bottom: 10px; display: block; }
.bsm-panel-header h3 { font-family: var(--font-heading); font-size: 1.55rem; font-weight: 700; color: #1a0a2e; margin-bottom: 6px; }
.bsm-panel-header p { font-size: 0.88rem; color: #7a6872; }
.bsm-form-group { margin-bottom: 18px; }
.bsm-form-group label { display: block; font-size: 0.8rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.08em; color: #3d0a2a; margin-bottom: 8px; }
.bsm-form-group label i { margin-right: 6px; color: #ff6eb4; }
.bsm-input { width: 100%; padding: 13px 16px; border: 1.5px solid #f0d0e0; border-radius: 12px; background: #fff; font-family: var(--font-body); font-size: 0.95rem; color: #1a0a2e; outline: none; transition: border-color 0.2s, box-shadow 0.2s; box-sizing: border-box; }
.bsm-input:focus { border-color: #ff6eb4; box-shadow: 0 0 0 3px rgba(255,110,180,0.12); }
.bsm-textarea { min-height: 90px; resize: vertical; }
.bsm-btn-next { width: 100%; padding: 15px; border: none; border-radius: 14px; background: linear-gradient(135deg, #ff6eb4, #ff2d87); color: #fff; font-family: var(--font-body); font-size: 1rem; font-weight: 600; letter-spacing: 0.04em; margin-top: 8px; transition: transform 0.2s, box-shadow 0.2s; box-shadow: 0 4px 20px rgba(255,45,135,0.35); cursor: pointer; }
.bsm-btn-next:hover { transform: translateY(-2px); box-shadow: 0 8px 28px rgba(255,45,135,0.45); }
.bsm-review-card { background: #fff; border: 1.5px solid #f0d0e0; border-radius: 16px; padding: 20px; margin-bottom: 20px; box-shadow: 0 4px 20px rgba(255,45,135,0.08); }
.bsm-review-row { display: flex; align-items: flex-start; gap: 12px; padding: 10px 0; border-bottom: 1px solid #fce8f0; }
.bsm-review-row:last-child { border-bottom: none; }
.bsm-review-icon { width: 34px; height: 34px; border-radius: 8px; background: linear-gradient(135deg, #ffe0ef, #fce8f0); display: flex; align-items: center; justify-content: center; font-size: 0.9rem; color: #ff2d87; flex-shrink: 0; }
.bsm-review-label { font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.07em; color: #9b6b7a; margin-bottom: 2px; }
.bsm-review-value { font-size: 0.95rem; font-weight: 600; color: #1a0a2e; }
.bsm-note { text-align: center; font-size: 0.8rem; color: #7a6872; margin-bottom: 18px; }
.bsm-btn-confirm { position: relative; width: 100%; padding: 16px; border: none; border-radius: 14px; background: linear-gradient(135deg, #ff9f00, #ffbe00); color: #1a0a2e; font-family: var(--font-body); font-size: 1rem; font-weight: 700; letter-spacing: 0.04em; overflow: hidden; transition: transform 0.2s, box-shadow 0.2s; box-shadow: 0 4px 20px rgba(255,159,0,0.4); cursor: pointer; }
.bsm-btn-confirm:hover { transform: translateY(-2px); box-shadow: 0 8px 28px rgba(255,159,0,0.5); }
.bsm-btn-confirm:disabled { opacity: 0.7; transform: none; }
@media (min-width: 600px) {
  .bsm-content { max-width: 480px; max-height: 90vh; margin: auto; border-radius: 20px; box-shadow: 0 24px 80px rgba(26,10,46,0.5); }
  .booking-steps-modal.open { align-items: center; justify-content: center; }
}

/* =================== CONFIRM MODAL (matches index.html) =================== */
.confirm-modal { position: fixed; inset: 0; z-index: 30000; display: flex; align-items: center; justify-content: center; background: rgba(0,0,0,0.6); backdrop-filter: blur(8px); opacity: 0; visibility: hidden; transition: all var(--transition); padding: 20px; }
.confirm-modal.open { opacity: 1; visibility: visible; }
.confirm-content { background: white; border-radius: 20px; padding: 52px 40px; text-align: center; max-width: 420px; width: 100%; box-shadow: 0 32px 80px rgba(0,0,0,0.2); }
.confirm-icon { font-size: 3rem; margin-bottom: 20px; }
.confirm-content h3 { font-family: var(--font-heading); font-size: 1.8rem; color: var(--black); margin-bottom: 12px; }
.confirm-content p { font-size: 0.9rem; color: var(--grey); line-height: 1.7; margin-bottom: 28px; }
.btn-confirm-close { background: linear-gradient(135deg, #4a8fa0, #6b2d8b); color: white; border: none; padding: 14px 32px; border-radius: 50px; font-size: 0.95rem; font-weight: 600; transition: all var(--transition); cursor: pointer; }
.btn-confirm-close:hover { transform: translateY(-2px); box-shadow: 0 8px 30px rgba(100,45,135,0.4); }

/* =================== DASHBOARD REVIEW PROMPT (lxb- prefixed) =================== */
.lxb-rp-card {
  margin-top: 24px;
  background: linear-gradient(135deg, #fff0f7 0%, #f5eeff 100%);
  border: 1.5px solid rgba(255,45,135,.15);
  border-radius: 20px;
  padding: 22px 22px 22px 20px;
  display: flex;
  align-items: center;
  gap: 16px;
  position: relative;
  overflow: hidden;
}
.lxb-rp-icon { font-size: 1.9rem; flex-shrink: 0; }
.lxb-rp-text { flex: 1; }
.lxb-rp-title { font-weight: 700; font-size: .93rem; color: #1a0a2e; margin-bottom: 3px; }
.lxb-rp-sub   { font-size: .78rem; color: #7a6872; }
.lxb-rp-btn {
  background: linear-gradient(135deg, #ff2d87, #9b00ff);
  color: #fff;
  border: none; border-radius: 50px;
  padding: 11px 20px;
  font-weight: 600; font-size: .83rem;
  cursor: pointer;
  display: inline-flex; align-items: center; gap: 6px;
  white-space: nowrap; flex-shrink: 0;
  transition: transform .2s, box-shadow .2s;
}
.lxb-rp-btn:hover { transform: translateY(-2px); box-shadow: 0 8px 22px rgba(255,45,135,.4); }

/* Shared modal base (mirrors index.css lxb- styles for dashboard) */
.lxb-modal-wrap {
  display: none;
  position: fixed; inset: 0;
  z-index: 3000;
  align-items: center; justify-content: center;
}
.lxb-modal-wrap.lxb-open { display: flex; }
.lxb-modal-overlay {
  position: absolute; inset: 0;
  background: rgba(26,10,46,.8);
  backdrop-filter: blur(7px);
}
.lxb-modal-box {
  position: relative; z-index: 1;
  background: #fff; border-radius: 28px;
  padding: 44px 32px 36px;
  max-width: 440px; width: 90%;
  max-height: 90vh; overflow-y: auto;
  animation: lxbUp .3s cubic-bezier(.4,0,.2,1);
}
@keyframes lxbUp {
  from { transform: translateY(26px); opacity: 0; }
  to   { transform: translateY(0);    opacity: 1; }
}
.lxb-modal-close {
  position: absolute; top: 14px; right: 16px;
  background: #f3eeff; border: none; border-radius: 50%;
  width: 33px; height: 33px;
  font-size: .85rem; color: #7a6872;
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  transition: background .2s, color .2s;
}
.lxb-modal-close:hover { background: rgba(255,45,135,.12); color: #ff2d87; }
.lxb-modal-head { text-align: center; margin-bottom: 26px; }
.lxb-modal-emoji { font-size: 2.3rem; margin-bottom: 10px; }
.lxb-modal-head h3 { font-family: 'Playfair Display', serif; font-size: 1.5rem; color: #1a0a2e; margin-bottom: 6px; }
.lxb-modal-head p  { color: #7a6872; font-size: .86rem; }
.lxb-star-row { margin-bottom: 20px; }
.lxb-star-row label { display: block; font-weight: 600; font-size: .84rem; color: #1a0a2e; margin-bottom: 9px; }
.lxb-stars { display: flex; gap: 6px; }
.lxb-star {
  background: none; border: none;
  font-size: 1.8rem; color: #ddd;
  cursor: pointer; padding: 0 2px;
  transition: color .15s, transform .15s;
}
.lxb-star.on, .lxb-star:hover { color: #ff9f00; transform: scale(1.18); }
.lxb-star-hint { display: block; font-size: .77rem; color: #7a6872; margin-top: 6px; }
.lxb-field { margin-bottom: 16px; }
.lxb-field label { display: block; font-weight: 600; font-size: .84rem; color: #1a0a2e; margin-bottom: 7px; }
.lxb-field textarea {
  width: 100%; border: 1.5px solid rgba(155,0,255,.15);
  border-radius: 12px; padding: 12px 14px;
  font-size: .88rem; color: #1a0a2e;
  background: #f9f0ff; outline: none; resize: none;
  transition: border-color .2s, background .2s;
}
.lxb-field textarea:focus { border-color: #ff2d87; background: #fff; }
.lxb-db-submit {
  width: 100%;
  background: linear-gradient(135deg, #ff2d87, #9b00ff);
  color: #fff; border: none; border-radius: 50px;
  padding: 14px; font-weight: 700; font-size: .93rem;
  cursor: pointer; display: flex; align-items: center; justify-content: center; gap: 8px;
  transition: transform .2s, box-shadow .2s;
}
.lxb-db-submit:hover { transform: translateY(-2px); box-shadow: 0 10px 28px rgba(255,45,135,.4); }
.lxb-success { text-align: center; padding: 8px 0; }
.lxb-success-emoji { font-size: 2.8rem; margin-bottom: 12px; }
.lxb-success h4 { font-family: 'Playfair Display', serif; font-size: 1.4rem; color: #1a0a2e; margin-bottom: 8px; }
.lxb-success p  { color: #7a6872; font-size: .86rem; }

@media (max-width: 560px) {
  .lxb-rp-card { flex-direction: column; align-items: flex-start; }
  .lxb-rp-btn  { width: 100%; justify-content: center; }
}
