*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--sidebar-w:220px;--topbar-h:56px;--bottom-nav-h:60px;--green:#1d9e75;--green-dk:#0f6e56;--green-lt:#e1f5ee;--amber:#ba7517;--amber-lt:#faeeda;--red:#a32d2d;--red-lt:#fcebeb;--blue:#185fa5;--blue-lt:#e6f1fb;--gray-lt:#f1efe8;--text-1:#1a1a1a;--text-2:#6b6b6b;--text-3:#9b9b9b;--border:#0000001a;--bg-page:#f5f5f2;--bg-card:#fff;--bg-hover:#f9f9f7;--radius:8px;--radius-lg:12px;--shadow-sm:0 1px 3px #00000012}body{background:var(--bg-page);color:var(--text-1);-webkit-text-size-adjust:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;line-height:1.5}.app-shell{height:100dvh;display:flex;overflow:hidden}.sidebar{width:var(--sidebar-w);background:var(--bg-card);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;display:flex;overflow-y:auto}.mobile-drawer{z-index:201;display:none;position:fixed;top:0;bottom:0;left:0;box-shadow:4px 0 20px #00000026;width:240px!important}.mobile-drawer.open{display:flex}.main-area{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.topbar{height:var(--topbar-h);background:var(--bg-card);border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;gap:8px;padding:0 16px;display:flex}.page-content{-webkit-overflow-scrolling:touch;flex:1;padding:16px;overflow-y:auto}.logo{letter-spacing:-.5px;border-bottom:1px solid var(--border);padding:18px 16px 14px;font-size:18px;font-weight:700}.logo span{color:var(--green)}.nav-section{color:var(--text-3);text-transform:uppercase;letter-spacing:.8px;padding:12px 16px 4px;font-size:10px;font-weight:600}.nav-item{cursor:pointer;color:var(--text-2);border-left:2px solid #0000;align-items:center;gap:10px;padding:8px 16px;font-size:13px;text-decoration:none;transition:all .12s;display:flex}.nav-item:hover{background:var(--bg-hover);color:var(--text-1)}.nav-item.active{color:var(--green);border-left-color:var(--green);background:var(--green-lt);font-weight:500}.nav-icon{opacity:.7;flex-shrink:0;width:16px;height:16px}.nav-item.active .nav-icon{opacity:1}.sidebar-footer{border-top:1px solid var(--border);margin-top:auto;padding:12px 16px}.bottom-nav{height:calc(var(--bottom-nav-h) + env(safe-area-inset-bottom,0px));background:var(--bg-card);border-top:1px solid var(--border);z-index:100;padding:0 4px;padding-bottom:env(safe-area-inset-bottom,0px);flex-shrink:0;display:none}.bottom-nav-items{justify-content:space-around;align-items:center;height:100%;display:flex}.bottom-nav-item{cursor:pointer;color:var(--text-3);border-radius:var(--radius);flex-direction:column;flex:1;align-items:center;gap:2px;padding:6px 10px;font-size:10px;font-weight:500;text-decoration:none;transition:all .12s;display:flex}.bottom-nav-item.active{color:var(--green)}.bottom-nav-item span.icon{font-size:20px;line-height:1}.mobile-menu-btn{cursor:pointer;color:var(--text-1);background:0 0;border:none;justify-content:center;align-items:center;min-width:40px;min-height:40px;padding:8px;font-size:26px;line-height:1;display:flex}.sidebar-overlay{z-index:200;background:#0006;display:none;position:fixed;inset:0}.sidebar-overlay.open{display:block}.sidebar.mobile-open{z-index:201;display:flex;position:fixed;top:0;bottom:0;left:0;box-shadow:4px 0 20px #00000026}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px}.card-title{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;margin-bottom:14px;font-size:14px;font-weight:600;display:flex}.card-grid{gap:12px;display:grid}.card-grid-2{grid-template-columns:1fr 1fr}.card-grid-3{grid-template-columns:repeat(3,1fr)}.card-grid-4{grid-template-columns:repeat(4,1fr)}.metric-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px}.metric-label{color:var(--text-2);margin-bottom:4px;font-size:12px}.metric-value{font-size:24px;font-weight:600;line-height:1.1}.metric-sub{color:var(--text-3);margin-top:4px;font-size:12px}.green{color:var(--green)}.amber{color:var(--amber)}.red{color:var(--red)}.blue{color:var(--blue)}.badge{white-space:nowrap;border-radius:20px;align-items:center;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.badge-green{background:var(--green-lt);color:var(--green-dk)}.badge-amber{background:var(--amber-lt);color:var(--amber)}.badge-red{background:var(--red-lt);color:var(--red)}.badge-blue{background:var(--blue-lt);color:var(--blue)}.badge-gray{background:var(--gray-lt);color:var(--text-2)}.btn{border-radius:var(--radius);border:1px solid var(--border);background:var(--bg-card);color:var(--text-1);cursor:pointer;white-space:nowrap;touch-action:manipulation;-webkit-tap-highlight-color:transparent;align-items:center;gap:6px;padding:8px 14px;font-size:13px;font-weight:500;transition:all .12s;display:inline-flex}.btn:hover{background:var(--bg-hover)}.btn:active{transform:scale(.97)}.btn-primary{background:var(--green);border-color:var(--green);color:#fff}.btn-primary:hover{background:var(--green-dk)}.btn-danger{background:var(--red-lt);border-color:var(--red);color:var(--red)}.btn-sm{padding:5px 10px;font-size:12px}.btn-icon{border-radius:var(--radius);padding:8px}.btn:disabled{opacity:.5;cursor:not-allowed}.form-group{flex-direction:column;gap:5px;margin-bottom:12px;display:flex}.form-row{gap:12px;margin-bottom:12px;display:grid}.form-row-2{grid-template-columns:1fr 1fr}.form-row-3{grid-template-columns:1fr 1fr 1fr}label{color:var(--text-2);font-size:12px;font-weight:600}input,select,textarea{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-card);color:var(--text-1);appearance:none;width:100%;padding:10px 12px;font-family:inherit;font-size:16px;transition:border-color .12s}select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%236b6b6b' d='M6 8L0 0h12z'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:32px}input:focus,select:focus,textarea:focus{border-color:var(--green);outline:none;box-shadow:0 0 0 3px #1d9e751f}textarea{resize:vertical;min-height:80px}input[type=checkbox]{width:18px;height:18px;accent-color:var(--green);cursor:pointer;appearance:auto;-webkit-appearance:checkbox;flex-shrink:0}input[type=date],input[type=time]{font-size:14px}.table-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}table{border-collapse:collapse;width:100%;min-width:500px;font-size:13px}th{text-align:left;color:var(--text-2);border-bottom:1px solid var(--border);white-space:nowrap;background:var(--bg-hover);text-transform:uppercase;letter-spacing:.4px;vertical-align:middle;padding:9px 12px;font-size:11px;font-weight:600}td{border-bottom:1px solid var(--border);vertical-align:middle;padding:10px 12px}tr{vertical-align:middle}tr:last-child td{border-bottom:none}tbody tr:hover td{background:var(--bg-hover)}.modal-overlay{z-index:1000;touch-action:none;background:#00000073;justify-content:center;align-items:flex-end;padding:0;display:flex;position:fixed;inset:0}.modal{background:var(--bg-card);border-radius:var(--radius-lg) var(--radius-lg) 0 0;padding:20px;padding-bottom:calc(20px + env(safe-area-inset-bottom,0px));-webkit-overflow-scrolling:touch;touch-action:pan-y;overscroll-behavior:contain;width:100%;max-width:100%;max-height:85vh;overflow-y:scroll;box-shadow:0 -4px 30px #00000026}.modal-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.modal-title{font-size:16px;font-weight:600}.modal-footer{border-top:1px solid var(--border);background:var(--bg-card);z-index:1;justify-content:flex-end;gap:8px;margin-top:16px;padding-top:16px;display:flex;position:sticky;bottom:0}.modal-footer .btn{flex:1;justify-content:center}.tabs{border-bottom:1px solid var(--border);-webkit-overflow-scrolling:touch;gap:0;margin-bottom:16px;display:flex;overflow-x:auto}.tab{cursor:pointer;color:var(--text-2);white-space:nowrap;border-bottom:2px solid #0000;margin-bottom:-1px;padding:10px 14px;font-size:13px;font-weight:500;transition:all .12s}.tab:hover{color:var(--text-1)}.tab.active{color:var(--green);border-bottom-color:var(--green)}.list-row{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:10px 0;display:flex}.list-row:last-child{border-bottom:none}.avatar{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:11px;font-weight:700;display:flex}.av-green{background:var(--green-lt);color:var(--green-dk)}.av-blue{background:var(--blue-lt);color:var(--blue)}.av-amber{background:var(--amber-lt);color:var(--amber)}.av-gray{background:var(--gray-lt);color:var(--text-2)}.progress{background:var(--gray-lt);border-radius:3px;height:6px;overflow:hidden}.progress-fill{background:var(--green);border-radius:3px;height:100%;transition:width .3s}.toast-container{z-index:9999;flex-direction:column;gap:8px;display:flex;position:fixed;bottom:20px;right:16px}.toast{background:var(--text-1);color:#fff;border-radius:var(--radius);box-shadow:var(--shadow-sm);max-width:300px;padding:10px 16px;font-size:13px;animation:.2s slideIn}.toast.success{background:var(--green-dk)}.toast.error{background:var(--red)}@keyframes slideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.spinner{border:2px solid var(--border);border-top-color:var(--green);border-radius:50%;width:24px;height:24px;animation:.6s linear infinite spin}.loading-center{justify-content:center;align-items:center;height:200px;display:flex}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;color:var(--text-3);padding:48px 20px}.empty-state h3{color:var(--text-2);margin-bottom:8px;font-size:15px;font-weight:600}.check-row{border-radius:var(--radius);align-items:center;gap:10px;padding:10px 8px;display:flex}.check-row:hover{background:var(--bg-hover)}.check-row.done label{color:var(--text-3);text-decoration:line-through}.img-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:8px;display:grid}.img-thumb{aspect-ratio:1;object-fit:cover;border-radius:var(--radius);border:1px solid var(--border);cursor:pointer;width:100%}.login-page{background:var(--bg-page);justify-content:center;align-items:center;min-height:100dvh;padding:16px;display:flex}.login-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);text-align:center;width:100%;max-width:380px;box-shadow:var(--shadow-sm);padding:32px 24px}.login-logo{margin-bottom:8px;font-size:28px;font-weight:700}.login-logo span{color:var(--green)}.login-sub{color:var(--text-2);margin-bottom:28px;font-size:14px}.google-btn{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-card);cursor:pointer;width:100%;color:var(--text-1);touch-action:manipulation;justify-content:center;align-items:center;gap:10px;padding:14px;font-size:15px;font-weight:500;transition:all .12s;display:flex}.google-btn:hover{background:var(--bg-hover)}.rbc-calendar{font-family:inherit;font-size:12px}.rbc-toolbar{flex-wrap:wrap;gap:8px}.rbc-toolbar button{border-radius:var(--radius);touch-action:manipulation;padding:6px 10px;font-size:12px}.rbc-event{background:var(--green)!important;border:none!important;border-radius:4px!important;font-size:11px!important}.rbc-today{background:#1d9e750f!important}.topbar-title-wrap{align-items:center;gap:8px;min-width:0;display:flex}.topbar-title-wrap h1{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.topbar-actions{flex-shrink:0;align-items:center;gap:6px;display:flex}@media (width>=769px){.bottom-nav,.mobile-menu-btn,.sidebar-overlay{display:none!important}.page-content{padding:20px}.modal-overlay{align-items:center;padding:16px}.modal{border-radius:var(--radius-lg);max-width:560px;padding:24px}.modal-lg{max-width:760px}.modal-footer .btn{flex:none}.toast-container{bottom:20px}.card-grid-2{grid-template-columns:1fr 1fr}.card-grid-3{grid-template-columns:repeat(3,1fr)}.card-grid-4{grid-template-columns:repeat(4,1fr)}.form-row-2{grid-template-columns:1fr 1fr}.form-row-3{grid-template-columns:1fr 1fr 1fr}input,select,textarea{padding:8px 10px;font-size:13px}select{padding-right:32px}}@media (width<=768px){.desktop-sidebar{display:none}.bottom-nav{flex-direction:column;justify-content:flex-start;display:flex}.mobile-menu-btn{display:flex}.page-content{padding:12px;padding-bottom:calc(12px + var(--bottom-nav-h) + env(safe-area-inset-bottom,0px))}.modal-overlay{bottom:var(--bottom-nav-h)}.card-grid-2,.card-grid-3,.card-grid-4,.form-row-2,.form-row-3{grid-template-columns:1fr}.topbar{padding:0 12px}.metric-value{font-size:22px}}
