/* ═══════════════════════════════════════════════════════ */
/*  CSS VARIABLES — matches home/booking design system    */
/* ═══════════════════════════════════════════════════════ */
:root{
  --font-display:'Cormorant Garamond',Georgia,serif;
  --font-body:'DM Sans',-apple-system,BlinkMacSystemFont,sans-serif;
  --bg-color:#0a0a08;--text-primary:#f0ebe3;--text-secondary:#8a8578;
  --accent-gold:#c9a84c;--accent-cream:#f0ebe3;--accent-rose:#b85c5c;
  --neon-glow:rgba(201,168,76,.45);--neon-glow-alt:rgba(184,92,92,.45);
  --glass-bg:rgba(18,17,14,.78);--glass-border:rgba(201,168,76,.12);
  --glass-shadow:0 8px 32px 0 rgba(0,0,0,.8);
  --success:#7fb069;--error:#c44040;
  --ease:cubic-bezier(.25,.46,.45,.94);--spring:cubic-bezier(.175,.885,.32,1.275);
  --nav-bg:rgba(10,10,8,.92);--card-hover:rgba(201,168,76,.04);
  --sidebar-w:260px;
  --safe-bottom:env(safe-area-inset-bottom,0px);
}
[data-theme="light"]{
  --bg-color:#f5f0e8;--text-primary:#1a1814;--text-secondary:#6b6560;
  --glass-bg:rgba(245,240,232,.92);--glass-border:rgba(201,168,76,.18);
  --glass-shadow:0 8px 32px rgba(0,0,0,.08);--nav-bg:rgba(245,240,232,.94);
  --card-hover:rgba(201,168,76,.06);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
body,html{width:100%;min-height:100vh;font-family:var(--font-body);color:var(--text-primary);background:var(--bg-color);overflow-x:clip;scroll-behavior:smooth;-webkit-font-smoothing:antialiased;}
a{color:inherit;text-decoration:none;}
::selection{background:rgba(201,168,76,.3);}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:600;letter-spacing:-.025em;}
p{font-size:.95rem;line-height:1.75;color:var(--text-secondary);}

/* ── Backgrounds ── */
.bg-base{position:fixed;inset:0;z-index:-4;background:radial-gradient(ellipse at 15% 45%,rgba(201,168,76,.035) 0%,transparent 55%),radial-gradient(ellipse at 85% 15%,rgba(184,92,92,.025) 0%,transparent 50%),radial-gradient(ellipse at 50% 90%,rgba(201,168,76,.02) 0%,transparent 40%),var(--bg-color);}
.bg-greek{position:fixed;inset:0;z-index:-3;pointer-events:none;overflow:hidden;}
.gk{position:absolute;font-family:var(--font-display);color:var(--accent-gold);opacity:.025;font-weight:300;user-select:none;line-height:1;}
.gk-1{font-size:32vw;top:-10%;right:-6%;transform:rotate(-12deg);}
.gk-2{font-size:20vw;bottom:-5%;left:-4%;transform:rotate(8deg);}
.bg-grid{position:fixed;inset:0;z-index:-2;pointer-events:none;background-image:linear-gradient(rgba(201,168,76,.018) 1px,transparent 1px),linear-gradient(90deg,rgba(201,168,76,.018) 1px,transparent 1px);background-size:72px 72px;}
[data-theme="light"] .bg-grid{background-image:linear-gradient(rgba(0,0,0,.022) 1px,transparent 1px),linear-gradient(90deg,rgba(0,0,0,.022) 1px,transparent 1px);}
[data-theme="light"] .gk{color:#1a1814;}
#particles{position:fixed;inset:0;z-index:0;pointer-events:none;}
.particle{position:absolute;border-radius:50%;background:var(--accent-gold);box-shadow:0 0 6px var(--accent-gold);opacity:0;animation:pF 16s infinite linear;}
@keyframes pF{0%{transform:translateY(100vh) scale(0);opacity:0}8%{opacity:.12}92%{opacity:.12}100%{transform:translateY(-80px) scale(1.4);opacity:0}}

/* ── Scroll Reveal ── */
.rv{opacity:0;transform:translateY(48px);transition:opacity .85s var(--ease),transform .85s var(--ease);will-change:transform,opacity;}
.rv.vis{opacity:1;transform:translateY(0);}
.rv-d1{transition-delay:.1s}.rv-d2{transition-delay:.2s}.rv-d3{transition-delay:.35s}

/* ── Glass Shared ── */
.glass{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:24px;box-shadow:var(--glass-shadow);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);transition:box-shadow .5s,border-color .35s;}
.glass:hover{box-shadow:0 16px 48px rgba(0,0,0,.65),0 0 28px rgba(201,168,76,.05);}

