*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html,body{height:100%;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;background:var(--bg);color:var(--text)}img{max-width:100%;display:block}a{text-decoration:none;color:inherit}:root{--primary: #2a7de1;--primary-dark: #1f5fab;--accent: #ffb300;--bg: #f7f7f7;--white: #fff;--text: #222;--text-light: #666;--border: #ddd;--danger: #e53935;--success: #43a047}[data-theme=dark]{--bg: #1e1e1e;--white: #2a2a2a;--text: #eee;--text-light: #aaa;--border: #444}.app-root{display:flex;flex-direction:column;height:100vh}.app-shell{display:flex;flex:1;overflow:hidden}.app-main{flex:1;padding:1rem;overflow-y:auto}.app-header{background:var(--primary);color:var(--white);padding:1rem;display:flex;justify-content:space-between;align-items:center}.logout-btn{background:var(--white);color:var(--primary);border:none;padding:.4rem .8rem;border-radius:6px;cursor:pointer}.app-header .right{display:flex;align-items:center;gap:1rem}@media(max-width:900px){.app-header h1{padding-left:2.5rem}}.bottom-nav{display:flex;justify-content:space-around;background:var(--white);border-top:1px solid var(--border);padding:.6rem 0}.bottom-nav a{color:var(--text-light);font-size:.9rem}.bottom-nav a.active{color:var(--primary)}@media(min-width:900px){.bottom-nav{display:none}}.drawer-toggle{position:fixed;top:1rem;left:1rem;background:var(--primary);color:var(--white);border:none;padding:.6rem .8rem;border-radius:6px;z-index:1000}.side-drawer{position:fixed;top:0;left:-260px;width:260px;height:100%;background:var(--white);border-right:1px solid var(--border);padding:1rem;transition:left .3s ease,width .25s ease;z-index:999;overflow-y:auto}.side-drawer{scrollbar-width:thin;scrollbar-color:rgba(0,0,0,.15) transparent}.side-drawer::-webkit-scrollbar{width:6px}.side-drawer::-webkit-scrollbar-track{background:transparent}.side-drawer::-webkit-scrollbar-thumb{background:#0000001f;border-radius:10px}.side-drawer::-webkit-scrollbar-thumb:hover{background:#00000038}.side-drawer.open{left:0}.close-btn{background:none;border:none;font-size:2rem;float:right;cursor:pointer}@media(min-width:900px){.side-drawer{position:relative;left:0;width:260px;height:100%;flex-shrink:0;overflow-y:auto;display:block;padding:1rem;z-index:1}.drawer-toggle,.side-drawer .close-btn{display:none}}.side-drawer nav a{display:flex;align-items:center;gap:.6rem;padding:.6rem .4rem;color:var(--text-light);transition:transform .15s ease,background .2s,color .2s;position:relative}.side-drawer nav a .icon{font-size:1.4rem;line-height:1}.side-drawer nav a .label{font-size:1rem;white-space:nowrap}.side-drawer nav a:hover{color:var(--primary);background:#0000000f;transform:translate(4px)}.side-drawer nav a.active{color:var(--primary);font-weight:600}.section{margin-bottom:1.2rem}.section-header{display:flex;justify-content:space-between;padding:.6rem 0;font-weight:600;cursor:pointer;color:var(--text);border-bottom:1px solid var(--border)}.section-links{overflow:hidden;max-height:0;transition:max-height .25s ease;display:flex;flex-direction:column;gap:.4rem;padding-left:.4rem}.section-links.open{max-height:500px;padding-top:.4rem}.side-drawer.mini{width:72px!important;padding:.5rem!important}.side-drawer.mini .section-header span:first-child{display:none}.side-drawer.mini nav a{justify-content:center;padding:.6rem 0}.side-drawer.mini nav a .label{display:none}.side-drawer.mini nav a .icon{font-size:1.6rem}.side-drawer.mini nav a .badge{position:absolute;top:4px;right:4px;transform:scale(.9)}.side-drawer.mini nav a[title]:hover:after{content:attr(title);position:absolute;left:78px;top:50%;transform:translateY(-50%) translate(6px);background:#000000bf;color:#fff;padding:.35rem .6rem;border-radius:6px;white-space:nowrap;font-size:.85rem;box-shadow:0 4px 12px #00000059;animation:tooltipSlideFade .22s ease-out;pointer-events:none}@keyframes tooltipSlideFade{0%{opacity:0;transform:translateY(-50%) translate(14px)}to{opacity:1;transform:translateY(-50%) translate(6px)}}.side-drawer.dark{background:#1e1e1e;color:#eee;border-right:1px solid #444}.side-drawer.dark nav a{color:#bbb}.side-drawer.dark nav a.active{color:var(--accent)}.side-drawer.dark .section-header{border-bottom:1px solid #444}.badge{background:var(--danger);color:#fff;padding:0 6px;border-radius:10px;font-size:.75rem;margin-left:6px;animation:badgePop .3s ease-out}@keyframes badgePop{0%{transform:scale(.6);opacity:0}60%{transform:scale(1.2);opacity:1}to{transform:scale(1)}}.sidebar-controls{display:flex;align-items:center;gap:.5rem;padding-bottom:.8rem;border-bottom:1px solid var(--border);margin-bottom:1rem}.sidebar-controls .mini-toggle,.sidebar-controls .dark-toggle{background:var(--primary);color:#fff;border:none;padding:.4rem .6rem;border-radius:6px;cursor:pointer}@media(max-width:900px){.sidebar-controls{display:none}}.page-transition{animation:fadeSlideIn .35s ease-out}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.skeleton{background:linear-gradient(90deg,#eee,#f5f5f5,#eee);background-size:200% 100%;animation:skeletonMove 1.2s infinite;border-radius:6px}@keyframes skeletonMove{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-line{height:14px;margin-bottom:10px}.skeleton-card{height:120px;margin-bottom:1rem}.item-card,.order-card,.delivery-card{background:var(--white);border:1px solid var(--border);border-radius:8px;padding:1rem;margin-bottom:1rem}form input,form select,form textarea{width:100%;padding:.7rem;margin-bottom:1rem;border:1px solid var(--border);border-radius:6px;font-size:1rem}form button{background:var(--primary);color:var(--white);border:none;padding:.7rem 1rem;border-radius:6px;cursor:pointer}form button:hover{background:var(--primary-dark)}.chat-messages{background:var(--white);border:1px solid var(--border);padding:1rem;height:60vh;overflow-y:auto;border-radius:8px}.chat-message{margin-bottom:1rem}.chat-message.mine .bubble{background:var(--primary);color:var(--white);margin-left:auto}.chat-message .bubble{background:#eee;padding:.6rem 1rem;border-radius:12px;max-width:70%}.admin-table{width:100%;border-collapse:collapse;margin-top:1rem}.admin-table th,.admin-table td{border:1px solid var(--border);padding:.6rem}.admin-table th{background:#fafafa}.grid{display:grid;gap:1rem}.list{display:flex;flex-direction:column;gap:1rem}.text-light{color:var(--text-light)}.input,input{width:100%;padding:.55rem .75rem;border-radius:8px;border:1px solid var(--surface-3, #d9d9d9);background:var(--surface-1, #fff);color:var(--text, #222);font-size:.95rem;transition:border-color .2s ease,box-shadow .2s ease,background .2s ease,transform .15s ease}.input:hover,input:hover{border-color:var(--brand, #2a7de1)}.input:focus,input:focus{outline:none;border-color:var(--brand, #2a7de1);box-shadow:0 0 0 3px #2a7de140;background:#fff;transform:translateY(-1px)}.input:disabled,input:disabled{opacity:.6;cursor:not-allowed}.input::placeholder,input::placeholder{color:#999;opacity:.8}button{padding:.55rem 1rem;border-radius:8px;border:none;cursor:pointer;font-size:.95rem;font-weight:600;transition:background .25s ease,box-shadow .25s ease,transform .15s ease;display:inline-flex;align-items:center;justify-content:center}.primary{background:var(--brand, #2a7de1);color:#fff;box-shadow:0 2px 6px #2a7de140}.primary:hover{background:#1f6ac4;box-shadow:0 4px 12px #2a7de159;transform:translateY(-2px)}.primary:active{transform:translateY(0);box-shadow:0 2px 6px #2a7de140}.primary:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.danger{background:#8b0000;color:#fff;box-shadow:0 2px 6px #8b000040}.danger:hover{background:#a30000;box-shadow:0 4px 12px #8b000059;transform:translateY(-2px)}.danger:active{transform:translateY(0);box-shadow:0 2px 6px #8b000040}.danger:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.btn-ghost{background:transparent;color:var(--brand, #2a7de1);border:1px solid rgba(42,125,225,.3)}.btn-ghost:hover{background:#2a7de114;border-color:#2a7de180;transform:translateY(-2px)}.btn-ghost:active{transform:translateY(0)}.dropzone{border:2px dashed var(--border);padding:1rem;text-align:center;cursor:pointer;border-radius:8px}.dropzone input{display:none}.preview-grid{display:flex;gap:1rem;flex-wrap:wrap}.preview-item{position:relative}.preview-item img{width:120px;height:120px;object-fit:cover;border-radius:6px}.preview-item button{position:absolute;top:4px;right:4px;background:red;color:#fff;border:none;border-radius:50%;width:22px;height:22px;cursor:pointer}.truncate-2{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.btn-order-animated{position:relative;overflow:visible;transition:transform .2s ease,box-shadow .2s ease}.btn-order-animated:hover{transform:translateY(-2px);box-shadow:0 6px 16px #2a7de159}.btn-order-animated:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:8px;background:#2a7de159;animation:btn-ping 1.8s infinite;z-index:-1;opacity:0}@keyframes btn-ping{0%{transform:scale(1);opacity:.6}70%{transform:scale(1.25);opacity:0}to{transform:scale(1.25);opacity:0}}.bottom-action-bar{position:relative;width:100%;background:#2a2a2a;color:#fff;border-top:1px solid rgba(255,255,255,.25);padding:.6rem 1rem;display:flex;justify-content:space-between;gap:1rem}.action-box{flex:1;background:#ffffff14;border:1px solid rgba(255,255,255,.25);border-radius:8px;padding:.8rem;text-align:center;font-size:.9rem;font-weight:600;color:#fff;box-shadow:0 2px 6px #00000040;transition:transform .15s ease,box-shadow .2s ease}.action-box:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000059}.bottom-status-bar{position:relative;width:100%;background:#2a2a2a;color:#fff;font-size:.8rem;padding:.3rem 1rem;border-top:1px solid rgba(255,255,255,.25);text-align:center}.global-footer{position:relative;width:100%;background:#2a2a2a;color:#fff;font-size:.8rem;padding:.4rem 1rem;border-top:1px solid rgba(255,255,255,.25);text-align:center}.global-bottom-wrapper{margin-top:2rem}.app-main{padding-bottom:260px;min-height:calc(100vh - 200px)}.modal-close-btn{position:absolute;top:12px;right:12px;font-size:22px;background:transparent;border:none;cursor:pointer;color:var(--text-color, #333);opacity:.7;transition:opacity .2s ease}.modal-close-btn:hover{opacity:1}.select-modern{width:220px;padding:10px 14px;border-radius:8px;border:1px solid #d0d0d0;background:#fff;font-size:14px;font-weight:500;color:#333;cursor:pointer;appearance:none;-webkit-appearance:none;-moz-appearance:none;transition:all .2s ease;background-image:url("data:image/svg+xml;utf8,<svg fill='%23666' height='12' viewBox='0 0 20 20' width='12' xmlns='http://www.w3.org/2000/svg'><polygon points='0,0 20,0 10,12'/></svg>");background-repeat:no-repeat;background-position:right 12px center;background-size:12px}.select-modern:hover{border-color:#999}.select-modern:focus{border-color:#007bff;outline:none}.select-modern:disabled{opacity:.5;cursor:not-allowed}:root{--color-primary: #2a7de1;--color-primary-soft: #e3f0ff;--color-accent: #ffb300;--color-danger: #e53935;--color-success: #43a047;--color-muted: #9e9e9e;--surface-0: #ffffff;--surface-1: #f7f7f7;--surface-2: #eeeeee;--text-strong: #1f2933;--text-default: #323f4b;--text-subtle: #7b8794;--text-inverse: #ffffff;--border-subtle: #e4e7eb;--border-strong: #cbd2d9;--radius-xs: 4px;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-pill: 999px;--shadow-sm: 0 1px 3px rgba(15, 23, 42, .08);--shadow-md: 0 4px 10px rgba(15, 23, 42, .12);--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.5rem;--space-6: 2rem;--font-sans: system-ui, -apple-system, "Segoe UI", sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-md: 1rem;--font-size-lg: 1.25rem;--font-size-xl: 1.5rem;--font-size-2xl: 1.875rem;--line-tight: 1.2;--line-normal: 1.5}.h1{font-size:var(--font-size-2xl);font-weight:700;line-height:var(--line-tight)}.h2{font-size:var(--font-size-xl);font-weight:600;line-height:var(--line-tight)}.h3{font-size:var(--font-size-lg);font-weight:600}.text-sm{font-size:var(--font-size-sm)}.text-xs{font-size:var(--font-size-xs)}.text-muted{color:var(--text-subtle)}.card{background:var(--surface-0);border-radius:var(--radius-md);border:1px solid var(--border-subtle);padding:var(--space-4);box-shadow:var(--shadow-sm)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:.55rem 1rem;border-radius:var(--radius-pill);border:1px solid transparent;font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:background .15s ease,color .15s ease,border-color .15s ease}.btn-primary{background:var(--color-primary);color:var(--text-inverse)}.btn-primary:hover{background:#2366b8}.btn-ghost{background:transparent;color:var(--color-primary)}.btn-ghost:hover{background:var(--color-primary-soft)}.btn-danger{background:var(--color-danger);color:var(--text-inverse)}.btn-outline{background:transparent;color:var(--color-primary);border-color:var(--color-primary)}.btn-sm{padding:.35rem .75rem;font-size:var(--font-size-xs)}.badge{display:inline-flex;align-items:center;padding:.15rem .5rem;border-radius:var(--radius-pill);font-size:var(--font-size-xs);font-weight:500}.badge-primary{background:var(--color-primary-soft);color:var(--color-primary)}.badge-success{background:#e6f4ea;color:var(--color-success)}.badge-danger{background:#fdecea;color:var(--color-danger)}.badge-muted{background:#f1f3f5;color:var(--text-subtle)}.container{max-width:1100px;margin:0 auto;padding:0 var(--space-4)}.stack{display:flex;flex-direction:column;gap:var(--space-3)}.stack-lg{display:flex;flex-direction:column;gap:var(--space-5)}.row{display:flex;gap:var(--space-3);flex-wrap:wrap}.row-center{display:flex;align-items:center;justify-content:center;gap:var(--space-3)}.status-badge{display:inline-flex;align-items:center;padding:.2rem .6rem;border-radius:var(--radius-pill);font-size:var(--font-size-xs);font-weight:600;text-transform:capitalize}.status-approved{background:#e6f4ea;color:var(--color-success)}.status-pending{background:#fff4e5;color:#c47f00}.status-rejected{background:#fdecea;color:var(--color-danger)}.status-needs_delivery{background:var(--color-primary-soft);color:var(--color-primary)}.status-claimed{background:#e3f2fd;color:#1565c0}.status-delivered,.status-completed{background:#e6f4ea;color:var(--color-success)}.status-cancelled{background:#f1f3f5;color:var(--text-subtle)}.section{margin-bottom:1rem}.section-header{display:flex;justify-content:space-between;font-weight:600;cursor:pointer;padding:.5rem 0}.section-links{display:flex;flex-direction:column;gap:.4rem;padding-left:1rem}.chat-room{width:100%;max-width:1100px;margin:0 auto}.chat-layout{display:flex;gap:var(--space-xl);min-height:70vh}.chat-messages{flex:1;overflow-y:auto;padding:var(--space-md);border-radius:var(--radius-md);background:var(--surface-1);border:1px solid var(--border)}.chat-messages::-webkit-scrollbar{width:8px}.chat-messages::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:4px}@media(max-width:768px){.chat-layout{flex-direction:column;gap:var(--space-lg)}.chat-messages{max-height:60vh}}.chat-messages{flex:1;min-height:0;max-height:60vh;display:flex;flex-direction:column;overflow-y:auto;scroll-behavior:smooth;padding:var(--space-md);padding-right:8px;border-radius:var(--radius-md);background:var(--surface-1);border:1px solid var(--border)}.chat-input-row{display:flex;gap:8px;padding:8px;border-top:1px solid var(--border)}.chat-sidebar{width:260px;background:var(--surface-1);border-right:1px solid var(--border);padding:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-md)}.sidebar-title{font-size:1.1rem;font-weight:600}.sidebar-participants{display:flex;flex-direction:column;gap:var(--space-sm)}.sidebar-participant{justify-content:space-between;align-items:center}.sidebar-role{font-size:.8rem;opacity:.7}@media(max-width:768px){.chat-sidebar{display:none}}.chat-layout{display:flex;gap:var(--space-lg)}.chat-left{width:260px;flex-shrink:0;display:flex;flex-direction:column;gap:var(--space-lg)}.chat-main{flex:1;display:flex;flex-direction:column;gap:var(--space-lg)}@media(max-width:768px){.chat-left{display:none}}.chat-header{align-items:center;justify-content:space-between;padding:var(--space-md) 0;border-bottom:1px solid var(--border)}.chat-header-back{font-size:1.4rem;text-decoration:none;color:var(--text);padding-right:var(--space-md)}.chat-header-info{flex:1}.chat-header-title{font-size:1.1rem;font-weight:600}.chat-header-subtitle{font-size:.85rem;opacity:.7}.chat-header-menu{font-size:1.4rem;opacity:.6;cursor:pointer}@media(min-width:768px){.chat-header-back{display:none}}.participants-panel{padding:var(--space-md)}.participants-list{flex-wrap:wrap;gap:8px}.chat-messages{display:flex;flex-direction:column}.message-row{display:flex;flex-direction:column;max-width:75%;margin-bottom:var(--space-md)}.message-row.me{align-self:flex-start;text-align:left}.message-row.them{align-self:flex-end;text-align:right}.message-bubble{padding:10px 14px;border-radius:12px;display:flex;flex-direction:column;gap:4px}.message-bubble.me{background:#e8f2ff;color:#2a7de1}.message-bubble.them{background:var(--surface-2);color:var(--text)}.message-sender{font-size:.85rem;font-weight:600;opacity:.9}.message-text{font-size:.95rem}.message-time{font-size:.75rem;opacity:.6;margin-top:4px}.chat-input{gap:var(--space-sm);padding-top:var(--space-md);border-top:1px solid var(--border)}.chat-empty-state{padding:var(--space-xl);text-align:center;align-items:center;justify-content:center;opacity:.7}.chat-empty-icon{font-size:2.5rem;margin-bottom:var(--space-md)}.chat-empty-title{font-size:1.2rem;font-weight:600}.chat-empty-text{font-size:.9rem}.order-status-badge{padding:4px 10px;border-radius:999px;font-size:.75rem;font-weight:600;display:inline-flex;align-items:center}.order-status-pending{background:#fff7e6;color:#b36b00}.order-status-approved{background:#e6f7ff;color:#0050b3}.order-status-needs_delivery{background:#fff1f0;color:#a8071a}.order-status-claimed{background:#f9f0ff;color:#531dab}.order-status-delivered{background:#f6ffed;color:#237804}.order-status-cancelled{background:#f5f5f5;color:#595959}.btn-danger{background-color:#c43c396e!important;color:#fff;border:none;transition:all .2s ease}.btn-danger:hover{border:1px solid #b36b00!important;background-color:#c43c396e!important;color:#fff}.btn-danger:hover{border:1px solid #b36b00!important;background-color:#c43c39a0!important}.notification-card.unread{background:#f0f5ff;border-left:4px solid #2f54eb}.notification-icon{font-size:1.4rem}.notifications-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}@media(max-width:1200px){.notifications-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:900px){.notifications-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:600px){.notifications-grid{grid-template-columns:repeat(1,1fr)}}.notification-icon.approved{color:#fff;background:#2ecc71;font-weight:900;font-size:.9rem;padding:4px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center}.notification-icon.deleted{color:#e74c3c;font-weight:900;font-size:1.2rem}.manager-dashboard{max-width:1100px}.dashboard-stats{display:flex;gap:var(--space-lg);flex-wrap:wrap}.stat-card{background:var(--surface-1);border:1px solid var(--border);padding:var(--space-lg);border-radius:var(--radius-md);flex:1;min-width:180px;text-align:center}.stat-number{font-size:2rem;font-weight:700}.stat-label{font-size:.9rem;opacity:.7}.dashboard-section{margin-top:var(--space-xl)}.section-card{padding:20px}.dashboard-order-row{justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--border)}.dashboard-order-row:last-child{border-bottom:none}.alert-item{padding:10px;background:#fff7e6;border-left:4px solid #fa8c16;border-radius:var(--radius-sm)}.dashboard-volunteer-row{justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--border)}.dashboard-volunteer-row:last-child{border-bottom:none}.notification-bell{position:relative;display:inline-flex;align-items:center;font-size:1.6rem;text-decoration:none;color:inherit}.bell-icon{position:relative}.notification-badge{position:absolute;top:-6px;right:-10px;background:#e53935;color:#fff;padding:2px 6px;border-radius:12px;font-size:.75rem;font-weight:700;line-height:1}
