:root{--primary-50: #fff7ed;--primary-100: #ffedd5;--primary-200: #fed7aa;--primary-300: #fdba74;--primary-400: #fb923c;--primary-500: #f97316;--primary-600: #ea580c;--primary-700: #c2410c;--primary-800: #9a3412;--primary-900: #7c2d12;--accent-50: #f0fdfa;--accent-100: #ccfbf1;--accent-200: #99f6e4;--accent-300: #5eead4;--accent-400: #2dd4bf;--accent-500: #14b8a6;--accent-600: #0d9488;--accent-700: #0f766e;--accent-800: #115e59;--accent-900: #134e4a;--neutral-50: #fafafa;--neutral-100: #f5f5f5;--neutral-200: #e5e5e5;--neutral-300: #d4d4d4;--neutral-400: #a3a3a3;--neutral-500: #737373;--neutral-600: #525252;--neutral-700: #404040;--neutral-800: #262626;--neutral-900: #171717;--success: #22c55e;--success-light: #dcfce7;--warning: #eab308;--warning-light: #fef9c3;--danger: #ef4444;--danger-light: #fee2e2;--info: #3b82f6;--info-light: #dbeafe;--bg-primary: #fafaf9;--bg-secondary: #f5f5f4;--bg-card: #ffffff;--bg-elevated: #ffffff;--bg-overlay: rgba(0, 0, 0, .5);--text-primary: #171717;--text-secondary: #525252;--text-tertiary: #a3a3a3;--text-inverse: #ffffff;--border-color: #e5e5e5;--border-focus: var(--primary-500);--font-sans: "Inter", "Noto Sans JP", -apple-system, system-ui, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--text-4xl: 2.25rem;--font-light: 300;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--font-extrabold: 800;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.5rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .07), 0 2px 4px -2px rgba(0, 0, 0, .05);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .08), 0 4px 6px -4px rgba(0, 0, 0, .04);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 8px 10px -6px rgba(0, 0, 0, .04);--shadow-glow: 0 0 20px rgba(249, 115, 22, .3);--glass-bg: rgba(255, 255, 255, .7);--glass-border: rgba(255, 255, 255, .3);--glass-blur: 16px;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .35s ease;--transition-spring: .3s cubic-bezier(.34, 1.56, .64, 1);--sidebar-width: 260px;--header-height: 64px;--max-content-width: 1200px}[data-theme=dark]{--bg-primary: #0f0f0f;--bg-secondary: #1a1a1a;--bg-card: #1e1e1e;--bg-elevated: #262626;--bg-overlay: rgba(0, 0, 0, .7);--text-primary: #fafafa;--text-secondary: #a3a3a3;--text-tertiary: #525252;--border-color: #333333;--glass-bg: rgba(30, 30, 30, .7);--glass-border: rgba(60, 60, 60, .3);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .4), 0 2px 4px -2px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .5), 0 4px 6px -4px rgba(0, 0, 0, .3);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .6), 0 8px 10px -6px rgba(0, 0, 0, .3)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);background-color:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh;overflow-x:hidden}a{color:var(--primary-500);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--primary-600)}img{max-width:100%;height:auto;display:block}input,select,textarea,button{font-family:inherit;font-size:inherit}h1,h2,h3,h4,h5,h6{line-height:1.25;font-weight:var(--font-bold);color:var(--text-primary)}h1{font-size:var(--text-4xl)}h2{font-size:var(--text-3xl)}h3{font-size:var(--text-2xl)}h4{font-size:var(--text-xl)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--neutral-300);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--neutral-400)}#app{min-height:100vh}.app-layout{display:flex;min-height:100vh}.app-main{flex:1;display:flex;flex-direction:column;min-height:100vh;transition:margin-left var(--transition-normal)}.app-main.with-sidebar{margin-left:var(--sidebar-width)}.app-content{flex:1;padding:var(--space-8);max-width:var(--max-content-width);width:100%;margin:0 auto}.page-enter{animation:pageEnter .4s ease forwards}@keyframes pageEnter{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .3s ease forwards}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.slide-up{animation:slideUp .4s var(--transition-spring) forwards}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.stagger>*{opacity:0;animation:slideUp .4s ease forwards}.stagger>*:nth-child(1){animation-delay:.05s}.stagger>*:nth-child(2){animation-delay:.1s}.stagger>*:nth-child(3){animation-delay:.15s}.stagger>*:nth-child(4){animation-delay:.2s}.stagger>*:nth-child(5){animation-delay:.25s}.stagger>*:nth-child(6){animation-delay:.3s}.stagger>*:nth-child(7){animation-delay:.35s}.stagger>*:nth-child(8){animation-delay:.4s}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#ff9a56,#f97316,#ea580c 60%,#c2410c);position:relative;overflow:hidden}.login-page:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at 30% 70%,rgba(20,184,166,.15) 0%,transparent 50%),radial-gradient(circle at 70% 30%,rgba(255,255,255,.1) 0%,transparent 40%);animation:bgFloat 15s ease-in-out infinite}@keyframes bgFloat{0%,to{transform:translate(0) rotate(0)}33%{transform:translate(2%,-2%) rotate(1deg)}66%{transform:translate(-1%,1%) rotate(-1deg)}}.login-card{background:var(--glass-bg);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:var(--radius-2xl);padding:var(--space-12);width:100%;max-width:420px;margin:var(--space-4);box-shadow:var(--shadow-xl);position:relative;z-index:1;animation:slideUp .6s ease forwards}.login-logo{text-align:center;margin-bottom:var(--space-8)}.login-logo .icon{font-size:3.5rem;color:var(--primary-500);margin-bottom:var(--space-2);display:inline-block;background:linear-gradient(135deg,var(--primary-400),var(--primary-600));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.login-logo h1{font-size:var(--text-2xl);font-weight:var(--font-extrabold);color:var(--text-inverse);letter-spacing:-.02em}.login-logo p{color:#ffffffb3;font-size:var(--text-sm);margin-top:var(--space-1)}.login-role-tabs{display:flex;gap:var(--space-2);margin-bottom:var(--space-6);background:#ffffff1a;border-radius:var(--radius-lg);padding:var(--space-1)}.login-role-tab{flex:1;padding:var(--space-3) var(--space-4);border:none;border-radius:var(--radius-md);background:transparent;color:#fff9;font-weight:var(--font-medium);cursor:pointer;transition:all var(--transition-normal);font-size:var(--text-sm)}.login-role-tab.active{background:#fffffff2;color:var(--primary-700);box-shadow:var(--shadow-md)}.login-role-tab:hover:not(.active){color:#fff;background:#ffffff1a}.login-form .form-group{margin-bottom:var(--space-5)}.login-form label{display:block;font-size:var(--text-sm);font-weight:var(--font-medium);color:#ffffffd9;margin-bottom:var(--space-2)}.login-form input{width:100%;padding:var(--space-3) var(--space-4);background:#ffffff26;border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-lg);color:#fff;font-size:var(--text-base);transition:all var(--transition-fast);outline:none}.login-form input::placeholder{color:#fff6}.login-form input:focus{background:#fff3;border-color:#ffffff80;box-shadow:0 0 0 3px #ffffff1a}.login-hint{margin-top:var(--space-6);padding:var(--space-3) var(--space-4);background:#ffffff1a;border-radius:var(--radius-md);font-size:var(--text-xs);color:#fff9;line-height:1.5}@media (max-width: 768px){.app-main.with-sidebar{margin-left:0}.app-content{padding:var(--space-4)}.login-card{padding:var(--space-8)}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);border:none;border-radius:var(--radius-lg);font-weight:var(--font-semibold);font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-normal);white-space:nowrap;text-decoration:none;line-height:1.4;position:relative;overflow:hidden}.btn:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,rgba(255,255,255,.1) 0%,transparent 100%);opacity:0;transition:opacity var(--transition-fast)}.btn:hover:after{opacity:1}.btn:active{transform:scale(.97)}.btn .material-icons-round{font-size:1.15em}.btn-primary{background:linear-gradient(135deg,var(--primary-500) 0%,var(--primary-600) 100%);color:#fff;box-shadow:0 2px 8px #f973164d}.btn-primary:hover{box-shadow:0 4px 16px #f9731666;transform:translateY(-1px)}.btn-secondary{background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--bg-secondary);border-color:var(--neutral-300)}.btn-accent{background:linear-gradient(135deg,var(--accent-500) 0%,var(--accent-600) 100%);color:#fff;box-shadow:0 2px 8px #14b8a64d}.btn-accent:hover{box-shadow:0 4px 16px #14b8a666;transform:translateY(-1px)}.btn-danger{background:linear-gradient(135deg,var(--danger) 0%,#dc2626 100%);color:#fff}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover{background:var(--bg-secondary);color:var(--text-primary)}.btn-sm{padding:var(--space-2) var(--space-3);font-size:var(--text-xs)}.btn-lg{padding:var(--space-4) var(--space-8);font-size:var(--text-base);border-radius:var(--radius-xl)}.btn-icon{width:40px;height:40px;padding:0;border-radius:var(--radius-lg)}.btn-full{width:100%}.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-6);box-shadow:var(--shadow-sm);transition:all var(--transition-normal)}.card:hover{box-shadow:var(--shadow-md)}.card-glass{background:var(--glass-bg);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-6)}.card-title{font-size:var(--text-lg);font-weight:var(--font-semibold)}.card-subtitle{font-size:var(--text-sm);color:var(--text-secondary);margin-top:var(--space-1)}.stat-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-6);position:relative;overflow:hidden;transition:all var(--transition-normal)}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--primary-400),var(--primary-600))}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.stat-card .stat-icon{width:48px;height:48px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:1.5rem;margin-bottom:var(--space-4)}.stat-card .stat-icon.orange{background:var(--primary-100);color:var(--primary-600)}.stat-card .stat-icon.teal{background:var(--accent-100);color:var(--accent-600)}.stat-card .stat-icon.blue{background:var(--info-light);color:var(--info)}.stat-card .stat-icon.green{background:var(--success-light);color:var(--success)}.stat-card .stat-value{font-size:var(--text-3xl);font-weight:var(--font-extrabold);letter-spacing:-.03em;line-height:1}.stat-card .stat-label{font-size:var(--text-sm);color:var(--text-secondary);margin-top:var(--space-1)}.stat-card .stat-change{font-size:var(--text-xs);margin-top:var(--space-2);display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);border-radius:var(--radius-full)}.stat-card .stat-change.up{background:var(--success-light);color:#16a34a}.stat-card .stat-change.down{background:var(--danger-light);color:var(--danger)}.form-group{margin-bottom:var(--space-5)}.form-label{display:block;font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary);margin-bottom:var(--space-2)}.form-input,.form-select,.form-textarea{width:100%;padding:var(--space-3) var(--space-4);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);color:var(--text-primary);font-size:var(--text-base);transition:all var(--transition-fast);outline:none}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--primary-500);box-shadow:0 0 0 3px #f973161a}.form-textarea{min-height:100px;resize:vertical}.form-hint{margin-top:var(--space-1);font-size:var(--text-xs);color:var(--text-tertiary)}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-4)}.toggle-wrap{display:flex;align-items:center;gap:var(--space-3);cursor:pointer}.toggle{position:relative;width:44px;height:24px;background:var(--neutral-300);border-radius:var(--radius-full);transition:background var(--transition-fast);cursor:pointer}.toggle:after{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;background:#fff;border-radius:50%;transition:transform var(--transition-fast);box-shadow:var(--shadow-sm)}.toggle.active{background:var(--primary-500)}.toggle.active:after{transform:translate(20px)}.table-wrapper{overflow-x:auto;border:1px solid var(--border-color);border-radius:var(--radius-xl);background:var(--bg-card)}.data-table{width:100%;border-collapse:collapse}.data-table th{padding:var(--space-3) var(--space-4);text-align:left;font-size:var(--text-xs);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);background:var(--bg-secondary);border-bottom:1px solid var(--border-color);white-space:nowrap}.data-table td{padding:var(--space-3) var(--space-4);font-size:var(--text-sm);border-bottom:1px solid var(--border-color);vertical-align:middle}.data-table tbody tr{transition:background var(--transition-fast)}.data-table tbody tr:hover{background:var(--bg-secondary)}.data-table tbody tr:last-child td{border-bottom:none}.badge{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-semibold);white-space:nowrap}.badge-orange{background:var(--primary-100);color:var(--primary-700)}.badge-teal{background:var(--accent-100);color:var(--accent-700)}.badge-green{background:var(--success-light);color:#16a34a}.badge-red{background:var(--danger-light);color:var(--danger)}.badge-yellow{background:var(--warning-light);color:#a16207}.badge-blue{background:var(--info-light);color:#2563eb}.badge-gray{background:var(--neutral-100);color:var(--neutral-600)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg-overlay);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease;padding:var(--space-4)}.modal{background:var(--bg-card);border-radius:var(--radius-2xl);width:100%;max-width:540px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-xl);animation:slideUp .3s var(--transition-spring)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-6);border-bottom:1px solid var(--border-color)}.modal-header h3{font-size:var(--text-lg);font-weight:var(--font-semibold)}.modal-body{padding:var(--space-6)}.modal-footer{display:flex;justify-content:flex-end;gap:var(--space-3);padding:var(--space-4) var(--space-6);border-top:1px solid var(--border-color)}.tabs{display:flex;gap:var(--space-1);border-bottom:2px solid var(--border-color);margin-bottom:var(--space-6)}.tab{padding:var(--space-3) var(--space-5);border:none;background:transparent;color:var(--text-secondary);font-weight:var(--font-medium);font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-fast);position:relative;border-bottom:2px solid transparent;margin-bottom:-2px}.tab:hover{color:var(--text-primary)}.tab.active{color:var(--primary-600);border-bottom-color:var(--primary-500)}.search-bar{position:relative;max-width:400px}.search-bar .material-icons-round{position:absolute;left:var(--space-3);top:50%;transform:translateY(-50%);color:var(--text-tertiary);font-size:1.25rem}.search-bar input{width:100%;padding:var(--space-3) var(--space-4) var(--space-3) var(--space-10);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-full);color:var(--text-primary);font-size:var(--text-sm);outline:none;transition:all var(--transition-fast)}.search-bar input:focus{border-color:var(--primary-500);box-shadow:0 0 0 3px #f973161a}#toast-container{position:fixed;top:var(--space-4);right:var(--space-4);z-index:9999;display:flex;flex-direction:column;gap:var(--space-2)}.toast{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-5);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);min-width:300px;max-width:450px;animation:toastIn .4s var(--transition-spring) forwards;font-size:var(--text-sm)}.toast.removing{animation:toastOut .3s ease forwards}.toast-icon{flex-shrink:0;font-size:1.25rem}.toast.success .toast-icon{color:var(--success)}.toast.error .toast-icon{color:var(--danger)}.toast.warning .toast-icon{color:var(--warning)}.toast.info .toast-icon{color:var(--info)}.toast-message{flex:1}.toast-close{background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:var(--space-1);border-radius:var(--radius-sm);transition:color var(--transition-fast)}.toast-close:hover{color:var(--text-primary)}@keyframes toastIn{0%{opacity:0;transform:translate(100px) scale(.9)}to{opacity:1;transform:translate(0) scale(1)}}@keyframes toastOut{to{opacity:0;transform:translate(100px) scale(.9)}}.app-header{height:var(--header-height);display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-8);background:var(--glass-bg);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border-bottom:1px solid var(--border-color);position:sticky;top:0;z-index:100}.header-left{display:flex;align-items:center;gap:var(--space-4)}.header-brand{display:flex;align-items:center;gap:var(--space-2);font-weight:var(--font-bold);font-size:var(--text-lg);color:var(--primary-600)}.header-brand .material-icons-round{font-size:1.75rem}.header-nav{display:flex;gap:var(--space-1)}.header-nav a{padding:var(--space-2) var(--space-4);border-radius:var(--radius-lg);color:var(--text-secondary);font-size:var(--text-sm);font-weight:var(--font-medium);transition:all var(--transition-fast);display:flex;align-items:center;gap:var(--space-2)}.header-nav a:hover{color:var(--text-primary);background:var(--bg-secondary)}.header-nav a.active{color:var(--primary-600);background:var(--primary-50)}.header-right{display:flex;align-items:center;gap:var(--space-3)}.header-user{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-lg);cursor:pointer;transition:background var(--transition-fast)}.header-user:hover{background:var(--bg-secondary)}.header-avatar{width:32px;height:32px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--primary-400),var(--primary-600));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:var(--font-bold);font-size:var(--text-sm)}.header-user-name{font-size:var(--text-sm);font-weight:var(--font-medium)}.app-sidebar{width:var(--sidebar-width);height:100vh;position:fixed;left:0;top:0;background:var(--bg-card);border-right:1px solid var(--border-color);display:flex;flex-direction:column;z-index:200;transition:transform var(--transition-normal)}.sidebar-header{height:var(--header-height);display:flex;align-items:center;padding:0 var(--space-6);border-bottom:1px solid var(--border-color)}.sidebar-brand{display:flex;align-items:center;gap:var(--space-2);font-weight:var(--font-bold);font-size:var(--text-lg);color:var(--primary-600)}.sidebar-brand .material-icons-round{font-size:1.75rem}.sidebar-brand small{font-size:var(--text-xs);color:var(--text-tertiary);font-weight:var(--font-normal);display:block;margin-top:-2px}.sidebar-nav{flex:1;padding:var(--space-4);overflow-y:auto}.sidebar-section{margin-bottom:var(--space-6)}.sidebar-section-title{font-size:var(--text-xs);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:.05em;color:var(--text-tertiary);padding:0 var(--space-3);margin-bottom:var(--space-2)}.sidebar-link{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-3);border-radius:var(--radius-lg);color:var(--text-secondary);font-size:var(--text-sm);font-weight:var(--font-medium);transition:all var(--transition-fast);margin-bottom:var(--space-1);text-decoration:none}.sidebar-link:hover{background:var(--bg-secondary);color:var(--text-primary)}.sidebar-link.active{background:var(--primary-50);color:var(--primary-600)}.sidebar-link .material-icons-round{font-size:1.25rem}.sidebar-footer{padding:var(--space-4) var(--space-6);border-top:1px solid var(--border-color)}.sidebar-user{display:flex;align-items:center;gap:var(--space-3)}.sidebar-avatar{width:36px;height:36px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--accent-400),var(--accent-600));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:var(--font-bold);font-size:var(--text-sm)}.sidebar-user-info{flex:1}.sidebar-user-info .name{font-size:var(--text-sm);font-weight:var(--font-semibold)}.sidebar-user-info .role{font-size:var(--text-xs);color:var(--text-tertiary)}.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--space-8);flex-wrap:wrap;gap:var(--space-4)}.page-title{font-size:var(--text-2xl);font-weight:var(--font-bold);letter-spacing:-.02em}.page-subtitle{font-size:var(--text-sm);color:var(--text-secondary);margin-top:var(--space-1)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--space-4);margin-bottom:var(--space-8)}.menu-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-6)}.menu-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);overflow:hidden;transition:all var(--transition-normal);cursor:pointer}.menu-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.menu-card-image{height:180px;background:linear-gradient(135deg,var(--primary-100),var(--accent-100));display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.menu-card-image .emoji{font-size:4rem}.menu-card-image .menu-tag{position:absolute;top:var(--space-3);right:var(--space-3)}.menu-card-body{padding:var(--space-5)}.menu-card-name{font-size:var(--text-lg);font-weight:var(--font-semibold);margin-bottom:var(--space-1)}.menu-card-desc{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--space-3);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.menu-card-footer{display:flex;align-items:center;justify-content:space-between}.menu-card-price{font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--primary-600)}.menu-card-calories{font-size:var(--text-xs);color:var(--text-tertiary)}.menu-allergens{display:flex;gap:var(--space-1);margin-top:var(--space-2);flex-wrap:wrap}.allergen-tag{padding:2px 8px;border-radius:var(--radius-full);font-size:.65rem;font-weight:var(--font-semibold);background:var(--danger-light);color:var(--danger)}.cart-sidebar{position:fixed;right:0;top:0;width:380px;height:100vh;background:var(--bg-card);border-left:1px solid var(--border-color);z-index:300;display:flex;flex-direction:column;transform:translate(100%);transition:transform var(--transition-normal);box-shadow:var(--shadow-xl)}.cart-sidebar.open{transform:translate(0)}.cart-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-6);border-bottom:1px solid var(--border-color)}.cart-items{flex:1;overflow-y:auto;padding:var(--space-4)}.cart-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);border-radius:var(--radius-lg);margin-bottom:var(--space-2);transition:background var(--transition-fast)}.cart-item:hover{background:var(--bg-secondary)}.cart-item-info{flex:1}.cart-item-name{font-size:var(--text-sm);font-weight:var(--font-medium)}.cart-item-price{font-size:var(--text-sm);color:var(--primary-600);font-weight:var(--font-semibold)}.cart-qty{display:flex;align-items:center;gap:var(--space-2)}.cart-qty button{width:28px;height:28px;border:1px solid var(--border-color);background:var(--bg-card);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:var(--text-sm);transition:all var(--transition-fast)}.cart-qty button:hover{background:var(--bg-secondary)}.cart-qty span{font-weight:var(--font-semibold);min-width:20px;text-align:center}.cart-summary{padding:var(--space-6);border-top:1px solid var(--border-color)}.cart-total{display:flex;justify-content:space-between;font-size:var(--text-lg);font-weight:var(--font-bold);margin-bottom:var(--space-4)}.qr-container{display:flex;flex-direction:column;align-items:center;padding:var(--space-8)}.qr-code{padding:var(--space-6);background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);margin-bottom:var(--space-6)}.empty-state{text-align:center;padding:var(--space-16) var(--space-8)}.empty-state .material-icons-round{font-size:4rem;color:var(--text-tertiary);margin-bottom:var(--space-4)}.empty-state h3{font-size:var(--text-lg);margin-bottom:var(--space-2)}.empty-state p{color:var(--text-secondary);font-size:var(--text-sm)}.category-filter{display:flex;gap:var(--space-2);margin-bottom:var(--space-6);overflow-x:auto;padding-bottom:var(--space-2)}.category-chip{padding:var(--space-2) var(--space-4);border:1px solid var(--border-color);border-radius:var(--radius-full);background:var(--bg-card);color:var(--text-secondary);font-size:var(--text-sm);font-weight:var(--font-medium);cursor:pointer;white-space:nowrap;transition:all var(--transition-fast)}.category-chip:hover{border-color:var(--primary-300);color:var(--primary-600)}.category-chip.active{background:var(--primary-500);border-color:var(--primary-500);color:#fff}.order-timeline{display:flex;align-items:center;justify-content:space-between;padding:var(--space-6) 0;position:relative}.order-timeline:before{content:"";position:absolute;top:50%;left:10%;right:10%;height:3px;background:var(--border-color);transform:translateY(-50%)}.timeline-step{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);position:relative;z-index:1}.timeline-dot{width:40px;height:40px;border-radius:50%;background:var(--bg-card);border:3px solid var(--border-color);display:flex;align-items:center;justify-content:center;transition:all var(--transition-normal)}.timeline-step.completed .timeline-dot{background:var(--success);border-color:var(--success);color:#fff}.timeline-step.active .timeline-dot{background:var(--primary-500);border-color:var(--primary-500);color:#fff;animation:pulse 2s infinite}@keyframes pulse{0%,to{box-shadow:0 0 #f9731666}50%{box-shadow:0 0 0 8px #f9731600}}.timeline-label{font-size:var(--text-xs);color:var(--text-tertiary);font-weight:var(--font-medium);text-align:center}.timeline-step.completed .timeline-label,.timeline-step.active .timeline-label{color:var(--text-primary)}.chart-container{position:relative;height:300px;padding:var(--space-4)}.filter-bar{display:flex;align-items:center;gap:var(--space-4);margin-bottom:var(--space-6);flex-wrap:wrap}@media (max-width: 768px){.stats-grid{grid-template-columns:repeat(2,1fr)}.menu-grid{grid-template-columns:1fr}.page-header{flex-direction:column}.header-nav{display:none}.cart-sidebar{width:100%}.filter-bar{flex-direction:column;align-items:stretch}.app-sidebar{transform:translate(-100%)}.app-sidebar.open{transform:translate(0)}}
