.header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) var(--space-md);background:var(--mhs-red);color:var(--mhs-white);min-height:56px;position:sticky;top:0;z-index:100}.header__left{display:flex;align-items:center}.header__brand{display:flex;align-items:center;gap:var(--space-sm);color:var(--mhs-white);text-decoration:none}.header__title{font-family:var(--font-heading);font-size:1.125rem;font-weight:700}.header__right{display:flex;align-items:center;gap:var(--space-md);font-size:.875rem}.header__link{color:var(--mhs-white);opacity:.9;font-weight:600;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);transition:opacity .15s}.header__link:hover{opacity:1}.header__user{opacity:.8;display:none}@media (min-width: 480px){.header__user{display:inline}}.header__logout{background:#ffffff26;color:var(--mhs-white);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:.8rem;font-weight:600;transition:background .15s}.header__logout:hover{background:#ffffff40}.login-page{display:flex;justify-content:center;align-items:center;min-height:100dvh;padding:var(--space-md)}.login-card{width:100%;max-width:400px;background:var(--mhs-white);border-radius:var(--radius-lg);padding:var(--space-xl);box-shadow:0 2px 12px #00000014;text-align:center}.login-title{font-size:1.5rem;color:var(--mhs-blue);margin-bottom:var(--space-xs)}.login-subtitle{color:var(--mhs-grey);margin-bottom:var(--space-xl);font-size:.875rem}.btn-sso{display:block;width:100%;padding:.875rem;background:var(--mhs-red);color:var(--mhs-white);border-radius:var(--radius-md);font-weight:600;font-size:1rem;text-align:center;transition:background .15s}.btn-sso:hover{background:var(--mhs-red-dark)}.login-divider{display:flex;align-items:center;gap:var(--space-md);margin:var(--space-lg) 0;color:var(--mhs-grey);font-size:.875rem}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--mhs-grey-light)}.login-form{text-align:left}.login-form label{display:block;font-size:.875rem;font-weight:600;margin-bottom:var(--space-xs);color:#333}.login-form input{display:block;width:100%;padding:.75rem;border:1px solid var(--mhs-grey-light);border-radius:var(--radius-md);margin-bottom:var(--space-md);transition:border-color .15s}.login-form input:focus{outline:none;border-color:var(--mhs-blue);box-shadow:0 0 0 3px #23346a1a}.login-error{background:var(--color-error-bg);color:var(--color-error);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);margin-bottom:var(--space-md);font-size:.875rem}.btn-login{width:100%;padding:.75rem;background:var(--mhs-grey);color:var(--mhs-white);border-radius:var(--radius-md);font-weight:600;transition:background .15s}.btn-login:hover:not(:disabled){background:#8a8c8f}.btn-login:disabled{opacity:.6}.tablet-display{display:flex;flex-direction:column;height:100dvh;background:var(--mhs-bg);user-select:none;-webkit-user-select:none}.tablet-display--error{justify-content:center;align-items:center;font-size:1.25rem;color:var(--color-error)}.tablet-display__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) var(--space-md);background:var(--mhs-blue);color:var(--mhs-white);min-height:56px;flex-shrink:0}.tablet-display__title{font-size:1.25rem;font-family:var(--font-heading)}.tablet-display__status{font-size:.75rem;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-weight:600}.tablet-display__status--connected{background:#2e7d3233;color:#a5d6a7}.tablet-display__status--disconnected{background:#e13a3e33;color:#ef9a9a}.tablet-display__queue{flex:1;overflow-y:auto;padding:var(--space-md);display:flex;flex-direction:column;gap:var(--space-md);-ms-overflow-style:none;scrollbar-width:none}.tablet-display__queue::-webkit-scrollbar{display:none}.tablet-display__empty{display:flex;flex-direction:column;justify-content:center;align-items:center;flex:1;gap:var(--space-lg)}.tablet-display__empty-logo{width:160px;height:auto;opacity:.4}.tablet-display__empty-name{font-family:var(--font-heading);font-size:1.25rem;color:var(--mhs-grey);font-weight:600;text-transform:uppercase;letter-spacing:.05em}.scan-card{display:flex;align-items:center;gap:var(--space-md);background:var(--mhs-white);border-radius:var(--radius-lg);padding:var(--space-md);box-shadow:0 2px 8px #0000000f;transition:opacity .5s ease,transform .3s ease}.scan-card--collected{opacity:.4}.scan-card__photo-wrapper{flex-shrink:0}.scan-card__photo{width:120px;height:120px;border-radius:var(--radius-full);object-fit:cover;border:3px solid var(--mhs-blue)}.scan-card__photo-placeholder{width:120px;height:120px;border-radius:var(--radius-full);background:var(--mhs-grey-light);border:3px solid var(--mhs-grey)}@media (min-width: 768px){.scan-card__photo,.scan-card__photo-placeholder{width:160px;height:160px}}.scan-card__info{flex:1;min-width:0}.scan-card__name{font-size:1.25rem;font-weight:700;color:var(--mhs-blue);font-family:var(--font-heading)}.scan-card__meal-option{font-size:1.25rem;font-weight:700;color:var(--mhs-red);font-family:var(--font-body);line-height:1.2}.scan-card__laundry-number{font-size:1.1rem;font-weight:700;color:var(--mhs-red);margin-bottom:var(--space-xs)}.scan-card__details{font-size:.875rem;color:var(--mhs-grey);margin-bottom:var(--space-xs)}.scan-card__meta{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-xs)}.scan-card__badge{display:inline-block;padding:2px 8px;border-radius:var(--radius-sm);font-size:.75rem;font-weight:700;text-transform:uppercase}.scan-card__badge--student{background:var(--color-success-bg);color:var(--color-success)}.scan-card__badge--prefect{background:var(--color-warning-bg);color:var(--color-warning)}.scan-card__time{font-size:.75rem;color:var(--mhs-grey)}.scan-card__prefect{font-size:.875rem;color:var(--mhs-blue);font-weight:600;padding:var(--space-xs) var(--space-sm);background:#23346a0d;border-radius:var(--radius-sm);margin-top:var(--space-xs)}.scan-card__actions{flex-shrink:0;display:flex;gap:var(--space-sm)}.scan-card__collect-btn{padding:var(--space-sm) var(--space-lg);background:var(--mhs-red);color:var(--mhs-white);border-radius:var(--radius-md);font-weight:700;font-size:1rem;min-height:48px;min-width:140px;transition:background .15s;white-space:nowrap}.scan-card__collect-btn:hover{background:var(--mhs-red-dark)}.scan-card__cancel-btn{padding:var(--space-sm) var(--space-lg);background:var(--mhs-grey-light);color:var(--mhs-grey);border-radius:var(--radius-md);font-weight:700;font-size:1rem;min-height:48px;min-width:100px;transition:background .15s;white-space:nowrap}.scan-card__cancel-btn:hover{background:var(--mhs-grey);color:var(--mhs-white)}.scan-card__cancel-btn:active,.scan-card__collect-btn:active{transform:scale(.97)}.scan-card__collected-badge{padding:var(--space-sm) var(--space-lg);background:var(--color-success-bg);color:var(--color-success);border-radius:var(--radius-md);font-weight:700;font-size:1rem;text-align:center;min-width:140px}.dashboard{max-width:800px;margin:0 auto;padding:var(--space-xl)}.dashboard__title{font-size:1.5rem;color:var(--mhs-blue);margin-bottom:var(--space-xl)}.dashboard__stats{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-md);margin-bottom:var(--space-xl)}@media (max-width: 600px){.dashboard__stats{grid-template-columns:repeat(2,1fr)}}.dashboard__stat{background:var(--mhs-white);border-radius:var(--radius-lg);padding:var(--space-lg);text-align:center;box-shadow:0 2px 8px #0000000f}.dashboard__stat-value{display:block;font-size:2rem;font-weight:700;color:var(--mhs-blue);font-family:var(--font-heading)}.dashboard__stat-label{font-size:.875rem;color:var(--mhs-grey)}.dashboard__stat--clickable{cursor:pointer;transition:background .15s,transform .1s}.dashboard__stat--clickable:hover{background:var(--mhs-grey-light);transform:translateY(-2px)}.dashboard__apps{background:var(--mhs-white);border-radius:var(--radius-lg);padding:var(--space-lg);margin-bottom:var(--space-xl);box-shadow:0 2px 8px #0000000f}.dashboard__apps h2{font-size:1.125rem;color:var(--mhs-blue);margin-bottom:var(--space-md)}.dashboard__apps-list{display:flex;flex-direction:column;gap:var(--space-sm)}.dashboard__app-card{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md);border-left:4px solid var(--color-success);border-radius:var(--radius-md);background:var(--mhs-bg);cursor:pointer;transition:background .15s,transform .1s}.dashboard__app-card:hover{background:var(--mhs-grey-light);transform:translate(2px)}.dashboard__app-info{flex:1;min-width:0}.dashboard__app-name{font-size:1rem;font-weight:700;color:var(--mhs-blue);font-family:var(--font-heading)}.dashboard__app-desc{font-size:.875rem;color:var(--mhs-grey);margin-top:var(--space-xs)}.dashboard__app-meta{font-size:.75rem;color:var(--mhs-grey);margin-top:var(--space-xs)}.dashboard__app-arrow{font-size:1.25rem;color:var(--mhs-grey);margin-left:var(--space-md);flex-shrink:0}.dashboard__quick-links{background:var(--mhs-white);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:0 2px 8px #0000000f}.dashboard__quick-links h2{font-size:1.125rem;color:var(--mhs-blue);margin-bottom:var(--space-md)}.dashboard__links-row{display:flex;gap:var(--space-md)}.dashboard__link{display:inline-block;color:var(--mhs-blue);font-weight:600;font-size:.875rem}.dashboard__link:hover{text-decoration:underline}.dashboard__empty{color:var(--mhs-grey);text-align:center;padding:var(--space-xl)}.dashboard__status{display:inline-block;padding:2px 8px;border-radius:var(--radius-sm);font-size:.75rem;font-weight:700;text-transform:uppercase}.dashboard__status--pending{background:var(--color-warning-bg);color:var(--color-warning)}.dashboard__status--completed,.dashboard__status--collected{background:var(--color-success-bg);color:var(--color-success)}.toast{position:fixed;top:72px;left:50%;transform:translate(-50%);z-index:200;padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-md);font-weight:600;font-size:.875rem;max-width:90vw;text-align:center;transition:opacity .3s,transform .3s}.toast--success{background:var(--color-success-bg);color:var(--color-success)}.toast--error{background:var(--color-error-bg);color:var(--color-error)}.toast--warning{background:var(--color-warning-bg);color:var(--color-warning)}.toast--show{opacity:1;transform:translate(-50%) translateY(0)}.toast--hide{opacity:0;transform:translate(-50%) translateY(-10px)}.app-detail{max-width:1000px;margin:0 auto;padding:var(--space-xl)}.app-detail__back{display:inline-flex;align-items:center;gap:var(--space-xs);color:var(--mhs-blue);font-size:.875rem;font-weight:600;margin-bottom:var(--space-lg)}.app-detail__back:hover{text-decoration:underline}.app-detail__header-card{background:var(--mhs-white);border-radius:var(--radius-lg);padding:var(--space-lg);margin-bottom:var(--space-xl);box-shadow:0 2px 8px #0000000f;display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-md)}.app-detail__header-info h1{font-size:1.5rem;color:var(--mhs-blue);margin-bottom:var(--space-xs)}.app-detail__header-info p{font-size:.875rem;color:var(--mhs-grey)}.app-detail__status-toggle{display:flex;align-items:center;gap:var(--space-sm)}.app-detail__status-badge{display:inline-block;padding:2px 8px;border-radius:var(--radius-sm);font-size:.75rem;font-weight:700;text-transform:uppercase}.app-detail__status-badge--active{background:var(--color-success-bg);color:var(--color-success)}.app-detail__status-badge--inactive{background:var(--color-error-bg);color:var(--color-error)}.app-detail__section{background:var(--mhs-white);border-radius:var(--radius-lg);padding:var(--space-lg);margin-bottom:var(--space-xl);box-shadow:0 2px 8px #0000000f}.app-detail__section h2{font-size:1.125rem;color:var(--mhs-blue);margin-bottom:var(--space-md)}.app-detail__settings-form{display:flex;flex-direction:column;gap:var(--space-md);max-width:400px}.app-detail__settings-form label{display:block;font-size:.875rem;font-weight:600;margin-bottom:var(--space-xs);color:#333}.app-detail__settings-form input{display:block;width:100%;padding:.5rem .75rem;border:1px solid var(--mhs-grey-light);border-radius:var(--radius-md)}.app-detail__settings-form input:focus{outline:none;border-color:var(--mhs-blue);box-shadow:0 0 0 3px #23346a1a}.app-detail__section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-md)}.app-detail__section-header h2{margin-bottom:0}.app-detail__table{width:100%;border-collapse:collapse}.app-detail__table th,.app-detail__table td{padding:var(--space-sm) var(--space-md);text-align:left;border-bottom:1px solid var(--mhs-grey-light);font-size:.8rem}.app-detail__table th{background:var(--mhs-bg);font-weight:600;color:#555}.app-detail__token{font-size:.7rem;background:var(--mhs-bg);padding:2px 6px;border-radius:var(--radius-sm);word-break:break-all}.app-detail__actions{display:flex;gap:var(--space-xs);flex-wrap:wrap}.app-detail__row--inactive{opacity:.5}.app-detail__links{display:flex;gap:var(--space-md);margin-top:var(--space-md)}.app-detail__link{color:var(--mhs-blue);font-weight:600;font-size:.875rem}.app-detail__link:hover{text-decoration:underline}.app-detail__empty{text-align:center;color:var(--mhs-grey);padding:var(--space-xl)}.app-detail__loading{text-align:center;color:var(--mhs-grey);padding:var(--space-xl) 0}.app-detail__reader-form{background:var(--mhs-bg);border-radius:var(--radius-md);padding:var(--space-lg);margin-bottom:var(--space-lg)}.app-detail__reader-form h3{font-size:1rem;color:var(--mhs-blue);margin-bottom:var(--space-md)}.app-detail__reader-form label{display:block;font-size:.875rem;font-weight:600;margin-bottom:var(--space-xs);color:#333}.app-detail__reader-form input{display:block;width:100%;padding:.5rem .75rem;border:1px solid var(--mhs-grey-light);border-radius:var(--radius-md);margin-bottom:var(--space-md)}.app-detail__reader-form input:focus{outline:none;border-color:var(--mhs-blue);box-shadow:0 0 0 3px #23346a1a}.app-detail__reader-form input:disabled{background:var(--mhs-bg);color:var(--mhs-grey)}.app-detail__form-actions{display:flex;gap:var(--space-sm)}.device-mappings{max-width:1000px;margin:0 auto;padding:var(--space-xl)}.device-mappings__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-xl)}.device-mappings__header h1{font-size:1.5rem;color:var(--mhs-blue)}.device-mappings__filter-bar{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-lg)}.device-mappings__filter-bar label{font-size:.875rem;font-weight:600;color:#333}.device-mappings__filter-bar select{padding:.5rem .75rem;border:1px solid var(--mhs-grey-light);border-radius:var(--radius-md);color:#333;background-color:#fff;-webkit-appearance:menulist;-moz-appearance:menulist;appearance:menulist}.device-mappings__filter-bar select option{color:#333;background-color:#fff}.device-mappings__filter-bar select:focus{outline:none;border-color:var(--mhs-blue);box-shadow:0 0 0 3px #23346a1a}.device-mappings__form select{display:block;width:100%;padding:.5rem .75rem;border:1px solid var(--mhs-grey-light);border-radius:var(--radius-md);margin-bottom:var(--space-md);color:#333;background-color:#fff;-webkit-appearance:menulist;-moz-appearance:menulist;appearance:menulist}.device-mappings__form select option{color:#333;background-color:#fff}.device-mappings__form select:focus{outline:none;border-color:var(--mhs-blue);box-shadow:0 0 0 3px #23346a1a}.device-mappings__form{background:var(--mhs-white);border-radius:var(--radius-lg);padding:var(--space-lg);margin-bottom:var(--space-xl);box-shadow:0 2px 8px #0000000f}.device-mappings__form h2{font-size:1.125rem;color:var(--mhs-blue);margin-bottom:var(--space-md)}.device-mappings__form label{display:block;font-size:.875rem;font-weight:600;margin-bottom:var(--space-xs);color:#333}.device-mappings__form input{display:block;width:100%;padding:.5rem .75rem;border:1px solid var(--mhs-grey-light);border-radius:var(--radius-md);margin-bottom:var(--space-md)}.device-mappings__form input:focus{outline:none;border-color:var(--mhs-blue);box-shadow:0 0 0 3px #23346a1a}.device-mappings__form input:disabled{background:var(--mhs-bg);color:var(--mhs-grey)}.device-mappings__form-actions{display:flex;gap:var(--space-sm)}.device-mappings__table{width:100%;background:var(--mhs-white);border-radius:var(--radius-lg);overflow:hidden;box-shadow:0 2px 8px #0000000f;border-collapse:collapse}.device-mappings__table th,.device-mappings__table td{padding:var(--space-sm) var(--space-md);text-align:left;border-bottom:1px solid var(--mhs-grey-light);font-size:.875rem}.device-mappings__table th{background:var(--mhs-bg);font-weight:600;color:#555}.device-mappings__row--inactive{opacity:.5}.device-mappings__token{font-size:.7rem;background:var(--mhs-bg);padding:2px 6px;border-radius:var(--radius-sm);word-break:break-all}.device-mappings__actions{display:flex;gap:var(--space-xs);flex-wrap:wrap}.btn-primary{padding:var(--space-sm) var(--space-md);background:var(--mhs-blue);color:var(--mhs-white);border-radius:var(--radius-md);font-weight:600;font-size:.875rem;transition:background .15s}.btn-primary:hover{background:var(--mhs-blue-dark)}.btn-secondary{padding:var(--space-sm) var(--space-md);background:var(--mhs-grey-light);color:#333;border-radius:var(--radius-md);font-weight:600;font-size:.875rem}.btn-small{padding:var(--space-xs) var(--space-sm);background:var(--mhs-bg);color:var(--mhs-blue);border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;transition:background .15s}.btn-small:hover{background:var(--mhs-grey-light)}.btn-small--danger{color:var(--color-error)}.btn-small--danger:hover{background:var(--color-error-bg)}.reporting{max-width:1200px;margin:0 auto;padding:var(--space-xl)}.reporting__title{font-size:1.5rem;color:var(--mhs-blue);margin-bottom:var(--space-xl)}.reporting__filters{display:flex;gap:var(--space-md);align-items:flex-end;margin-bottom:var(--space-lg);flex-wrap:wrap;justify-content:space-between}.reporting__filter{display:flex;flex-direction:column}.reporting__filter label{font-size:.875rem;font-weight:600;margin-bottom:var(--space-xs);color:#333}.reporting__filter input,.reporting__filter select{padding:.5rem .75rem;border:1px solid var(--mhs-grey-light);border-radius:var(--radius-md);min-width:140px}.reporting__filter input:focus,.reporting__filter select:focus{outline:none;border-color:var(--mhs-blue);box-shadow:0 0 0 3px #23346a1a}.reporting__filter-actions{display:flex;gap:var(--space-sm);align-items:flex-end;padding-bottom:1px}.reporting__total{font-size:.875rem;color:var(--mhs-grey);margin-bottom:var(--space-sm)}.reporting__table-wrapper{overflow-x:auto}.reporting__table{width:100%;background:var(--mhs-white);border-radius:var(--radius-lg);overflow:hidden;box-shadow:0 2px 8px #0000000f;border-collapse:collapse}.reporting__table th,.reporting__table td{padding:var(--space-sm) var(--space-md);text-align:left;border-bottom:1px solid var(--mhs-grey-light);font-size:.8rem;white-space:nowrap}.reporting__table th{background:var(--mhs-bg);font-weight:600;color:#555}.reporting__table tr.reporting__row--expandable{cursor:pointer}.reporting__table tr.reporting__row--expandable:hover{background:var(--mhs-bg)}.reporting__badge{display:inline-block;padding:2px 6px;border-radius:var(--radius-sm);font-size:.7rem;font-weight:700;text-transform:uppercase}.reporting__badge--student{background:var(--color-success-bg);color:var(--color-success)}.reporting__badge--prefect{background:var(--color-warning-bg);color:var(--color-warning)}.reporting__status{display:inline-block;padding:2px 6px;border-radius:var(--radius-sm);font-size:.7rem;font-weight:700;text-transform:uppercase}.reporting__status--pending{background:var(--color-warning-bg);color:var(--color-warning)}.reporting__status--completed{background:var(--color-success-bg);color:var(--color-success)}.reporting__metadata{background:var(--mhs-bg);font-size:.75rem;color:#555}.reporting__metadata td{padding:var(--space-sm) var(--space-md) var(--space-sm) calc(var(--space-md) * 2);white-space:normal}.reporting__empty{text-align:center;color:var(--mhs-grey);padding:var(--space-xl)!important}.reporting__pagination{display:flex;justify-content:center;align-items:center;gap:var(--space-md);margin-top:var(--space-lg);font-size:.875rem}:root{--mhs-red: #e13a3e;--mhs-red-dark: #c4292d;--mhs-blue: #23346a;--mhs-blue-dark: #1a2750;--mhs-white: #ffffff;--mhs-grey: #a7a9ac;--mhs-grey-light: #d1d3d4;--mhs-bg: #f4f5f7;--color-success: #2e7d32;--color-success-bg: #e8f5e9;--color-warning: #f57c00;--color-warning-bg: #fff3e0;--color-error: #e13a3e;--color-error-bg: #fce4ec;--font-heading: "Orpheus Pro", Georgia, "Times New Roman", serif;--font-body: "Franklin Gothic Medium", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-full: 50%}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:var(--font-body);background:var(--mhs-bg);color:#1a1a1a;line-height:1.5;min-height:100dvh}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:700;line-height:1.2}a{color:var(--mhs-blue);text-decoration:none}button{font-family:var(--font-body);cursor:pointer;border:none;font-size:1rem}input,select,textarea{font-family:var(--font-body);font-size:1rem}
