:root{--brand-ivory:#fdfbf7;--brand-cream:#f5f0e8;--brand-beige:#e8e2d2;--brand-brown:#8b7355;--brand-dark:#2c2c2c;--brand-gray:#6b6b6b;--brand-light-gray:#f5f5f5;--spacing-xs:0.5rem;--spacing-sm:1rem;--spacing-md:1.5rem;--spacing-lg:2rem;--spacing-xl:3rem;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-full:9999px;--transition-fast:150ms ease-in-out;--transition-normal:300ms ease-in-out;--transition-slow:500ms ease-in-out}*{box-sizing:border-box;padding:0}*,body{margin:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#fdfbf7;background-color:var(--brand-ivory);color:#2c2c2c;color:var(--brand-dark);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}html{scroll-behavior:smooth}button{-webkit-tap-highlight-color:transparent;background:none;cursor:pointer;touch-action:manipulation}button,input,select,textarea{border:none;font-family:inherit}input,select,textarea{font-size:inherit;outline:none}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.fade-in{animation:fadeIn .3s ease-in-out;animation:fadeIn var(--transition-normal)}.slide-in{animation:slideIn .3s ease-in-out;animation:slideIn var(--transition-normal)}.landing-page{background-color:#fdfbf7;overflow-x:hidden;width:100%}.hero-section{align-items:center;background:linear-gradient(135deg,#fdfbf7,#f5f1e8);display:flex;flex-direction:column;justify-content:center;min-height:100vh;padding:2rem;position:relative}.hero-content{animation:fadeInUp 1s ease-out;max-width:800px;text-align:center}.hero-title{color:#2c2c2c;font-size:3.5rem;font-weight:300;letter-spacing:-.02em;line-height:1.3;margin-bottom:1.5rem}.hero-subtitle{color:#8b7355;font-size:1.25rem;font-weight:300;line-height:1.8;margin-bottom:3rem}.cta-button{background-color:#8b7355;border:none;border-radius:50px;box-shadow:0 4px 15px #8b735533;color:#fdfbf7;cursor:pointer;font-size:1.1rem;font-weight:500;letter-spacing:.05em;padding:1rem 3rem;transition:all .3s ease}.cta-button:hover{background-color:#725e45;box-shadow:0 6px 20px #8b73554d;transform:translateY(-2px)}.cta-button:active{transform:translateY(0)}.scroll-indicator{align-items:center;animation:fadeIn 2s ease-out 1s both;bottom:3rem;color:#8b7355;display:flex;flex-direction:column;font-size:.75rem;letter-spacing:.2em;position:absolute}.scroll-line{animation:scrollLine 2s ease-in-out infinite;background-color:#8b7355;height:40px;margin-top:.5rem;width:1px}.about-section{background-color:#fdfbf7;padding:6rem 2rem}.about-container{grid-gap:3rem;display:grid;gap:3rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin:0 auto;max-width:1200px}.about-item{background-color:#fff;border-radius:16px;box-shadow:0 2px 20px #0000000d;padding:2rem;text-align:center;transition:transform .3s ease,box-shadow .3s ease}.about-item:hover{box-shadow:0 8px 30px #0000001a;transform:translateY(-5px)}.about-icon{font-size:3rem;margin-bottom:1.5rem}.about-title{color:#2c2c2c;font-size:1.5rem;font-weight:500;margin-bottom:1rem}.about-description{color:#666;font-size:1rem;font-weight:300;line-height:1.8}.philosophy-section{background:linear-gradient(180deg,#e8e2d2,#fdfbf7);padding:6rem 2rem}.philosophy-content{margin:0 auto;max-width:800px;text-align:center}.philosophy-title{color:#2c2c2c;font-size:2.5rem;font-weight:300;letter-spacing:.05em;margin-bottom:2rem}.philosophy-text{color:#555;font-size:1.1rem;font-weight:300;line-height:2;margin-bottom:3rem}.cta-button-secondary{background-color:initial;border:2px solid #8b7355;border-radius:50px;color:#8b7355;cursor:pointer;font-size:1.1rem;font-weight:500;letter-spacing:.05em;padding:1rem 3rem;transition:all .3s ease}.cta-button-secondary:hover{background-color:#8b7355;box-shadow:0 6px 20px #8b73554d;color:#fdfbf7;transform:translateY(-2px)}.location-section{background-color:#fdfbf7;padding:6rem 2rem}.location-content{margin:0 auto;max-width:800px;text-align:center}.location-title{color:#2c2c2c;font-size:2.5rem;font-weight:300;letter-spacing:.05em;margin-bottom:2rem}.location-info{background-color:#fff;border-radius:16px;box-shadow:0 2px 20px #0000000d;padding:3rem}.location-address{color:#2c2c2c;font-size:1.2rem;font-weight:400;line-height:2;margin-bottom:1.5rem}.location-notice{color:#8b7355;font-size:.9rem;font-style:italic}.floating-button{background-color:#8b7355;border:none;border-radius:50px;bottom:2rem;box-shadow:0 4px 20px #8b735566;color:#fdfbf7;cursor:pointer;font-size:1rem;font-weight:500;letter-spacing:.05em;padding:1rem 2rem;position:fixed;right:2rem;transition:all .3s ease;z-index:1000}.floating-button:hover{background-color:#725e45;box-shadow:0 6px 25px #8b735580;transform:translateY(-3px)}.floating-button span{align-items:center;display:flex;gap:.5rem}@keyframes scrollLine{0%,to{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}}@media (max-width:768px){.hero-title{font-size:2.5rem}.hero-subtitle{font-size:1rem}.about-container{gap:2rem;grid-template-columns:1fr}.location-title,.philosophy-title{font-size:2rem}.philosophy-text{font-size:1rem}.floating-button{bottom:1rem;font-size:.9rem;padding:.875rem 1.5rem;right:1rem}.location-info{padding:2rem}}@media (max-width:480px){.hero-title{font-size:2rem}.cta-button,.cta-button-secondary{font-size:1rem;padding:.875rem 2rem}}.layout{background-color:var(--brand-ivory);justify-content:center;padding:var(--spacing-md)}.layout,.layout-container{display:flex;min-height:100vh}.layout-container{flex-direction:column;max-width:480px;width:100%}.layout-header{animation:fadeIn var(--transition-slow);padding:var(--spacing-xl) 0;text-align:center}.layout-logo{color:var(--brand-brown);font-size:2rem;font-weight:300;letter-spacing:.1em;margin-bottom:var(--spacing-xs)}.layout-tagline{color:var(--brand-gray);font-size:.875rem;font-weight:300;letter-spacing:.05em}.layout-main{animation:fadeIn var(--transition-normal);animation-delay:.2s;animation-fill-mode:both;flex:1 1}.layout-footer{border-top:1px solid var(--brand-beige);margin-top:var(--spacing-xl);padding:var(--spacing-lg) 0;text-align:center}.layout-footer p{color:var(--brand-gray);font-size:.75rem;font-weight:300}@media (max-width:768px){.layout-header{padding:var(--spacing-md) 0}}@media (max-width:480px){.layout{padding:var(--spacing-sm)}.layout-header{padding:var(--spacing-sm) 0}.layout-logo{font-size:1.75rem}.layout-tagline{font-size:.8rem}}.btn{align-items:center;border:none;cursor:pointer;display:inline-flex;font-family:inherit;font-weight:500;justify-content:center;outline:none;overflow:hidden;position:relative;text-align:center;transition:all var(--transition-fast)}.btn:active{transform:scale(.98)}.btn:disabled{cursor:not-allowed;opacity:.6}.btn-primary{background-color:var(--brand-brown);box-shadow:0 4px 12px #8b735533}.btn-primary:hover:not(:disabled){background-color:#7a6349;box-shadow:0 6px 16px #8b73554d;transform:translateY(-2px)}.btn-secondary{background-color:var(--brand-beige);color:var(--brand-dark)}.btn-secondary:hover:not(:disabled){background-color:#ddd7c5;transform:translateY(-2px)}.btn-outline{background-color:initial;border:2px solid var(--brand-brown);color:var(--brand-brown)}.btn-outline:hover:not(:disabled){background-color:var(--brand-brown);color:#fff}.btn-large{border-radius:var(--radius-lg);font-size:1rem;min-height:56px;padding:var(--spacing-md) var(--spacing-lg)}.btn-medium{border-radius:var(--radius-md);font-size:.875rem;min-height:44px;padding:var(--spacing-sm) var(--spacing-md)}.btn-small{border-radius:var(--radius-sm);font-size:.8rem;min-height:36px;padding:var(--spacing-xs) var(--spacing-sm)}.btn-full{width:100%}.btn-loading{pointer-events:none}.btn-spinner{animation:spin .6s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:20px;width:20px}.btn:before{background:#ffffff4d;border-radius:50%;content:"";height:0;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);transition:width .6s,height .6s;width:0}.btn:active:before{height:300px;width:300px}.calendar{animation:fadeIn var(--transition-normal);background-color:#fff;border-radius:var(--radius-lg);box-shadow:0 4px 20px #0000000d;padding:var(--spacing-lg)}.calendar-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:var(--spacing-lg)}.calendar-title{color:var(--brand-dark);font-size:1.125rem;font-weight:500;letter-spacing:.02em}.calendar-nav-button{align-items:center;background-color:var(--brand-beige);border:none;border-radius:var(--radius-md);color:var(--brand-brown);cursor:pointer;display:flex;font-size:1.5rem;height:40px;justify-content:center;transition:all var(--transition-fast);width:40px}.calendar-nav-button:hover{background-color:var(--brand-brown);color:#fff;transform:scale(1.05)}.calendar-nav-button:active{transform:scale(.95)}.calendar-weekdays{grid-gap:var(--spacing-xs);display:grid;gap:var(--spacing-xs);grid-template-columns:repeat(7,1fr);margin-bottom:var(--spacing-sm)}.calendar-weekday{color:var(--brand-gray);font-size:.875rem;font-weight:600;padding:var(--spacing-xs);text-align:center}.calendar-weekday.sunday{color:#d84315}.calendar-days{grid-gap:var(--spacing-xs);display:grid;gap:var(--spacing-xs);grid-template-columns:repeat(7,1fr)}.calendar-day{align-items:center;aspect-ratio:1;background-color:initial;border:2px solid #0000;border-radius:var(--radius-sm);cursor:pointer;display:flex;flex-direction:column;justify-content:center;min-height:50px;position:relative;transition:all var(--transition-fast)}.calendar-day.empty{cursor:default;pointer-events:none}.calendar-day-number{color:var(--brand-dark);font-size:.95rem;font-weight:500}.calendar-day.available:hover{background-color:var(--brand-beige);transform:scale(1.05)}.calendar-day.selected{background-color:var(--brand-brown);border-color:var(--brand-brown)}.calendar-day.selected .calendar-day-number{color:#fff;font-weight:600}.calendar-day.today{border-color:var(--brand-brown)}.today-indicator{color:var(--brand-brown);font-size:.625rem;font-weight:600;margin-top:2px}.calendar-day.selected .today-indicator{color:#fff}.calendar-day.disabled{cursor:not-allowed;opacity:.3;pointer-events:none}.calendar-day.disabled.sunday .calendar-day-number,.calendar-day.sunday .calendar-day-number{color:#d84315}@media (max-width:480px){.calendar{padding:var(--spacing-sm)}.calendar-header{margin-bottom:var(--spacing-sm)}.calendar-days,.calendar-weekdays{gap:4px}.calendar-day{min-height:38px}.calendar-day-number{font-size:.8rem}.calendar-title{font-size:1rem}.today-indicator{font-size:.55rem}.calendar-weekday{font-size:.75rem;padding:2px 0}.calendar-nav-button{font-size:1.2rem;height:34px;width:34px}}.time-slots{animation:slideIn var(--transition-normal);margin-top:var(--spacing-lg)}.time-slots-title{color:var(--brand-dark);font-size:1rem;font-weight:500;letter-spacing:.02em;margin-bottom:var(--spacing-xs)}.time-slots-subtitle{color:var(--brand-gray);font-size:.85rem;font-weight:400;margin-bottom:var(--spacing-md)}.time-slots-grid{grid-gap:var(--spacing-sm);display:grid;gap:var(--spacing-sm);grid-template-columns:repeat(4,1fr)}.time-slot-button{align-items:center;background-color:#fff;border:2px solid var(--brand-beige);border-radius:var(--radius-md);cursor:pointer;display:flex;flex-direction:column;gap:1px;justify-content:center;min-height:68px;padding:var(--spacing-sm) var(--spacing-xs);position:relative;transition:all var(--transition-fast)}.time-slot-button:hover:not(.disabled){background-color:var(--brand-beige);border-color:var(--brand-brown);box-shadow:0 4px 12px #8b735526;transform:translateY(-2px)}.time-slot-button:active:not(.disabled){transform:translateY(0)}.time-slot-button.selected{background-color:var(--brand-brown);border-color:var(--brand-brown);box-shadow:0 4px 16px #8b73554d}.time-slot-period{color:var(--brand-gray);font-size:.7rem;font-weight:500;letter-spacing:.03em}.time-slot-button.selected .time-slot-period{color:#fffc}.time-slot-time{color:var(--brand-dark);font-size:1rem;font-weight:600;margin-bottom:1px}.time-slot-button.selected .time-slot-time{color:#fff}.time-slot-range{color:var(--brand-gray);font-size:.75rem;font-weight:400}.time-slot-button.selected .time-slot-range{color:#ffffffe6}.time-slot-badge{background-color:#e57373;border-radius:10px;font-size:.65rem;font-weight:600;padding:2px 6px}.time-slot-badge,.time-slot-check{color:#fff;position:absolute;right:6px;top:6px}.time-slot-check{font-size:.9rem;font-weight:700}.time-slot-button.disabled{background-color:#f5f5f5;border-color:#e0e0e0;cursor:not-allowed}.time-slot-button.disabled:hover{background-color:#f5f5f5;border-color:#e0e0e0;box-shadow:none;transform:none}.time-slot-button.disabled .time-slot-range,.time-slot-button.disabled .time-slot-time{color:#bdbdbd}.time-slots-legend{border-top:1px solid var(--brand-beige);display:flex;gap:var(--spacing-lg);justify-content:center;margin-top:var(--spacing-md);padding-top:var(--spacing-sm)}.legend-item{color:var(--brand-gray);font-size:.8rem;gap:6px}.legend-dot{border-radius:50%;height:10px;width:10px}.legend-dot.available{background-color:var(--brand-brown)}.legend-dot.unavailable{background-color:#e0e0e0}.time-slots-loading{align-items:center;color:var(--brand-gray);display:flex;flex-direction:column;justify-content:center;padding:var(--spacing-xl)}.time-slots-loading .loading-spinner{animation:spin 1s linear infinite;border:3px solid var(--brand-beige);border-radius:50%;border-top-color:var(--brand-brown);height:32px;margin-bottom:var(--spacing-sm);width:32px}.time-slots-loading p{font-size:.9rem}.time-slots-error{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:var(--spacing-xl);text-align:center}.time-slots-error .error-icon{font-size:2rem;margin-bottom:var(--spacing-sm)}.time-slots-error p{color:#e57373;font-size:.9rem;margin-bottom:var(--spacing-md)}.time-slots-error .retry-btn{background-color:var(--brand-brown);border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer;font-size:.9rem;padding:var(--spacing-sm) var(--spacing-lg);transition:background-color var(--transition-fast)}.time-slots-error .retry-btn:hover{background-color:var(--brand-dark)}.time-slots-empty{align-items:center;background-color:#fff8e1;border-radius:var(--radius-md);display:flex;flex-direction:column;justify-content:center;padding:var(--spacing-xl);text-align:center}.time-slots-empty .empty-icon{font-size:2.5rem;margin-bottom:var(--spacing-sm)}.time-slots-empty .empty-title{color:var(--brand-dark);font-size:1rem;font-weight:600;margin-bottom:var(--spacing-xs)}.time-slots-empty .empty-subtitle{color:var(--brand-gray);font-size:.85rem}.time-slots-message{color:var(--brand-gray);font-size:.95rem;padding:var(--spacing-lg);text-align:center}@media (max-width:768px){.time-slots{margin-top:var(--spacing-md)}.time-slots-grid{gap:6px;grid-template-columns:repeat(4,1fr)}.time-slot-button{min-height:60px;padding:6px 4px}.time-slot-period{font-size:.6rem}.time-slot-time{font-size:.9rem}.time-slot-range{font-size:.65rem}}@media (max-width:380px){.time-slots-grid{gap:5px;grid-template-columns:repeat(3,1fr)}.time-slot-button{min-height:56px;padding:5px 3px}.time-slot-time{font-size:.85rem}.time-slots-legend{gap:var(--spacing-md)}}.reservation-page{animation:fadeIn var(--transition-normal);position:relative}.progress-indicator{align-items:center;display:flex;justify-content:center;margin-bottom:var(--spacing-xl);padding:var(--spacing-lg) 0}.progress-step{align-items:center;display:flex;flex-direction:column;gap:var(--spacing-xs);opacity:.4;transition:opacity var(--transition-normal)}.progress-step.active,.progress-step.completed{opacity:1}.progress-circle{align-items:center;background-color:var(--brand-beige);border-radius:50%;color:var(--brand-gray);display:flex;font-size:1.125rem;font-weight:600;height:48px;justify-content:center;transition:all var(--transition-normal);width:48px}.progress-step.active .progress-circle{background-color:var(--brand-brown);box-shadow:0 4px 12px #8b73554d;color:#fff;transform:scale(1.1)}.progress-step.completed .progress-circle{background-color:#4caf50;color:#fff}.progress-label{color:var(--brand-gray);font-size:.875rem;font-weight:500;white-space:nowrap}.progress-step.active .progress-label{color:var(--brand-brown);font-weight:600}.progress-line{background-color:var(--brand-beige);height:2px;margin:0 var(--spacing-sm);margin-bottom:28px;transition:background-color var(--transition-normal);width:50px}.progress-line.active{background-color:#4caf50}.step-container{animation:fadeIn var(--transition-normal)}.step-header{margin-bottom:var(--spacing-xl);text-align:center}.step-title{color:var(--brand-dark);font-size:1.5rem;font-weight:400;letter-spacing:.02em;margin-bottom:var(--spacing-sm)}.step-description{color:var(--brand-gray);font-size:.95rem;font-weight:300}.step-actions{animation:slideIn var(--transition-normal);margin-top:var(--spacing-xl)}.step-actions-group{grid-gap:var(--spacing-md);display:grid;gap:var(--spacing-md);grid-template-columns:1fr 2fr;margin-top:var(--spacing-xl)}.reservation-summary{align-items:center;background-color:var(--brand-cream);border:1px solid var(--brand-beige);border-radius:var(--radius-md);display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);padding:var(--spacing-md) var(--spacing-lg)}.summary-icon{font-size:2rem}.summary-content{flex:1 1}.summary-title{color:var(--brand-gray);font-size:.8rem;font-weight:500;margin-bottom:4px}.summary-details{display:flex;flex-wrap:wrap;gap:var(--spacing-md)}.summary-date{color:var(--brand-dark)}.summary-date,.summary-time{font-size:1rem;font-weight:600}.summary-edit-btn,.summary-time{color:var(--brand-brown)}.summary-edit-btn{background:none;border:1px solid var(--brand-brown);border-radius:var(--radius-sm);cursor:pointer;font-size:.8rem;padding:6px 12px;transition:all var(--transition-fast)}.summary-edit-btn:hover{background-color:var(--brand-brown);color:#fff}.reservation-form{background-color:#fff;border-radius:var(--radius-lg);box-shadow:0 4px 20px #0000000d;padding:var(--spacing-xl)}.input-wrapper{margin-bottom:var(--spacing-lg)}.input-label{color:var(--brand-dark);display:block;font-size:.9rem;font-weight:500;margin-bottom:var(--spacing-xs)}.input-required{color:#e57373;margin-left:4px}.input-optional{color:var(--brand-gray);font-size:.8rem;font-weight:400;margin-left:4px}.input-field{background-color:#fff;border:2px solid var(--brand-beige);border-radius:var(--radius-md);color:var(--brand-dark);font-size:1rem;padding:var(--spacing-md);transition:border-color var(--transition-fast);width:100%}.input-field:focus{border-color:var(--brand-brown);outline:none}.input-field.error{border-color:#e57373}.input-field:disabled{background-color:#f5f5f5;cursor:not-allowed}.select-field{-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12'%3E%3Cpath fill='%238B7355' d='M6 8 1 3h10z'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;cursor:pointer;padding-right:36px}.textarea-field{font-family:inherit;min-height:80px;resize:vertical}.input-error-message{color:#e57373;display:block;font-size:.8rem;margin-top:var(--spacing-xs)}.char-count{color:var(--brand-gray);font-size:.75rem;margin-top:4px}.phone-input-row{grid-gap:8px;align-items:center;display:grid;gap:8px;grid-template-columns:1fr auto}.phone-input-row .input-field{width:100%}.phone-input-row .btn{white-space:nowrap}.phone-verified-section{background-color:#e8f5e9;border-radius:var(--radius-md);padding:var(--spacing-md)}.verified-phone{align-items:center;display:flex;gap:var(--spacing-md)}.verified-label{color:var(--brand-gray);font-size:.85rem}.verified-value{color:var(--brand-dark);flex:1 1;font-size:1rem;font-weight:600}.change-phone-btn{background:none;border:1px solid var(--brand-brown);border-radius:var(--radius-sm);color:var(--brand-brown);cursor:pointer;font-size:.8rem;padding:4px 12px;transition:all var(--transition-fast)}.change-phone-btn:hover{background-color:var(--brand-brown);color:#fff}.welcome-message{align-items:flex-start;animation:slideIn var(--transition-normal);border-radius:var(--radius-md);display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);padding:var(--spacing-md) var(--spacing-lg)}.welcome-emoji{font-size:1.5rem}.welcome-text{display:flex;flex-direction:column;gap:4px}.welcome-greeting{font-size:1rem;font-weight:600}.visit-count{font-size:.85rem;font-weight:400}.deposit-notice{font-size:.8rem;font-weight:400;opacity:.8}.welcome-message.existing{background:linear-gradient(135deg,#e8f5e9,#c8e6c9);border:1px solid #a5d6a7;color:#2e7d32}.welcome-message.new{background:linear-gradient(135deg,#fff3e0,#ffe0b2);border:1px solid #ffcc80;color:#e65100}.treatment-info{background-color:var(--brand-cream);border-radius:var(--radius-sm);display:flex;gap:var(--spacing-lg);margin-top:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md)}.treatment-detail{display:flex;flex-direction:column;gap:2px}.treatment-label{color:var(--brand-gray);font-size:.75rem}.treatment-value{color:var(--brand-dark);font-size:.9rem;font-weight:600}.treatment-value.price{color:var(--brand-brown)}.submit-message{align-items:center;animation:slideIn var(--transition-normal);border-radius:var(--radius-md);display:flex;font-size:.9rem;font-weight:500;gap:var(--spacing-sm);justify-content:center;margin-bottom:var(--spacing-lg);padding:var(--spacing-md)}.submit-message-error{background-color:#ffebee;border:1px solid #ffcdd2;color:#c62828}.submit-message .error-icon{font-size:1.2rem}.completion-container{text-align:center}.completion-header{margin-bottom:var(--spacing-xl)}.completion-icon{animation:bounceIn .5s ease;font-size:4rem;margin-bottom:var(--spacing-md)}@keyframes bounceIn{0%{opacity:0;transform:scale(0)}50%{transform:scale(1.2)}to{opacity:1;transform:scale(1)}}.completion-title{color:var(--brand-dark);font-size:1.5rem;font-weight:600;margin-bottom:var(--spacing-sm)}.completion-subtitle{color:var(--brand-gray);font-size:.95rem}.completion-details{background-color:#fff;border-radius:var(--radius-lg);box-shadow:0 4px 20px #0000000d;margin-bottom:var(--spacing-xl);padding:var(--spacing-xl);text-align:left}.details-title{border-bottom:1px solid var(--brand-beige);color:var(--brand-dark);font-size:1rem;font-weight:600;margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-sm)}.details-grid{grid-gap:var(--spacing-md);display:grid;gap:var(--spacing-md)}.detail-item{align-items:center;border-bottom:1px solid var(--brand-cream);display:flex;justify-content:space-between;padding:var(--spacing-sm) 0}.detail-item:last-child{border-bottom:none}.detail-label{color:var(--brand-gray);font-size:.9rem}.detail-value{color:var(--brand-dark);font-size:.95rem;font-weight:600}.detail-value.highlight{color:var(--brand-brown);font-size:1.1rem}.detail-item.deposit-info{border-bottom:none;border-radius:var(--radius-sm);margin:var(--spacing-sm) calc(var(--spacing-md)*-1)}.deposit-notice-box,.detail-item.deposit-info{background-color:#fff8e1;padding:var(--spacing-md)}.deposit-notice-box{border:1px solid #ffe082;border-radius:var(--radius-md);display:flex;gap:var(--spacing-md);margin-top:var(--spacing-lg)}.deposit-notice-box .notice-icon{font-size:1.5rem}.deposit-notice-box .notice-content{flex:1 1}.deposit-notice-box .notice-content strong{color:#f57c00;display:block;margin-bottom:var(--spacing-xs)}.deposit-notice-box .notice-content p{color:#8d6e63;font-size:.85rem;line-height:1.5;margin:0}.completion-actions{margin:0 auto;max-width:300px}.reservation-info{animation:fadeIn var(--transition-slow);animation-delay:.4s;animation-fill-mode:both;background-color:var(--brand-beige);border-radius:var(--radius-md);margin-top:var(--spacing-xl);padding:var(--spacing-lg)}.info-title{color:var(--brand-dark);font-size:1rem;font-weight:500;letter-spacing:.02em;margin-bottom:var(--spacing-md)}.info-list{list-style:none;margin:0;padding:0}.info-list li{color:var(--brand-gray);font-size:.875rem;line-height:1.6;margin-bottom:var(--spacing-sm);padding-left:var(--spacing-md);position:relative}.info-list li:last-child{color:var(--brand-brown);font-weight:500;margin-bottom:0;margin-top:var(--spacing-md)}.info-list li:before{color:var(--brand-brown);content:"•";font-weight:700;left:0;position:absolute}.info-list li:last-child:before{content:"📞"}@media (max-width:768px){.reservation-summary{flex-wrap:wrap}.summary-edit-btn{margin-top:var(--spacing-sm);text-align:center;width:100%}}@media (max-width:480px){.step-title{font-size:1.25rem}.step-description{font-size:.875rem}.reservation-form{padding:var(--spacing-lg)}.reservation-info{padding:var(--spacing-md)}.progress-circle{font-size:.9rem;height:36px;width:36px}.progress-line{margin:0 var(--spacing-xs);margin-bottom:20px;width:30px}.progress-label{font-size:.7rem}.step-actions-group{grid-template-columns:1fr}.treatment-info{flex-direction:column;gap:var(--spacing-sm)}.detail-item{align-items:flex-start;flex-direction:column;gap:4px}.completion-icon{font-size:3rem}.completion-title{font-size:1.25rem}}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.reservation-page.mobile-view{display:flex;flex-direction:column;min-height:calc(100vh - 120px);padding-bottom:calc(80px + env(safe-area-inset-bottom, 0px))}.mobile-progress{align-items:center;background-color:#fff;border-bottom:1px solid var(--brand-beige);display:flex;gap:var(--spacing-md);padding:var(--spacing-md);padding-top:calc(var(--spacing-md) + env(safe-area-inset-top, 0px));position:-webkit-sticky;position:sticky;top:0;z-index:10}.mobile-progress-bar{background-color:var(--brand-beige);border-radius:3px;flex:1 1;height:6px;overflow:hidden}.mobile-progress-fill{background:linear-gradient(90deg,var(--brand-brown) 0,#a68b6a 100%);border-radius:3px;height:100%;transition:width .4s cubic-bezier(.4,0,.2,1)}.mobile-progress-text{align-items:center;display:flex;gap:2px;justify-content:center;min-width:40px}.mobile-progress-current{color:var(--brand-brown);font-size:1.1rem;font-weight:700}.mobile-progress-divider,.mobile-progress-total{color:var(--brand-gray);font-size:.9rem}.mobile-step-container{-webkit-overflow-scrolling:touch;display:flex;flex:1 1;flex-direction:column;min-height:0;overflow-y:auto;overscroll-behavior-y:contain;padding:var(--spacing-md)}.mobile-step-content{animation:mobileSlideIn .35s cubic-bezier(.4,0,.2,1);flex:1 1}.mobile-step-content.slide-next{animation:mobileSlideInNext .35s cubic-bezier(.4,0,.2,1)}.mobile-step-content.slide-prev{animation:mobileSlideInPrev .35s cubic-bezier(.4,0,.2,1)}@keyframes mobileSlideInNext{0%{opacity:0;transform:translateX(30px)}to{opacity:1;transform:translateX(0)}}@keyframes mobileSlideInPrev{0%{opacity:0;transform:translateX(-30px)}to{opacity:1;transform:translateX(0)}}.mobile-step-header{margin-bottom:var(--spacing-lg);padding-top:var(--spacing-sm);text-align:center}.mobile-step-title{color:var(--brand-dark);font-size:1.4rem;font-weight:600;letter-spacing:.01em;margin-bottom:var(--spacing-xs)}.mobile-step-description{color:var(--brand-gray);font-size:.9rem;font-weight:400}.mobile-selected-info{align-items:center;background-color:var(--brand-cream);border:1px solid var(--brand-beige);border-radius:var(--radius-md);display:flex;justify-content:space-between;margin-bottom:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md)}.mobile-selected-label{color:var(--brand-gray);font-size:.8rem}.mobile-selected-value{color:var(--brand-brown);font-size:.95rem;font-weight:600}.mobile-form-section{background-color:#fff;border-radius:var(--radius-lg);box-shadow:0 2px 12px #0000000f;padding:var(--spacing-lg)}.mobile-form-section .input-wrapper{margin-bottom:var(--spacing-lg)}.mobile-form-section .input-wrapper:last-child{margin-bottom:0}.input-field.mobile-input{border-radius:var(--radius-lg);font-size:1.1rem;padding:var(--spacing-md) var(--spacing-lg)}.treatment-step-header{margin-bottom:10px!important}.welcome-inline{align-items:center;display:flex;font-size:.82rem;gap:4px;margin-top:2px}.welcome-greeting-sm{color:var(--brand-brown);font-weight:500}.mobile-treatment-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:1fr 1fr}.mobile-treatment-card{align-items:flex-start;background-color:#fff;border:2px solid var(--brand-beige);border-radius:var(--radius-md);cursor:pointer;display:flex;flex-direction:column;gap:3px;min-height:76px;padding:10px;position:relative;text-align:left;transition:all .15s ease;width:100%}.mobile-treatment-card:active{transform:scale(.97)}.mobile-treatment-card.selected{background-color:#8b73550f;border-color:var(--brand-brown);box-shadow:0 2px 8px #8b73552e}.mobile-treatment-card.consult{border-style:dashed}.treatment-card-category{background-color:var(--brand-beige);border-radius:6px;color:var(--brand-gray);font-size:.62rem;line-height:1.6;padding:1px 5px;white-space:nowrap}.mobile-treatment-card.selected .treatment-card-category{background-color:#8b735526;color:var(--brand-brown)}.treatment-card-name{color:var(--brand-dark);flex:1 1;font-size:.82rem;font-weight:600;line-height:1.3;word-break:keep-all}.mobile-treatment-card.selected .treatment-card-name,.treatment-card-price{color:var(--brand-brown)}.treatment-card-price{font-size:.82rem;font-weight:700;margin-top:auto}.treatment-card-consult{color:var(--brand-gray);font-size:.82rem}.treatment-card-check{align-items:center;background-color:var(--brand-brown);border-radius:50%;color:#fff;display:flex;font-size:.65rem;font-weight:700;height:18px;justify-content:center;position:absolute;right:7px;top:7px;width:18px}.mobile-treatment-list{display:flex;flex-direction:column;gap:8px}.treatment-item-header{align-items:center;display:flex;gap:8px;justify-content:space-between}.treatment-item-name{color:var(--brand-dark);flex:1 1;font-size:.9rem;font-weight:600;min-width:0}.treatment-item-category{background-color:var(--brand-beige);border-radius:8px;color:var(--brand-gray);flex-shrink:0;font-size:.65rem;padding:1px 6px;white-space:nowrap}.treatment-item-details{display:flex;gap:var(--spacing-md)}.treatment-item-price{color:var(--brand-brown);font-size:.85rem;font-weight:600}.treatment-item-consult-text{color:var(--brand-gray);font-size:.8rem}.treatment-item-check{align-items:center;background-color:var(--brand-brown);border-radius:50%;color:#fff;display:flex;font-size:.75rem;font-weight:700;height:22px;justify-content:center;position:absolute;right:10px;top:50%;transform:translateY(-50%);width:22px}.mobile-reservation-summary{background-color:#fff;border-radius:var(--radius-lg);box-shadow:0 2px 12px #0000000f;margin-bottom:var(--spacing-lg);padding:var(--spacing-lg)}.mobile-reservation-summary .summary-row{align-items:center;border-bottom:1px solid var(--brand-cream);display:flex;justify-content:space-between;padding:var(--spacing-sm) 0}.mobile-reservation-summary .summary-row:last-child{border-bottom:none}.mobile-reservation-summary .summary-label{color:var(--brand-gray);font-size:.9rem}.mobile-reservation-summary .summary-value{color:var(--brand-dark);font-size:.95rem;font-weight:600;text-align:right}.mobile-reservation-summary .summary-value.price{color:var(--brand-brown);font-size:1.1rem}.mobile-reservation-summary .summary-row.highlight{background-color:var(--brand-cream)}.mobile-reservation-summary .summary-row.deposit,.mobile-reservation-summary .summary-row.highlight{border-bottom:none;margin:var(--spacing-xs) calc(var(--spacing-lg)*-1);padding:var(--spacing-md) var(--spacing-lg)}.mobile-reservation-summary .summary-row.deposit{background-color:#fff8e1;border-radius:0 0 var(--radius-lg) var(--radius-lg);margin-bottom:calc(var(--spacing-lg)*-1)}.mobile-bottom-nav{background-color:#fff;border-top:1px solid var(--brand-beige);bottom:0;box-shadow:0 -4px 20px #00000014;display:flex;gap:var(--spacing-sm);left:0;padding:var(--spacing-md);padding-bottom:calc(var(--spacing-md) + env(safe-area-inset-bottom, 0px));position:fixed;right:0;z-index:100}.mobile-bottom-nav button{flex:1 1}.mobile-bottom-nav .mobile-next-btn,.mobile-bottom-nav .mobile-submit-btn{flex:2 1}.welcome-message.compact{margin-bottom:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md)}.welcome-message.compact .welcome-emoji{font-size:1.2rem}.welcome-message.compact .welcome-greeting{font-size:.9rem}.welcome-message.compact .visit-count{font-size:.8rem}@media (max-width:768px){.reservation-page.desktop-view{display:none}.reservation-page.mobile-view{display:flex}.mobile-step-content .calendar{box-shadow:none;margin:0;padding:var(--spacing-sm)}.mobile-step-content .mobile-step-header{margin-bottom:var(--spacing-md)}.mobile-step-content .time-slots{margin-top:0}.mobile-step-content .completion-container{padding:0}.mobile-step-content .completion-details{margin-bottom:var(--spacing-lg)}.mobile-step-content .completion-actions{max-width:100%}}@media (min-width:769px){.reservation-page.mobile-view{display:none}.reservation-page.desktop-view{display:block}}.login-page{align-items:center;background:linear-gradient(135deg,#fdfbf7,#f5f1e8);display:flex;justify-content:center;min-height:100vh;padding:2rem}.login-container{animation:fadeInUp .6s ease-out;background-color:#fff;border-radius:20px;box-shadow:0 10px 40px #0000001a;max-width:420px;padding:3rem;width:100%}.login-header{margin-bottom:2.5rem;text-align:center}.login-logo{color:#2c2c2c;font-size:2rem;font-weight:300;letter-spacing:.05em;margin-bottom:.5rem}.login-subtitle{color:#8b7355;font-size:.95rem;font-weight:500;letter-spacing:.05em}.login-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{gap:.5rem}.form-group label{color:#2c2c2c;font-size:.9rem;letter-spacing:.02em}.form-group input{background-color:#fdfbf7;border:2px solid #e8e2d2;border-radius:8px;color:#2c2c2c;font-size:1rem;padding:.875rem 1rem;transition:all .3s ease}.form-group input:focus{background-color:#fff;border-color:#8b7355;box-shadow:0 0 0 3px #8b73551a;outline:none}.form-group input:disabled{cursor:not-allowed;opacity:.6}.form-group input::placeholder{color:#b8b0a0}.form-options{align-items:center;display:flex;justify-content:space-between;margin-top:-.5rem}.checkbox-label{color:#666;font-size:.875rem;gap:.5rem;-webkit-user-select:none;user-select:none}.checkbox-label input[type=checkbox]{accent-color:#8b7355;height:18px;width:18px}.checkbox-label:hover span{color:#8b7355}.login-button{background-color:#8b7355;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;letter-spacing:.05em;margin-top:.5rem;padding:1rem;transition:all .3s ease;width:100%}.login-button:hover:not(:disabled){background-color:#725e45;box-shadow:0 6px 20px #8b73554d;transform:translateY(-2px)}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{cursor:not-allowed;opacity:.6}.back-home-button{background-color:initial;border:2px solid #e8e2d2;border-radius:8px;color:#8b7355;cursor:pointer;font-size:.95rem;font-weight:500;letter-spacing:.02em;padding:.875rem;transition:all .3s ease;width:100%}.back-home-button:hover:not(:disabled){background-color:#f5f1e8;border-color:#8b7355;color:#725e45}.back-home-button:disabled{cursor:not-allowed;opacity:.6}.error-message{align-items:center;animation:shake .5s ease;background-color:#fff3f3;border:1px solid #ffb4ab;border-radius:8px;color:#b3261e;display:flex;font-size:.875rem;gap:.5rem;padding:.875rem}.login-footer{margin-top:2rem;text-align:center}.test-info{background-color:#fff9f0;border:1px solid #ffe4cc;border-radius:8px;color:#8b7355;font-size:.8rem;padding:.75rem}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes shake{0%,to{transform:translateX(0)}25%{transform:translateX(-5px)}75%{transform:translateX(5px)}}@media (max-width:480px){.login-page{padding:1rem}.login-container{padding:2rem 1.5rem}.login-logo{font-size:1.75rem}.login-subtitle{font-size:.85rem}.form-group input{font-size:.95rem;padding:.75rem .875rem}.back-home-button,.login-button{font-size:.95rem;padding:.875rem}}.dashboard-content{display:flex;flex-direction:column;gap:2rem;padding:2rem}.welcome-card{background:linear-gradient(135deg,#8b7355,#725e45);border-radius:16px;box-shadow:0 4px 20px #8b735533;color:#fff;padding:2.5rem}.welcome-title{font-size:1.75rem;font-weight:400;letter-spacing:.02em;margin:0 0 1rem}.welcome-message{font-size:1rem;font-weight:300;line-height:1.7;margin:0;opacity:.95}.stats-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.stat-card{align-items:center;background-color:#fff;box-shadow:0 2px 12px #0000000d;display:flex;gap:1.25rem;padding:1.75rem;transition:transform .3s ease,box-shadow .3s ease}.stat-card.clickable{cursor:pointer}.stat-card:hover{box-shadow:0 4px 20px #0000001a;transform:translateY(-3px)}.stat-card.clickable:hover{background-color:#fdfbf7}.stat-icon{font-size:2.5rem}.stat-icon,.stat-icon-wrapper{align-items:center;background-color:#f5f1e8;border-radius:12px;display:flex;height:60px;justify-content:center;width:60px}.stat-icon-wrapper{flex-shrink:0}.stat-icon-lucide{color:#8b7355;flex-shrink:0}.stat-card:hover .stat-icon-lucide{color:#725e45}.stat-info{flex:1 1}.stat-label{font-size:.875rem;font-weight:500;margin:0 0 .5rem}.stat-value{color:#2c2c2c;font-size:1.75rem;margin:0}.section-title{color:#2c2c2c;font-size:1.25rem;font-weight:500;letter-spacing:.02em;margin:0 0 1.5rem}.quick-actions{background-color:#fff;border-radius:16px;box-shadow:0 2px 12px #0000000d;padding:2rem}.actions-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.action-button{align-items:center;background-color:#f5f1e8;border-radius:12px;display:flex;flex-direction:column;gap:.75rem;padding:1.5rem}.action-button:hover{background-color:#8b7355;box-shadow:0 4px 15px #8b735533;transform:translateY(-3px)}.action-button:hover .action-icon{transform:scale(1.1)}.action-button:hover .action-text{color:#fff}.action-icon{font-size:2rem;transition:transform .3s ease}.action-icon-lucide{color:#8b7355;flex-shrink:0;transition:all .3s ease}.action-button:hover .action-icon-lucide{color:#fff;transform:scale(1.1)}.action-text{color:#2c2c2c;font-size:.95rem;font-weight:500;transition:color .3s ease}.recent-activity{background-color:#fff;border-radius:16px;box-shadow:0 2px 12px #0000000d;padding:2rem}.activity-list{display:flex;flex-direction:column;gap:1.25rem}.activity-item{align-items:flex-start;background-color:#fdfbf7;border-left:3px solid #8b7355;gap:1rem;padding:1rem}.activity-icon,.activity-item{border-radius:8px;display:flex}.activity-icon{font-size:1.5rem}.activity-icon,.activity-icon-wrapper{align-items:center;background-color:#fff;height:40px;justify-content:center;width:40px}.activity-icon-wrapper{border-radius:8px;display:flex;flex-shrink:0}.activity-icon-lucide{color:#8b7355;flex-shrink:0}.activity-info{flex:1 1}.activity-text{color:#2c2c2c;font-size:.95rem;line-height:1.5;margin:0 0 .25rem}.activity-time{color:#999;font-size:.8rem;margin:0}.error-message,.loading-message{color:#8b7355;font-size:1rem;padding:3rem;text-align:center}.error-message{color:#d32f2f}@media (max-width:1024px){.actions-grid,.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.dashboard-content{padding:1.5rem}.welcome-card{padding:2rem}.welcome-title{font-size:1.5rem}.actions-grid,.stats-grid{grid-template-columns:1fr}}@media (max-width:480px){.dashboard-content{padding:1rem}.quick-actions,.recent-activity,.welcome-card{padding:1.5rem}}.modal-overlay{align-items:center;animation:fadeIn .2s ease-out;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-content{animation:slideUp .3s ease-out;background-color:#fff;border-radius:16px;box-shadow:0 10px 40px #0003;max-height:90vh;max-width:500px;overflow-y:auto;width:90%}.modal-header{align-items:center;border-bottom:1px solid #e8e2d2;display:flex;justify-content:space-between;padding:1.5rem 2rem}.modal-title{color:#2c2c2c;font-size:1.5rem;font-weight:500;margin:0}.modal-close{align-items:center;background:none;border:none;border-radius:50%;color:#666;cursor:pointer;display:flex;justify-content:center;padding:.5rem;transition:all .3s ease}.modal-close:hover{background-color:#f5f1e8;color:#2c2c2c}.modal-body{padding:2rem}.status-badge{border-radius:20px;color:#fff;display:inline-block;font-size:.9rem;font-weight:600;margin-bottom:1.5rem;padding:.5rem 1rem}.info-section{display:flex;flex-direction:column;gap:1.25rem;margin-bottom:2rem}.info-item{align-items:flex-start;background-color:#fdfbf7;border-left:3px solid #8b7355;border-radius:12px;display:flex;gap:1rem;padding:1rem}.info-icon{align-items:center;background-color:#f5f1e8;border-radius:8px;color:#8b7355;display:flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.info-content{flex:1 1}.info-label{color:#666;font-size:.85rem;font-weight:500;margin:0 0 .25rem}.info-value{color:#2c2c2c;font-size:1rem;font-weight:600;margin:0}.modal-actions{border-top:1px solid #e8e2d2;display:flex;flex-direction:column;gap:.75rem;padding-top:1rem}.action-button{border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:1rem;transition:all .3s ease}.action-button:hover:not(:disabled){box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.action-button:disabled{cursor:not-allowed;opacity:.6}.action-button.confirm{background-color:#4caf50}.action-button.confirm:hover{background-color:#45a049}.action-button.complete{background-color:#2196f3}.action-button.complete:hover{background-color:#1976d2}.action-button.cancel{background-color:#f44336}.action-button.cancel:hover{background-color:#d32f2f}.action-button.noshow{background-color:#ff5722}.action-button.noshow:hover{background-color:#e64a19}.action-button.updating{background-color:#9e9e9e;cursor:wait}.status-message{color:#666;font-size:.95rem;margin:0;padding:1rem;text-align:center}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.modal-content{max-height:95vh;width:95%}.modal-header{padding:1.25rem 1.5rem}.modal-title{font-size:1.25rem}.modal-body{padding:1.5rem}.info-item{padding:.875rem}.info-icon{height:36px;width:36px}}@media (max-width:480px){.modal-body,.modal-header{padding:1rem}.action-button{font-size:.95rem;padding:.875rem}}.reservation-management-container{display:flex;flex-direction:column;gap:2rem;padding:2rem}.view-switcher-section{display:flex;justify-content:flex-end}.view-switcher{background-color:#f5f1e8;border-radius:8px;display:flex;gap:.5rem;padding:.25rem}.view-button{background:none;border:none;border-radius:6px;color:#666;cursor:pointer;font-size:.9rem;font-weight:500;padding:.5rem 1.25rem;transition:all .3s ease}.view-button:hover{background-color:#8b73551a;color:#8b7355}.view-button.active{background-color:#8b7355;color:#fff}.reservation-content{display:flex;flex-direction:column;gap:2rem}.loading-message{background-color:#fff;border-radius:16px;box-shadow:0 2px 12px #0000000d;padding:4rem 2rem;text-align:center}.loading-message p{color:#8b7355;font-size:1.1rem;margin:0}.calendar-container{background-color:#fff;border-radius:16px;box-shadow:0 2px 12px #0000000d;padding:2rem}.fc{font-family:inherit}.fc .fc-toolbar-title{color:#2c2c2c;font-size:1.5rem;font-weight:500}.fc .fc-button{background-color:#f5f1e8;border:none;border-radius:6px;color:#8b7355;font-weight:500;padding:.5rem 1rem;transition:all .3s ease}.fc .fc-button:hover{background-color:#8b7355;color:#fff}.fc .fc-button:focus{box-shadow:0 0 0 3px #8b735533}.fc .fc-button-primary:not(:disabled).fc-button-active{background-color:#8b7355;color:#fff}.fc .fc-daygrid-day-number{color:#2c2c2c;font-weight:500;padding:.5rem}.fc .fc-col-header-cell{background-color:#fdfbf7;border:none;color:#8b7355;font-weight:600;padding:1rem 0}.fc .fc-daygrid-day{background-color:#fff;transition:background-color .2s ease}.fc .fc-daygrid-day:hover{background-color:#fdfbf7}.fc .fc-day-today{background-color:#fff9f0!important}.fc .fc-day-today .fc-daygrid-day-number{align-items:center;background-color:#8b7355;border-radius:50%;color:#fff;display:flex;height:32px;justify-content:center;width:32px}.fc .fc-event{border-radius:6px;cursor:pointer;font-size:.85rem;font-weight:500;padding:.25rem .5rem;transition:transform .2s ease,box-shadow .2s ease}.fc .fc-event:hover{box-shadow:0 4px 12px #8b73554d;transform:translateY(-2px)}.fc .fc-event-title{font-weight:500}.fc .fc-timegrid-slot{height:3rem}.fc .fc-timegrid-slot-label{color:#666;font-size:.875rem}.fc .fc-timegrid-event{border-radius:6px;padding:.5rem}.fc-scroller::-webkit-scrollbar{height:8px;width:8px}.fc-scroller::-webkit-scrollbar-track{background:#f5f1e8;border-radius:4px}.fc-scroller::-webkit-scrollbar-thumb{background:#8b7355;border-radius:4px}.fc-scroller::-webkit-scrollbar-thumb:hover{background:#725e45}.calendar-legend{background-color:#fff;border-radius:12px;box-shadow:0 2px 12px #0000000d;padding:1.5rem}.legend-title{color:#2c2c2c;font-size:1rem;font-weight:600;margin:0 0 1rem}.legend-items{display:flex;flex-wrap:wrap;gap:2rem}.legend-item{align-items:center;display:flex;gap:.5rem}.legend-color{border-radius:4px;flex-shrink:0;height:20px;width:20px}.legend-text{color:#666;font-size:.9rem;font-weight:500}@media (max-width:1024px){.calendar-container{padding:1.5rem}.fc .fc-toolbar{flex-direction:column;gap:1rem}.fc .fc-toolbar-title{font-size:1.25rem}}@media (max-width:768px){.reservation-management-container{padding:1.5rem}.view-switcher-section{justify-content:stretch}.view-switcher{width:100%}.view-button{flex:1 1;font-size:.85rem;padding:.625rem}.calendar-container{padding:1rem}.fc .fc-toolbar-title{font-size:1.1rem}.fc .fc-button{font-size:.85rem;padding:.4rem .75rem}.legend-items{gap:1rem}}@media (max-width:480px){.calendar-legend,.reservation-management-container{padding:1rem}.legend-items{flex-direction:column;gap:.75rem}.fc .fc-daygrid-day-number{font-size:.875rem;padding:.25rem}.fc .fc-event{font-size:.75rem;padding:.2rem .4rem}}.customer-list-container{background:linear-gradient(135deg,#fdfbf7,#f5f1e8);font-family:Noto Sans KR,-apple-system,sans-serif;min-height:100vh;padding:40px 20px}.customer-list-header{margin-bottom:40px;text-align:center}.customer-list-header h1{color:#2c2c2c;font-size:2.5rem;font-weight:300;letter-spacing:3px;margin-bottom:10px}.customer-list-header .subtitle{color:#8b7355;font-size:1rem;letter-spacing:1px}.search-stats-section{margin:0 auto 30px;max-width:1200px}.stats-cards{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:30px}.stat-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d;padding:25px;text-align:center;transition:transform .2s,box-shadow .2s}.stat-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.stat-label{color:#666;font-size:.9rem;margin-bottom:10px}.stat-value{color:#8b7355;font-size:2rem;font-weight:600}.search-box{margin:0 auto;max-width:400px;position:relative}.search-input{background:#fff;border:2px solid #e8e2d2;border-radius:25px;font-size:1rem;padding:15px 50px 15px 20px;transition:border-color .3s,box-shadow .3s;width:100%}.search-input:focus{border-color:#8b7355;box-shadow:0 0 0 3px #8b73551a;outline:none}.search-icon{font-size:1.2rem;position:absolute;right:20px;top:50%;transform:translateY(-50%)}.table-container{background:#fff;border-radius:12px;box-shadow:0 2px 12px #00000014;margin:0 auto;max-width:1200px;overflow:hidden}.customer-table{border-collapse:collapse;width:100%}.customer-table thead{background:linear-gradient(135deg,#8b7355,#6d5b47);color:#fff}.customer-table th{font-size:.9rem;font-weight:500;letter-spacing:.5px;padding:18px 15px;text-align:left}.customer-table tbody tr{border-bottom:1px solid #f0ebe3;transition:background-color .2s}.customer-table tbody tr:hover{background-color:#fdfbf7}.customer-table td{color:#2c2c2c;font-size:.95rem;padding:18px 15px}.customer-name{color:#8b7355}.date-cell{color:#666;font-size:.9rem}.badge{display:inline-block;font-size:.85rem;font-weight:500;padding:4px 12px}.badge-success{background:#e8f5e9;color:#2e7d32}.badge-new{background:#fff3e0;color:#e65100}.badge-warning{background:#ffebee;color:#c62828}.badge-gray{background:#f5f5f5;color:#757575}.no-data{color:#999;font-size:1rem;padding:60px 20px!important;text-align:center}.error-message,.loading{color:#666;font-size:1.1rem;padding:60px 20px;text-align:center}.error-message{color:#c62828}.action-buttons{margin:30px auto 0;max-width:1200px;text-align:center}.refresh-button,.retry-button{background:#8b7355;border:none;border-radius:25px;color:#fff;cursor:pointer;font-size:1rem;font-weight:500;padding:12px 30px;transition:background-color .3s,transform .2s}.refresh-button:hover,.retry-button:hover{background:#6d5b47;transform:translateY(-2px)}.refresh-button:active,.retry-button:active{transform:translateY(0)}@media (max-width:768px){.customer-list-header h1{font-size:2rem}.stats-cards{grid-template-columns:1fr}.table-container{overflow-x:auto}.customer-table{min-width:800px}.customer-table td,.customer-table th{font-size:.85rem;padding:12px 10px}}.clickable-row{cursor:pointer;transition:all .15s ease}.clickable-row:hover{background-color:#fff8f0!important;box-shadow:0 2px 8px #d4a57426;transform:translateY(-1px)}.clickable-row:active{transform:translateY(0)}.customer-tags-preview{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px}.mini-tag{background:#d4a57418;border:1px solid #d4a57430;border-radius:10px;color:#8b7355;display:inline-block;font-size:10px;font-weight:600;padding:1px 7px}.care-report-page{background-color:#faf8f3;display:flex;font-family:Segoe UI,Malgun Gothic,sans-serif;min-height:100vh;position:relative}.mobile-tab-nav{background-color:#fff;border-bottom:2px solid #e8dcc4;box-shadow:0 2px 8px #3d281714;display:none;position:-webkit-sticky;position:sticky;top:0;z-index:100}.tab-button{align-items:center;background-color:#fff;border:none;border-bottom:3px solid #0000;color:#8b7355;cursor:pointer;display:flex;flex:1 1;font-size:15px;font-weight:500;gap:8px;justify-content:center;padding:16px;transition:all .2s}.tab-button:hover{background-color:#f9f3e8}.tab-button.active{background-color:#faf8f3;border-bottom-color:#8b7355;color:#3d2817}.tab-button svg{flex-shrink:0}.section-header{align-items:center;border-bottom:2px solid #d4c5a9;display:flex;gap:12px;margin-bottom:24px;padding-bottom:12px}.section-header h2{color:#3d2817;font-size:22px;font-weight:600;margin:0}.section-icon{color:#8b7355}.history-section{background-color:#fff;border-right:1px solid #e8dcc4;flex:1 1;overflow-x:hidden;overflow-y:auto;padding:30px}.selected-customer-info{background:linear-gradient(135deg,#f5ede0,#ede3d3);border-left:4px solid #8b7355;border-radius:8px;margin-bottom:24px;padding:16px 20px}.selected-customer-info h3{color:#3d2817;font-size:18px;font-weight:600;margin:0 0 6px}.selected-customer-info p{color:#5d4a3a;font-size:14px;margin:0 0 8px}.history-count{color:#8b7355;font-size:13px;font-weight:500;margin:8px 0 0}.no-customer-selected{padding:80px 20px;text-align:center}.no-customer-icon{color:#d4c5a9;margin-bottom:16px}.no-customer-selected p{color:#a89884;font-size:15px;margin:8px 0}.mobile-hint{color:#c4b5a1;display:none;font-size:13px;margin-top:12px}.history-table-wrapper{border-radius:8px;box-shadow:0 2px 8px #3d28170d;margin-bottom:20px;overflow-x:auto}.history-table{background-color:#fffef9;border-collapse:collapse;min-width:600px;width:100%}.history-table thead{background-color:#e8dcc4;position:-webkit-sticky;position:sticky;top:0;z-index:10}.history-table th{border-bottom:2px solid #d4c5a9;color:#3d2817;font-size:14px;font-weight:600;padding:14px 16px;text-align:left;white-space:nowrap}.history-table th:first-child{width:120px}.history-table th:nth-child(2){min-width:200px;width:auto}.history-table th:nth-child(3),.history-table th:nth-child(4){text-align:center;width:100px}.history-table tbody tr{background-color:#fffef9;border-bottom:1px solid #f0e9db;transition:background-color .2s}.history-table tbody tr:hover{background-color:#f9f3e8}.history-table td{color:#3d2817;font-size:14px;padding:14px 16px;vertical-align:middle}.date-cell{color:#5d4a3a;font-weight:500;white-space:nowrap}.content-cell{line-height:1.6}.content-text{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:#3d2817;display:-webkit-box;margin-bottom:6px;overflow:hidden;text-overflow:ellipsis;word-break:break-word}.admin-name{color:#8b7355;font-size:12px;font-style:italic}.signature-cell{text-align:center;vertical-align:middle}.signature-label{background-color:#f5ede0;border:1px solid #d4c5a9;border-radius:4px;color:#3d2817;display:inline-block;font-size:13px;font-weight:500;padding:6px 16px}.signature-image{background-color:#fff;border:1px solid #e8dcc4;border-radius:4px;height:40px;max-width:80px;object-fit:contain}.no-history{padding:60px 20px;text-align:center}.no-history-icon{color:#d4c5a9;margin-bottom:16px}.no-history p{color:#a89884;font-size:15px}.pagination{border-top:1px solid #e8dcc4;gap:16px;justify-content:center;margin-top:20px;padding:20px 0}.pagination,.pagination-btn{align-items:center;display:flex}.pagination-btn{background-color:#fff;border:1px solid #d4c5a9;border-radius:6px;color:#5d4a3a;cursor:pointer;font-size:14px;font-weight:500;gap:6px;padding:8px 16px;transition:all .2s}.pagination-btn:hover:not(:disabled){background-color:#f5ede0;border-color:#8b7355;color:#3d2817}.pagination-btn:disabled{cursor:not-allowed;opacity:.4}.pagination-info{align-items:center;color:#5d4a3a;display:flex;font-size:15px;font-weight:500;gap:8px}.current-page{color:#3d2817;font-size:16px;font-weight:600}.page-separator{color:#a89884}.total-pages{color:#8b7355}.form-section{background-color:#fff;flex:1 1;overflow-y:auto;padding:30px}.form-group{margin-bottom:24px}.form-group label{color:#3d2817;font-size:14px;font-weight:500;gap:8px;margin-bottom:10px}.label-icon{color:#8b7355}.date-input{background-color:#f5ede0;border:1px solid #d4c5a9;border-radius:6px;color:#3d2817;cursor:not-allowed;font-size:14px;font-weight:500;padding:10px 14px;width:200px}.customer-search{position:relative}.customer-search input{background-color:#fffef9;border:1px solid #d4c5a9;border-radius:6px;color:#3d2817;font-size:14px;padding:12px 14px;transition:border-color .2s;width:calc(100% - 90px)}.customer-search input:focus{background-color:#fff;border-color:#8b7355;outline:none}.search-button{align-items:center;background-color:#8b7355;border:none;border-radius:0 6px 6px 0;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:6px;height:100%;justify-content:center;position:absolute;right:0;top:0;transition:background-color .2s;width:80px}.search-button:hover{background-color:#6f5a43}.search-button:disabled{cursor:not-allowed;opacity:.6}.search-results{background-color:#fff;border:1px solid #d4c5a9;border-radius:6px;box-shadow:0 4px 12px #3d28171a;left:0;max-height:200px;overflow-y:auto;position:absolute;right:0;top:calc(100% + 4px);z-index:100}.search-result-item{border-bottom:1px solid #f0e9db;color:#3d2817;cursor:pointer;font-size:14px;padding:12px 16px;transition:background-color .2s}.search-result-item:hover{background-color:#f9f3e8}.search-result-item:last-child{border-bottom:none}.selected-customer-badge{background:linear-gradient(135deg,#e8f4e8,#d4e8d4);border-left:4px solid #5a9a5a;border-radius:6px;color:#2d5a2d;font-size:14px;margin-bottom:20px;padding:12px 16px}.selected-customer-badge strong{color:#1e4a1e;font-weight:600}.form-group textarea{background-color:#fffef9;border:1px solid #d4c5a9;border-radius:6px;color:#3d2817;font-family:inherit;font-size:14px;line-height:1.6;padding:14px;resize:vertical;transition:border-color .2s;width:100%}.form-group textarea:focus{background-color:#fff;border-color:#8b7355;outline:none}.signature-section{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr;margin-top:20px}.admin-signature-box{align-items:center;background:linear-gradient(135deg,#fff9f0,#f5ede0);border:2px dashed #d4c5a9;border-radius:6px;display:flex;justify-content:center;min-height:80px;padding:20px;text-align:center}.admin-name-signature{color:#3d2817;font-size:18px;font-weight:600;letter-spacing:.5px}.signature-container{background-color:#fff;border:2px solid #d4c5a9;border-radius:6px;margin-bottom:10px;padding:8px}.signature-canvas{background-color:#fffef9;border-radius:4px;cursor:crosshair;height:150px;width:100%}.btn-primary{align-items:center;background:linear-gradient(135deg,#8b7355,#6f5a43);border:none;border-radius:6px;box-shadow:0 2px 8px #3d281726;color:#fff;cursor:pointer;display:flex;font-size:15px;font-weight:600;gap:10px;justify-content:center;padding:14px 28px;transition:all .2s;width:100%}.btn-primary:hover{background:linear-gradient(135deg,#6f5a43,#5d4a3a);box-shadow:0 4px 12px #3d281740;transform:translateY(-1px)}.btn-secondary{align-items:center;background-color:#a89884;border:none;border-radius:4px;color:#fff;cursor:pointer;display:flex;font-size:13px;gap:6px;padding:8px 16px;transition:background-color .2s}.btn-secondary:hover{background-color:#8b7c6a}.form-actions{margin-top:32px}@media (max-width:1024px){.signature-section{grid-template-columns:1fr}.section-header h2{font-size:20px}.form-section,.history-section{padding:24px}}@media (max-width:768px){.mobile-tab-nav{display:flex}.form-section,.history-section{border-right:none;display:none;min-height:calc(100vh - 60px);padding:16px;width:100%}.form-section.active,.history-section.active,.mobile-hint{display:block}.section-header{margin-bottom:16px}.section-header h2{font-size:18px}.section-icon{height:20px;width:20px}.selected-customer-info{margin-bottom:16px;padding:12px 16px}.selected-customer-info h3{font-size:16px}.history-table-wrapper{margin-bottom:16px}.history-table{min-width:550px}.history-table td,.history-table th{font-size:13px;padding:10px 12px}.history-table th:first-child{width:90px}.signature-image{height:30px;max-width:60px}.pagination{gap:12px;margin-top:16px;padding:16px 0}.pagination-btn{font-size:13px;padding:6px 12px}.pagination-btn svg{height:14px;width:14px}.form-group{margin-bottom:20px}.form-group label{font-size:13px}.label-icon{height:16px;width:16px}.date-input{width:100%}.customer-search input{font-size:13px;padding:10px 12px;width:calc(100% - 75px)}.search-button{font-size:13px;width:70px}.form-group textarea{rows:6;font-size:13px;padding:12px}.signature-section{gap:16px}.admin-signature-box{min-height:60px;padding:16px}.admin-name-signature{font-size:16px}.signature-canvas{height:120px}.btn-primary{font-size:14px;padding:12px 24px}.btn-secondary{font-size:12px;padding:6px 12px}.form-actions{margin-top:24px}}@media (max-width:480px){.form-section,.history-section{padding:12px}.tab-button{font-size:14px;padding:14px}.tab-button span{display:none}.history-table{min-width:500px}.history-table td,.history-table th{font-size:12px;padding:8px 10px}.content-text{-webkit-line-clamp:1}.signature-image{height:25px;max-width:50px}.signature-label{font-size:12px;padding:4px 12px}}.form-section::-webkit-scrollbar,.history-section::-webkit-scrollbar,.history-table-wrapper::-webkit-scrollbar,.search-results::-webkit-scrollbar{height:8px;width:8px}.form-section::-webkit-scrollbar-track,.history-section::-webkit-scrollbar-track,.history-table-wrapper::-webkit-scrollbar-track,.search-results::-webkit-scrollbar-track{background:#f9f3e8}.form-section::-webkit-scrollbar-thumb,.history-section::-webkit-scrollbar-thumb,.history-table-wrapper::-webkit-scrollbar-thumb,.search-results::-webkit-scrollbar-thumb{background:#d4c5a9;border-radius:4px}.form-section::-webkit-scrollbar-thumb:hover,.history-section::-webkit-scrollbar-thumb:hover,.history-table-wrapper::-webkit-scrollbar-thumb:hover,.search-results::-webkit-scrollbar-thumb:hover{background:#bfb099}.dashboard-container{background:linear-gradient(135deg,#fff8f0,#f5ebe0);min-height:calc(100vh - 120px);padding:2rem}.loading-spinner{align-items:center;display:flex;flex-direction:column;height:60vh;justify-content:center}.spinner{animation:spin 1s linear infinite;border:4px solid #f5ebe0;border-radius:50%;border-top-color:#d4a574;height:50px;width:50px}.loading-spinner p{color:#8b7355;font-size:1.1rem;margin-top:1rem}.error-message{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:3rem;text-align:center}.error-message p{color:#c17767;font-size:1.1rem;margin-bottom:1rem}.retry-btn{background:#d4a574;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;padding:.75rem 1.5rem;transition:all .3s ease}.retry-btn:hover{background:#c9a690;transform:translateY(-2px)}.summary-cards{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:2rem}.summary-card{background:#fff;border-radius:16px;box-shadow:0 4px 12px #8b73551a;display:flex;gap:1.5rem;padding:1.5rem;transition:all .3s ease}.summary-card:hover{box-shadow:0 8px 20px #8b735526;transform:translateY(-5px)}.summary-card.revenue{border-left:4px solid #d4a574}.summary-card.bookings{border-left:4px solid #c9a690}.summary-card.customers{border-left:4px solid #e8c4a0}.card-icon{align-items:center;background:linear-gradient(135deg,#fff8f0,#f5ebe0);border-radius:12px;color:#d4a574;display:flex;height:70px;justify-content:center;width:70px}.card-content{flex:1 1}.card-label{color:#a0826d;font-size:.9rem;margin-bottom:.5rem}.card-value{color:#8b7355;font-size:2rem;font-weight:700;margin:.25rem 0}.card-description{color:#b8a491;font-size:.85rem;margin-top:.5rem}.growth-indicator{align-items:center;display:flex;font-size:.9rem;font-weight:600;gap:.5rem;margin-top:.75rem}.growth-indicator.positive{color:#6ba368}.growth-indicator.negative{color:#c17767}.growth-label{color:#a0826d;font-size:.85rem;font-weight:400;margin-left:.25rem}.chart-section{background:#fff;border-radius:16px;box-shadow:0 4px 12px #8b73551a;margin-bottom:2rem;padding:2rem}.chart-title{border-bottom:2px solid #f5ebe0;color:#8b7355;font-size:1.3rem;font-weight:600;margin-bottom:1.5rem;padding-bottom:1rem}.chart-container{margin-top:1rem}.bottom-section{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr 1fr}.donut-section,.table-section{display:flex;flex-direction:column}.treatments-table{overflow-x:auto}.treatments-table table{border-collapse:collapse;width:100%}.treatments-table th{background:linear-gradient(135deg,#fff8f0,#f5ebe0);border-bottom:2px solid #e8c4a0;color:#8b7355;font-weight:600;padding:1rem;text-align:left}.treatments-table td{border-bottom:1px solid #f5ebe0;color:#8b7355;padding:1rem}.treatments-table tr:hover{background:#fff8f0}.rank-badge{border-radius:50%;color:#fff;display:inline-block;font-weight:700;height:30px;line-height:30px;text-align:center;width:30px}.rank-badge.rank-1{background:linear-gradient(135deg,#d4a574,#c9a690)}.rank-badge.rank-2{background:linear-gradient(135deg,#c9a690,#b8947d)}.rank-badge.rank-3{background:linear-gradient(135deg,#e8c4a0,#ddb892)}.rank-badge.rank-4,.rank-badge.rank-5{background:linear-gradient(135deg,#b8a491,#a0826d)}.treatment-name{color:#8b7355;font-weight:600}.booking-count{color:#a0826d;font-weight:500}.revenue{color:#d4a574;font-weight:700}@media (max-width:1024px){.bottom-section{grid-template-columns:1fr}}@media (max-width:768px){.dashboard-container{padding:1rem}.summary-cards{grid-template-columns:1fr}.card-value{font-size:1.5rem}.chart-section{padding:1rem}}.customer-detail-page{font-family:Noto Sans KR,-apple-system,sans-serif;margin:0 auto;max-width:1200px;padding:0 24px 40px}.detail-error,.detail-loading{align-items:center;color:#8b7355;display:flex;flex-direction:column;gap:16px;justify-content:center;min-height:300px}.detail-spinner{animation:spin .8s linear infinite;border:3px solid #f0ebe4;border-radius:50%;border-top-color:#d4a574;height:36px;width:36px}@keyframes spin{to{transform:rotate(1turn)}}.detail-nav{justify-content:space-between;margin-bottom:20px;padding:4px 0}.btn-back,.detail-nav{align-items:center;display:flex}.btn-back{background:#fff;border:1px solid #e0d5c8;border-radius:8px;color:#8b7355;cursor:pointer;font-size:13px;font-weight:600;gap:6px;padding:8px 14px;transition:all .2s}.btn-back:hover{background:#f5f0ea;color:#3d2817}.nav-actions{display:flex;gap:8px}.btn-edit{align-items:center;background:#3d2817;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:13px;font-weight:600;gap:6px;padding:8px 18px;transition:all .2s}.btn-edit:hover{background:#5a3d28}.btn-cancel{background:#fff;border:1px solid #e0d5c8;border-radius:8px;color:#8b7355;cursor:pointer;font-size:13px;font-weight:600;padding:8px 16px;transition:all .2s}.btn-cancel:hover{background:#f5f0ea}.btn-save{align-items:center;background:#d4a574;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:13px;font-weight:700;gap:6px;padding:8px 22px;transition:all .2s}.btn-save:hover{background:#c49464}.btn-save:disabled{cursor:not-allowed;opacity:.6}.success-toast{align-items:center;animation:slideDown .3s ease;background:#e8f5e9;border:1px solid #a5d6a7;border-radius:10px;color:#2e7d32;display:flex;font-size:13px;font-weight:600;gap:8px;margin-bottom:16px;padding:12px 18px}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.profile-header-card{align-items:center;background:#fff;border-radius:16px;box-shadow:0 1px 6px #0000000f;display:flex;flex-wrap:wrap;gap:20px;margin-bottom:20px;padding:24px}.profile-avatar{align-items:center;background:linear-gradient(135deg,#d4a574,#c49464);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:26px;font-weight:800;height:64px;justify-content:center;width:64px}.profile-info{flex:1 1;min-width:200px}.profile-name{color:#3d2817;font-size:22px;font-weight:800;margin:0}.profile-phone{color:#8b7355;font-size:14px;margin:2px 0 10px}.profile-badges{display:flex;flex-wrap:wrap;gap:8px}.badge{align-items:center;border-radius:12px;display:inline-flex;font-size:11px;font-weight:600;gap:4px;padding:4px 10px}.badge-visit{background:#e8f5e9;color:#2e7d32}.badge-noshow{background:#fff3e0;color:#e65100}.badge-date{background:#f5f0ea;color:#8b7355}.profile-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px;width:100%}.tag-chip{align-items:center;background:#d4a57418;border:1px solid #d4a57440;border-radius:16px;color:#8b7355;display:inline-flex;font-size:12px;font-weight:600;gap:4px;padding:4px 12px}.tag-chip.editable{padding-right:6px}.tag-remove{align-items:center;background:#d4a57430;border:none;border-radius:50%;color:#8b7355;cursor:pointer;display:flex;height:18px;justify-content:center;margin-left:2px;padding:0;transition:all .15s;width:18px}.tag-remove:hover{background:#f44336;color:#fff}.detail-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr}@media (max-width:900px){.detail-grid{grid-template-columns:1fr}}.detail-left,.detail-right{display:flex;flex-direction:column;gap:20px}.detail-section{background:#fff;border-radius:14px;box-shadow:0 1px 4px #0000000d;padding:22px}.section-title{align-items:center;color:#3d2817;display:flex;font-size:15px;font-weight:700;gap:8px;margin:0 0 16px}.section-title-row{align-items:center;display:flex;justify-content:space-between;margin-bottom:0}.section-title-row .section-title{margin-bottom:16px}.memo-hint{background:#f5f0ea;border-radius:10px;color:#999;font-size:10px;font-weight:500;margin-left:auto;padding:2px 8px}.form-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:1fr 1fr}@media (max-width:600px){.form-grid{grid-template-columns:1fr}}.form-group{display:flex;flex-direction:column;gap:4px}.form-group label{align-items:center;color:#8b7355;display:flex;font-size:12px;font-weight:600;gap:4px}.form-group input,.form-group select{background:#fff;border:1px solid #e0d5c8;border-radius:8px;color:#3d2817;font-family:inherit;font-size:14px;padding:10px 12px;transition:all .2s}.form-group input:focus,.form-group select:focus{border-color:#d4a574;box-shadow:0 0 0 3px #d4a57420;outline:none}.form-group input:disabled,.form-group select:disabled{background:#fdfbf7;border-color:#f0ebe4;color:#555;cursor:default}.form-group input.has-allergy{background:#fff8e1;border-color:#ff9800}.checkbox-group{border-top:1px solid #f0ebe4;display:flex;flex-direction:column;gap:10px;margin-top:14px;padding-top:14px}.checkbox-label{align-items:center;color:#555;cursor:pointer;display:flex;font-size:13px;gap:8px}.checkbox-label input[type=checkbox]{accent-color:#d4a574;cursor:pointer;height:16px;width:16px}.checkbox-label input[type=checkbox]:disabled{cursor:default}.caution-badge{background:#fff3e0;border-radius:10px;color:#e65100;font-size:11px;font-weight:700;margin-left:4px;padding:2px 8px}.tags-display{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px;min-height:32px}.empty-text{color:#999;font-size:13px;margin:0}.tag-input-row{display:flex;gap:8px;margin-bottom:12px}.tag-input{border:1px solid #e0d5c8;border-radius:8px;color:#3d2817;flex:1 1;font-family:inherit;font-size:13px;padding:8px 12px}.tag-input:focus{border-color:#d4a574;box-shadow:0 0 0 3px #d4a57420;outline:none}.tag-add-btn{align-items:center;background:#d4a574;border:1px solid #d4a574;border-radius:8px;color:#fff;cursor:pointer;display:flex;flex-shrink:0;height:36px;justify-content:center;transition:all .15s;width:36px}.tag-add-btn:hover{background:#c49464}.tag-presets{align-items:center;display:flex;flex-wrap:wrap;gap:6px}.preset-label{color:#999;font-size:11px;font-weight:600}.tag-preset-btn{background:#0000;border:1px dashed #d0c5b8;border-radius:14px;color:#8b7355;cursor:pointer;font-family:inherit;font-size:11px;padding:4px 10px;transition:all .15s}.tag-preset-btn:hover{background:#d4a57412;border-color:#d4a574;color:#d4a574}.memo-textarea{background:#fff;border:1px solid #e0d5c8;border-radius:10px;box-sizing:border-box;color:#3d2817;font-family:inherit;font-size:14px;line-height:1.7;padding:14px;resize:vertical;transition:all .2s;width:100%}.memo-textarea:focus{border-color:#d4a574;box-shadow:0 0 0 3px #d4a57420;outline:none}.memo-textarea:disabled{background:#fdfbf7;border-color:#f0ebe4;color:#555;cursor:default}.btn-link{background:none;border:none;color:#d4a574;cursor:pointer;font-size:13px;font-weight:600;padding:0}.btn-link:hover{text-decoration:underline}.empty-care{align-items:center;color:#ccc;display:flex;flex-direction:column;gap:10px;padding:30px 0}.empty-care p{color:#999;font-size:13px;margin:0}.empty-icon{color:#e0d5c8}.btn-care-link{background:#d4a57415;border:1px solid #d4a57440;border-radius:8px;color:#d4a574;cursor:pointer;font-family:inherit;font-size:12px;font-weight:600;padding:8px 16px;transition:all .2s}.btn-care-link:hover{background:#d4a57430}.care-history-list{display:flex;flex-direction:column;gap:0}.care-history-item{border-bottom:1px solid #f5f0ea;padding:12px 0}.care-history-item:last-child{border-bottom:none}.care-date{align-items:center;color:#d4a574;display:flex;font-size:12px;font-weight:600;gap:4px;margin-bottom:4px}.care-content{color:#555;font-size:13px;line-height:1.5;margin-bottom:4px}.care-admin{color:#999;font-size:11px}.more-records{color:#999;font-size:12px;margin:0;padding:8px 0;text-align:center}@media (max-width:768px){.customer-detail-page{padding:0 12px 32px}.profile-header-card{align-items:flex-start;flex-direction:column;gap:12px;padding:18px}.profile-avatar{font-size:22px;height:52px;width:52px}.profile-name{font-size:20px}.detail-section{padding:16px}.detail-nav{align-items:stretch;flex-direction:column;gap:10px}.nav-actions{justify-content:flex-end}}.notification-page{font-family:Noto Sans KR,-apple-system,sans-serif;margin:0 auto;max-width:1200px;padding:0 24px 40px}.noti-stats-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(4,1fr);margin-bottom:24px}.noti-stat-card{align-items:center;background:#fff;border-radius:14px;box-shadow:0 1px 5px #0000000d;display:flex;gap:14px;padding:18px 20px}.noti-stat-icon{align-items:center;border-radius:12px;display:flex;flex-shrink:0;height:46px;justify-content:center;width:46px}.noti-stat-icon.channel{background:#ede7f6;color:#7e57c2}.noti-stat-icon.success{background:#e8f5e9;color:#43a047}.noti-stat-icon.failed{background:#fff3e0;color:#ef6c00}.noti-stat-icon.total{background:#e3f2fd;color:#1e88e5}.noti-stat-info{display:flex;flex-direction:column;gap:2px}.noti-stat-label{color:#999;font-size:12px;font-weight:500}.noti-stat-value{color:#3d2817;font-size:20px;font-weight:800}.noti-tabs{background:#f5f0ea;border-radius:12px;display:flex;gap:4px;margin-bottom:20px;padding:4px}.noti-tab{align-items:center;background:#0000;border:none;border-radius:10px;color:#8b7355;cursor:pointer;display:flex;font-family:inherit;font-size:13px;font-weight:600;gap:6px;padding:10px 20px;transition:all .2s}.noti-tab:hover{background:#ffffff80}.noti-tab.active{background:#fff;box-shadow:0 1px 4px #00000014;color:#3d2817}.noti-section{background:#fff;border-radius:14px;box-shadow:0 1px 5px #0000000d;padding:24px}.noti-section h3{color:#3d2817;font-size:17px;font-weight:700;margin:0 0 6px}.section-desc{color:#999;font-size:13px;margin:0 0 20px}.section-header-row{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.section-header-row h3{margin:0}.header-actions{display:flex;gap:8px}.btn-reminder{align-items:center;background:#fff3e0;border:1px solid #ffcc80;border-radius:8px;color:#ef6c00;cursor:pointer;display:flex;font-family:inherit;font-size:12px;font-weight:600;gap:5px;padding:7px 14px;transition:all .15s}.btn-reminder:hover{background:#ffe0b2}.btn-refresh{align-items:center;background:#f5f0ea;border:1px solid #e0d5c8;border-radius:8px;color:#8b7355;cursor:pointer;display:flex;font-family:inherit;font-size:12px;font-weight:600;gap:5px;padding:7px 14px;transition:all .15s}.btn-refresh:hover{background:#ebe4d8}.noti-loading{color:#999;font-size:14px;padding:40px;text-align:center}.noti-empty{align-items:center;display:flex;flex-direction:column;gap:10px;padding:60px 0}.noti-empty .empty-icon{color:#e0d5c8}.noti-empty p{color:#999;font-size:14px;margin:0}.noti-empty .empty-hint{color:#ccc;font-size:12px}.noti-table-wrapper{overflow-x:auto}.noti-table{border-collapse:collapse;font-size:13px;width:100%}.noti-table th{border-bottom:2px solid #f0ebe4;color:#8b7355;font-size:12px;font-weight:600;padding:10px 12px;text-align:left;white-space:nowrap}.noti-table td{border-bottom:1px solid #f5f0ea;color:#555;padding:10px 12px;vertical-align:middle}.noti-table tbody tr:hover{background:#fdfbf7}.status-cell{align-items:center;display:flex;gap:5px;white-space:nowrap}.status-icon.success{color:#43a047}.status-icon.failed{color:#e53935}.status-icon.skipped{color:#fb8c00}.status-icon.pending{color:#999}.status-text{font-size:11px;font-weight:700}.status-text.success{color:#43a047}.status-text.failed{color:#e53935}.status-text.skipped{color:#fb8c00}.status-text.pending{color:#999}.type-badge{border-radius:10px;display:inline-block;font-size:11px;font-weight:600;padding:3px 10px;white-space:nowrap}.type-created{background:#e3f2fd;color:#1565c0}.type-confirmed{background:#e8f5e9;color:#2e7d32}.type-reminder{background:#fff3e0;color:#ef6c00}.type-completed{background:#f3e5f5;color:#7b1fa2}.type-cancelled{background:#ffebee;color:#c62828}.channel-badge,.type-custom{background:#f5f0ea;color:#8b7355}.channel-badge{border-radius:8px;display:inline-block;font-size:10px;font-weight:700;padding:2px 8px}.recipient-cell{font-family:SF Mono,Menlo,monospace;font-size:12px;white-space:nowrap}.content-cell{max-width:280px}.content-preview{cursor:default;font-size:12px;line-height:1.4;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.error-text{color:#e53935;font-size:11px;margin-top:2px}.time-cell{color:#999;font-size:12px;white-space:nowrap}.noti-pagination{gap:12px;padding-top:16px}.noti-pagination,.page-btn{align-items:center;display:flex;justify-content:center}.page-btn{background:#fff;border:1px solid #e0d5c8;border-radius:8px;color:#8b7355;cursor:pointer;height:32px;transition:all .15s;width:32px}.page-btn:hover:not(:disabled){background:#f5f0ea}.page-btn:disabled{cursor:default;opacity:.3}.page-info{color:#8b7355;font-size:13px;font-weight:600}.send-form{gap:16px;max-width:600px}.send-form,.send-form .form-group{display:flex;flex-direction:column}.send-form .form-group{gap:6px}.send-form .form-group label{align-items:center;color:#8b7355;display:flex;font-size:13px;font-weight:600;gap:5px}.search-row{display:flex;gap:8px}.search-row input{border:1px solid #e0d5c8;border-radius:8px;color:#3d2817;flex:1 1;font-family:inherit;font-size:14px;padding:10px 12px}.search-row input:focus{border-color:#d4a574;box-shadow:0 0 0 3px #d4a57420;outline:none}.btn-search{background:#3d2817;border:none;border-radius:8px;color:#fff;cursor:pointer;font-family:inherit;font-size:13px;font-weight:600;padding:10px 18px;transition:background .15s;white-space:nowrap}.btn-search:hover{background:#5a3d28}.btn-search:disabled{cursor:not-allowed;opacity:.5}.search-dropdown{background:#fff;border:1px solid #e0d5c8;border-radius:10px;box-shadow:0 4px 12px #00000014;overflow:hidden}.search-item{cursor:pointer;display:flex;font-size:13px;justify-content:space-between;padding:10px 14px;transition:background .1s}.search-item:hover{background:#fff8f0}.search-item strong{color:#3d2817}.search-item span{color:#999;font-size:12px}.selected-customer{align-items:center;background:#e8f5e9;border:1px solid #a5d6a7;border-radius:10px;color:#2e7d32;display:flex;font-size:13px;justify-content:space-between;padding:10px 14px}.btn-clear{background:none;border:none;color:#999;cursor:pointer;font-size:16px;padding:0 4px}.btn-clear:hover{color:#e53935}.send-form textarea{border:1px solid #e0d5c8;border-radius:10px;color:#3d2817;font-family:inherit;font-size:14px;line-height:1.6;padding:12px 14px;resize:vertical;transition:all .2s}.send-form textarea:focus{border-color:#d4a574;box-shadow:0 0 0 3px #d4a57420;outline:none}.char-count{color:#ccc;font-size:11px;text-align:right}.send-result{align-items:center;border-radius:10px;display:flex;font-size:13px;font-weight:600;gap:8px;padding:10px 14px}.send-result.success{background:#e8f5e9;border:1px solid #a5d6a7;color:#2e7d32}.send-result.error{background:#ffebee;border:1px solid #ef9a9a;color:#c62828}.btn-send{align-items:center;align-self:flex-start;background:#d4a574;border:none;border-radius:10px;color:#fff;cursor:pointer;display:flex;font-family:inherit;font-size:15px;font-weight:700;gap:8px;justify-content:center;padding:12px 24px;transition:all .2s}.btn-send:hover{background:#c49464}.btn-send:disabled{cursor:not-allowed;opacity:.5}.settings-card{display:flex;flex-wrap:wrap;gap:20px;margin-bottom:28px}.settings-status{display:flex;flex-direction:column;gap:6px}.settings-label{color:#999;font-size:12px;font-weight:500}.settings-badge{border-radius:10px;display:inline-block;font-size:13px;font-weight:700;padding:6px 14px}.settings-badge.enabled{background:#e8f5e9;color:#2e7d32}.settings-badge.disabled{background:#fff3e0;color:#ef6c00}.settings-badge.channel{background:#f5f0ea;color:#8b7355}.settings-guide h4{color:#3d2817;font-size:15px;margin:0 0 16px}.guide-steps{display:flex;flex-direction:column;gap:16px;margin-bottom:28px}.guide-step{align-items:flex-start;display:flex;gap:14px}.step-num{align-items:center;background:#d4a574;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:14px;font-weight:800;height:30px;justify-content:center;width:30px}.step-content strong{color:#3d2817;display:block;font-size:14px;margin-bottom:2px}.step-content p{color:#777;font-size:13px;line-height:1.5;margin:0}.code-block{background:#2d2d2d;border-radius:8px;margin-top:10px;overflow-x:auto;padding:14px}.code-block code{color:#a5d6a7;font-family:SF Mono,Menlo,Consolas,monospace;font-size:12px;line-height:1.8}.guide-info-box{background:#fdfbf7;border:1px solid #e0d5c8;border-radius:12px;padding:20px}.guide-info-box h4{font-size:14px;margin:0 0 12px}.guide-info-box ul{display:flex;flex-direction:column;gap:8px;margin:0;padding:0 0 0 18px}.guide-info-box li{color:#555;font-size:13px;line-height:1.5}.guide-info-box li strong{color:#3d2817}@media (max-width:900px){.noti-stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:600px){.notification-page{padding:0 12px 32px}.noti-stats-grid{grid-template-columns:1fr}.noti-tabs{flex-wrap:wrap}.noti-tab{flex:1 1;justify-content:center;min-width:100px}.section-header-row{align-items:flex-start;gap:10px}.section-header-row,.settings-card{flex-direction:column}.noti-section{padding:16px}}.admin-page{background-color:#f5f1e8;display:flex;min-height:100vh}.admin-sidebar{background-color:#2c2c2c;color:#fff;display:flex;flex-direction:column;height:100vh;left:0;position:fixed;top:0;transition:width .3s ease;width:260px;z-index:100}.admin-sidebar.closed{width:70px}.sidebar-header{align-items:center;border-bottom:1px solid #ffffff1a;display:flex;justify-content:space-between;padding:2rem 1.5rem}.sidebar-logo{color:#fff;font-size:1.5rem;font-weight:300;letter-spacing:.1em;margin:0}.sidebar-toggle{background:none;border:none;color:#fff;cursor:pointer;font-size:1.2rem;padding:.5rem;transition:transform .3s ease}.sidebar-toggle:hover{transform:scale(1.1)}.sidebar-nav{flex:1 1;justify-content:space-between;padding:1.5rem 0}.nav-section,.sidebar-nav{display:flex;flex-direction:column}.nav-section{gap:.5rem;padding:0 1rem}.nav-item{align-items:center;background:none;border:none;border-radius:8px;color:#ffffffb3;cursor:pointer;display:flex;font-size:.95rem;gap:1rem;padding:1rem 1.25rem;text-align:left;transition:all .3s ease}.nav-item:hover{background-color:#ffffff1a;color:#fff}.nav-item.active{background-color:#8b7355;color:#fff}.nav-item.logout{color:#ffb4ab}.nav-item.logout:hover{background-color:#ffb4ab1a;color:#ff8a80}.nav-icon{font-size:1.3rem;text-align:center;width:24px}.nav-icon-lucide{color:currentColor;flex-shrink:0}.nav-text{font-weight:500;letter-spacing:.02em}.admin-sidebar.closed .nav-text{display:none}.admin-sidebar.closed .nav-item{justify-content:center;padding:1rem}.admin-content{flex:1 1;margin-left:260px;transition:margin-left .3s ease}.admin-sidebar.closed~.admin-content{margin-left:70px}.admin-header{align-items:center;background-color:#fff;box-shadow:0 2px 8px #0000000d;display:flex;justify-content:space-between;padding:2rem}.header-left{flex:1 1}.page-title{color:#2c2c2c;font-size:1.75rem;font-weight:500;letter-spacing:.02em;margin:0 0 .25rem}.page-subtitle{color:#8b7355;font-size:.9rem;font-weight:400;margin:0}.header-right{gap:1rem}.header-right,.user-info{align-items:center;display:flex}.user-info{background-color:#f5f1e8;border-radius:50px;gap:.75rem;padding:.75rem 1.25rem}.user-icon{font-size:1.2rem}.user-name{color:#2c2c2c;font-size:.95rem;font-weight:500}@media (max-width:768px){.admin-sidebar{width:70px}.admin-sidebar .nav-text,.admin-sidebar .sidebar-logo{display:none}.admin-content{margin-left:70px}.admin-header{align-items:flex-start;flex-direction:column;gap:1rem;padding:1.5rem}.page-title{font-size:1.5rem}}@media (max-width:480px){.admin-header{padding:1rem}.user-info{padding:.5rem 1rem}}.App{background-color:var(--brand-ivory);min-height:100vh}.react-calendar{border:none!important;border-radius:var(--radius-md)!important;box-shadow:0 4px 20px #0000001a!important;font-family:inherit!important}.react-calendar__tile--active{background-color:var(--brand-brown)!important;color:#fff!important}.react-calendar__tile--hover{background-color:var(--brand-beige)!important}
/*# sourceMappingURL=main.4155e04e.css.map*/