@import "https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700&display=swap";.menu-board-container{flex-direction:column;min-height:calc(100vh - 120px);display:flex;position:relative}.menu-board-header{text-align:center;flex-direction:column;align-items:center;margin-bottom:2rem;display:flex;position:relative}.menu-board-title{color:var(--text-primary);margin-bottom:.35rem;font-family:DM Serif Display,serif;font-size:1.8rem}.menu-board-subtitle{color:var(--text-secondary);font-size:.95rem}.btn-back-dashboard{border:1.5px solid var(--border);color:var(--text-secondary);cursor:pointer;background:#fff;border-radius:20px;padding:.5rem 1rem;font-family:DM Sans,sans-serif;font-size:.85rem;font-weight:500;transition:all .2s;position:absolute;bottom:0;right:0}.btn-back-dashboard:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-light)}.step-indicator{justify-content:center;align-items:center;gap:.75rem;margin-bottom:1.5rem;display:flex}.step-dot{color:var(--text-secondary);align-items:center;gap:.4rem;font-family:DM Sans,sans-serif;font-size:.85rem;font-weight:500;display:flex}.step-dot.active{color:var(--primary);font-weight:700}.step-dot .dot{background:var(--border);width:26px;height:26px;color:var(--text-secondary);border-radius:50%;justify-content:center;align-items:center;font-size:.78rem;font-weight:700;display:flex}.step-dot.active .dot{background:var(--primary);color:#fff;box-shadow:0 0 0 3px #7c3aed26}.step-dot.completed .dot{color:#fff;background:#22c55e}.step-connector{background:var(--border);border-radius:1px;width:48px;height:2px}.step-connector.active{background:var(--primary)}.menu-grid-container{border:1px solid var(--border);box-sizing:border-box;background:#fff;border-radius:12px;max-width:100%;margin-bottom:1.5rem;overflow:auto hidden}.menu-col-headers{border-bottom:1px solid var(--border);background:var(--bg-page);grid-template-columns:1fr 1fr;display:grid}.menu-col-header{text-align:center;text-transform:uppercase;letter-spacing:.5px;padding:.85rem 1rem;font-family:DM Sans,sans-serif;font-size:.88rem;font-weight:700}.menu-col-header-left{border-right:1px solid var(--border);background:var(--accent-light);color:#92400e}.menu-col-header-right{background:var(--primary-light);color:var(--primary)}.menu-week-row{border-bottom:1px solid var(--border);grid-template-columns:1fr 1fr;display:grid}.menu-week-row:last-child{border-bottom:none}.menu-week-col{flex-direction:column;display:flex}.menu-week-col-left{border-right:1px solid var(--border)}.menu-date-label{text-align:center;border-bottom:1px solid var(--border);padding:.5rem 1rem;font-family:DM Sans,sans-serif;font-size:.85rem;font-weight:600}.menu-date-label-left{background:var(--accent-light);color:#92400e}.menu-date-label-right{background:var(--primary-light);color:var(--primary)}.menu-items-wrap{flex:1;padding:.75rem 1rem}.menu-empty-week{text-align:center;color:var(--border);flex:1;justify-content:center;align-items:center;padding:1.5rem;font-size:.85rem;display:flex}.menu-item-row{border-bottom:1px dashed var(--border);justify-content:space-between;align-items:center;padding:.5rem 0;display:flex}.menu-item-row:last-child{border-bottom:none}.menu-item-details{color:var(--text-primary);flex:1;justify-content:space-between;align-items:center;gap:.5rem;padding-right:.75rem;font-size:.9rem;display:flex}.menu-item-price{color:var(--text-secondary);white-space:nowrap;font-size:.82rem}.menu-quantity-input{text-align:center;border:1.5px solid var(--border);border-radius:6px;outline:none;width:52px;padding:.3rem;font-family:DM Sans,sans-serif;font-size:.95rem;transition:border-color .2s}.menu-quantity-input:focus{border-color:var(--primary)}.menu-subtotals-row{border-top:1px solid var(--border);background:var(--bg-page);grid-template-columns:1fr 1fr;display:grid}.subtotal-row{justify-content:flex-end;align-items:center;gap:.5rem;padding:.65rem 1rem;font-size:.88rem;display:flex}.menu-subtotals-row .subtotal-row:first-child{border-right:1px solid var(--border)}.subtotal-label{color:var(--text-secondary);font-weight:500}.subtotal-amount{color:var(--primary);font-weight:700}.sticky-bottom-bar{border-top:1px solid var(--border);z-index:100;background:#fff;justify-content:space-between;align-items:center;margin-left:-2rem;margin-right:-2rem;padding:1.25rem 2rem;display:flex;position:sticky;bottom:-2rem;box-shadow:0 -4px 16px #7c3aed14}.total-amount-text{color:var(--text-primary);font-family:DM Serif Display,serif;font-size:1.3rem}.btn-submit-order{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:.75rem 2rem;font-family:DM Sans,sans-serif;font-size:.95rem;font-weight:600;transition:background .2s,transform .1s}.btn-submit-order:hover{background:var(--primary-hover)}.btn-submit-order:active{transform:scale(.98)}.btn-submit-order:disabled{cursor:not-allowed;background:#c4b5fd}.order-locked-banner{background:var(--accent-light);color:#92400e;border:1.5px solid #fde68a;border-radius:10px;align-items:flex-start;gap:.75rem;margin-bottom:1.25rem;padding:1rem 1.25rem;font-size:.9rem;line-height:1.5;display:flex}.order-frozen-banner{color:#991b1b;background:#fef2f2;border-color:#fecaca}.banner-icon{flex-shrink:0;margin-top:.1rem;font-size:1.2rem}.banner-text{flex:1}.banner-text strong{font-weight:700}.order-summary-section{background:var(--bg-page);border:1px solid var(--border);border-radius:12px;margin-bottom:1.25rem;padding:1.25rem 1.5rem}.order-summary-title{color:var(--text-primary);align-items:center;gap:.5rem;margin-bottom:1rem;font-family:DM Serif Display,serif;font-size:1.15rem;display:flex}.summary-group{margin-bottom:1rem}.summary-group-title{color:var(--primary);border-bottom:1px dashed var(--border);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem;padding-bottom:.3rem;font-family:DM Sans,sans-serif;font-size:.78rem;font-weight:700}.summary-item{color:var(--text-secondary);justify-content:space-between;align-items:center;padding:.35rem 0;font-size:.88rem;display:flex}.summary-item-name{flex:1}.summary-item-qty{text-align:center;width:40px;font-weight:500}.summary-item-total{text-align:right;width:80px;color:var(--text-primary);font-weight:600}.summary-subtotal{border-top:1px solid var(--border);color:var(--primary);justify-content:flex-end;gap:.75rem;margin-top:.2rem;padding:.4rem 0;font-family:DM Sans,sans-serif;font-size:.88rem;font-weight:600;display:flex}.summary-grand-total{border-top:2px solid var(--text-primary);color:var(--primary);justify-content:flex-end;gap:.75rem;margin-top:.5rem;padding:.75rem 0;font-family:DM Sans,sans-serif;font-size:1.1rem;font-weight:800;display:flex}.payment-section{border:1px solid var(--border);background:#fff;border-radius:12px;margin-bottom:80px;padding:1.5rem}.payment-section-title{color:var(--text-primary);border-bottom:1px solid var(--border);align-items:center;gap:.5rem;margin-bottom:1.25rem;padding-bottom:.75rem;font-family:DM Serif Display,serif;font-size:1.25rem;display:flex}.payment-fields{grid-template-columns:1fr 1fr;gap:1.25rem;display:grid}@media (width<=640px){.payment-fields{grid-template-columns:1fr}}.payment-field{flex-direction:column;gap:.35rem;display:flex}.payment-field.full-width{grid-column:1/-1}.payment-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-family:DM Sans,sans-serif;font-size:.75rem;font-weight:600}.payment-value{color:var(--text-primary);background:var(--bg-page);border:1px solid var(--border);border-radius:8px;padding:.6rem .85rem;font-family:DM Sans,sans-serif;font-size:.95rem;font-weight:600}.payment-value.amount-due{color:var(--primary);background:var(--primary-light);border-color:#c4b5fd;font-size:1.1rem}.payment-input,.payment-textarea,.payment-select{border:1.5px solid var(--border);color:var(--text-primary);box-sizing:border-box;background:#fff;border-radius:8px;outline:none;width:100%;padding:.6rem .85rem;font-family:DM Sans,sans-serif;font-size:.95rem;transition:border-color .2s,box-shadow .2s}.payment-input:focus,.payment-textarea:focus,.payment-select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #7c3aed1a}.payment-input:read-only,.payment-textarea:read-only{background:var(--bg-page);color:var(--text-secondary);cursor:not-allowed}.payment-textarea{resize:vertical;min-height:60px}.payment-select{cursor:pointer;appearance:auto;font-weight:500}.payment-disclaimer{color:var(--primary);background:var(--primary-light);border:1px solid #c4b5fd;border-radius:6px;margin:.3rem 0 0;padding:.4rem .7rem;font-family:DM Sans,sans-serif;font-size:.8rem}.optional-badge{color:var(--text-secondary);text-transform:none;letter-spacing:0;font-size:.72rem;font-weight:400}.payment-balance{border:1px solid var(--border);border-radius:8px;padding:.6rem .85rem;font-family:DM Sans,sans-serif;font-size:1rem;font-weight:600}.payment-balance.balanced{color:#166534;background:#f0fdf4;border-color:#bbf7d0}.payment-balance.owing{background:var(--accent-light);color:#92400e;border-color:#fde68a}.payment-balance.overpaid{background:var(--primary-light);color:var(--primary);border-color:#c4b5fd}.btn-back-step{border:1.5px solid var(--border);color:var(--text-secondary);cursor:pointer;background:#fff;border-radius:8px;padding:.6rem 1.5rem;font-family:DM Sans,sans-serif;font-size:.9rem;font-weight:500;transition:all .2s}.btn-back-step:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-light)}.menu-board-container.read-only .menu-quantity-input{background:var(--bg-page);color:var(--text-secondary);cursor:not-allowed;pointer-events:none;border-color:var(--border)}@media (width<=768px){.btn-back-dashboard{margin-top:.75rem;position:static}.sticky-bottom-bar{flex-direction:column;gap:.75rem;margin-left:-1.25rem;margin-right:-1.25rem;padding:1rem 1.25rem;bottom:-1.25rem}.btn-submit-order{width:100%}.menu-board-container{min-height:auto}.menu-board-header{margin-bottom:1.25rem}.menu-board-title{font-size:1.35rem}.menu-board-subtitle{font-size:.85rem}.menu-col-headers{grid-template-columns:1fr}.menu-col-header-left{border-right:none;border-bottom:1px solid var(--border)}.menu-week-row{grid-template-columns:1fr}.menu-week-col-left{border-right:none;border-bottom:1px solid var(--border)}.menu-subtotals-row{grid-template-columns:1fr}.menu-subtotals-row .subtotal-row:first-child{border-right:none;border-bottom:1px solid var(--border)}.menu-items-wrap{padding:.6rem .75rem}.menu-item-details{padding-right:.5rem;font-size:.85rem}.menu-item-price{font-size:.78rem}.menu-quantity-input{width:46px;padding:.25rem;font-size:.88rem}.menu-date-label{padding:.4rem .75rem;font-size:.82rem}.menu-col-header{padding:.65rem .75rem;font-size:.82rem}.sticky-bottom-bar{margin-left:-1rem;margin-right:-1rem;padding:.75rem 1rem;bottom:-1rem}.total-amount-text{font-size:1.1rem}.btn-submit-order{padding:.65rem 1.25rem;font-size:.88rem}.order-summary-section{padding:1rem}.order-summary-title{font-size:1rem}.payment-section{padding:1rem}.payment-section-title{font-size:1.05rem}.order-locked-banner{padding:.75rem 1rem;font-size:.82rem}.step-indicator{margin-bottom:1rem}}.dashboard-container{background:var(--bg-page);height:100dvh;display:flex;overflow:hidden}.sidebar{background:#1e1b2e;flex-direction:column;width:260px;height:100dvh;padding:0;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-logo{border-bottom:1px solid #ffffff14;flex-direction:column;align-items:flex-start;gap:.5rem;padding:1.5rem 1.25rem 1.25rem;display:flex}.sidebar-logo img{object-fit:contain;width:auto;height:72px}.sidebar-logo h1{color:#fff;letter-spacing:-.5px;font-family:DM Serif Display,serif;font-size:1.8rem}.sidebar-logo span{color:var(--accent);text-transform:uppercase;letter-spacing:1.2px;margin-top:-.25rem;font-size:.72rem;font-weight:500}.sidebar-nav{flex-direction:column;flex:1;gap:.25rem;min-height:0;padding:1.5rem .75rem;display:flex;overflow-y:auto}.nav-item{cursor:pointer;color:#fff9;border-radius:8px;align-items:center;gap:.75rem;padding:.75rem 1rem;font-size:.9rem;font-weight:400;transition:all .2s;display:flex}.nav-item:hover{color:#ffffffe6;background:#ffffff0f}.nav-item.active{color:#fff;background:#7c3aed4d;font-weight:500}.nav-icon{text-align:center;width:20px;font-size:1rem}.sidebar-footer{padding:1.25rem 1.5rem;padding-bottom:max(1.25rem, env(safe-area-inset-bottom));border-top:1px solid #ffffff14;flex-shrink:0}.sidebar-footer p{color:#fff6;word-break:break-all;margin-bottom:.75rem;font-size:.78rem}.sidebar-footer button{color:#ffffff80;cursor:pointer;background:0 0;border:1px solid #ffffff26;border-radius:6px;width:100%;padding:.6rem;font-family:DM Sans,sans-serif;font-size:.85rem;transition:all .2s}.sidebar-footer button:hover{color:#fffc;background:#ffffff14}.dashboard-main{flex:1;height:100dvh;margin-left:260px;padding:2rem;overflow:hidden auto}.dashboard-header{justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;display:flex}.dashboard-header h2{color:var(--text-primary);margin-bottom:.25rem;font-family:DM Serif Display,serif;font-size:1.8rem}.dashboard-header p{color:var(--text-secondary);font-size:.9rem}.btn-refresh{border:1.5px solid var(--border);color:var(--text-primary);cursor:pointer;background:#fff;border-radius:8px;padding:.6rem 1.25rem;font-family:DM Sans,sans-serif;font-size:.88rem;transition:all .2s}.btn-refresh:hover{border-color:var(--primary);color:var(--primary)}.toast{border-radius:8px;margin-bottom:1.5rem;padding:.85rem 1.25rem;font-size:.9rem;font-weight:500;animation:.2s fadeIn}.toast.success{color:#166534;background:#f0fdf4;border:1px solid #bbf7d0}.toast.error{color:#991b1b;background:#fef2f2;border:1px solid #fecaca}@keyframes fadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.filter-tabs{gap:.5rem;margin-bottom:1.5rem;display:flex}.filter-tab{border:1.5px solid var(--border);color:var(--text-secondary);cursor:pointer;background:#fff;border-radius:20px;align-items:center;gap:.5rem;padding:.5rem 1rem;font-family:DM Sans,sans-serif;font-size:.88rem;transition:all .2s;display:flex}.filter-tab:hover{border-color:var(--primary);color:var(--primary)}.filter-tab.active{background:var(--primary);border-color:var(--primary);color:#fff}.tab-count{background:#0000001a;border-radius:10px;padding:.1rem .45rem;font-size:.75rem;font-weight:600}.filter-tab.active .tab-count{background:#ffffff40}.stats-row{grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem;display:grid}.stat-card{border:1px solid var(--border);background:#fff;border-radius:12px;padding:1.25rem 1.5rem}.stat-number{color:var(--primary);margin-bottom:.35rem;font-size:2rem;font-weight:600;line-height:1}.stat-label{color:var(--text-secondary);font-size:.82rem}.users-table-wrapper{border:1px solid var(--border);background:#fff;border-radius:12px;overflow:auto visible}.users-table{border-collapse:collapse;width:100%}.users-table th{text-align:left;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;background:var(--bg-page);border-bottom:1px solid var(--border);padding:1rem 1.25rem;font-size:.78rem;font-weight:600}.users-table td{color:var(--text-primary);border-bottom:1px solid var(--border);padding:1rem 1.25rem;font-size:.9rem}.users-table tr:last-child td{border-bottom:none}.users-table tr:hover td{background:#fafafa}.badge{border-radius:20px;padding:.25rem .65rem;font-size:.78rem;font-weight:500;display:inline-block}.badge-admin{background:var(--primary-light);color:var(--primary)}.badge-staff{color:#92400e;background:#fef3c7}.badge-parent{color:#166534;background:#f0fdf4}.action-btns{gap:.5rem;display:flex}.icon-btn-group{align-items:center;gap:.2rem;display:flex}.icon-btn{cursor:pointer;background:0 0;border:1.5px solid #0000;border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;padding:0;transition:background .15s,border-color .15s,color .15s;display:inline-flex;position:relative}.icon-btn svg{pointer-events:none;width:15px;height:15px}.icon-btn:after{content:attr(data-tooltip);color:#fff;white-space:nowrap;pointer-events:none;opacity:0;z-index:200;background:#1f2937;border-radius:5px;padding:3px 8px;font-family:DM Sans,sans-serif;font-size:.7rem;font-weight:500;transition:opacity .15s;position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%)}.icon-btn:hover:not(:disabled):after{opacity:1}.icon-btn:disabled{opacity:.35;cursor:not-allowed}.icon-btn-edit{color:#5b21b6}.icon-btn-edit:hover:not(:disabled){background:#ede9fe;border-color:#c4b5fd}.icon-btn-deactivate{color:#b45309}.icon-btn-deactivate:hover:not(:disabled){background:#fffbeb;border-color:#fde68a}.icon-btn-activate{color:#166534}.icon-btn-activate:hover:not(:disabled){background:#f0fdf4;border-color:#bbf7d0}.icon-btn-delete{color:#991b1b}.icon-btn-delete:hover:not(:disabled){background:#fef2f2;border-color:#fecaca}.icon-btn-approve{color:#166534}.icon-btn-approve:hover:not(:disabled){background:#f0fdf4;border-color:#bbf7d0}.icon-btn-reject{color:#991b1b}.icon-btn-reject:hover:not(:disabled){background:#fef2f2;border-color:#fecaca}.btn-approve{color:#166534;cursor:pointer;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:6px;padding:.4rem .9rem;font-family:DM Sans,sans-serif;font-size:.82rem;font-weight:500;transition:all .2s}.btn-approve:hover{color:#fff;background:#166534;border-color:#166534}.btn-reject{color:#991b1b;cursor:pointer;background:#fef2f2;border:1px solid #fecaca;border-radius:6px;padding:.4rem .9rem;font-family:DM Sans,sans-serif;font-size:.82rem;font-weight:500;transition:all .2s}.btn-reject:hover{color:#fff;background:#991b1b;border-color:#991b1b}.btn-approve:disabled,.btn-reject:disabled{opacity:.5;cursor:not-allowed}.empty-state{border:1px solid var(--border);text-align:center;background:#fff;border-radius:12px;padding:4rem 2rem}.empty-icon{color:#166534;background:#f0fdf4;border:2px solid #bbf7d0;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;margin:0 auto 1rem;font-size:1.5rem;display:flex}.empty-state h3{color:var(--text-primary);margin-bottom:.5rem;font-size:1.1rem}.empty-state p{color:var(--text-secondary);font-size:.9rem}.loading-state{border:1px solid var(--border);text-align:center;background:#fff;border-radius:12px;flex-direction:column;align-items:center;gap:1rem;padding:4rem;display:flex}.loading-state:before{content:"";border:3px solid #ede9fe;border-top-color:#7c3aed;border-radius:50%;width:36px;height:36px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.footer-email{color:#fff6;word-break:break-all;margin-bottom:.25rem;font-size:.78rem}.footer-school{color:var(--accent);margin-bottom:.75rem;font-size:.75rem;font-weight:500}.module-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem;margin-top:1rem;display:grid}.module-card{border:1px solid var(--border);cursor:pointer;background:#fff;border-radius:12px;flex-direction:column;gap:.5rem;padding:1.5rem;transition:transform .2s,box-shadow .2s;display:flex}.module-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #7c3aed1a}.module-icon{margin-bottom:.25rem;font-size:2rem}.module-title{color:var(--text-primary);font-size:1rem;font-weight:600}.module-desc{color:var(--text-secondary);font-size:.83rem;line-height:1.5}.module-badge{border-radius:20px;width:fit-content;margin-top:.5rem;padding:.2rem .65rem;font-size:.75rem;font-weight:500;display:inline-block}.module-badge.coming{background:var(--accent-light);color:var(--accent-hover)}.module-badge.ready{color:#166534;background:#f0fdf4}.mobile-topbar{z-index:98;background:#1e1b2e;justify-content:space-between;align-items:center;height:56px;padding:0 1.25rem;display:none;position:fixed;top:0;left:0;right:0}.mobile-topbar-logo{object-fit:contain;width:auto;height:36px}.mobile-menu-btn{color:#fffc;cursor:pointer;background:0 0;border:none;align-items:center;padding:.25rem;font-size:1.5rem;line-height:1;display:flex}.sidebar-backdrop{z-index:100;background:#00000080;position:fixed;inset:0}@media (width<=768px){.mobile-topbar{display:flex}.sidebar{z-index:101;transition:transform .25s;transform:translate(-100%)}.sidebar.sidebar-open{transform:translate(0)}.dashboard-main{padding:calc(56px + 1.25rem) 1.25rem 1.25rem;padding-bottom:max(1.25rem, env(safe-area-inset-bottom));height:100dvh;margin-left:0}.stats-row{grid-template-columns:repeat(2,1fr)}.filter-tabs{flex-wrap:wrap}.dashboard-header{flex-wrap:wrap;gap:.75rem}.btn-refresh,.btn-add{width:100%}}.pagination{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;margin-top:1rem;padding:.25rem 0;display:flex}.pagination-info{color:var(--text-secondary);font-size:.83rem}.pagination-controls{flex-wrap:wrap;align-items:center;gap:.3rem;display:flex}.pagination-btn{border:1.5px solid var(--border);background:var(--bg-card);color:var(--text-primary);cursor:pointer;white-space:nowrap;border-radius:6px;padding:.35rem .7rem;font-family:DM Sans,sans-serif;font-size:.82rem;transition:background .15s,border-color .15s,color .15s}.pagination-btn:hover:not(:disabled){border-color:var(--primary);color:var(--primary)}.pagination-btn.active{background:var(--primary);border-color:var(--primary);color:#fff;font-weight:600}.pagination-btn:disabled{opacity:.38;cursor:not-allowed}.pagination-ellipsis{color:var(--text-secondary);padding:0 .2rem;font-size:.85rem}.approvals-group{margin-bottom:2rem}.approvals-group-title{color:var(--text-primary);border-bottom:1.5px solid var(--border);margin-bottom:.75rem;padding-bottom:.5rem;font-size:.95rem;font-weight:600}.row-actions-wrap{display:inline-block;position:relative}.row-actions-trigger{border:1.5px solid var(--border);width:30px;height:30px;color:var(--text-secondary);cursor:pointer;background:#fff;border-radius:6px;justify-content:center;align-items:center;font-size:1.1rem;line-height:1;transition:background .15s,border-color .15s;display:flex}.row-actions-trigger:hover{background:var(--primary-light,#ede9fe);border-color:var(--primary);color:var(--primary)}.row-actions-menu{border:1.5px solid var(--border);z-index:100;background:#fff;border-radius:10px;flex-direction:column;min-width:140px;display:flex;position:absolute;top:calc(100% + 4px);right:0;overflow:hidden;box-shadow:0 6px 20px #0000001f}.row-actions-item{text-align:left;color:var(--text-primary);cursor:pointer;background:0 0;border:none;padding:.6rem 1rem;font-family:DM Sans,sans-serif;font-size:.875rem;font-weight:500;transition:background .15s}.row-actions-item:hover:not(:disabled){background:var(--bg-page,#f9fafb)}.row-actions-item:disabled{opacity:.4;cursor:not-allowed}.row-actions-item.row-action-deactivate{color:#b45309}.row-actions-item.row-action-deactivate:hover:not(:disabled){background:#fffbeb}.row-actions-item.row-action-activate{color:#166534}.row-actions-item.row-action-activate:hover:not(:disabled){background:#f0fdf4}.row-actions-item.row-action-delete{color:#991b1b}.row-actions-item.row-action-delete:hover:not(:disabled){background:#fef2f2}.order-section-card{border:1px solid var(--border);background:#fff;border-radius:12px;margin-bottom:1.5rem;padding:1.5rem}.order-section-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:1rem;font-size:.78rem;font-weight:600}.order-month-select{border:1.5px solid var(--border);width:100%;max-width:380px;color:var(--text-primary);cursor:pointer;background:#fff;border-radius:8px;outline:none;padding:.65rem .9rem;font-family:DM Sans,sans-serif;font-size:.95rem;transition:border-color .2s}.order-month-select:focus{border-color:var(--primary)}.order-students-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem;display:grid}.student-order-card{border:1px solid var(--border);background:#fff;border-radius:12px;flex-direction:column;gap:.5rem;padding:1.25rem;transition:box-shadow .2s;display:flex}.student-order-card:hover{box-shadow:0 4px 16px #7c3aed1a}.student-order-name{color:var(--text-primary);font-family:DM Serif Display,serif;font-size:1.2rem}.student-order-grade{color:var(--text-secondary);font-size:.85rem}.order-status-banner{border-radius:6px;align-items:center;gap:.4rem;margin-top:.25rem;padding:.5rem .75rem;font-size:.82rem;font-weight:500;display:flex}.order-status-none{background:var(--bg-page);color:var(--text-secondary);border:1px dashed var(--border)}.order-status-pending{color:#92400e;background:#fef3c7;border:1px solid #fde68a}.order-status-confirmed{color:#166534;background:#f0fdf4;border:1px solid #bbf7d0}.order-status-mismatch{color:#991b1b;background:#fef2f2;border:1px solid #fecaca}.order-status-partial{color:#92400e;background:#fef3c7;border:1px solid #fde68a}.order-status-returned{color:#be123c;background:#fff1f2;border:1px solid #fda4af}.btn-create-order,.btn-edit-order,.btn-view-order{cursor:pointer;border:none;border-radius:8px;width:100%;margin-top:auto;padding:.7rem;font-family:DM Sans,sans-serif;font-size:.9rem;font-weight:600;transition:opacity .2s}.btn-create-order{color:#fff;background:#6bb076}.btn-edit-order{background:var(--accent-light);color:#92400e;border:1px solid #fde68a}.btn-view-order{background:var(--primary-light);color:var(--primary)}.btn-create-order:hover,.btn-edit-order:hover,.btn-view-order:hover{opacity:.85}.files-dropzone{text-align:center;cursor:pointer;-webkit-user-select:none;user-select:none;background:#7c3aed08;border:2px dashed #7c3aed59;border-radius:12px;padding:2.5rem 1.5rem;transition:border-color .2s,background .2s}.files-dropzone:hover,.files-dropzone--active{border-color:var(--primary);background:#7c3aed12}.files-dropzone--uploading{cursor:default;border-color:var(--primary)}.files-dropzone-icon{margin-bottom:.5rem;font-size:2.5rem;display:block}.files-dropzone-text{color:var(--text-primary);margin:0 0 .3rem;font-size:.95rem}.files-dropzone-hint{color:var(--text-secondary);margin:0;font-size:.78rem}.files-upload-progress{padding:.5rem 0}.files-upload-progress p{color:var(--text-secondary);margin-bottom:.6rem;font-size:.9rem}.files-progress-bar{background:#7c3aed26;border-radius:999px;max-width:320px;height:6px;margin:0 auto;overflow:hidden}.files-progress-fill{background:var(--primary);border-radius:999px;height:100%;transition:width .2s}.file-name-link{color:var(--primary);font-weight:500;text-decoration:none}.file-name-link:hover{text-decoration:underline}.icon-btn-download,.icon-btn.icon-btn-download{color:#059669}.icon-btn.icon-btn-download:hover{color:#047857;background:#0596691a}.login-container{background:linear-gradient(135deg,#f5f3ff 0%,#fef3c7 100%);justify-content:center;align-items:center;min-height:100vh;padding:1rem;display:flex}.login-card{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;width:100%;max-width:420px;padding:2.5rem;box-shadow:0 8px 32px #7c3aed1f}.login-header{text-align:center;margin-bottom:2rem}.login-header h1{color:var(--primary);letter-spacing:-.5px;font-family:DM Serif Display,serif;font-size:2.4rem}.login-logo{width:min(140px,100%);height:auto;margin:0 auto;display:block}.login-header p{color:var(--text-secondary);margin-top:.3rem;font-size:.9rem;font-weight:300}.form-group{flex-direction:column;gap:.4rem;margin-bottom:1.25rem;display:flex}.form-group label{color:var(--text-primary);font-size:.85rem;font-weight:500}.form-group input{border:1.5px solid var(--border);color:var(--text-primary);background:#fafafa;border-radius:8px;outline:none;padding:.75rem 1rem;font-family:DM Sans,sans-serif;font-size:.95rem;transition:border-color .2s,box-shadow .2s}.form-group input:focus{border-color:var(--primary);background:#fff;box-shadow:0 0 0 3px #7c3aed1a}.error-message{color:var(--error);background:var(--error-bg);border:1px solid #fecaca;border-radius:6px;margin-bottom:1rem;padding:.6rem .9rem;font-size:.85rem}button[type=submit]{background:linear-gradient(135deg, var(--primary) 0%, var(--accent) 100%);color:#fff;cursor:pointer;border:none;border-radius:8px;width:100%;padding:.85rem;font-family:DM Sans,sans-serif;font-size:.95rem;font-weight:500;transition:opacity .2s,transform .1s}button[type=submit]:hover{opacity:.92}button[type=submit]:active{transform:scale(.99)}button[type=submit]:disabled{opacity:.5;cursor:not-allowed}.login-divider{text-align:center;color:var(--text-secondary);margin:1.25rem 0;font-size:.8rem;position:relative}.login-divider:before,.login-divider:after{content:"";background:var(--border);width:42%;height:1px;position:absolute;top:50%}.login-divider:before{left:0}.login-divider:after{right:0}.forgot-link{color:var(--primary);cursor:pointer;background:0 0;border:none;padding:0;font-family:DM Sans,sans-serif;font-size:.85rem;font-weight:500;text-decoration:none}.forgot-link:hover{text-decoration:underline}.reset-hint{color:var(--text-secondary);margin-bottom:1.25rem;font-size:.88rem;line-height:1.55}.btn-google{color:#3c4043;cursor:pointer;background:#fff;border:1.5px solid #dadce0;border-radius:8px;justify-content:center;align-items:center;gap:.6rem;width:100%;padding:.8rem 1rem;font-family:DM Sans,sans-serif;font-size:.95rem;font-weight:500;transition:background .2s,box-shadow .2s;display:flex}.btn-google:hover{background:#f8f9fa;box-shadow:0 1px 6px #3c404326}.btn-google:active{background:#f1f3f4}.btn-google:disabled{opacity:.55;cursor:not-allowed}.google-signed-badge{color:#166534;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px;align-items:center;gap:.5rem;margin-bottom:1rem;padding:.65rem 1rem;font-size:.9rem;font-weight:500;display:flex}.success-banner{color:#166534;text-align:center;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px;margin-bottom:1.25rem;padding:.75rem 1rem;font-size:.88rem;font-weight:500}.register-card{max-width:520px}.steps{justify-content:space-between;margin-bottom:2rem;display:flex;position:relative}.steps:before{content:"";background:var(--border);z-index:0;height:2px;position:absolute;top:16px;left:10%;right:10%}.step{z-index:1;flex-direction:column;align-items:center;gap:.4rem;display:flex}.step-circle{background:var(--bg-page);border:2px solid var(--border);width:32px;height:32px;color:var(--text-secondary);border-radius:50%;justify-content:center;align-items:center;font-size:.8rem;font-weight:500;transition:all .2s;display:flex}.step.active .step-circle{background:var(--primary);border-color:var(--primary);color:#fff}.step.done .step-circle{background:var(--accent);border-color:var(--accent);color:#fff}.step span{color:var(--text-secondary);font-size:.75rem}.step.active span{color:var(--primary);font-weight:500}.step-content{flex-direction:column;gap:.5rem;display:flex}.step-label{color:var(--text-secondary);margin-bottom:.5rem;font-size:.9rem}.step-label strong{color:var(--primary)}.profile-actions{margin-top:1.5rem}.profile-signout-btn{border:1.5px solid var(--border);width:100%;color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:8px;padding:.85rem;font-family:DM Sans,sans-serif;font-size:.95rem;font-weight:500;transition:all .2s}.profile-signout-btn:hover{border-color:var(--primary);color:var(--primary)}.school-list{flex-direction:column;gap:.5rem;max-height:220px;margin-bottom:1rem;display:flex;overflow-y:auto}.school-item{border:1.5px solid var(--border);cursor:pointer;border-radius:8px;flex-direction:column;padding:.75rem 1rem;transition:border-color .2s,background .2s;display:flex}.school-item:hover,.school-item.selected{border-color:var(--primary);background:var(--primary-light)}.school-name{color:var(--text-primary);font-size:.95rem;font-weight:500}.school-address{color:var(--text-secondary);margin-top:.15rem;font-size:.8rem}.no-results{color:var(--text-secondary);text-align:center;padding:1rem;font-size:.85rem}.role-cards{gap:.75rem;margin-bottom:1.5rem;display:flex}.role-card{border:1.5px solid var(--border);cursor:pointer;text-align:center;border-radius:12px;flex-direction:column;flex:1;align-items:center;gap:.4rem;padding:1.25rem .5rem;transition:all .2s;display:flex}.role-card:hover,.role-card.selected{border-color:var(--primary);background:var(--primary-light)}.role-icon{font-size:2rem}.role-title{color:var(--text-primary);font-size:1rem;font-weight:600}.role-desc{color:var(--text-secondary);font-size:.78rem}.form-row{gap:1rem;display:flex}.form-row .form-group{flex:1}.form-group select{border:1.5px solid var(--border);color:var(--text-primary);background:#fafafa;border-radius:8px;outline:none;width:100%;padding:.75rem 1rem;font-family:DM Sans,sans-serif;font-size:.95rem;transition:border-color .2s,box-shadow .2s}.step-nav{gap:.75rem;margin-top:1rem;display:flex}.btn-primary{background:linear-gradient(135deg, var(--primary) 0%, var(--accent) 100%);color:#fff;cursor:pointer;border:none;border-radius:8px;flex:1;padding:.85rem;font-family:DM Sans,sans-serif;font-size:.95rem;font-weight:500;transition:opacity .2s}.btn-primary:hover{opacity:.92}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{color:var(--text-primary);border:1.5px solid var(--border);cursor:pointer;background:0 0;border-radius:8px;padding:.85rem 1.25rem;font-family:DM Sans,sans-serif;font-size:.95rem;font-weight:500;transition:background .2s}.btn-secondary:hover{background:var(--bg-page)}.school-search-wrapper{position:relative}.school-dropdown{background:var(--bg-card);border:1.5px solid var(--border);z-index:100;border-radius:10px;max-height:260px;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow-y:auto;box-shadow:0 8px 24px #7c3aed1a}.school-dropdown-item{cursor:pointer;border-bottom:1px solid var(--border);flex-direction:column;padding:.75rem 1rem;transition:background .15s;display:flex}.school-dropdown-item:last-child{border-bottom:none}.school-dropdown-item:hover,.school-dropdown-item.selected{background:var(--primary-light)}.school-dropdown-empty{text-align:center;color:var(--text-secondary);padding:1rem;font-size:.85rem}.selected-school-badge{background:var(--accent-light);color:var(--accent-hover);border:1px solid var(--accent);border-radius:20px;align-items:center;gap:.4rem;margin-bottom:1rem;padding:.35rem .85rem;font-size:.85rem;font-weight:500;display:inline-flex}.input-error{border-color:var(--error)!important;background:#fff8f8!important}.input-error:focus{border-color:var(--error)!important;box-shadow:0 0 0 3px #dc26261a!important}.field-error{color:var(--error);margin-top:.2rem;font-size:.78rem}@media (width<=480px){.form-row{flex-direction:column;gap:0}.role-cards{flex-direction:column}.step-nav{flex-direction:column-reverse}.btn-secondary{text-align:center;width:100%}}.chat-fab{cursor:pointer;color:#fff;z-index:9999;background:#30224a;border:none;border-radius:50%;width:62px;height:62px;font-size:28px;transition:transform .2s,box-shadow .2s;position:fixed;bottom:24px;right:24px;box-shadow:0 10px 24px #4f46e540}.chat-fab-tooltip{color:#fff;z-index:9998;pointer-events:none;background:#1d1836;border-radius:8px;padding:7px 10px;font-family:Plus Jakarta Sans,sans-serif;font-size:12px;position:fixed;bottom:95px;right:24px}.chat-window{isolation:isolate;z-index:10000;background:#f3f2fa;border:1px solid #e4e0f2;border-radius:24px;flex-direction:column;width:390px;height:570px;font-family:Times New Roman,Times,serif;animation:.2s cubic-bezier(.34,1.56,.64,1) chat-open;display:flex;position:fixed;bottom:96px;right:24px;overflow:hidden;box-shadow:0 16px 40px #2018441f}@keyframes chat-open{0%{opacity:0;transform:scale(.92)translateY(10px)}to{opacity:1;transform:scale(1)translateY(0)}}.chat-header{color:#fff;background:#30224a;justify-content:space-between;align-items:center;padding:18px 18px 16px;display:flex}.chat-header h3{margin:0;font-family:Times New Roman,Times,serif;font-size:15px;font-weight:700}.chat-header p{opacity:.75;margin:4px 0 0;font-family:Times New Roman,Times,serif;font-size:12px}.close-btn{color:#fff;cursor:pointer;opacity:.7;background:0 0;border:none;padding:4px 6px;font-size:18px;transition:opacity .15s}.close-btn:hover{opacity:1}.chat-body{background:#f3f2fa;flex-direction:column;flex:1;gap:12px;padding:14px;display:flex;overflow-y:auto}.chat-message{white-space:pre-wrap;border-radius:18px;max-width:90%;padding:12px 15px;font-family:Times New Roman,Times,serif;font-size:15px;font-weight:400;line-height:1.6;animation:.18s msg-in}@keyframes msg-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}.user-message{color:#fff;background:#30224a;border-bottom-right-radius:6px;align-self:flex-end}.bot-message{color:#2f2a44;background:#fff;border:1px solid #ece8f6;border-bottom-left-radius:6px;align-self:flex-start;box-shadow:0 2px 8px #2c22540a}.typing-indicator{align-items:center;gap:5px;min-width:60px;padding:14px 18px;display:inline-flex}.typing-indicator span{background:#9b8ec4;border-radius:50%;width:7px;height:7px;animation:1.2s ease-in-out infinite dot-bounce;display:block}.typing-indicator span:nth-child(2){animation-delay:.18s}.typing-indicator span:nth-child(3){animation-delay:.36s}@keyframes dot-bounce{0%,80%,to{opacity:.4;transform:translateY(0)}40%{opacity:1;transform:translateY(-5px)}}.quick-actions{scrollbar-width:none;background:#f7f6fb;border-top:1px solid #e7e2f2;gap:7px;padding:10px 12px;display:flex;overflow-x:auto}.quick-actions::-webkit-scrollbar{display:none}.gmail-token-bar{background:#f7f6fb;border-top:1px solid #e7e2f2;padding:6px 12px}.gmail-token-wrap{flex-direction:column;gap:0;display:flex}.gmail-token-btn{color:#30224a;cursor:pointer;background:#eeebff;border:1px solid #ddd6fe;border-radius:999px;align-self:flex-start;padding:5px 13px;font-family:Plus Jakarta Sans,sans-serif;font-size:12px;font-weight:500;transition:all .15s}.gmail-token-btn:hover{color:#fff;background:#30224a;border-color:#30224a}.gmail-token-btn--connected{color:#166534;background:#f0fdf4;border-color:#86efac}.gmail-token-btn--connected:hover{color:#fff;background:#166534;border-color:#166534}.gmail-token-form{background:#fff;border:1.5px solid #e4e0f2;border-radius:12px;flex-direction:column;gap:8px;margin-top:8px;padding:10px 12px;animation:.15s msg-in;display:flex}.gmail-token-hint{color:#6b5f8a;margin:0;font-family:Plus Jakarta Sans,sans-serif;font-size:11.5px;line-height:1.4}.gmail-token-input{color:#2f2a44;box-sizing:border-box;background:#faf9ff;border:1.5px solid #ddd8ea;border-radius:8px;outline:none;width:100%;padding:7px 10px;font-family:monospace;font-size:12px;transition:border-color .15s}.gmail-token-input:focus{border-color:#9b8ec4}.gmail-token-actions{gap:7px;display:flex}.gmail-token-connect{color:#fff;cursor:pointer;background:#30224a;border:none;border-radius:8px;flex:1;padding:6px 0;font-family:Plus Jakarta Sans,sans-serif;font-size:12px;font-weight:600;transition:opacity .15s}.gmail-token-connect:hover{opacity:.85}.gmail-token-disconnect{color:#b91c1c;cursor:pointer;background:#fee2e2;border:none;border-radius:8px;flex:1;padding:6px 0;font-family:Plus Jakarta Sans,sans-serif;font-size:12px;font-weight:600;transition:background .15s}.gmail-token-disconnect:hover{background:#fecaca}.quick-actions button{color:#30224a;cursor:pointer;white-space:nowrap;background:#eeebff;border:1px solid #ddd6fe;border-radius:999px;flex-shrink:0;padding:7px 13px;font-family:Plus Jakarta Sans,sans-serif;font-size:12px;font-weight:500;transition:all .15s}.quick-actions button:hover{color:#fff;background:#30224a;border-color:#30224a}.chat-input-area{background:#f7f6fb;border-top:1px solid #e7e2f2;align-items:flex-end;gap:8px;padding:12px;display:flex}.chat-input-area textarea{resize:none;color:#2f2a44;background:#fff;border:1px solid #ddd8ea;border-radius:16px;outline:none;flex:1;padding:10px 14px;font-family:Times New Roman,Times,serif;font-size:15px;line-height:1.5;transition:border-color .15s,box-shadow .15s}.chat-input-area textarea:focus{border-color:#c7bfff;box-shadow:0 0 0 3px #4f46e514}.chat-input-area>button:last-child{color:#fff;cursor:pointer;background:#30224a;border:none;border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;min-width:52px;height:42px;padding:0 16px;font-weight:600;transition:opacity .15s,transform .15s;display:flex}.chat-input-area>button:last-child:hover:not(:disabled){opacity:.88;transform:translateY(-1px)}.chat-input-area>button:last-child:disabled{opacity:.45;cursor:not-allowed}.chat-body::-webkit-scrollbar{width:5px}.chat-body::-webkit-scrollbar-thumb{background:#d8d2ea;border-radius:10px}.chat-body::-webkit-scrollbar-track{background:0 0}.mic-btn{color:#30224a;cursor:pointer;background:#fff;border:1.5px solid #ddd8ea;border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;transition:all .18s;display:flex}.mic-btn:hover:not(:disabled){color:#fff;background:#30224a;border-color:#30224a;transform:translateY(-1px)}.mic-btn:disabled{opacity:.4;cursor:not-allowed}.mic-btn--active{color:#fff;background:#ef4444;border-color:#ef4444;animation:1s infinite mic-pulse}.mic-btn--active:hover:not(:disabled){background:#dc2626;border-color:#dc2626}@keyframes mic-pulse{0%,to{box-shadow:0 0 #ef444466}50%{box-shadow:0 0 0 6px #ef44441a}}.recording-banner{color:#b91c1c;background:#fff5f5;border-top:1px solid #fecaca;align-items:center;gap:10px;padding:8px 14px;font-family:Plus Jakarta Sans,sans-serif;font-size:12.5px;animation:.2s msg-in;display:flex}.recording-wave{align-items:center;gap:3px;display:flex}.recording-wave span{background:#ef4444;border-radius:2px;width:3px;animation:.8s ease-in-out infinite wave-bar;display:block}.recording-wave span:first-child{height:8px;animation-delay:0s}.recording-wave span:nth-child(2){height:14px;animation-delay:.1s}.recording-wave span:nth-child(3){height:10px;animation-delay:.2s}.recording-wave span:nth-child(4){height:16px;animation-delay:.15s}.recording-wave span:nth-child(5){height:9px;animation-delay:50ms}@keyframes wave-bar{0%,to{transform:scaleY(1)}50%{transform:scaleY(.4)}}.recording-stop{color:#b91c1c;cursor:pointer;background:0 0;border:1px solid #fca5a5;border-radius:6px;margin-left:auto;padding:3px 9px;font-family:Plus Jakarta Sans,sans-serif;font-size:12px;transition:background .15s}.recording-stop:hover{background:#fee2e2}.voice-error{color:#b91c1c;background:#fff5f5;border-top:1px solid #fecaca;padding:7px 14px;font-family:Times New Roman,Times,serif;font-size:15px}.voice-badge{letter-spacing:.3px;vertical-align:middle;background:#ffffff2e;border:1px solid #ffffff40;border-radius:10px;margin-bottom:5px;margin-right:4px;padding:1px 7px;font-size:11px;display:inline-block}.chat-window{transition:width .25s,height .25s,max-height .25s}.chat-window--minimized{height:auto!important;min-height:unset!important;max-height:unset!important;resize:none!important;overflow:hidden!important}.chat-window--maximized{bottom:90px;right:24px;width:680px!important;height:82vh!important;max-height:82vh!important}.chat-header{justify-content:space-between;align-items:center;display:flex}.chat-header-info{flex:1;min-width:0}.chat-header-actions{flex-shrink:0;align-items:center;gap:4px;margin-left:8px;display:flex}.chat-ctrl-btn{color:#fff;cursor:pointer;background:#ffffff1f;border:none;border-radius:6px;justify-content:center;align-items:center;width:28px;height:28px;padding:0;font-size:12px;line-height:1;transition:background .15s,transform .1s;display:flex}.chat-ctrl-btn:hover{background:#ffffff40;transform:scale(1.08)}.chat-ctrl-btn:active{transform:scale(.95)}.chat-ctrl-btn--close:hover{background:#ef444499}.stop-btn{color:#fff;cursor:pointer;background:#ef4444;border:none;border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;min-width:52px;height:42px;padding:0 16px;font-weight:600;transition:all .15s;display:flex}.stop-btn:hover{background:#dc2626;transform:translateY(-1px)}.stop-btn:active{transform:translateY(0)}@media (width<=640px){.chat-window{border-radius:20px;width:calc(100vw - 32px);height:65vh;max-height:560px;bottom:84px;right:16px}.chat-window--maximized{border-radius:20px!important;width:calc(100vw - 16px)!important;height:calc(100vh - 90px)!important;max-height:calc(100vh - 90px)!important;bottom:80px!important;right:8px!important}.chat-fab{width:54px;height:54px;font-size:24px;bottom:16px;right:16px}.chat-fab-tooltip{bottom:80px;right:16px}}@media (width<=420px){.chat-window{border-radius:18px;width:calc(100vw - 16px);height:70vh;bottom:78px;right:8px}.chat-window--maximized{border-radius:18px 18px 0 0!important;width:100vw!important;height:calc(100vh - 68px)!important;max-height:calc(100vh - 68px)!important;bottom:0!important;right:0!important}.chat-header{padding:14px 14px 12px}.chat-header h3{font-size:14px}.chat-message{padding:10px 12px;font-size:14px}.chat-input-area{gap:6px;padding:10px}.chat-input-area textarea{padding:9px 12px;font-size:14px}.mic-btn,.stop-btn{width:38px;height:38px;min-width:unset;border-radius:12px;padding:0}.chat-input-area>button:last-child{border-radius:12px;min-width:44px;height:38px;padding:0 12px}.quick-actions{gap:6px;padding:8px 10px}.quick-actions button{padding:6px 11px;font-size:11px}}.audio-settings-toggle{color:#30224a;cursor:pointer;background:#fff;border:1.5px solid #ddd8ea;border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;font-size:16px;transition:all .18s;display:flex}.audio-settings-toggle:hover,.audio-settings-toggle--active{background:#30224a;border-color:#30224a}.audio-settings-panel{z-index:10001;opacity:0;pointer-events:none;background:#fff;border:1.5px solid #e4e0f2;border-radius:16px;max-height:0;transition:max-height .22s,opacity .18s;position:absolute;bottom:68px;left:12px;right:12px;overflow:hidden;box-shadow:0 -4px 20px #2018441f,0 4px 12px #2018440f}.audio-settings-panel--open{opacity:1;pointer-events:auto;max-height:220px}.audio-settings-header{background:#f7f6fb;border-bottom:1px solid #ece8f6;justify-content:space-between;align-items:center;padding:10px 14px 8px;display:flex}.settings-title{color:#30224a;letter-spacing:.3px;text-transform:uppercase;font-family:Plus Jakarta Sans,sans-serif;font-size:12px;font-weight:700}.settings-close-btn{color:#9b8ec4;cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;width:22px;height:22px;padding:0;font-size:13px;transition:background .15s,color .15s;display:flex}.settings-close-btn:hover{color:#30224a;background:#ece8f6}.audio-settings-content{flex-direction:column;gap:10px;padding:10px 14px 12px;display:flex}.setting-row{align-items:center;gap:10px;display:flex}.setting-row label{color:#6b5f8a;min-width:50px;font-family:Plus Jakarta Sans,sans-serif;font-size:12px;font-weight:600}.voice-selector{color:#2f2a44;cursor:pointer;background:#fff;border:1.5px solid #ddd8ea;border-radius:8px;outline:none;flex:1;height:32px;padding:0 8px;font-family:Plus Jakarta Sans,sans-serif;font-size:12px;transition:border-color .15s}.voice-selector:focus{border-color:#9b8ec4}.slider-group{flex:1;align-items:center;gap:8px;display:flex}.settings-slider{appearance:none;cursor:pointer;background:#ddd8ea;border-radius:4px;outline:none;flex:1;height:4px;transition:background .15s}.settings-slider::-webkit-slider-thumb{appearance:none;cursor:pointer;background:#30224a;border:2px solid #fff;border-radius:50%;width:16px;height:16px;transition:transform .12s;box-shadow:0 1px 4px #20184440}.settings-slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.settings-slider::-moz-range-thumb{cursor:pointer;background:#30224a;border:2px solid #fff;border-radius:50%;width:16px;height:16px;box-shadow:0 1px 4px #20184440}.settings-slider:focus{background:#c4b5fd}.slider-value{color:#30224a;text-align:right;min-width:32px;font-family:Plus Jakarta Sans,sans-serif;font-size:11px;font-weight:700}.msg-listen-row{justify-content:flex-end;margin-top:8px;display:flex}.listen-btn{cursor:pointer;color:#30224a;background:#eeebff;border:1px solid #ddd6fe;border-radius:999px;padding:4px 13px;font-family:Plus Jakarta Sans,sans-serif;font-size:11.5px;font-weight:500;line-height:1.6;transition:all .15s}.listen-btn:hover{color:#fff;background:#30224a;border-color:#30224a}.listen-btn--processing{color:#6b7280;cursor:wait;background:#f3f4f6;border-color:#d1d5db;animation:1.2s ease-in-out infinite listen-pulse}.listen-btn--processing:hover{color:#6b7280;background:#f3f4f6;border-color:#d1d5db}.listen-btn--playing{color:#fff;background:#ef4444;border-color:#ef4444}.listen-btn--playing:hover{color:#fff;background:#dc2626;border-color:#dc2626}@keyframes listen-pulse{0%,to{opacity:1}50%{opacity:.55}}.error-details-toggle{color:#9b8ec4;cursor:pointer;-webkit-user-select:none;user-select:none;margin-top:5px;font-size:11px;display:inline-block}.error-details-toggle:hover{color:#30224a}.error-details-content{color:#2f2a44;white-space:pre-wrap;word-break:break-word;background:#f7f6fb;border-radius:8px;max-height:150px;margin-top:5px;padding:8px 10px;font-size:11.5px;line-height:1.5;overflow-y:auto}.gmail-token-error{color:#dc2626;background:#fef2f2;border-left:3px solid #dc2626;border-radius:4px;margin-bottom:12px;padding:8px 12px;font-family:Plus Jakarta Sans,sans-serif;font-size:12px}.gmail-token-oauth{margin-bottom:12px}.gmail-token-oauth-btn{color:#fff;cursor:pointer;background:#4285f4;border:1px solid #4285f4;border-radius:8px;width:100%;padding:10px;font-family:Plus Jakarta Sans,sans-serif;font-size:13px;font-weight:600;transition:background .15s,box-shadow .15s}.gmail-token-oauth-btn:hover{background:#3367d6;box-shadow:0 2px 8px #4285f44d}.gmail-token-oauth-btn:disabled{opacity:.6;cursor:not-allowed}.gmail-token-oauth-hint{color:#666;text-align:center;margin-top:6px;font-family:Plus Jakarta Sans,sans-serif;font-size:11px}.gmail-token-divider{text-align:center;color:#999;margin:12px 0;font-family:Plus Jakarta Sans,sans-serif;font-size:12px;font-weight:600;position:relative}.gmail-token-divider:before{content:"";background:#ccc;height:1px;position:absolute;top:50%;left:0;right:0}.gmail-token-divider{background:#fff;width:100%;padding:0 8px;display:inline-block;position:relative}.gmail-token-manual{padding-top:6px}.status-container{background:linear-gradient(135deg,#f5f3ff 0%,#fef3c7 100%);justify-content:center;align-items:center;min-height:100vh;padding:1rem;display:flex}.status-card{text-align:center;border:1px solid var(--border);background:#fff;border-radius:16px;width:100%;max-width:460px;padding:3rem 2.5rem;box-shadow:0 8px 32px #7c3aed1f}.status-logo{width:min(260px,100%);height:auto;margin:0 auto 1.25rem;display:block}.status-icon{border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;margin:0 auto 1.5rem;font-size:2rem;display:flex}.status-icon.pending{background:var(--accent-light);border:2px solid var(--accent)}.status-icon.rejected{color:var(--error);background:#fef2f2;border:2px solid #fca5a5}.status-card h2{color:var(--text-primary);margin-bottom:1rem;font-family:DM Serif Display,serif;font-size:1.8rem}.status-card p{color:var(--text-secondary);margin-bottom:.75rem;font-size:.95rem;line-height:1.6}.status-email{background:var(--primary-light);border-radius:8px;padding:.6rem 1rem;color:var(--primary)!important;font-size:.88rem!important}.status-email strong{color:var(--primary)}.status-note{color:var(--text-secondary);background:var(--bg-page);border-radius:8px;margin-top:.5rem;padding:.75rem 1rem;font-size:.85rem!important}.status-actions{flex-direction:column;gap:.75rem;margin-top:1.5rem;display:flex}.btn-signout{width:100%;color:var(--text-secondary);border:1.5px solid var(--border);cursor:pointer;background:0 0;border-radius:8px;padding:.85rem;font-family:DM Sans,sans-serif;font-size:.95rem;font-weight:500;transition:all .2s}.btn-signout:hover{border-color:var(--primary);color:var(--primary)}.status-school{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px;margin-bottom:.75rem;padding:.6rem 1rem;color:#166534!important;font-size:.88rem!important}.status-school strong{color:#166534}.status-still-pending{background:#fffbeb;border:1px solid #fde68a;border-radius:8px;padding:.6rem 1rem;color:#92400e!important;font-size:.85rem!important}.btn-check-status{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:8px;width:100%;padding:.85rem;font-family:DM Sans,sans-serif;font-size:.95rem;font-weight:600;transition:background .2s,opacity .2s}.btn-check-status:hover:not(:disabled){background:var(--primary-dark,#5b21b6)}.btn-check-status:disabled{opacity:.65;cursor:not-allowed}.sp-search-bar{margin-bottom:1.25rem;position:relative}.sp-search-bar input{border:1.5px solid var(--border);width:100%;color:var(--text-primary);background:#fff;border-radius:8px;outline:none;padding:.75rem 2.5rem .75rem 1rem;font-family:DM Sans,sans-serif;font-size:.9rem;transition:border-color .2s,box-shadow .2s}.sp-search-bar input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #7c3aed1a}.sp-clear-search{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;padding:.25rem;font-size:.85rem;position:absolute;top:50%;right:.75rem;transform:translateY(-50%)}.sp-form-card{border:1px solid var(--border);background:#fff;border-radius:12px;margin-bottom:1.5rem;padding:1.5rem}.sp-form-header{justify-content:space-between;align-items:center;margin-bottom:1.25rem;display:flex}.sp-form-header h3{color:var(--text-primary);font-family:DM Serif Display,serif;font-size:1.3rem}.sp-form-grid{grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem;display:grid}.sp-full-width{grid-column:1/-1}.sp-form-actions{justify-content:flex-end;gap:.75rem;margin-top:.5rem;display:flex}.btn-add-primary{background:linear-gradient(135deg, var(--primary) 0%, var(--accent) 100%);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:8px;padding:.7rem 1.25rem;font-family:DM Sans,sans-serif;font-size:.9rem;font-weight:500;transition:opacity .2s}.btn-add-primary:hover{opacity:.9}.btn-edit{color:#5b21b6;cursor:pointer;background:#ede9fe;border:1px solid #c4b5fd;border-radius:6px;padding:.4rem .9rem;font-family:DM Sans,sans-serif;font-size:.82rem;font-weight:500;transition:all .2s}.btn-edit:hover{color:#fff;background:#5b21b6;border-color:#5b21b6}.btn-deactivate{color:#991b1b;cursor:pointer;background:#fef2f2;border:1px solid #fecaca;border-radius:6px;padding:.4rem .9rem;font-family:DM Sans,sans-serif;font-size:.82rem;font-weight:500;transition:all .2s}.btn-deactivate:hover{color:#fff;background:#991b1b;border-color:#991b1b}.btn-activate{color:#166534;cursor:pointer;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:6px;padding:.4rem .9rem;font-family:DM Sans,sans-serif;font-size:.82rem;font-weight:500;transition:all .2s}.btn-activate:hover{color:#fff;background:#166534;border-color:#166534}.sp-id-badge{color:var(--primary);background:var(--primary-light);border-radius:4px;padding:.2rem .5rem;font-family:Courier New,monospace;font-size:.78rem;font-weight:600}.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap}.sortable:hover{color:var(--primary)}.sort-icon{color:var(--text-secondary);font-size:.75rem}.badge-inactive{color:#6b7280;background:#f3f4f6}.badge-info{color:#4338ca;background:#eef2ff}.row-inactive{opacity:.55}.form-group select{border:1.5px solid var(--border);width:100%;color:var(--text-primary);background:#fafafa;border-radius:8px;outline:none;padding:.75rem 1rem;font-family:DM Sans,sans-serif;font-size:.95rem;transition:border-color .2s,box-shadow .2s}.form-group select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #7c3aed1a}.btn-delete:hover:not(:disabled){color:#fff;background:#991b1b;border-color:#991b1b}.btn-delete:disabled{opacity:.5;cursor:not-allowed}.sp-modal-backdrop{z-index:1000;background:#00000073;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.sp-modal{background:#fff;border-radius:14px;flex-direction:column;gap:1.25rem;width:100%;max-width:440px;padding:2rem;display:flex;box-shadow:0 20px 60px #0003}.sp-modal-header{align-items:center;gap:.75rem;display:flex}.sp-modal-icon{font-size:1.5rem}.sp-modal-header h3{color:var(--text-primary);margin:0;font-size:1.1rem;font-weight:600}.sp-modal-body{color:var(--text-secondary);flex-direction:column;gap:.5rem;font-size:.9rem;display:flex}.sp-modal-body p{margin:0}.sp-modal-email{word-break:break-all;font-weight:600;color:var(--text-primary)!important;font-size:.95rem!important}.sp-modal-detail{color:var(--text-secondary)}.sp-modal-warning{background:#fef2f2;border:1px solid #fecaca;border-radius:8px;margin-top:.25rem;padding:.75rem 1rem;color:#991b1b!important;font-size:.85rem!important}.sp-modal-actions{justify-content:flex-end;gap:.75rem;display:flex}@media (width<=768px){.sp-form-grid{grid-template-columns:1fr}.sp-full-width{grid-column:1}.sp-modal-actions{flex-direction:column-reverse}.sp-modal-actions button{width:100%}}.profile-card{border:1px solid var(--border);background:#fff;border-radius:14px;margin-bottom:1.5rem;padding:2rem;box-shadow:0 1px 4px #0000000d}.profile-card-header{border-bottom:1px solid var(--border);align-items:center;gap:1.25rem;margin-bottom:1.75rem;padding-bottom:1.5rem;display:flex}.profile-avatar{color:#fff;background:linear-gradient(135deg,#7c3aed,#a78bfa);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:64px;height:64px;font-size:1.6rem;font-weight:700;display:flex}.profile-name{color:var(--text-primary);margin-bottom:.35rem;font-size:1.15rem;font-weight:700}.profile-role-badge{color:#6d28d9;text-transform:uppercase;letter-spacing:.04em;background:#ede9fe;border-radius:99px;padding:.2rem .75rem;font-size:.75rem;font-weight:600;display:inline-block}.profile-section-title{text-transform:uppercase;letter-spacing:.07em;color:var(--text-secondary);margin-bottom:1rem;font-size:.8rem;font-weight:700}.profile-fields-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem 2rem;display:grid}.profile-field{flex-direction:column;gap:.2rem;display:flex}.profile-field-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-size:.75rem;font-weight:600}.profile-field-value{color:var(--text-primary);word-break:break-word;font-size:.92rem}@media (width<=600px){.profile-card{padding:1.25rem}.profile-fields-grid{grid-template-columns:1fr}}.profile-avatar img{object-fit:cover;border-radius:50%;width:100%;height:100%}.sidebar-profile-widget{cursor:pointer;border-radius:10px;align-items:center;gap:.75rem;margin:0 .25rem;padding:.4rem;transition:background .15s;display:flex}.sidebar-profile-widget:hover,.sidebar-profile-widget--active{background:#ffffff1f}.sidebar-profile-avatar{color:#fff;background:linear-gradient(135deg,#7c3aed,#a78bfa);border:2px solid #fff3;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;font-size:1rem;font-weight:700;display:flex;overflow:hidden}.sidebar-profile-avatar img{object-fit:cover;width:100%;height:100%}.sidebar-profile-info{flex:1;min-width:0}.sidebar-profile-name{color:#fffffff2;white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;font-weight:600;overflow:hidden}.sidebar-profile-role{color:#ffffff80;text-transform:uppercase;letter-spacing:.07em;margin-top:.15rem;font-size:.7rem}.sidebar-profile-edit-hint{color:#ffffff4d;flex-shrink:0;margin-left:auto;font-size:.65rem}.profile-overlay-backdrop{z-index:1050;background:#00000073;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.profile-overlay-panel{background:#f9f8ff;border-radius:16px;width:100%;max-width:580px;max-height:90vh;padding:1.75rem 2rem 2rem;position:relative;overflow-y:auto;box-shadow:0 24px 64px #0000004d}.profile-overlay-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;display:flex}.profile-overlay-title{color:var(--text-primary);font-size:1.05rem;font-weight:700}.profile-overlay-close{border:1px solid var(--border);cursor:pointer;width:32px;height:32px;color:var(--text-secondary);background:0 0;border-radius:8px;justify-content:center;align-items:center;font-size:.9rem;transition:all .15s;display:flex}.profile-overlay-close:hover{color:var(--text-primary);background:#ede9fe;border-color:#c4b5fd}.profile-overlay-toast{z-index:1100;white-space:nowrap;border-radius:8px;padding:.65rem 1.25rem;font-size:.85rem;font-weight:500;position:fixed;top:1.25rem;left:50%;transform:translate(-50%);box-shadow:0 4px 12px #00000026}.profile-overlay-toast.success{color:#065f46;background:#d1fae5;border:1px solid #6ee7b7}.profile-overlay-toast.error{color:#991b1b;background:#fee2e2;border:1px solid #fca5a5}@media (width<=600px){.profile-overlay-panel{max-height:95vh;padding:1.25rem}}.parent-info-modal{width:90%;max-width:420px}.parent-modal-subtitle{text-align:center;color:var(--text-secondary);margin:-.5rem 0 .75rem;font-size:.85rem}.parent-modal-loading,.parent-modal-error{text-align:center;color:var(--text-secondary);padding:.75rem 0;font-size:.9rem}.parent-modal-error{color:#dc2626}.parent-info-grid{flex-direction:column;gap:.75rem;display:flex}.parent-info-row{border-bottom:1px solid var(--border);align-items:flex-start;gap:.75rem;padding-bottom:.75rem;display:flex}.parent-info-row:last-child{border-bottom:none;padding-bottom:0}.parent-info-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;min-width:130px;padding-top:.1rem;font-size:.78rem;font-weight:600}.parent-info-value{color:var(--text-primary);flex:1;font-size:.9rem}.icon-btn-parent{color:#7c3aed}.icon-btn-parent:hover{background:#7c3aed1a}:root{--bg-card:#fff;--bg-page:#f9fafb;--border:#e5e7eb;--text-primary:#111827;--text-secondary:#4b5563;--primary:#7c3aed;--primary-hover:#6d28d9;--radius-md:8px;--radius-lg:12px}.lunch-form-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);margin-top:1.5rem;padding:1.75rem;box-shadow:0 1px 4px #0000000f}.lunch-form-title{color:var(--text-primary);margin:0 0 1.25rem;font-size:1rem;font-weight:600}.lunch-form{flex-direction:column;gap:1.25rem;display:flex}.lunch-form-row{flex-wrap:wrap;align-items:flex-end;gap:1rem;display:flex}.lunch-field{flex-direction:column;flex:1;gap:.4rem;min-width:160px;display:flex}.lunch-field--wide{flex:2;min-width:260px}.lunch-field label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;font-size:.78rem;font-weight:600}.lunch-field input,.lunch-field select,.lunch-field textarea{border:1.5px solid var(--border);border-radius:var(--radius-md);width:100%;color:var(--text-primary);resize:vertical;background:#fff;outline:none;padding:.6rem .8rem;font-family:inherit;font-size:.9rem;transition:border-color .15s,box-shadow .15s}.lunch-field input:focus,.lunch-field select:focus,.lunch-field textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #7c3aed1f}@media (width<=900px){.event-meta-grid{grid-template-columns:1fr 1fr}}@media (width<=600px){.event-meta-grid{grid-template-columns:1fr}}.subevent-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.25rem;margin-top:.5rem;display:grid}.subevent-card{border:1.5px solid var(--border);border-radius:var(--radius-lg);background:#fff;flex-direction:column;gap:1rem;padding:1.25rem;transition:box-shadow .2s;display:flex}.subevent-card:hover{box-shadow:0 4px 12px #00000012}.subevent-card--pizza{border-top:3px solid #f59e0b}.subevent-card--hotlunch{border-top:3px solid #ef4444}.subevent-card--readonly{background:var(--bg-page)}.subevent-card-header{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.subevent-day-label{color:var(--primary);text-transform:uppercase;letter-spacing:.06em;background:#7c3aed14;border-radius:20px;padding:.2rem .6rem;font-size:.78rem;font-weight:700}.template-select{border:1.5px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;background:#fff;flex:1;min-width:0;padding:.35rem .6rem;font-size:.82rem}.template-select:focus{border-color:var(--primary);outline:none}.subevent-fields{grid-template-columns:1fr 1fr;gap:.75rem;display:grid}@media (width<=480px){.subevent-fields{grid-template-columns:1fr}}.items-section{flex-direction:column;gap:.5rem;display:flex}.items-section-header{justify-content:space-between;align-items:center;display:flex}.items-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;font-size:.78rem;font-weight:700}.items-hint{color:#9ca3af;font-size:.75rem;font-style:italic}.item-rows{flex-direction:column;gap:.4rem;display:flex}.item-row{background:var(--bg-page);border:1px solid var(--border);border-radius:var(--radius-md);flex-wrap:wrap;align-items:center;gap:.5rem;padding:.4rem .6rem;display:flex}.item-row select{min-width:150px;color:var(--text-primary);cursor:pointer;background:0 0;border:none;outline:none;flex:1;padding:.3rem .4rem;font-size:.85rem}.item-row-preview{color:var(--text-secondary);white-space:nowrap;background:#7c3aed12;border-radius:20px;padding:.2rem .5rem;font-size:.75rem;font-weight:500}.btn-remove-item{color:#d1d5db;cursor:pointer;background:0 0;border:none;border-radius:4px;flex-shrink:0;padding:.1rem .3rem;font-size:.9rem;line-height:1;transition:color .15s}.btn-remove-item:hover{color:#ef4444}.btn-add-row{border-radius:var(--radius-md);color:var(--primary);cursor:pointer;background:0 0;border:1.5px dashed #c4b5fd;align-self:flex-start;margin-top:.25rem;padding:.3rem .75rem;font-size:.8rem;font-weight:600;transition:all .15s}.btn-add-row:hover{border-color:var(--primary);background:#7c3aed0f}.subevent-readonly-title{color:var(--text-primary);margin:0;font-size:.95rem;font-weight:600}.slot-items-list{flex-direction:column;gap:.4rem;margin:0;padding:0;list-style:none;display:flex}.slot-items-list li{background:var(--bg-page);border:1px solid var(--border);border-radius:var(--radius-md);justify-content:space-between;align-items:center;padding:.4rem .6rem;font-size:.85rem;display:flex}.slot-item-name{color:var(--text-primary);font-weight:500}.slot-item-meta{color:var(--text-secondary);font-size:.78rem}.slot-no-items{color:#9ca3af;margin:0;font-size:.85rem;font-style:italic}.btn-save,.btn-add-item{background:var(--primary);color:#fff;border-radius:var(--radius-md);cursor:pointer;white-space:nowrap;border:none;justify-content:center;align-items:center;height:40px;padding:0 1.5rem;font-family:inherit;font-size:.88rem;font-weight:600;transition:background .15s,transform .1s;display:inline-flex}.btn-save:hover:not(:disabled),.btn-add-item:hover{background:var(--primary-hover)}.btn-save:active{transform:scale(.98)}.btn-save:disabled{opacity:.55;cursor:not-allowed}.btn-save--full{border-radius:var(--radius-md);background:linear-gradient(135deg, var(--primary) 0%, #a855f7 100%);width:100%;height:48px;font-size:.95rem}.btn-save--full:hover:not(:disabled){background:linear-gradient(135deg, var(--primary-hover) 0%, #9333ea 100%)}.btn-delete{color:#ef4444;cursor:pointer;background:0 0;border:1.5px solid #fca5a5;border-radius:6px;padding:.35rem .8rem;font-family:inherit;font-size:.8rem;font-weight:500;transition:all .15s}.btn-delete:hover{background:#fef2f2;border-color:#ef4444}.lunch-form-actions{justify-content:flex-end;display:flex}.badge-active{color:#166534;white-space:nowrap;background:#dcfce7;border-radius:20px;padding:.25rem .65rem;font-size:.78rem;font-weight:600}.badge-inactive{color:#6b7280;white-space:nowrap;background:#f3f4f6;border-radius:20px;padding:.25rem .65rem;font-size:.78rem;font-weight:600}.badge-pizza{color:#854d0e;white-space:nowrap;background:#fef9c3;border:1px solid #fde68a;border-radius:20px;padding:.25rem .65rem;font-size:.78rem;font-weight:600}.badge-hotlunch{color:#991b1b;white-space:nowrap;background:#fee2e2;border:1px solid #fecaca;border-radius:20px;padding:.25rem .65rem;font-size:.78rem;font-weight:600}.item-code{background:var(--bg-page);border:1px solid var(--border);color:var(--text-primary);border-radius:4px;padding:.15rem .45rem;font-family:monospace;font-size:.82rem}.item-name{color:var(--text-primary);font-size:.9rem;font-weight:500}.item-desc{color:var(--text-secondary);margin-top:.2rem;font-size:.78rem}.clickable-title{cursor:pointer;color:var(--primary);text-underline-offset:3px;text-decoration:underline}.clickable-title:hover{color:var(--primary-hover)}@media (width<=768px){.subevent-grid{grid-template-columns:1fr}.lunch-form-row{flex-direction:column}}.day-type-form{grid-template-columns:180px 1fr 200px 100px;align-items:flex-end;gap:1rem;margin-bottom:1rem;display:grid}@media (width<=700px){.day-type-form{grid-template-columns:1fr}}.day-type-chips{flex-wrap:wrap;gap:.5rem;margin-top:.75rem;display:flex}.day-type-chip{background:#7c3aed12;border:1.5px solid #7c3aed33;border-radius:20px;align-items:center;gap:.4rem;padding:.3rem .75rem;display:inline-flex}.day-type-chip-name{color:var(--primary);font-size:.85rem;font-weight:600}.day-type-chip-day{color:var(--text-secondary);background:#0000000d;border-radius:10px;padding:.1rem .4rem;font-size:.78rem}.day-type-chip-delete{color:#d1d5db;cursor:pointer;background:0 0;border:none;padding:0;font-size:.8rem;line-height:1;transition:color .15s}.day-type-chip-delete:hover{color:#ef4444}.day-type-empty{color:#9ca3af;margin:.5rem 0 0;font-size:.85rem;font-style:italic}.badge-daytype{color:var(--primary);white-space:nowrap;background:#7c3aed1a;border:1px solid #7c3aed33;border-radius:20px;padding:.25rem .65rem;font-size:.78rem;font-weight:600}.dates-section{flex-direction:column;gap:.5rem;display:flex}.week-groups{flex-direction:column;gap:.5rem;margin-top:.4rem;display:flex}.week-group{border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.week-group-header{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border);background:#f8fafc;padding:.4rem .75rem;font-size:.78rem;font-weight:700}.week-group-rows{flex-direction:column;display:flex}.date-row{border-bottom:1px solid var(--border);align-items:center;gap:.75rem;padding:.5rem .75rem;transition:background .1s;display:flex}.date-row:last-child{border-bottom:none}.date-row--inactive{opacity:.7;background:#fafafa}.date-row-date{color:var(--text-primary);flex:1;font-size:.85rem;font-weight:500}.btn-date-toggle{cursor:pointer;white-space:nowrap;border:none;border-radius:6px;padding:.25rem .65rem;font-family:inherit;font-size:.75rem;font-weight:500;transition:all .15s}.btn-date-disable{color:#991b1b;background:#fee2e2}.btn-date-disable:hover{background:#fecaca}.btn-date-enable{color:#166534;background:#dcfce7}.btn-date-enable:hover{background:#bbf7d0}.dates-hint{color:#9ca3af;margin:.25rem 0 0;font-size:.8rem;font-style:italic}.event-meta-grid{grid-template-columns:2fr 1fr 1fr 1fr 1fr;gap:1rem;margin-bottom:1.5rem;display:grid}@media (width<=1024px){.event-meta-grid{grid-template-columns:1fr 1fr 1fr}}@media (width<=600px){.event-meta-grid{grid-template-columns:1fr}}.day-type-chip-code{color:#fff;background:var(--primary);letter-spacing:.04em;border-radius:10px;padding:.1rem .45rem;font-size:.75rem;font-weight:700}.filter-tabs-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.lunch-field .input-error{background:#fff8f8!important;border-color:#dc2626!important}.lunch-field .input-error:focus{border-color:#dc2626!important;box-shadow:0 0 0 3px #dc26261a!important}.lunch-field .field-error{color:#dc2626;margin-top:.2rem;font-size:.78rem}.btn-add{background:linear-gradient(135deg, var(--primary) 0%, var(--accent) 100%);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:.7rem 1.25rem;font-family:DM Sans,sans-serif;font-size:.9rem;font-weight:500;transition:opacity .2s}.btn-add:hover{opacity:.9}.child-form-card{border:1px solid var(--border);background:#fff;border-radius:12px;margin-bottom:1.5rem;padding:1.5rem}.child-form-header{justify-content:space-between;align-items:center;margin-bottom:1.25rem;display:flex}.child-form-header h3{color:var(--text-primary);font-family:DM Serif Display,serif;font-size:1.3rem}.btn-close{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:.25rem .5rem;font-size:1rem;transition:background .2s}.btn-close:hover{background:var(--bg-page)}.form-group textarea{border:1.5px solid var(--border);width:100%;color:var(--text-primary);resize:vertical;background:#fafafa;border-radius:8px;outline:none;padding:.75rem 1rem;font-family:DM Sans,sans-serif;font-size:.95rem;transition:border-color .2s,box-shadow .2s}.form-group textarea:focus{border-color:var(--primary);background:#fff;box-shadow:0 0 0 3px #7c3aed1a}.form-actions{justify-content:flex-end;gap:.75rem;margin-top:1rem;display:flex}.children-grid{flex-direction:column;gap:1rem;display:flex}.child-card{border:1px solid var(--border);background:#fff;border-radius:12px;align-items:center;gap:1.25rem;padding:1.25rem 1.5rem;transition:box-shadow .2s;display:flex}.child-card:hover{box-shadow:0 4px 16px #7c3aed14}.child-avatar{flex-shrink:0}.child-avatar img{object-fit:cover;border:2px solid var(--border);border-radius:50%;width:56px;height:56px}.child-avatar-placeholder{background:var(--primary-light);width:56px;height:56px;color:var(--primary);border:2px solid var(--border);border-radius:50%;justify-content:center;align-items:center;font-size:1.1rem;font-weight:600;display:flex}.child-info{flex-direction:column;flex:1;gap:.25rem;display:flex}.child-name{color:var(--text-primary);font-size:1rem;font-weight:600}.child-grade{color:var(--primary);font-size:.85rem;font-weight:500}.child-allergy{color:#92400e;background:#fef3c7;border-radius:4px;width:fit-content;padding:.2rem .5rem;font-size:.8rem}.child-meta{color:var(--text-secondary);font-size:.8rem}.child-status{flex-shrink:0}.badge-pending{color:#92400e;background:#fef3c7}.badge-approved{color:#166534;background:#f0fdf4}.badge-rejected{color:#991b1b;background:#fef2f2}@media (width<=480px){.form-row{flex-direction:column;gap:0}.form-actions{flex-direction:column-reverse}.form-actions .btn-secondary,.form-actions .btn-primary{width:100%}.child-card{flex-wrap:wrap}}*{box-sizing:border-box;margin:0;padding:0}:root{--primary:#7c3aed;--primary-hover:#6d28d9;--primary-light:#ede9fe;--accent:#f59e0b;--accent-hover:#d97706;--accent-light:#fef3c7;--bg-page:#f5f3ff;--bg-card:#fff;--text-primary:#1e1b2e;--text-secondary:#6b7280;--border:#e5e0f8;--error:#dc2626;--error-bg:#fef2f2}body{background-color:var(--bg-page);color:var(--text-primary);font-family:DM Sans,sans-serif}.chat-fab{cursor:pointer;z-index:999;background:linear-gradient(135deg,#7c3aed 0%,#f59e0b 100%);border:none;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;font-size:1.5rem;transition:transform .2s,box-shadow .2s;display:flex;position:fixed;bottom:2rem;right:2rem;box-shadow:0 4px 16px #7c3aed66}.chat-fab:hover{transform:scale(1.1);box-shadow:0 6px 24px #7c3aed80}.chat-fab:active{transform:scale(.95)}.chat-fab-tooltip{color:#fff;white-space:nowrap;opacity:0;pointer-events:none;z-index:999;background:#1e1b2e;border-radius:6px;padding:.4rem .75rem;font-family:DM Sans,sans-serif;font-size:.78rem;font-weight:500;transition:opacity .2s;position:fixed;bottom:5.5rem;right:2rem}.chat-fab:hover+.chat-fab-tooltip{opacity:1}.dialog-overlay{z-index:1100;background:#00000073;justify-content:center;align-items:center;padding:1rem;animation:.15s dialog-fade-in;display:flex;position:fixed;inset:0}@keyframes dialog-fade-in{0%{opacity:0}to{opacity:1}}.dialog-box{background:var(--bg-card);border-radius:12px;width:100%;max-width:440px;padding:1.75rem;animation:.15s dialog-slide-in;box-shadow:0 20px 60px #0003}@keyframes dialog-slide-in{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}.dialog-icon{margin-bottom:.6rem;font-size:1.75rem;display:block}.dialog-title{color:var(--text-primary);margin-bottom:.5rem;font-size:1.05rem;font-weight:700}.dialog-title--danger,.dialog-title--error{color:var(--error)}.dialog-title--success{color:#16a34a}.dialog-title--warning{color:var(--accent)}.dialog-message{color:var(--text-secondary);white-space:pre-line;margin-bottom:1.5rem;font-size:.9rem;line-height:1.6}.dialog-actions{justify-content:flex-end;gap:.625rem;display:flex}.dialog-btn{cursor:pointer;border:none;border-radius:8px;padding:.55rem 1.25rem;font-size:.875rem;font-weight:600;transition:background .15s,opacity .15s}.dialog-btn--cancel{color:var(--text-primary);background:#f3f4f6}.dialog-btn--cancel:hover{background:#e5e7eb}.dialog-btn--confirm{background:var(--primary);color:#fff}.dialog-btn--confirm:hover{background:var(--primary-hover)}.dialog-btn--danger{background:var(--error);color:#fff}.dialog-btn--danger:hover{background:#b91c1c}.dialog-btn--success{color:#fff;background:#16a34a}.dialog-btn--success:hover{background:#15803d}.dialog-btn--warning{background:var(--accent);color:#fff}.dialog-btn--warning:hover{background:var(--accent-hover)}
