@import "https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700;800&family=Inter:wght@400;500;600&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--green-900:#022c22;--green-800:#064e3b;--green-700:#047857;--green-600:#059669;--green-500:#10b981;--green-400:#34d399;--green-100:#d1fae5;--green-50:#ecfdf5;--bg:#f8fafc;--surface:#fff;--surface2:#f1f5f9;--border:#e2e8f0cc;--text:#0f172a;--text-2:#475569;--text-3:#94a3b8;--danger:#ef4444;--warning:#f59e0b;--info:#3b82f6;--success:#10b981;--shadow-sm:0 1px 2px 0 #0000000d;--shadow:0 4px 6px -1px #0000000d, 0 2px 4px -1px #00000008;--shadow-lg:0 20px 25px -5px #0000000d, 0 10px 10px -5px #00000005;--radius:16px;--radius-sm:10px;--sidebar-w:260px;--header-h:72px;--sidebar-bg:#0f172a}[data-theme=dark]{--bg:#020617;--surface:#0f172a;--surface2:#1e293b;--border:#33415580;--text:#f8fafc;--text-2:#cbd5e1;--text-3:#64748b;--shadow-sm:0 1px 2px 0 #0000004d;--shadow:0 4px 6px -1px #0006, 0 2px 4px -1px #0003;--shadow-lg:0 20px 25px -5px #00000080, 0 10px 10px -5px #0000004d;--sidebar-bg:#020617}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font-family:Poppins,sans-serif;font-size:14px;line-height:1.6}h1,h2,h3,h4,h5,h6,.topbar-title,.card-title,.stat-info h2,.nav-section-title,.mobile-logo .logo-text,.custom-calendar-header .month-label{font-family:Poppins,sans-serif}.input-like{background:var(--bg);border:1px solid var(--border);width:100%;color:var(--text);border-radius:10px;align-items:center;min-height:42px;padding:10px 16px;font-size:14px;display:flex}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#00000014;border-radius:10px;transition:background .2s}::-webkit-scrollbar-thumb:hover{background:#00000026}*{scrollbar-width:thin;scrollbar-color:#00000014 transparent}.drag-overlay-container{width:calc(100vw - var(--sidebar-w) - 96px);max-width:1408px}.drag-overlay-table{table-layout:fixed;background:var(--surface);border-collapse:collapse;width:100%;box-shadow:0 20px 40px #00000026, 0 0 0 1px var(--border);pointer-events:none;z-index:9999;border-radius:12px}.drag-overlay-table tr{background:var(--surface)}.drag-overlay-table td{text-overflow:ellipsis;white-space:nowrap;vertical-align:middle;padding:16px 20px;overflow:hidden;border-bottom:none!important}.drag-overlay-table td:first-child{width:44px;padding-left:12px;padding-right:0}.layout{min-height:100vh;display:flex}.sidebar-container{width:var(--sidebar-w);flex-shrink:0;transition:width .4s cubic-bezier(.22,.68,0,1.04)}.sidebar{width:var(--sidebar-w);background:var(--sidebar-bg);z-index:100;border-right:1px solid #ffffff0a;flex-direction:column;transition:width .4s cubic-bezier(.22,.68,0,1.04);display:flex;position:fixed;top:0;bottom:0;left:0;overflow:hidden;box-shadow:4px 0 30px #00000014}@media (width<=1024px){.sidebar-container{z-index:200;width:280px;position:fixed;top:0;bottom:0;left:0;transform:translate(-100%)}.sidebar-container.open{transform:translate(0)}.sidebar{width:100%}.sidebar-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:190;background:#0006;animation:.2s fadeIn;position:fixed;inset:0}}.sidebar[data-sidebar=user]{background:linear-gradient(#1e293b 0%,#0f172a 100%)!important}.sidebar-logo{background:#ffffff05;padding:28px 24px 20px;transition:padding .4s cubic-bezier(.22,.68,0,1.04);position:relative}.sidebar-logo-content{min-width:0;max-width:100%;padding-right:40px;transition:opacity .3s cubic-bezier(.4,0,.2,1) 50ms,transform .35s cubic-bezier(.22,.68,0,1.04) 50ms,max-height .35s cubic-bezier(.22,.68,0,1.04)}.sidebar-collapse-btn{-webkit-backdrop-filter:blur(8px);color:#94a3b8;cursor:pointer;background:#ffffff0f;border:1px solid #ffffff1a;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:18px;transition:all .3s cubic-bezier(.22,.68,0,1.04);display:none;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.sidebar-collapse-btn svg{transition:transform .4s cubic-bezier(.22,.68,0,1.04)}.sidebar-collapse-btn:hover{color:#34d399;background:#10b98126;border-color:#10b9814d;transform:translateY(-50%)scale(1.1);box-shadow:0 0 20px #10b98126}.sidebar-collapse-btn:active{transform:translateY(-50%)scale(.92)}.sidebar-logo h1{letter-spacing:-.02em;background:linear-gradient(135deg,#6ee7b7 0%,#10b981 50%,#047857 100%);-webkit-text-fill-color:transparent;text-shadow:0 4px 12px #10b98126;-webkit-background-clip:text;background-clip:text;align-items:center;gap:8px;font-size:19px;font-weight:800;display:flex}.mg-badge{background:linear-gradient(135deg,#059669 0%,#022c22 100%);-webkit-text-fill-color:#fff;color:#fff;text-shadow:none;letter-spacing:.05em;-webkit-background-clip:padding-box;background-clip:padding-box;border-radius:4px;justify-content:center;align-items:center;margin-right:4px;padding:2px 6px;font-size:10px;font-weight:700;line-height:1;display:inline-flex;transform:translateY(-1px);box-shadow:0 2px 8px #0003,inset 0 1px 1px #fff3}.sidebar-logo span{filter:drop-shadow(0 2px 4px #0003);font-size:24px}.sidebar-logo p{color:var(--green-400);margin-top:4px;font-family:Inter,sans-serif;font-size:12px;font-weight:500}.nav-label{white-space:nowrap;transition:opacity .25s cubic-bezier(.4,0,.2,1) 80ms,transform .3s cubic-bezier(.22,.68,0,1.04) 80ms,max-width .35s cubic-bezier(.22,.68,0,1.04)}.logout-text{white-space:nowrap;transition:opacity .25s cubic-bezier(.4,0,.2,1) .12s,transform .3s cubic-bezier(.22,.68,0,1.04) .12s,max-width .35s cubic-bezier(.22,.68,0,1.04)}.sidebar-user-info{transition:opacity .25s cubic-bezier(.4,0,.2,1) .1s,transform .3s cubic-bezier(.22,.68,0,1.04) .1s,max-width .35s cubic-bezier(.22,.68,0,1.04)}.nav-section-title{transition:opacity .2s cubic-bezier(.4,0,.2,1),transform .25s cubic-bezier(.22,.68,0,1.04),max-width .3s cubic-bezier(.22,.68,0,1.04),height .3s cubic-bezier(.22,.68,0,1.04),padding .3s cubic-bezier(.22,.68,0,1.04),margin .3s cubic-bezier(.22,.68,0,1.04)}.sidebar-nav{flex:1;padding:20px 16px;transition:padding .4s cubic-bezier(.22,.68,0,1.04);overflow:hidden auto}.nav-section-title{color:#64748b;letter-spacing:.08em;text-transform:uppercase;padding:16px 12px 8px;font-family:Outfit,sans-serif;font-size:11px;font-weight:600}.nav-item{color:#94a3b8;cursor:pointer;border-radius:12px;align-items:center;gap:12px;margin-bottom:4px;padding:11px 14px;font-size:14px;font-weight:500;text-decoration:none;transition:all .25s cubic-bezier(.22,.68,0,1.04);display:flex;position:relative}.nav-item:hover{color:#f8fafc;background:#ffffff0d;transform:translate(2px)}.nav-item.active{color:#10b981;background:linear-gradient(90deg,#10b98126 0%,#10b9810d 100%);border-left:3px solid #10b981;font-weight:600;box-shadow:0 0 20px #10b9810f}.nav-item svg{flex-shrink:0;width:20px;height:20px;transition:transform .3s cubic-bezier(.22,.68,0,1.04)}.nav-badge{background:var(--green-500);color:#fff;border-radius:99px;margin-left:auto;padding:2px 8px;font-size:11px;font-weight:700;box-shadow:0 2px 4px #10b98133}.sidebar-footer{background:#0000001a;border-top:1px solid #ffffff0d;padding:20px 24px;transition:padding .4s cubic-bezier(.22,.68,0,1.04)}.sidebar-user{align-items:center;gap:12px;transition:justify-content .3s;display:flex}.sidebar-avatar{background:linear-gradient(135deg, var(--green-500), var(--green-700));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:16px;font-weight:700;transition:transform .3s cubic-bezier(.22,.68,0,1.04);display:flex;box-shadow:0 2px 8px #10b9814d}.sidebar-avatar:hover{transform:scale(1.08)}.sidebar-user-info p{color:#f8fafc;font-family:Poppins,sans-serif;font-size:14px;font-weight:600}.sidebar-user-info span{color:#94a3b8;font-size:12px}.logout-btn{color:#cbd5e1;border-radius:var(--radius-sm);cursor:pointer;background:#ffffff0d;border:1px solid #ffffff1a;justify-content:center;align-items:center;gap:8px;width:100%;margin-top:16px;padding:10px;font-family:inherit;font-size:13px;font-weight:500;transition:all .3s cubic-bezier(.22,.68,0,1.04);display:flex}.logout-btn:hover{color:#f87171;background:#ef44441f;border-color:#ef444440;box-shadow:0 0 20px #ef444414}@media (width>=1025px){.sidebar-collapse-btn{display:inline-flex}.desktop-sidebar-collapsed .sidebar-container,.desktop-sidebar-collapsed .sidebar{width:78px}.desktop-sidebar-collapsed .sidebar-logo{min-height:64px;padding:18px 0 14px}.desktop-sidebar-collapsed .sidebar-logo-content{opacity:0;pointer-events:none;max-height:0;padding-right:0;position:absolute;overflow:hidden;transform:translate(-10px)scale(.95)}.desktop-sidebar-collapsed .sidebar-collapse-btn{color:#34d399;background:#10b98114;border-color:#10b98126;border-radius:10px;width:36px;height:36px;position:absolute;top:50%;left:50%;right:auto;transform:translate(-50%,-50%)}.desktop-sidebar-collapsed .sidebar-collapse-btn:hover{background:#10b9812e;transform:translate(-50%,-50%)scale(1.12);box-shadow:0 0 24px #10b98133}.desktop-sidebar-collapsed .sidebar-collapse-btn:active{transform:translate(-50%,-50%)scale(.9)}.desktop-sidebar-collapsed .sidebar-nav{padding:10px 0}.desktop-sidebar-collapsed .nav-item{border-radius:14px;justify-content:center;gap:0;width:56px;min-height:42px;margin:0 auto 8px;padding:0}.desktop-sidebar-collapsed .nav-item svg{margin:0;transform:scale(1.08)}.desktop-sidebar-collapsed .nav-item{position:relative}.desktop-sidebar-collapsed .nav-item:after{content:attr(title);color:#f1f5f9;white-space:nowrap;pointer-events:none;opacity:0;z-index:999;letter-spacing:.01em;background:#1e293b;border-radius:8px;padding:6px 14px;font-size:13px;font-weight:500;transition:opacity .2s .15s,transform .25s cubic-bezier(.22,.68,0,1.04) .15s;position:absolute;top:50%;left:calc(100% + 12px);transform:translateY(-50%)translate(-6px);box-shadow:0 4px 16px #00000040,0 0 0 1px #ffffff0f}.desktop-sidebar-collapsed .nav-item:hover:after{opacity:1;transform:translateY(-50%)translate(0)}.desktop-sidebar-collapsed .nav-item.active{background:#10b9811f;border-left:none;box-shadow:inset 0 0 0 1px #10b98133,0 0 16px #10b98114}.desktop-sidebar-collapsed .nav-item.active svg{filter:drop-shadow(0 0 6px #10b98166)}.desktop-sidebar-collapsed .sidebar-footer{padding:14px 0 18px}.desktop-sidebar-collapsed .sidebar-user{justify-content:center}.desktop-sidebar-collapsed .sidebar-avatar{width:36px;height:36px;font-size:14px}.desktop-sidebar-collapsed .sidebar-user-info,.desktop-sidebar-collapsed .nav-label,.desktop-sidebar-collapsed .logout-text,.desktop-sidebar-collapsed .nav-section-title{opacity:0;white-space:nowrap;pointer-events:none;max-width:0;overflow:hidden;transform:translate(-8px)}.desktop-sidebar-collapsed .nav-section-title{height:0;min-height:0;margin:0;padding:0}.desktop-sidebar-collapsed .logout-btn{border-radius:14px;width:56px;min-height:42px;margin:12px auto 0;padding:0;position:relative}.desktop-sidebar-collapsed .logout-btn:after{content:"Sign Out";color:#f1f5f9;white-space:nowrap;pointer-events:none;opacity:0;z-index:999;background:#1e293b;border-radius:8px;padding:6px 14px;font-size:13px;font-weight:500;transition:opacity .2s .15s,transform .25s cubic-bezier(.22,.68,0,1.04) .15s;position:absolute;top:50%;left:calc(100% + 12px);transform:translateY(-50%)translate(-6px);box-shadow:0 4px 16px #00000040,0 0 0 1px #ffffff0f}.desktop-sidebar-collapsed .logout-btn:hover:after{opacity:1;transform:translateY(-50%)translate(0)}}.main{background:var(--bg);flex-direction:column;flex:1;min-width:0;height:100vh;display:flex;overflow:hidden auto}.main-content-scroll{flex-direction:column;flex:1;display:flex}.mobile-header{background:var(--surface);border-bottom:1px solid var(--border);z-index:50;align-items:center;gap:16px;height:64px;padding:0 24px;display:none;position:sticky;top:0}.menu-toggle{background:var(--surface2);border:1px solid var(--border);cursor:pointer;width:40px;height:40px;color:var(--text);border-radius:10px;justify-content:center;align-items:center;font-size:24px;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex}.menu-toggle:hover{background:var(--border)}.mobile-logo{align-items:center;gap:10px;display:flex}.mobile-logo .logo-text{letter-spacing:-.02em;background:linear-gradient(135deg,#10b981 0%,#047857 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-family:Poppins,sans-serif;font-size:18px;font-weight:700}@media (width<=1024px){.mobile-header{background:var(--surface);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border);z-index:100;justify-content:space-between;align-items:center;height:56px;padding:0 16px;display:flex;position:sticky;top:0}.mobile-header-title{color:var(--text);white-space:nowrap;text-overflow:ellipsis;max-width:60%;font-family:Poppins,sans-serif;font-size:16px;font-weight:600;position:absolute;left:50%;overflow:hidden;transform:translate(-50%)}.menu-toggle{width:36px;height:36px;color:var(--text);background:0 0;border:none;border-radius:50%;font-size:24px}.theme-toggle-mobile{width:36px;height:36px;color:var(--text);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:20px;display:flex}.topbar{display:none!important}.content{padding:16px}.main{margin-left:0}.content>div:first-child:not(.page-toolbar):not(.card){display:none}.card{border:1px solid var(--border);border-radius:16px;margin-bottom:20px}.card-header{flex-direction:column;align-items:flex-start;gap:8px;padding:16px 20px}.card-body{padding:20px}.pagination{text-align:center;flex-direction:column;gap:16px;padding:20px}.page-toolbar{flex-direction:column;align-items:stretch;gap:16px;margin-bottom:24px}.page-toolbar-left{flex-direction:column;align-items:stretch;gap:12px}.page-toolbar-left .custom-select-container{width:100%!important}.page-toolbar-left .custom-select-trigger{height:44px;width:100%!important}.search-input-wrap{width:100%}.search-input-wrap input{width:100%;height:44px;font-size:14px}.btn{justify-content:center;width:100%;height:46px;font-size:15px}.stats-grid{gap:16px;margin-bottom:24px}.stat-card{gap:16px;padding:20px}.stat-icon{width:48px;height:48px;font-size:22px}.stat-info h2{font-size:28px}table{min-width:900px}th,td{padding:14px 18px;font-size:14px}td .badge{white-space:nowrap;display:inline-flex}td>div{flex-direction:column;gap:4px;display:flex}td div{white-space:normal}}.topbar{height:var(--header-h);background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:20px;padding:0 40px;display:flex;box-shadow:0 1px 3px #00000005}.theme-toggle{border:1px solid var(--border);background:var(--surface2);width:40px;height:40px;color:var(--text);cursor:pointer;border-radius:12px;justify-content:center;align-items:center;font-size:20px;transition:all .2s;display:flex}.theme-toggle:hover{background:var(--border);transform:scale(1.05)}.topbar-title{color:var(--text);letter-spacing:-.02em;font-size:24px;font-weight:700}.topbar-sub{color:var(--text-2);margin-top:4px;font-size:14px;font-weight:400}.topbar-right{align-items:center;gap:16px;margin-left:auto;display:flex}.content{flex:1;width:100%;max-width:1600px;margin:0 auto;padding:40px}.card{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);transition:all .35s cubic-bezier(.22,.68,0,1.04);position:relative;overflow:hidden;box-shadow:0 1px 3px #0000000a,0 4px 12px #00000008}.card:before{content:"";opacity:0;pointer-events:none;z-index:0;background:radial-gradient(at 0 0,#10b98108 0%,#0000 60%);width:100%;height:100%;transition:opacity .4s;position:absolute;top:0;left:0}.card:hover{border-color:#10b9811f;box-shadow:0 8px 32px #0000000f,0 2px 8px #0000000a}.card:hover:before{opacity:1}.card-body{z-index:1;padding:32px;position:relative}.card-header{border-bottom:1px solid var(--border);background:var(--surface);z-index:1;justify-content:space-between;align-items:center;padding:24px 32px;display:flex;position:relative}.card-title{color:var(--text);letter-spacing:-.01em;font-size:18px;font-weight:700}.stats-grid{grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:32px;display:grid}@media (width<=1280px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=640px){.stats-grid{grid-template-columns:1fr;gap:16px}}.stat-card{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);align-items:flex-start;gap:18px;padding:24px 24px 22px;transition:all .35s cubic-bezier(.22,.68,0,1.04);display:flex;position:relative;overflow:hidden;box-shadow:0 1px 3px #0000000a,0 4px 12px #00000008}.stat-card:before{content:"";border-radius:3px 3px 0 0;height:3px;transition:height .3s;position:absolute;top:0;left:0;right:0}.stat-card:first-child:before{background:linear-gradient(90deg,#10b981,#34d399)}.stat-card:nth-child(2):before{background:linear-gradient(90deg,#3b82f6,#60a5fa)}.stat-card:nth-child(3):before{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.stat-card:nth-child(4):before{background:linear-gradient(90deg,#8b5cf6,#a78bfa)}.stat-card:after{content:"";opacity:0;pointer-events:none;border-radius:50%;width:120px;height:120px;transition:opacity .4s;position:absolute;top:-40px;right:-40px}.stat-card:first-child:after{background:radial-gradient(circle,#10b98114 0%,#0000 70%)}.stat-card:nth-child(2):after{background:radial-gradient(circle,#3b82f614 0%,#0000 70%)}.stat-card:nth-child(3):after{background:radial-gradient(circle,#f59e0b14 0%,#0000 70%)}.stat-card:nth-child(4):after{background:radial-gradient(circle,#8b5cf614 0%,#0000 70%)}.stat-card:hover{transform:translateY(-3px);box-shadow:0 12px 36px #00000014,0 2px 8px #0000000a}.stat-card:hover:after{opacity:1}.stat-card:hover:before{height:4px}.stat-icon{z-index:1;border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;font-size:24px;display:flex;position:relative}.stat-icon.green{color:#059669;background:linear-gradient(135deg,#d1fae5,#a7f3d0);box-shadow:0 4px 12px #10b9811f}.stat-icon.blue{color:#2563eb;background:linear-gradient(135deg,#dbeafe,#bfdbfe);box-shadow:0 4px 12px #3b82f61f}.stat-icon.orange{color:#ea580c;background:linear-gradient(135deg,#ffedd5,#fed7aa);box-shadow:0 4px 12px #f59e0b1f}.stat-icon.purple{color:#7e22ce;background:linear-gradient(135deg,#f3e8ff,#e9d5ff);box-shadow:0 4px 12px #8b5cf61f}[data-theme=dark] .stat-icon.green{color:#34d399;background:linear-gradient(135deg,#10b9812e,#10b98114);box-shadow:0 4px 16px #10b9811a}[data-theme=dark] .stat-icon.blue{color:#60a5fa;background:linear-gradient(135deg,#3b82f62e,#3b82f614);box-shadow:0 4px 16px #3b82f61a}[data-theme=dark] .stat-icon.orange{color:#fbbf24;background:linear-gradient(135deg,#f59e0b2e,#f59e0b14);box-shadow:0 4px 16px #f59e0b1a}[data-theme=dark] .stat-icon.purple{color:#a78bfa;background:linear-gradient(135deg,#8b5cf62e,#8b5cf614);box-shadow:0 4px 16px #8b5cf61a}.stat-info{z-index:1;flex:1;min-width:0;position:relative}.stat-info p{color:var(--text-3);text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px;font-size:13px;font-weight:500}.stat-info h2{color:var(--text);letter-spacing:-.03em;margin-bottom:10px;font-size:30px;font-weight:800;line-height:1}.stat-trend-row{align-items:center;gap:6px;display:flex}.stat-trend{border-radius:6px;align-items:center;gap:3px;padding:3px 8px;font-size:12px;font-weight:600;display:inline-flex}.stat-trend.trend-up{color:#059669;background:#10b9811a}.stat-trend.trend-down{color:#ef4444;background:#ef44441a}[data-theme=dark] .stat-trend.trend-up{color:#34d399;background:#10b98126}[data-theme=dark] .stat-trend.trend-down{color:#f87171;background:#ef444426}.stat-trend-sub{color:var(--text-3);font-size:12px}.charts-grid{grid-template-columns:1.6fr 1fr;gap:24px;margin-bottom:32px;display:grid}@media (width<=1024px){.charts-grid{grid-template-columns:1fr}}.dashboard-chart-card .card-header{flex-wrap:wrap;gap:12px}.card-subtitle{color:var(--text-3);margin-top:2px;font-size:13px;font-weight:400;display:block}.chart-header-value{text-align:right}.chart-total{color:var(--text);letter-spacing:-.02em;font-size:22px;font-weight:700;display:block}.chart-trend{align-items:center;gap:4px;margin-top:2px;font-size:13px;font-weight:600;display:inline-flex}.chart-trend.trend-up{color:#10b981}.chart-trend.trend-down{color:#ef4444}.chart-tooltip{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:10px 16px;box-shadow:0 8px 24px #0000001f}.chart-tooltip-label{color:var(--text-3);margin-bottom:4px;font-size:12px;font-weight:500}.chart-tooltip-value{font-size:16px;font-weight:700}.popular-courses-body{flex-direction:column;gap:0;display:flex;padding:16px 24px!important}.popular-course-item{border-bottom:1px solid var(--border);align-items:center;gap:14px;padding:14px 0;transition:all .2s;display:flex}.popular-course-item:last-child{border-bottom:none}.popular-course-item:hover{background:var(--surface2);border-color:#0000;border-radius:10px;margin:0 -24px;padding:14px 24px}.popular-course-rank{background:var(--surface2);width:32px;height:32px;color:var(--text-3);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;font-size:13px;font-weight:700;display:flex}.popular-course-item:first-child .popular-course-rank{color:#fff;background:linear-gradient(135deg,#fbbf24,#f59e0b)}.popular-course-info{flex:1;min-width:0}.popular-course-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;margin-bottom:2px;font-size:14px;font-weight:600;overflow:hidden}.popular-course-bookings{color:var(--text-3);font-size:12px}.popular-course-stats{text-align:right;flex-shrink:0}.popular-course-revenue{color:var(--text);margin-bottom:2px;font-size:14px;font-weight:700}.popular-course-trend{align-items:center;gap:2px;font-size:12px;font-weight:600;display:inline-flex}.popular-course-trend.trend-up{color:#10b981}.popular-course-trend.trend-down{color:#ef4444}.receipt-code{background:var(--surface2);color:var(--text-2);border:1px solid var(--border);border-radius:6px;padding:4px 8px;font-family:SF Mono,Fira Code,monospace;font-size:12px}.table-user{align-items:center;gap:10px;display:flex}.table-user-avatar{background:linear-gradient(135deg, var(--green-500), var(--green-700));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:13px;font-weight:700;display:flex}.table-date{color:var(--text-2);align-items:center;gap:6px;display:flex}.table-amount{color:var(--text);font-size:14px;font-weight:700}.table-wrap{border-radius:0 0 var(--radius) var(--radius);-webkit-overflow-scrolling:touch;background:var(--surface);overflow-x:auto}.rt-desktop{display:block}.rt-mobile{display:none}.rt-cards{flex-direction:column;gap:12px;padding:12px;display:flex}.rt-card{background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-sm);border-radius:16px;overflow:hidden}.rt-card-header{border-bottom:1px solid var(--border);background:var(--surface2);justify-content:space-between;align-items:flex-start;gap:12px;padding:14px 14px 10px;display:flex}.rt-card-title{color:var(--text);font-size:14px;font-weight:700;line-height:1.3}.rt-card-sub{color:var(--text-3);margin-top:4px;font-size:12px;line-height:1.35}.rt-card-meta{flex-shrink:0}.rt-card-body{flex-direction:column;gap:10px;padding:12px 14px;display:flex}.rt-row{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.rt-k{width:40%;color:var(--text-3);text-transform:uppercase;letter-spacing:.04em;font-size:12px;font-weight:700}.rt-v{text-align:right;width:60%;color:var(--text);font-size:13px;font-weight:600}.rt-card-actions{border-top:1px solid var(--border);background:var(--surface2);justify-content:flex-end;gap:10px;padding:12px 14px 14px;display:flex}table{border-collapse:collapse;width:100%;min-width:800px}@media (width<=1024px){.table-wrap{border-left:none;border-right:none;border-radius:0;width:100%}th,td{padding:12px 16px;font-size:13px}.rt-desktop{display:none}.rt-mobile{display:block}}thead tr{background:var(--surface2)}th{text-align:center;color:var(--text-2);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border);white-space:nowrap;padding:14px 20px;font-size:12px;font-weight:600}td{border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle;text-align:center;padding:16px 20px;font-size:14px}th:first-child,td:first-child,th:nth-child(2),td:nth-child(2){text-align:left}th:last-child,td:last-child{text-align:center}th:has(.badge){text-align:center}td:has(.badge){text-align:center}tr:last-child td{border-bottom:none}tbody tr{transition:background .15s}tbody tr:hover{background:var(--surface2)}.custom-select-container{width:auto;position:relative}.custom-select-trigger{background:var(--surface);border:1px solid var(--border);cursor:pointer;-webkit-user-select:none;user-select:none;text-align:center;border-radius:12px;justify-content:center;align-items:center;gap:12px;min-height:42px;padding:10px 16px;font-size:13px;font-weight:500;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex}.custom-select-trigger span{text-align:center;flex:1}.custom-select-trigger:hover{border-color:var(--green-500);background:var(--bg)}.custom-select-trigger.open{border-color:var(--green-500);background:var(--surface);box-shadow:0 0 0 4px #10b9811a}.custom-select-trigger .arrow{color:var(--text-3);flex-shrink:0;font-size:20px;transition:transform .3s}.custom-select-trigger.open .arrow{color:var(--green-600);transform:rotate(180deg)}.custom-select-options{border:1px solid var(--border);box-shadow:var(--shadow-lg);z-index:1000;border-radius:14px;flex-direction:column;width:max-content;min-width:100%;padding:6px;animation:.2s cubic-bezier(.16,1,.3,1) forwards selectSlideUp;display:flex;position:absolute;top:calc(100% + 6px);left:50%;overflow:hidden;transform:translate(-50%);background:var(--surface)!important}.custom-select-options.direction-up{animation:.2s cubic-bezier(.16,1,.3,1) forwards selectSlideDown;top:auto;bottom:calc(100% + 6px)}.custom-select-option{cursor:pointer;text-align:center;border-radius:8px;justify-content:center;align-items:center;gap:8px;padding:10px 16px;font-size:13px;transition:all .15s;display:flex;color:var(--text-2)!important;background:0 0!important}.custom-select-option:hover{background:var(--bg)!important;color:var(--green-600)!important}.custom-select-option.selected{font-weight:600;background:var(--green-600)!important;color:#fff!important}@keyframes selectSlideUp{0%{opacity:0;transform:translate(-50%)translateY(10px)}to{opacity:1;transform:translate(-50%)translateY(0)}}@keyframes selectSlideDown{0%{opacity:0;transform:translate(-50%)translateY(-10px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.custom-select-container.badge{min-width:110px;background:0 0!important;border:none!important;padding:0!important}.custom-select-container.badge .custom-select-trigger{border:1px solid #0000;border-radius:99px;justify-content:center;gap:6px;min-height:28px;padding:4px 12px;font-size:12px;font-weight:600;display:flex}.custom-select-container.badge .custom-select-trigger span{flex:none}.custom-select-container.badge .custom-select-trigger .arrow{font-size:16px}.custom-select-container.badge .custom-select-options{border-radius:12px;min-width:120px}.custom-select-container.badge-green .custom-select-trigger{color:#065f46;background:#d1fae5;border-color:#a7f3d0}.custom-select-container.badge-yellow .custom-select-trigger{color:#92400e;background:#fef3c7;border-color:#fde68a}.custom-select-container.badge-red .custom-select-trigger{color:#991b1b;background:#fee2e2;border-color:#fecaca}.custom-select-container.badge-blue .custom-select-trigger{color:#1e40af;background:#dbeafe;border-color:#bfdbfe}.pagination{border-top:1px solid var(--border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding:16px 24px;display:flex}.pagination-info{color:var(--text-3);font-size:13px}.pagination-pages{gap:6px;display:flex}.page-btn{border:1px solid var(--border);background:var(--surface);min-width:36px;height:36px;color:var(--text-2);cursor:pointer;box-shadow:var(--shadow-sm);border-radius:10px;justify-content:center;align-items:center;font-size:14px;font-weight:600;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex}.page-btn:hover{border-color:var(--green-500);color:var(--green-600);background:var(--bg);transform:translateY(-1px)}.page-btn.active{background:var(--green-600);color:#fff;border-color:var(--green-600);box-shadow:0 4px 12px #10b98133}.pagination-per-page{align-items:center;gap:8px;display:flex}.pagination-per-page select{border-radius:8px;width:auto;min-width:110px;font-size:13px;font-weight:600;padding:6px 32px 6px 12px!important}.badge{letter-spacing:.02em;border-radius:99px;align-items:center;gap:6px;padding:4px 12px;font-size:12px;font-weight:600;display:inline-flex}select.badge{background-position:right 8px center;background-size:12px;border:1px solid #0000;width:auto;padding:4px 28px 4px 12px!important}select.badge:hover{background-color:#00000008;border-color:#0000001a}.badge-green{color:#065f46;background:#d1fae5;border:1px solid #a7f3d0}.badge-red{color:#991b1b;background:#fee2e2;border:1px solid #fecaca}.badge-yellow{color:#92400e;background:#fef3c7;border:1px solid #fde68a}.badge-blue{color:#1e40af;background:#dbeafe;border:1px solid #bfdbfe}.badge-orange{color:#9a3412;background:#ffedd5;border:1px solid #fed7aa}.badge-purple{color:#6b21a8;background:#f3e8ff;border:1px solid #e9d5ff}.badge-gray{color:#64748b;background:#f1f5f9;border:1px solid #e2e8f0}.badge-outline{color:var(--text-3);border:1px solid var(--border);background:0 0;font-weight:500}.badge-premium{color:#92400e;background:#fffbeb;border:1px solid #fde68a;font-weight:600}.btn{border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;border:1px solid #0000;justify-content:center;align-items:center;gap:8px;padding:10px 20px;font-family:inherit;font-size:14px;font-weight:600;transition:all .2s cubic-bezier(.4,0,.2,1);display:inline-flex}.btn-primary{background:linear-gradient(135deg, var(--green-500), var(--green-600));color:#fff;box-shadow:0 4px 12px #10b98133}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 16px #10b9814d}.btn-primary:active{transform:translateY(1px)}.btn-outline{background:var(--surface);border:1px solid var(--border);color:var(--text-2);box-shadow:var(--shadow-sm)}.btn-outline:hover{border-color:var(--green-500);color:var(--green-600);background:var(--surface2)}.btn-danger{color:#ef4444;background:#fef2f2;border:1px solid #fecaca}.btn-danger:hover{color:#fff;background:#ef4444}.btn-sm{padding:6px 14px;font-size:13px}.btn-icon{background:var(--surface);border:1px solid var(--border);cursor:pointer;color:var(--text-2);border-radius:8px;justify-content:center;align-items:center;padding:8px;transition:all .2s;display:flex}.btn-icon:hover{background:var(--green-50);color:var(--green-600);border-color:var(--green-200);transform:translateY(-1px)}.form-group{margin-bottom:20px}label{color:var(--text-2);margin-bottom:8px;font-size:13px;font-weight:600;display:block}.toggle-switch{width:44px;height:24px;display:inline-block;position:relative}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{cursor:pointer;background-color:#cbd5e1;border-radius:24px;transition:all .3s cubic-bezier(.4,0,.2,1);position:absolute;inset:0}.toggle-slider:before{content:"";background-color:#fff;border-radius:50%;width:18px;height:18px;transition:all .3s cubic-bezier(.4,0,.2,1);position:absolute;bottom:3px;left:3px;box-shadow:0 2px 4px #0000001a}input:checked+.toggle-slider{background-color:var(--green-600)}input:checked+.toggle-slider:before{transform:translate(20px)}.custom-datepicker-container{width:auto;position:relative}.custom-datepicker-input{background:var(--surface);border:1px solid var(--border);cursor:pointer;min-width:160px;min-height:42px;color:var(--text);text-align:center;border-radius:12px;justify-content:space-between;align-items:center;gap:12px;padding:10px 16px;font-size:13px;font-weight:500;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex}.custom-datepicker-input span{text-align:center;flex:1}.custom-datepicker-input:hover{border-color:var(--green-500);background:var(--bg)}.custom-datepicker-input .calendar-icon{color:var(--text-3);flex-shrink:0;font-size:18px}.custom-calendar-popup{background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-lg);z-index:1100;border-radius:16px;width:280px;padding:16px;animation:.2s cubic-bezier(.16,1,.3,1) forwards selectSlideUp;position:absolute;top:calc(100% + 8px);left:50%;transform:translate(-50%)}.custom-calendar-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.custom-calendar-header .nav-btn{border:1px solid var(--border);background:var(--surface);cursor:pointer;width:32px;height:32px;color:var(--text-2);border-radius:10px;justify-content:center;align-items:center;transition:all .2s;display:flex}.custom-calendar-header .nav-btn:hover{background:var(--green-50);border-color:var(--green-200);color:var(--green-600)}.custom-calendar-header .month-label{color:var(--text);font-family:Outfit,sans-serif;font-size:15px;font-weight:700}.custom-calendar-days-row{grid-template-columns:repeat(7,1fr);margin-bottom:8px;display:grid}.custom-calendar-days-row .day-name{text-align:center;color:var(--text-3);text-transform:uppercase;font-size:11px;font-weight:700}.custom-calendar-grid{grid-template-columns:repeat(7,1fr);gap:2px;display:grid}.calendar-cell{cursor:pointer;height:34px;color:var(--text);border-radius:8px;justify-content:center;align-items:center;font-size:13px;transition:all .15s;display:flex}.calendar-cell:hover{background:var(--green-50);color:var(--green-600)}.calendar-cell.disabled{color:var(--text-3);opacity:.3}.calendar-cell.selected{font-weight:700;background:var(--green-600)!important;color:#fff!important}.calendar-cell.today{color:var(--green-600);font-weight:800;text-decoration:underline}.custom-calendar-footer{border-top:1px solid var(--border);gap:8px;margin-top:16px;padding-top:12px;display:flex}.custom-calendar-footer button{cursor:pointer;border-radius:8px;flex:1;padding:8px;font-size:12px;font-weight:600;transition:all .2s}.today-btn{background:var(--green-600);color:#fff;border:none}.today-btn:hover{background:var(--green-700)}.clear-btn{background:var(--surface);color:var(--text-2);border:1px solid var(--border)}.clear-btn:hover{color:#991b1b;background:#fee2e2;border-color:#fecaca}input[type=date]{appearance:none;background-color:var(--surface);border:1px solid var(--border);min-height:42px;color:var(--text);cursor:pointer;border-radius:12px;padding:10px 16px;font-family:inherit;font-size:13px;font-weight:500;transition:all .2s cubic-bezier(.4,0,.2,1);position:relative}input[type=date]::-webkit-calendar-picker-indicator{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%2394a3b8' stroke-width='2'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M8 7V3m8 4V3m-9 8h10M5 21h14a2 2 0 002-2V7a2 2 0 00-2-2H5a2 2 0 00-2 2v12a2 2 0 002 2z'%3E%3C/path%3E%3C/svg%3E");background-repeat:no-repeat;background-size:18px;margin-right:-4px;padding:5px;transition:all .2s}input[type=date]:hover::-webkit-calendar-picker-indicator{filter:brightness(.8)}input[type=date]:focus::-webkit-calendar-picker-indicator{stroke:var(--green-600)}input,select,textarea{border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text);background-color:var(--surface);outline:none;padding:12px 16px;font-family:inherit;font-size:14px;transition:all .2s;box-shadow:0 1px 2px #00000005}select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%2394a3b8'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2.5' d='M19 9l-7 7-7-7'%3E%3C/path%3E%3C/svg%3E");background-position:right 14px center;background-repeat:no-repeat;background-size:16px;padding-right:40px!important}input:hover,select:hover,textarea:hover{border-color:var(--text-3)}input:focus,select:focus,textarea:focus{border-color:var(--green-500);background-color:var(--surface);box-shadow:0 0 0 4px #10b9811a}textarea{resize:vertical;min-height:100px;line-height:1.5}.form-grid{grid-template-columns:1fr 1fr;gap:20px;display:grid}.form-grid-3{grid-template-columns:1fr 1fr 1fr;gap:20px;display:grid}@media (width<=768px){.form-grid,.form-grid-3{grid-template-columns:1fr;gap:16px}}.modal-backdrop{-webkit-backdrop-filter:blur(4px);z-index:200;background:#0f172a99;justify-content:center;align-items:center;padding:24px;animation:.15s ease-out both modalBackdropIn;display:flex;position:fixed;inset:0}.modal{background:var(--surface);will-change:transform, opacity;border-radius:20px;width:100%;max-width:640px;max-height:calc(100vh - 48px);animation:.2s cubic-bezier(.16,1,.3,1) both modalSlideIn;position:relative;overflow-y:auto;box-shadow:0 25px 50px -12px #00000040}@media (width<=640px){.modal{border-radius:16px;max-height:calc(100vh - 32px)}}.modal-header{border-bottom:1px solid var(--border);background:var(--surface2);border-radius:20px 20px 0 0;justify-content:space-between;align-items:center;padding:24px 32px;display:flex}.modal-header h3{color:var(--text);font-size:18px;font-weight:700}.modal-body{padding:32px}.modal-footer{border-top:1px solid var(--border);background:var(--surface2);border-radius:0 0 20px 20px;justify-content:flex-end;gap:12px;padding:20px 32px;display:flex}.page-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:24px;display:flex}.page-toolbar-left{align-items:center;gap:12px;display:flex}.page-toolbar select{border-radius:12px;width:auto;min-width:160px;font-size:13px;font-weight:500;padding:10px 40px 10px 16px!important}.search-input-wrap{position:relative}.search-input-wrap input{border-radius:99px;width:280px;padding-left:40px}.search-icon{color:var(--text-3);font-size:18px;position:absolute;top:50%;left:14px;transform:translateY(-50%)}.filter-select{width:180px}.drag-hint{color:var(--text-3);align-items:center;padding-left:8px;font-size:12px;display:inline-flex}@media (width<=1024px){.filter-select{width:100%!important}.drag-hint{justify-content:center;padding:4px 0}}.toggle{width:44px;height:24px;display:inline-block;position:relative}.toggle input{opacity:0;width:0;height:0}.toggle-slider{cursor:pointer;background:#cbd5e1;border-radius:99px;transition:all .3s;position:absolute;inset:0}.toggle-slider:before{content:"";background:#fff;border-radius:50%;width:18px;height:18px;transition:all .3s cubic-bezier(.4,0,.2,1);position:absolute;top:3px;left:3px;box-shadow:0 1px 2px #0000001a}.toggle input:checked+.toggle-slider{background:var(--green-500)}.toggle input:checked+.toggle-slider:before{transform:translate(20px)}.empty-state{text-align:center;color:var(--text-2);padding:80px 32px}.empty-state .icon{opacity:.5;margin-bottom:16px;font-size:56px}.empty-state h3{color:var(--text);margin-bottom:8px;font-size:18px;font-weight:600}.empty-state p{color:var(--text-3);font-size:14px}.spinner{border:3px solid var(--surface2);border-top-color:var(--green-500);border-radius:50%;width:36px;height:36px;animation:.8s cubic-bezier(.5,0,.5,1) infinite spin}.loading-center{justify-content:center;align-items:center;padding:80px;display:flex}.login-page{background:var(--bg);background-image:radial-gradient(at 0 0,#10b9811a 0,#0000 50%),radial-gradient(at 100% 100%,#2563eb1a 0,#0000 50%);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-card{background:var(--surface);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:24px;width:100%;max-width:440px;padding:48px;animation:.4s cubic-bezier(.16,1,.3,1) slideUp;box-shadow:0 25px 50px -12px #00000080}.login-logo{text-align:center;margin-bottom:36px}.login-logo h1{letter-spacing:-.03em;background:linear-gradient(135deg,#10b981 0%,#047857 100%);-webkit-text-fill-color:transparent;text-shadow:0 4px 16px #10b98133;-webkit-background-clip:text;background-clip:text;margin-bottom:8px;font-size:32px;font-weight:800}.login-logo h1 .mg-badge{border-radius:6px;margin-right:6px;padding:4px 8px;font-size:13px;transform:translateY(-2px)}.login-logo p{color:var(--text-2);font-size:14px}.login-logo .golf-emoji{filter:drop-shadow(0 4px 8px #0000001a);margin-bottom:16px;font-size:48px}.login-btn{background:linear-gradient(135deg, var(--green-500), var(--green-600));color:#fff;cursor:pointer;border:none;border-radius:12px;width:100%;padding:14px;font-family:inherit;font-size:15px;font-weight:700;transition:all .2s;box-shadow:0 4px 12px #10b98133}.login-btn:hover{transform:translateY(-2px);box-shadow:0 8px 16px #10b9814d}.login-error{color:#ef4444;border-radius:var(--radius-sm);background:#ef44441a;border:1px solid #ef444433;margin-bottom:20px;padding:12px 16px;font-size:14px}.pagination{border-top:1px solid var(--border);justify-content:flex-end;align-items:center;gap:8px;padding:20px 24px;display:flex}.page-btn{border:1px solid var(--border);background:var(--surface);cursor:pointer;width:36px;height:36px;color:var(--text-2);border-radius:10px;justify-content:center;align-items:center;font-size:14px;font-weight:500;transition:all .2s;display:flex}.page-btn:hover{border-color:var(--green-500);color:var(--green-600);background:var(--surface2)}.page-btn.active{background:var(--green-500);border-color:var(--green-500);color:#fff;font-weight:700;box-shadow:0 2px 8px #10b98133}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes modalBackdropIn{0%{opacity:0;-webkit-backdrop-filter:blur()}to{opacity:1;-webkit-backdrop-filter:blur(4px)}}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(12px)scale(.97)}to{opacity:1;transform:translate(0,0)scale(1)}}.confirm-dialog-backdrop{z-index:300;-webkit-backdrop-filter:blur(5px);background:#02061794;justify-content:center;align-items:center;padding:20px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.confirm-dialog{background:var(--surface);border:1px solid var(--border);width:100%;max-width:430px;box-shadow:var(--shadow-lg);text-align:center;border-radius:18px;padding:24px;animation:.22s ease-out slideUp}.confirm-dialog-badge{color:#fff;background:linear-gradient(135deg,#ef4444,#f97316);border-radius:50%;justify-content:center;align-items:center;width:42px;height:42px;margin:0 auto 12px;font-size:20px;font-weight:700;display:flex;box-shadow:0 10px 20px #ef444440}.confirm-dialog h3{color:var(--text);margin-bottom:8px;font-size:18px;font-weight:700}.confirm-dialog p{color:var(--text-2);margin-bottom:18px;font-size:14px;line-height:1.65}.confirm-dialog-actions{justify-content:center;gap:10px;display:flex}.ProseMirror{outline:none;min-height:200px;padding:16px}.ProseMirror p{margin-bottom:.75em}.ProseMirror h1{color:var(--text);margin:.8em 0 .4em;font-size:1.6em;font-weight:800}.ProseMirror h2{color:var(--text);margin:.8em 0 .4em;font-size:1.3em;font-weight:700}.ProseMirror h3{color:var(--text);margin:.6em 0 .3em;font-size:1.1em;font-weight:700}.ProseMirror ul,.ProseMirror ol{margin-bottom:.75em;padding-left:1.5em}.ProseMirror li{margin-bottom:.25em}.ProseMirror blockquote{border-left:4px solid var(--green-500);color:var(--text-2);background:var(--green-50);border-radius:0 8px 8px 0;margin:1em 0;padding:8px 16px}.ProseMirror code{color:#ef4444;background:#f1f5f9;border-radius:6px;padding:2px 6px;font-family:Courier New,monospace;font-size:.9em}.ProseMirror pre{color:#f8fafc;background:#0f172a;border-radius:12px;margin-bottom:.75em;padding:16px 20px;overflow-x:auto}.ProseMirror pre code{color:inherit;background:0 0;padding:0}.ProseMirror hr{border:none;border-top:2px solid var(--border);margin:1.5em 0}.ProseMirror a{color:var(--green-600);font-weight:500;text-decoration:underline}.ProseMirror a:hover{color:var(--green-500)}.ProseMirror p.is-editor-empty:first-child:before{content:attr(data-placeholder);float:left;color:var(--text-3);pointer-events:none;height:0;font-style:italic}.rich-preview h1{margin-bottom:.5em;font-size:1.5em;font-weight:800}.rich-preview h2{margin-bottom:.4em;font-size:1.25em;font-weight:700}.rich-preview h3{margin-bottom:.3em;font-size:1.1em;font-weight:600}.rich-preview p{margin-bottom:.7em;line-height:1.7}.rich-preview ul,.rich-preview ol{margin-bottom:.7em;padding-left:1.5em}.rich-preview blockquote{border-left:4px solid var(--green-500);color:var(--text-2);background:var(--green-50);border-radius:0 8px 8px 0;margin:1em 0;padding:8px 16px}.rich-preview a{color:var(--green-600);text-decoration:underline}.notif-bell-wrap{align-items:center;display:flex;position:relative}.notif-bell-btn{width:38px;height:38px;color:var(--text-2);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:22px;transition:background .2s,color .2s,transform .2s;display:flex;position:relative}.notif-bell-btn:hover{background:var(--surface2);color:var(--text);transform:scale(1.08)}.notif-bell-btn--active{color:var(--green-500);animation:2.4s infinite bell-ring}@keyframes bell-ring{0%,55%,to{transform:rotate(0)}5%{transform:rotate(14deg)}10%{transform:rotate(-12deg)}15%{transform:rotate(10deg)}20%{transform:rotate(-8deg)}25%{transform:rotate(6deg)}30%{transform:rotate(-4deg)}35%{transform:rotate(2deg)}40%{transform:rotate(0)}}.notif-badge{color:#fff;border:2px solid var(--surface);background:linear-gradient(135deg,#ef4444,#dc2626);border-radius:99px;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 4px;font-family:Inter,sans-serif;font-size:10px;font-weight:700;line-height:1;animation:.3s cubic-bezier(.34,1.56,.64,1) badge-pop;display:flex;position:absolute;top:2px;right:2px;box-shadow:0 2px 6px #ef444466}@keyframes badge-pop{0%{transform:scale(0)}to{transform:scale(1)}}.notif-dropdown{background:var(--surface);border:1px solid var(--border);z-index:1000;transform-origin:100% 0;border-radius:16px;width:360px;max-width:calc(100vw - 24px);animation:.22s cubic-bezier(.34,1.56,.64,1) dropdown-slide;position:absolute;top:calc(100% + 10px);right:0;overflow:hidden;box-shadow:0 20px 60px #0000001f,0 4px 16px #0000000f}@keyframes dropdown-slide{0%{opacity:0;transform:scale(.92)translateY(-8px)}to{opacity:1;transform:scale(1)translateY(0)}}.notif-dropdown-header{border-bottom:1px solid var(--border);background:var(--surface);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.notif-dropdown-header h3{color:var(--text);margin:0;font-family:Poppins,sans-serif;font-size:15px;font-weight:700;display:inline}.notif-unread-pill{color:var(--green-500);vertical-align:middle;background:#10b9811f;border-radius:99px;align-items:center;margin-left:8px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.notif-mark-all-btn{color:var(--green-500);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:8px;align-items:center;gap:4px;padding:6px 10px;font-family:inherit;font-size:12px;font-weight:500;transition:background .15s;display:flex}.notif-mark-all-btn:hover{background:#10b9811a}.notif-mark-all-btn svg{font-size:16px}.notif-list{max-height:420px;overflow-y:auto}.notif-empty{color:var(--text-3);flex-direction:column;justify-content:center;align-items:center;gap:10px;padding:48px 24px;display:flex}.notif-empty svg{opacity:.4;font-size:40px}.notif-empty p{font-size:14px;font-weight:500}.notif-item{cursor:pointer;border-bottom:1px solid var(--border);align-items:flex-start;gap:12px;padding:14px 20px;transition:background .15s;display:flex;position:relative}.notif-item:last-child{border-bottom:none}.notif-item:hover{background:var(--surface2)}.notif-item--unread{background:#10b9810a}.notif-item--unread:before{content:"";background:linear-gradient(180deg, var(--green-500), var(--green-700));border-radius:0 2px 2px 0;width:3px;position:absolute;top:0;bottom:0;left:0}.notif-item-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:17px;display:flex}.notif-item-icon--new_booking{color:var(--green-500);background:#10b9811f}.notif-item-icon--cancellation{color:#ef4444;background:#ef44441a}.notif-item-body{flex:1;min-width:0}.notif-item-header{justify-content:space-between;align-items:baseline;gap:8px;margin-bottom:3px;display:flex}.notif-item-title{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.notif-item-time{color:var(--text-3);white-space:nowrap;flex-shrink:0;font-size:11px}.notif-item-msg{color:var(--text-2);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:12px;line-height:1.5;display:-webkit-box;overflow:hidden}.notif-item-check{border:1px solid var(--border);width:28px;height:28px;color:var(--text-3);cursor:pointer;opacity:0;background:0 0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:15px;transition:all .2s;display:flex}.notif-item:hover .notif-item-check{opacity:1}.notif-item-check:hover{color:var(--green-500);border-color:var(--green-400);background:#10b9811f}.notif-toast{background:var(--surface);border:1px solid var(--border);cursor:pointer;border-radius:14px;align-items:flex-start;gap:12px;max-width:360px;padding:14px 18px;transition:opacity .3s,transform .3s;display:flex;box-shadow:0 12px 40px #0000001f,0 2px 8px #0000000f}.notif-toast--in{animation:.35s cubic-bezier(.34,1.56,.64,1) toast-slide-in}.notif-toast--out{opacity:0;transform:translate(100%)}@keyframes toast-slide-in{0%{opacity:0;transform:translate(60px)scale(.9)}to{opacity:1;transform:translate(0)scale(1)}}.notif-toast--booking{border-left:4px solid var(--green-500)}.notif-toast--cancel{border-left:4px solid #ef4444}.notif-toast--payment{border-left:4px solid #f59e0b}.notif-toast--payment .notif-toast-icon{color:#f59e0b;background:#f59e0b1f}.notif-toast-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:18px;display:flex}.notif-toast--booking .notif-toast-icon{color:var(--green-500);background:#10b9811f}.notif-toast--cancel .notif-toast-icon{color:#ef4444;background:#ef44441a}.notif-toast-body{flex:1;min-width:0}.notif-toast-title{color:var(--text);margin-bottom:3px;font-family:Poppins,sans-serif;font-size:13px;font-weight:700}.notif-toast-msg{color:var(--text-2);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:12px;line-height:1.5;display:-webkit-box;overflow:hidden}[data-theme=dark] .notif-dropdown{box-shadow:0 20px 60px #0006,0 4px 16px #00000040}[data-theme=dark] .notif-toast{box-shadow:0 12px 40px #0006,0 2px 8px #00000040}.desktop-topbar{display:none}@media (width>=1025px){.desktop-topbar{background:var(--surface);border-bottom:1px solid var(--border);z-index:100;-webkit-backdrop-filter:blur(12px);height:64px;box-shadow:var(--shadow-sm);flex-shrink:0;justify-content:space-between;align-items:center;padding:0 32px;display:flex;position:sticky;top:0}.desktop-topbar-left{align-items:center;gap:8px;display:flex}.desktop-topbar-prefix{color:var(--text-3);font-family:Inter,sans-serif;font-size:13px;font-weight:500}.desktop-topbar-sep{color:var(--text-3);opacity:.5;font-size:13px}.desktop-topbar-title{color:var(--text);letter-spacing:-.01em;font-family:Poppins,sans-serif;font-size:15px;font-weight:700}.desktop-topbar-right{align-items:center;gap:6px;display:flex}.topbar-icon-btn{width:38px;height:38px;color:var(--text-2);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:20px;transition:background .2s,color .2s;display:flex}.topbar-icon-btn:hover{background:var(--surface2);color:var(--text)}.topbar-user-chip{border:1px solid var(--border);background:var(--surface2);cursor:default;border-radius:99px;align-items:center;gap:10px;margin-left:6px;padding:5px 12px 5px 6px;transition:background .2s;display:flex}.topbar-avatar{background:linear-gradient(135deg, var(--green-500), var(--green-700));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:12px;font-weight:700;display:flex}.topbar-username{color:var(--text);white-space:nowrap;text-overflow:ellipsis;max-width:140px;font-family:Inter,sans-serif;font-size:13px;font-weight:600;overflow:hidden}.desktop-topbar .notif-bell-wrap{position:relative}.desktop-topbar .notif-dropdown{position:absolute;top:calc(100% + 10px);right:0}}