/* ═══════════════════════════════════════════════════════ */
/*  TOP NAV                                                */
/* ═══════════════════════════════════════════════════════ */
nav{display:flex;justify-content:space-between;align-items:center;padding:0 5%;height:64px;position:fixed;top:0;width:100%;z-index:999;background:var(--nav-bg);border-bottom:1px solid var(--glass-border);backdrop-filter:blur(22px);-webkit-backdrop-filter:blur(22px);}
.nav-logo{display:flex;align-items:center;gap:12px;}
.nav-wm{font-family:var(--font-display);font-size:1.55rem;font-weight:700;color:var(--accent-gold);letter-spacing:-.04em;text-shadow:0 0 18px var(--neon-glow);}
.nav-wm em{font-weight:300;opacity:.55;font-style:normal;}
.nav-sep{width:1px;height:18px;background:var(--glass-border);}
.nav-badge{display:flex;align-items:center;gap:5px;font-size:.63rem;font-weight:700;font-family:var(--font-body);background:rgba(201,168,76,.07);border:1px solid rgba(201,168,76,.22);padding:3px 10px;border-radius:20px;color:var(--accent-gold);letter-spacing:.08em;text-transform:uppercase;}
.nav-dot{width:5px;height:5px;background:var(--accent-gold);border-radius:50%;box-shadow:0 0 6px var(--accent-gold);animation:blink 2s infinite;}
@keyframes blink{0%,100%{opacity:.45}50%{opacity:1}}
.nav-r{display:flex;align-items:center;gap:5px;}
.np{padding:5px 11px;border-radius:20px;font-size:.7rem;font-weight:600;cursor:pointer;transition:all .25s var(--ease);border:1px solid var(--glass-border);background:transparent;color:var(--text-secondary);letter-spacing:.02em;font-family:var(--font-body);white-space:nowrap;display:inline-flex;align-items:center;gap:4px;}
.np:hover{background:var(--glass-bg);color:var(--accent-gold);border-color:var(--accent-gold);}
.np-gold{border-color:rgba(201,168,76,.3);color:var(--accent-gold);}
.np-gold:hover{background:rgba(201,168,76,.1);}
.np-rose{border-color:rgba(184,92,92,.25);color:var(--accent-rose);}
.np-rose:hover{background:rgba(184,92,92,.08);border-color:var(--accent-rose);}
.np-active{border-color:var(--accent-gold);color:var(--accent-gold);background:rgba(201,168,76,.08);}
.np i{font-size:.58rem;}
.tbtn{background:none;border:1px solid var(--glass-border);color:var(--text-primary);width:32px;height:32px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.9rem;transition:transform .3s,border-color .3s;}
.tbtn:hover{transform:scale(1.15) rotate(15deg);border-color:var(--accent-gold);}
/* Auth pill in nav */
.nav-auth-pill{display:inline-flex;align-items:center;gap:6px;padding:4px 12px 4px 5px;border-radius:20px;font-size:.7rem;font-weight:600;cursor:pointer;transition:all .25s var(--ease);border:1px solid rgba(201,168,76,.3);background:transparent;color:var(--accent-gold);letter-spacing:.02em;font-family:var(--font-body);white-space:nowrap;}
.nav-auth-pill:hover{background:rgba(201,168,76,.1);border-color:var(--accent-gold);}
.nav-auth-avatar{width:22px;height:22px;border-radius:50%;border:1.5px solid var(--accent-gold);object-fit:cover;display:none;}
.hamburger{display:none;background:none;border:1px solid var(--glass-border);color:var(--text-primary);width:40px;height:40px;border-radius:12px;cursor:pointer;align-items:center;justify-content:center;font-size:1.1rem;transition:all .3s;}
@media(hover:hover){.hamburger:hover{border-color:var(--accent-gold);color:var(--accent-gold);}}
.nav-mobile-avatar{display:none;background:none;border:none;padding:0;cursor:pointer;}
.nav-mobile-signin{display:none;}
.nav-mobile-group{display:none;}

/* ── Mobile nav drawer ── */
.mobile-drawer{display:none;}
.drawer-backdrop{display:none;}

/* ═══════════════════════════════════════════════════════ */
/*  LAYOUT — sidebar + main content                       */
/* ═══════════════════════════════════════════════════════ */
.app-shell{display:flex;min-height:100vh;padding-top:64px;position:relative;z-index:1;}

/* ── Sidebar (desktop) ── */
.sidebar{width:var(--sidebar-w);position:fixed;top:64px;left:0;bottom:0;background:var(--glass-bg);border-right:1px solid var(--glass-border);backdrop-filter:blur(28px);-webkit-backdrop-filter:blur(28px);display:flex;flex-direction:column;padding:1.6rem 1rem 1.2rem;z-index:10;overflow-y:auto;transition:transform .35s var(--ease);}
.sidebar-user{display:flex;align-items:center;gap:12px;padding:.8rem;border-radius:16px;background:rgba(201,168,76,.04);border:1px solid var(--glass-border);margin-bottom:1.4rem;min-height:64px;transition:opacity .3s;}
.sidebar-avatar{width:42px;height:42px;border-radius:50%;border:2px solid var(--accent-gold);object-fit:cover;flex-shrink:0;background:rgba(201,168,76,.08);}
.sidebar-user-info{flex:1;min-width:0;}
.sidebar-user-name{font-weight:700;font-size:.88rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.sidebar-user-email{font-size:.72rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.sidebar-nav{display:flex;flex-direction:column;gap:4px;flex:1;}
.snav{display:flex;align-items:center;gap:12px;padding:.75rem 1rem;border-radius:14px;font-size:.86rem;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all .25s var(--ease);border:1px solid transparent;background:transparent;text-align:left;width:100%;font-family:var(--font-body);}
.snav:hover{background:var(--card-hover);color:var(--text-primary);border-color:var(--glass-border);}
.snav.active{background:rgba(201,168,76,.08);color:var(--accent-gold);border-color:rgba(201,168,76,.25);}
.snav i{width:18px;text-align:center;font-size:.9rem;}
.snav .badge{margin-left:auto;padding:2px 8px;border-radius:20px;background:var(--accent-rose);color:#fff;font-size:.65rem;font-weight:700;min-width:20px;text-align:center;display:none;}
.snav .badge.visible{display:inline-block;}
.sidebar-signout{margin-top:auto;padding-top:1rem;border-top:1px solid var(--glass-border);}
.sidebar-signout button{display:flex;align-items:center;gap:10px;width:100%;padding:.7rem 1rem;border-radius:12px;font-size:.82rem;font-weight:600;color:var(--error);background:transparent;border:1px solid transparent;cursor:pointer;transition:all .25s;font-family:var(--font-body);}
.sidebar-signout button:hover{border-color:rgba(196,64,64,.25);background:rgba(196,64,64,.06);}

/* ── Main panel ── */
.main-panel{flex:1;margin-left:var(--sidebar-w);padding:2rem 2.5rem 4rem;min-width:0;}
.main-panel-header{margin-bottom:2rem;}
.main-panel-header h1{font-size:clamp(1.8rem,3vw,2.6rem);letter-spacing:-.04em;margin-bottom:.25rem;}
.main-panel-header p{font-size:.9rem;color:var(--text-secondary);}

/* ── Tab panels ── */
.tab-panel{display:none;animation:fadeUp .45s var(--ease) both;}
.tab-panel.active{display:block;}
@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}

/* ═══════════════════════════════════════════════════════ */
/*  OVERVIEW TAB                                           */
/* ═══════════════════════════════════════════════════════ */
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:2rem;}
.kpi-card{position:relative;overflow:hidden;padding:1.4rem;border-radius:20px;background:var(--glass-bg);border:1px solid var(--glass-border);backdrop-filter:blur(14px);transition:all .35s var(--ease);}
.kpi-card:hover{border-color:rgba(201,168,76,.25);transform:translateY(-2px);box-shadow:0 12px 36px rgba(0,0,0,.4),0 0 20px rgba(201,168,76,.04);}
.kpi-card::after{content:'';position:absolute;top:0;right:0;width:60%;height:100%;background:linear-gradient(135deg,transparent 40%,rgba(201,168,76,.03) 100%);pointer-events:none;}
.kpi-icon{width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1rem;margin-bottom:.8rem;}
.kpi-icon.gold{background:rgba(201,168,76,.1);color:var(--accent-gold);}
.kpi-icon.rose{background:rgba(184,92,92,.1);color:var(--accent-rose);}
.kpi-icon.green{background:rgba(127,176,105,.1);color:var(--success);}
.kpi-icon.cream{background:rgba(240,235,227,.08);color:var(--accent-cream);}
.kpi-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary);margin-bottom:.35rem;}
.kpi-value{font-family:var(--font-display);font-size:1.8rem;font-weight:700;letter-spacing:-.03em;color:var(--text-primary);font-variant-numeric:tabular-nums;}
.kpi-sub{font-size:.72rem;color:var(--text-secondary);margin-top:.25rem;}

