:root{--color-primary: #1A5F5A;--color-primary-dark: #134845;--color-primary-light: #2A7A74;--color-primary-muted: rgba(26, 95, 90, .1);--color-accent: #E8725C;--color-accent-dark: #D45A44;--color-accent-light: #F08B78;--color-success: #4A9B78;--color-success-light: #5FB58E;--color-success-bg: rgba(74, 155, 120, .12);--color-warning: #D4A84B;--color-warning-light: #E6C06A;--color-warning-bg: rgba(212, 168, 75, .15);--color-danger: #C94A4A;--color-danger-light: #E05555;--color-danger-bg: rgba(201, 74, 74, .1);--color-cream: #F7F5F2;--color-cream-dark: #EDE9E3;--color-white: #FFFFFF;--color-card: rgba(255, 255, 255, .85);--color-text-primary: #2D3748;--color-text-secondary: #5A6578;--color-text-muted: #8895A7;--color-gray-50: #F9F8F6;--color-gray-100: #F0EDE8;--color-gray-200: #E2DED6;--color-gray-300: #CCC7BC;--color-gray-400: #9E9789;--color-gray-500: #7A7367;--color-gray-600: #5A554C;--color-gray-700: #3D3A34;--color-gray-800: #2A2825;--color-gray-900: #1A1917;--font-display: "DM Serif Display", Georgia, serif;--font-body: "DM Sans", -apple-system, BlinkMacSystemFont, sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 2rem;--font-size-4xl: 2.5rem;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--radius-sm: .5rem;--radius-md: .75rem;--radius-lg: 1rem;--radius-xl: 1.5rem;--radius-2xl: 2rem;--radius-full: 9999px;--shadow-soft: 0 2px 8px rgba(45, 55, 72, .06);--shadow-md: 0 4px 16px rgba(45, 55, 72, .08);--shadow-lg: 0 8px 32px rgba(45, 55, 72, .12);--shadow-xl: 0 16px 48px rgba(45, 55, 72, .16);--shadow-glow: 0 0 40px rgba(26, 95, 90, .15);--glass-bg: rgba(255, 255, 255, .75);--glass-border: rgba(255, 255, 255, .5);--glass-blur: blur(20px);--touch-target: 48px;--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .4s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:var(--font-body);font-size:var(--font-size-base);line-height:1.6;color:var(--color-text-primary);background:linear-gradient(135deg,#1a5f5a,#2a7a74,#4a9b78,#7bb89e,#a8d4c4);background-attachment:fixed;min-height:100vh;min-height:100dvh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body:before{content:"";position:fixed;inset:0;pointer-events:none;opacity:.03;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)'/%3E%3C/svg%3E")}#app{max-width:430px;margin:0 auto;min-height:100vh;min-height:100dvh;background:var(--color-cream);position:relative;overflow-x:hidden;box-shadow:var(--shadow-xl)}.header{background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);padding:var(--spacing-md) var(--spacing-lg);position:sticky;top:0;z-index:100;border-bottom:1px solid var(--glass-border)}.header__title{font-family:var(--font-display);font-size:var(--font-size-xl);font-weight:400;color:var(--color-primary);display:flex;align-items:center;gap:var(--spacing-sm);letter-spacing:-.01em}.header__subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:var(--spacing-xs);font-weight:500}.header__back{background:var(--color-primary-muted);border:none;color:var(--color-primary);width:var(--touch-target);height:var(--touch-target);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-base);font-size:var(--font-size-lg)}.header__back:hover{background:var(--color-primary);color:var(--color-white);transform:translate(-2px)}.header__row{display:flex;align-items:center;gap:var(--spacing-md)}.screen{padding:var(--spacing-lg);animation:screenFadeIn .5s ease}@keyframes screenFadeIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.stagger-1{animation-delay:.05s}.stagger-2{animation-delay:.1s}.stagger-3{animation-delay:.15s}.stagger-4{animation-delay:.2s}.stagger-5{animation-delay:.25s}.floor-grid{display:grid;grid-template-columns:1fr;gap:var(--spacing-md);margin-top:var(--spacing-lg)}.floor-card{background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:var(--radius-xl);padding:var(--spacing-xl);text-align:center;cursor:pointer;transition:all var(--transition-base);min-height:110px;position:relative;overflow:hidden;animation:cardReveal .5s ease backwards}.floor-card:nth-child(1){animation-delay:.1s}.floor-card:nth-child(2){animation-delay:.15s}.floor-card:nth-child(3){animation-delay:.2s}.floor-card:nth-child(4){animation-delay:.25s}.floor-card:nth-child(5){animation-delay:.3s}@keyframes cardReveal{0%{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.floor-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--color-primary),var(--color-primary-light));opacity:0;transition:opacity var(--transition-base)}.floor-card:hover,.floor-card:focus{transform:translateY(-4px);box-shadow:var(--shadow-lg),var(--shadow-glow);border-color:var(--color-primary)}.floor-card:hover:before,.floor-card:focus:before{opacity:1}.floor-card:active{transform:translateY(-2px)}.floor-card__number{font-family:var(--font-display);font-size:var(--font-size-3xl);color:var(--color-primary);margin-bottom:var(--spacing-xs)}.floor-card__count{font-size:var(--font-size-sm);color:var(--color-text-secondary);display:flex;align-items:center;justify-content:center;gap:var(--spacing-md);font-weight:500}.floor-card__count span:last-child{color:var(--color-danger)}.floor-card__label{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-top:var(--spacing-sm);text-transform:uppercase;letter-spacing:.08em}.room-chip{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-xs);min-width:64px;height:var(--touch-target);padding:0 var(--spacing-md);background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:var(--color-white);border:none;border-radius:var(--radius-lg);font-family:var(--font-body);font-weight:600;font-size:var(--font-size-base);cursor:pointer;-webkit-user-select:none;user-select:none;touch-action:none;transition:all var(--transition-base);box-shadow:var(--shadow-soft)}.room-chip:hover{transform:translateY(-2px) scale(1.02);box-shadow:var(--shadow-md)}.room-chip:active{transform:scale(1.05);box-shadow:var(--shadow-lg)}.room-chip--assigned{background:linear-gradient(135deg,var(--color-success) 0%,#3A8B68 100%)}.room-chip--dragging{opacity:.6}.room-chip--has-allergy{background:linear-gradient(135deg,var(--color-danger) 0%,#A83A3A 100%);animation:allergyPulse 2s infinite}@keyframes allergyPulse{0%,to{box-shadow:0 0 #c94a4a66}50%{box-shadow:0 0 0 10px #c94a4a00}}.rooms-section{margin-bottom:var(--spacing-xl)}.rooms-section__title{font-family:var(--font-display);font-size:var(--font-size-base);color:var(--color-primary);margin-bottom:var(--spacing-md);display:flex;align-items:center;gap:var(--spacing-sm)}.rooms-grid{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.drop-zone{min-height:140px;border:2px dashed var(--color-gray-300);border-radius:var(--radius-xl);padding:var(--spacing-lg);display:flex;flex-wrap:wrap;gap:var(--spacing-sm);align-content:flex-start;transition:all var(--transition-base);background:var(--color-gray-50)}.drop-zone--active{border-color:var(--color-primary);background:var(--color-primary-muted);border-style:solid}.drop-zone--empty{justify-content:center;align-items:center}.drop-zone__placeholder{color:var(--color-text-muted);text-align:center;font-size:var(--font-size-sm)}.drop-zone__placeholder-icon{font-size:2.5rem;display:block;margin-bottom:var(--spacing-sm);opacity:.6}.btn{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);width:100%;height:56px;border:none;border-radius:var(--radius-lg);font-family:var(--font-body);font-size:var(--font-size-base);font-weight:600;cursor:pointer;transition:all var(--transition-base);letter-spacing:.02em}.btn--primary{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:var(--color-white);box-shadow:var(--shadow-md),0 4px 12px #1a5f5a40}.btn--primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg),0 6px 20px #1a5f5a4d}.btn--primary:active{transform:translateY(0)}.btn--primary:disabled{background:var(--color-gray-300);box-shadow:none;cursor:not-allowed;transform:none}.btn--danger{background:linear-gradient(135deg,var(--color-danger) 0%,var(--color-danger-dark) 100%);color:var(--color-white)}.btn--success{background:linear-gradient(135deg,var(--color-success) 0%,#3A8B68 100%);color:var(--color-white);box-shadow:var(--shadow-md)}.btn--success:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.btn--outline{background:var(--color-white);border:2px solid var(--color-gray-300);color:var(--color-text-secondary)}.btn--outline:hover{border-color:var(--color-primary);color:var(--color-primary)}.meal-tabs{display:flex;justify-content:space-between;gap:2px;padding:var(--spacing-sm) 0;overflow-x:visible;flex-wrap:nowrap}.meal-tabs::-webkit-scrollbar{display:none}.meal-tab{flex:1;display:flex;align-items:center;justify-content:center;min-width:0;padding:8px 2px;border:none;background:var(--color-gray-100);border-radius:var(--radius-md);font-family:var(--font-body);font-size:11px;font-weight:600;color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-base);white-space:nowrap}.meal-tab:hover{background:var(--color-gray-200)}.meal-tab--active{background:var(--color-primary);color:var(--color-white);box-shadow:var(--shadow-soft)}.meal-tab__icon{margin-right:3px;font-size:13px;flex-shrink:0}.customer-card{background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-xl);padding:var(--spacing-lg);margin-bottom:var(--spacing-md);transition:all var(--transition-base);position:relative;overflow:hidden;box-shadow:var(--shadow-soft)}.customer-card:hover{box-shadow:var(--shadow-md)}.customer-card--completed{opacity:.65;border-color:var(--color-success);background:linear-gradient(135deg,var(--color-white) 0%,var(--color-success-bg) 100%)}.customer-card__header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--spacing-md)}.customer-card__id{font-family:var(--font-display);font-size:var(--font-size-2xl);color:var(--color-primary)}.customer-card__name{font-size:var(--font-size-lg);color:var(--color-text-primary);margin-left:var(--spacing-sm);font-weight:500}.customer-card__diet-badge{display:inline-flex;align-items:center;padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-gray-100);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-secondary)}.customer-card__diet-badge--sose{background:var(--color-warning-bg);color:#8b6914}.customer-card__diet-badge--tehostettu{background:#3b82f61f;color:#1e40af}.allergy-warning{background:linear-gradient(135deg,var(--color-accent) 0%,var(--color-accent-dark) 100%);color:var(--color-white);padding:var(--spacing-lg);border-radius:var(--radius-lg);margin-bottom:var(--spacing-md);text-align:center;box-shadow:0 4px 20px #e8725c59}.allergy-warning__icon{font-size:2.5rem;display:block;margin-bottom:var(--spacing-sm);animation:warningShake .6s ease-in-out infinite}@keyframes warningShake{0%,to{transform:translate(0) rotate(0)}25%{transform:translate(-4px) rotate(-3deg)}75%{transform:translate(4px) rotate(3deg)}}.allergy-warning__title{font-family:var(--font-display);font-size:var(--font-size-lg);margin-bottom:var(--spacing-xs)}.allergy-warning__list{font-size:var(--font-size-xl);font-weight:700;text-transform:uppercase;letter-spacing:.1em;margin-bottom:var(--spacing-md)}.allergy-warning__btn{width:100%;height:52px;background:var(--color-white);color:var(--color-accent-dark);border:none;border-radius:var(--radius-lg);font-family:var(--font-body);font-size:var(--font-size-base);font-weight:700;cursor:pointer;transition:all var(--transition-base)}.allergy-warning__btn:hover{transform:scale(1.02);box-shadow:var(--shadow-md)}.allergy-confirmed{display:flex;align-items:center;gap:var(--spacing-sm);background:var(--color-danger-bg);color:var(--color-danger);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:600;margin-bottom:var(--spacing-md)}.allergy-confirmed__check{color:var(--color-success)}.no-allergy{display:flex;align-items:center;gap:var(--spacing-sm);background:var(--color-success-bg);color:var(--color-success);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:500;margin-bottom:var(--spacing-md)}.preferences{border-top:1px solid var(--color-gray-200);padding-top:var(--spacing-md);margin-top:var(--spacing-md)}.preference-row{display:flex;align-items:flex-start;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm);font-size:var(--font-size-base);color:var(--color-text-primary)}.preference-row__icon{flex-shrink:0;width:24px;text-align:center}.preference-row__label{font-weight:500;color:var(--color-text-muted);min-width:60px}.preference-row__value{font-weight:600}.customer-card__notes{background:var(--color-warning-bg);color:var(--color-gray-800);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);font-size:var(--font-size-sm);margin-top:var(--spacing-md);display:flex;align-items:center;gap:var(--spacing-sm)}.customer-card__complete-btn{margin-top:var(--spacing-md)}.customer-card__completed-badge{position:absolute;top:var(--spacing-md);right:var(--spacing-md);background:var(--color-success);color:var(--color-white);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:600;display:flex;align-items:center;gap:var(--spacing-xs)}.lactose-badge{display:inline-flex;align-items:center;gap:var(--spacing-xs);background:var(--color-warning-bg);color:#8b6914;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:600;margin-left:var(--spacing-sm)}.assistance-badge{display:inline-flex;align-items:center;gap:var(--spacing-xs);background:#3b82f61f;color:#1e40af;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:600;margin-bottom:var(--spacing-sm)}.empty-state{text-align:center;padding:var(--spacing-2xl);color:var(--color-text-muted)}.empty-state__icon{font-size:4rem;margin-bottom:var(--spacing-md);opacity:.6}.empty-state__text{font-size:var(--font-size-lg)}.footer-actions{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:430px;padding:var(--spacing-md) var(--spacing-lg);background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border-top:1px solid var(--glass-border)}.screen--with-footer{padding-bottom:100px}.loading{display:flex;align-items:center;justify-content:center;padding:var(--spacing-2xl)}.loading__spinner{width:40px;height:40px;border:3px solid var(--color-gray-200);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.summary-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.summary-stat{background:var(--color-white);border-radius:var(--radius-lg);padding:var(--spacing-md);text-align:center;border:1px solid var(--color-gray-200);box-shadow:var(--shadow-soft)}.summary-stat__value{font-family:var(--font-display);font-size:var(--font-size-2xl);color:var(--color-primary)}.summary-stat__label{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-top:var(--spacing-xs)}.summary-stat--warning .summary-stat__value{color:var(--color-danger)}.section-divider{display:flex;align-items:center;gap:var(--spacing-md);margin:var(--spacing-xl) 0}.section-divider:before,.section-divider:after{content:"";flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--color-gray-300),transparent)}.section-divider__text{font-size:var(--font-size-sm);color:var(--color-text-muted);font-weight:500}.install-prompt{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:var(--color-white);padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-lg);margin-bottom:var(--spacing-lg);display:flex;align-items:center;justify-content:space-between;box-shadow:var(--shadow-md)}.install-prompt__text{font-size:var(--font-size-sm);font-weight:500}.install-prompt__btn{background:var(--color-white);color:var(--color-primary);border:none;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);font-weight:600;cursor:pointer;transition:all var(--transition-base)}.install-prompt__btn:hover{transform:scale(1.05)}.install-prompt__dismiss{background:transparent;border:none;color:#ffffffb3;padding:var(--spacing-sm);cursor:pointer;margin-left:var(--spacing-sm)}.admin-tabs{display:flex;gap:var(--spacing-xs);margin-bottom:var(--spacing-lg);background:var(--color-gray-100);padding:var(--spacing-xs);border-radius:var(--radius-lg)}.admin-tab{flex:1;padding:var(--spacing-sm) var(--spacing-md);border:none;background:transparent;border-radius:var(--radius-md);font-family:var(--font-body);font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-base)}.admin-tab:hover{color:var(--color-primary)}.admin-tab--active{background:var(--color-white);color:var(--color-primary);box-shadow:var(--shadow-soft)}.admin-section{margin-bottom:var(--spacing-xl)}.admin-section__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.admin-section h3{font-family:var(--font-display);font-size:var(--font-size-lg);color:var(--color-primary)}.admin-hint{color:var(--color-text-muted);font-size:var(--font-size-sm);margin-bottom:var(--spacing-lg)}.admin-floor-group{margin-bottom:var(--spacing-lg)}.admin-floor-title{font-family:var(--font-display);font-size:var(--font-size-base);color:var(--color-primary);margin-bottom:var(--spacing-sm);padding-bottom:var(--spacing-xs);border-bottom:1px solid var(--color-gray-200)}.admin-customer-list{display:flex;flex-direction:column;gap:var(--spacing-xs)}.admin-customer-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) var(--spacing-md);background:var(--color-white);border-radius:var(--radius-md);border:1px solid var(--color-gray-200);transition:all var(--transition-base)}.admin-customer-item:hover{border-color:var(--color-primary);box-shadow:var(--shadow-soft)}.admin-customer-info{display:flex;align-items:center;gap:var(--spacing-sm)}.admin-customer-id{font-family:var(--font-display);font-weight:400;color:var(--color-primary);min-width:40px}.admin-customer-name{color:var(--color-text-primary)}.admin-customer-actions{display:flex;gap:var(--spacing-xs)}.admin-badge{font-size:var(--font-size-xs);padding:2px 8px;border-radius:var(--radius-full);font-weight:600}.admin-badge--danger{background:var(--color-danger-bg);color:var(--color-danger)}.admin-badge--warning{background:var(--color-warning-bg);color:#8b6914}.btn-small{padding:var(--spacing-xs) var(--spacing-md);border:none;border-radius:var(--radius-md);font-family:var(--font-body);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:all var(--transition-base)}.btn-small--primary{background:var(--color-primary);color:var(--color-white)}.btn-small--primary:hover{background:var(--color-primary-dark)}.btn-small--secondary{background:var(--color-gray-200);color:var(--color-text-secondary)}.btn-small--secondary:hover{background:var(--color-gray-300)}.btn-small:disabled{opacity:.5;cursor:not-allowed}.admin-header-actions{display:flex;gap:var(--spacing-sm);align-items:center}.btn-icon{width:40px;height:40px;border:none;background:var(--color-gray-100);border-radius:var(--radius-md);cursor:pointer;font-size:var(--font-size-base);transition:all var(--transition-base);display:flex;align-items:center;justify-content:center}.btn-icon:hover{background:var(--color-gray-200)}.btn-icon--danger:hover{background:var(--color-danger-bg);color:var(--color-danger)}.admin-floor-summary{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md)}.admin-floor-stat{background:var(--color-white);padding:var(--spacing-lg);border-radius:var(--radius-lg);text-align:center;border:1px solid var(--color-gray-200);transition:all var(--transition-base)}.admin-floor-stat:hover{border-color:var(--color-primary)}.admin-floor-stat__number{font-family:var(--font-display);font-size:var(--font-size-lg);color:var(--color-primary)}.admin-floor-stat__count{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-top:var(--spacing-xs)}.admin-diet-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.admin-diet-item{display:flex;gap:var(--spacing-sm);align-items:center}.admin-input,.admin-select,.admin-textarea{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:2px solid var(--color-gray-300);border-radius:var(--radius-md);font-family:var(--font-body);font-size:var(--font-size-base);color:var(--color-text-primary);background:var(--color-white);transition:all var(--transition-base)}.admin-input:focus,.admin-select:focus,.admin-textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-muted)}.admin-textarea{min-height:80px;resize:vertical}.admin-select{cursor:pointer}.modal-overlay{position:fixed;inset:0;background:#1a252f99;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-md);animation:overlayFadeIn .2s ease}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--color-white);border-radius:var(--radius-xl);width:100%;max-width:400px;max-height:90vh;overflow-y:auto;animation:modalSlideIn .3s ease;box-shadow:var(--shadow-xl)}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(24px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.modal__header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--color-gray-200);position:sticky;top:0;background:var(--color-white)}.modal__header h3{font-family:var(--font-display);font-size:var(--font-size-lg);color:var(--color-primary)}.modal__close{width:36px;height:36px;border:none;background:var(--color-gray-100);border-radius:var(--radius-full);cursor:pointer;font-size:var(--font-size-lg);color:var(--color-text-secondary);transition:all var(--transition-base);display:flex;align-items:center;justify-content:center}.modal__close:hover{background:var(--color-gray-200)}.modal__body{padding:var(--spacing-lg)}.modal__footer{display:flex;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--color-gray-200);position:sticky;bottom:0;background:var(--color-white)}.modal__footer .btn{flex:1}.form-group{margin-bottom:var(--spacing-md)}.form-group label{display:block;font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-secondary);margin-bottom:var(--spacing-xs)}.form-group--inline{display:flex;align-items:center}.form-group--inline label{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:0;cursor:pointer}.form-group--inline input[type=checkbox]{width:20px;height:20px;cursor:pointer;accent-color:var(--color-primary)}.confirm-modal{background:var(--color-white);border-radius:var(--radius-xl);width:100%;max-width:340px;overflow:hidden;animation:modalSlideIn .3s ease;box-shadow:var(--shadow-xl)}.confirm-modal__icon{font-size:3.5rem;text-align:center;padding:var(--spacing-xl) var(--spacing-lg) 0}.confirm-modal__body{padding:var(--spacing-md) var(--spacing-lg) var(--spacing-lg);text-align:center}.confirm-modal__title{font-family:var(--font-display);font-size:var(--font-size-lg);color:var(--color-text-primary);margin-bottom:var(--spacing-xs)}.confirm-modal__message{font-size:var(--font-size-sm);color:var(--color-text-muted);line-height:1.6}.confirm-modal__customer{font-weight:700;color:var(--color-primary)}.confirm-modal__footer{display:flex;gap:var(--spacing-sm);padding:0 var(--spacing-lg) var(--spacing-lg)}.confirm-modal__btn{flex:1;padding:var(--spacing-md);border:none;border-radius:var(--radius-md);font-family:var(--font-body);font-size:var(--font-size-base);font-weight:600;cursor:pointer;transition:all var(--transition-base)}.confirm-modal__btn--cancel{background:var(--color-gray-100);color:var(--color-text-secondary)}.confirm-modal__btn--cancel:hover{background:var(--color-gray-200)}.confirm-modal__btn--danger{background:linear-gradient(135deg,var(--color-danger) 0%,#A83A3A 100%);color:var(--color-white)}.confirm-modal__btn--danger:hover{transform:scale(1.02);box-shadow:0 4px 16px #c94a4a59}.text-center{text-align:center}.text-primary{color:var(--color-primary)}.text-muted{color:var(--color-text-muted)}.font-display{font-family:var(--font-display)}.mt-sm{margin-top:var(--spacing-sm)}.mt-md{margin-top:var(--spacing-md)}.mb-sm{margin-bottom:var(--spacing-sm)}.mb-md{margin-bottom:var(--spacing-md)}.modal-overlay{position:fixed;inset:0;background:#1a191799;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .3s ease}.modal-content{background:var(--color-white);border-radius:var(--radius-xl);padding:var(--spacing-xl);width:90%;max-width:360px;text-align:center;box-shadow:var(--shadow-xl);animation:slideUp .3s ease}.modal-title{font-family:var(--font-display);font-size:var(--font-size-xl);color:var(--color-primary);margin-bottom:var(--spacing-sm)}.modal-text{color:var(--color-text-secondary);font-size:var(--font-size-base);margin-bottom:var(--spacing-lg)}.modal-actions{display:flex;gap:var(--spacing-md)}.modal-btn{flex:1}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
