*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;line-height:1.5;color:var(--color-text);background:var(--color-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button{font-family:inherit;cursor:pointer}input{font-family:inherit}.toast-container{position:fixed;top:var(--space-lg);right:var(--space-lg);z-index:1000;display:flex;flex-direction:column;gap:var(--space-sm)}.toast{padding:var(--space-md) var(--space-lg);border-radius:var(--radius-md);color:#fff;font-weight:500;font-size:.95rem;box-shadow:var(--shadow-md);animation:toast-in .3s ease;min-width:250px}.toast--success{background-color:var(--color-success)}.toast--error{background-color:var(--color-danger)}.toast--info{background-color:var(--color-primary)}@keyframes toast-in{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}.sidebar{width:var(--sidebar-width);background:var(--color-surface);border-right:1px solid var(--color-border);display:flex;flex-direction:column;align-items:center;padding:var(--space-md) 0;height:100vh;position:fixed;left:0;top:0;z-index:50}.sidebar__brand{font-size:.8rem;font-weight:800;color:var(--color-primary);margin-bottom:var(--space-xl);letter-spacing:1px}.sidebar__nav{display:flex;flex-direction:column;gap:var(--space-sm);flex:1}.sidebar__link{display:flex;flex-direction:column;align-items:center;gap:4px;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);text-decoration:none;color:var(--color-text-secondary);font-size:.65rem;font-weight:500;transition:all .15s ease}.sidebar__link svg{width:22px;height:22px}.sidebar__link:hover{background:var(--color-bg);color:var(--color-text)}.sidebar__link--active{background:var(--color-primary);color:#fff}.sidebar__link--active:hover{background:var(--color-primary-hover);color:#fff}.sidebar__footer{display:flex;flex-direction:column;align-items:center;gap:var(--space-sm)}.sidebar__user{width:36px;height:36px;border-radius:50%;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem}.sidebar__logout{background:none;border:none;padding:var(--space-sm);border-radius:var(--radius-sm);color:var(--color-text-secondary);cursor:pointer;transition:all .15s ease}.sidebar__logout:hover{background:#fef2f2;color:var(--color-danger)}.sidebar__logout svg{width:20px;height:20px}@media (max-width: 768px){.sidebar{width:100%;height:56px;flex-direction:row;position:fixed;bottom:0;top:auto;left:0;right:0;border-right:none;border-top:1px solid var(--color-border);padding:0 var(--space-lg);justify-content:space-between;z-index:100}.sidebar__brand{display:none}.sidebar__nav{flex-direction:row;flex:1;justify-content:center;gap:var(--space-lg)}.sidebar__link{flex-direction:row;gap:var(--space-xs);font-size:.75rem;padding:var(--space-sm)}.sidebar__footer{flex-direction:row;align-items:center;gap:var(--space-sm)}.sidebar__user{width:32px;height:32px;font-size:.75rem}}.app-layout{display:flex;min-height:100vh;background:var(--color-bg)}.main-content{flex:1;margin-left:var(--sidebar-width);height:100vh;overflow:hidden}@media (max-width: 768px){.main-content{margin-left:0;height:calc(100vh - 56px);overflow-y:auto}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--color-bg);padding:var(--space-md)}.login-card{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:var(--space-xl) var(--space-xl);width:100%;max-width:400px}.login-card__title{font-size:1.75rem;font-weight:800;color:var(--color-primary);text-align:center;margin:0 0 var(--space-xs)}.login-card__subtitle{text-align:center;color:var(--color-text-secondary);margin:0 0 var(--space-lg);font-size:.9rem}.login-card__error{background:#fef2f2;color:var(--color-danger);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);font-size:.85rem;margin-bottom:var(--space-md);border:1px solid #fecaca}.login-card__field{margin-bottom:var(--space-md)}.login-card__field label{display:block;font-size:.85rem;font-weight:600;color:var(--color-text);margin-bottom:var(--space-xs)}.login-card__field input{width:100%;padding:14px 16px;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:1rem;font-family:inherit;transition:border-color .15s ease;box-sizing:border-box}.login-card__field input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #2563eb1a}.login-card__button{width:100%;padding:14px;background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:1rem;font-weight:600;font-family:inherit;cursor:pointer;transition:background .15s ease;margin-top:var(--space-sm)}.login-card__button:hover:not(:disabled){background:var(--color-primary-hover)}.login-card__button:disabled{opacity:.7;cursor:not-allowed}.transaction-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-md);margin-bottom:var(--space-lg)}.transaction-summary__card{background:var(--color-surface);border-radius:var(--radius-md);padding:var(--space-md);display:flex;flex-direction:column;gap:var(--space-xs);border-left:4px solid transparent}.transaction-summary__card--success{border-left-color:var(--color-success)}.transaction-summary__card--primary{border-left-color:var(--color-primary)}.transaction-summary__card--info{border-left-color:#06b6d4}.transaction-summary__card--danger{border-left-color:var(--color-danger)}.transaction-summary__label{font-size:.75rem;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px}.transaction-summary__value{font-size:1.3rem;font-weight:800;color:var(--color-text)}.transaction-summary__divider{font-weight:300;color:var(--color-text-secondary);font-size:1.1rem}@media (max-width: 900px){.transaction-summary{grid-template-columns:repeat(2,1fr)}}@media (max-width: 480px){.transaction-summary{grid-template-columns:repeat(2,1fr);gap:var(--space-sm)}.transaction-summary__value{font-size:1.1rem}}.transaction-row td{padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--color-border);font-size:.85rem;color:var(--color-text)}.transaction-row--void td{opacity:.6}.transaction-row__amount{font-weight:700}.transaction-row__status{display:inline-block;padding:2px 8px;border-radius:12px;font-size:.7rem;font-weight:700;text-transform:uppercase}.transaction-row__status--completed{background:#dcfce7;color:var(--color-success)}.transaction-row__status--void{background:#fef2f2;color:var(--color-danger)}.transaction-row__actions{display:flex;gap:var(--space-xs)}.transaction-row__btn{padding:4px 10px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);font-size:.75rem;font-weight:600;color:var(--color-text);white-space:nowrap}.transaction-row__btn:hover{background:var(--color-bg)}.transaction-row__btn--void{color:var(--color-danger);border-color:var(--color-danger)}.transaction-row__btn--void:hover{background:#fef2f2}@media (max-width: 768px){.transaction-row td{padding:var(--space-sm);font-size:.8rem;white-space:nowrap}.transaction-row__btn{padding:6px 10px;font-size:.75rem}}.txn-detail-modal{max-width:520px}.txn-detail-modal__header{display:flex;justify-content:space-between;align-items:flex-start;padding:var(--space-lg);border-bottom:1px solid var(--color-border)}.txn-detail-modal__header h3{font-size:1.1rem;font-weight:700}.txn-detail-modal__time{font-size:.8rem;color:var(--color-text-secondary)}.txn-detail-modal__body{padding:var(--space-md) var(--space-lg)}.txn-detail-modal__table{width:100%;border-collapse:collapse;font-size:.85rem}.txn-detail-modal__table th{text-align:left;padding:var(--space-sm);border-bottom:2px solid var(--color-border);color:var(--color-text-secondary);font-size:.75rem;font-weight:600;text-transform:uppercase}.txn-detail-modal__table td{padding:var(--space-sm);border-bottom:1px solid var(--color-border);color:var(--color-text)}.txn-detail-modal__options{font-size:.7rem;color:var(--color-text-secondary);margin-top:2px}.txn-detail-modal__footer{padding:var(--space-md) var(--space-lg);border-top:1px solid var(--color-border)}.txn-detail-modal__meta{font-size:.8rem;color:var(--color-text-secondary);margin-bottom:var(--space-sm)}.txn-detail-modal__total{display:flex;justify-content:space-between;font-size:1.1rem;font-weight:800;margin-bottom:var(--space-md)}.txn-detail-modal__close{width:100%;padding:12px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);font-size:.9rem;font-weight:600;color:var(--color-text)}.txn-detail-modal__close:hover{background:var(--color-bg)}.import-modal{max-width:480px}.import-modal__header{padding:var(--space-lg);border-bottom:1px solid var(--color-border)}.import-modal__header h3{font-size:1.1rem;font-weight:700}.import-modal__body{padding:var(--space-lg)}.import-modal__desc{font-size:.85rem;color:var(--color-text-secondary);margin-bottom:var(--space-sm)}.import-modal__format{display:block;font-size:.7rem;background:var(--color-bg);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);color:var(--color-text-secondary);margin-bottom:var(--space-lg)}.import-modal__upload{margin-bottom:var(--space-md)}.import-modal__file-input{display:none}.import-modal__browse{width:100%;padding:14px;border:2px dashed var(--color-border);border-radius:var(--radius-md);background:var(--color-bg);font-size:.9rem;font-weight:600;color:var(--color-text-secondary);cursor:pointer;transition:all .15s ease}.import-modal__browse:hover{border-color:var(--color-primary);color:var(--color-primary)}.import-modal__error{background:#fef2f2;color:var(--color-danger);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);font-size:.85rem;margin-bottom:var(--space-md);border:1px solid #fecaca}.import-modal__preview,.import-modal__result{background:var(--color-bg);border-radius:var(--radius-md);padding:var(--space-md);display:flex;flex-direction:column;gap:var(--space-sm)}.import-modal__stat{display:flex;justify-content:space-between;align-items:center;font-size:.85rem}.import-modal__stat span{color:var(--color-text-secondary)}.import-modal__stat strong{color:var(--color-text);font-size:.95rem}.import-modal__stat--success strong{color:var(--color-success);font-size:1.1rem}.import-modal__footer{display:flex;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);border-top:1px solid var(--color-border)}.import-modal__cancel{flex:1;padding:12px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);font-size:.9rem;font-weight:600;color:var(--color-text)}.import-modal__cancel:hover{background:var(--color-bg)}.import-modal__submit{flex:2;padding:12px;border:none;border-radius:var(--radius-md);background:var(--color-primary);color:#fff;font-size:.9rem;font-weight:700}.import-modal__submit:hover:not(:disabled){background:var(--color-primary-hover)}.import-modal__submit:disabled{opacity:.5;cursor:not-allowed}.loading-spinner{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-xl);gap:var(--space-md)}.loading-spinner__message{color:var(--color-text-secondary);font-size:.9rem}.transactions-page{padding:var(--space-lg);height:100%;overflow-y:auto}.transactions-page__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-md)}.transactions-page__title{font-size:1.5rem;font-weight:800;color:var(--color-text)}.transactions-page__import-btn{padding:var(--space-sm) var(--space-md);border:1px solid var(--color-primary);border-radius:var(--radius-md);background:var(--color-surface);font-size:.85rem;font-weight:600;font-family:inherit;color:var(--color-primary);cursor:pointer;transition:all .15s ease}.transactions-page__import-btn:hover{background:var(--color-primary);color:#fff}.transactions-page__filter-bar{display:flex;align-items:center;gap:var(--space-xs);margin-bottom:var(--space-lg);flex-wrap:wrap}.transactions-page__filter-btn{padding:6px 14px;border:1px solid var(--color-border);border-radius:999px;background:var(--color-surface);font-size:.8rem;font-weight:600;font-family:inherit;color:var(--color-text-secondary);cursor:pointer;transition:all .15s ease;white-space:nowrap}.transactions-page__filter-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.transactions-page__filter-btn--active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.transactions-page__filter-btn--active:hover{background:var(--color-primary);color:#fff}.transactions-page__custom-range{display:flex;align-items:center;gap:var(--space-xs);margin-left:var(--space-xs)}.transactions-page__date{padding:5px 10px;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:.8rem;font-family:inherit;background:var(--color-surface);color:var(--color-text)}.transactions-page__date-separator{font-size:.8rem;color:var(--color-text-secondary)}.transactions-page__apply-btn{padding:5px 14px;border:1px solid var(--color-primary);border-radius:var(--radius-md);background:var(--color-primary);font-size:.8rem;font-weight:600;font-family:inherit;color:#fff;cursor:pointer;white-space:nowrap;transition:all .15s ease}.transactions-page__apply-btn:disabled{opacity:.4;cursor:not-allowed}.transactions-page__apply-btn:not(:disabled):hover{background:var(--color-primary-hover)}.transactions-page__table-wrapper{background:var(--color-surface);border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--color-border)}.transactions-page__table{width:100%;border-collapse:collapse}.transactions-page__table thead th{text-align:left;padding:var(--space-sm) var(--space-md);background:var(--color-bg);font-size:.75rem;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--color-border)}.transactions-page__empty{display:flex;align-items:center;justify-content:center;height:40vh;color:var(--color-text-secondary);font-size:.95rem}@media (max-width: 768px){.transactions-page{padding:var(--space-md)}.transactions-page__header{flex-direction:column;align-items:flex-start;gap:var(--space-sm)}.transactions-page__import-btn{width:100%;text-align:center}.transactions-page__filter-bar{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:var(--space-xs);scrollbar-width:none}.transactions-page__filter-bar::-webkit-scrollbar{display:none}.transactions-page__custom-range{flex-shrink:0;margin-left:0}.transactions-page__table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}}.reports-page{padding:var(--space-lg);height:100%;overflow-y:auto}.reports-page__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-md)}.reports-page__title{font-size:1.5rem;font-weight:800;color:var(--color-text)}.reports-page__filter-bar{display:flex;gap:var(--space-xs);margin-bottom:var(--space-lg);flex-wrap:wrap}.reports-page__filter-btn{padding:6px 14px;border:1px solid var(--color-border);border-radius:999px;background:var(--color-surface);font-size:.8rem;font-weight:600;font-family:inherit;color:var(--color-text-secondary);cursor:pointer;transition:all .15s ease;white-space:nowrap}.reports-page__filter-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.reports-page__filter-btn--active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.reports-page__custom-range{display:flex;align-items:center;gap:var(--space-xs);flex-wrap:wrap}.reports-page__date{padding:5px 10px;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:.8rem;font-family:inherit;background:var(--color-surface);color:var(--color-text)}.reports-page__apply-btn{padding:5px 14px;border:1px solid var(--color-primary);border-radius:var(--radius-md);background:var(--color-primary);font-size:.8rem;font-weight:600;font-family:inherit;color:#fff;cursor:pointer;white-space:nowrap;transition:all .15s ease}.reports-page__apply-btn:disabled{opacity:.4;cursor:not-allowed}.reports-page__apply-btn:not(:disabled):hover{background:var(--color-primary-hover)}.reports-page__cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:var(--space-md);margin-bottom:var(--space-lg)}.reports-card{background:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border);padding:var(--space-md);display:flex;flex-direction:column;gap:6px}.reports-card--profit{border-left:3px solid var(--color-success)}.reports-card--cost{border-left:3px solid var(--color-danger)}.reports-card--margin{border-left:3px solid var(--color-warning)}.reports-card__label{font-size:.7rem;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px}.reports-card__value{font-size:1.3rem;font-weight:800;color:var(--color-text)}.reports-page__notice{background:#fffbeb;border:1px solid #fde68a;border-radius:var(--radius-md);padding:var(--space-md);font-size:.85rem;color:#92400e;margin-bottom:var(--space-lg)}.reports-page__notice a{color:var(--color-primary);font-weight:600;text-decoration:none}.reports-page__table-wrapper{background:var(--color-surface);border-radius:var(--radius-md);overflow-x:auto;border:1px solid var(--color-border)}.reports-page__table{width:100%;border-collapse:collapse}.reports-page__table thead th{text-align:left;padding:var(--space-sm) var(--space-md);background:var(--color-bg);font-size:.75rem;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--color-border);white-space:nowrap}.reports-page__table tbody td{padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--color-border);font-size:.85rem;color:var(--color-text)}.reports-page__table tbody tr:last-child td{border-bottom:none}.reports-page__amount{font-weight:700}.reports-page__profit{font-weight:700;color:var(--color-success)}.reports-page__margin{font-weight:600}.reports-page__margin--low{color:var(--color-danger)}@media (max-width: 768px){.reports-page{padding:var(--space-md)}.reports-page__cards{grid-template-columns:repeat(2,1fr)}}.costs-page{padding:var(--space-lg);height:100%;overflow-y:auto}.costs-page__header{margin-bottom:var(--space-lg)}.costs-page__title{font-size:1.5rem;font-weight:800;color:var(--color-text);margin-bottom:4px}.costs-page__subtitle{font-size:.85rem;color:var(--color-text-secondary)}.costs-page__list{display:flex;flex-direction:column;gap:var(--space-lg)}.costs-category__name{font-size:.75rem;font-weight:700;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--space-sm)}.costs-category__table-wrapper{background:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border);overflow-x:auto}.costs-category__table{width:100%;border-collapse:collapse}.costs-category__table thead th{text-align:left;padding:var(--space-sm) var(--space-md);background:var(--color-bg);font-size:.75rem;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--color-border);white-space:nowrap}.costs-category__table tbody td{padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--color-border);font-size:.85rem;color:var(--color-text);vertical-align:middle}.costs-category__table tbody tr:last-child td{border-bottom:none}.costs-input-wrapper{display:flex;align-items:center;border:1px solid var(--color-border);border-radius:var(--radius-sm);overflow:hidden;width:110px;background:var(--color-surface)}.costs-input-wrapper:focus-within{border-color:var(--color-primary)}.costs-input-prefix{padding:0 6px;font-size:.85rem;color:var(--color-text-secondary);background:var(--color-bg);border-right:1px solid var(--color-border);height:100%;display:flex;align-items:center}.costs-input{border:none;outline:none;padding:6px 8px;font-size:.85rem;font-family:inherit;width:100%;background:transparent;color:var(--color-text)}.costs-profit{font-weight:700;color:var(--color-success)}.costs-margin{font-weight:600;font-size:.85rem;color:var(--color-success)}.costs-margin--low{color:var(--color-danger)}.costs-save-btn{padding:5px 14px;border:1px solid var(--color-primary);border-radius:var(--radius-sm);background:var(--color-surface);font-size:.78rem;font-weight:600;font-family:inherit;color:var(--color-primary);cursor:pointer;transition:all .15s ease;white-space:nowrap}.costs-save-btn:hover{background:var(--color-primary);color:#fff}.costs-save-btn:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 768px){.costs-page{padding:var(--space-md)}}.menu-page{padding:var(--space-lg);height:100%;overflow-y:auto}.menu-page__header{margin-bottom:var(--space-lg)}.menu-page__title{font-size:1.5rem;font-weight:800;color:var(--color-text);margin-bottom:4px}.menu-page__subtitle{font-size:.85rem;color:var(--color-text-secondary)}.menu-page__list{display:flex;flex-direction:column;gap:var(--space-lg)}.menu-category__name{font-size:.75rem;font-weight:700;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--space-sm)}.menu-category__table-wrapper{background:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border);overflow-x:auto}.menu-category__table{width:100%;border-collapse:collapse}.menu-category__table thead th{text-align:left;padding:var(--space-sm) var(--space-md);background:var(--color-bg);font-size:.75rem;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--color-border);white-space:nowrap}.menu-th--center{text-align:center!important}.menu-category__table tbody td{padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--color-border);font-size:.85rem;color:var(--color-text);vertical-align:middle}.menu-category__table tbody tr:last-child td{border-bottom:none}.menu-row--unavailable td{color:var(--color-text-secondary);opacity:.6}.menu-input{border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:6px 8px;font-size:.85rem;font-family:inherit;color:var(--color-text);background:var(--color-surface);outline:none;width:100%}.menu-input:focus{border-color:var(--color-primary)}.menu-price-input-wrapper{display:flex;align-items:center;border:1px solid var(--color-border);border-radius:var(--radius-sm);overflow:hidden;width:110px;background:var(--color-surface)}.menu-price-input-wrapper:focus-within{border-color:var(--color-primary)}.menu-input-prefix{padding:0 6px;font-size:.85rem;color:var(--color-text-secondary);background:var(--color-bg);border-right:1px solid var(--color-border);align-self:stretch;display:flex;align-items:center}.menu-input--price{border:none;width:80px}.menu-textarea{border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:6px 8px;font-size:.82rem;font-family:inherit;color:var(--color-text);background:var(--color-surface);outline:none;width:100%;resize:none}.menu-textarea:focus{border-color:var(--color-primary)}.menu-td--desc{max-width:260px}.menu-desc{font-size:.8rem;color:var(--color-text-secondary)}.menu-toggle{width:40px;height:22px;border-radius:999px;border:none;cursor:pointer;position:relative;transition:background .2s;display:inline-flex;align-items:center}.menu-toggle--on{background:var(--color-primary)}.menu-toggle--off{background:var(--color-border)}.menu-toggle:disabled{opacity:.5;cursor:not-allowed}.menu-toggle__knob{position:absolute;width:16px;height:16px;background:#fff;border-radius:50%;box-shadow:0 1px 3px #0003;transition:left .2s}.menu-toggle--on .menu-toggle__knob{left:20px}.menu-toggle--off .menu-toggle__knob{left:4px}.menu-td--actions{text-align:right;white-space:nowrap}.menu-action-group{display:flex;gap:8px;justify-content:flex-end}.menu-btn{padding:5px 14px;border-radius:var(--radius-sm);font-size:.78rem;font-weight:600;font-family:inherit;cursor:pointer;transition:all .15s;white-space:nowrap}.menu-btn--edit{border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-secondary)}.menu-btn--edit:hover{border-color:var(--color-primary);color:var(--color-primary)}.menu-btn--save{border:1px solid var(--color-primary);background:var(--color-primary);color:#fff}.menu-btn--save:hover{opacity:.85}.menu-btn--save:disabled{opacity:.5;cursor:not-allowed}.menu-btn--cancel{border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-secondary)}.menu-btn--cancel:hover{color:var(--color-text)}@media (max-width: 768px){.menu-page{padding:var(--space-md)}.menu-td--desc{max-width:160px}}:root{--color-primary: #2563eb;--color-primary-hover: #1d4ed8;--color-success: #16a34a;--color-danger: #dc2626;--color-warning: #f59e0b;--color-bg: #f1f5f9;--color-surface: #ffffff;--color-text: #1e293b;--color-text-secondary: #64748b;--color-border: #e2e8f0;--touch-min: 48px;--button-height: 52px;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .07);--sidebar-width: 80px}.loading-screen{display:flex;align-items:center;justify-content:center;height:100vh;background:var(--color-bg)}.spinner{width:36px;height:36px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:100;animation:fade-in .15s ease}.modal-content{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:0 20px 60px #00000026;max-height:85vh;overflow-y:auto;width:90%;max-width:500px;animation:modal-in .2s ease}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes modal-in{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}