/* Activity Feed */
.activity-section{margin-top:2rem;}
.activity-section h3{font-size:1.2rem;margin-bottom:1rem;}
.activity-list{display:flex;flex-direction:column;gap:.6rem;}
.activity-item{display:flex;align-items:flex-start;gap:14px;padding:1rem 1.2rem;border-radius:16px;background:var(--glass-bg);border:1px solid var(--glass-border);transition:all .25s;}
.activity-item:hover{border-color:rgba(201,168,76,.2);}
.activity-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:.85rem;flex-shrink:0;}
.activity-icon.booking{background:rgba(201,168,76,.1);color:var(--accent-gold);}
.activity-icon.message{background:rgba(127,176,105,.1);color:var(--success);}
.activity-icon.system{background:rgba(240,235,227,.06);color:var(--text-secondary);}
.activity-body{flex:1;min-width:0;}
.activity-title{font-size:.88rem;font-weight:600;color:var(--text-primary);}
.activity-meta{font-size:.74rem;color:var(--text-secondary);margin-top:2px;}
.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;text-align:center;}
.empty-state svg{width:80px;height:80px;opacity:.2;margin-bottom:1.2rem;}
.empty-state h3{font-size:1.1rem;margin-bottom:.4rem;}
.empty-state p{font-size:.85rem;color:var(--text-secondary);max-width:320px;}
.empty-state .btn{margin-top:1.2rem;}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:.85rem 2rem;border-radius:50px;font-weight:700;font-size:.9rem;cursor:pointer;transition:all .35s var(--spring);border:none;background:var(--accent-gold);color:#0a0a08;box-shadow:0 0 22px var(--neon-glow);letter-spacing:.01em;font-family:var(--font-body);}
.btn:hover{transform:translateY(-2px) scale(1.02);box-shadow:0 8px 32px var(--neon-glow);}
.btn-outline{background:transparent;border:1.5px solid rgba(201,168,76,.22);color:var(--text-primary);box-shadow:none;}
.btn-outline:hover{background:rgba(201,168,76,.06);border-color:var(--accent-gold);box-shadow:none;transform:translateY(-2px);}

/* ═══════════════════════════════════════════════════════ */
/*  BOOKINGS TAB                                           */
/* ═══════════════════════════════════════════════════════ */
.bookings-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1rem;}
.booking-card{position:relative;border-radius:20px;padding:1.4rem;background:var(--glass-bg);border:1px solid var(--glass-border);backdrop-filter:blur(14px);cursor:pointer;transition:all .35s var(--ease);overflow:hidden;}
.booking-card:hover{border-color:rgba(201,168,76,.25);transform:translateY(-2px);box-shadow:0 12px 36px rgba(0,0,0,.4);}
.booking-card-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:.8rem;}
.booking-card-id{font-family:var(--font-body);font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--accent-gold);background:rgba(201,168,76,.08);padding:3px 10px;border-radius:20px;}
.booking-status{font-size:.68rem;font-weight:700;padding:3px 10px;border-radius:20px;text-transform:uppercase;letter-spacing:.06em;}
.booking-status.submitted{background:rgba(201,168,76,.1);color:var(--accent-gold);}
.booking-status.confirmed{background:rgba(127,176,105,.1);color:var(--success);}
.booking-status.completed{background:rgba(184,92,92,.1);color:var(--accent-rose);}
.booking-title{font-family:var(--font-display);font-size:1.15rem;font-weight:600;letter-spacing:-.02em;margin-bottom:.5rem;}
.booking-details{display:flex;flex-wrap:wrap;gap:.8rem;margin-bottom:.8rem;}
.booking-detail{display:flex;align-items:center;gap:6px;font-size:.78rem;color:var(--text-secondary);}
.booking-detail i{color:var(--accent-gold);font-size:.7rem;width:14px;text-align:center;}
.booking-progress{height:3px;border-radius:3px;background:rgba(201,168,76,.1);overflow:hidden;margin-bottom:.8rem;}
.booking-progress-bar{height:100%;border-radius:3px;background:var(--accent-gold);transition:width .5s var(--ease);}
.booking-expand{display:none;padding-top:.8rem;border-top:1px solid var(--glass-border);margin-top:.8rem;animation:fadeUp .3s var(--ease);}
.booking-card.expanded .booking-expand{display:block;}
.booking-receipt{display:grid;grid-template-columns:1fr 1fr;gap:.4rem .8rem;font-size:.8rem;margin-bottom:.8rem;}
.booking-receipt dt{color:var(--text-secondary);}
.booking-receipt dd{text-align:right;font-weight:600;color:var(--text-primary);}
.booking-actions{display:flex;gap:.5rem;}
.booking-actions button{padding:.55rem 1rem;border-radius:50px;font-size:.78rem;font-weight:700;cursor:pointer;transition:all .25s;font-family:var(--font-body);border:1px solid var(--glass-border);background:transparent;color:var(--text-primary);}
.booking-actions button:hover{border-color:var(--accent-gold);color:var(--accent-gold);background:rgba(201,168,76,.04);}

