.sidebar{background:var(--bg-sidebar);border-right:1px solid var(--border-light);display:flex;flex-direction:column;flex-shrink:0;gap:4px;height:100vh;overflow-y:auto;padding:24px 16px;position:sticky;top:0;width:260px}.sidebar-title{border-bottom:1px solid var(--border-light);font-family:var(--font-display);font-size:1.5rem;font-weight:400;margin-bottom:8px;padding:0 8px 16px}.sidebar-title em{color:var(--accent);font-style:italic}.sidebar-section{color:var(--text-light);font-size:.65rem;font-weight:600;letter-spacing:.08em;padding:12px 8px 6px;text-transform:uppercase}.sidebar-item{align-items:center;background:none;border:none;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;display:flex;font-family:inherit;font-size:.875rem;gap:10px;padding:9px 12px;text-align:left;transition:var(--transition);width:100%}.sidebar-item:hover{background:var(--bg-hover);color:var(--text)}.sidebar-item.active{background:var(--accent-soft);color:var(--accent);font-weight:500}.sidebar-item .cat-dot{border-radius:3px;flex-shrink:0;height:10px;width:10px}.sidebar-item .cat-count{background:var(--bg);border-radius:100px;color:var(--text-light);font-size:.72rem;padding:1px 7px}.sidebar-item.active .cat-count{background:#c4553a26;color:var(--accent)}.sidebar-item .cat-delete{opacity:0;transition:var(--transition)}.sidebar-item:hover .cat-delete{opacity:1}.sidebar-add-sub{align-items:center;background:none;border:none;border-radius:var(--radius-sm);color:var(--text-light);cursor:pointer;display:flex;font-family:inherit;font-size:.75rem;padding:4px 12px 4px 36px;text-align:left;transition:var(--transition);width:100%}.sidebar-add-sub:hover{color:var(--accent)}.sidebar-add{align-items:center;background:none;border:1px dashed var(--border);border-radius:var(--radius-sm);color:var(--text-light);cursor:pointer;display:flex;font-family:inherit;font-size:.82rem;gap:8px;margin-top:4px;padding:8px 12px;text-align:left;transition:var(--transition);width:100%}.sidebar-add:hover{border-color:var(--accent);color:var(--accent)}.sidebar-subcat{padding-left:4px}.subcat-indent{align-items:center;display:flex;flex-shrink:0;position:relative;width:16px}.subcat-indent:before{background:var(--border);content:"";height:1px;left:8px;position:absolute;top:50%;width:8px}.sidebar-recurring{align-items:center;cursor:default}.recurring-icon{align-items:center;color:var(--text-light);display:flex;flex-shrink:0}.sidebar-recurring-info{display:flex;flex:1 1;flex-direction:column;gap:1px;min-width:0;text-align:left}.sidebar-recurring-title{color:var(--text-muted);font-size:.855rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-recurring-days{color:var(--text-light);font-size:.65rem;letter-spacing:.02em}@media (max-width:768px){.sidebar{height:100vh;left:-280px;position:fixed;top:0;transition:left .25s ease;width:270px;z-index:50}.sidebar.open{left:0}.sidebar-backdrop{background:#00000059;inset:0;position:fixed;z-index:49}}.header{padding:36px 0 24px}.header h2{font-family:var(--font-display);font-size:2rem;font-weight:400;letter-spacing:-.02em;line-height:1.1}.header h2 em{color:var(--accent);font-style:italic}.header-meta{align-items:center;color:var(--text-muted);display:flex;font-size:.82rem;gap:16px;margin-top:8px}.header-meta .dot{background:var(--border);border-radius:50%;height:4px;width:4px}.stats{display:flex;gap:8px;margin-bottom:20px}.stat{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-sm);flex:1 1;padding:12px 14px;text-align:center}.stat-number{font-family:var(--font-display);font-size:1.5rem;line-height:1}.stat-label{color:var(--text-muted);font-size:.65rem;letter-spacing:.08em;margin-top:3px;text-transform:uppercase}@media (max-width:768px){.header{padding:20px 0 16px}.header h2{font-size:1.6rem}.stats{gap:6px}.stat{padding:10px 8px}.stat-number{font-size:1.3rem}.header-admin,.header-logout,.header-user{display:none}}.header-user{font-size:.8rem}.header-logout,.header-user{color:#888;color:var(--text-muted,#888)}.header-logout{background:none;border:1px solid #333;border:1px solid var(--border,#333);border-radius:6px;cursor:pointer;font-size:.75rem;margin-left:4px;padding:3px 8px;transition:all .15s}.header-logout:hover{border-color:#ef5350;color:#ef5350}.add-form{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius);box-shadow:var(--shadow-sm);margin-bottom:20px;padding:18px;transition:box-shadow var(--transition)}.add-form:focus-within{border-color:var(--border);box-shadow:var(--shadow-md)}.add-form-row{align-items:center;display:flex;gap:10px}.add-form input[type=text]{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);flex:1 1;font-family:var(--font-body);font-size:.9rem;outline:none;padding:9px 12px;transition:var(--transition)}.add-form input[type=text]:focus{background:var(--bg-card);border-color:var(--accent)}.add-form input[type=text]::placeholder{color:var(--text-light)}.add-form-extras{align-items:center;display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.add-form-extras input[type=text]{background:var(--bg);border:1px solid var(--border-light);border-radius:var(--radius-sm);color:var(--text);flex:1 1;font-family:var(--font-body);font-size:.82rem;min-width:120px;outline:none;padding:7px 10px;transition:var(--transition)}.add-form-extras input:focus{border-color:var(--accent)}.form-select{appearance:none;-webkit-appearance:none;background:var(--bg);background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg width='10' height='6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='m1 1 4 4 4-4' stroke='%237a7570' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");background-position:right 8px center;background-repeat:no-repeat;border:1px solid var(--border-light);border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;font-family:var(--font-body);font-size:.78rem;outline:none;padding:7px 26px 7px 10px}input[type=date].form-select,input[type=time].form-select{appearance:auto;-webkit-appearance:auto;background-image:none;cursor:text;padding:7px 10px}input[type=time].form-select:disabled{cursor:not-allowed;opacity:.4}.btn-add{background:var(--accent);border:none;border-radius:var(--radius-sm);color:#fff;cursor:pointer;font-family:var(--font-body);font-size:.82rem;font-weight:600;padding:9px 18px;transition:var(--transition);white-space:nowrap}.btn-add:hover{background:var(--accent-hover)}.btn-add:active{transform:scale(.97)}.form-date-label{display:flex;flex-direction:column;gap:2px}.form-date-hint{color:var(--text-light);font-size:.65rem;letter-spacing:.06em;text-transform:uppercase}@media (max-width:768px){.add-form-row{flex-direction:column}.add-form-row .btn-add,.add-form-row input[type=text]{width:100%}}.todo-item{align-items:flex-start;animation:slideIn .3s ease;background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius);display:flex;gap:12px;padding:14px 16px;transition:var(--transition)}.todo-item:hover{border-color:var(--border);box-shadow:var(--shadow-sm)}.todo-item.completed{opacity:.5}.todo-item.completed .todo-title{color:var(--text-muted);text-decoration:line-through}@keyframes slideIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.todo-check{flex-shrink:0;height:20px;margin-top:2px;position:relative;width:20px}.todo-check input{cursor:pointer;height:100%;opacity:0;position:absolute;width:100%;z-index:1}.todo-check .checkmark{align-items:center;border:2px solid var(--border);border-radius:5px;display:flex;height:20px;justify-content:center;transition:var(--transition);width:20px}.todo-check input:checked+.checkmark{background:var(--success);border-color:var(--success)}.todo-check .checkmark svg{opacity:0;transition:var(--transition)}.todo-check input:checked+.checkmark svg{opacity:1}.todo-content{flex:1 1;min-width:0}.todo-title{font-size:.9rem;font-weight:500;word-break:break-word}.todo-desc{color:var(--text-muted);font-size:.78rem;margin-top:2px;word-break:break-word}.todo-meta{align-items:center;display:flex;flex-wrap:wrap;gap:6px;margin-top:5px}.priority-badge{border-radius:100px;font-size:.6rem;font-weight:600;letter-spacing:.05em;padding:2px 7px;text-transform:uppercase}.priority-badge.high{background:#fdf0ed;color:var(--priority-high)}.priority-badge.medium{background:#fdf6ed;color:var(--priority-medium)}.priority-badge.low{background:#eef6f1;color:var(--priority-low)}.cat-badge{border:1px solid var(--border-light);border-radius:100px;color:var(--text-muted)}.cat-badge,.recurring-badge{font-size:.6rem;font-weight:500;padding:2px 7px}.recurring-badge{align-items:center;background:#e8f4f8;border-radius:100px;color:#2a7b9b;display:inline-flex;gap:3px}.todo-date{color:var(--text-light);font-size:.68rem}.due-badge{background:#f0f4ff;border-radius:100px;color:#4a6fa5;font-size:.6rem;font-weight:500;padding:2px 7px}.due-badge.overdue{background:#fdf0ed;color:var(--accent)}.due-badge.today{background:#fff8e1;color:#b07d00}.due-badge.soon{background:#eef6f1;color:var(--priority-low)}.time-left-badge{animation:slideIn .2s ease;background:#eef3ff;border-radius:100px;color:#3a5fa8;font-size:.6rem;font-weight:600;padding:2px 7px}.time-left-badge.overdue{background:#fdf0ed;color:var(--priority-high)}.btn-icon.clock.active,.btn-icon.clock:hover{background:#eef3ff;color:#3a5fa8}.todo-item-editing{align-items:stretch}.edit-form{display:flex;flex:1 1;flex-direction:column;gap:8px}.edit-title{border:1px solid var(--accent);border-radius:var(--radius-sm);font-size:.9rem;font-weight:500}.edit-desc,.edit-title{background:var(--bg);color:var(--text);font-family:var(--font-body);outline:none;padding:6px 10px;width:100%}.edit-desc{border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.82rem}.edit-desc:focus{border-color:var(--accent)}.edit-row{display:flex;flex-wrap:wrap;gap:8px}.edit-row .form-select{flex:1 1;min-width:100px}.edit-row input[type=date].form-select,.edit-row input[type=time].form-select{appearance:auto;-webkit-appearance:auto;background-image:none;padding:7px 10px}.edit-row input[type=time].form-select:disabled{cursor:not-allowed;opacity:.4}.edit-actions{display:flex;gap:8px;justify-content:flex-end}.btn-cancel-edit,.btn-save-edit{border-radius:var(--radius-sm);cursor:pointer;font-family:inherit;font-size:.82rem;font-weight:500;padding:5px 14px;transition:var(--transition)}.btn-cancel-edit{background:var(--bg);border:1px solid var(--border);color:var(--text-muted)}.btn-cancel-edit:hover{border-color:var(--text-muted)}.btn-save-edit{background:var(--accent);border:none;color:#fff}.btn-save-edit:hover{filter:brightness(1.1)}.btn-icon.edit:hover{background:#e8f0ff;color:#4a6fa5}.btn-icon{align-items:center;background:#0000;border:none;border-radius:var(--radius-sm);color:var(--text-light);cursor:pointer;display:flex;height:30px;justify-content:center;transition:var(--transition);width:30px}.btn-icon:hover{background:var(--bg);color:var(--text-muted)}.btn-icon.delete:hover{background:var(--accent-soft);color:var(--accent)}@media (max-width:768px){.todo-item{gap:10px;padding:12px}}.search-bar{margin-bottom:14px;position:relative}.search-bar input{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-sm);color:var(--text);font-family:var(--font-body);font-size:.82rem;outline:none;padding:9px 12px 9px 36px;transition:var(--transition);width:100%}.search-bar input:focus{border-color:var(--border);box-shadow:var(--shadow-sm)}.search-bar .search-icon{color:var(--text-light);left:11px;position:absolute;top:50%;transform:translateY(-50%)}.filters{-webkit-overflow-scrolling:touch;display:flex;gap:6px;margin-bottom:16px;overflow-x:auto;scrollbar-width:none}.filters::-webkit-scrollbar{display:none}.filter-btn{background:#0000;border:1px solid var(--border);border-radius:100px;color:var(--text-muted);cursor:pointer;font-family:var(--font-body);font-size:.78rem;font-weight:500;padding:6px 12px;transition:var(--transition);white-space:nowrap}.filter-btn:hover{border-color:var(--text-muted);color:var(--text)}.filter-btn.active{background:var(--text);border-color:var(--text);color:var(--bg)}.clear-completed{align-items:center;background:none;border:none;color:var(--text-light);cursor:pointer;display:inline-flex;font-family:var(--font-body);font-size:.75rem;gap:6px;margin-bottom:10px;padding:5px 0;transition:var(--transition)}.clear-completed:hover{color:var(--accent)}.todo-list{display:flex;flex-direction:column;gap:5px;padding-bottom:80px}.empty-state{color:var(--text-muted);padding:50px 20px;text-align:center}.empty-state .empty-icon{font-size:2.5rem;margin-bottom:12px;opacity:.4}.empty-state h3{font-family:var(--font-display);font-size:1.2rem;font-weight:400;margin-bottom:4px}.empty-state p{font-size:.82rem}.modal-overlay{align-items:center;animation:fadeIn .15s ease;background:#0006;display:flex;inset:0;justify-content:center;position:fixed;z-index:100}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-md);max-width:90vw;padding:24px;width:360px}.modal h3{font-size:1rem;font-weight:600;margin-bottom:4px}.modal-subtext{color:var(--text-light);font-size:.8rem;margin-bottom:16px}.modal-field{margin-bottom:12px}.modal-field label{color:var(--text-muted);display:block;font-size:.75rem;font-weight:500;margin-bottom:4px}.modal-field input{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:var(--font-body);font-size:.9rem;outline:none;padding:9px 12px;width:100%}.modal-field input:focus{border-color:var(--accent)}.modal-field select{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:var(--font-body);font-size:.9rem;outline:none;padding:9px 12px;width:100%}.modal-field select:focus{border-color:var(--accent)}.modal-colors{display:flex;flex-wrap:wrap;gap:6px;padding:4px 0}.modal-color{border:2px solid #0000;border-radius:6px;cursor:pointer;height:28px;transition:var(--transition);width:28px}.modal-color.active{border-color:var(--text);transform:scale(1.1)}.modal-actions{display:flex;gap:8px;margin-top:16px}.modal-actions button{border-radius:var(--radius-sm);cursor:pointer;flex:1 1;font-family:inherit;font-size:.85rem;font-weight:500;padding:9px 16px;transition:var(--transition)}.btn-cancel{background:var(--bg);border:1px solid var(--border);color:var(--text-muted)}.btn-cancel:hover{border-color:var(--text-muted)}.btn-confirm{background:var(--accent);border:none;color:#fff}.btn-confirm:hover{filter:brightness(1.1)}.recurrence-modal{width:420px}.optional{color:var(--text-light);font-weight:400}.day-picker{display:flex;gap:5px}.day-btn{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;flex:1 1;font-family:inherit;font-size:.72rem;font-weight:500;padding:7px 4px;transition:var(--transition)}.day-btn:hover{border-color:var(--accent);color:var(--accent)}.day-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.recurrence-selects{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr 1fr}.recurrence-modal select{appearance:none;background:var(--bg) url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12'%3E%3Cpath d='m2 4 4 4 4-4' stroke='%23999' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E") no-repeat right 10px center;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);cursor:pointer;font-family:var(--font-body);font-size:.85rem;outline:none;padding:8px 28px 8px 10px;width:100%}.recurrence-modal select:focus{border-color:var(--accent)}@media (max-width:480px){.recurrence-modal{width:100%}.day-btn{font-size:.65rem;padding:6px 2px}.recurrence-selects{grid-template-columns:1fr}}.calendar-view{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius);overflow:hidden}.cal-nav{align-items:center;border-bottom:1px solid var(--border-light);display:flex;justify-content:space-between;padding:16px 20px}.cal-month-label{font-family:var(--font-display);font-size:1.15rem;font-weight:400}.cal-month-label em{color:var(--text-muted);font-style:normal}.cal-nav-btn{align-items:center;background:none;border:none;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;display:flex;font-size:1.3rem;height:32px;justify-content:center;line-height:1;transition:var(--transition);width:32px}.cal-nav-btn:hover{background:var(--bg-hover);color:var(--text)}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr)}.cal-dow{color:var(--text-light);font-size:.62rem;font-weight:600;letter-spacing:.06em;padding:10px 4px 8px;text-align:center;text-transform:uppercase}.cal-cell,.cal-dow{border-bottom:1px solid var(--border-light)}.cal-cell{border-right:1px solid var(--border-light);cursor:pointer;display:flex;flex-direction:column;gap:5px;min-height:68px;padding:8px 8px 6px;transition:background var(--transition)}.cal-cell:nth-child(7n){border-right:none}.cal-cell:hover:not(.empty){background:var(--bg-hover)}.cal-cell.empty{background:var(--bg);border-right:1px solid var(--border-light);cursor:default}.cal-cell.empty:nth-child(7n){border-right:none}.cal-cell.selected{background:var(--accent-soft)}.cal-day-num{align-items:center;border-radius:50%;color:var(--text-muted);display:flex;flex-shrink:0;font-size:.78rem;font-weight:500;height:22px;justify-content:center;width:22px}.cal-cell.today .cal-day-num{background:var(--accent);color:#fff;font-weight:600}.cal-cell.selected:not(.today) .cal-day-num{color:var(--accent);font-weight:600}.cal-dots{display:flex;flex-wrap:wrap;gap:3px}.cal-dot{border-radius:50%;flex-shrink:0;height:6px;width:6px}.cal-detail{border-top:2px solid var(--border-light);padding:20px}.cal-detail-header{color:var(--text);font-size:.875rem;font-weight:600;margin-bottom:14px}.cal-detail-empty{color:var(--text-light);font-size:.82rem;font-style:italic}.cal-detail-list{display:flex;flex-direction:column;gap:8px}.cal-detail-item{align-items:flex-start;background:var(--bg);border:1px solid var(--border-light);border-radius:var(--radius-sm);display:flex;gap:10px;padding:10px 14px;transition:var(--transition)}.cal-detail-item:hover{border-color:var(--border)}.cal-detail-item.done{opacity:.5}.cal-detail-item.projected{border-style:dashed}.cal-detail-dot{border-radius:50%;flex-shrink:0;height:8px;margin-top:4px;width:8px}.cal-detail-text{display:flex;flex:1 1;flex-direction:column;gap:2px;min-width:0}.cal-detail-title{color:var(--text);font-size:.875rem;font-weight:500}.cal-detail-item.done .cal-detail-title{color:var(--text-muted);text-decoration:line-through}.cal-detail-desc{color:var(--text-muted);font-size:.75rem}.cal-detail-tags{align-items:center;display:flex;flex-shrink:0;gap:5px}.cal-tag{border-radius:100px;font-size:.58rem;font-weight:600;letter-spacing:.04em;padding:2px 7px;text-transform:uppercase}.cat-tag{background:#0000;border:1px solid;opacity:.8}.rec-tag{background:#e8f4f8;color:#2a7b9b}.done-tag{background:#eef6f1;color:var(--priority-low)}@media (max-width:600px){.cal-cell{min-height:50px;padding:5px 4px 4px}.cal-dow{font-size:.55rem;padding:8px 2px 6px}.cal-day-num{font-size:.7rem;height:18px;width:18px}.cal-dot{height:5px;width:5px}.cal-detail{padding:14px}}.ext-cal-backdrop{background:#00000040;inset:0;position:fixed;z-index:59}.ext-cal-panel{background:var(--bg-card);border-left:1px solid var(--border);box-shadow:-4px 0 24px #00000014;display:flex;flex-direction:column;height:100vh;overflow:hidden;position:fixed;right:-340px;top:0;transition:right .28s cubic-bezier(.4,0,.2,1);width:320px;z-index:60}.ext-cal-panel.open{right:0}.ext-cal-header{align-items:center;border-bottom:1px solid var(--border-light);display:flex;flex-shrink:0;justify-content:space-between;padding:20px 20px 16px}.ext-cal-title{color:var(--text);font-family:var(--font-display);font-size:1.15rem;font-weight:400}.ext-cal-close{color:var(--text-light)}.ext-cal-list{display:flex;flex:1 1;flex-direction:column;gap:4px;overflow-y:auto;padding:12px 16px}.ext-cal-empty{color:var(--text-light);font-size:.85rem;padding:32px 0;text-align:center}.ext-cal-item{align-items:center;border-radius:var(--radius-sm);display:flex;gap:6px;padding:2px 4px 2px 0;transition:var(--transition)}.ext-cal-item:hover{background:var(--bg-hover)}.ext-cal-link{align-items:center;border-radius:var(--radius-sm);color:var(--text-muted);display:flex;flex:1 1;gap:8px;min-width:0;padding:8px 10px;text-decoration:none;transition:var(--transition)}.ext-cal-link:hover{color:var(--accent)}.ext-cal-name{flex:1 1;font-size:.875rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ext-cal-link-icon{align-items:center;display:flex;flex-shrink:0;opacity:0;transition:var(--transition)}.ext-cal-link:hover .ext-cal-link-icon{opacity:1}.ext-cal-action{flex-shrink:0;opacity:0;transition:var(--transition)}.ext-cal-item:hover .ext-cal-action{opacity:1}.ext-cal-item-editing{align-items:stretch;background:var(--bg-hover);border-radius:var(--radius-sm);flex-direction:column;gap:6px;padding:8px}.ext-cal-edit-fields{display:flex;flex-direction:column;gap:6px}.ext-cal-edit-actions{display:flex;gap:4px;justify-content:flex-end}.ext-cal-save{color:var(--success)}.ext-cal-save:hover{background:#4a8c6f1f!important;color:var(--success)!important}.ext-cal-form{background:var(--bg-sidebar);border-top:1px solid var(--border-light);display:flex;flex-direction:column;flex-shrink:0;gap:8px;padding:16px}.ext-cal-form-title{color:var(--text-light);font-size:.72rem;font-weight:600;letter-spacing:.08em;margin-bottom:2px;text-transform:uppercase}.ext-cal-error{color:var(--priority-high);font-size:.8rem}.ext-cal-input{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:inherit;font-size:.875rem;outline:none;padding:8px 12px;transition:var(--transition)}.ext-cal-input:focus{border-color:var(--accent)}.ext-cal-input::placeholder{color:var(--text-light)}.ext-cal-submit{align-self:flex-start;background:var(--accent);border:none;border-radius:var(--radius-sm);color:#fff;cursor:pointer;font-family:inherit;font-size:.875rem;font-weight:500;padding:9px 16px;transition:var(--transition)}.ext-cal-submit:hover{background:var(--accent-hover)}@media (max-width:480px){.ext-cal-panel{right:-100vw;width:100vw}}.login-bg{align-items:center;background:#1a1a1a;background:var(--bg-primary,#1a1a1a);display:flex;justify-content:center;min-height:100vh;padding:24px}.login-card{background:#242424;background:var(--surface,#242424);border:1px solid #333;border:1px solid var(--border,#333);border-radius:16px;box-shadow:0 20px 60px #0006;max-width:400px;padding:40px 36px;width:100%}.login-logo{gap:10px;margin-bottom:28px}.login-logo,.login-logo-icon{align-items:center;display:flex}.login-logo-icon{background:#26a69a;background:var(--accent,#26a69a);border-radius:10px;color:#fff;font-size:18px;font-weight:700;height:36px;justify-content:center;width:36px}.login-logo-text{font-family:Georgia,serif;font-family:var(--font-display,Georgia,serif);font-size:1.3rem;font-weight:600}.login-logo-text,.login-title{color:#f0f0f0;color:var(--text-primary,#f0f0f0)}.login-title{font-size:1.5rem;font-weight:700;margin:0 0 6px}.login-sub{color:#888;color:var(--text-muted,#888);font-size:.9rem;margin:0 0 24px}.login-form{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.login-label{color:#aaa;color:var(--text-secondary,#aaa);font-size:.8rem;font-weight:600;letter-spacing:.05em;margin-top:10px;text-transform:uppercase}.login-input{background:#1a1a1a;background:var(--bg-primary,#1a1a1a);border:1px solid #333;border:1px solid var(--border,#333);border-radius:8px;color:#f0f0f0;color:var(--text-primary,#f0f0f0);font-size:.95rem;outline:none;padding:10px 14px;transition:border-color .15s}.login-input:focus{border-color:#26a69a;border-color:var(--accent,#26a69a)}.login-input-mono{font-family:monospace;font-size:.82rem;letter-spacing:.02em}.login-error{background:#ef53501f;border:1px solid #ef535066;border-radius:8px;color:#ef5350}.login-error,.login-info{font-size:.85rem;margin-top:6px;padding:9px 13px}.login-info{background:#26a69a1a;border:1px solid #26a69a4d;border-radius:8px;color:#26a69a;word-break:break-all}.login-btn{background:#26a69a;background:var(--accent,#26a69a);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.95rem;font-weight:600;margin-top:14px;padding:11px;transition:opacity .15s}.login-btn:hover{opacity:.88}.login-btn:disabled{cursor:not-allowed;opacity:.5}.login-link{background:none;border:none;color:#888;color:var(--text-muted,#888);cursor:pointer;display:block;font-size:.85rem;margin-top:4px;padding:6px 0;text-align:center;text-decoration:underline;transition:color .15s;width:100%}.login-link:hover{color:#aaa;color:var(--text-secondary,#aaa)}.admin-overlay{align-items:center;background:#0006;display:flex;inset:0;justify-content:center;padding:24px;position:fixed;z-index:1000}.admin-panel{background:#fff;background:var(--bg,#fff);border-radius:14px;box-shadow:0 20px 60px #0003;display:flex;flex-direction:column;max-height:85vh;max-width:800px;overflow:hidden;width:100%}.admin-header{align-items:center;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border,#e5e7eb);display:flex;justify-content:space-between;padding:20px 24px 16px}.admin-header h2{font-size:1.2rem;font-weight:600;margin:0}.admin-close{background:none;border:none;border-radius:6px;color:#6b7280;color:var(--text-muted,#6b7280);cursor:pointer;font-size:1.1rem;padding:4px 8px}.admin-close:hover{background:#f3f4f6;background:var(--hover,#f3f4f6)}.admin-stats{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border,#e5e7eb);display:flex;gap:0}.admin-stat{border-right:1px solid #e5e7eb;border-right:1px solid var(--border,#e5e7eb);flex:1 1;padding:16px 24px;text-align:center}.admin-stat:last-child{border-right:none}.admin-stat-num{color:#4f46e5;color:var(--accent,#4f46e5);font-size:1.8rem;font-weight:700}.admin-stat-label{color:#6b7280;color:var(--text-muted,#6b7280);font-size:.75rem;letter-spacing:.05em;margin-top:2px;text-transform:uppercase}.admin-error,.admin-loading{color:#6b7280;color:var(--text-muted,#6b7280);padding:32px;text-align:center}.admin-error{color:#ef4444}.admin-table{border-collapse:collapse;display:block;overflow-y:auto;width:100%}.admin-table thead{background:#fff;background:var(--bg,#fff);position:sticky;top:0;z-index:1}.admin-table th{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border,#e5e7eb);color:#6b7280;color:var(--text-muted,#6b7280);font-size:.72rem;letter-spacing:.05em;padding:10px 16px;text-align:left;text-transform:uppercase}.admin-table td{border-bottom:1px solid #f3f4f6;border-bottom:1px solid var(--border,#f3f4f6);font-size:.9rem;padding:12px 16px}.admin-table tr:last-child td{border-bottom:none}.admin-table tr:hover td{background:#f9fafb;background:var(--hover,#f9fafb)}.admin-email{font-weight:500}.admin-date{font-size:.82rem}.admin-date,.admin-num{color:#6b7280;color:var(--text-muted,#6b7280)}.admin-num{text-align:center}.admin-badge{background:none;border:1.5px solid #d1d5db;border:1.5px solid var(--border,#d1d5db);border-radius:20px;color:#6b7280;color:var(--text-muted,#6b7280);cursor:pointer;font-size:.75rem;font-weight:600;padding:3px 10px;transition:all .15s}.admin-badge-on{background:#eef2ff;border-color:#4f46e5;color:#4f46e5}.admin-delete{background:none;border:1.5px solid #fecaca;border-radius:6px;color:#ef4444;cursor:pointer;font-size:.75rem;font-weight:500;padding:3px 10px;transition:all .15s}.admin-delete:hover{background:#fef2f2}.header-admin{background:#eef2ff;border:1px solid #c7d2fe;border-radius:6px;color:#4f46e5;cursor:pointer;font-size:.8rem;font-weight:600;margin-right:4px;padding:4px 10px}.header-admin:hover{background:#e0e7ff}*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f6f3ee;--bg-card:#fff;--bg-sidebar:#f0ede6;--bg-hover:#faf8f5;--text:#1a1a1a;--text-muted:#7a7570;--text-light:#b0a99f;--accent:#2563eb;--accent-hover:#1d4ed8;--accent-soft:#eff6ff;--border:#e8e3dc;--border-light:#f0ece6;--success:#4a8c6f;--priority-high:#c4553a;--priority-medium:#d4963a;--priority-low:#7a9a6b;--shadow-sm:0 1px 3px #0000000a;--shadow-md:0 4px 16px #0000000f;--radius:12px;--radius-sm:8px;--font-display:"Instrument Serif",Georgia,serif;--font-body:"DM Sans",-apple-system,sans-serif;--transition:0.2s cubic-bezier(0.4,0,0.2,1)}html{-webkit-font-smoothing:antialiased;font-size:16px}body{background:#f6f3ee;background:var(--bg);color:#1a1a1a;color:var(--text);font-family:DM Sans,-apple-system,sans-serif;font-family:var(--font-body);line-height:1.5;min-height:100vh}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:#0000}::-webkit-scrollbar-thumb{background:#e8e3dc;background:var(--border);border-radius:3px}.app-layout{display:flex;min-height:100vh}.main{flex:1 1;min-width:0}.main-inner{margin:0 auto;max-width:640px;padding:0 24px env(safe-area-inset-bottom,20px)}.mobile-header{align-items:center;background:#f0ede6;background:var(--bg-sidebar);border-bottom:1px solid #f0ece6;border-bottom:1px solid var(--border-light);display:none;gap:12px;padding:14px 20px}.hamburger{background:none;border:none;color:#1a1a1a;color:var(--text);cursor:pointer;padding:4px}.loading{color:#7a7570;color:var(--text-muted);font-size:.9rem;padding:80px 20px;text-align:center}.spinner{animation:spin .6s linear infinite;border:2px solid #e8e3dc;border-top-color:#2563eb;border:2px solid var(--border);border-radius:50%;border-top-color:var(--accent);height:28px;margin:0 auto 12px;width:28px}@keyframes spin{to{transform:rotate(1turn)}}.error-banner{background:#eff6ff;background:var(--accent-soft);border-radius:8px;border-radius:var(--radius-sm);color:#2563eb;color:var(--accent);font-size:.85rem;margin-bottom:16px;padding:12px 16px}.view-tabs{background:#f0ede6;background:var(--bg-sidebar);border:1px solid #f0ece6;border:1px solid var(--border-light);border-radius:8px;border-radius:var(--radius-sm);display:flex;gap:4px;margin-bottom:20px;padding:3px;width:fit-content}.view-tab{background:none;border:none;border-radius:6px;color:#7a7570;color:var(--text-muted);cursor:pointer;font-family:DM Sans,-apple-system,sans-serif;font-family:var(--font-body);font-size:.82rem;font-weight:500;padding:6px 18px;transition:.2s cubic-bezier(.4,0,.2,1);transition:var(--transition)}.view-tab.active,.view-tab:hover{color:#1a1a1a;color:var(--text)}.view-tab.active{background:#fff;background:var(--bg-card);box-shadow:0 1px 3px #0000000a;box-shadow:var(--shadow-sm)}.main-inner-wide{max-width:820px}.mobile-header-btn{background:none;border:1px solid #e8e3dc;border:1px solid var(--border);border-radius:6px;color:#7a7570;color:var(--text-muted);cursor:pointer;flex-shrink:0;font-family:inherit;font-size:.75rem;padding:4px 8px}.mobile-header-btn:hover{border-color:#2563eb;border-color:var(--accent);color:#2563eb;color:var(--accent)}.mobile-signout:hover{border-color:#ef5350;color:#ef5350}.cat-pills{background:#f0ede6;background:var(--bg-sidebar);border-bottom:1px solid #f0ece6;border-bottom:1px solid var(--border-light);display:none;gap:6px;overflow-x:auto;padding:10px 16px;scrollbar-width:none}.cat-pills::-webkit-scrollbar{display:none}.cat-pill{align-items:center;background:#fff;background:var(--bg-card);border:1px solid #e8e3dc;border:1px solid var(--border);border-radius:100px;color:#7a7570;color:var(--text-muted);cursor:pointer;display:flex;flex-shrink:0;font-family:inherit;font-size:.78rem;gap:5px;padding:5px 12px;transition:.2s cubic-bezier(.4,0,.2,1);transition:var(--transition);white-space:nowrap}.cat-pill:hover{color:#2563eb;color:var(--accent)}.cat-pill.active,.cat-pill:hover{border-color:#2563eb;border-color:var(--accent)}.cat-pill.active{background:#2563eb;background:var(--accent);color:#fff}.cat-pill.active .cat-pill-count{background:#ffffff40;color:#fff}.cat-pill-dot{border-radius:50%;flex-shrink:0;height:7px;width:7px}.cat-pill-count{background:#f6f3ee;background:var(--bg);border-radius:100px;color:#b0a99f;color:var(--text-light);font-size:.65rem;padding:1px 5px}@media (max-width:768px){.cat-pills,.mobile-header{display:flex}}
/*# sourceMappingURL=main.c6314ef1.css.map*/