:root{--color-brand: #1D9E75;--color-brand-dark: #178a65;--color-brand-soft: #e8f5f0;--font-body: "Roboto", "Segoe UI", sans-serif;--top-bar-h: 56px;--bottom-bar-h: 0px;--header-offset: calc(var(--top-bar-h) + var(--safe-top));--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--safe-left: env(safe-area-inset-left, 0px);--safe-right: env(safe-area-inset-right, 0px);--tap-min: 44px;--rail-w: 44px;--rail-gap: 8px}@media (max-width: 1023px){:root{--bottom-bar-h: 64px}}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0;font-family:var(--font-body)}button{-webkit-tap-highlight-color:transparent;touch-action:manipulation}input,select,textarea{font-size:16px}@media (min-width: 768px){input,select,textarea{font-size:.95rem}}input[type=date],input[type=time]{-webkit-appearance:none;appearance:none}.drawer-root[data-v-4dce5743]{position:relative;z-index:2000}.drawer-backdrop[data-v-4dce5743]{position:fixed;top:0;left:0;width:100vw;height:100dvh;background:#00000080}.drawer-content[data-v-4dce5743]{position:fixed;top:0;left:0;width:min(280px,85vw);height:100dvh;background:#fff;display:flex;flex-direction:column;box-shadow:2px 0 8px #0000001a}.drawer-header[data-v-4dce5743]{height:var(--top-bar-h);padding:0 1.5rem;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #eee;padding-top:var(--safe-top)}.drawer-logo[data-v-4dce5743]{font-weight:700;font-size:1.25rem;color:var(--color-brand)}.close-btn[data-v-4dce5743]{background:none;border:none;font-size:1.5rem;color:#777;cursor:pointer;padding:.5rem}.drawer-nav[data-v-4dce5743]{flex:1;padding:1rem 0;overflow-y:auto}.nav-item[data-v-4dce5743]{display:flex;align-items:center;padding:.8rem 1.5rem;text-decoration:none;color:#444;font-size:1rem;gap:12px;position:relative}.nav-item.router-link-active[data-v-4dce5743]{color:var(--color-brand);background:var(--color-brand-soft);font-weight:500}.nav-icon[data-v-4dce5743]{font-size:1.2rem;width:24px;text-align:center}.notif-badge[data-v-4dce5743]{margin-left:auto;background:#c0392b;color:#fff;font-size:.7rem;font-weight:700;min-width:18px;height:18px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;padding:0 5px}.drawer-footer[data-v-4dce5743]{padding:1.5rem;border-top:1px solid #eee;padding-bottom:calc(1.5rem + var(--safe-bottom))}.user-info[data-v-4dce5743]{display:flex;align-items:center;gap:12px;margin-bottom:1rem}.user-avatar[data-v-4dce5743]{width:36px;height:36px;background:var(--color-brand);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.1rem}.user-name[data-v-4dce5743]{font-size:.95rem;font-weight:500;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.logout-btn[data-v-4dce5743]{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:8px;background:#fff;color:#c0392b;font-weight:600;cursor:pointer}.fade-enter-active[data-v-4dce5743],.fade-leave-active[data-v-4dce5743]{transition:opacity .25s ease}.fade-enter-from[data-v-4dce5743],.fade-leave-to[data-v-4dce5743]{opacity:0}.drawer-enter-active[data-v-4dce5743],.drawer-leave-active[data-v-4dce5743]{transition:transform .25s ease}.drawer-enter-from[data-v-4dce5743],.drawer-leave-to[data-v-4dce5743]{transform:translate(-100%)}.notif-backdrop[data-v-1febfa77]{position:fixed;inset:0;z-index:500}.notif-panel--bottom[data-v-1febfa77]{position:fixed;top:var(--header-offset);right:1rem;width:min(380px,calc(100vw - 2rem))}.notif-panel--top[data-v-1febfa77]{position:fixed;bottom:calc(var(--bottom-bar-h) + var(--safe-bottom));left:0;right:0;width:100%;max-width:100%}.notif-panel[data-v-1febfa77]{background:#fff;border-radius:12px;box-shadow:0 8px 32px #0000002e;overflow:hidden;display:flex;flex-direction:column;max-height:calc(100dvh - var(--header-offset) - 1rem)}.notif-panel--top[data-v-1febfa77]{border-radius:16px 16px 0 0;max-height:70dvh}.notif-panel__header[data-v-1febfa77]{display:flex;align-items:center;justify-content:space-between;padding:.85rem 1rem .85rem 1.1rem;border-bottom:1px solid #f0f0f0;flex-shrink:0;gap:.5rem}.notif-panel__title[data-v-1febfa77]{font-weight:700;font-size:.95rem;color:#222}.notif-panel__header-actions[data-v-1febfa77]{display:flex;align-items:center;gap:.75rem}.notif-panel__mark-all[data-v-1febfa77]{font-size:.775rem;color:var(--color-brand);background:none;border:none;cursor:pointer;padding:0;white-space:nowrap}.notif-panel__mark-all[data-v-1febfa77]:disabled{opacity:.5;cursor:not-allowed}.notif-panel__close[data-v-1febfa77]{background:none;border:none;cursor:pointer;font-size:.85rem;color:#999;line-height:1;padding:.25rem;border-radius:4px;min-width:var(--tap-min);min-height:var(--tap-min);display:flex;align-items:center;justify-content:center}.notif-panel__close[data-v-1febfa77]:hover{color:#333}.notif-panel__body[data-v-1febfa77]{overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}.notif-panel__state[data-v-1febfa77]{padding:2rem 1rem;text-align:center;color:#888;font-size:.875rem}.notif-panel__state--error[data-v-1febfa77]{color:#c0392b}.notif-panel__list[data-v-1febfa77]{list-style:none;margin:0;padding:.5rem;display:flex;flex-direction:column;gap:.35rem}.notif-panel__item[data-v-1febfa77]{display:flex;justify-content:space-between;align-items:flex-start;padding:.75rem .875rem;border-radius:8px;border:1px solid #efefef;gap:.75rem}.notif-panel__item--unread[data-v-1febfa77]{border-left:3px solid var(--color-brand);background:#f8fffe}.notif-panel__item-content[data-v-1febfa77]{flex:1;min-width:0}.notif-panel__item-title[data-v-1febfa77]{margin:0 0 .2rem;font-weight:600;font-size:.85rem}.notif-panel__item-message[data-v-1febfa77]{margin:0 0 .25rem;color:#555;font-size:.8rem;word-break:break-word}.notif-panel__item-date[data-v-1febfa77]{margin:0;color:#aaa;font-size:.72rem}.notif-panel__mark-read[data-v-1febfa77]{font-size:.725rem;color:var(--color-brand);background:none;border:none;cursor:pointer;white-space:nowrap;padding:0;flex-shrink:0;align-self:center}.app-header[data-v-52276bbc]{height:var(--header-offset);background:#fff;border-bottom:1px solid #e5e5e5;position:fixed;top:0;left:0;right:0;z-index:100;padding-top:var(--safe-top)}.header-content[data-v-52276bbc]{display:flex;align-items:center;justify-content:space-between;height:100%;padding:0 1.5rem;max-width:1440px;margin:0 auto}.hamburger-btn[data-v-52276bbc]{display:none;background:none;border:none;font-size:1.5rem;color:#333;cursor:pointer;padding:.5rem;margin-left:-.5rem}.header-logo[data-v-52276bbc]{font-weight:700;font-size:1.25rem;color:var(--color-brand);text-decoration:none}.header-nav[data-v-52276bbc]{display:flex;gap:1.5rem}.header-nav a[data-v-52276bbc]{text-decoration:none;color:#555;font-size:.9rem;font-weight:500}.header-nav a.router-link-active[data-v-52276bbc]{color:var(--color-brand)}.header-right[data-v-52276bbc]{display:flex;align-items:center}.user-info-desktop[data-v-52276bbc]{display:flex;align-items:center;gap:1rem}.header-user[data-v-52276bbc]{font-size:.85rem;color:#666;text-decoration:none;max-width:140px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header-user[data-v-52276bbc]:hover{color:var(--color-brand)}.header-logout[data-v-52276bbc]{padding:.4rem .8rem;border:1px solid #ddd;border-radius:6px;background:none;cursor:pointer;font-size:.85rem;color:#555}.mobile-actions[data-v-52276bbc]{display:none;align-items:center;gap:1rem}.mobile-notif[data-v-52276bbc]{position:relative;background:none;border:none;cursor:pointer;font-size:1.25rem;padding:0;display:flex;align-items:center;justify-content:center;min-width:var(--tap-min);min-height:var(--tap-min)}.mobile-avatar[data-v-52276bbc]{width:32px;height:32px;background:var(--color-brand);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem;text-decoration:none}.admin-link[data-v-52276bbc]{color:var(--color-brand)!important;font-weight:600!important}.desktop-notif[data-v-52276bbc]{position:relative;background:none;border:none;cursor:pointer;font-size:1.25rem;padding:0;display:flex;align-items:center;justify-content:center}.notif-badge[data-v-52276bbc]{position:absolute;top:-6px;right:-10px;background:#c0392b;color:#fff;font-size:.65rem;font-weight:700;min-width:16px;height:16px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;padding:0 4px;line-height:1}@media (max-width: 1023px){.header-nav[data-v-52276bbc]{display:none}.hamburger-btn[data-v-52276bbc]{display:block}}@media (max-width: 480px){.hamburger-btn[data-v-52276bbc],.user-info-desktop[data-v-52276bbc]{display:none}.mobile-actions[data-v-52276bbc]{display:flex}.header-content[data-v-52276bbc]{padding:0 1rem}}.bottom-tab-bar[data-v-18b7327f]{position:fixed;bottom:0;left:0;right:0;height:calc(var(--bottom-bar-h) + var(--safe-bottom));background:#fff;border-top:1px solid #e5e5e5;display:flex;justify-content:space-around;align-items:center;padding-bottom:var(--safe-bottom);z-index:300}@media (min-width: 1024px){.bottom-tab-bar[data-v-18b7327f]{display:none}}.tab-item[data-v-18b7327f]{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;height:var(--bottom-bar-h);min-height:var(--tap-min);text-decoration:none;color:#777;gap:2px;-webkit-tap-highlight-color:transparent}.tab-item.active[data-v-18b7327f]{color:var(--color-brand)}.tab-icon[data-v-18b7327f]{font-size:1.25rem}.tab-label[data-v-18b7327f]{font-size:.7rem;font-weight:500}.app-main[data-v-d3446a60]{min-height:100vh;min-height:100dvh;padding-top:var(--header-offset);padding-bottom:0}@media (max-width: 1023px){.app-main[data-v-d3446a60]{padding-bottom:calc(var(--bottom-bar-h) + var(--safe-bottom))}}