/* ═══════════════════════════════════════════════════════ */
/*  MESSAGES TAB — full chat UI                            */
/* ═══════════════════════════════════════════════════════ */
.chat-shell{display:grid;grid-template-columns:300px 6px 1fr;height:calc(100vh - 180px);border-radius:20px;overflow:hidden;border:1px solid var(--glass-border);background:var(--glass-bg);backdrop-filter:blur(18px);}

/* Conversation list */
.chat-list{border-right:1px solid var(--glass-border);display:flex;flex-direction:column;overflow:hidden;}
.chat-list-header{padding:1.2rem;border-bottom:1px solid var(--glass-border);display:flex;align-items:center;justify-content:space-between;}
.chat-list-header h3{font-size:1rem;margin:0;}
.chat-sound-toggle{width:30px;height:30px;border-radius:50%;border:1px solid var(--glass-border);background:transparent;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;}
.chat-sound-toggle:hover{border-color:var(--accent-gold);color:var(--accent-gold);}
.chat-sound-toggle.muted{color:var(--accent-rose);border-color:rgba(184,92,92,.35);}
.chat-list-search{padding:.6rem 1rem;border-bottom:1px solid var(--glass-border);}
.chat-list-search input{width:100%;padding:.55rem .8rem;border-radius:10px;border:1px solid var(--glass-border);background:rgba(15,14,12,.6);color:var(--text-primary);font-size:.82rem;font-family:var(--font-body);outline:none;transition:border-color .25s;}
.chat-list-search input:focus{border-color:var(--accent-gold);}
[data-theme="light"] .chat-list-search input{background:rgba(255,255,255,.6);}
.chat-list-items{flex:1;overflow-y:auto;overscroll-behavior:contain;}
.chat-resize-handle{cursor:col-resize;background:linear-gradient(180deg,transparent,rgba(201,168,76,.25),transparent);border-left:1px solid rgba(201,168,76,.08);border-right:1px solid rgba(201,168,76,.08);}
.chat-resize-handle:hover{background:linear-gradient(180deg,transparent,rgba(201,168,76,.4),transparent);}
.chat-pull-indicator{display:flex;align-items:center;justify-content:center;gap:7px;font-size:.68rem;color:var(--text-secondary);padding:.35rem .4rem;border-bottom:1px solid rgba(201,168,76,.08);opacity:0;transform:translateY(-8px);transition:all .2s;pointer-events:none;}
.chat-pull-indicator.visible{opacity:.9;transform:translateY(0);}
.chat-item{display:flex;align-items:center;gap:12px;padding:1rem 1.2rem;cursor:pointer;transition:all .2s;border-bottom:1px solid rgba(201,168,76,.06);}
.chat-item:hover{background:var(--card-hover);}
.chat-item.active{background:rgba(201,168,76,.08);border-left:3px solid var(--accent-gold);}
.chat-item-avatar{width:38px;height:38px;border-radius:50%;background:rgba(201,168,76,.08);border:1px solid var(--glass-border);display:flex;align-items:center;justify-content:center;font-size:.85rem;color:var(--accent-gold);flex-shrink:0;}
.chat-item-body{flex:1;min-width:0;}
.chat-item-title{font-size:.84rem;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.chat-item-preview{font-size:.75rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px;}
.chat-item-meta{display:flex;flex-direction:column;align-items:flex-end;gap:4px;flex-shrink:0;}
.chat-item-time{font-size:.68rem;color:var(--text-secondary);}
.chat-item-unread{width:20px;height:20px;border-radius:50%;background:var(--accent-rose);color:#fff;font-size:.62rem;font-weight:700;display:flex;align-items:center;justify-content:center;}

/* Thread pane */
.chat-thread{display:flex;flex-direction:column;overflow:hidden;position:relative;}
.chat-thread-header{padding:1rem 1.4rem;border-bottom:1px solid var(--glass-border);display:flex;align-items:center;gap:12px;min-height:60px;}
.chat-thread-header .back-btn{display:none;width:32px;height:32px;border-radius:50%;border:1px solid var(--glass-border);background:transparent;color:var(--text-primary);cursor:pointer;align-items:center;justify-content:center;font-size:.85rem;transition:all .25s;flex-shrink:0;}
.chat-thread-header .back-btn:hover{border-color:var(--accent-gold);color:var(--accent-gold);}
.chat-thread-title{font-size:.92rem;font-weight:700;color:var(--text-primary);}
.chat-thread-subtitle{font-size:.72rem;color:var(--text-secondary);}
.chat-thread-booking-link{margin-top:.35rem;background:transparent;border:1px solid var(--glass-border);border-radius:999px;color:var(--accent-gold);font-size:.68rem;font-weight:700;letter-spacing:.03em;padding:.25rem .6rem;cursor:pointer;display:inline-flex;align-items:center;gap:6px;}
.chat-thread-booking-link:hover{border-color:var(--accent-gold);background:rgba(201,168,76,.08);}
.chat-context-bar{padding:.6rem 1.2rem;border-bottom:1px solid var(--glass-border);background:rgba(201,168,76,.03);display:none;align-items:center;gap:10px;font-size:.78rem;color:var(--text-secondary);}
.chat-context-bar.visible{display:flex;}
.chat-context-bar i{color:var(--accent-gold);}
.chat-messages{flex:1;overflow-y:auto;overscroll-behavior:contain;padding:1.2rem 1.4rem;display:flex;flex-direction:column;gap:.6rem;}
.chat-load-earlier{align-self:center;border:1px solid var(--glass-border);background:rgba(201,168,76,.06);color:var(--accent-gold);border-radius:999px;padding:.4rem .85rem;font-size:.68rem;font-weight:700;cursor:pointer;display:inline-flex;align-items:center;gap:6px;margin-bottom:.2rem;}
.chat-load-earlier:hover{border-color:var(--accent-gold);background:rgba(201,168,76,.12);}
.chat-render-all-loaded{align-self:center;border:1px solid rgba(201,168,76,.2);background:rgba(201,168,76,.03);color:var(--text-secondary);border-radius:999px;padding:.34rem .78rem;font-size:.64rem;font-weight:700;cursor:pointer;display:inline-flex;align-items:center;gap:6px;margin-bottom:.15rem;}
.chat-render-all-loaded:hover{color:var(--accent-gold);border-color:var(--accent-gold);}
.chat-bubble-wrap{display:flex;align-items:flex-end;gap:8px;max-width:78%;}
.chat-bubble-wrap.me{margin-left:auto;flex-direction:row-reverse;}
.chat-bubble-wrap.grouped{margin-top:-.28rem;}
.chat-bubble-wrap.grouped .chat-bubble-avatar{visibility:hidden;}
.chat-bubble-wrap.sent-pop{animation:sentPop .24s var(--spring);}
.chat-bubble-avatar{width:28px;height:28px;border-radius:50%;background:rgba(201,168,76,.08);border:1px solid var(--glass-border);display:flex;align-items:center;justify-content:center;font-size:.65rem;color:var(--accent-gold);flex-shrink:0;}
.chat-bubble{padding:.65rem 1rem;border-radius:18px;font-size:.86rem;line-height:1.55;word-break:break-word;position:relative;}
.chat-bubble .chat-link{color:inherit;text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:2px;opacity:.95;}
.chat-bubble .chat-link:hover{opacity:1;}
.chat-bubble-wrap.them .chat-bubble{background:rgba(201,168,76,.06);border:1px solid rgba(201,168,76,.12);border-bottom-left-radius:6px;color:var(--text-primary);}
.chat-bubble-wrap.me .chat-bubble{background:var(--accent-gold);color:#0a0a08;border-bottom-right-radius:6px;}
.chat-bubble-wrap.them.grouped .chat-bubble{border-bottom-left-radius:18px;}
.chat-bubble-wrap.me.grouped .chat-bubble{border-bottom-right-radius:18px;}
.chat-bubble-time{font-size:.64rem;color:var(--text-secondary);margin-top:3px;padding:0 4px;}
.chat-bubble-wrap.me .chat-bubble-time{text-align:right;}
.chat-read-tick{font-size:.6rem;color:var(--accent-gold);margin-left:4px;}
.chat-delivered-tick{font-size:.58rem;color:rgba(10,10,8,.7);margin-left:4px;}
.chat-date-divider{text-align:center;padding:.5rem 0;font-size:.68rem;color:var(--text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.06em;}

/* Composer */
.chat-composer{padding:1rem 1.2rem;border-top:1px solid var(--glass-border);display:flex;align-items:flex-end;gap:.6rem;background:rgba(10,10,8,.3);}
[data-theme="light"] .chat-composer{background:rgba(245,240,232,.3);}
.chat-composer textarea{flex:1;resize:none;border:1px solid var(--glass-border);border-radius:16px;padding:.7rem 1rem;font-size:.86rem;font-family:var(--font-body);background:rgba(15,14,12,.6);color:var(--text-primary);outline:none;max-height:120px;min-height:42px;line-height:1.4;transition:border-color .25s;}
.chat-composer textarea:focus{border-color:var(--accent-gold);}
[data-theme="light"] .chat-composer textarea{background:rgba(255,255,255,.6);}
.chat-composer textarea::placeholder{color:var(--text-secondary);opacity:.6;}
.chat-send-btn{width:42px;height:42px;border-radius:50%;background:var(--accent-gold);color:#0a0a08;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1rem;transition:all .25s var(--spring);flex-shrink:0;}
.chat-send-btn:hover{transform:scale(1.08);box-shadow:0 4px 16px var(--neon-glow);}
.chat-send-btn:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none;}
.chat-composer-hint{display:none;flex-basis:100%;font-size:.68rem;color:var(--text-secondary);padding:.1rem .15rem 0;}
.chat-composer-hint.visible{display:block;}
.chat-scroll-fab{position:absolute;right:1rem;bottom:5.4rem;z-index:6;border-radius:999px;border:1px solid rgba(201,168,76,.4);background:rgba(24,22,18,.88);color:var(--accent-gold);padding:.5rem .9rem;font-size:.72rem;font-weight:700;display:none;align-items:center;gap:7px;cursor:pointer;box-shadow:0 10px 24px rgba(0,0,0,.35);}
.chat-scroll-fab.visible{display:inline-flex;}
.chat-scroll-fab:hover{background:rgba(201,168,76,.12);border-color:var(--accent-gold);}
.chat-typing-indicator{display:none;align-items:center;gap:6px;padding:.5rem 1.2rem;color:var(--text-secondary);font-size:.72rem;border-top:1px solid rgba(201,168,76,.08);background:rgba(201,168,76,.03);}
.chat-typing-indicator.visible{display:flex;}
.chat-typing-indicator span{width:6px;height:6px;border-radius:50%;background:var(--accent-gold);opacity:.5;animation:typingDots 1s infinite;}
.chat-typing-indicator span:nth-child(2){animation-delay:.15s;}
.chat-typing-indicator span:nth-child(3){animation-delay:.3s;}

/* New conversation from booking */
.chat-new-convo{padding:1rem 1.2rem;border-bottom:1px solid var(--glass-border);display:none;}
.chat-new-convo.visible{display:block;}
.chat-new-convo label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary);display:block;margin-bottom:.4rem;}
.chat-new-convo input{width:100%;padding:.6rem .8rem;border-radius:10px;border:1px solid var(--glass-border);background:rgba(15,14,12,.6);color:var(--text-primary);font-size:.84rem;font-family:var(--font-body);outline:none;transition:border-color .25s;}
.chat-new-convo input:focus{border-color:var(--accent-gold);}
[data-theme="light"] .chat-new-convo input{background:rgba(255,255,255,.6);}

/* Empty thread state */
.chat-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:2rem;opacity:.5;}
.chat-empty i{font-size:2.5rem;color:var(--accent-gold);margin-bottom:1rem;opacity:.3;}
.chat-empty p{font-size:.88rem;color:var(--text-secondary);}
.chat-empty-cta{margin-top:.85rem;display:inline-flex;align-items:center;gap:8px;padding:.55rem .95rem;border-radius:999px;border:1px solid rgba(201,168,76,.3);color:var(--accent-gold);font-size:.75rem;font-weight:700;letter-spacing:.02em;text-decoration:none;background:rgba(201,168,76,.05);}
.chat-empty-cta:hover{background:rgba(201,168,76,.1);border-color:var(--accent-gold);}

/* ═══════════════════════════════════════════════════════ */
/*  PROFILE TAB                                            */
/* ═══════════════════════════════════════════════════════ */
.profile-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:1.5rem;}
.profile-card{border-radius:20px;padding:1.6rem;background:var(--glass-bg);border:1px solid var(--glass-border);backdrop-filter:blur(14px);}
.profile-card h3{font-size:1.1rem;margin-bottom:1.2rem;display:flex;align-items:center;gap:8px;}
.profile-card h3 i{color:var(--accent-gold);font-size:.9rem;}

