@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800&family=JetBrains+Mono:wght@400;500&display=swap";:root{--gold:#c9a96e;--gold-light:#dfc08a;--gold-dark:#a07840;--bg:#0d0d0f;--bg-1:#131316;--bg-2:#18181c;--bg-3:#222228;--bg-4:#2e2e38;--border:#ffffff12;--border-gold:#c9a96e4d;--text-1:#f5f5f7;--text-2:#b8b8c0;--text-3:#64646e;--green:#22c55e;--red:#ef4444;--amber:#f59e0b;--blue:#3b82f6;--radius-sm:8px;--radius-md:12px;--radius-lg:18px;--radius-xl:24px;--radius-full:9999px;--shadow-sm:0 2px 8px #0006;--shadow-md:0 6px 24px #00000080;--shadow-lg:0 16px 48px #0009;--shadow-gold:0 4px 20px #c9a96e40;--font:"Outfit", system-ui, sans-serif;--font-mono:"JetBrains Mono", monospace;--ease:cubic-bezier(.16,1,.3,1)}*,:before,:after{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text-1);font-family:var(--font);-webkit-font-smoothing:antialiased;min-height:100vh;font-size:16px;line-height:1.6;overflow-x:hidden}body:before{content:"";pointer-events:none;z-index:0;background:radial-gradient(70% 50% at 85% 5%,#c9a96e12 0%,#0000 55%),radial-gradient(50% 60% at 5% 95%,#3b82f60a 0%,#0000 55%);position:fixed;inset:0}#root{z-index:1;flex-direction:column;min-height:100vh;display:flex;position:relative}h1{letter-spacing:-.03em;font-size:clamp(2rem,4vw,3rem);font-weight:700;line-height:1.15}h2{letter-spacing:-.025em;font-size:clamp(1.4rem,3vw,2.2rem);font-weight:700;line-height:1.2}h3{letter-spacing:-.015em;font-size:1.25rem;font-weight:600;line-height:1.35}h4{font-size:1rem;font-weight:600;line-height:1.4}p{color:var(--text-2);line-height:1.7}a{color:inherit;text-decoration:none}.app-container{width:100%;max-width:1100px;margin:0 auto;padding:0 28px}.top-nav{z-index:100;-webkit-backdrop-filter:blur(24px);border-bottom:1px solid var(--border);background:#0d0d0fd9;justify-content:space-between;align-items:center;padding:18px 28px;display:flex;position:sticky;top:0}.logo{letter-spacing:-.5px;color:var(--text-1);align-items:center;gap:10px;font-size:20px;font-weight:700;display:flex}.logo-icon{background:linear-gradient(135deg, var(--gold) 0%, var(--gold-dark) 100%);border-radius:var(--radius-sm);color:#000;width:36px;height:36px;box-shadow:var(--shadow-gold);flex-shrink:0;justify-content:center;align-items:center;display:flex}.logo-wordmark{color:var(--text-1)}.logo-wordmark span{color:var(--gold)}.nav-right{align-items:center;gap:12px;display:flex}.nav-badge{color:var(--text-3);background:var(--bg-3);border:1px solid var(--border);border-radius:var(--radius-full);letter-spacing:.01em;padding:6px 12px;font-size:13px;font-weight:500}.btn{border-radius:var(--radius-md);font-family:var(--font);letter-spacing:-.01em;cursor:pointer;transition:all var(--ease) .18s;white-space:nowrap;-webkit-user-select:none;user-select:none;border:none;justify-content:center;align-items:center;gap:7px;padding:11px 22px;font-size:15px;font-weight:600;display:inline-flex}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.45;cursor:not-allowed;pointer-events:none}.btn-primary{background:linear-gradient(135deg, var(--gold) 0%, var(--gold-dark) 100%);color:#0d0d0f;box-shadow:var(--shadow-gold)}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg, var(--gold-light) 0%, var(--gold) 100%);box-shadow:0 6px 28px #c9a96e59}.btn-secondary{background:var(--bg-3);color:var(--text-1);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--bg-4);border-color:#ffffff1f}.btn-ghost{color:var(--text-2);border:1px solid var(--border);background:0 0}.btn-ghost:hover:not(:disabled){color:var(--text-1);background:#ffffff0a}.btn-danger{color:var(--red);background:#ef44441a;border:1px solid #ef444433}.btn-danger:hover:not(:disabled){background:#ef44442e}.btn-success{color:var(--green);background:#22c55e1a;border:1px solid #22c55e33}.btn-success:hover:not(:disabled){color:#fff;background:linear-gradient(135deg,#22c55e 0%,#16a34a 100%);border-color:#0000}.btn-sm{border-radius:var(--radius-sm);gap:5px;padding:8px 16px;font-size:13px}.btn-lg{border-radius:var(--radius-lg);padding:14px 28px;font-size:16px}.btn-block{width:100%}.btn-pill{border-radius:var(--radius-full)}.form-group{flex-direction:column;gap:7px;display:flex}.form-label{color:var(--text-2);letter-spacing:.02em;text-transform:uppercase;font-size:13px;font-weight:600}.form-input,.form-select,.form-textarea{background:var(--bg-2);color:var(--text-1);border:1px solid var(--border);border-radius:var(--radius-md);font-size:15px;font-family:var(--font);appearance:none;outline:none;width:100%;padding:12px 16px;transition:border-color .18s,box-shadow .18s}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-3)}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--gold);background:var(--bg-3);box-shadow:0 0 0 3px #c9a96e1f}.form-select{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%2364646E' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-position:right 14px center;background-repeat:no-repeat;padding-right:40px}.form-textarea{resize:vertical;min-height:90px}.card{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-xl);padding:28px;transition:border-color .22s,box-shadow .22s}.card:hover{border-color:var(--border-gold)}.card-sm{border-radius:var(--radius-lg);padding:20px}.stat-card{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-lg);transition:transform .22s var(--ease), box-shadow .22s;padding:24px;position:relative;overflow:hidden}.stat-card:after{content:"";opacity:0;background:linear-gradient(90deg,#0000,#c9a96e66,#0000);height:1px;transition:opacity .22s;position:absolute;inset:0 0 auto}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}.stat-card:hover:after{opacity:1}.stat-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-3);margin-bottom:14px;font-size:11px;font-weight:700}.stat-value{letter-spacing:-.04em;color:var(--text-1);font-size:2.5rem;font-weight:700;line-height:1}.stat-sub{color:var(--text-3);margin-top:6px;font-size:13px}.stat-icon{border-radius:var(--radius-sm);justify-content:center;align-items:center;width:36px;height:36px;display:flex;position:absolute;top:20px;right:20px}.alert{border-radius:var(--radius-md);border:1px solid #0000;padding:12px 16px;font-size:14px;font-weight:500;line-height:1.5}.alert-error{color:#fca5a5;background:#ef44441a;border-color:#ef444433}.alert-success{color:#86efac;background:#22c55e1a;border-color:#22c55e33}.alert-info{color:#93c5fd;background:#3b82f61a;border-color:#3b82f633}.badge{border-radius:var(--radius-full);letter-spacing:.02em;border:1px solid #0000;align-items:center;gap:5px;padding:4px 10px;font-size:12px;font-weight:600;display:inline-flex}.badge-pending{color:#fcd34d;background:#f59e0b1f;border-color:#f59e0b33}.badge-approved{color:#86efac;background:#22c55e1a;border-color:#22c55e33}.badge-rejected{color:#fca5a5;background:#ef44441a;border-color:#ef444433}.badge-gold{color:var(--gold);border-color:var(--border-gold);background:#c9a96e1f}.chip{border-radius:var(--radius-full);cursor:pointer;border:1px solid var(--border);background:var(--bg-3);color:var(--text-2);align-items:center;gap:5px;padding:7px 14px;font-size:14px;font-weight:500;transition:all .18s;display:inline-flex}.chip:hover{border-color:var(--border-gold);color:var(--text-1)}.chip.active{color:var(--gold);border-color:var(--border-gold);background:#c9a96e1f}.divider{background:var(--border);height:1px;margin:24px 0}.auth-page{background:var(--bg);place-items:center;min-height:100vh;padding:24px;display:grid}.auth-card{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-xl);width:100%;max-width:440px;box-shadow:var(--shadow-lg);padding:44px 40px}.auth-logo-wrap{background:linear-gradient(135deg, var(--gold) 0%, var(--gold-dark) 100%);border-radius:var(--radius-md);color:#000;width:56px;height:56px;box-shadow:var(--shadow-gold);justify-content:center;align-items:center;margin:0 auto 24px;display:flex}.auth-title{letter-spacing:-.03em;text-align:center;margin-bottom:6px;font-size:1.6rem;font-weight:700}.auth-subtitle{color:var(--text-3);text-align:center;margin-bottom:32px;font-size:14px}.auth-form{flex-direction:column;gap:16px;display:flex}.auth-divider{color:var(--text-3);align-items:center;gap:12px;margin:4px 0;font-size:13px;display:flex}.auth-divider:before,.auth-divider:after{content:"";background:var(--border);flex:1;height:1px}.auth-switch{text-align:center;color:var(--text-3);margin-top:24px;font-size:14px}.auth-switch a,.auth-switch span[role=button]{color:var(--gold);cursor:pointer;font-weight:600;transition:color .15s}.auth-switch a:hover,.auth-switch span[role=button]:hover{color:var(--gold-light)}.forgot-panel{background:var(--bg-3);border:1px solid var(--border);border-radius:var(--radius-md);margin-top:20px;padding:20px}.page-header{margin-bottom:36px}.page-header h2{margin-bottom:6px}.page-header p{color:var(--text-3);font-size:15px}.mode-tabs{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-full);gap:8px;width:fit-content;margin-bottom:32px;padding:5px;display:flex}.search-panel{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-lg);align-items:center;gap:12px;margin-bottom:24px;padding:16px;display:flex}.empty-state{text-align:center;flex-direction:column;align-items:center;gap:12px;padding:64px 24px;display:flex}.empty-state-icon{border-radius:var(--radius-lg);background:var(--bg-3);border:1px solid var(--border);width:64px;height:64px;color:var(--text-3);justify-content:center;align-items:center;margin-bottom:4px;display:flex}.salon-result-card{background:var(--bg-3);border:1px solid var(--border);border-radius:var(--radius-md);justify-content:space-between;align-items:center;padding:18px 22px;transition:border-color .18s,transform .18s;display:flex}.salon-result-card:hover{border-color:var(--border-gold);transform:translateY(-2px)}.salon-name{color:var(--text-1);margin-bottom:4px;font-size:16px;font-weight:600}.salon-meta{color:var(--text-3);margin-bottom:8px;font-size:13px}.salon-score{color:var(--gold);border:1px solid var(--border-gold);border-radius:var(--radius-full);background:#c9a96e1a;align-items:center;gap:5px;padding:3px 10px;font-size:13px;font-weight:600;display:inline-flex}.salon-card{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;transition:border-color .18s,transform .18s}.salon-card:hover{border-color:var(--border-gold);transform:translateY(-3px)}.salon-card-header{justify-content:space-between;align-items:flex-start;margin-bottom:16px;display:flex}.rating{color:var(--gold);align-items:center;gap:5px;font-size:14px;font-weight:600;display:flex}.time-slots{flex-wrap:wrap;gap:8px;margin-top:16px;display:flex}.success-ticket{text-align:center;max-width:520px;margin:0 auto}.success-icon{width:80px;height:80px;color:var(--green);background:#22c55e1a;border:1px solid #22c55e33;border-radius:50%;justify-content:center;align-items:center;margin:0 auto 28px;display:flex}.ref-code-box{background:var(--bg-3);border:1px solid var(--border-gold);border-radius:var(--radius-lg);margin:28px 0;padding:28px}.ref-label{text-transform:uppercase;letter-spacing:.1em;color:var(--text-3);margin-bottom:10px;font-size:11px;font-weight:700}.ref-code{font-family:var(--font-mono);letter-spacing:.12em;color:var(--gold);font-size:2.5rem;font-weight:500}.queue-table{width:100%}.queue-head{border-bottom:1px solid var(--border);text-transform:uppercase;letter-spacing:.07em;color:var(--text-3);grid-template-columns:120px 1fr 120px 140px 100px;gap:12px;padding:0 0 14px;font-size:11px;font-weight:700;display:grid}.queue-row{animation:rowIn .3s var(--ease) both;border-bottom:1px solid #ffffff0a;grid-template-columns:120px 1fr 120px 140px 100px;align-items:center;gap:12px;padding:18px 0;display:grid}@keyframes rowIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.queue-time{color:var(--text-1);letter-spacing:-.02em;font-size:15px;font-weight:700}.queue-customer{color:var(--text-2);font-size:14px;font-weight:500}.ref-mono{font-family:var(--font-mono);color:var(--text-2);background:var(--bg-3);border:1px solid var(--border);border-radius:var(--radius-sm);letter-spacing:.05em;padding:4px 10px;font-size:13px}.queue-empty{text-align:center;color:var(--text-3);padding:64px 24px}.calendar-grid{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-3);display:flex;overflow:auto hidden}.calendar-time-col{border-right:1px solid var(--border);flex-shrink:0;width:64px}.calendar-time-cell{height:60px;color:var(--text-3);text-align:right;border-bottom:1px solid #ffffff0a;padding:8px 10px 0 0;font-size:11px;font-weight:600}.calendar-day-header{border-bottom:1px solid var(--border);height:48px;color:var(--text-2);background:#ffffff05;justify-content:center;align-items:center;font-size:13px;font-weight:600;display:flex}.calendar-event{color:#fff;box-shadow:var(--shadow-sm);cursor:pointer;border-radius:6px;padding:6px 8px;font-size:11px;transition:filter .15s;position:absolute;left:4px;right:4px;overflow:hidden}.calendar-event:hover{filter:brightness(1.15)}.application-row{background:var(--bg-3);border:1px solid var(--border);border-radius:var(--radius-lg);justify-content:space-between;align-items:center;gap:20px;padding:22px 24px;transition:border-color .18s;display:flex}.application-row:hover{border-color:var(--border-gold)}.application-name{color:var(--text-1);align-items:center;gap:10px;margin-bottom:8px;font-size:16px;font-weight:600;display:flex}.application-meta{color:var(--text-3);flex-wrap:wrap;gap:20px;font-size:13px;display:flex}.status-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;display:inline-block}.status-dot.live{background:var(--green);animation:2s infinite pulse-dot;box-shadow:0 0 0 2px #22c55e40}.status-dot.offline{background:var(--red)}@keyframes pulse-dot{0%,to{box-shadow:0 0 0 2px #22c55e40}50%{box-shadow:0 0 0 5px #22c55e1a}}.live-badge{border-radius:var(--radius-full);border:1px solid;align-items:center;gap:7px;padding:5px 12px;font-size:13px;font-weight:600;display:inline-flex}.live-badge.connected{color:var(--green);background:#22c55e14;border-color:#22c55e33}.live-badge.disconnected{color:var(--red);background:#ef444414;border-color:#ef444433}@keyframes fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.anim-fade-up{animation:fadeUp .35s var(--ease) both}@keyframes flash-green{0%{background:#22c55e26}to{background:0 0}}.flash{animation:1.4s forwards flash-green}.logout-btn{color:var(--text-3);border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font);cursor:pointer;background:0 0;align-items:center;gap:7px;padding:8px 16px;font-size:14px;font-weight:500;transition:all .18s;display:flex}.logout-btn:hover{color:var(--red);background:#ef44440f;border-color:#ef44444d}.main-content{padding:40px 0 80px}.grid-2{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px;display:grid}.grid-3{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;display:grid}.stack{flex-direction:column;gap:16px;display:flex}.row{align-items:center;gap:16px;display:flex}.row-between{justify-content:space-between;align-items:center;display:flex}.text-muted{color:var(--text-3)}.text-gold{color:var(--gold)}.text-green{color:var(--green)}.text-red{color:var(--red)}.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.mt-32{margin-top:32px}.mb-8{margin-bottom:8px}.mb-16{margin-bottom:16px}.mb-24{margin-bottom:24px}.mb-32{margin-bottom:32px}.text-center{text-align:center}.text-right{text-align:right}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg-2)}::-webkit-scrollbar-thumb{background:var(--bg-4);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:var(--neutral-500)}.customer-taskbar{-webkit-backdrop-filter:blur(24px);border-top:1px solid var(--border);padding:12px 16px;padding-bottom:calc(12px + env(safe-area-inset-bottom,0px));z-index:100;background:#0d0d0fd9;justify-content:space-around;display:flex;position:fixed;bottom:0;left:0;right:0}@media (width>=768px){.customer-taskbar{border-radius:var(--radius-xl) var(--radius-xl) 0 0;border-left:1px solid var(--border);border-right:1px solid var(--border);max-width:960px;margin:0 auto}}.taskbar-item{color:var(--text-3);font-family:var(--font);text-transform:uppercase;letter-spacing:.05em;cursor:pointer;background:0 0;border:none;flex-direction:column;align-items:center;gap:4px;width:70px;font-size:11px;font-weight:600;transition:all .15s;display:flex;position:relative}.taskbar-item:hover{color:var(--text-2)}.taskbar-item.active{color:var(--gold)}.taskbar-item.active svg{transform:translateY(-2px)}.notification-dot{background-color:var(--red);border:2px solid var(--bg);border-radius:50%;width:8px;height:8px;position:absolute;top:0;right:18px}.profile-avatar-container{width:80px;height:80px;position:relative}.profile-avatar{background:linear-gradient(135deg, var(--bg-3) 0%, var(--bg-4) 100%);border:1px solid var(--border);width:100%;height:100%;color:var(--text-2);border-radius:50%;justify-content:center;align-items:center;font-size:2rem;font-weight:700;display:flex}.avatar-upload-btn{background:var(--bg-2);border:1px solid var(--border);width:28px;height:28px;color:var(--text-1);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;transition:all .15s;display:flex;position:absolute;bottom:0;right:0}.avatar-upload-btn:hover{background:var(--bg-3);color:var(--gold);border-color:var(--border-gold)}.tier-card{border-radius:var(--radius-xl);box-shadow:var(--shadow-md);flex-direction:column;justify-content:space-between;padding:24px;display:flex;position:relative;overflow:hidden}.gold-tier{color:#000;background:linear-gradient(135deg,#a07840 0%,#c9a96e 50%,#dfc08a 100%)}.gold-tier:before{content:"";pointer-events:none;background:linear-gradient(#ffffff4d 0%,#fff0 100%);position:absolute;inset:-50%;transform:rotate(30deg)}.tier-header{z-index:1;justify-content:space-between;align-items:center;margin-bottom:24px;display:flex;position:relative}.tier-body{z-index:1;position:relative}.tier-footer{z-index:1;margin-top:24px;position:relative}.progress-bar-bg{border-radius:var(--radius-full);background:#0003;width:100%;height:6px;overflow:hidden}.progress-bar-fill{border-radius:var(--radius-full);background:#000;height:100%}.salon-cover-photo{border-radius:var(--radius-xl);background-position:50%;background-size:cover;height:240px;position:relative;overflow:hidden}.salon-cover-overlay{background:linear-gradient(#0003 0%,#000000e6 100%);align-items:flex-end;padding:24px;display:flex;position:absolute;inset:0}.salon-cover-content{width:100%}.time-slot-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:10px;display:grid}.time-slot-btn{color:var(--green);border-radius:var(--radius-sm);font-family:var(--font);cursor:pointer;text-align:center;background:#22c55e1a;border:1px solid #22c55e4d;padding:10px;font-size:13px;font-weight:600;transition:all .15s}.time-slot-btn:hover:not(:disabled){background:#22c55e33;border-color:#22c55e80}.time-slot-btn.selected{background:var(--green);color:#fff;border-color:var(--green);box-shadow:0 4px 12px #22c55e4d}.time-slot-btn:disabled,.time-slot-btn.booked{color:var(--red);cursor:not-allowed;opacity:.7;background:#ef44440d;border:1px solid #ef444426}
