*{box-sizing:border-box}body{color:#172033;background:linear-gradient(135deg,#eef4ff,#fff7ed);margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}button,input{font:inherit}.login-screen{place-items:center;min-height:100vh;padding:24px;display:grid}.login-card{text-align:center;background:#fff;border-radius:30px;width:min(420px,100%);padding:34px;box-shadow:0 30px 80px #4150782e}.login-icon{background:#eef2ff;border-radius:24px;place-items:center;width:76px;height:76px;margin:0 auto 16px;font-size:38px;display:grid}.login-card h1{margin:0 0 10px}.login-card p{color:#657085}.login-card form{gap:12px;margin-top:20px;display:grid}.login-card input{border:1px solid #d9e0ea;border-radius:16px;outline:none;padding:15px 16px}.login-card button{color:#fff;background:#2563eb;border:0;border-radius:16px;padding:15px 16px;font-weight:800}.error{color:#dc2626;font-weight:700}.app-shell{width:min(1180px,100%);margin:0 auto;padding:20px 18px 96px}.header-card{background:#fff;border-radius:30px;justify-content:space-between;align-items:center;gap:18px;padding:22px;display:flex;box-shadow:0 20px 60px #4858801f}.brand{align-items:center;gap:16px;display:flex}.brand-icon{background:linear-gradient(135deg,#dbeafe,#ede9fe);border-radius:22px;place-items:center;width:62px;height:62px;font-size:32px;display:grid}.brand h1{margin:0;font-size:clamp(1.4rem,3vw,2.25rem)}.brand p{color:#64748b;margin:4px 0 0}.header-actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:12px;display:flex}.greeting{color:#334155;font-weight:800}.manager-btn,.bell,.add-project,.details-btn,.join-btn,.complete-btn,.logout-btn{cursor:pointer;border:0}.logout-btn{color:#b91c1c;background:#f8fafc;border-radius:999px;align-items:center;gap:8px;padding:12px 15px;font-weight:800;display:flex;box-shadow:inset 0 0 0 1px #e2e8f0}.logout-btn:hover{background:#fef2f2;box-shadow:inset 0 0 0 1px #fecaca}.manager-btn{color:#fff;background:#111827;border-radius:999px;align-items:center;gap:8px;padding:12px 15px;font-weight:800;display:flex}.manager-btn.active{background:#2563eb;box-shadow:0 0 0 3px #2563eb40}.bell{color:#334155;background:#f8fafc;border-radius:50%;width:44px;height:44px;position:relative}.bell-badge{color:#fff;background:#ef4444;border:2px solid #fff;border-radius:999px;place-items:center;min-width:20px;height:20px;padding:0 5px;font-size:.72rem;font-weight:900;display:grid;position:absolute;top:-3px;right:-3px}.quick-grid{grid-template-columns:repeat(4,1fr);gap:16px;margin-top:18px;display:grid}.access-card{background:#fff;border-radius:28px;min-height:160px;padding:20px;position:relative;box-shadow:0 20px 50px #4858801a}.access-card svg:first-child{color:#fff;border-radius:15px;width:42px;height:42px;padding:9px}.access-card h2{margin:18px 0 4px;font-size:1.15rem}.access-card p{color:#64748b;margin:0}.access-card svg:last-child{position:absolute;bottom:18px;right:18px}.purple svg:first-child{background:#8b5cf6}.blue svg:first-child{background:#3b82f6}.green svg:first-child{background:#22c55e}.orange svg:first-child{background:#f97316}.stats-panel{background:#fff;border-radius:28px;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:18px;padding:10px;display:grid;box-shadow:0 20px 50px #4858801a}.stat-widget{background:#f8fafc;border-radius:16px;align-items:center;gap:10px;padding:8px 12px;display:flex}.stat-icon{color:#2563eb;flex-shrink:0;display:flex}.stat-icon svg{width:20px;height:20px}.stat-body{gap:0;min-width:0;line-height:1.15;display:grid}.stat-widget strong{font-size:1.25rem}.stat-widget span{font-size:.82rem;font-weight:800}.stat-widget small{color:#64748b;font-size:.7rem}.weather-panel{background:linear-gradient(135deg,#dbeafe,#ede9fe);border-radius:28px;margin-top:18px;padding:16px 18px;box-shadow:0 20px 50px #4858801a}.weather-head{justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;display:flex}.weather-place{color:#1e3a8a;align-items:center;gap:7px;display:flex}.weather-place strong{font-size:1.05rem}.weather-sub{color:#475569;font-size:.8rem;font-weight:700}.weather-days{grid-template-columns:repeat(7,1fr);gap:8px;display:grid}.weather-day{text-align:center;background:#ffffffb3;border-radius:16px;justify-items:center;gap:4px;padding:10px 6px;display:grid}.weather-dow{color:#334155;font-size:.78rem;font-weight:800}.weather-icon{font-size:1.4rem;line-height:1}.weather-temp{align-items:baseline;gap:5px;display:flex}.weather-temp strong{color:#0f172a;font-size:.95rem}.weather-temp small{color:#64748b;font-size:.78rem}.weather-note{color:#475569;margin:0;font-size:.9rem;font-weight:600}.toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-top:20px;display:flex}.tabs{flex-wrap:wrap;gap:8px;display:flex}.tabs button{color:#475569;background:#fff;border:0;border-radius:999px;padding:11px 16px;font-weight:800}.tabs button.active{color:#fff;background:#2563eb}.add-project{color:#fff;background:#2563eb;border-radius:16px;align-items:center;gap:8px;padding:13px 18px;font-weight:900;display:flex}.active-panel{margin-top:18px}.active-panel h2{font-size:1.55rem}.project-card{background:#fff;border-radius:30px;grid-template-columns:1.65fr .85fr .65fr auto;align-items:center;gap:18px;margin-bottom:16px;padding:18px;display:grid;box-shadow:0 22px 60px #4858801f}.project-left{gap:15px;display:flex}.project-icon{background:#eef2ff;border-radius:20px;place-items:center;min-width:56px;height:56px;font-size:28px;display:grid}.project-title-row h3{margin:0 0 8px;font-size:1.2rem}.badges{flex-wrap:wrap;gap:6px;display:flex}.badge{color:#0369a1;background:#e0f2fe;border-radius:999px;padding:5px 10px;font-size:.78rem;font-weight:900}.badge.pending{color:#92400e;background:#fef3c7}.badge.overdue{color:#991b1b;background:#fee2e2}.project-meta{color:#64748b;flex-wrap:wrap;align-items:center;gap:8px;margin:6px 0;display:flex}.project-note{color:#334155;margin:8px 0 0}.progress-label{justify-content:space-between;margin-bottom:8px;font-weight:900;display:flex}.progress-bar{background:#e2e8f0;border-radius:999px;height:12px;overflow:hidden}.progress-bar div{background:linear-gradient(90deg,#3b82f6,#8b5cf6);border-radius:999px;height:100%}.volunteers{gap:8px;display:grid}.avatar-row{display:flex}.avatar{color:#fff;cursor:pointer;background:#2563eb 50%/cover;border:2px solid #fff;border-radius:50%;place-items:center;width:34px;height:34px;margin-right:-8px;padding:0;font-weight:900;display:grid;overflow:hidden}.avatar.small{cursor:default;vertical-align:middle;width:26px;height:26px;margin-right:8px}.avatar.small.clickable{cursor:pointer}.avatar.open{color:#475569;background:#e2e8f0}.volunteer-names li{align-items:center;display:flex}.join-btn{color:#1d4ed8;background:#eef2ff;border-radius:12px;padding:9px 12px;font-weight:900}.project-actions{justify-items:end;gap:8px;display:grid}.details-btn,.complete-btn{border-radius:13px;padding:10px 13px;font-weight:900}.details-btn{color:#fff;background:#111827}.complete-btn{color:#166534;background:#dcfce7}.icon-btn{background:0 0;border:0}.card-menu{position:relative}.menu-backdrop{z-index:40;cursor:default;background:0 0;border:0;padding:0;position:fixed;inset:0}.card-dropdown{z-index:50;background:#fff;border:1px solid #eef1f6;border-radius:16px;gap:2px;min-width:200px;padding:8px;display:grid;position:absolute;top:calc(100% + 6px);right:0;box-shadow:0 24px 60px #0f172a38}.card-dropdown button{color:#1f2937;text-align:left;cursor:pointer;background:0 0;border:0;border-radius:11px;align-items:center;gap:10px;width:100%;padding:11px 12px;font-size:.92rem;font-weight:700;display:flex}.card-dropdown button:hover,.card-dropdown button:focus-visible{background:#f1f5f9}.card-dropdown button svg{color:#2563eb;flex:none}.menu-divider{background:#eef1f6;height:1px;margin:4px 2px}.member-edit-list{gap:8px;display:grid}.member-edit-row{grid-template-columns:auto 1fr auto;align-items:center;gap:10px;display:grid}.member-edit-avatar{color:#475569;text-transform:uppercase;background:#e2e8f0 50%/cover no-repeat;border-radius:50%;place-items:center;width:36px;height:36px;font-weight:900;display:grid}.member-remove{color:#b91c1c;cursor:pointer;background:#fee2e2;border:0;border-radius:11px;place-items:center;padding:9px;display:grid}.member-remove:hover{background:#fecaca}.focus-flash{border-radius:14px;animation:1.6s focus-flash}@keyframes focus-flash{0%,to{box-shadow:0 0 #2563eb00}20%,60%{box-shadow:0 0 0 4px #2563eb40}}.completed-panel{background:linear-gradient(135deg,#dcfce7,#bbf7d0);border-radius:28px;justify-content:space-between;align-items:center;margin-top:16px;padding:22px;display:flex}.completed-panel h2,.completed-panel p{margin:0}.completed-panel button{background:#fff;border:0;border-radius:14px;padding:12px 16px;font-weight:900}.reminders{grid-template-columns:repeat(3,1fr);gap:14px;margin-top:16px;display:grid}.reminders div{background:#fff;border-radius:22px;grid-template-columns:auto 1fr auto auto;align-items:center;gap:10px;padding:16px;display:grid;box-shadow:0 16px 45px #48588014}.reminders span{font-size:1.2rem;font-weight:900}.empty-state{text-align:center;color:#64748b;background:#fff;border-radius:24px;justify-items:center;gap:14px;padding:32px;display:grid}.empty-state p{margin:0}.empty-state .add-project{justify-content:center}.bottom-nav{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#ffffffeb;border:1px solid #e2e8f0cc;border-radius:28px;grid-template-columns:repeat(5,1fr);width:min(680px,100% - 24px);padding:10px;display:grid;position:fixed;bottom:16px;left:50%;transform:translate(-50%);box-shadow:0 20px 60px #28325029}.bottom-nav button{color:#64748b;background:0 0;border:0;justify-items:center;gap:4px;font-size:.76rem;font-weight:900;display:grid}.bottom-nav button svg{width:20px;height:20px}.bottom-nav .selected{color:#2563eb}.access-card.clickable{cursor:pointer;transition:transform .12s,box-shadow .12s}.access-card.clickable:hover{transform:translateY(-3px);box-shadow:0 26px 60px #4858802e}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:50;background:#0f172a80;place-items:center;padding:18px;display:grid;position:fixed;inset:0}.modal{background:#fff;border-radius:26px;width:min(640px,100%);max-height:90vh;padding:24px;overflow-y:auto;box-shadow:0 40px 100px #0f172a59}.calendar-modal{width:min(880px,100%)}.admin-modal{width:min(420px,100%)}.admin-modal-title{align-items:center;gap:8px;display:flex}.admin-modal-title h2{margin:0}.admin-form{gap:14px;display:grid}.modal-head{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:16px;display:flex}.modal-head h2{margin:0 0 8px}.project-form{grid-template-columns:1fr 1fr;gap:14px;display:grid}.field{gap:6px;display:grid}.field.full{grid-column:1/-1}.field span{color:#334155;font-size:.85rem;font-weight:800}.field input,.field select,.field textarea{background:#fff;border:1px solid #d9e0ea;border-radius:14px;outline:none;width:100%;padding:12px 13px}.field input[type=range]{padding:0}.field textarea{resize:vertical}.modal-actions{justify-content:flex-end;gap:10px;margin-top:4px;display:flex}.modal-actions.full{grid-column:1/-1}.primary-btn,.ghost-btn{cursor:pointer;border:0;border-radius:14px;padding:12px 20px;font-weight:900}.primary-btn{color:#fff;background:#2563eb}.ghost-btn{color:#334155;background:#f1f5f9}.detail-grid{grid-template-columns:1fr 1fr;gap:12px;margin:8px 0 14px;display:grid}.detail-grid div{background:#f8fafc;border-radius:16px;gap:3px;padding:12px 14px;display:grid}.detail-grid span{color:#64748b;font-size:.8rem;font-weight:700}.detail-grid strong{align-items:center;gap:6px;display:flex}.detail-bar{margin-bottom:14px}.detail-notes{color:#334155;background:#fff7ed;border-radius:16px;margin:0 0 14px;padding:14px}.detail-volunteers-head{justify-content:space-between;align-items:baseline;gap:10px;margin-bottom:8px;display:flex}.detail-volunteers-head span{color:#64748b;font-size:.85rem;font-weight:700}.volunteer-names{gap:4px;margin:0;padding-left:18px;display:grid}.muted{color:#94a3b8}.cal-nav{justify-content:space-between;align-items:center;margin-bottom:12px;font-size:1.1rem;display:flex}.cal-grid{grid-template-columns:repeat(7,1fr);gap:6px;display:grid}.cal-weekdays{margin-bottom:6px}.cal-weekday{text-align:center;color:#64748b;padding:4px 0;font-size:.78rem;font-weight:800}.cal-cell{background:#f8fafc;border-radius:14px;flex-direction:column;gap:4px;min-height:78px;padding:6px;display:flex;position:relative}.cal-cell.empty{background:0 0}.cal-cell.today{outline:2px solid #2563eb}.cal-date{color:#334155;font-size:.8rem;font-weight:800}.cal-dot{background:#2563eb;border-radius:50%;width:8px;height:8px;position:absolute;top:8px;right:8px}.cal-events{gap:3px;display:grid}.cal-event{cursor:pointer;text-align:left;color:#1d4ed8;white-space:nowrap;text-overflow:ellipsis;background:#dbeafe;border:0;border-radius:8px;padding:4px 6px;font-size:.68rem;font-weight:800;overflow:hidden}.cal-event.done{color:#166534;background:#dcfce7}.cal-hint{color:#64748b;text-align:center;margin:14px 0 0;font-size:.85rem}@media (width<=920px){.quick-grid,.stats-panel{grid-template-columns:repeat(2,1fr)}.weather-days{grid-template-columns:repeat(4,1fr)}.project-card{grid-template-columns:1fr}.project-actions{justify-items:stretch}}@media (width<=560px){.app-shell{padding:12px 12px 92px}.header-card{flex-direction:column;align-items:flex-start}.quick-grid,.stats-panel,.reminders{grid-template-columns:1fr}.weather-days{grid-template-columns:repeat(3,1fr)}.access-card{min-height:120px}.bottom-nav button{font-size:.66rem}.project-form,.detail-grid{grid-template-columns:1fr}.field.full{grid-column:auto}.cal-cell{min-height:60px}}.smart-bot-fab{cursor:pointer;color:#fff;touch-action:none;z-index:1000;background:linear-gradient(135deg,#2563eb,#8b5cf6);border:0;border-radius:50%;place-items:center;width:64px;height:64px;display:grid;position:fixed;bottom:86px;right:22px;box-shadow:0 16px 40px #3c46826b}.smart-bot-fab.open{background:linear-gradient(135deg,#4338ca,#6d28d9)}.smart-bot-panel{z-index:1000;background:#fff;border-radius:24px;flex-direction:column;width:min(400px,100vw - 32px);max-height:min(74vh,640px);display:flex;position:fixed;bottom:160px;right:22px;overflow:hidden;box-shadow:0 30px 90px #323c6e57}.smart-bot-head{color:#fff;background:linear-gradient(135deg,#2563eb,#8b5cf6);justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.smart-bot-title{align-items:center;gap:10px;font-size:1.12rem;display:flex}.smart-bot-head-actions{gap:6px;display:flex}.smart-bot-icon{cursor:pointer;color:#fff;background:#ffffff2e;border:0;border-radius:12px;place-items:center;width:38px;height:38px;display:grid}.smart-bot-icon.active{background:#ffffff6b}.smart-bot-tabs{flex-wrap:wrap;gap:6px;padding:12px 14px 0;display:flex}.smart-bot-tabs button{cursor:pointer;color:#1e3a8a;background:#e8eeff;border:0;border-radius:999px;padding:8px 14px;font-size:.92rem;font-weight:800}.smart-bot-tabs button:hover{background:#d7e1ff}.smart-bot-tabs button.active{color:#fff;background:#2563eb}.smart-bot-attention{cursor:pointer;color:#7c2d12;background:#ffedd5;border:0;border-radius:14px;margin:12px 14px 4px;padding:13px 16px;font-size:1rem;font-weight:900}.smart-bot-attention:hover{background:#fed7aa}.smart-bot-messages{flex-direction:column;flex:1;gap:10px;padding:12px 14px;display:flex;overflow-y:auto}.smart-bot-msg{border-radius:16px;max-width:88%;padding:11px 14px;font-size:1.02rem;line-height:1.45;position:relative}.smart-bot-msg p{white-space:pre-line;margin:0}.smart-bot-msg.bot{color:#172033;background:#f1f5fb;align-self:flex-start;padding-right:36px}.smart-bot-msg.user{color:#fff;background:#2563eb;align-self:flex-end}.smart-bot-replay{cursor:pointer;color:#2563eb;background:0 0;border:0;border-radius:8px;place-items:center;width:24px;height:24px;display:grid;position:absolute;top:8px;right:8px}.smart-bot-replay:hover{background:#e2e8f5}.smart-bot-suggestions{border-top:1px solid #eef1f7;flex-wrap:wrap;gap:6px;padding:8px 14px;display:flex}.smart-bot-suggestions button{cursor:pointer;color:#334155;background:#eef2f9;border:0;border-radius:999px;padding:7px 12px;font-size:.86rem;font-weight:700}.smart-bot-suggestions button:hover{background:#e2e8f5}.smart-bot-suggestions button.admin{color:#5b21b6;background:#ede9fe}.smart-bot-suggestions button.admin:hover{background:#ddd6fe}.smart-bot-input{border-top:1px solid #eef1f7;align-items:center;gap:8px;padding:10px 12px 12px;display:flex}.smart-bot-input input{border:1px solid #d7deeb;border-radius:14px;flex:1;padding:12px 14px;font-size:1rem}.smart-bot-mic,.smart-bot-send{cursor:pointer;color:#fff;border:0;border-radius:14px;flex:none;place-items:center;width:44px;height:44px;display:grid}.smart-bot-mic{background:#8b5cf6}.smart-bot-mic.listening{background:#dc2626}.smart-bot-send{background:#2563eb}@media (width<=480px){.smart-bot-panel{width:auto;bottom:150px;left:12px;right:12px}}.project-media{flex-wrap:wrap;gap:8px;margin-top:12px;display:flex}.media-thumb{cursor:pointer;background:#eef2ff;border:0;border-radius:12px;width:56px;height:56px;padding:0;position:relative;overflow:hidden}.media-thumb img,.media-thumb video{object-fit:cover;width:100%;height:100%;display:block}.play-badge{color:#fff;background:#0f172a61;place-items:center;font-size:.9rem;display:grid;position:absolute;inset:0}.media-overlay{z-index:60}.media-viewer{place-items:center;width:min(900px,100%);max-height:90vh;display:grid;position:relative}.media-stage{place-items:center;width:100%;display:grid}.media-stage img,.media-stage video{border-radius:16px;max-width:100%;max-height:82vh;box-shadow:0 40px 100px #0f172a80}.media-close{color:#fff;z-index:2;background:#0f172a8c;border-radius:50%;place-items:center;width:44px;height:44px;display:grid;position:absolute;top:-6px;right:-6px}.media-nav{cursor:pointer;color:#fff;z-index:2;background:#0f172a8c;border:0;border-radius:50%;place-items:center;width:48px;height:48px;display:grid;position:absolute;top:50%;transform:translateY(-50%)}.media-nav.prev{left:4px}.media-nav.next{right:4px}.media-dots{gap:7px;display:flex;position:absolute;bottom:10px;left:50%;transform:translate(-50%)}.media-dots span{background:#ffffff73;border-radius:50%;width:8px;height:8px}.media-dots span.on{background:#fff}.media-pick-row{flex-wrap:wrap;gap:10px;display:flex}.media-pick{background:#eef2ff;border-radius:14px;width:72px;height:72px;position:relative;overflow:hidden}.media-pick img,.media-pick video{object-fit:cover;width:100%;height:100%;display:block}.media-remove{cursor:pointer;color:#fff;background:#0f172a99;border:0;border-radius:50%;place-items:center;width:22px;height:22px;display:grid;position:absolute;top:4px;right:4px}.media-add{color:#64748b;cursor:pointer;border:2px dashed #c7d2e5;border-radius:14px;place-items:center;width:72px;height:72px;display:grid}.error.full{grid-column:1/-1}.announcements-modal{width:min(520px,100%)}.announcement-list{gap:10px;margin:0;padding:0;list-style:none;display:grid}.announcement{cursor:pointer;text-align:left;color:#172033;background:#f8fafc;border:0;border-radius:16px;align-items:center;gap:12px;width:100%;padding:14px;display:flex}.announcement:hover{background:#eef2ff}.announcement-icon{font-size:1.4rem}.announcement-body{flex:1;gap:2px;display:grid}.announcement-body small{color:#64748b}.volunteer-modal{width:min(440px,100%)}.volunteer-form{gap:14px;display:grid}.volunteer-form .muted{margin:0}.notif-modal{width:min(480px,100%)}.notif-toolbar{flex-wrap:wrap;gap:8px;margin-bottom:14px;display:flex}.notif-toolbar .ghost-btn{align-items:center;gap:6px;padding:9px 13px;font-size:.85rem;display:flex}.notif-list{gap:10px;margin:0;padding:0;list-style:none;display:grid}.notif-item{background:#f8fafc;border-radius:16px;align-items:flex-start;gap:12px;padding:12px 14px;display:flex}.notif-item.unread{background:#eef4ff;box-shadow:inset 3px 0 #2563eb}.notif-icon{font-size:1.3rem;line-height:1.6}.notif-body{cursor:pointer;text-align:left;color:#172033;background:0 0;border:0;flex:1;gap:3px;display:grid}.notif-body strong{font-size:.98rem}.notif-body span{color:#475569;font-size:.9rem}.notif-body small{color:#94a3b8;font-size:.76rem}.notif-actions{flex:none;gap:2px;display:flex}.notif-actions .icon-btn{color:#475569;cursor:pointer;border-radius:10px;place-items:center;width:32px;height:32px;display:grid}.notif-actions .icon-btn:hover{background:#e2e8f5}body:has(.hub-shell){background:#f8fafc}.hub-shell{color:#172033;background:radial-gradient(900px 480px at 50% -120px,#2563eb1a,#0000 70%),linear-gradient(#fff,#f1f5f9 60%);width:min(960px,100%);min-height:100vh;margin:0 auto;padding:22px 18px 110px}.hub-topbar{justify-content:space-between;align-items:center;gap:12px;margin-bottom:8px;display:flex}.hub-topbar-right{align-items:center;gap:10px;display:flex}.hub-shell .manager-btn{color:#1d4ed8;background:#eff6ff;border:1px solid #bfdbfe}.hub-shell .manager-btn.active{color:#fff;background:#2563eb}.hub-shell .bell{color:#1d4ed8;background:#eff6ff;border:1px solid #bfdbfe}.hub-shell .logout-btn{color:#b91c1c;background:#f8fafc;border:1px solid #e2e8f0}.hub-hero{text-align:center;padding:14px 10px 22px}.hub-hero-icon{color:#fff;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:24px;place-items:center;width:78px;height:78px;margin:0 auto 14px;display:grid;box-shadow:0 18px 50px #3b82f647}.hub-welcome{color:#2563eb;letter-spacing:.02em;margin:0;font-weight:700}.hub-hero h1{color:#0f172a;margin:4px 0 10px;font-size:clamp(1.7rem,5vw,2.6rem);font-weight:900}.hub-tagline{color:#475569;max-width:540px;margin:0 auto;line-height:1.5}.hub-notif-pill{color:#1d4ed8;cursor:pointer;background:#eff6ff;border:1px solid #bfdbfe;border-radius:999px;align-items:center;gap:8px;padding:9px 16px;font-weight:800;display:inline-flex}.hub-notif-pill.on{color:#047857;background:#ecfdf5;border-color:#a7f3d0}.hub-hero-actions{flex-wrap:wrap;justify-content:center;gap:10px;margin-top:16px;display:flex}.hub-install-pill{color:#fff;cursor:pointer;background:linear-gradient(135deg,#3b82f6,#2563eb);border:1px solid #0000;border-radius:999px;align-items:center;gap:8px;padding:9px 16px;font-weight:800;display:inline-flex;box-shadow:0 10px 26px #2563eb47}.hub-install-pill:hover{filter:brightness(1.05)}.hub-grid{grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:14px;margin-bottom:14px;display:grid}.hub-app-card{text-align:left;cursor:pointer;color:#0f172a;background:#fff;border:1px solid #e2e8f0;border-radius:22px;flex-direction:column;gap:8px;padding:20px;transition:transform .12s,border-color .12s,box-shadow .12s;display:flex;box-shadow:0 18px 50px #4858801a}.hub-app-card:hover{border-color:#cbd5e1;transform:translateY(-3px);box-shadow:0 26px 60px #48588029}.hub-app-icon{color:#fff;background:linear-gradient(135deg,#2563eb,#3b82f6);border-radius:16px;place-items:center;width:48px;height:48px;display:grid}.hub-app-card.vehiclewatch .hub-app-icon{background:linear-gradient(135deg,#fb923c,#f97316)}.hub-app-card.harvest .hub-app-icon{background:linear-gradient(135deg,#22c55e,#16a34a)}.hub-app-card.calendar{background:linear-gradient(160deg,#eff6ff,#dbeafe);border-color:#bfdbfe}.hub-app-card.vehiclewatch{background:linear-gradient(160deg,#fff7ed,#ffedd5);border-color:#fed7aa}.hub-app-card.harvest{background:linear-gradient(160deg,#f0fdf4,#dcfce7);border-color:#bbf7d0}.hub-app-card strong{color:#0f172a;font-size:1.12rem}.hub-app-card small{color:#64748b;line-height:1.4}.hub-cmh-entry{cursor:pointer;text-align:left;color:#0f172a;background:linear-gradient(160deg,#faf5ff,#ede9fe);border:1px solid #ddd6fe;border-radius:18px;align-items:center;gap:14px;width:100%;margin-bottom:16px;padding:14px 18px;transition:border-color .12s,background .12s;display:flex}.hub-cmh-entry:hover{background:#ede9fe;border-color:#c4b5fd}.hub-cmh-icon{color:#fff;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:13px;flex:none;place-items:center;width:40px;height:40px;display:grid}.hub-cmh-text{flex-direction:column;flex:1;display:flex}.hub-cmh-text strong{color:#0f172a}.hub-cmh-text small{color:#64748b}.hub-cmh-entry svg{color:#7c3aed;flex:none}.hub-card{background:#fff;border:1px solid #e2e8f0;border-radius:22px;padding:18px;box-shadow:0 18px 50px #4858801a}.hub-card h2{color:#0f172a;align-items:center;gap:8px;margin:0 0 12px;font-size:1.05rem;display:flex}.hub-card h2 svg{color:#2563eb}.hub-schedule-row{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:14px;margin-bottom:16px;display:grid}.hub-empty{color:#64748b;margin:0}.hub-task-list{gap:8px;margin:0;padding:0;list-style:none;display:grid}.hub-task-list button{cursor:pointer;text-align:left;color:#0f172a;background:#f8fafc;border:1px solid #e2e8f0;border-radius:14px;align-items:center;gap:10px;width:100%;padding:10px 12px;display:flex}.hub-task-list button:hover{border-color:#93c5fd}.hub-task-dot{background:#60a5fa;border-radius:50%;flex:none;width:10px;height:10px}.hub-task-dot.in-progress{background:#f59e0b}.hub-task-dot.completed{background:#22c55e}.hub-task-dot.closed{background:#94a3b8}.hub-task-main{flex-direction:column;flex:1;min-width:0;display:flex}.hub-task-main strong{color:#0f172a}.hub-task-main small{color:#64748b}.hub-taskcenter-head{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:14px;display:flex}.hub-taskcenter-head h2{margin:0}.hub-taskcenter-head p{color:#64748b;margin:4px 0 0;font-size:.9rem}.hub-tabs{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.hub-tabs button{color:#475569;cursor:pointer;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:999px;padding:8px 14px;font-weight:700}.hub-tabs button.active{color:#fff;background:#2563eb;border-color:#2563eb}.hub-cal .cal-nav{color:#0f172a}.hub-cal .icon-btn{color:#1d4ed8;background:#eff6ff;border:1px solid #bfdbfe}.hub-cal .cal-weekday{color:#64748b}.hub-cal .cal-cell{background:#f8fafc;min-height:56px}.hub-cal .cal-cell.empty{background:0 0}.hub-cal .cal-cell.today{background:#dbeafe;outline:2px solid #2563eb}.hub-cal .cal-date{color:#334155}.hub-cal .cal-event{color:#1d4ed8;background:#dbeafe}.hub-cal .cal-event.done{opacity:.6}.hub-shell .bottom-nav{background:#ffffffeb;border:1px solid #e2e8f0cc}.hub-shell .bottom-nav button{color:#64748b}.hub-shell .bottom-nav .selected{color:#2563eb}.hub-back{color:#1d4ed8;cursor:pointer;background:#eff6ff;border:1px solid #bfdbfe;border-radius:12px;align-items:center;gap:6px;margin-bottom:14px;padding:9px 14px;font-weight:800;display:inline-flex}.app-shell .hub-back{color:#2563eb;background:#eef2ff;border-color:#c7d2fe}.app-launch-shell{flex-direction:column;display:flex}.launch-hero{text-align:center;background:#fff;border:1px solid #e2e8f0;border-radius:26px;max-width:520px;margin:auto;padding:40px 26px;box-shadow:0 26px 70px #48588024}.launch-icon{color:#fff;background:linear-gradient(135deg,#2563eb,#3b82f6);border-radius:26px;place-items:center;width:86px;height:86px;margin:0 auto 18px;display:grid}.launch-hero.harvest .launch-icon{background:linear-gradient(135deg,#10b981,#22c55e)}.launch-hero.vw .launch-icon{background:linear-gradient(135deg,#fb923c,#f97316)}.launch-hero h1{color:#0f172a;margin:0 0 8px}.launch-tagline{color:#2563eb;margin:0 0 14px;font-weight:700}.launch-desc{color:#475569;margin:0;line-height:1.6}@media (width<=560px){.hub-shell .bottom-nav button{font-size:.68rem}.hub-cal .cal-cell{min-height:46px}}.install-modal .primary-btn,.notif-toolbar .ghost-btn{align-items:center;gap:8px;display:inline-flex}.install-steps{color:#334155;gap:8px;margin:12px 0 4px;padding-left:22px;font-weight:600;display:grid}.install-steps li{line-height:1.4}.install-steps li svg{vertical-align:-2px;margin:0 2px}.install-steps-note{margin:10px 0 4px;line-height:1.5}.install-steps-note strong{color:#334155}.danger-btn{cursor:pointer;color:#fff;background:#dc2626;border:0;border-radius:13px;align-items:center;gap:8px;padding:11px 16px;font-weight:900;display:inline-flex}.danger-btn:hover{background:#b91c1c}.danger-btn:disabled{opacity:.6;cursor:default}.card-dropdown button.danger{color:#b91c1c}.card-dropdown button.danger svg{color:#dc2626}.card-dropdown button.danger:hover,.card-dropdown button.danger:focus-visible{background:#fef2f2}.notif-actions .icon-btn.danger{color:#dc2626}.notif-actions .icon-btn.danger:hover{background:#fef2f2}.signup-delete{color:#dc2626;cursor:pointer;background:0 0;border:0;border-radius:9px;margin-left:auto;padding:6px;display:inline-flex}.signup-delete:hover{background:#fef2f2}.announcement-list li{align-items:center;gap:8px;display:flex}.announcement-list li .announcement{flex:1;min-width:0}.announcement-delete{color:#dc2626;cursor:pointer;background:#fef2f2;border:0;border-radius:12px;flex:none;padding:10px;display:inline-flex}.announcement-delete:hover{background:#fee2e2}.confirm-message{color:#0f172a;margin:4px 0 6px;font-weight:700}.confirm-target{margin:0 0 4px}.approval-list{border-color:#bfdbfe;margin-bottom:16px}.approval-head h2{color:#1d4ed8;align-items:center;gap:8px;display:flex}.approval-head h2 svg{color:#2563eb}.approval-head p{color:#64748b;margin:0 0 12px;font-size:.92rem}.approval-items{gap:10px;margin:0;padding:0;list-style:none;display:grid}.approval-item{background:#fbfcfe;border:1px solid #eef1f6;border-radius:14px;justify-content:space-between;align-items:center;gap:12px;padding:10px 14px;display:flex}.approval-person{align-items:center;gap:10px;min-width:0;display:flex}.approval-avatar{color:#2563eb;background:#e0edff;border-radius:50%;flex:none;justify-content:center;align-items:center;width:34px;height:34px;display:inline-flex}.approval-name{color:#0f172a;text-overflow:ellipsis;white-space:nowrap;font-weight:800;overflow:hidden}.approve-btn{flex:none;align-items:center;gap:6px;padding:9px 16px;display:inline-flex}.approve-btn:disabled{opacity:.6;cursor:default}.approval-relock{flex-direction:column;align-items:flex-start;gap:10px;display:flex}.approval-relock .primary-btn{align-items:center;gap:8px;display:inline-flex}.sync-badge{color:#15803d;white-space:nowrap;background:#dcfce7;border:1px solid #86efac;border-radius:999px;align-items:center;gap:6px;padding:5px 11px;font-size:.82rem;font-weight:800;display:inline-flex}.sync-badge svg{color:#16a34a}.sync-dot{background:#22c55e;border-radius:50%;width:8px;height:8px;animation:2s infinite sync-pulse;box-shadow:0 0 #22c55e99}@keyframes sync-pulse{0%{box-shadow:0 0 #22c55e8c}70%{box-shadow:0 0 0 6px #22c55e00}to{box-shadow:0 0 #22c55e00}}.active-users{border-color:#bbf7d0;margin-bottom:16px}.active-users .approval-head h2{color:#15803d}.active-users .approval-head h2 svg{color:#16a34a}.user-items{gap:10px;margin:0;padding:0;list-style:none;display:grid}.user-item{background:#fbfcfe;border:1px solid #eef1f6;border-radius:14px;justify-content:space-between;align-items:center;gap:12px;padding:10px 14px;display:flex}.user-status{white-space:nowrap;border-radius:999px;flex:none;align-items:center;gap:7px;padding:5px 12px;font-size:.82rem;font-weight:800;display:inline-flex}.user-status .status-dot{background:currentColor;border-radius:50%;width:8px;height:8px}.user-status.active{color:#15803d;background:#dcfce7}.user-status.inactive{color:#64748b;background:#f1f5f9}.user-status.pending{color:#b45309;background:#fef3c7}.admin-delete{border-color:#fecaca;margin-bottom:16px}.admin-delete-head h2{color:#b91c1c}.admin-delete-head h2 svg{color:#dc2626}.admin-delete-head p{color:#64748b;margin:0 0 12px;font-size:.92rem}.delete-group{background:#fbfcfe;border:1px solid #eef1f6;border-radius:14px;margin-bottom:10px;padding:4px 12px}.delete-group>summary{cursor:pointer;color:#0f172a;justify-content:space-between;align-items:center;gap:10px;padding:10px 2px;font-weight:800;list-style:none;display:flex}.delete-group>summary::-webkit-details-marker{display:none}.delete-group-count{text-align:center;color:#334155;background:#e2e8f0;border-radius:999px;flex:none;min-width:24px;padding:2px 8px;font-size:.8rem;font-weight:800}.delete-list{gap:8px;margin:0 0 8px;padding:0;list-style:none;display:grid}.delete-row{background:#fff;border:1px solid #eef1f6;border-radius:12px;align-items:center;gap:12px;padding:10px 12px;display:flex}.delete-row-icon{flex:none;font-size:1.2rem}.delete-row-body{flex:1;gap:2px;min-width:0;display:grid}.delete-row-body strong{color:#0f172a;white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.delete-row-body small{color:#64748b}.delete-row-btn{color:#dc2626;cursor:pointer;background:#fef2f2;border:0;border-radius:10px;flex:none;padding:9px;display:inline-flex}.delete-row-btn:hover{background:#fee2e2}.update-banner{left:50%;bottom:calc(76px + env(safe-area-inset-bottom,0px));z-index:1100;color:#fff;background:#111827;border-radius:14px;justify-content:space-between;align-items:center;gap:12px;width:min(440px,100vw - 24px);padding:12px 14px;display:flex;position:fixed;transform:translate(-50%);box-shadow:0 18px 50px #0f172a61}.update-banner-text{font-size:.92rem;font-weight:600}.update-banner-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.update-banner-refresh{cursor:pointer;color:#fff;background:#2563eb;border:0;border-radius:10px;padding:8px 14px;font-size:.9rem;font-weight:700}.update-banner-refresh:hover{background:#1d4ed8}.update-banner-dismiss{cursor:pointer;color:#cbd5e1;background:0 0;border:0;border-radius:10px;padding:8px 10px;font-size:.9rem;font-weight:600}.update-banner-dismiss:hover{color:#fff}.login-divider{color:#9aa4b5;text-transform:uppercase;letter-spacing:.04em;align-items:center;gap:12px;margin:22px 0 4px;font-size:.85rem;font-weight:700;display:flex}.login-divider:before,.login-divider:after{content:"";background:#e2e8f0;flex:1;height:1px}.create-pin{border-top:1px solid #eef2f7;margin-top:22px;padding-top:16px}.create-pin-toggle{color:#2563eb;cursor:pointer;background:#f8fafc;border:1px solid #d9e0ea;border-radius:16px;width:100%;padding:14px 16px;font-weight:800}.create-pin-toggle:hover{background:#eef2ff}.create-pin-form{gap:12px;margin-top:14px;display:grid}.create-pin-form .muted{text-align:left;margin:0;font-size:.9rem}.success-msg{color:#16a34a;font-weight:700}.update-modal p{color:#475569;margin:4px 0 18px}