/* Avatar upload */
.avatar-zone{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2rem;border:2px dashed var(--glass-border);border-radius:20px;cursor:pointer;transition:all .3s;text-align:center;}
.avatar-zone:hover,.avatar-zone.dragover{border-color:var(--accent-gold);background:rgba(201,168,76,.03);}
.avatar-preview{width:100px;height:100px;border-radius:50%;border:3px solid var(--accent-gold);object-fit:cover;background:rgba(201,168,76,.08);box-shadow:0 8px 32px rgba(0,0,0,.3);}
.avatar-zone p{font-size:.82rem;color:var(--text-secondary);}
.avatar-zone .accent{color:var(--accent-gold);font-weight:700;}

/* Form fields */
.form-group{margin-bottom:1rem;}
.form-label{display:block;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary);margin-bottom:.4rem;}
.form-input{width:100%;padding:.8rem 1rem;border-radius:14px;border:1px solid var(--glass-border);background:rgba(15,14,12,.6);color:var(--text-primary);font-size:.88rem;font-family:var(--font-body);outline:none;transition:border-color .25s,box-shadow .25s;}
.form-input:focus{border-color:var(--accent-gold);box-shadow:0 0 0 3px rgba(201,168,76,.1);}
[data-theme="light"] .form-input{background:rgba(255,255,255,.6);}
.form-input::placeholder{color:var(--text-secondary);opacity:.6;}
textarea.form-input{min-height:100px;resize:vertical;line-height:1.6;}

