:root{--petrol-50:#e0f4f7;--petrol-100:#c0e9ef;--petrol-200:#86cfd9;--petrol-300:#4db5c3;--petrol-400:#259bad;--petrol-500:#0c7e8c;--petrol-600:#0c6e7a;--petrol-700:#094f59;--petrol-800:#063640;--petrol-900:#021e25;--neutral-0:#fff;--neutral-50:#f9f9f9;--neutral-100:#f5f5f5;--neutral-200:#e5e5e5;--neutral-300:#d4d4d4;--neutral-400:#a3a3a3;--neutral-500:#898989;--neutral-600:#666;--neutral-700:#444;--neutral-800:#242424;--neutral-900:#111;--color-success:#16a34a;--color-success-light:#dcfce7;--color-warning:#d97706;--color-warning-light:#fef3c7;--color-danger:#dc2626;--color-danger-light:#fee2e2;--color-primary:#0c6e7a;--color-primary-hover:#094f59;--color-primary-active:#063640;--color-primary-light:#e0f4f7;--color-owner-shared:#0c6e7a;--color-owner-user1:#2b7de0;--color-owner-user2:#e07a5f;--color-bg:#fff;--color-bg-subtle:#f9f9f9;--color-fg:#242424;--color-fg-secondary:#898989;--color-fg-muted:#a3a3a3;--color-border:#222a3514;--color-surface:#fff;--color-text:#242424;--color-text-muted:#898989;--color-secondary:#e07a5f;--font-display:"Cal Sans", Georgia, serif;--font-body:"Inter", system-ui, -apple-system, sans-serif;--font-mono:"Roboto Mono", "Courier New", monospace;--text-xs:12px;--text-sm:14px;--text-base:16px;--text-lg:18px;--text-xl:20px;--text-2xl:24px;--text-3xl:32px;--weight-light:300;--weight-regular:400;--weight-medium:500;--weight-semibold:600;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-pill:9999px;--radius:12px;--shadow-card:#131316b3 0px 1px 5px -4px, #222a3514 0px 0px 0px 1px, #222a350d 0px 4px 8px 0px;--shadow-elevated:#131316b3 0px 2px 12px -4px, #222a351a 0px 0px 0px 1px, #222a3514 0px 8px 24px 0px;--shadow-soft:#222a350d 0px 4px 8px;--shadow-petrol:#0c6e7a66 0px 1px 5px -4px, #0c6e7a26 0px 0px 0px 1px, #0c6e7a14 0px 4px 8px 0px;--shadow-btn-highlight:#ffffff26 0px 2px 0px inset;--shadow-md:var(--shadow-card);--shadow-lg:var(--shadow-elevated);--shadow-sm:var(--shadow-soft);--shadow:var(--shadow-card);--transition-fast:all .15s ease;--transition-base:all .2s ease;--transition:.2s ease}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-body);font-size:var(--text-base);font-weight:var(--weight-regular);color:var(--neutral-800);background:var(--neutral-50);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-thumb{background:var(--neutral-200);border-radius:3px}.app-shell{background:#f5f6f8;min-height:100vh;display:flex}.sidebar{background:var(--neutral-0);z-index:10;border-right:1px solid #222a3514;flex-direction:column;flex-shrink:0;width:220px;height:100vh;display:flex;position:sticky;top:0}.sidebar-logo{border-bottom:1px solid #222a3512;padding:22px 20px 18px}.sidebar-logo-name{font-family:var(--font-display);color:var(--neutral-900);letter-spacing:-.2px;font-size:18px;font-weight:600}.sidebar-logo-sub{color:var(--neutral-400);margin-top:2px;font-size:11px}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:12px 10px;display:flex}.nav-item{border-radius:var(--radius-md);font-family:var(--font-body);font-size:13px;font-weight:var(--weight-medium);color:var(--neutral-600);cursor:pointer;transition:var(--transition-fast);text-align:left;background:0 0;border:none;align-items:center;gap:10px;width:100%;padding:9px 12px;text-decoration:none;display:flex}.nav-item:hover{background:var(--neutral-100);color:var(--neutral-800)}.nav-item.active{background:var(--petrol-50);color:var(--color-primary);font-weight:var(--weight-semibold)}.nav-item svg{flex-shrink:0}.sidebar-users{border-top:1px solid #222a3512;flex-direction:column;gap:6px;padding:14px 12px;display:flex}.sidebar-user{border-radius:var(--radius-md);transition:var(--transition-fast);align-items:center;gap:10px;padding:6px 8px;display:flex}.sidebar-user:hover{background:var(--neutral-50)}.user-avatar{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:11px;font-weight:700;display:flex}.user-name{font-size:13px;font-weight:var(--weight-semibold);color:var(--neutral-800);line-height:1.2}.user-status{color:var(--neutral-400);font-size:11px}.sidebar-logout{border-radius:var(--radius-md);font-family:var(--font-body);font-size:12px;font-weight:var(--weight-medium);color:var(--neutral-500);cursor:pointer;transition:var(--transition-fast);background:0 0;border:none;align-items:center;gap:8px;margin-top:4px;padding:8px 10px;display:flex}.sidebar-logout:hover{background:var(--neutral-100);color:var(--neutral-800)}.main-area{background:var(--neutral-0);flex-direction:column;flex:1;min-width:0;display:flex}.page-topbar{background:var(--neutral-0);z-index:20;border-bottom:1px solid #222a3514;flex-shrink:0;justify-content:space-between;align-items:center;height:56px;padding:0 28px;display:flex;position:sticky;top:0}.page-topbar-left{align-items:center;gap:16px;min-width:0;display:flex}.page-topbar-right{flex-shrink:0;align-items:center;gap:10px;display:flex}.page-topbar-title{font-family:var(--font-display);font-size:16px;font-weight:var(--weight-semibold);color:var(--neutral-900);white-space:nowrap}.page-body{padding:var(--space-6) 28px;flex:1;overflow-y:auto}.page-topbar-weeknav{align-items:center;gap:4px;display:flex}.nav-arrow{cursor:pointer;width:28px;height:28px;color:var(--neutral-600);transition:var(--transition-fast);background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;display:flex}.nav-arrow:hover{background:var(--neutral-100)}.week-range{font-size:13px;font-weight:var(--weight-semibold);color:var(--neutral-800);text-align:center;min-width:200px}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:var(--weight-semibold);color:var(--neutral-800);letter-spacing:-.01em;line-height:1.15}h2{font-size:var(--text-2xl)}h3{font-size:var(--text-xl)}h4{font-size:var(--text-lg)}.section-title{font-family:var(--font-display);font-size:var(--text-base);font-weight:var(--weight-semibold);color:var(--neutral-800);margin-bottom:var(--space-3);letter-spacing:-.01em}.btn{align-items:center;gap:var(--space-2);border-radius:var(--radius-md);font-family:var(--font-body);font-size:var(--text-sm);font-weight:var(--weight-semibold);cursor:pointer;transition:var(--transition-base);white-space:nowrap;border:none;padding:8px 16px;line-height:1;text-decoration:none;display:inline-flex}.btn-primary{background:var(--color-primary);color:#fff;box-shadow:var(--shadow-btn-highlight), var(--shadow-petrol)}.btn-primary:hover{background:var(--color-primary-hover);transform:translateY(-1px)}.btn-primary:active{background:var(--color-primary-active);transform:scale(.98)}.btn-ghost{background:var(--neutral-0);color:var(--neutral-800);box-shadow:var(--shadow-card)}.btn-ghost:hover{box-shadow:var(--shadow-elevated);transform:translateY(-1px)}.btn-ghost:active{transform:scale(.98)}.btn-danger{background:var(--color-danger);color:#fff;box-shadow:var(--shadow-btn-highlight)}.btn-danger:hover{opacity:.88;transform:translateY(-1px)}.btn-danger:active{transform:scale(.98)}.btn-touch{min-width:44px;min-height:44px}.card{background:var(--neutral-0);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);padding:var(--space-5);transition:box-shadow .2s}.card:hover{box-shadow:var(--shadow-elevated)}.accent-card{border-left:3px solid var(--color-primary)}.accent-card-user1{border-left:3px solid var(--color-owner-user1)}.accent-card-user2{border-left:3px solid var(--color-owner-user2)}label{font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--neutral-800);margin-bottom:var(--space-1);display:block}input,select,textarea{font-family:var(--font-body);font-size:var(--text-sm);color:var(--neutral-800);background:var(--neutral-0);border-radius:var(--radius-md);width:100%;transition:var(--transition-fast);box-shadow:var(--shadow-card);border:none;outline:none;padding:9px 12px}input::placeholder,textarea::placeholder{color:var(--neutral-400)}input:focus,select:focus,textarea:focus{box-shadow:#0c6e7a40 0px 0px 0px 2px, var(--shadow-card)}input[type=checkbox]{width:auto;box-shadow:none;accent-color:var(--color-primary)}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;padding:var(--space-4);background:#1111117a;justify-content:center;align-items:center;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.modal-card{background:var(--neutral-0);border-radius:var(--radius-xl);width:100%;max-width:440px;box-shadow:var(--shadow-elevated);padding:var(--space-8);animation:.2s slideUp}.modal-card h3{font-family:var(--font-display);font-size:var(--text-xl);margin-bottom:var(--space-5)}.modal-form{gap:var(--space-4);flex-direction:column;display:flex}.modal-actions{gap:var(--space-2);padding-top:var(--space-2);display:flex}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.week-grid{border-radius:var(--radius-lg);background:var(--neutral-0);border:1px solid #222a3517;grid-template-columns:repeat(7,1fr);display:grid;overflow:hidden}.wg-day-hdr{background:#fafafa;border-bottom:1px solid #222a3517;border-right:1px solid #222a3512;justify-content:space-between;align-items:flex-end;padding:12px 14px 10px;transition:background .15s;display:flex}.wg-day-hdr.wg-today{background:var(--color-primary)}.wg-day-hdr.wg-weekend{background:#f7f7f7}.wg-hdr-wd{letter-spacing:.8px;text-transform:uppercase;color:var(--neutral-400);margin-bottom:2px;font-size:10px;font-weight:700}.wg-today .wg-hdr-wd{color:#ffffffa6}.wg-hdr-date{font-family:var(--font-display);color:var(--neutral-900);font-size:20px;font-weight:600;line-height:1}.wg-today .wg-hdr-date{color:#fff}.wg-weekend:not(.wg-today) .wg-hdr-date{color:var(--neutral-400)}.wg-hdr-month{color:#c4c4c4;margin-top:1px;font-size:10px;font-weight:500}.wg-today .wg-hdr-month{color:#ffffff80}.wg-add-btn{cursor:pointer;color:#ccc;width:22px;height:22px;transition:var(--transition-fast);background:0 0;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.wg-add-btn:hover{color:var(--color-primary);background:#0c6e7a1a}.wg-today .wg-add-btn{color:#ffffff80}.wg-today .wg-add-btn:hover{color:#fff;background:#fff3}.wg-section-lbl{letter-spacing:.9px;text-transform:uppercase;color:#b0b0b0;background:#f5f6f8;border-top:1px solid #222a3512;border-bottom:1px solid #222a3512;grid-column:1/-1;padding:7px 14px;font-size:9px;font-weight:800}.wg-cell{border-right:1px solid #222a350d;min-height:80px;padding:10px 12px;transition:background .1s}.wg-cell.wg-today-col{background:#0c6e7a05}.wg-cell.wg-weekend-col{background:#fafafa}.wg-cell.wg-cell-last{border-bottom:none}.event-pill{cursor:pointer;transition:var(--transition-fast);border-radius:6px;align-items:center;gap:5px;margin-bottom:3px;padding:5px 8px;display:flex}.event-pill:hover{filter:brightness(.93)}.event-pill:active{transform:scale(.98)}.ep-dot{border-radius:50%;flex-shrink:0;width:5px;height:5px}.ep-title{color:var(--neutral-800);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:12px;font-weight:600;overflow:hidden}.ep-time{color:var(--neutral-500);flex-shrink:0;font-size:10px}.dc-empty{color:var(--neutral-300);font-size:11px;font-style:italic}.dog-slot-row{cursor:pointer;transition:var(--transition-fast);border-radius:6px;justify-content:space-between;align-items:center;margin-bottom:3px;padding:4px 7px;display:flex}.dog-slot-row:hover{filter:brightness(.93)}.dog-slot-row:active{transform:scale(.98)}.dsr-left{align-items:center;gap:5px;display:flex}.dsr-label{color:#555;font-size:10px;font-weight:600}.dsr-badge{border-radius:var(--radius-pill);padding:2px 6px;font-size:10px;font-weight:700}.meal-row{cursor:pointer;transition:var(--transition-fast);border-radius:6px;align-items:baseline;gap:6px;margin-bottom:3px;padding:4px 7px;display:flex}.meal-row:hover{background:#f0f0f0}.mr-label{color:#b0b0b0;letter-spacing:.4px;flex-shrink:0;font-size:9px;font-weight:700}.mr-name{color:var(--neutral-800);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:12px;font-weight:500;overflow:hidden}.mr-empty{color:var(--neutral-300);font-size:11px;font-style:italic}.legend-bar{background:var(--neutral-0);border-bottom:1px solid #222a350f;align-items:center;gap:20px;padding:8px 28px;display:flex}.legend-item{color:var(--neutral-600);align-items:center;gap:6px;font-size:12px;display:flex}.legend-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.legend-hint{color:var(--neutral-300);margin-left:auto;font-size:11px}.today-btn{background:var(--neutral-0);color:#444;cursor:pointer;transition:var(--transition-fast);font-size:12px;font-weight:600;font-family:var(--font-body);border:1.5px solid #222a351f;border-radius:7px;padding:6px 14px}.today-btn:hover{background:var(--neutral-100)}.add-btn{border-radius:var(--radius-md);background:var(--color-primary);color:#fff;cursor:pointer;transition:var(--transition-fast);font-size:13px;font-weight:600;font-family:var(--font-body);border:none;align-items:center;gap:6px;padding:8px 16px;display:flex}.add-btn:hover{background:var(--color-primary-hover)}.add-btn:active{transform:scale(.97)}.form-label{letter-spacing:.6px;text-transform:uppercase;color:var(--neutral-500);margin-bottom:6px;font-size:10px;font-weight:700;display:block}.form-input{border-radius:var(--radius-md);width:100%;font-family:var(--font-body);color:var(--neutral-800);background:var(--neutral-0);transition:var(--transition-fast);border:1.5px solid #222a351f;padding:10px 14px;font-size:14px}.form-input:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 3px #0c6e7a1f}.modal-box{background:var(--neutral-0);border-radius:var(--radius-xl);width:100%;max-width:480px;box-shadow:var(--shadow-elevated);flex-direction:column;gap:14px;padding:22px 24px;animation:.2s slideUp;display:flex}.modal-tabs{background:var(--neutral-100);border-radius:var(--radius-md);gap:4px;padding:4px;display:flex}.modal-tab{border-radius:calc(var(--radius-md) - 2px);font-family:var(--font-body);color:var(--neutral-500);cursor:pointer;transition:var(--transition-fast);background:0 0;border:none;flex:1;padding:8px 12px;font-size:13px;font-weight:600}.modal-tab.active{background:var(--neutral-0);color:var(--color-primary);box-shadow:0 1px 2px #0000000f}.modal-title{font-family:var(--font-display);color:var(--neutral-900);margin:0;font-size:17px;font-weight:600}.modal-subtitle{font-family:var(--font-body);color:var(--neutral-500);text-transform:capitalize;font-size:13px;font-weight:400}.form-field{flex-direction:column;gap:6px;display:flex}.form-field-row{flex-direction:row;align-items:flex-end;gap:12px}.form-checkbox{color:var(--neutral-700);cursor:pointer;white-space:nowrap;align-items:center;gap:6px;padding-bottom:10px;font-size:13px;display:flex}.person-btns{flex-wrap:wrap;gap:6px;display:flex}.person-btn{border-radius:var(--radius-md);background:var(--neutral-0);font-family:var(--font-body);color:var(--neutral-600);cursor:pointer;transition:var(--transition-fast);border:1.5px solid #222a351f;padding:8px 14px;font-size:13px;font-weight:600}.person-btn:hover{background:var(--neutral-50)}.type-btns{flex-wrap:wrap;gap:6px;display:flex}.type-btn{border-radius:var(--radius-pill);background:var(--neutral-0);font-family:var(--font-body);color:var(--neutral-600);cursor:pointer;transition:var(--transition-fast);border:1.5px solid #222a351f;align-items:center;gap:6px;padding:6px 12px;font-size:12px;font-weight:600;display:inline-flex}.type-btn:hover{background:var(--neutral-50)}.type-dot{border-radius:50%;width:7px;height:7px}.meal-suggestions{flex-wrap:wrap;gap:6px;display:flex}.meal-sug{border-radius:var(--radius-pill);background:var(--neutral-100);color:var(--neutral-700);cursor:pointer;transition:var(--transition-fast);padding:6px 12px;font-size:12px}.meal-sug:hover{background:var(--petrol-50);color:var(--color-primary)}.modal-actions{align-items:center;gap:8px;padding-top:6px;display:flex}.mbtn{border-radius:var(--radius-md);font-family:var(--font-body);cursor:pointer;transition:var(--transition-fast);border:none;align-items:center;gap:5px;padding:9px 16px;font-size:13px;font-weight:600;display:inline-flex}.mbtn-cancel{background:var(--neutral-100);color:var(--neutral-700)}.mbtn-cancel:hover{background:var(--neutral-200)}.mbtn-save{background:var(--color-primary);color:#fff}.mbtn-save:hover{background:var(--color-primary-hover)}.mbtn-del{color:var(--color-danger,#dc2626);background:0 0;padding:9px 12px}.mbtn-del:hover{background:#dc262614}.year-wrap{padding:24px 28px}.months-grid{grid-template-columns:repeat(4,1fr);gap:14px;display:grid}@media (width<=1200px){.months-grid{grid-template-columns:repeat(3,1fr)}}@media (width<=900px){.months-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=600px){.months-grid{grid-template-columns:1fr}}.month-card{background:var(--neutral-0);border-radius:var(--radius-lg);transition:var(--transition-fast);border:1.5px solid #222a3514;padding:14px}.month-card-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.month-card-name{color:var(--neutral-800);text-transform:capitalize;font-size:13px;font-weight:700}.month-card-dots{gap:3px;display:flex}.month-card-dot{border-radius:50%;width:6px;height:6px}.mini-cal{grid-template-columns:repeat(7,1fr);gap:1px;display:grid}.mini-cal-hdr{text-align:center;color:#ccc;letter-spacing:.3px;padding:2px 0;font-size:8px;font-weight:700}.mini-cal-day{aspect-ratio:1;color:var(--neutral-500);cursor:pointer;transition:var(--transition-fast);border-radius:50%;justify-content:center;align-items:center;font-size:10px;display:flex;position:relative}.mini-cal-day:hover{background:var(--neutral-100)}.mini-cal-day.mcd-has{color:var(--neutral-800);font-weight:700}.mini-cal-day.mcd-today{background:var(--color-primary);color:#fff;font-weight:700}.mini-cal-day.mcd-today:hover{background:var(--color-primary-hover)}.mini-cal-day.mcd-selected{background:var(--petrol-50);color:var(--color-primary);font-weight:700}.mini-cal-day.mcd-we{color:#d4d4d4}.mini-cal-day.mcd-holiday{color:#d97706}.mini-cal-day .mcd-dot{border-radius:50%;width:3px;height:3px;position:absolute;bottom:2px;left:50%;transform:translate(-50%)}.year-day-panel{background:var(--neutral-0);border-radius:var(--radius-lg);border:1.5px solid #222a3514;max-width:560px;margin-top:24px;padding:16px 20px}.year-day-panel-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.year-day-panel-date{font-family:var(--font-display);color:var(--neutral-900);text-transform:capitalize;font-size:15px;font-weight:600}.year-day-item{border-radius:var(--radius-md);background:var(--neutral-50);cursor:pointer;transition:var(--transition-fast);align-items:center;gap:10px;margin-bottom:6px;padding:8px 12px;display:flex}.year-day-item:hover{filter:brightness(.95)}.year-day-holiday{cursor:default;background:#fef3c7}.year-day-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.year-day-title{color:var(--neutral-800);flex:1;font-size:13px;font-weight:600}.year-day-time{color:var(--neutral-500);font-size:11px}.year-day-person{font-size:11px;font-weight:600}.year-day-empty{color:var(--neutral-400);padding:8px 0;font-size:13px;font-style:italic}.day-cell{background:var(--neutral-0);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);padding:var(--space-2) var(--space-3);cursor:default;min-height:120px;transition:box-shadow .15s}.day-cell-today{background:var(--petrol-50);box-shadow:0 0 0 1.5px #0c6e7a33,0 4px 8px #0c6e7a14}.day-cell-weekend{background:var(--neutral-50)}.day-cell-label{font-size:var(--text-xs);font-weight:var(--weight-semibold);color:var(--neutral-500);margin-bottom:var(--space-2);letter-spacing:.02em;text-transform:uppercase}.day-cell-label-today{color:var(--color-primary)}.day-cell-label-weekend{color:var(--color-owner-user2)}.day-cell-actions{gap:var(--space-1);margin-top:var(--space-2);display:flex}.day-cell-add-btn{font-family:var(--font-body);font-size:11px;font-weight:var(--weight-medium);color:var(--neutral-400);cursor:pointer;border-radius:var(--radius-sm);transition:var(--transition-fast);text-align:center;background:0 0;border:none;flex:1;padding:4px 2px}.day-cell-add-btn:hover{color:var(--neutral-700);background:#222a350d}.task-chip{border-radius:var(--radius-sm);font-size:11px;font-weight:var(--weight-medium);cursor:pointer;color:#fff;align-items:center;gap:4px;margin-bottom:3px;padding:3px 7px;transition:opacity .15s;display:flex}.task-chip:hover{opacity:.85}.task-chip-completed{opacity:.45}.task-chip-completed span:last-child{text-decoration:line-through}.task-chip-user1{background:var(--color-owner-user1)}.task-chip-user2{background:var(--color-owner-user2)}.task-chip-unassigned{background:var(--neutral-400)}.current-time-indicator{border-top:2px solid var(--color-danger);align-items:center;margin:2px -8px 6px;display:flex;position:relative}.current-time-indicator:before{content:"";background:var(--color-danger);border-radius:50%;width:8px;height:8px;position:absolute;top:-5px;left:0}.current-time-label{font-size:10px;font-family:var(--font-mono);color:var(--color-danger);font-weight:var(--weight-semibold);margin-top:-1px;margin-left:12px;line-height:1}.progress-bar{background:var(--neutral-100);border-radius:var(--radius-pill);height:5px;margin-top:var(--space-2);overflow:hidden}.progress-fill{border-radius:var(--radius-pill);background:var(--color-primary);height:100%;transition:width .5s}.check-item{align-items:center;gap:var(--space-3);padding:9px var(--space-3);border-radius:var(--radius-md);cursor:pointer;transition:var(--transition-fast);display:flex}.check-item:hover{background:var(--neutral-50)}.check-item.checked .check-label{color:var(--neutral-400);text-decoration:line-through}.check-box{border-radius:var(--radius-sm);border:1.5px solid var(--neutral-300);background:var(--neutral-0);width:20px;height:20px;transition:var(--transition-fast);flex-shrink:0;justify-content:center;align-items:center;font-size:11px;display:flex}.check-item:hover .check-box{border-color:var(--color-primary)}.check-item.checked .check-box{background:var(--color-success);border-color:var(--color-success);color:#fff}.badge{border-radius:var(--radius-pill);font-size:var(--text-xs);font-weight:var(--weight-semibold);align-items:center;padding:2px 9px;display:inline-flex}.badge-petrol{background:var(--petrol-50);color:var(--petrol-700)}.badge-neutral{background:var(--neutral-100);color:var(--neutral-700)}.badge-success{background:var(--color-success-light);color:var(--color-success)}.badge-danger{background:var(--color-danger-light);color:var(--color-danger)}.lists-page{gap:var(--space-5);min-height:calc(100vh - 120px);display:flex}.list-sidebar{background:var(--neutral-0);border-radius:var(--radius-lg);width:240px;box-shadow:var(--shadow-card);flex-direction:column;flex-shrink:0;display:flex;overflow:hidden}.list-sidebar-header{padding:var(--space-4);border-bottom:1px solid #222a350f}.list-sidebar-header h3{font-family:var(--font-display);font-size:var(--text-base);font-weight:var(--weight-semibold);color:var(--neutral-800)}.list-sidebar-items{padding:var(--space-2);flex-direction:column;flex:1;gap:2px;display:flex;overflow-y:auto}.list-sidebar-item{align-items:center;gap:var(--space-2);border-radius:var(--radius-md);cursor:pointer;transition:var(--transition-fast);font-size:var(--text-sm);font-weight:var(--weight-regular);color:var(--neutral-600);text-align:left;background:0 0;border:none;width:100%;padding:8px 10px;display:flex}.list-sidebar-item:hover{background:var(--neutral-50);color:var(--neutral-900)}.list-sidebar-item-active{background:var(--petrol-50);color:var(--petrol-700);font-weight:var(--weight-medium)}.list-sidebar-item-active:hover{background:var(--petrol-100)}.list-sidebar-item-icon{font-size:15px;line-height:1}.list-sidebar-item-name{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.list-sidebar-item-count{font-size:var(--text-xs);font-weight:var(--weight-semibold);font-family:var(--font-body);color:var(--neutral-400);background:var(--neutral-100);border-radius:var(--radius-pill);text-align:center;min-width:20px;padding:1px 6px}.list-sidebar-item-active .list-sidebar-item-count{color:var(--petrol-700);background:#0c6e7a1f}.list-sidebar-add-btn{margin:var(--space-2);border:1.5px dashed var(--neutral-200);border-radius:var(--radius-md);color:var(--neutral-400);cursor:pointer;font-size:var(--text-sm);font-family:var(--font-body);transition:var(--transition-fast);background:0 0;padding:8px}.list-sidebar-add-btn:hover{border-color:var(--color-primary);color:var(--color-primary);background:var(--petrol-50)}.list-sidebar-new-form{padding:var(--space-2);position:relative;overflow:visible}.list-sidebar-archive-toggle{padding:var(--space-3);color:var(--neutral-400);cursor:pointer;font-size:var(--text-xs);font-family:var(--font-body);transition:var(--transition-fast);text-align:center;background:0 0;border:none;border-top:1px solid #222a350f;width:100%}.list-sidebar-archive-toggle:hover{color:var(--color-primary);background:var(--neutral-50)}.lists-page-detail{flex:1;min-width:0}.lists-page-empty{height:100%;color:var(--neutral-400);font-size:var(--text-sm);justify-content:center;align-items:center;gap:var(--space-2);flex-direction:column;display:flex}.list-detail{background:var(--neutral-0);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);overflow:hidden}.list-detail-header{padding:var(--space-4) var(--space-5);border-bottom:1px solid #222a350f;justify-content:space-between;align-items:center;display:flex}.list-detail-header h3{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--weight-semibold);color:var(--neutral-800)}.list-detail-add-form{gap:var(--space-2);padding:var(--space-4) var(--space-5);background:var(--neutral-50);border-bottom:1px solid #222a350f;display:flex}.list-detail-items{padding:var(--space-2)}.list-detail-empty{text-align:center;color:var(--neutral-400);padding:var(--space-12) var(--space-4);font-size:var(--text-sm)}.list-detail-separator{font-size:var(--text-xs);font-weight:var(--weight-semibold);color:var(--neutral-400);text-transform:uppercase;letter-spacing:.06em;margin-top:var(--space-2);padding:8px 10px}.list-item-row{align-items:flex-start;gap:var(--space-2);padding:10px var(--space-3);border-radius:var(--radius-md);background:var(--neutral-0);box-shadow:var(--shadow-card);margin-bottom:var(--space-1);transition:box-shadow .15s;display:flex}.list-item-row:hover{box-shadow:var(--shadow-elevated)}.list-item-checked{opacity:.5;background:var(--neutral-50);box-shadow:none}.list-item-drag{cursor:grab;color:var(--neutral-300);-webkit-user-select:none;user-select:none;padding-top:2px;font-size:14px}.list-item-drag:active{cursor:grabbing}.list-item-title{font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--neutral-800)}.list-item-title-checked{color:var(--neutral-400);text-decoration:line-through}.list-item-note{color:var(--neutral-500);font-size:var(--text-xs);margin-top:3px}.list-item-link{color:var(--color-primary);font-size:var(--text-xs);margin-top:2px;text-decoration:none;display:inline-block}.list-item-link:hover{text-decoration:underline}.list-item-menu-wrapper{position:relative}.list-item-menu-btn{color:var(--neutral-400);cursor:pointer;border-radius:var(--radius-sm);transition:var(--transition-fast);background:0 0;border:none;padding:2px 6px;font-size:16px;line-height:1}.list-item-menu-btn:hover{background:var(--neutral-100);color:var(--neutral-700)}.list-item-menu{background:var(--neutral-0);border-radius:var(--radius-md);box-shadow:var(--shadow-elevated);z-index:10;min-width:150px;margin-top:4px;position:absolute;top:100%;right:0;overflow:hidden}.list-item-menu button{width:100%;padding:9px var(--space-4);text-align:left;cursor:pointer;font-size:var(--text-sm);font-family:var(--font-body);color:var(--neutral-800);transition:var(--transition-fast);background:0 0;border:none;display:block}.list-item-menu button:hover{background:var(--neutral-50)}.icon-picker-wrapper{position:relative}.icon-picker-trigger{border-radius:var(--radius-md);background:var(--neutral-0);cursor:pointer;width:44px;height:44px;box-shadow:var(--shadow-card);transition:var(--transition-fast);border:none;flex-shrink:0;justify-content:center;align-items:center;font-size:1.2rem;display:flex}.icon-picker-trigger:hover{box-shadow:var(--shadow-elevated)}.icon-picker-dropdown{z-index:100;background:var(--neutral-0);border-radius:var(--radius-lg);box-shadow:var(--shadow-elevated);padding:var(--space-2);width:280px;max-height:320px;position:fixed;overflow-y:auto}.icon-picker-category{margin-bottom:var(--space-2)}.icon-picker-category:last-child{margin-bottom:0}.icon-picker-category-label{font-size:var(--text-xs);font-weight:var(--weight-semibold);text-transform:uppercase;letter-spacing:.06em;color:var(--neutral-400);padding:4px var(--space-1) 6px}.icon-picker-grid{grid-template-columns:repeat(5,1fr);gap:2px;display:grid}.icon-picker-item{aspect-ratio:1;border-radius:var(--radius-md);cursor:pointer;width:100%;transition:var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;font-size:1.1rem;display:flex}.icon-picker-item:hover{background:var(--neutral-100);transform:scale(1.1)}.icon-picker-item-active{background:var(--petrol-50)}.color-picker{gap:var(--space-2);flex-wrap:wrap;display:flex}.color-picker-swatch{cursor:pointer;width:24px;height:24px;transition:var(--transition-fast);outline-offset:2px;border:2px solid #0000;border-radius:50%;outline:2px solid #0000}.color-picker-swatch:hover{transform:scale(1.15)}.color-picker-swatch-active{outline-color:var(--neutral-800)}.toast-container{bottom:var(--space-6);right:var(--space-6);z-index:300;gap:var(--space-2);pointer-events:none;flex-direction:column;display:flex;position:fixed}.toast{align-items:center;gap:var(--space-3);padding:12px var(--space-4);background:var(--neutral-900);color:var(--neutral-0);border-radius:var(--radius-lg);box-shadow:var(--shadow-elevated);pointer-events:auto;border-left:3px solid #0000;min-width:260px;max-width:380px;animation:.25s toastIn;display:flex}.toast-success{border-left-color:var(--color-success)}.toast-error{border-left-color:var(--color-danger)}.toast-info{border-left-color:var(--petrol-400)}.toast-message{font-size:var(--text-sm);font-weight:var(--weight-medium);flex:1}.toast-close{color:var(--neutral-500);cursor:pointer;transition:var(--transition-fast);background:0 0;border:none;padding:0 2px;font-size:18px;line-height:1}.toast-close:hover{color:var(--neutral-0)}@keyframes toastIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.spinner{border:2px solid var(--neutral-200);border-top-color:var(--color-primary);border-radius:50%;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.spinner-center{padding:var(--space-12);justify-content:center;align-items:center;display:flex}.nav-icon{display:none}.nav-label{display:inline}.week-mobile{display:none}.week-desktop{display:block}.day-strip{margin-bottom:var(--space-4);background:var(--neutral-0);padding:var(--space-2) 0;z-index:5;grid-template-columns:repeat(7,1fr);gap:6px;display:grid;position:sticky;top:0}.day-chip{border:1px solid var(--neutral-200);background:var(--neutral-0);border-radius:var(--radius-md);cursor:pointer;flex-direction:column;justify-content:center;align-items:center;gap:2px;padding:8px 2px;transition:all .15s;display:flex}.day-chip .dc-wd{color:var(--neutral-500);text-transform:uppercase;letter-spacing:.04em;font-size:10px;font-weight:600}.day-chip .dc-num{color:var(--neutral-700);font-size:16px;font-weight:700}.day-chip-today{border-color:var(--color-primary);color:var(--color-primary)}.day-chip-today .dc-num{color:var(--color-primary)}.day-chip-selected{background:var(--color-primary);border-color:var(--color-primary)}.day-chip-selected .dc-wd,.day-chip-selected .dc-num{color:#fff}.day-detail-header{margin-bottom:var(--space-3);justify-content:space-between;align-items:center;display:flex}.ddh-title{color:var(--neutral-800);font-size:16px;font-weight:600}.day-section{margin-bottom:var(--space-4)}.day-section-title{color:var(--neutral-500);text-transform:uppercase;letter-spacing:.06em;margin:0 0 var(--space-2) 0;font-size:11px;font-weight:600}.day-section-empty{color:var(--neutral-400);padding:var(--space-3);text-align:center;background:var(--neutral-50);border-radius:var(--radius-md);font-size:13px}.day-section-list{flex-direction:column;gap:6px;display:flex}.day-event-pill{cursor:pointer;text-align:left;border:none;justify-content:flex-start;width:100%}@media (width<=768px){.week-desktop{display:none}.week-mobile{display:block}.app-shell{flex-direction:column}.sidebar{z-index:100;-webkit-backdrop-filter:blur(12px);background:#fffffff5;border-top:1px solid #222a3514;border-right:none;flex-direction:row;width:100%;height:auto;padding:0;position:fixed;inset:auto 0 0}.sidebar-logo,.sidebar-users{display:none}.sidebar-nav{flex-direction:row;flex:1;justify-content:space-around;gap:0;padding:0}.nav-item{border-radius:0;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;min-height:56px;padding:8px 0;font-size:10px}.nav-item:hover{color:var(--neutral-700);background:0 0}.nav-item.active{color:var(--color-primary);background:0 0}.main-area{padding-bottom:56px}.page-body{padding:var(--space-3)}.page-topbar{padding:0 var(--space-3);gap:8px}.page-topbar-left{flex:1;gap:8px;min-width:0}.page-topbar-right{gap:6px}:is(.page-topbar-left:has(.page-topbar-weeknav) .page-topbar-title,.page-topbar-left:has(.year-nav) .page-topbar-title){display:none}.page-topbar-weeknav{flex:1;justify-content:center;gap:2px;min-width:0}.week-range{text-align:center;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:12px;overflow:hidden}.nav-arrow{flex-shrink:0;width:32px;height:32px}.today-btn,.add-btn{padding:6px 10px;font-size:12px}.add-btn .add-btn-label{display:none}.lists-page{flex-direction:column}.list-sidebar{width:100%}.list-sidebar-items{gap:var(--space-1);padding:var(--space-2);flex-direction:row;overflow-x:auto}.list-sidebar-item{white-space:nowrap}.btn{min-height:44px;padding:10px var(--space-4)}.check-box{width:26px;height:26px}.list-item-menu-btn{justify-content:center;align-items:center;min-width:44px;min-height:44px;display:flex}.toast-container{bottom:5rem;right:var(--space-3);left:var(--space-3)}.toast{min-width:auto;max-width:none}}.meals-wrap{grid-template-columns:1fr 340px;align-items:start;gap:16px;display:grid}.meals-week{grid-template-columns:repeat(7,1fr);gap:8px;display:grid}.meal-day-card{border:1px solid var(--neutral-200);background:#fff;border-radius:12px;flex-direction:column;gap:8px;min-height:180px;padding:10px;display:flex}.meal-day-today{border-color:var(--petrol-500);box-shadow:0 0 0 2px var(--petrol-100)}.meal-day-header{border-bottom:1px solid var(--neutral-100);justify-content:space-between;align-items:baseline;padding-bottom:6px;display:flex}.meal-day-name{color:var(--neutral-800);font-size:13px;font-weight:600}.meal-day-date{color:var(--neutral-500);font-variant-numeric:tabular-nums;font-size:12px}.meal-slot-empty,.meal-slot-filled{all:unset;cursor:pointer;border:1px dashed var(--neutral-200);border-radius:8px;flex-direction:column;gap:4px;padding:8px 10px;transition:all .15s;display:flex}.meal-slot-empty{color:var(--neutral-400);flex-direction:row;justify-content:center;align-items:center;gap:8px;min-height:48px}.meal-slot-empty:hover{border-color:var(--petrol-400);color:var(--petrol-600);background:var(--petrol-50)}.meal-slot-filled{color:#0c6e7a;background:#e0f4f7;border:1px solid #0c6e7a22}.meal-slot-filled:hover{background:#cfebef}.meal-slot-lbl{text-transform:uppercase;letter-spacing:.03em;opacity:.8;font-size:11px;font-weight:600}.meal-slot-name{color:var(--neutral-800);word-break:break-word;font-size:13px;font-weight:500;line-height:1.25}.meal-slot-plus{display:inline-flex}.recipe-panel{border:1px solid var(--neutral-200);background:#fff;border-radius:12px;flex-direction:column;gap:10px;max-height:calc(100vh - 96px);padding:14px;display:flex;position:sticky;top:72px}.recipe-panel-header{justify-content:space-between;align-items:center;display:flex}.recipe-panel-header h3{color:var(--neutral-800);margin:0;font-size:15px;font-weight:600}.recipe-search{border:1px solid var(--neutral-200);color:var(--neutral-400);border-radius:8px;align-items:center;gap:6px;padding:0 8px;display:flex}.recipe-search .form-input{background:0 0;border:none;flex:1;padding:6px 0}.recipe-search .form-input:focus{box-shadow:none;outline:none}.recipe-tags-bar{flex-wrap:wrap;gap:4px;display:flex}.recipe-tag{all:unset;cursor:pointer;background:var(--neutral-100);color:var(--neutral-600);border:1px solid #0000;border-radius:999px;padding:3px 8px;font-size:11px}.recipe-tag.active{background:var(--petrol-100);color:var(--petrol-700);border-color:var(--petrol-400)}.recipe-list{flex-direction:column;flex:1;gap:4px;margin:0 -6px;padding:0 6px;display:flex;overflow-y:auto}.recipe-row{border-radius:6px;justify-content:space-between;align-items:center;gap:8px;padding:6px 8px;display:flex}.recipe-row:hover{background:var(--neutral-50)}.recipe-row-main{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.recipe-name{color:var(--neutral-800);font-size:13px;font-weight:500}.recipe-row-tags{flex-wrap:wrap;gap:3px;display:flex}.recipe-tag-pill{background:var(--neutral-100);color:var(--neutral-500);border-radius:999px;padding:1px 6px;font-size:10px}.recipe-row-actions{opacity:0;gap:2px;transition:opacity .1s;display:flex}.recipe-row:hover .recipe-row-actions{opacity:1}.icon-btn{all:unset;cursor:pointer;width:26px;height:26px;color:var(--neutral-500);border-radius:6px;justify-content:center;align-items:center;display:inline-flex}.icon-btn:hover{background:var(--neutral-100);color:var(--neutral-700)}.recipe-empty{text-align:center;color:var(--neutral-400);padding:16px 0;font-size:13px}@media (width<=1100px){.meals-wrap{grid-template-columns:1fr}.recipe-panel{max-height:none;position:static}}@media (width<=768px){.meals-week{grid-template-columns:1fr}}.month-drill-wrap{grid-template-columns:1fr 320px;align-items:start;gap:16px;display:grid}.month-drill-grid{background:var(--neutral-200);border:1px solid var(--neutral-200);border-radius:12px;grid-template-columns:repeat(7,1fr);gap:0;display:grid;overflow:hidden}.month-drill-hdr{background:var(--neutral-50);text-align:center;color:var(--neutral-600);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--neutral-200);padding:8px 6px;font-size:11px;font-weight:600}.month-drill-day{cursor:pointer;border-right:1px solid var(--neutral-100);border-bottom:1px solid var(--neutral-100);background:#fff;flex-direction:column;gap:4px;min-height:108px;padding:6px 6px 4px;transition:background .1s;display:flex}.month-drill-day:hover{background:var(--neutral-50)}.month-drill-empty{background:var(--neutral-50);cursor:default}.month-drill-empty:hover{background:var(--neutral-50)}.mdd-we{background:#fafafa}.mdd-holiday{background:#fff7ed}.mdd-today{background:var(--petrol-50);box-shadow:inset 0 0 0 2px var(--petrol-500)}.mdd-selected{outline:2px solid var(--petrol-500);outline-offset:-2px;z-index:1;position:relative}.mdd-date{justify-content:space-between;align-items:baseline;gap:6px;display:flex}.mdd-num{color:var(--neutral-800);font-variant-numeric:tabular-nums;font-size:13px;font-weight:600}.mdd-today .mdd-num{color:var(--petrol-700)}.mdd-holiday-name{color:#c2410c;white-space:nowrap;text-overflow:ellipsis;max-width:80%;font-size:10px;font-weight:500;overflow:hidden}.mdd-events{flex-direction:column;gap:2px;min-height:0;display:flex}.mdd-event{cursor:pointer;border-radius:4px;align-items:center;gap:4px;padding:2px 6px;font-size:11px;line-height:1.3;display:flex;overflow:hidden}.mdd-event:hover{filter:brightness(.96)}.mdd-event-dot{border-radius:50%;flex-shrink:0;width:6px;height:6px}.mdd-event-title{white-space:nowrap;text-overflow:ellipsis;font-weight:500;overflow:hidden}.mdd-event-more{color:var(--neutral-500);padding:0 6px;font-size:10px;font-weight:500}.month-card{cursor:pointer}.month-card:hover{border-color:var(--petrol-400);box-shadow:0 2px 8px #0c7e8c14}@media (width<=900px){.month-drill-wrap{grid-template-columns:1fr}.month-drill-day{min-height:70px}}
