@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-translate-x:0;--tw-translate-y:0;--tw-translate-z:0;--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-space-y-reverse:0;--tw-divide-y-reverse:0;--tw-border-style:solid;--tw-leading:initial;--tw-font-weight:initial;--tw-tracking:initial;--tw-ordinal:initial;--tw-slashed-zero:initial;--tw-numeric-figure:initial;--tw-numeric-spacing:initial;--tw-numeric-fraction:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial;--tw-duration:initial;--tw-ease:initial;--tw-scale-x:1;--tw-scale-y:1;--tw-scale-z:1}}}@layer theme{:root,:host{--font-sans:"Inter", system-ui, -apple-system, sans-serif;--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--color-red-50:oklch(97.1% .013 17.38);--color-amber-50:oklch(98.7% .022 95.277);--color-amber-100:oklch(96.2% .059 95.617);--color-amber-200:oklch(92.4% .12 95.746);--color-amber-400:oklch(82.8% .189 84.429);--color-amber-600:oklch(66.6% .179 58.318);--color-amber-700:oklch(55.5% .163 48.998);--color-amber-800:oklch(47.3% .137 46.201);--color-amber-900:oklch(41.4% .112 45.904);--color-green-50:oklch(98.2% .018 155.826);--color-green-100:oklch(96.2% .044 156.743);--color-green-200:oklch(92.5% .084 155.995);--color-green-600:oklch(62.7% .194 149.214);--color-green-700:oklch(52.7% .154 150.069);--color-blue-50:oklch(97% .014 254.604);--color-blue-100:oklch(93.2% .032 255.585);--color-blue-200:oklch(88.2% .059 254.128);--color-blue-700:oklch(48.8% .243 264.376);--color-purple-200:oklch(90.2% .063 306.703);--color-purple-600:oklch(55.8% .288 302.321);--color-slate-50:oklch(98.4% .003 247.858);--color-slate-100:oklch(96.8% .007 247.896);--color-black:#000;--color-white:#fff;--spacing:.25rem;--container-sm:24rem;--container-md:28rem;--text-xs:.75rem;--text-xs--line-height:calc(1 / .75);--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--text-base:1rem;--text-base--line-height: 1.5 ;--text-lg:1.125rem;--text-lg--line-height:calc(1.75 / 1.125);--text-xl:1.25rem;--text-xl--line-height:calc(1.75 / 1.25);--text-2xl:1.5rem;--text-2xl--line-height:calc(2 / 1.5);--text-3xl:1.875rem;--text-3xl--line-height: 1.2 ;--text-4xl:2.25rem;--text-4xl--line-height:calc(2.5 / 2.25);--text-5xl:3rem;--text-5xl--line-height:1;--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--font-weight-extrabold:800;--font-weight-black:900;--tracking-tight:-.025em;--tracking-wide:.025em;--tracking-wider:.05em;--tracking-widest:.1em;--leading-relaxed:1.625;--radius-sm:.25rem;--radius-md:.375rem;--radius-lg:.5rem;--radius-xl:.75rem;--radius-2xl:1rem;--ease-out:cubic-bezier(0, 0, .2, 1);--ease-in-out:cubic-bezier(.4, 0, .2, 1);--animate-spin:spin 1s linear infinite;--animate-pulse:pulse 2s cubic-bezier(.4, 0, .6, 1) infinite;--blur-sm:8px;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono);--color-primary:#2563eb;--color-primary-dark:#1d4ed8;--color-success:#16a34a;--color-warning:#f59e0b;--color-danger:#dc2626;--color-bg:#f1f5f9;--color-surface:#fff;--color-surface-hover:#f8fafc;--color-border:#e2e8f0;--color-text:#0f172a;--color-text-secondary:#475569;--color-text-muted:#94a3b8;--radius-card:16px;--radius-btn:10px;--radius-input:10px}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);background-color:var(--color-bg);color:var(--color-text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:15px;line-height:1.6}input,select,textarea,button{font-family:inherit}h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.3}}@layer components{.btn{border-radius:var(--radius-btn);cursor:pointer;letter-spacing:.01em;white-space:nowrap;border:none;justify-content:center;align-items:center;gap:.5rem;padding:.625rem 1.375rem;font-size:.875rem;font-weight:600;text-decoration:none;transition:all .2s;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{color:#fff;background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 2px 8px #2563eb40}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#1d4ed8,#1e40af);transform:translateY(-1px);box-shadow:0 6px 16px #2563eb59}.btn-success{color:#fff;background:linear-gradient(135deg,#16a34a,#15803d);box-shadow:0 2px 8px #16a34a40}.btn-success:hover:not(:disabled){background:linear-gradient(135deg,#15803d,#166534);transform:translateY(-1px);box-shadow:0 6px 16px #16a34a59}.btn-danger{color:#fff;background:linear-gradient(135deg,#dc2626,#b91c1c);box-shadow:0 2px 8px #dc262640}.btn-danger:hover:not(:disabled){background:linear-gradient(135deg,#b91c1c,#991b1b);transform:translateY(-1px);box-shadow:0 6px 16px #dc262659}.btn-outline{color:var(--color-primary);border:1.5px solid var(--color-primary);background:0 0}.btn-outline:hover:not(:disabled){background:var(--color-primary);color:#fff}.btn-ghost{color:var(--color-text-secondary);background:0 0;border:1.5px solid #0000}.btn-ghost:hover:not(:disabled){background:var(--color-surface-hover);color:var(--color-text);border-color:var(--color-border)}.btn-secondary{color:var(--color-text-secondary);border:1.5px solid var(--color-border);background:#f1f5f9}.btn-secondary:hover:not(:disabled){color:var(--color-text);background:#e2e8f0}.btn-warning{color:#fff;background:linear-gradient(135deg,#f59e0b,#d97706);box-shadow:0 2px 8px #f59e0b40}.btn-warning:hover:not(:disabled){background:linear-gradient(135deg,#d97706,#b45309);transform:translateY(-1px);box-shadow:0 6px 16px #f59e0b4d}.btn-sm{border-radius:8px;padding:.375rem .875rem;font-size:.8125rem}.btn-xs{border-radius:6px;padding:.25rem .625rem;font-size:.75rem}.btn-lg{padding:.875rem 2rem;font-size:1rem}.card{background:var(--color-surface);border-radius:var(--radius-card);border:1px solid #e2e8f0cc;padding:1.5rem;transition:box-shadow .2s,transform .2s;box-shadow:0 2px 12px #0000000a,0 1px 3px #00000008}.card-hover:hover{transform:translateY(-1px);box-shadow:0 8px 28px #00000014,0 2px 8px #0000000a}.card-elevated{box-shadow:0 4px 20px #00000014,0 2px 8px #0000000a}.input{border:1.5px solid var(--color-border);border-radius:var(--radius-input);width:100%;color:var(--color-text);background:var(--color-surface);outline:none;padding:.625rem 1rem;font-size:.875rem;line-height:1.5;transition:border-color .2s,box-shadow .2s}.input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #2563eb1a}.input::placeholder{color:var(--color-text-muted)}.badge{text-transform:capitalize;letter-spacing:.01em;border-radius:9999px;align-items:center;gap:.25rem;padding:.25rem .75rem;font-size:.73rem;font-weight:600;display:inline-flex}.badge-success{color:#15803d;background:#dcfce7}.badge-warning{color:#92400e;background:#fef3c7}.badge-danger{color:#991b1b;background:#fee2e2}.badge-info{color:#1e40af;background:#dbeafe}.badge-muted{color:#64748b;background:#f1f5f9}.badge-purple{color:#5b21b6;background:#ede9fe}.label{color:var(--color-text-secondary);letter-spacing:.01em;margin-bottom:.375rem;font-size:.8125rem;font-weight:600;display:block}.toggle{cursor:pointer;background:#cbd5e1;border:none;border-radius:9999px;flex-shrink:0;width:46px;height:26px;padding:0;transition:background .3s;position:relative}.toggle.active{background:var(--color-primary)}.toggle:after{content:"";background:#fff;border-radius:50%;width:20px;height:20px;transition:transform .3s;position:absolute;top:3px;left:3px;box-shadow:0 1px 4px #0003}.toggle.active:after{transform:translate(20px)}.skeleton{border-radius:var(--radius-btn);background:linear-gradient(90deg,#e2e8f0 25%,#f1f5f9,#e2e8f0 75%) 0 0/200% 100%;animation:1.5s infinite shimmer}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.login-bg{background:linear-gradient(135deg,#eef2ff,#e0e7ff,#f8fafc 60%,#dbeafe);min-height:100vh}.login-card{-webkit-backdrop-filter:blur(16px);background:#ffffffe6;border:1px solid #e2e8f0b3;border-radius:20px;padding:2rem;transition:box-shadow .2s;box-shadow:0 16px 48px #00000014,0 4px 16px #0000000a}.badge-admin{color:#15803d;background:linear-gradient(135deg,#dcfce7,#bbf7d0);border:1px solid #86efac}.badge-student{color:#1e40af;background:linear-gradient(135deg,#dbeafe,#bfdbfe);border:1px solid #93c5fd}.divider{background:var(--color-border);height:1px;margin:.75rem 0}.page-header{margin-bottom:2rem}.page-title{color:var(--color-text);letter-spacing:-.02em;font-size:1.625rem;font-weight:800;line-height:1.2}.page-subtitle{color:var(--color-text-secondary);margin-top:.375rem;font-size:.9rem}.section-title{color:var(--color-text);letter-spacing:-.01em;font-size:1.125rem;font-weight:700}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:3rem 1.5rem;display:flex}.empty-state-icon{opacity:.6;margin-bottom:1rem;font-size:3rem}.empty-state-text{color:var(--color-text-secondary);margin-bottom:.375rem;font-size:.9375rem;font-weight:600}.empty-state-sub{color:var(--color-text-muted);max-width:260px;font-size:.8125rem;line-height:1.6}.metric-card{background:var(--color-surface);border-radius:var(--radius-card);border:1px solid #e2e8f0cc;align-items:center;gap:1rem;padding:1.25rem 1.5rem;display:flex;box-shadow:0 2px 12px #0000000a}.metric-icon{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.375rem;display:flex}.metric-value{color:var(--color-text);letter-spacing:-.02em;font-size:1.75rem;font-weight:800;line-height:1}.metric-label{color:var(--color-text-muted);margin-top:.25rem;font-size:.8rem;font-weight:500}.tab-bar{background:#f1f5f9;border-radius:12px;gap:.25rem;width:fit-content;padding:.25rem;display:flex}.tab-btn{cursor:pointer;color:var(--color-text-secondary);background:0 0;border:none;border-radius:9px;padding:.5rem 1.125rem;font-size:.8rem;font-weight:600;transition:all .2s}.tab-btn.active{color:var(--color-primary);background:#fff;box-shadow:0 2px 8px #00000014}.tab-btn:not(.active):hover{color:var(--color-text);background:#fff9}.ann-card{border:1.5px solid var(--color-border);background:#fff;border-radius:12px;padding:1.125rem 1.25rem;transition:box-shadow .2s;position:relative;overflow:hidden}.ann-card:hover{box-shadow:0 4px 16px #00000012}.ann-card-important{background:#fffbeb;border-color:#fcd34d #fcd34d #fcd34d #f59e0b;border-left-style:solid;border-left-width:4px}.ann-card-important:before{display:none}.overview-root{flex-direction:column;gap:1.5rem;display:flex}.overview-header{margin-bottom:.25rem}.overview-stats-grid{grid-template-columns:repeat(4,1fr);gap:1rem;display:grid}@media(max-width:900px){.overview-stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:480px){.overview-stats-grid{grid-template-columns:1fr}}.overview-stat-card{background:var(--stat-tint,var(--color-surface));border-radius:var(--radius-card);border:1px solid #e2e8f0cc;align-items:center;gap:1rem;padding:1.25rem 1.5rem;transition:box-shadow .25s,transform .25s;display:flex;box-shadow:0 2px 12px #0000000a}.overview-stat-card:hover{transform:translateY(-2px);box-shadow:0 8px 28px #0000001a,0 2px 8px #0000000a}.overview-stat-icon{background:#ffffffb3;border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.375rem;display:flex;box-shadow:0 2px 8px #0000000f}.overview-stat-body{min-width:0}.overview-stat-value{color:var(--stat-accent,var(--color-text));letter-spacing:-.02em;font-size:1.75rem;font-weight:800;line-height:1}.overview-stat-label{color:var(--color-text-muted);white-space:nowrap;text-overflow:ellipsis;margin-top:.25rem;font-size:.8rem;font-weight:500;overflow:hidden}.overview-meal-breakdown{grid-template-columns:repeat(3,1fr);gap:1.5rem;display:grid}@media(max-width:640px){.overview-meal-breakdown{grid-template-columns:1fr;gap:1rem}}.overview-meal-item{flex-direction:column;gap:.5rem;display:flex}.overview-progress-track{background:var(--color-border);border-radius:9999px;height:.625rem;overflow:hidden}.overview-progress-fill{background:linear-gradient(90deg,#16a34a,#22c55e);border-radius:9999px;height:100%;transition:width .7s}.overview-two-col{grid-template-columns:1fr 1fr;gap:1.5rem;display:grid}@media(max-width:900px){.overview-two-col{grid-template-columns:1fr}}.overview-menu-grid{grid-template-columns:repeat(3,1fr);gap:1rem;display:grid}@media(max-width:640px){.overview-menu-grid{grid-template-columns:1fr}}.overview-menu-col{background:var(--color-surface-hover);border:1px solid var(--color-border);border-radius:12px;padding:1rem}.overview-menu-col-header{border-bottom:1px solid var(--color-border);align-items:center;gap:.5rem;margin-bottom:.75rem;padding-bottom:.5rem;display:flex}.overview-menu-col-title{color:var(--color-text);font-size:.875rem;font-weight:700}.overview-menu-list{flex-direction:column;gap:.375rem;margin:0;padding:0;list-style:none;display:flex}.overview-menu-list li{color:var(--color-text-secondary);padding-left:1rem;font-size:.8125rem;line-height:1.5;position:relative}.overview-menu-list li:before{content:"•";color:var(--color-primary);font-weight:700;position:absolute;left:0}.overview-menu-empty{color:var(--color-text-muted);font-size:.8125rem;font-style:italic}.overview-ann-list{flex-direction:column;gap:.625rem;display:flex}.overview-ann-item{border:1px solid var(--color-border);background:var(--color-surface);border-radius:12px;padding:.875rem 1rem;transition:box-shadow .2s,transform .2s}.overview-ann-item:hover{transform:translateY(-1px);box-shadow:0 4px 16px #0000000f}.overview-ann-important{background:#fffbeb;border-color:#fcd34d #fcd34d #fcd34d #f59e0b;border-left-style:solid;border-left-width:4px}.overview-ann-top{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.overview-ann-title-row{flex:1;align-items:center;gap:.375rem;min-width:0;display:flex}.overview-ann-star{flex-shrink:0;font-size:.875rem}.overview-ann-title{color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;font-size:.875rem;font-weight:600;overflow:hidden}.overview-ann-important .overview-ann-title{color:#92400e}.overview-ann-meta{flex-shrink:0}.overview-ann-desc{color:var(--color-text-secondary);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-top:.25rem;font-size:.75rem;display:-webkit-box;overflow:hidden}.overview-ann-time{color:var(--color-text-muted);margin-top:.375rem;font-size:.6875rem}.overview-charts-grid{grid-template-columns:repeat(2,1fr);gap:1.5rem;display:grid}@media(max-width:768px){.overview-charts-grid{grid-template-columns:1fr}}}@layer utilities{.pointer-events-none{pointer-events:none}.collapse{visibility:collapse}.visible{visibility:visible}.sr-only{clip-path:inset(50%);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.inset-0{inset:calc(var(--spacing) * 0)}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.top-1\/2{top:50%}.top-4{top:calc(var(--spacing) * 4)}.right-4{right:calc(var(--spacing) * 4)}.left-3{left:calc(var(--spacing) * 3)}.z-10{z-index:10}.z-\[100\]{z-index:100}.mx-4{margin-inline:calc(var(--spacing) * 4)}.mx-auto{margin-inline:auto}.-mt-2{margin-top:calc(var(--spacing) * -2)}.mt-0\.5{margin-top:calc(var(--spacing) * .5)}.mt-1{margin-top:calc(var(--spacing) * 1)}.mt-1\.5{margin-top:calc(var(--spacing) * 1.5)}.mt-2{margin-top:calc(var(--spacing) * 2)}.mt-6{margin-top:calc(var(--spacing) * 6)}.mb-0\.5{margin-bottom:calc(var(--spacing) * .5)}.mb-1{margin-bottom:calc(var(--spacing) * 1)}.mb-2{margin-bottom:calc(var(--spacing) * 2)}.mb-3{margin-bottom:calc(var(--spacing) * 3)}.mb-4{margin-bottom:calc(var(--spacing) * 4)}.mb-5{margin-bottom:calc(var(--spacing) * 5)}.mb-6{margin-bottom:calc(var(--spacing) * 6)}.mb-8{margin-bottom:calc(var(--spacing) * 8)}.ml-1{margin-left:calc(var(--spacing) * 1)}.ml-1\.5{margin-left:calc(var(--spacing) * 1.5)}.ml-auto{margin-left:auto}.line-clamp-2{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.table{display:table}.h-2{height:calc(var(--spacing) * 2)}.h-2\.5{height:calc(var(--spacing) * 2.5)}.h-3{height:calc(var(--spacing) * 3)}.h-3\.5{height:calc(var(--spacing) * 3.5)}.h-4{height:calc(var(--spacing) * 4)}.h-6{height:calc(var(--spacing) * 6)}.h-7{height:calc(var(--spacing) * 7)}.h-8{height:calc(var(--spacing) * 8)}.h-9{height:calc(var(--spacing) * 9)}.h-10{height:calc(var(--spacing) * 10)}.h-11{height:calc(var(--spacing) * 11)}.h-12{height:calc(var(--spacing) * 12)}.h-14{height:calc(var(--spacing) * 14)}.h-16{height:calc(var(--spacing) * 16)}.h-20{height:calc(var(--spacing) * 20)}.h-24{height:calc(var(--spacing) * 24)}.h-28{height:calc(var(--spacing) * 28)}.h-32{height:calc(var(--spacing) * 32)}.h-44{height:calc(var(--spacing) * 44)}.h-64{height:calc(var(--spacing) * 64)}.h-full{height:100%}.max-h-\[580px\]{max-height:580px}.min-h-screen{min-height:100vh}.w-2{width:calc(var(--spacing) * 2)}.w-3{width:calc(var(--spacing) * 3)}.w-3\.5{width:calc(var(--spacing) * 3.5)}.w-4{width:calc(var(--spacing) * 4)}.w-8{width:calc(var(--spacing) * 8)}.w-9{width:calc(var(--spacing) * 9)}.w-10{width:calc(var(--spacing) * 10)}.w-11{width:calc(var(--spacing) * 11)}.w-12{width:calc(var(--spacing) * 12)}.w-14{width:calc(var(--spacing) * 14)}.w-16{width:calc(var(--spacing) * 16)}.w-20{width:calc(var(--spacing) * 20)}.w-24{width:calc(var(--spacing) * 24)}.w-28{width:calc(var(--spacing) * 28)}.w-32{width:calc(var(--spacing) * 32)}.w-auto{width:auto}.w-full{width:100%}.max-w-md{max-width:var(--container-md)}.max-w-sm{max-width:var(--container-sm)}.min-w-0{min-width:calc(var(--spacing) * 0)}.flex-1{flex:1}.flex-shrink-0,.shrink-0{flex-shrink:0}.-translate-y-1\/2{--tw-translate-y: -50% ;translate:var(--tw-translate-x) var(--tw-translate-y)}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.animate-pulse{animation:var(--animate-pulse)}.animate-spin{animation:var(--animate-spin)}.cursor-default{cursor:default}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.resize{resize:both}.list-disc{list-style-type:disc}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-7{grid-template-columns:repeat(7,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-end{align-items:flex-end}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-1{gap:calc(var(--spacing) * 1)}.gap-1\.5{gap:calc(var(--spacing) * 1.5)}.gap-2{gap:calc(var(--spacing) * 2)}.gap-2\.5{gap:calc(var(--spacing) * 2.5)}.gap-3{gap:calc(var(--spacing) * 3)}.gap-4{gap:calc(var(--spacing) * 4)}.gap-5{gap:calc(var(--spacing) * 5)}.gap-6{gap:calc(var(--spacing) * 6)}:where(.space-y-1>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 1) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 1) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-2>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 2) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 2) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-2\.5>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 2.5) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 2.5) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-3>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 3) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 3) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-4>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 4) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 4) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-5>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 5) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 5) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-6>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 6) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 6) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-8>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 8) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 8) * calc(1 - var(--tw-space-y-reverse)))}.gap-x-4{column-gap:calc(var(--spacing) * 4)}.gap-y-1{row-gap:calc(var(--spacing) * 1)}:where(.divide-y>:not(:last-child)){--tw-divide-y-reverse:0;border-bottom-style:var(--tw-border-style);border-top-style:var(--tw-border-style);border-top-width:calc(1px * var(--tw-divide-y-reverse));border-bottom-width:calc(1px * calc(1 - var(--tw-divide-y-reverse)))}:where(.divide-border>:not(:last-child)){border-color:var(--color-border)}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.rounded{border-radius:.25rem}.rounded-2xl{border-radius:var(--radius-2xl)}.rounded-full{border-radius:3.40282e38px}.rounded-lg{border-radius:var(--radius-lg)}.rounded-md{border-radius:var(--radius-md)}.rounded-sm{border-radius:var(--radius-sm)}.rounded-xl{border-radius:var(--radius-xl)}.border{border-style:var(--tw-border-style);border-width:1px}.border-2{border-style:var(--tw-border-style);border-width:2px}.border-4{border-style:var(--tw-border-style);border-width:4px}.border-t{border-top-style:var(--tw-border-style);border-top-width:1px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-l-4{border-left-style:var(--tw-border-style);border-left-width:4px}.\!border-primary\/20{border-color:#2563eb33!important}@supports (color:color-mix(in lab,red,red)){.\!border-primary\/20{border-color:color-mix(in oklab,var(--color-primary) 20%,transparent)!important}}.\!border-purple-200{border-color:var(--color-purple-200)!important}.\!border-warning\/20{border-color:#f59e0b33!important}@supports (color:color-mix(in lab,red,red)){.\!border-warning\/20{border-color:color-mix(in oklab,var(--color-warning) 20%,transparent)!important}}.border-amber-200{border-color:var(--color-amber-200)}.border-blue-200{border-color:var(--color-blue-200)}.border-border{border-color:var(--color-border)}.border-danger\/15{border-color:#dc262626}@supports (color:color-mix(in lab,red,red)){.border-danger\/15{border-color:color-mix(in oklab,var(--color-danger) 15%,transparent)}}.border-danger\/20{border-color:#dc262633}@supports (color:color-mix(in lab,red,red)){.border-danger\/20{border-color:color-mix(in oklab,var(--color-danger) 20%,transparent)}}.border-green-200{border-color:var(--color-green-200)}.border-primary{border-color:var(--color-primary)}.border-primary\/15{border-color:#2563eb26}@supports (color:color-mix(in lab,red,red)){.border-primary\/15{border-color:color-mix(in oklab,var(--color-primary) 15%,transparent)}}.border-primary\/20{border-color:#2563eb33}@supports (color:color-mix(in lab,red,red)){.border-primary\/20{border-color:color-mix(in oklab,var(--color-primary) 20%,transparent)}}.border-success\/20{border-color:#16a34a33}@supports (color:color-mix(in lab,red,red)){.border-success\/20{border-color:color-mix(in oklab,var(--color-success) 20%,transparent)}}.border-warning\/20{border-color:#f59e0b33}@supports (color:color-mix(in lab,red,red)){.border-warning\/20{border-color:color-mix(in oklab,var(--color-warning) 20%,transparent)}}.border-warning\/25{border-color:#f59e0b40}@supports (color:color-mix(in lab,red,red)){.border-warning\/25{border-color:color-mix(in oklab,var(--color-warning) 25%,transparent)}}.border-warning\/30{border-color:#f59e0b4d}@supports (color:color-mix(in lab,red,red)){.border-warning\/30{border-color:color-mix(in oklab,var(--color-warning) 30%,transparent)}}.border-white{border-color:var(--color-white)}.border-white\/30{border-color:#ffffff4d}@supports (color:color-mix(in lab,red,red)){.border-white\/30{border-color:color-mix(in oklab,var(--color-white) 30%,transparent)}}.border-t-transparent{border-top-color:#0000}.border-t-white{border-top-color:var(--color-white)}.border-l-amber-400{border-left-color:var(--color-amber-400)}.bg-amber-50{background-color:var(--color-amber-50)}.bg-amber-100{background-color:var(--color-amber-100)}.bg-bg{background-color:var(--color-bg)}.bg-black\/40{background-color:#0006}@supports (color:color-mix(in lab,red,red)){.bg-black\/40{background-color:color-mix(in oklab,var(--color-black) 40%,transparent)}}.bg-blue-50{background-color:var(--color-blue-50)}.bg-blue-100{background-color:var(--color-blue-100)}.bg-border\/50{background-color:#e2e8f080}@supports (color:color-mix(in lab,red,red)){.bg-border\/50{background-color:color-mix(in oklab,var(--color-border) 50%,transparent)}}.bg-border\/60{background-color:#e2e8f099}@supports (color:color-mix(in lab,red,red)){.bg-border\/60{background-color:color-mix(in oklab,var(--color-border) 60%,transparent)}}.bg-danger\/5{background-color:#dc26260d}@supports (color:color-mix(in lab,red,red)){.bg-danger\/5{background-color:color-mix(in oklab,var(--color-danger) 5%,transparent)}}.bg-danger\/10{background-color:#dc26261a}@supports (color:color-mix(in lab,red,red)){.bg-danger\/10{background-color:color-mix(in oklab,var(--color-danger) 10%,transparent)}}.bg-green-50{background-color:var(--color-green-50)}.bg-green-100{background-color:var(--color-green-100)}.bg-primary{background-color:var(--color-primary)}.bg-primary\/5{background-color:#2563eb0d}@supports (color:color-mix(in lab,red,red)){.bg-primary\/5{background-color:color-mix(in oklab,var(--color-primary) 5%,transparent)}}.bg-primary\/10{background-color:#2563eb1a}@supports (color:color-mix(in lab,red,red)){.bg-primary\/10{background-color:color-mix(in oklab,var(--color-primary) 10%,transparent)}}.bg-red-50{background-color:var(--color-red-50)}.bg-slate-50{background-color:var(--color-slate-50)}.bg-slate-100{background-color:var(--color-slate-100)}.bg-success{background-color:var(--color-success)}.bg-success\/5{background-color:#16a34a0d}@supports (color:color-mix(in lab,red,red)){.bg-success\/5{background-color:color-mix(in oklab,var(--color-success) 5%,transparent)}}.bg-success\/10{background-color:#16a34a1a}@supports (color:color-mix(in lab,red,red)){.bg-success\/10{background-color:color-mix(in oklab,var(--color-success) 10%,transparent)}}.bg-surface{background-color:var(--color-surface)}.bg-surface-hover{background-color:var(--color-surface-hover)}.bg-warning\/5{background-color:#f59e0b0d}@supports (color:color-mix(in lab,red,red)){.bg-warning\/5{background-color:color-mix(in oklab,var(--color-warning) 5%,transparent)}}.bg-warning\/10{background-color:#f59e0b1a}@supports (color:color-mix(in lab,red,red)){.bg-warning\/10{background-color:color-mix(in oklab,var(--color-warning) 10%,transparent)}}.bg-white{background-color:var(--color-white)}.bg-white\/70{background-color:#ffffffb3}@supports (color:color-mix(in lab,red,red)){.bg-white\/70{background-color:color-mix(in oklab,var(--color-white) 70%,transparent)}}.\!p-0{padding:calc(var(--spacing) * 0)!important}.p-1\.5{padding:calc(var(--spacing) * 1.5)}.p-2{padding:calc(var(--spacing) * 2)}.p-3{padding:calc(var(--spacing) * 3)}.p-3\.5{padding:calc(var(--spacing) * 3.5)}.p-4{padding:calc(var(--spacing) * 4)}.px-1{padding-inline:calc(var(--spacing) * 1)}.px-1\.5{padding-inline:calc(var(--spacing) * 1.5)}.px-2{padding-inline:calc(var(--spacing) * 2)}.px-2\.5{padding-inline:calc(var(--spacing) * 2.5)}.px-3{padding-inline:calc(var(--spacing) * 3)}.px-4{padding-inline:calc(var(--spacing) * 4)}.px-5{padding-inline:calc(var(--spacing) * 5)}.px-6{padding-inline:calc(var(--spacing) * 6)}.py-0\.5{padding-block:calc(var(--spacing) * .5)}.py-1{padding-block:calc(var(--spacing) * 1)}.py-1\.5{padding-block:calc(var(--spacing) * 1.5)}.py-2{padding-block:calc(var(--spacing) * 2)}.py-2\.5{padding-block:calc(var(--spacing) * 2.5)}.py-3{padding-block:calc(var(--spacing) * 3)}.py-3\.5{padding-block:calc(var(--spacing) * 3.5)}.py-4{padding-block:calc(var(--spacing) * 4)}.py-5{padding-block:calc(var(--spacing) * 5)}.py-6{padding-block:calc(var(--spacing) * 6)}.py-8{padding-block:calc(var(--spacing) * 8)}.py-10{padding-block:calc(var(--spacing) * 10)}.py-12{padding-block:calc(var(--spacing) * 12)}.py-14{padding-block:calc(var(--spacing) * 14)}.py-16{padding-block:calc(var(--spacing) * 16)}.pt-1{padding-top:calc(var(--spacing) * 1)}.pt-5{padding-top:calc(var(--spacing) * 5)}.pt-6{padding-top:calc(var(--spacing) * 6)}.pr-1{padding-right:calc(var(--spacing) * 1)}.pb-4{padding-bottom:calc(var(--spacing) * 4)}.pb-5{padding-bottom:calc(var(--spacing) * 5)}.pl-4{padding-left:calc(var(--spacing) * 4)}.pl-9{padding-left:calc(var(--spacing) * 9)}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.font-mono{font-family:var(--font-mono)}.text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.text-3xl{font-size:var(--text-3xl);line-height:var(--tw-leading,var(--text-3xl--line-height))}.text-4xl{font-size:var(--text-4xl);line-height:var(--tw-leading,var(--text-4xl--line-height))}.text-5xl{font-size:var(--text-5xl);line-height:var(--tw-leading,var(--text-5xl--line-height))}.text-base{font-size:var(--text-base);line-height:var(--tw-leading,var(--text-base--line-height))}.text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.text-\[10px\]{font-size:10px}.text-\[11px\]{font-size:11px}.text-\[15px\]{font-size:15px}.leading-none{--tw-leading:1;line-height:1}.leading-relaxed{--tw-leading:var(--leading-relaxed);line-height:var(--leading-relaxed)}.font-black{--tw-font-weight:var(--font-weight-black);font-weight:var(--font-weight-black)}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-extrabold{--tw-font-weight:var(--font-weight-extrabold);font-weight:var(--font-weight-extrabold)}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-normal{--tw-font-weight:var(--font-weight-normal);font-weight:var(--font-weight-normal)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.tracking-tight{--tw-tracking:var(--tracking-tight);letter-spacing:var(--tracking-tight)}.tracking-wide{--tw-tracking:var(--tracking-wide);letter-spacing:var(--tracking-wide)}.tracking-wider{--tw-tracking:var(--tracking-wider);letter-spacing:var(--tracking-wider)}.tracking-widest{--tw-tracking:var(--tracking-widest);letter-spacing:var(--tracking-widest)}.text-amber-600{color:var(--color-amber-600)}.text-amber-700{color:var(--color-amber-700)}.text-amber-800{color:var(--color-amber-800)}.text-amber-900{color:var(--color-amber-900)}.text-blue-700{color:var(--color-blue-700)}.text-danger{color:var(--color-danger)}.text-danger\/80{color:#dc2626cc}@supports (color:color-mix(in lab,red,red)){.text-danger\/80{color:color-mix(in oklab,var(--color-danger) 80%,transparent)}}.text-green-600{color:var(--color-green-600)}.text-green-700{color:var(--color-green-700)}.text-primary{color:var(--color-primary)}.text-purple-600{color:var(--color-purple-600)}.text-success{color:var(--color-success)}.text-text{color:var(--color-text)}.text-text-muted{color:var(--color-text-muted)}.text-text-secondary{color:var(--color-text-secondary)}.text-warning{color:var(--color-warning)}.text-warning\/80{color:#f59e0bcc}@supports (color:color-mix(in lab,red,red)){.text-warning\/80{color:color-mix(in oklab,var(--color-warning) 80%,transparent)}}.text-white{color:var(--color-white)}.capitalize{text-transform:capitalize}.lowercase{text-transform:lowercase}.uppercase{text-transform:uppercase}.italic{font-style:italic}.tabular-nums{--tw-numeric-spacing:tabular-nums;font-variant-numeric:var(--tw-ordinal,) var(--tw-slashed-zero,) var(--tw-numeric-figure,) var(--tw-numeric-spacing,) var(--tw-numeric-fraction,)}.opacity-40{opacity:.4}.opacity-50{opacity:.5}.opacity-60{opacity:.6}.opacity-70{opacity:.7}.shadow-2xl{--tw-shadow:0 25px 50px -12px var(--tw-shadow-color,#00000040);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-inner{--tw-shadow:inset 0 2px 4px 0 var(--tw-shadow-color,#0000000d);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-lg{--tw-shadow:0 10px 15px -3px var(--tw-shadow-color,#0000001a), 0 4px 6px -4px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-sm{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.ring-2{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-primary\/25{--tw-shadow-color:#2563eb40}@supports (color:color-mix(in lab,red,red)){.shadow-primary\/25{--tw-shadow-color:color-mix(in oklab, color-mix(in oklab, var(--color-primary) 25%, transparent) var(--tw-shadow-alpha), transparent)}}.ring-primary\/20{--tw-ring-color:#2563eb33}@supports (color:color-mix(in lab,red,red)){.ring-primary\/20{--tw-ring-color:color-mix(in oklab, var(--color-primary) 20%, transparent)}}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.backdrop-blur-sm{--tw-backdrop-blur:blur(var(--blur-sm));-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-all{transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-transform{transition-property:transform,translate,scale,rotate;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.duration-200{--tw-duration:.2s;transition-duration:.2s}.duration-500{--tw-duration:.5s;transition-duration:.5s}.ease-in-out{--tw-ease:var(--ease-in-out);transition-timing-function:var(--ease-in-out)}.ease-out{--tw-ease:var(--ease-out);transition-timing-function:var(--ease-out)}.last\:border-0:last-child{border-style:var(--tw-border-style);border-width:0}@media(hover:hover){.hover\:scale-105:hover{--tw-scale-x:105%;--tw-scale-y:105%;--tw-scale-z:105%;scale:var(--tw-scale-x) var(--tw-scale-y)}.hover\:border-primary\/30:hover{border-color:#2563eb4d}@supports (color:color-mix(in lab,red,red)){.hover\:border-primary\/30:hover{border-color:color-mix(in oklab,var(--color-primary) 30%,transparent)}}.hover\:border-primary\/40:hover{border-color:#2563eb66}@supports (color:color-mix(in lab,red,red)){.hover\:border-primary\/40:hover{border-color:color-mix(in oklab,var(--color-primary) 40%,transparent)}}.hover\:bg-amber-200:hover{background-color:var(--color-amber-200)}.hover\:bg-danger\/8:hover{background-color:#dc262614}@supports (color:color-mix(in lab,red,red)){.hover\:bg-danger\/8:hover{background-color:color-mix(in oklab,var(--color-danger) 8%,transparent)}}.hover\:bg-danger\/10:hover{background-color:#dc26261a}@supports (color:color-mix(in lab,red,red)){.hover\:bg-danger\/10:hover{background-color:color-mix(in oklab,var(--color-danger) 10%,transparent)}}.hover\:bg-primary\/10:hover{background-color:#2563eb1a}@supports (color:color-mix(in lab,red,red)){.hover\:bg-primary\/10:hover{background-color:color-mix(in oklab,var(--color-primary) 10%,transparent)}}.hover\:bg-surface-hover:hover{background-color:var(--color-surface-hover)}.hover\:bg-warning\/8:hover{background-color:#f59e0b14}@supports (color:color-mix(in lab,red,red)){.hover\:bg-warning\/8:hover{background-color:color-mix(in oklab,var(--color-warning) 8%,transparent)}}.hover\:bg-white\/70:hover{background-color:#ffffffb3}@supports (color:color-mix(in lab,red,red)){.hover\:bg-white\/70:hover{background-color:color-mix(in oklab,var(--color-white) 70%,transparent)}}.hover\:text-primary-dark:hover{color:var(--color-primary-dark)}.hover\:text-text:hover{color:var(--color-text)}.hover\:shadow-sm:hover{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}}@media(min-width:40rem){.sm\:block{display:block}.sm\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.sm\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.sm\:flex-row{flex-direction:row}.sm\:items-center{align-items:center}.sm\:items-start{align-items:flex-start}}@media(min-width:48rem){.md\:block{display:block}.md\:hidden{display:none}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(min-width:64rem){.lg\:col-span-2{grid-column:span 2/span 2}.lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}}@media(min-width:80rem){.xl\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}.container-app{max-width:1200px;margin:0 auto;padding:0 2rem}.animate-fade-in{animation:.3s ease-in-out fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.animate-slide-in{animation:.3s ease-out slideIn}@keyframes slideIn{0%{opacity:0;transform:translate(-16px)}to{opacity:1;transform:translate(0)}}.animate-pulse-slow{animation:2s infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.animate-float{animation:3s ease-in-out infinite float}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.animate-scale-in{animation:.2s ease-out scaleIn}@keyframes scaleIn{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}.text-gradient{-webkit-text-fill-color:transparent;background:linear-gradient(135deg,#2563eb,#7c3aed);-webkit-background-clip:text;background-clip:text}.glass{-webkit-backdrop-filter:blur(12px);background:#fffc}.truncate-2{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}@media(max-width:900px){.meal-stats-grid{grid-template-columns:repeat(3,1fr)!important}}@media(max-width:580px){.meal-stats-grid{grid-template-columns:repeat(2,1fr)!important}}.module-select-bg{background:linear-gradient(135deg,#eef2ff,#e0e7ff,#f8fafc 60%,#dbeafe);flex-direction:column;min-height:100vh;display:flex}.module-select-topbar{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fffc;border-bottom:1px solid #e2e8f099;justify-content:space-between;align-items:center;padding:1rem 2rem;display:flex}.module-select-logo{color:var(--color-primary);letter-spacing:-.02em;align-items:center;gap:.5rem;font-size:1.25rem;font-weight:800;display:flex}.module-select-user{align-items:center;gap:1rem;display:flex}.module-select-greeting{color:var(--color-text-secondary);font-size:.875rem;font-weight:500}.module-select-main{flex-direction:column;flex:1;justify-content:center;align-items:center;padding:3rem 1.5rem;display:flex}.module-select-hero{text-align:center;margin-bottom:3rem}.module-select-title{color:var(--color-text);letter-spacing:-.03em;margin-bottom:.5rem;font-size:2.25rem;font-weight:900}.module-select-subtitle{color:var(--color-text-secondary);font-size:1rem}.module-cards-grid{grid-template-columns:repeat(2,1fr);gap:1.75rem;width:100%;max-width:780px;display:grid}@media(max-width:600px){.module-cards-grid{grid-template-columns:1fr}.module-select-title{font-size:1.6rem}}.module-card{text-align:left;cursor:pointer;box-shadow:0 4px 24px var(--mod-shadow,#00000014);background:#fff;border:1px solid #e2e8f0b3;border-radius:24px;flex-direction:column;gap:.75rem;padding:2.25rem 2rem;transition:transform .25s,box-shadow .25s;display:flex;position:relative;overflow:hidden}.module-card:before{content:"";background:var(--mod-gradient);border-radius:24px 24px 0 0;height:4px;position:absolute;top:0;left:0;right:0}.module-card:hover{box-shadow:0 16px 48px var(--mod-shadow-hover,#00000026);transform:translateY(-6px)}.module-card-badge{color:#fff;letter-spacing:.05em;text-transform:uppercase;background:linear-gradient(135deg,#f59e0b,#ef4444);border-radius:999px;padding:.2rem .6rem;font-size:.7rem;font-weight:700;position:absolute;top:1.25rem;right:1.25rem}.module-card-icon{margin-bottom:.25rem;font-size:3rem;line-height:1}.module-card-title{color:var(--color-text);letter-spacing:-.02em;font-size:1.375rem;font-weight:800}.module-card-desc{color:var(--color-text-secondary);font-size:.9rem;line-height:1.5}.module-card-highlight{flex-wrap:wrap;gap:.375rem;margin-top:.25rem;display:flex}.module-highlight-chip{color:var(--color-text-secondary);border:1px solid var(--color-border);background:#f1f5f9;border-radius:999px;padding:.2rem .6rem;font-size:.72rem;font-weight:600}.module-card-cta{color:var(--color-primary);align-items:center;gap:.375rem;margin-top:auto;padding-top:1rem;font-size:.9rem;font-weight:700;display:flex}.module-select-footer{color:var(--color-text-muted);text-align:center;margin-top:3rem;font-size:.8rem}.canteen-page{max-width:900px;min-height:100vh;margin:0 auto;padding:1.5rem 1.25rem 6rem}.canteen-page-header{margin-bottom:1.75rem}.canteen-grid,.canteen-loading{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;display:grid}.canteen-card-skeleton{background:#fff;border-radius:16px;overflow:hidden}.canteen-card{background:#fff;border:1px solid #e2e8f0cc;border-radius:20px;flex-direction:column;transition:transform .22s,box-shadow .22s;display:flex;overflow:hidden;box-shadow:0 2px 16px #0000000d}.canteen-card:hover{transform:translateY(-4px);box-shadow:0 12px 36px #0000001a}.canteen-card-img{background:linear-gradient(135deg,#f1f5f9,#e2e8f0);height:180px;position:relative;overflow:hidden}.canteen-card-img img{object-fit:cover;width:100%;height:100%}.canteen-card-img-placeholder{opacity:.4;justify-content:center;align-items:center;width:100%;height:100%;font-size:4rem;display:flex}.canteen-status-badge{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:999px;align-items:center;gap:.375rem;padding:.3rem .75rem;font-size:.75rem;font-weight:700;display:inline-flex;position:absolute;top:.75rem;right:.75rem}.canteen-status-badge.open{color:#15803d;background:#dcfce7e6}.canteen-status-badge.closed{color:#991b1b;background:#fee2e2e6}.canteen-status-dot{border-radius:50%;width:7px;height:7px}.canteen-status-badge.open .canteen-status-dot{background:#16a34a;animation:1.5s infinite pulse-green}.canteen-status-badge.closed .canteen-status-dot{background:#dc2626}@keyframes pulse-green{0%,to{opacity:1}50%{opacity:.4}}.canteen-card-body{flex-direction:column;flex:1;gap:.625rem;padding:1.25rem;display:flex}.canteen-card-name{color:var(--color-text);letter-spacing:-.01em;font-size:1.125rem;font-weight:800}.canteen-card-desc{color:var(--color-text-secondary);font-size:.8375rem;line-height:1.5}.canteen-card-meta{flex-direction:column;gap:.25rem;display:flex}.canteen-meta-item{color:var(--color-text-muted);align-items:center;gap:.375rem;font-size:.8rem;display:flex}.canteen-card-cats{flex-wrap:wrap;gap:.375rem;display:flex}.canteen-cat-pill{color:var(--color-text-secondary);border:1px solid var(--color-border);background:#f1f5f9;border-radius:999px;padding:.2rem .5rem;font-size:.7rem;font-weight:600}.canteen-card-footer{margin-top:auto;padding-top:.75rem}.menu-category-tabs{scrollbar-width:none;gap:.5rem;margin-bottom:1.5rem;padding-bottom:.25rem;display:flex;overflow-x:auto}.menu-category-tabs::-webkit-scrollbar{display:none}.menu-category-tab{white-space:nowrap;border:1.5px solid var(--color-border);color:var(--color-text-secondary);cursor:pointer;background:#fff;border-radius:999px;flex-shrink:0;align-items:center;gap:.375rem;padding:.55rem 1.125rem;font-size:.85rem;font-weight:600;transition:all .2s;display:inline-flex}.menu-category-tab.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary);box-shadow:0 2px 8px #2563eb40}.menu-category-tab:not(.active):hover{color:var(--color-text);background:#f1f5f9}.menu-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;display:grid}.menu-item-card{border:1.5px solid var(--color-border);background:#fff;border-radius:14px;flex-direction:column;gap:.5rem;padding:1rem;transition:box-shadow .2s,transform .2s;display:flex}.menu-item-card:hover{transform:translateY(-1px);box-shadow:0 4px 16px #00000012}.menu-item-card.unavailable{opacity:.55}.menu-item-top{justify-content:space-between;align-items:center;display:flex}.menu-item-body{justify-content:space-between;align-items:flex-start;gap:.75rem;display:flex}.menu-item-name{color:var(--color-text);font-size:.9375rem;font-weight:700}.menu-item-desc{color:var(--color-text-muted);margin-top:.2rem;font-size:.78rem;line-height:1.4}.menu-item-price{color:var(--color-primary);margin-top:.375rem;font-size:1rem;font-weight:800}.veg-dot,.nonveg-dot{border:1.5px solid;border-radius:2px;flex-shrink:0;width:14px;height:14px;display:inline-block}.veg-dot{border-color:#16a34a;position:relative}.veg-dot:after{content:"";background:#16a34a;border-radius:50%;width:6px;height:6px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.nonveg-dot{border-color:#dc2626;position:relative}.nonveg-dot:after{content:"";background:#dc2626;border-radius:50%;width:6px;height:6px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.qty-controls{background:#f1f5f9;border-radius:999px;flex-shrink:0;align-items:center;gap:.5rem;padding:.25rem .5rem;display:flex}.qty-btn{width:28px;height:28px;color:var(--color-text);cursor:pointer;background:#fff;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:1.1rem;font-weight:700;transition:background .15s;display:flex;box-shadow:0 1px 4px #0000001a}.qty-btn:hover{background:var(--color-border)}.qty-btn-add{background:var(--color-primary);color:#fff}.qty-btn-add:hover{background:var(--color-primary-dark)}.qty-value{text-align:center;min-width:20px;font-size:.9rem;font-weight:700}.cart-fab-container{z-index:100;width:min(480px,100vw - 2rem);position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%)}.cart-fab{background:var(--color-primary);color:#fff;cursor:pointer;border:none;border-radius:16px;justify-content:space-between;align-items:center;width:100%;padding:1rem 1.25rem;transition:transform .2s,box-shadow .2s;display:flex;box-shadow:0 8px 24px #2563eb66}.cart-fab:hover{transform:translateY(-2px);box-shadow:0 12px 32px #2563eb80}.cart-fab-left{align-items:center;gap:.75rem;display:flex}.cart-fab-count{background:#ffffff40;border-radius:8px;padding:.2rem .6rem;font-size:.875rem;font-weight:700}.cart-fab-label{font-size:.875rem;font-weight:600}.cart-fab-right{align-items:center;gap:.5rem;display:flex}.cart-fab-total{font-size:1rem;font-weight:800}.cart-fab-arrow{opacity:.8;font-size:1rem}.cart-items-list{flex-direction:column;gap:.75rem;margin-bottom:1.5rem;display:flex}.cart-item-row{border:1.5px solid var(--color-border);background:#fff;border-radius:14px;justify-content:space-between;align-items:center;gap:1rem;padding:1rem 1.25rem;display:flex}.cart-item-left{flex:1;align-items:center;gap:.75rem;min-width:0;display:flex}.cart-item-name{color:var(--color-text);font-size:.9375rem;font-weight:700}.cart-item-unit{color:var(--color-text-muted);margin-top:.1rem;font-size:.8rem}.cart-item-right{flex-shrink:0;align-items:center;gap:1rem;display:flex}.cart-item-subtotal{color:var(--color-text);text-align:right;min-width:70px;font-size:.9375rem;font-weight:800}.cart-summary-card{border:1.5px solid var(--color-border);background:#fff;border-radius:16px;padding:1.5rem;box-shadow:0 4px 20px #0000000d}.cart-summary-row{color:var(--color-text);justify-content:space-between;align-items:center;margin-bottom:.5rem;font-size:.9rem;display:flex}.cart-summary-total{color:var(--color-text);margin-bottom:0;font-size:1.125rem;font-weight:800}.pickup-slots-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.625rem;display:grid}.pickup-slot-btn{border:1.5px solid var(--color-border);color:var(--color-text);cursor:pointer;text-align:center;background:#fff;border-radius:10px;padding:.625rem .5rem;font-size:.8rem;font-weight:600;transition:all .2s}.pickup-slot-btn:hover{border-color:var(--color-primary);color:var(--color-primary);background:#eef2ff}.pickup-slot-btn.selected{background:var(--color-primary);color:#fff;border-color:var(--color-primary);box-shadow:0 2px 8px #2563eb4d}.checkout-success-card{text-align:center;background:#fff;border:1px solid #e2e8f0b3;border-radius:24px;margin-top:2rem;padding:2.5rem 2rem;box-shadow:0 8px 32px #00000012}.checkout-success-icon{margin-bottom:.75rem;font-size:3.5rem}.checkout-success-title{color:var(--color-text);margin-bottom:.5rem;font-size:1.75rem;font-weight:900}.checkout-success-sub{color:var(--color-text-secondary);margin-bottom:1.5rem;font-size:.9rem}.checkout-qr-wrapper{border:1.5px solid var(--color-border);background:#fff;border-radius:16px;justify-content:center;margin:1.5rem 0;padding:1rem;display:inline-block}.checkout-order-meta{background:#f8fafc;border-radius:12px;flex-direction:column;gap:.5rem;margin-top:1rem;padding:1rem 1.25rem;display:flex}.checkout-meta-row{color:var(--color-text);justify-content:space-between;align-items:center;font-size:.875rem;display:flex}.order-card{border:1.5px solid var(--color-border);background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 2px 12px #0000000a}.order-card-header{cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:1rem;width:100%;padding:1rem 1.25rem;transition:background .15s;display:flex}.order-card-header:hover{background:#f8fafc}.order-card-left{flex:1;min-width:0}.order-card-canteen{color:var(--color-text);font-size:.9375rem;font-weight:700}.order-card-date{color:var(--color-text-muted);margin-top:.15rem;font-size:.775rem}.order-card-right{flex-direction:column;align-items:flex-end;gap:.3rem;display:flex}.order-card-amount{color:var(--color-text);font-size:.9rem;font-weight:800}.order-card-chevron{color:var(--color-text-muted);font-size:1rem;transition:transform .2s}.order-card-detail{border-top:1px solid var(--color-border);background:#fafafa;flex-direction:column;gap:1rem;padding:1.25rem;display:flex}.order-detail-meta{color:var(--color-text-secondary);flex-wrap:wrap;gap:1rem;font-size:.8rem;display:flex}.order-detail-items{flex-direction:column;gap:.5rem;display:flex}.order-detail-item{color:var(--color-text);border-bottom:1px dashed var(--color-border);justify-content:space-between;align-items:center;padding:.375rem 0;font-size:.875rem;display:flex}.order-detail-item:last-child{border-bottom:none}.order-detail-qr{flex-direction:column;align-items:center;gap:.625rem;padding-top:.5rem;display:flex}.order-qr-label{color:var(--color-text-secondary);font-size:.8rem;font-weight:600}.order-status-badge{border-radius:999px;align-items:center;gap:.375rem;padding:.3rem .875rem;font-size:.78rem;font-weight:700;display:inline-flex}.order-status-sm{padding:.2rem .6rem;font-size:.7rem}.order-status-emoji{font-size:.85em}.order-status-not-preparing{color:#475569;background:#f1f5f9}.order-status-preparing{color:#92400e;background:#fef3c7}.order-status-prepared{color:#15803d;background:#dcfce7}}@property --tw-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-z{syntax:"*";inherits:false;initial-value:0}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-divide-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-ordinal{syntax:"*";inherits:false}@property --tw-slashed-zero{syntax:"*";inherits:false}@property --tw-numeric-figure{syntax:"*";inherits:false}@property --tw-numeric-spacing{syntax:"*";inherits:false}@property --tw-numeric-fraction{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}@property --tw-duration{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}@property --tw-scale-x{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-y{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-z{syntax:"*";inherits:false;initial-value:1}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{50%{opacity:.5}}.ms-layout{display:flex;height:100vh;overflow:hidden;background:#f1f5f9}.ms-main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.ms-content{flex:1;overflow-y:auto;padding:2rem 2.25rem}.ms-sidebar{width:256px;height:100vh;background:#0f172a;color:#fff;display:flex;flex-direction:column;flex-shrink:0;transition:width .25s ease;overflow:hidden;z-index:50}.ms-sidebar.collapsed{width:68px}.ms-brand{display:flex;align-items:center;gap:.75rem;padding:1.125rem 1rem;border-bottom:1px solid rgba(255,255,255,.07);min-height:64px;flex-shrink:0}.ms-brand-logo{width:36px;height:36px;border-radius:10px;flex-shrink:0;background:linear-gradient(135deg,#2563eb,#7c3aed);display:flex;align-items:center;justify-content:center;font-size:1.0625rem;font-weight:900;color:#fff;box-shadow:0 4px 14px #2563eb66;letter-spacing:-.02em}.ms-brand-text{overflow:hidden;white-space:nowrap;flex:1;min-width:0}.ms-brand-name{font-size:.9375rem;font-weight:800;letter-spacing:-.02em;color:#fff}.ms-brand-sub{font-size:.6625rem;color:#fff6;font-weight:500;margin-top:1px}.ms-collapse-btn{margin-left:auto;background:#ffffff12;border:none;color:#ffffffa6;width:26px;height:26px;border-radius:7px;cursor:pointer;font-size:1.1rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s,color .15s}.ms-collapse-btn:hover{background:#ffffff24;color:#fff}.ms-nav{flex:1;padding:.75rem .5rem;display:flex;flex-direction:column;gap:2px;overflow-y:auto;scrollbar-width:none}.ms-nav::-webkit-scrollbar{display:none}.ms-nav-divider{height:1px;background:#ffffff12;margin:.375rem .25rem}.ms-nav-section-label{font-size:.625rem;color:#ffffff4d;font-weight:700;text-transform:uppercase;letter-spacing:.1em;padding:.5rem .875rem .25rem;white-space:nowrap;overflow:hidden}.ms-nav-item{display:flex;align-items:center;gap:.75rem;padding:.625rem .875rem;border-radius:10px;border:none;background:transparent;color:#ffffff94;cursor:pointer;text-decoration:none;font-size:.845rem;font-weight:500;transition:background .15s,color .15s;white-space:nowrap;width:100%;position:relative;text-align:left}.ms-nav-item:hover{background:#ffffff14;color:#ffffffe6}.ms-nav-item.active{background:#2563eb4d;color:#fff;font-weight:600}.ms-nav-item.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:18px;background:#60a5fa;border-radius:0 3px 3px 0}.ms-nav-icon{font-size:1rem;flex-shrink:0;width:20px;text-align:center;display:flex;align-items:center;justify-content:center}.ms-nav-label{flex:1;overflow:hidden;text-overflow:ellipsis}.ms-nav-badge{background:#ef4444;color:#fff;font-size:.675rem;font-weight:700;padding:.1rem .45rem;border-radius:999px;flex-shrink:0;line-height:1.4}.ms-footer{padding:.625rem .5rem .75rem;border-top:1px solid rgba(255,255,255,.07);display:flex;flex-direction:column;gap:2px;flex-shrink:0}.ms-footer-label{font-size:.625rem;color:#ffffff47;font-weight:700;text-transform:uppercase;letter-spacing:.1em;padding:.375rem .875rem .125rem;white-space:nowrap;overflow:hidden}.ms-user-card{margin:.375rem .25rem .125rem;background:#ffffff0d;border-radius:10px;padding:.6rem .75rem;display:flex;align-items:center;gap:.625rem;overflow:hidden;border:1px solid rgba(255,255,255,.06)}.ms-user-avatar{width:30px;height:30px;border-radius:8px;flex-shrink:0;background:linear-gradient(135deg,#2563eb,#7c3aed);display:flex;align-items:center;justify-content:center;font-size:.8125rem;font-weight:700;color:#fff}.ms-user-info{flex:1;min-width:0;overflow:hidden}.ms-user-name{font-size:.775rem;font-weight:600;color:#ffffffd1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ms-user-role{font-size:.6375rem;color:#ffffff61;margin-top:1px}.ms-signout-btn{background:none;border:none;cursor:pointer;color:#ffffff4d;flex-shrink:0;padding:4px;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:color .15s,background .15s}.ms-signout-btn:hover{color:#f87171;background:#ef44441f}.ms-topbar{background:#fff;border-bottom:1px solid #E2E8F0;height:64px;display:flex;align-items:center;justify-content:space-between;padding:0 1.75rem;position:sticky;top:0;z-index:20;box-shadow:0 1px 8px #0000000d;flex-shrink:0}.ms-topbar-left{display:flex;align-items:center;gap:.75rem}.ms-topbar-title{font-size:1.0625rem;font-weight:800;color:#0f172a;letter-spacing:-.02em}.ms-topbar-right{display:flex;align-items:center;gap:.5rem}.ms-mobile-menu-btn{display:none;background:none;border:none;cursor:pointer;color:#64748b;width:36px;height:36px;border-radius:8px;align-items:center;justify-content:center;transition:background .15s}.ms-mobile-menu-btn:hover{background:#f1f5f9}.ms-overlay{display:none;position:fixed;inset:0;background:#0000008c;z-index:40;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}@media(max-width:1024px){.ms-sidebar{position:fixed;top:0;left:0;transform:translate(-100%);transition:transform .28s ease,width .25s ease}.ms-sidebar.mobile-open{transform:translate(0)}.ms-mobile-menu-btn{display:flex}.ms-overlay{display:block}.ms-content{padding:1.25rem}}@media(max-width:640px){.ms-topbar{padding:0 1rem}.ms-content{padding:1rem}}.ct-layout{display:flex;height:100vh;overflow:hidden;background:#f1f5f9}.ct-main{flex:1;display:flex;flex-direction:column;overflow:hidden}.ct-content{flex:1;overflow-y:auto;padding:1.5rem}.ct-sidebar{width:240px;height:100vh;background:#0f172a;color:#fff;display:flex;flex-direction:column;flex-shrink:0;transition:width .25s ease;overflow:hidden}.ct-sidebar.collapsed{width:64px}.ct-sidebar-brand{display:flex;align-items:center;gap:.75rem;padding:1.25rem 1rem;border-bottom:1px solid rgba(255,255,255,.08);min-height:64px}.ct-brand-icon{font-size:1.5rem;flex-shrink:0}.ct-brand-text{font-size:1.1rem;font-weight:800;letter-spacing:-.02em;white-space:nowrap}.ct-collapse-btn{margin-left:auto;background:#ffffff1a;border:none;color:#fff;width:24px;height:24px;border-radius:6px;cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.ct-sidebar-nav{flex:1;padding:.75rem .5rem;display:flex;flex-direction:column;gap:2px;overflow-y:auto}.ct-sidebar-divider{height:1px;background:#ffffff14;margin:.5rem 0}.ct-sidebar-section-label{font-size:.68rem;color:#fff6;font-weight:600;text-transform:uppercase;letter-spacing:.08em;padding:0 .5rem .25rem}.ct-nav-item{display:flex;align-items:center;gap:.75rem;padding:.625rem .75rem;border-radius:10px;border:none;background:transparent;color:#ffffffa6;cursor:pointer;text-decoration:none;font-size:.875rem;font-weight:500;transition:all .15s ease;white-space:nowrap;width:100%}.ct-nav-item:hover{background:#ffffff14;color:#fff}.ct-nav-item.active{background:#2563eb59;color:#fff;font-weight:600}.ct-nav-icon{font-size:1.1rem;flex-shrink:0;width:20px;text-align:center;display:flex;align-items:center;justify-content:center}.ct-nav-label{flex:1}.ct-nav-badge{background:#ef4444;color:#fff;font-size:.7rem;font-weight:700;padding:.15rem .5rem;border-radius:999px;flex-shrink:0}.ct-sidebar-footer{padding:.75rem .5rem;border-top:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;gap:2px}.ct-sidebar-user{padding:.75rem}.ct-user-name{display:block;font-size:.8rem;font-weight:600;color:#ffffffb3;margin-bottom:.375rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ct-signout-btn{font-size:.75rem;color:#fff6;background:none;border:none;cursor:pointer;padding:0}.ct-signout-btn:hover{color:#fff}.ct-topbar{background:#fff;border-bottom:1px solid #E2E8F0;padding:.75rem 1.25rem;display:flex;flex-direction:column;gap:.625rem;min-height:auto;position:sticky;top:0;z-index:10;box-shadow:0 1px 6px #0000000d}.ct-topbar-search{position:relative;display:flex;align-items:center}.ct-search-icon{position:absolute;left:.875rem;font-size:.9rem;pointer-events:none;color:#94a3b8}.ct-search-input{width:100%;padding:.625rem 1rem .625rem 2.5rem;border:1.5px solid #E2E8F0;border-radius:10px;font-size:.875rem;outline:none;transition:border .2s ease;background:#f8fafc;color:#0f172a}.ct-search-input:focus{border-color:#2563eb;background:#fff;box-shadow:0 0 0 3px #2563eb1a}.ct-search-clear{position:absolute;right:.75rem;background:none;border:none;cursor:pointer;color:#94a3b8;font-size:.9rem}.ct-topbar-filters{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center}.ct-filter-select{padding:.4rem .75rem;border:1.5px solid #E2E8F0;border-radius:8px;font-size:.8rem;font-weight:500;background:#fff;color:#0f172a;cursor:pointer;outline:none}.ct-filter-select:focus{border-color:#2563eb}.ct-diet-btn{display:flex;align-items:center;gap:.375rem;padding:.4rem .875rem;border:1.5px solid #E2E8F0;border-radius:8px;font-size:.8rem;font-weight:600;background:#fff;color:#475569;cursor:pointer;transition:all .15s ease}.ct-diet-btn.active-veg{border-color:#16a34a;background:#dcfce7;color:#15803d}.ct-diet-btn.active-nonveg{border-color:#dc2626;background:#fee2e2;color:#991b1b}.ct-avail-btn{padding:.4rem .875rem;border:1.5px solid #E2E8F0;border-radius:8px;font-size:.8rem;font-weight:600;background:#fff;color:#475569;cursor:pointer;transition:all .15s ease}.ct-avail-btn.active{border-color:#2563eb;background:#dbeafe;color:#1e40af}.ct-page{padding:.25rem 0 3rem}.ct-page-header{margin-bottom:1.5rem}.ct-page-title{font-size:1.5rem;font-weight:800;color:#0f172a;letter-spacing:-.02em}.ct-page-subtitle{font-size:.875rem;color:#475569;margin-top:.25rem}.ct-stats-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;font-size:.85rem;color:#64748b}.ct-canteen-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.ct-canteen-skeleton{background:#fff;border-radius:18px;overflow:hidden;box-shadow:0 2px 12px #0000000d}.ct-canteen-card{background:#fff;border-radius:18px;overflow:hidden;box-shadow:0 2px 16px #0000000f;border:1px solid rgba(226,232,240,.7);transition:transform .22s ease,box-shadow .22s ease;display:flex;flex-direction:column}.ct-canteen-card:hover{transform:translateY(-4px);box-shadow:0 12px 36px #0000001c}.ct-canteen-card--closed{opacity:.72;cursor:not-allowed}.ct-canteen-banner{height:180px;position:relative;overflow:hidden}.ct-canteen-banner img{width:100%;height:100%;object-fit:cover}.ct-canteen-banner-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,transparent 30%,rgba(0,0,0,.6))}.ct-canteen-banner-title{position:absolute;bottom:.875rem;left:1rem;color:#fff}.ct-canteen-banner-title h3{font-size:1.125rem;font-weight:800;text-shadow:0 1px 4px rgba(0,0,0,.4)}.ct-canteen-banner-title p{font-size:.78rem;opacity:.9;margin-top:.15rem}.ct-status-badge{position:absolute;top:.75rem;right:.75rem;display:inline-flex;align-items:center;gap:.375rem;padding:.3rem .75rem;border-radius:999px;font-size:.73rem;font-weight:700;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.ct-status-open{background:#dcfce7eb;color:#15803d}.ct-status-closing{background:#fef3c7eb;color:#92400e}.ct-status-closed{background:#fee2e2eb;color:#991b1b}.ct-status-dot{width:7px;height:7px;border-radius:50%;background:currentColor}.ct-status-dot.pulse{animation:ct-pulse 1.4s infinite}@keyframes ct-pulse{0%,to{opacity:1}50%{opacity:.35}}.ct-canteen-body{padding:1rem 1.125rem 1.125rem;display:flex;flex-direction:column;gap:.5rem;flex:1}.ct-canteen-hours{font-size:.78rem;color:#64748b}.ct-canteen-desc{font-size:.82rem;color:#475569;line-height:1.5}.ct-canteen-cta{margin-top:auto;width:100%}.ct-cat-pills{display:flex;gap:.5rem;margin-bottom:1.25rem;overflow-x:auto;padding-bottom:.25rem;scrollbar-width:none}.ct-cat-pills::-webkit-scrollbar{display:none}.ct-cat-pill{display:inline-flex;align-items:center;gap:.3rem;padding:.45rem 1rem;border-radius:999px;font-size:.82rem;font-weight:600;white-space:nowrap;flex-shrink:0;border:1.5px solid #E2E8F0;background:#fff;color:#475569;cursor:pointer;transition:all .15s ease}.ct-cat-pill.active{background:#2563eb;color:#fff;border-color:#2563eb;box-shadow:0 2px 8px #2563eb47}.ct-cat-pill:not(.active):hover{background:#f1f5f9;color:#0f172a}.ct-results-count{font-size:.8rem;color:#94a3b8;margin-bottom:.875rem}.ct-menu-section{margin-bottom:2rem}.ct-menu-section-title{font-size:1.05rem;font-weight:700;color:#0f172a;margin-bottom:.875rem;display:flex;align-items:center;gap:.375rem}.ct-menu-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem}.ct-menu-skeleton{background:#fff;border-radius:14px;overflow:hidden}.ct-menu-card{background:#fff;border-radius:14px;border:1.5px solid #E2E8F0;overflow:hidden;display:flex;flex-direction:column;transition:transform .2s ease,box-shadow .2s ease}.ct-menu-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px #00000014}.ct-menu-card--unavailable{opacity:.55}.ct-menu-img{height:140px;position:relative;overflow:hidden}.ct-menu-img img{width:100%;height:100%;object-fit:cover}.ct-menu-sold-out{position:absolute;inset:0;background:#00000080;color:#fff;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;letter-spacing:.05em}.ct-menu-body{padding:.875rem;display:flex;flex-direction:column;gap:.375rem;flex:1}.ct-menu-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:.25rem}.ct-diet-badge{display:inline-flex;align-items:center;gap:.3rem;font-size:.68rem;font-weight:700;padding:.15rem .5rem;border-radius:999px}.ct-diet-badge.veg{background:#dcfce7;color:#15803d}.ct-diet-badge.nonveg{background:#fee2e2;color:#991b1b}.ct-menu-canteen-tag{font-size:.66rem;color:#94a3b8;background:#f1f5f9;padding:.1rem .4rem;border-radius:4px}.ct-menu-name{font-size:.9375rem;font-weight:700;color:#0f172a;line-height:1.3}.ct-menu-desc{font-size:.775rem;color:#64748b;line-height:1.4}.ct-menu-price{font-size:1rem;font-weight:800;color:#2563eb}.ct-menu-action{margin-top:auto;padding-top:.5rem}.ct-add-btn{width:100%;padding:.5rem;border-radius:8px;border:1.5px solid #2563EB;background:#fff;color:#2563eb;font-size:.85rem;font-weight:700;cursor:pointer;transition:all .15s ease}.ct-add-btn:hover{background:#2563eb;color:#fff}.ct-menu-unavail-label{font-size:.78rem;color:#94a3b8}.veg-dot,.nonveg-dot{width:13px;height:13px;border-radius:2px;flex-shrink:0;display:inline-block;border:1.5px solid;position:relative}.veg-dot{border-color:#16a34a}.veg-dot:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:6px;height:6px;border-radius:50%;background:#16a34a}.nonveg-dot{border-color:#dc2626}.nonveg-dot:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:6px;height:6px;border-radius:50%;background:#dc2626}.qty-controls{display:flex;align-items:center;gap:.5rem;background:#f1f5f9;border-radius:999px;padding:.2rem .4rem}.qty-btn{width:28px;height:28px;border-radius:50%;border:none;background:#fff;color:#0f172a;font-size:1.1rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 1px 3px #0000001a;transition:background .15s}.qty-btn:hover{background:#e2e8f0}.qty-btn-add{background:#2563eb;color:#fff}.qty-btn-add:hover{background:#1d4ed8}.qty-value{font-weight:700;font-size:.9rem;min-width:20px;text-align:center}.ct-cart-layout{display:grid;grid-template-columns:1fr 360px;gap:1.5rem;align-items:start}@media(max-width:900px){.ct-cart-layout{grid-template-columns:1fr}}.ct-cart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;font-size:.875rem;font-weight:600;color:#475569}.ct-cart-items{display:flex;flex-direction:column;gap:0;background:#fff;border-radius:16px;border:1.5px solid #E2E8F0;overflow:hidden}.ct-cart-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.875rem 1.125rem;border-bottom:1px solid #F1F5F9}.ct-cart-row:last-child{border-bottom:none}.ct-cart-row-left{display:flex;align-items:center;gap:.75rem;flex:1;min-width:0}.ct-cart-item-name{font-size:.9rem;font-weight:700;color:#0f172a}.ct-cart-item-unit{font-size:.775rem;color:#94a3b8;margin-top:.1rem}.ct-cart-row-right{display:flex;align-items:center;gap:.875rem;flex-shrink:0}.ct-cart-item-total{font-size:.9rem;font-weight:800;color:#0f172a;min-width:64px;text-align:right}.ct-cart-summary{background:#fff;border-radius:16px;border:1.5px solid #E2E8F0;padding:1.25rem;position:sticky;top:1rem}.ct-cart-summary-title{font-size:1rem;font-weight:700;color:#0f172a;margin-bottom:1rem}.ct-cart-summary-rows{display:flex;flex-direction:column;gap:.5rem}.ct-cart-summary-row{display:flex;justify-content:space-between;font-size:.875rem;color:#0f172a}.ct-cart-summary-row.muted{color:#94a3b8;font-size:.82rem}.ct-cart-divider{height:1px;background:#f1f5f9;margin:.75rem 0}.ct-cart-total-row{display:flex;justify-content:space-between;align-items:center;font-size:1rem;font-weight:700;color:#0f172a}.ct-cart-total-amount{font-size:1.25rem;font-weight:800;color:#2563eb}.ct-checkout-layout{display:grid;grid-template-columns:1fr 340px;gap:1.5rem;align-items:start}@media(max-width:900px){.ct-checkout-layout{grid-template-columns:1fr}}.ct-card{background:#fff;border-radius:16px;border:1.5px solid #E2E8F0;padding:1.25rem}.ct-card-title{font-size:.9375rem;font-weight:700;color:#0f172a;margin-bottom:.875rem}.ct-slots-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:.5rem}.ct-slot-btn{padding:.55rem .5rem;border-radius:9px;font-size:.8rem;font-weight:600;border:1.5px solid #E2E8F0;background:#fff;color:#0f172a;cursor:pointer;transition:all .15s ease;text-align:center}.ct-slot-btn:hover{border-color:#2563eb;color:#2563eb;background:#eef2ff}.ct-slot-btn.active{background:#2563eb;color:#fff;border-color:#2563eb;box-shadow:0 2px 8px #2563eb4d}.ct-summary-items{display:flex;flex-direction:column;gap:.5rem}.ct-summary-item{display:flex;justify-content:space-between;font-size:.875rem;color:#0f172a}.ct-warning-text{font-size:.85rem;color:#d97706}.ct-error-text{font-size:.85rem;color:#dc2626}.ct-success-card{background:#fff;border-radius:24px;border:1.5px solid #E2E8F0;padding:2.5rem 2rem;text-align:center;max-width:440px;margin:2rem auto;box-shadow:0 8px 32px #00000012}.ct-success-checkmark{font-size:3.5rem;margin-bottom:.75rem}.ct-success-title{font-size:1.75rem;font-weight:900;color:#0f172a;margin-bottom:.5rem}.ct-success-sub{font-size:.9rem;color:#475569;margin-bottom:1.5rem}.ct-token-box{background:linear-gradient(135deg,#eef2ff,#dbeafe);border-radius:16px;padding:1.25rem;margin:1rem 0;border:1.5px solid #BFDBFE}.ct-token-label{font-size:.78rem;font-weight:600;color:#1e40af;text-transform:uppercase;letter-spacing:.08em;margin-bottom:.375rem}.ct-token-value{font-size:3rem;font-weight:900;color:#1d4ed8;letter-spacing:.2em;font-family:monospace}.ct-qr-wrapper{display:flex;justify-content:center;padding:1rem;background:#fff;border-radius:12px;border:1.5px solid #E2E8F0;margin:1rem 0}.ct-success-meta{background:#f8fafc;border-radius:12px;padding:1rem;display:flex;flex-direction:column;gap:.5rem;margin-top:1rem}.ct-success-meta-row{display:flex;justify-content:space-between;font-size:.875rem;color:#0f172a}.ct-success-actions{display:flex;gap:.75rem;margin-top:1.5rem}.ct-success-actions .btn{flex:1}.ct-orders-list{display:flex;flex-direction:column;gap:.875rem}.ct-order-card{background:#fff;border-radius:16px;border:1.5px solid #E2E8F0;overflow:hidden;box-shadow:0 2px 10px #0000000a}.ct-order-card.expanded{border-color:#bfdbfe}.ct-order-header{width:100%;display:flex;align-items:center;gap:.875rem;padding:1rem 1.125rem;background:transparent;border:none;cursor:pointer;text-align:left;transition:background .15s}.ct-order-header:hover{background:#f8fafc}.ct-order-header-left{flex:1;min-width:0}.ct-order-canteen{font-size:.9375rem;font-weight:700;color:#0f172a}.ct-order-date{font-size:.775rem;color:#94a3b8;margin-top:.15rem}.ct-order-header-right{display:flex;flex-direction:column;align-items:flex-end;gap:.3rem}.ct-order-amount{font-size:.9rem;font-weight:800;color:#0f172a}.ct-order-chevron{font-size:1rem;color:#94a3b8;transition:transform .2s ease;flex-shrink:0}.ct-order-chevron.up{transform:rotate(180deg)}.ct-order-detail{border-top:1px solid #F1F5F9;padding:1.125rem;display:flex;flex-direction:column;gap:1rem;background:#fafafa}.ct-order-token-row{display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap}.ct-order-token-box{display:flex;flex-direction:column;gap:.2rem}.ct-order-token-label{font-size:.7rem;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.06em}.ct-order-token{font-size:1.75rem;font-weight:900;color:#1d4ed8;letter-spacing:.15em;font-family:monospace}.ct-order-items{display:flex;flex-direction:column;gap:.375rem}.ct-order-item-row{display:flex;justify-content:space-between;align-items:center;font-size:.875rem;color:#0f172a;padding:.3rem 0;border-bottom:1px dashed #E2E8F0}.ct-order-item-row:last-child{border-bottom:none}.ct-order-qr{display:flex;flex-direction:column;align-items:center;gap:.5rem}.ct-order-qr-label{font-size:.78rem;color:#64748b;font-weight:600}.ct-order-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.3rem .875rem;border-radius:999px;font-size:.78rem;font-weight:700}.ct-order-badge-sm{padding:.2rem .6rem;font-size:.7rem}.ct-badge-gray{background:#f1f5f9;color:#475569}.ct-badge-orange{background:#fef3c7;color:#92400e}.ct-badge-green{background:#dcfce7;color:#15803d}.ct-badge-pulse-dot{width:7px;height:7px;border-radius:50%;background:#d97706;animation:ct-pulse 1.2s infinite}.ct-error-card{background:#fef2f2;border:1.5px solid #FECACA;border-radius:14px;padding:2rem;text-align:center;color:#dc2626;display:flex;flex-direction:column;align-items:center;gap:.75rem}@media(max-width:768px){.ct-content{padding:1rem}.ct-canteen-grid{grid-template-columns:1fr}.ct-menu-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}}