/* ═══════════════════════════════════════════════════════ */
/*  TOAST NOTIFICATIONS                                    */
/* ═══════════════════════════════════════════════════════ */
.toast-container{position:fixed;top:80px;right:20px;z-index:3000;display:flex;flex-direction:column;gap:.5rem;pointer-events:none;}
.toast{padding:.75rem 1.2rem;border-radius:14px;font-size:.84rem;font-weight:600;backdrop-filter:blur(18px);border:1px solid var(--glass-border);display:flex;align-items:center;gap:8px;pointer-events:auto;animation:toastIn .4s var(--spring) both;font-family:var(--font-body);max-width:360px;}
.toast.ok{background:rgba(127,176,105,.15);border-color:rgba(127,176,105,.3);color:var(--success);}
.toast.err{background:rgba(196,64,64,.15);border-color:rgba(196,64,64,.3);color:var(--error);}
.toast.info{background:rgba(201,168,76,.1);border-color:rgba(201,168,76,.25);color:var(--accent-gold);}
.toast.out{animation:toastOut .3s var(--ease) both;}
@keyframes toastIn{from{opacity:0;transform:translateX(60px) scale(.92)}to{opacity:1;transform:translateX(0) scale(1)}}
@keyframes toastOut{to{opacity:0;transform:translateX(60px) scale(.92)}}

/* ═══════════════════════════════════════════════════════ */
/*  OVERVIEW — Welcome banner + Quick actions              */
/* ═══════════════════════════════════════════════════════ */
.welcome-banner{display:flex;justify-content:space-between;align-items:center;padding:1.4rem 1.6rem;border-radius:20px;background:linear-gradient(135deg,rgba(201,168,76,.06) 0%,rgba(184,92,92,.04) 100%);border:1px solid var(--glass-border);margin-bottom:1.5rem;gap:1rem;flex-wrap:wrap;}
.welcome-text h2{font-size:clamp(1.2rem,2.5vw,1.6rem);letter-spacing:-.03em;margin-bottom:.15rem;}
.welcome-text p{font-size:.84rem;color:var(--text-secondary);margin:0;}
.welcome-status{display:inline-flex;align-items:center;gap:6px;padding:5px 14px;border-radius:20px;background:rgba(127,176,105,.08);border:1px solid rgba(127,176,105,.2);font-size:.72rem;font-weight:700;color:var(--success);letter-spacing:.04em;white-space:nowrap;}
.welcome-status .status-dot{width:6px;height:6px;border-radius:50%;background:var(--success);box-shadow:0 0 6px var(--success);animation:blink 2s infinite;}
.welcome-status.inactive{background:rgba(138,133,120,.08);border-color:rgba(138,133,120,.2);color:var(--text-secondary);}
.welcome-status.inactive .status-dot{background:var(--text-secondary);box-shadow:none;}

.kpi-card.kpi-clickable{cursor:pointer;text-align:left;font-family:inherit;color:inherit;}
.kpi-card.kpi-clickable:hover{border-color:var(--accent-gold);box-shadow:0 12px 36px rgba(0,0,0,.4),0 0 24px rgba(201,168,76,.06);}
.kpi-action{position:absolute;bottom:1rem;right:1rem;width:26px;height:26px;border-radius:50%;background:rgba(201,168,76,.08);color:var(--accent-gold);display:flex;align-items:center;justify-content:center;font-size:.65rem;opacity:.5;transition:all .25s;}
.kpi-card.kpi-clickable:hover .kpi-action{opacity:1;transform:translateX(2px);}
.kpi-value-sm{font-size:1.15rem;}

.quick-actions{display:flex;gap:.6rem;margin-bottom:2rem;flex-wrap:wrap;}
.qa-btn{display:inline-flex;align-items:center;gap:7px;padding:.65rem 1.2rem;border-radius:50px;font-size:.78rem;font-weight:700;cursor:pointer;transition:all .3s var(--ease);border:none;background:var(--accent-gold);color:#0a0a08;font-family:var(--font-body);text-decoration:none;letter-spacing:.01em;}
.qa-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px var(--neon-glow);}
.qa-btn.qa-outline{background:transparent;border:1.5px solid var(--glass-border);color:var(--text-primary);box-shadow:none;}
.qa-btn.qa-outline:hover{border-color:var(--accent-gold);color:var(--accent-gold);background:rgba(201,168,76,.04);box-shadow:none;transform:translateY(-1px);}
.qa-btn i{font-size:.7rem;}

