.button{min-height:44px;display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid transparent;border-radius:var(--radius-md);padding:10px 16px;cursor:pointer;font-weight:700;line-height:1.2;max-width:100%;position:relative;transition:background var(--duration-fast) var(--ease-standard),border-color var(--duration-fast) var(--ease-standard),box-shadow var(--duration-fast) var(--ease-standard),color var(--duration-fast) var(--ease-standard),transform var(--duration-fast) var(--ease-standard)}.button:hover{transform:translateY(-1px)}.button:active{transform:translateY(0)}.button.primary{background:var(--color-charcoal-900);color:var(--color-cream-50);box-shadow:0 8px 18px #1118272e}.button.primary:hover{background:var(--color-barber-blue)}.button.secondary{border-color:#11182747;background:var(--color-surface);color:var(--color-charcoal-900)}.button.secondary:hover{border-color:var(--color-barber-blue);color:var(--color-barber-blue)}.button.danger{background:var(--color-danger);color:var(--color-cream-50);box-shadow:0 8px 18px #b423182e}.button.ghost{background:transparent;color:var(--color-charcoal-900)}.button.ghost:hover{background:#1d4ed814;color:var(--color-barber-blue)}.button.full{width:100%}.button:disabled{cursor:not-allowed;opacity:.6;transform:none;box-shadow:none}.button-icon,.button svg{flex:0 0 auto}.button span{min-width:0;overflow-wrap:anywhere}.button.is-loading{pointer-events:none}.spin{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.card{border:var(--border-soft);border-radius:var(--radius-md);background:var(--color-surface);padding:20px;box-shadow:var(--shadow-soft);transition:border-color var(--duration-fast) var(--ease-standard),box-shadow var(--duration-fast) var(--ease-standard),transform var(--duration-fast) var(--ease-standard);overflow-wrap:anywhere}.card:hover{box-shadow:var(--shadow-lift)}.card.highlighted{border-top:4px solid var(--color-teal-500)}.field{display:grid;gap:8px;font-weight:700}.input{min-height:44px;width:100%;border:1px solid var(--color-sand-300);border-radius:var(--radius-md);background:var(--color-surface);padding:10px 12px;color:var(--color-charcoal-900);transition:border-color var(--duration-fast) var(--ease-standard),box-shadow var(--duration-fast) var(--ease-standard)}.input:focus{border-color:var(--color-barber-blue);box-shadow:0 0 0 3px #1d4ed824;outline:0}.input.invalid{border-color:var(--color-danger);box-shadow:0 0 0 3px #b423181f}.field small{color:var(--color-danger);font-weight:600}.field small.hint{color:var(--color-taupe-500)}.badge{display:inline-flex;align-items:center;border-radius:999px;padding:4px 10px;background:var(--color-cream-200);color:var(--color-charcoal-900);font-size:12px;font-weight:700}.badge.success{color:var(--color-success);background:#15803d1a}.badge.danger{color:var(--color-danger);background:#b423181a}.badge.info{color:var(--color-info);background:#1d4ed81a}.badge.warning{color:var(--color-warning);background:#b7791f1f}.stepper{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:8px;padding:0;list-style:none}.stepper li{display:flex;align-items:center;gap:8px;min-height:44px;color:var(--color-taupe-500);font-weight:700;transition:color var(--duration-fast) var(--ease-standard);min-width:0}.stepper span{display:inline-flex;width:28px;height:28px;align-items:center;justify-content:center;border-radius:999px;background:var(--color-cream-200)}.stepper .current{color:var(--color-charcoal-900)}.stepper .current span{background:var(--color-charcoal-900);color:var(--color-cream-50);box-shadow:0 0 0 4px #1d4ed81f}.stepper .done{color:var(--color-success)}.stepper .done span{background:#15803d1f}.status-message{align-items:flex-start;border:1px solid transparent;border-radius:var(--radius-md);display:flex;gap:10px;line-height:1.45;margin:0;padding:10px 12px;overflow-wrap:anywhere}.status-message svg{flex:0 0 auto;margin-top:2px}@media(max-width:520px){.stepper{grid-template-columns:repeat(2,minmax(0,1fr))}}.status-message.loading,.status-message.info,.status-message.empty{background:#1d4ed814;border-color:#1d4ed82e;color:var(--color-charcoal-800)}.status-message.success{background:#15803d17;border-color:#15803d33;color:var(--color-success)}.status-message.error{background:#b4231814;border-color:#b423182e;color:var(--color-danger)}.status-message.warning,.status-message.confirmation{background:#b7791f1a;border-color:#b7791f38;color:var(--color-warning)}@media(prefers-reduced-motion:reduce){.button:hover,.card:hover{transform:none}.spin{animation:none}}.site-header{position:sticky;top:0;z-index:10;border-bottom:1px solid var(--color-sand-300);background:#f8f2e2eb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.header-inner{min-height:68px;display:flex;align-items:center;justify-content:space-between;gap:16px}.brand{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-heading);font-size:24px;font-weight:800}.site-header nav{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:16px;font-weight:700}.barber-sidebar{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}.barber-sidebar a{min-height:44px;display:inline-flex;align-items:center;gap:8px;border:var(--border-soft);border-radius:var(--radius-md);padding:10px 14px;background:var(--color-surface);font-weight:700;transition:background var(--duration-fast) var(--ease-standard),border-color var(--duration-fast) var(--ease-standard),color var(--duration-fast) var(--ease-standard),transform var(--duration-fast) var(--ease-standard)}.barber-sidebar a:hover{border-color:var(--color-barber-blue);color:var(--color-barber-blue);transform:translateY(-1px)}.barber-sidebar a.active{background:var(--color-charcoal-900);color:var(--color-cream-50)}.customer-footer{margin-top:auto;border-top:1px solid var(--color-sand-300);background:var(--color-charcoal-900);color:var(--color-cream-50)}.customer-footer-inner{min-height:64px;display:flex;align-items:center;justify-content:space-between;gap:24px;padding:8px 0}.customer-footer h2{margin:0 0 4px;font-family:var(--font-heading);font-size:18px}.customer-footer p{max-width:34rem;margin:0;color:var(--color-cream-200);font-size:13px}.customer-footer-links{display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-end;gap:8px}.customer-footer-links a{min-height:36px;display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid rgb(252 248 234 / 24%);border-radius:var(--radius-md);padding:7px 10px;background:#fcf8ea14;color:var(--color-cream-50);font-weight:800}.customer-footer-links a:hover{background:#fcf8ea29}@media(prefers-reduced-motion:reduce){.barber-sidebar a:hover{transform:none}}@media(max-width:720px){.header-inner{align-items:flex-start;flex-direction:column;padding:14px 0}.customer-footer-inner{align-items:flex-start;flex-direction:column;gap:10px}.customer-footer-links{width:100%;justify-content:flex-start}.customer-footer-links a{flex:1 1 150px}}.auth-page{display:grid;place-items:center;padding:10px 16px}.auth-card{width:min(440px,100%);display:grid;gap:8px;padding:16px}.auth-card h1{margin:0;font-family:var(--font-heading);font-size:26px}.auth-copy,.form-success{margin:0;color:var(--color-taupe-500);line-height:1.5}.form-success{color:var(--color-success);font-weight:700}.auth-card form{display:grid;gap:8px}.form-error{margin:0;color:var(--color-danger);font-weight:700}.auth-card>svg{color:var(--color-barber-blue)}.auth-card a{color:var(--color-barber-blue);font-weight:800}@media(max-height:760px){.auth-page{padding:6px 16px}.auth-card{gap:6px;padding:12px}.auth-card>svg,.auth-copy{display:none}.auth-card h1{font-size:24px}.auth-card form{gap:6px}.auth-card .field{gap:4px}.auth-card .input,.auth-card .button{min-height:40px;padding-bottom:8px;padding-top:8px}}.slot-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:8px;min-width:0}.slot-grid button{min-height:44px;border:1px solid var(--color-sand-300);border-radius:var(--radius-md);background:var(--color-cream-50);color:var(--color-charcoal-900);cursor:pointer;font-weight:700;min-width:0;transition:background var(--duration-fast) var(--ease-standard),border-color var(--duration-fast) var(--ease-standard),box-shadow var(--duration-fast) var(--ease-standard),color var(--duration-fast) var(--ease-standard),transform var(--duration-fast) var(--ease-standard)}.slot-grid button:hover{border-color:var(--color-barber-blue);transform:translateY(-1px)}.slot-grid button.selected{background:var(--color-charcoal-900);color:var(--color-cream-50);box-shadow:0 0 0 4px #1d4ed81f}.empty-state{margin:0;color:var(--color-taupe-500);font-weight:700}.booking-summary{position:sticky;top:92px}@media(max-width:800px){.booking-summary{position:static}}@media(prefers-reduced-motion:reduce){.slot-grid button:hover{transform:none}}.booking-layout{display:grid;grid-template-columns:minmax(0,2fr) minmax(280px,1fr);gap:20px;align-items:start;min-width:0}.booking-layout .card:first-child,.booking-layout label{display:grid;gap:10px}.booking-layout .card:first-child{gap:16px}.booking-panel{position:relative}select,input[type=date],input[type=datetime-local]{min-height:44px;border:1px solid var(--color-sand-300);border-radius:var(--radius-md);background:var(--color-surface);padding:10px 12px;transition:border-color var(--duration-fast) var(--ease-standard),box-shadow var(--duration-fast) var(--ease-standard)}select:focus,input[type=date]:focus,input[type=datetime-local]:focus{border-color:var(--color-barber-blue);box-shadow:0 0 0 3px #1d4ed824;outline:0}.success-state{color:var(--color-success);font-weight:800}.appointment-row{display:flex;align-items:center;justify-content:space-between;gap:16px;min-width:0}.actions,.inline-form{display:flex;flex-wrap:wrap;gap:8px;min-width:0}.appointment-row h2,.booking-summary h2{margin-top:0}.inline-form input{min-width:min(220px,100%)}@media(max-width:800px){.booking-layout{grid-template-columns:1fr}.appointment-row{align-items:flex-start;flex-direction:column}.actions,.inline-form{width:100%}.actions .button,.inline-form .button{flex:1 1 150px}}.dashboard-grid{display:grid;grid-template-columns:minmax(280px,380px) minmax(0,1fr);gap:20px;align-items:start;min-width:0}.panel-form{display:grid;gap:12px}.panel-form label{display:grid;gap:8px;font-weight:700}.checkbox-row{align-items:center;display:flex!important;gap:8px!important}.form-actions,.item-actions,.confirm-row{align-items:center;display:flex;flex-wrap:wrap;gap:8px;min-width:0}.availability-item{border-top:var(--border-soft);display:grid;gap:10px;grid-template-columns:minmax(0,1fr) auto;padding:12px 0;min-width:0}.availability-item p,.dashboard-grid h2{margin-top:0}.availability-item:first-of-type{border-top:0}.availability-editor,.confirm-row{grid-column:1 / -1}.feedback{border-radius:6px;font-weight:700;margin:0 0 12px;padding:10px 12px}.feedback.success{background:#e7f6ed;color:#1f6f3d}.feedback.error{background:#fbeaea;color:#9a2a2a}.muted{color:var(--color-taupe-500);margin-top:4px}.agenda-date{display:grid;gap:8px;font-weight:700;margin-bottom:16px;max-width:260px}.confirm-row{border:1px solid rgb(183 121 31 / 22%);border-radius:var(--radius-md);background:#b7791f1a;padding:10px}@media(max-width:860px){.dashboard-grid,.availability-item{grid-template-columns:1fr}.form-actions .button,.item-actions .button,.confirm-row .button{flex:1 1 140px}}:root{--color-cream-50: #ffffff;--color-cream-100: #f6f7fb;--color-cream-200: #e8ecf3;--color-sand-300: #c8d0dd;--color-taupe-500: #687286;--color-brown-600: #4b5668;--color-charcoal-800: #253041;--color-charcoal-900: #111827;--color-barber-red: #b42318;--color-barber-blue: #1d4ed8;--color-teal-500: #0f766e;--color-gold-500: #b7791f;--color-success: #15803d;--color-warning: #b7791f;--color-danger: #b42318;--color-info: #1d4ed8;--color-surface: #ffffff;--color-surface-raised: #fdfefe;--color-ring: #2563eb;--font-heading: "Playfair Display", Georgia, serif;--font-body: Inter, Arial, sans-serif;--radius-sm: 6px;--radius-md: 8px;--shadow-soft: 0 10px 28px rgb(17 24 39 / 10%);--shadow-lift: 0 16px 36px rgb(17 24 39 / 14%);--border-soft: 1px solid rgb(17 24 39 / 12%);--duration-fast: .14s;--duration-medium: .22s;--ease-standard: cubic-bezier(.2, 0, 0, 1)}*{box-sizing:border-box}body{margin:0;background:var(--color-cream-100);color:var(--color-charcoal-900);font-family:var(--font-body);line-height:1.5}a{color:inherit;text-decoration:none}button,input,select{font:inherit}:focus-visible{outline:3px solid var(--color-ring);outline-offset:2px}.app-shell{min-height:100vh;display:flex;flex-direction:column}.customer-layout{display:flex;flex:1;flex-direction:column}.customer-layout>main{flex:1}.container{width:min(1120px,calc(100% - 32px));margin:0 auto}.page{animation:page-enter var(--duration-medium) var(--ease-standard);padding:22px 0 30px}.grid{display:grid;gap:16px}.grid.two{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.barber-stripe{height:4px;background:repeating-linear-gradient(135deg,var(--color-barber-red) 0 8px,var(--color-cream-50) 8px 16px,var(--color-barber-blue) 16px 24px,var(--color-cream-50) 24px 32px)}.action-row{display:flex;flex-wrap:wrap;gap:10px}@keyframes page-enter{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:1ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:1ms!important}.page{animation:none}}
