:root{--bg:#fff;--bg-secondary:#f5f5f5;--surface:#fff;--border:#e0e0e0;--text:#202124;--text-muted:#5f6368;--accent:#1a73e8;--danger:#d93025;--success:#188038;--radius:8px;--sidebar-w:280px;--header-h:56px;--label-w:38px;--font:"Google Sans", Roboto, system-ui, sans-serif}@media (prefers-color-scheme:dark){:root:not([data-theme=light]){--bg:#121212;--bg-secondary:#1e1e1e;--surface:#2a2a2a;--border:#3a3a3a;--text:#e8eaed;--text-muted:#9aa0a6;--accent:#8ab4f8}}[data-theme=dark]{--bg:#121212;--bg-secondary:#1e1e1e;--surface:#2a2a2a;--border:#3a3a3a;--text:#e8eaed;--text-muted:#9aa0a6;--accent:#8ab4f8}[data-theme=light]{--bg:#fff;--bg-secondary:#f5f5f5;--surface:#fff;--border:#e0e0e0;--text:#202124;--text-muted:#5f6368;--accent:#1a73e8}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;font-family:var(--font);background:var(--bg);color:var(--text);font-size:14px}.app-shell{flex-direction:column;height:100%;display:flex}.app-header{height:var(--header-h);background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:12px;padding:0 16px;display:flex}.app-header h1{flex:1;font-size:18px;font-weight:500}.app-body{flex:1;display:flex;overflow:hidden}.main-area{flex-direction:column;flex:1;display:flex;overflow:hidden}.sidebar{width:var(--sidebar-w);border-left:1px solid var(--border);background:var(--surface);flex-direction:column;flex-shrink:0;display:flex;overflow:hidden}.week-nav{border-bottom:1px solid var(--border);background:var(--bg-secondary);flex-shrink:0;align-items:center;gap:8px;padding:8px 12px;display:flex}.week-nav span{text-align:center;flex:1;font-weight:500}.week-container{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.day-headers{grid-template-columns:var(--label-w) repeat(8, minmax(110px, 1fr));border-bottom:2px solid var(--border);background:var(--bg-secondary);z-index:2;flex-shrink:0;display:grid;position:sticky;top:0;overflow-x:auto}.day-header-spacer{border-right:1px solid var(--border);background:var(--bg-secondary)}.sections-body{flex:1;overflow:auto}.day-header{text-align:center;color:var(--text-muted);border-right:1px solid var(--border);padding:8px 8px 4px;font-size:13px;font-weight:500}.day-header:last-child{border-right:none}.day-header.today{color:var(--accent)}.day-date{color:var(--text);font-size:22px;font-weight:400;line-height:1.2;display:block}.day-header.today .day-date{background:var(--accent);color:#fff;border-radius:50%;width:36px;height:36px;margin:2px auto 0;font-size:18px;line-height:36px}.section-row{border-bottom:2px solid var(--border);display:flex}.section-row-label{width:var(--label-w);border-right:1px solid var(--border);background:var(--bg-secondary);flex-shrink:0;justify-content:center;align-items:center;padding:4px 0;display:flex}.section-row-label span{writing-mode:vertical-rl;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);white-space:nowrap;font-size:10px;font-weight:700;transform:rotate(180deg)}.section-cells{flex:1;grid-template-columns:repeat(8,minmax(110px,1fr));min-width:0;display:grid}.day-cell{border-right:1px solid var(--border);flex-direction:column;align-items:stretch;gap:3px;min-height:36px;padding:4px;display:flex}.day-cell:last-child{border-right:none}.day-cell.today{background:color-mix(in srgb, var(--accent) 6%, transparent)}.day-cell.yesterday,.day-header.yesterday{opacity:.45}.day-cell-empty{color:var(--text-muted);padding:2px;font-size:11px}.event-card{cursor:default;background:color-mix(in srgb, var(--cal-color,#4285f4) 15%, var(--surface));border-left:3px solid;border-color:var(--cal-color,#4285f4);border-radius:4px;flex-direction:column;flex:1;justify-content:center;padding:4px 6px;font-size:12px;line-height:1.3;display:flex}.event-card.all-day{border-left-width:4px;font-weight:500}.event-time{color:var(--text-muted);margin-bottom:1px;font-size:11px;display:block}.event-title{word-break:break-word;font-weight:500;display:block}.event-cal{color:var(--text-muted);font-size:11px}.settings-section-block{border:1px solid var(--border);border-radius:var(--radius);margin-bottom:10px;overflow:hidden}.settings-section-block.drop-target{border-color:var(--accent);box-shadow:0 0 0 2px color-mix(in srgb, var(--accent) 25%, transparent)}.settings-section-header{background:var(--bg-secondary);border-bottom:1px solid var(--border);cursor:grab;align-items:center;gap:8px;padding:8px 12px;display:flex}.settings-section-header:active{cursor:grabbing}.section-name-input{color:var(--text);font-size:13px;font-weight:600;font-family:var(--font);cursor:text;background:0 0;border:none;outline:none;flex:1}.section-name-input:focus{background:var(--bg);border-radius:4px;padding:2px 6px}.section-cal-drop-zone{min-height:44px;padding:6px 12px;transition:background .15s}.section-cal-drop-zone.drop-active{background:color-mix(in srgb, var(--accent) 10%, var(--surface));outline:2px dashed var(--accent);outline-offset:-4px;border-radius:4px}.drop-hint{color:var(--text-muted);padding:6px 0;font-size:12px;font-style:italic}.drag-handle{cursor:grab;color:var(--text-muted);-webkit-user-select:none;user-select:none;flex-shrink:0;padding:0 2px;font-size:16px}.drag-handle:active{cursor:grabbing}.cal-row[draggable]{cursor:default}.cal-row-drop-target{border-top:2px solid var(--accent);margin-top:-1px}.btn{cursor:pointer;border-radius:var(--radius);font-size:13px;font-family:var(--font);background:var(--bg-secondary);color:var(--text);border:none;padding:6px 12px;transition:opacity .15s}.btn:hover{opacity:.8}.btn-icon{cursor:pointer;color:var(--text-muted);border-radius:var(--radius);background:0 0;border:none;padding:6px 8px;font-size:16px}.btn-icon:hover{background:var(--bg-secondary)}.scrape-alert{color:#92400e;background:#fef3c7;border-bottom:1px solid #fde68a;flex-shrink:0;padding:8px 16px;font-size:12px}.scrape-alert code{background:#00000014;border-radius:3px;padding:1px 4px;font-family:monospace}[data-theme=dark] .scrape-alert{color:#fcd34d;background:#451a03;border-color:#78350f}.btn-sync{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:6px;align-items:center;gap:4px;padding:5px 10px;font-size:12px;transition:color .2s,background .2s;display:flex}.btn-sync:hover{background:var(--bg-secondary);color:var(--text)}.btn-sync:disabled{cursor:default;opacity:.6}.sync-icon{font-size:15px;line-height:1;transition:transform .4s;display:inline-block}.btn-sync.syncing .sync-icon{animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.btn-primary{background:var(--accent);color:#fff}.login-wrap{background:var(--bg);justify-content:center;align-items:center;height:100%;display:flex}.login-card{background:var(--surface);border:1px solid var(--border);text-align:center;border-radius:12px;flex-direction:column;gap:16px;width:300px;padding:32px;display:flex}.login-card h2{font-size:20px;font-weight:500}.login-card p{color:var(--text-muted);font-size:13px}.login-input{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);width:100%;color:var(--text);outline:none;padding:10px 12px;font-size:14px}.login-input:focus{border-color:var(--accent)}.login-error{color:var(--danger);font-size:13px}.sidebar-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:12px 14px;font-size:14px;font-weight:500;display:flex}.task-list{flex:1;padding:8px 0;overflow-y:auto}.task-item{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:10px;padding:7px 14px;transition:background .1s;display:flex}.task-item:hover{background:var(--bg-secondary)}.task-item input[type=checkbox]{cursor:pointer;width:16px;height:16px;accent-color:var(--accent);flex-shrink:0}.task-item span{flex:1;font-size:13px}.task-item.done span{color:var(--text-muted);text-decoration:line-through}.task-list-section{border-bottom:1px solid var(--border)}.task-list-section:last-of-type{border-bottom:none}.status-bar{border-top:1px solid var(--border);color:var(--text-muted);align-items:center;gap:6px;padding:8px 14px;font-size:11px;display:flex}.status-dot{background:var(--success);border-radius:50%;flex-shrink:0;width:7px;height:7px}.event-popout-overlay{z-index:90;background:#0006;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}@media (width>=769px){.event-popout-overlay{align-items:center}}.event-popout{background:var(--surface);border-top:4px solid var(--cal-color,#4285f4);border-radius:16px 16px 0 0;flex-direction:column;width:100%;max-width:480px;max-height:80vh;display:flex;overflow:hidden}@media (width>=769px){.event-popout{border-top:none;border-left:4px solid var(--cal-color,#4285f4);border-radius:12px}}.event-popout-bar{background:var(--border);border-radius:2px;flex-shrink:0;width:40px;height:4px;margin:12px auto 0}@media (width>=769px){.event-popout-bar{display:none}}.event-popout-header{justify-content:space-between;align-items:flex-start;gap:8px;padding:14px 16px 4px;display:flex}.event-popout-title{flex:1;font-size:17px;font-weight:500;line-height:1.3}.event-popout-meta{padding:0 16px 10px;font-size:13px}.event-popout-cal{font-weight:500}.event-popout-body{flex-direction:column;gap:10px;padding:0 16px 20px;display:flex;overflow-y:auto}.event-popout-row{gap:12px;font-size:14px;display:flex}.event-popout-label{color:var(--text-muted);flex-shrink:0;min-width:52px;padding-top:1px;font-size:12px}.event-popout-desc span{white-space:pre-wrap;word-break:break-word}.event-popout-desc a{color:var(--accent);word-break:break-all}.event-popout-location-link{color:var(--accent);word-break:break-word}.settings-overlay{z-index:100;background:#0006;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.settings-panel{background:var(--surface);border-radius:12px;flex-direction:column;width:min(760px,95vw);max-height:90vh;display:flex;overflow:hidden}.settings-panel-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 20px;font-size:16px;font-weight:500;display:flex}.settings-tabs{border-bottom:1px solid var(--border);flex-shrink:0;gap:4px;padding:0 20px;display:flex}.settings-tab{font-size:13px;font-family:var(--font);color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:10px 16px}.settings-tab:hover{color:var(--text)}.settings-tab.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:500}.settings-body{flex-direction:column;flex:1;gap:20px;padding:16px 20px;display:flex;overflow-y:auto}.settings-section h3{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:10px;font-size:12px}.cal-row{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:6px 0;display:flex}.cal-dot{border-radius:50%;flex-shrink:0;width:12px;height:12px}.cal-name-input{color:var(--text);font-size:13px;font-family:var(--font);background:0 0;border:none;border-radius:4px;outline:none;flex:1;padding:2px 4px}.cal-name-input:focus{background:var(--bg-secondary)}.cal-color-input{cursor:pointer;background:0 0;border:none;border-radius:50%;width:28px;height:28px;padding:0}.person-tag-input{border:1px solid var(--border);background:var(--bg);width:100px;color:var(--text);font-size:12px;font-family:var(--font);border-radius:4px;padding:3px 6px}@media (width<=1024px){.sidebar{width:240px}}.mobile-list-fab{background:var(--accent);cursor:pointer;z-index:50;border:none;border-radius:50%;justify-content:center;align-items:center;width:52px;height:52px;font-size:22px;display:flex;position:fixed;bottom:20px;right:20px;box-shadow:0 4px 12px #00000040}.mobile-drawer-overlay{z-index:80;background:#0006;align-items:flex-end;display:flex;position:fixed;inset:0}.mobile-drawer{background:var(--surface);border-radius:16px 16px 0 0;flex-direction:column;width:100%;max-height:75vh;display:flex;overflow:hidden}.mobile-drawer-handle{background:var(--border);cursor:pointer;border-radius:2px;flex-shrink:0;width:40px;height:4px;margin:12px auto 4px}@media (width<=768px){.app-body{flex-direction:column}.section-cells{grid-template-columns:1fr}.day-cell{min-height:48px}}