/* ═══════════════════════════════════════════════════════ */
/*  ADMIN TAB                                              */
/* ═══════════════════════════════════════════════════════ */
.admin-notice{display:flex;align-items:center;gap:10px;padding:.8rem 1.2rem;border-radius:14px;background:rgba(201,168,76,.06);border:1px solid rgba(201,168,76,.18);color:var(--accent-gold);font-size:.82rem;font-weight:600;margin-bottom:1.5rem;}
.admin-notice i{font-size:1rem;}

.admin-kpi-row{display:grid;grid-template-columns:repeat(6,1fr);gap:.8rem;margin-bottom:1.5rem;}
.admin-kpi{padding:1rem;border-radius:16px;background:var(--glass-bg);border:1px solid var(--glass-border);text-align:center;backdrop-filter:blur(14px);}
.admin-kpi-num{font-family:var(--font-display);font-size:1.6rem;font-weight:700;color:var(--text-primary);font-variant-numeric:tabular-nums;}
.admin-kpi-label{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary);margin-top:.2rem;}

.admin-tabs{display:flex;gap:.4rem;margin-bottom:1rem;border-bottom:1px solid var(--glass-border);padding-bottom:.6rem;}
.admin-tab{padding:.55rem 1rem;border-radius:10px 10px 0 0;font-size:.78rem;font-weight:700;color:var(--text-secondary);background:transparent;border:1px solid transparent;border-bottom:none;cursor:pointer;transition:all .2s;font-family:var(--font-body);}
.admin-tab:hover{color:var(--text-primary);}
.admin-tab.active{color:var(--accent-gold);background:rgba(201,168,76,.06);border-color:var(--glass-border);}

.admin-table-wrap{display:none;}
.admin-table-wrap.active{display:block;}
.admin-table-header{margin-bottom:.8rem;}
.admin-search{width:100%;max-width:400px;padding:.6rem 1rem;border-radius:12px;border:1px solid var(--glass-border);background:rgba(15,14,12,.6);color:var(--text-primary);font-size:.82rem;font-family:var(--font-body);outline:none;transition:border-color .25s;}
.admin-search:focus{border-color:var(--accent-gold);}
[data-theme="light"] .admin-search{background:rgba(255,255,255,.6);}

