:root{--charcoal:#15130f;--charcoal-2:#211d17;--charcoal-3:#2d2820;--brass:#c89b4a;--brass-soft:#e0c081;--cream:#f4efe6;--cream-dim:#b3aa98;--cream-mute:#756d5d;--paper:#faf7f1;--ink:#1a1712;--ink-dim:#6b6356;--line:#e6ded0;--line-dark:#38322820;--green:#4a7c59;--green-bg:#e3efe5;--amber:#9a7b24;--amber-bg:#f7efd9;--red:#a14b3f;--red-bg:#f6e3df;--radius:18px;--radius-sm:12px;--shadow:0 4px 24px rgba(0,0,0,.1);--shadow-lg:0 12px 48px rgba(0,0,0,.18)}*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}body,html{height:100%;background:var(--charcoal);font-family:Georgia,Times New Roman,serif}body{color:var(--cream);font-size:16px;line-height:1.55}.ui{font-family:-apple-system,Helvetica Neue,sans-serif}.display{font-family:Georgia,serif;font-weight:700;letter-spacing:-.01em}#app{max-width:480px;margin:0 auto;flex-direction:column;background:var(--charcoal);position:relative;overflow:hidden}#app,#auth-screen{min-height:100vh;display:flex}#auth-screen,.auth-hero{flex:1;flex-direction:column}.auth-hero{display:flex;justify-content:center;align-items:center;padding:40px 28px;text-align:center;position:relative}.auth-hero:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 60% 40% at 50% 30%,rgba(200,155,74,.1),transparent 70%),repeating-linear-gradient(45deg,transparent,transparent 14px,rgba(200,155,74,.015) 0,rgba(200,155,74,.015) 15px);pointer-events:none}.barber-pole{width:56px;height:56px;border-radius:50%;position:relative;z-index:1;background:var(--brass);display:flex;align-items:center;justify-content:center;box-shadow:0 0 0 6px rgba(200,155,74,.12),0 8px 28px rgba(200,155,74,.25);margin-bottom:28px}.barber-pole span{font-size:26px}.auth-eyebrow{font-family:-apple-system,sans-serif;font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--brass-soft);margin-bottom:16px;z-index:1}.auth-title{font-size:38px;line-height:1.05;color:var(--cream);z-index:1;margin-bottom:14px}.auth-title em{font-style:italic;color:var(--brass-soft)}.auth-sub{font-family:-apple-system,sans-serif;font-size:14px;color:var(--cream-dim);max-width:300px;z-index:1;line-height:1.6}.auth-panel{background:var(--charcoal-2);border-top:1px solid var(--line-dark);border-radius:28px 28px 0 0;padding:32px 28px calc(32px + env(safe-area-inset-bottom));box-shadow:0 -8px 40px rgba(0,0,0,.3)}.auth-panel h2{font-size:22px;margin-bottom:6px;color:var(--cream)}.auth-panel p.hint{font-family:-apple-system,sans-serif;font-size:13px;color:var(--cream-mute);margin-bottom:22px}.field{margin-bottom:14px}.field label{display:block;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--cream-dim);margin-bottom:7px;font-weight:600}.field input,.field label{font-family:-apple-system,sans-serif}.field input{width:100%;font-size:16px;color:var(--cream);background:var(--charcoal);border:1.5px solid var(--charcoal-3);border-radius:var(--radius-sm);padding:14px 16px;outline:none;transition:border-color .18s}.field input::-moz-placeholder{color:var(--cream-mute)}.field input::placeholder{color:var(--cream-mute)}.field input:focus{border-color:var(--brass)}.btn-brass{width:100%;font-family:-apple-system,sans-serif;font-size:16px;font-weight:700;color:var(--charcoal);background:var(--brass);border:none;border-radius:var(--radius-sm);padding:16px;cursor:pointer;transition:transform .12s,background .18s;letter-spacing:.01em}.btn-brass:active{transform:scale(.98);background:var(--brass-soft)}.btn-brass:disabled{opacity:.55;cursor:default}.btn-outline{width:100%;font-family:-apple-system,sans-serif;font-size:15px;font-weight:600;color:var(--cream);background:transparent;border:1.5px solid var(--charcoal-3);border-radius:var(--radius-sm);padding:14px;cursor:pointer;transition:border-color .18s,background .18s;display:flex;align-items:center;justify-content:center;gap:10px}.btn-outline:active{background:var(--charcoal-3)}.btn-google-icon{width:18px;height:18px}.divider-or{display:flex;align-items:center;gap:14px;margin:20px 0}.divider-or:after,.divider-or:before{content:"";flex:1;height:1px;background:var(--charcoal-3)}.divider-or span{font-family:-apple-system,sans-serif;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--cream-mute)}.magic-sent{text-align:center;padding:10px 0}.magic-sent .check-ring{width:64px;height:64px;border-radius:50%;background:rgba(200,155,74,.12);display:flex;align-items:center;justify-content:center;margin:0 auto 16px;font-size:30px}.magic-sent h3{font-size:20px;margin-bottom:8px}.magic-sent p{font-family:-apple-system,sans-serif;font-size:14px;color:var(--cream-dim);line-height:1.6}.magic-sent strong{color:var(--brass-soft)}.skip-link{font-family:-apple-system,sans-serif;text-align:center;margin-top:18px}.skip-link button{background:none;border:none;color:var(--cream-mute);font-size:13px;text-decoration:underline;cursor:pointer}#main-app{display:none;flex-direction:column;min-height:100vh}.topbar{background:var(--charcoal);padding:18px 22px 14px;justify-content:space-between;border-bottom:1px solid var(--line-dark)}.topbar,.topbar-brand{display:flex;align-items:center}.topbar-brand{gap:11px}.topbar-logo{width:38px;height:38px;border-radius:10px;background:var(--brass);display:flex;align-items:center;justify-content:center;font-size:17px;overflow:hidden}.topbar-logo img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.topbar-name{font-size:19px;color:var(--cream)}.topbar-account{width:38px;height:38px;border-radius:50%;background:var(--charcoal-3);border:1.5px solid var(--charcoal-3);display:flex;align-items:center;justify-content:center;font-family:-apple-system,sans-serif;font-weight:700;font-size:14px;color:var(--brass-soft);cursor:pointer}.tabbar{position:sticky;bottom:0;background:var(--charcoal-2);border-top:1px solid var(--line-dark);display:flex;padding:8px 8px calc(8px + env(safe-area-inset-bottom));z-index:40}.tab-btn{flex:1;font-family:-apple-system,sans-serif;background:none;border:none;cursor:pointer;padding:8px 4px;display:flex;flex-direction:column;align-items:center;gap:3px;color:var(--cream-mute);transition:color .15s}.tab-btn.active{color:var(--brass-soft)}.tab-icon{font-size:19px;line-height:1}.tab-label{font-size:10.5px;font-weight:600;letter-spacing:.02em}.tab-content{flex:1;display:none;flex-direction:column;overflow-y:auto}.tab-content.active{display:flex}.steps-bar{padding:16px 22px;background:var(--charcoal);border-bottom:1px solid var(--line-dark)}.step-dot,.steps-bar{display:flex;align-items:center}.step-dot{flex-direction:column;flex:1;position:relative}.step-dot:not(:last-child):after{content:"";position:absolute;top:13px;left:calc(50% + 13px);width:calc(100% - 26px);height:1.5px;background:var(--charcoal-3)}.step-dot.done:not(:last-child):after{background:var(--brass)}.dot-circle{width:26px;height:26px;border-radius:50%;border:1.5px solid var(--charcoal-3);background:var(--charcoal);display:flex;align-items:center;justify-content:center;font-family:-apple-system,sans-serif;font-size:12px;font-weight:700;color:var(--cream-mute);transition:all .22s;z-index:1}.step-dot.active .dot-circle,.step-dot.done .dot-circle{border-color:var(--brass);background:var(--brass);color:var(--charcoal)}.dot-label{font-family:-apple-system,sans-serif;font-size:10px;color:var(--cream-mute);margin-top:5px;font-weight:600;letter-spacing:.02em}.step-dot.active .dot-label{color:var(--brass-soft)}.screen{display:none;flex-direction:column;gap:18px;padding:22px}.screen.active{display:flex}.screen-head h2{font-size:25px;color:var(--cream);margin-bottom:3px}.screen-head p{font-family:-apple-system,sans-serif;font-size:13px;color:var(--cream-dim)}.opt-list{display:flex;flex-direction:column;gap:11px}.opt-card{background:var(--charcoal-2);border:1.5px solid var(--charcoal-3);border-radius:var(--radius);padding:16px;cursor:pointer;transition:border-color .15s,background .15s;display:flex;align-items:center;gap:14px}.opt-card:active{transform:scale(.99)}.opt-card.selected{border-color:var(--brass);background:rgba(200,155,74,.07)}.opt-avatar{width:50px;height:50px;border-radius:13px;background:var(--charcoal-3);color:var(--brass-soft);display:flex;align-items:center;justify-content:center;font-family:Georgia,serif;font-weight:700;font-size:19px;flex-shrink:0}.opt-body{flex:1;min-width:0}.opt-name{font-size:15px;font-weight:600;color:var(--cream)}.opt-desc,.opt-name{font-family:-apple-system,sans-serif}.opt-desc{font-size:12.5px;color:var(--cream-dim);margin-top:2px}.opt-price{font-family:Georgia,serif;font-weight:700;font-size:17px;color:var(--brass-soft);flex-shrink:0}.opt-check{width:22px;height:22px;border-radius:50%;border:1.5px solid var(--charcoal-3);flex-shrink:0;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s}.opt-card.selected .opt-check{opacity:1;background:var(--brass);border-color:var(--brass)}.opt-check:after{content:"✓";color:var(--charcoal);font-size:12px;font-weight:700}.svc-cat-title{font-size:10px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--brass);opacity:.7;padding:14px 2px 6px}.cal-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.cal-month{font-family:Georgia,serif;font-size:17px;font-weight:700;color:var(--cream);text-transform:capitalize}.cal-arrow{width:38px;height:38px;border:1.5px solid var(--charcoal-3);border-radius:11px;background:var(--charcoal-2);color:var(--cream);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center}.cal-arrow:active{background:var(--charcoal-3)}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:5px;text-align:center}.cal-dow{font-size:10.5px;font-weight:700;color:var(--cream-mute);padding:4px 0;text-transform:uppercase}.cal-day,.cal-dow{font-family:-apple-system,sans-serif}.cal-day{aspect-ratio:1;border-radius:10px;font-size:13.5px;font-weight:600;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--cream);transition:all .12s;position:relative}.cal-day:hover:not(.disabled):not(.blank){background:var(--charcoal-3)}.cal-day.today{color:var(--brass-soft);font-weight:800}.cal-day.selected{background:var(--brass);color:var(--charcoal)}.cal-day.disabled{color:var(--cream-mute);opacity:.35;cursor:default}.cal-day.blank{cursor:default}.cal-day.open:after{content:"";position:absolute;bottom:4px;left:50%;transform:translateX(-50%);width:4px;height:4px;border-radius:50%;background:var(--brass)}.cal-day.selected:after{background:var(--charcoal)}.slots-wrap{margin-top:4px}.slots-label{font-family:-apple-system,sans-serif;font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--cream-mute);margin-bottom:11px}.slots-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.slot-chip{font-family:-apple-system,sans-serif;padding:11px 4px;border:1.5px solid var(--charcoal-3);border-radius:11px;background:var(--charcoal-2);color:var(--cream);font-size:13px;font-weight:600;cursor:pointer;text-align:center;transition:all .14s}.slot-chip.selected,.slot-chip:hover{border-color:var(--brass)}.slot-chip.selected{background:var(--brass);color:var(--charcoal)}.slots-empty{font-family:-apple-system,sans-serif;text-align:center;padding:30px 0;color:var(--cream-mute);font-size:14px;grid-column:1/-1}.recap{background:var(--charcoal-2);border:1px solid var(--charcoal-3);border-radius:var(--radius);padding:18px}.recap-row{display:flex;justify-content:space-between;align-items:center;padding:9px 0;border-bottom:1px solid var(--line-dark);font-family:-apple-system,sans-serif}.recap-row:last-child{border:none;padding-bottom:0}.recap-k{font-size:13px;color:var(--cream-dim)}.recap-v{font-size:14px;font-weight:600;color:var(--cream);text-align:right}.recap-total{font-family:Georgia,serif;font-size:22px;font-weight:700;color:var(--brass-soft)}.pay-opts{display:flex;flex-direction:column;gap:10px}.pay-opt{border:1.5px solid var(--charcoal-3);border-radius:var(--radius);padding:15px;cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:13px;background:var(--charcoal-2)}.pay-opt.selected{border-color:var(--brass);background:rgba(200,155,74,.07)}.pay-icon{width:42px;height:34px;border-radius:9px;background:var(--charcoal-3);display:flex;align-items:center;justify-content:center;font-size:19px;flex-shrink:0}.pay-name{font-size:14.5px;font-weight:600;color:var(--cream)}.pay-name,.pay-sub{font-family:-apple-system,sans-serif}.pay-sub{font-size:12px;color:var(--cream-dim)}.pay-check{margin-left:auto;width:22px;height:22px;border-radius:50%;border:1.5px solid var(--charcoal-3);display:flex;align-items:center;justify-content:center;opacity:0;flex-shrink:0}.pay-opt.selected .pay-check{opacity:1;background:var(--brass);border-color:var(--brass)}.pay-check:after{content:"✓";color:var(--charcoal);font-size:12px;font-weight:700}.bottom-cta{padding:16px 22px calc(16px + env(safe-area-inset-bottom));border-top:1px solid var(--line-dark);background:var(--charcoal);display:flex;gap:10px}.btn-back{font-family:-apple-system,sans-serif;padding:15px 20px;background:transparent;color:var(--cream-dim);border:1.5px solid var(--charcoal-3);border-radius:var(--radius-sm);font-size:14px;font-weight:600;cursor:pointer}.confirm-wrap{flex:1;flex-direction:column;text-align:center;padding:36px 24px;gap:16px}.confirm-ring,.confirm-wrap{display:flex;align-items:center;justify-content:center}.confirm-ring{width:84px;height:84px;border-radius:50%;background:rgba(200,155,74,.12);font-size:40px}.confirm-title{font-size:27px;color:var(--cream)}.confirm-sub{font-family:-apple-system,sans-serif;font-size:14px;color:var(--cream-dim);line-height:1.6}.confirm-sub strong{color:var(--brass-soft)}#tab-account{background:var(--paper);color:var(--ink)}.acc-header{padding:26px 22px 20px;background:var(--charcoal);color:var(--cream);border-radius:0 0 26px 26px}.acc-avatar{width:58px;height:58px;border-radius:50%;background:var(--brass);color:var(--charcoal);display:flex;align-items:center;justify-content:center;font-family:Georgia,serif;font-weight:700;font-size:24px;margin-bottom:14px}.acc-name{font-size:23px;margin-bottom:2px}.acc-email{font-family:-apple-system,sans-serif;font-size:13px;color:var(--cream-dim)}.acc-body{padding:20px 22px 28px;display:flex;flex-direction:column;gap:22px}.acc-section-title{font-family:-apple-system,sans-serif;font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-dim);margin-bottom:11px}.acc-stat-row{display:flex;gap:11px}.acc-stat{flex:1;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:15px}.acc-stat-num{font-family:Georgia,serif;font-size:26px;font-weight:700;color:var(--ink);line-height:1}.acc-stat-lbl{font-family:-apple-system,sans-serif;font-size:11.5px;color:var(--ink-dim);margin-top:5px}.rdv-card{background:#fff;border-radius:var(--radius);padding:15px 16px;margin-bottom:10px;border:1px solid var(--line);border-left:4px solid var(--brass)}.rdv-card.past{border-left-color:var(--line);opacity:.9}.rdv-top{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}.rdv-date{font-family:-apple-system,sans-serif;font-size:12px;color:var(--ink-dim);font-weight:600;text-transform:capitalize}.rdv-service{font-family:Georgia,serif;font-size:16px;font-weight:700;color:var(--ink);margin-top:2px}.rdv-meta{font-family:-apple-system,sans-serif;font-size:13px;color:var(--ink-dim);margin-top:3px}.rdv-price{font-family:Georgia,serif;font-weight:700;font-size:16px;color:var(--ink);white-space:nowrap}.badge{display:inline-block;font-family:-apple-system,sans-serif;font-size:10.5px;font-weight:700;padding:3px 9px;border-radius:20px;margin-top:8px;letter-spacing:.02em}.badge.pending{background:var(--amber-bg);color:#8a6d1f}.badge.confirmed{background:var(--green-bg);color:var(--green)}.badge.completed{background:#e8edf2;color:#3d5a73}.badge.cancelled{background:var(--red-bg);color:var(--red)}.badge.paid{background:var(--green-bg);color:var(--green)}.badge.unpaid{background:#efe9dd;color:var(--ink-dim)}.rdv-actions{display:flex;gap:8px;margin-top:12px}.rdv-btn{flex:1;font-family:-apple-system,sans-serif;padding:9px;border-radius:10px;font-size:12.5px;font-weight:700;cursor:pointer;border:1.5px solid var(--line);background:#fff;color:var(--ink)}.rdv-btn.danger{border-color:#e3b8b0;background:var(--red-bg);color:var(--red)}.rdv-btn:active{transform:scale(.98)}.empty-state{text-align:center;padding:30px 20px;color:var(--ink-dim)}.empty-state .ic{font-size:34px;margin-bottom:10px;opacity:.5}.empty-state button,.empty-state p{font-family:-apple-system,sans-serif;font-size:14px}.empty-state button{margin-top:14px;background:var(--charcoal);color:var(--cream);border:none;border-radius:11px;padding:12px 22px;font-weight:600;cursor:pointer}.acc-field{margin-bottom:13px}.acc-field label{display:block;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-dim);margin-bottom:6px;font-weight:600}.acc-field input,.acc-field label{font-family:-apple-system,sans-serif}.acc-field input{width:100%;font-size:15px;color:var(--ink);background:#fff;border:1.5px solid var(--line);border-radius:11px;padding:13px 15px;outline:none;transition:border-color .16s}.acc-field input:focus{border-color:var(--brass)}.btn-save-dark{width:100%;font-family:-apple-system,sans-serif;font-size:15px;font-weight:700;color:var(--cream);background:var(--charcoal);border:none;border-radius:12px;padding:15px;cursor:pointer}.btn-save-dark:active{transform:scale(.99)}.btn-logout{width:100%;font-family:-apple-system,sans-serif;font-size:14px;font-weight:600;color:var(--red);background:transparent;border:1.5px solid #e3b8b0;border-radius:12px;padding:13px;cursor:pointer;margin-top:4px}.guest-prompt{padding:40px 28px;text-align:center}.guest-prompt .ic{width:80px;height:80px;border-radius:20px;overflow:hidden;background:var(--brass);display:flex;align-items:center;justify-content:center;font-size:32px;margin:0 auto 20px}.guest-prompt .ic img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.guest-prompt h3{font-family:Georgia,serif;font-size:22px;color:var(--ink);margin-bottom:8px}.guest-prompt p{font-size:14px;color:var(--ink-dim);margin-bottom:22px;line-height:1.6}#toast,.guest-prompt p{font-family:-apple-system,sans-serif}#toast{position:fixed;bottom:90px;left:50%;transform:translateX(-50%) translateY(10px);background:var(--charcoal-3);color:var(--cream);padding:12px 20px;border-radius:13px;font-size:13.5px;font-weight:600;opacity:0;transition:opacity .25s,transform .25s;pointer-events:none;z-index:999;max-width:88%;text-align:center;border:1px solid var(--brass);box-shadow:var(--shadow-lg)}#toast.show{opacity:1;transform:translateX(-50%) translateY(0)}.spinner{display:inline-block;width:18px;height:18px;border:2px solid rgba(21,19,15,.25);border-top:2px solid var(--charcoal);border-radius:50%;animation:spin .7s linear infinite}.spinner-light{border:2px solid hsla(39,39%,93%,.3);border-top:2px solid var(--cream)}@keyframes spin{to{transform:rotate(1turn)}}.full-loader{position:fixed;inset:0;background:var(--charcoal);display:flex;align-items:center;justify-content:center;z-index:9999}.full-loader .spinner{width:30px;height:30px;border-color:rgba(200,155,74,.25);border-top-color:var(--brass)}