.admin-table-scroll{overflow-x:auto;border-radius:16px;border:1px solid var(--glass-border);background:var(--glass-bg);backdrop-filter:blur(14px);}
.admin-table{width:100%;border-collapse:collapse;font-size:.8rem;}
.admin-table thead{background:rgba(201,168,76,.04);}
.admin-table th{padding:.7rem .8rem;text-align:left;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);border-bottom:1px solid var(--glass-border);white-space:nowrap;}
.admin-table td{padding:.65rem .8rem;border-bottom:1px solid rgba(201,168,76,.06);color:var(--text-primary);vertical-align:top;}
.admin-table tbody tr:hover{background:var(--card-hover);}
.admin-table .truncate{max-width:200px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.admin-status{display:inline-block;padding:2px 8px;border-radius:12px;font-size:.66rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;}
.admin-status.submitted{background:rgba(201,168,76,.1);color:var(--accent-gold);}
.admin-status.confirmed{background:rgba(127,176,105,.1);color:var(--success);}
.admin-status.completed{background:rgba(184,92,92,.1);color:var(--accent-rose);}

/* ═══════════════════════════════════════════════════════ */
/*  SKELETON LOADING                                       */
/* ═══════════════════════════════════════════════════════ */
.skeleton{border-radius:10px;background:linear-gradient(90deg,rgba(201,168,76,.04) 25%,rgba(201,168,76,.08) 50%,rgba(201,168,76,.04) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;pointer-events:none;}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.skel-line{height:14px;margin-bottom:8px;border-radius:7px;}
.skel-line.w60{width:60%}.skel-line.w80{width:80%}.skel-line.w40{width:40%}
.skel-card{height:100px;border-radius:16px;margin-bottom:.8rem;}

/* ═══════════════════════════════════════════════════════ */
/*  MODALS (Privacy / Legal)                               */
/* ═══════════════════════════════════════════════════════ */
.modal-overlay{position:fixed;inset:0;z-index:2000;background:rgba(0,0,0,.7);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .35s var(--ease);padding:1rem;}
.modal-overlay.active{opacity:1;pointer-events:auto;}
.modal-content{max-width:560px;width:100%;max-height:82vh;overflow-y:auto;position:relative;padding:2.5rem;}
.modal-close{position:absolute;top:1rem;right:1rem;width:36px;height:36px;border-radius:50%;border:1px solid var(--glass-border);background:transparent;color:var(--text-primary);font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .25s;}
.modal-close:hover{border-color:var(--error);color:var(--error);transform:rotate(90deg);}
.pbadge{display:inline-flex;align-items:center;gap:6px;padding:5px 14px;border-radius:20px;background:rgba(201,168,76,.07);border:1px solid rgba(201,168,76,.2);color:var(--accent-gold);font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;margin-bottom:1rem;}
.mst{font-weight:700;font-size:.9rem;margin:.8rem 0 .3rem;color:var(--text-primary);}
.mbt{font-size:.84rem;line-height:1.7;color:var(--text-secondary);}
.pdiv{height:1px;background:var(--glass-border);margin:.8rem 0;}

/* ═══════════════════════════════════════════════════════ */
/*  MOBILE RESPONSIVE                                      */
/* ═══════════════════════════════════════════════════════ */
@media(max-width:992px){
  .nav-r{display:none;}
  .nav-mobile-group{display:flex;align-items:center;gap:8px;}
  .hamburger{display:flex;}
  .nav-mobile-avatar{width:34px;height:34px;border-radius:50%;overflow:hidden;border:1.5px solid var(--accent-gold);flex-shrink:0;align-items:center;justify-content:center;}
  .nav-mobile-avatar.visible{display:flex;}
  .nav-mobile-avatar img{width:100%;height:100%;object-fit:cover;}
  .nav-mobile-signin{display:flex;align-items:center;gap:5px;padding:6px 12px;border-radius:20px;border:1px solid rgba(201,168,76,.3);background:transparent;color:var(--accent-gold);font-size:.72rem;font-weight:600;font-family:var(--font-body);cursor:pointer;white-space:nowrap;transition:all .25s;}
  .nav-mobile-signin.hidden{display:none;}
  .nav-mobile-signin svg{width:14px;height:14px;flex-shrink:0;}
  .mobile-drawer{display:flex;flex-direction:column;gap:.6rem;position:fixed;top:0;right:0;width:min(86vw,320px);height:100vh;height:100dvh;z-index:1001;background:var(--glass-bg);border-left:1px solid var(--glass-border);backdrop-filter:blur(28px);-webkit-backdrop-filter:blur(28px);transform:translateX(100%);transition:transform .4s var(--ease);padding:5rem 1.5rem 2rem;}
  .mobile-drawer.open{transform:translateX(0);}
  .drawer-backdrop{display:block;position:fixed;inset:0;z-index:1000;background:rgba(0,0,0,.5);backdrop-filter:blur(4px);opacity:0;pointer-events:none;transition:opacity .35s var(--ease);}
  .drawer-backdrop.open{opacity:1;pointer-events:auto;}
  .drawer-close{position:absolute;top:1rem;right:1rem;width:40px;height:40px;border-radius:12px;border:1px solid var(--glass-border);background:transparent;color:var(--text-primary);font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s;}
  .drawer-close:active{border-color:var(--error);color:var(--error);}
  .drawer-pill{display:flex;align-items:center;gap:10px;padding:.85rem 1rem;border-radius:14px;font-size:.92rem;font-weight:600;color:var(--text-primary);background:transparent;border:1px solid var(--glass-border);transition:all .25s;cursor:pointer;font-family:var(--font-body);text-decoration:none;width:100%;}
  .drawer-pill:active{border-color:var(--accent-gold);color:var(--accent-gold);background:rgba(201,168,76,.04);}
  .drawer-active{border-color:var(--accent-gold);color:var(--accent-gold);background:rgba(201,168,76,.06);}
  .drawer-pill i{width:20px;text-align:center;color:var(--accent-gold);}
}

@media(max-width:860px){
  .sidebar{display:none;}
  .main-panel{margin-left:0;padding:1.2rem 1rem 6.5rem;}
  .kpi-grid{grid-template-columns:1fr 1fr;}
  .profile-grid{grid-template-columns:1fr;}
  .welcome-banner{flex-direction:column;align-items:flex-start;}
  .quick-actions{flex-direction:column;}
  .qa-btn{justify-content:center;}
  .admin-kpi-row{grid-template-columns:repeat(3,1fr);}
  .admin-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;}
  .admin-table{font-size:.72rem;}
  .admin-table th,.admin-table td{padding:.5rem .6rem;}

  /* Mobile bottom tab bar */
  .mobile-tabs{display:flex!important;position:fixed;bottom:0;left:0;right:0;z-index:100;background:var(--glass-bg);border-top:1px solid var(--glass-border);backdrop-filter:blur(22px);-webkit-backdrop-filter:blur(22px);padding:.5rem .8rem calc(.5rem + env(safe-area-inset-bottom));gap:.3rem;}
  .mtab{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:.55rem .3rem;border-radius:12px;font-size:.62rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--text-secondary);background:transparent;border:none;cursor:pointer;transition:all .25s;font-family:var(--font-body);}
  .mtab i{font-size:1rem;transition:transform .25s;}
  .mtab.active{color:var(--accent-gold);}
  .mtab.active i{transform:scale(1.15);}
  .mtab{position:relative;}
  .mtab-badge{position:absolute;top:5px;right:9px;min-width:17px;height:17px;padding:0 5px;border-radius:999px;background:var(--accent-rose);color:#fff;font-size:.58rem;font-weight:800;display:none;align-items:center;justify-content:center;line-height:1;box-shadow:0 0 0 2px rgba(10,10,8,.4);}
  .mtab-badge.visible{display:inline-flex;}

  /* Chat mobile */
  .chat-shell{grid-template-columns:1fr;height:calc(100vh - 190px);height:calc(100dvh - 190px);}
  .chat-resize-handle{display:none;}
  .chat-list{display:flex;}
  .chat-list.hidden{display:none;}
  .chat-thread{display:none;}
  .chat-thread.visible{display:flex;}
  .chat-thread-header .back-btn{display:flex;}
  .chat-composer{padding-bottom:calc(.85rem + env(safe-area-inset-bottom));}
  .chat-scroll-fab{right:.8rem;bottom:6.3rem;}

  .bookings-grid{grid-template-columns:1fr;}

  /* Perf: reduce blur on mobile */
  nav{backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);}
  .mobile-tabs{backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);}

  /* Touch feedback */
  .qa-btn:active,.mtab:active{transform:scale(.96);transition:transform .08s;}
}

/* Mobile tabs — hidden on desktop */
.mobile-tabs{display:none;}

/* ── 374px — iPhone SE and small Androids ── */
@media(max-width:374px){
  .main-panel{padding:1rem .8rem 6.5rem;}
  .kpi-grid{grid-template-columns:1fr;}
  .admin-kpi-row{grid-template-columns:repeat(2,1fr);}
  .welcome-banner h2{font-size:1.2rem;}
  .kpi-card{padding:1rem .8rem;}
  .kpi-value{font-size:1.6rem;}
  .mtab{font-size:.55rem;padding:.45rem .2rem;}
  .mtab i{font-size:.9rem;}
  .chat-composer input{font-size:1rem;} /* prevent iOS zoom */
}

/* ── Count-up animation ── */
@keyframes countPulse{0%{transform:scale(1)}50%{transform:scale(1.05)}100%{transform:scale(1)}}
.count-done{animation:countPulse .35s var(--spring);}
@keyframes typingDots{0%,80%,100%{transform:translateY(0);opacity:.35;}40%{transform:translateY(-3px);opacity:1;}}
@keyframes sentPop{0%{transform:scale(.98);}100%{transform:scale(1);}}

@media (prefers-reduced-motion: reduce){
  .chat-typing-indicator span,.chat-bubble-wrap.sent-pop,.chat-scroll-fab,.chat-pull-indicator{animation:none!important;transition:none!important;}
  .count-done{animation:none!important;}
  .particle{display:none!important;}
}
