*,:after,:before{box-sizing:border-box}:root{--app-bg:#f6f7f9;--surface:#fff;--surface-soft:#f2f7f5;--surface-blue:#eef5ff;--border:#dce3ea;--border-strong:#c2ccd6;--text:#17202a;--text-muted:#687384;--primary:#2b6be8;--primary-dark:#1f55c7;--green:#0f9f6e;--green-soft:#e6f6ef;--red:#d94d45;--red-soft:#fff0ed;--amber:#b87908;--amber-soft:#fff6dd;--shadow:0 18px 50px rgba(27,38,49,.08);--radius:8px}body,html{min-height:100%;background:var(--app-bg)}body{margin:0;color:var(--text);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Noto Sans KR,sans-serif;letter-spacing:0}button,input,select{font:inherit;letter-spacing:0}button{cursor:pointer}a{color:inherit}.icon{display:block;height:1em;width:1em}.todo-shell{display:grid;grid-template-columns:260px minmax(520px,1fr) minmax(340px,430px);grid-gap:14px;gap:14px;min-height:100svh;padding:max(14px,env(safe-area-inset-top)) max(14px,env(safe-area-inset-right)) max(14px,env(safe-area-inset-bottom)) max(14px,env(safe-area-inset-left))}.loading-shell{display:grid;place-items:center}.loading-card{color:var(--text-muted);padding:24px 28px}.calendar-board,.day-panel,.loading-card,.task-sidebar{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow)}.calendar-board,.day-panel,.task-sidebar{min-width:0}.task-sidebar{display:flex;flex-direction:column;gap:20px;padding:18px}.brand-block{display:flex;align-items:center;gap:12px}.brand-mark{display:grid;flex:0 0 auto;height:42px;width:42px;place-items:center;border-radius:var(--radius);background:var(--primary);color:#fff;font-size:20px}.board-toolbar p,.brand-caption,.panel-header p{margin:0 0 4px;color:var(--text-muted);font-size:12px;font-weight:700;text-transform:uppercase}.board-toolbar h2,.brand-block h1,.panel-header h2{margin:0;color:var(--text);font-size:24px;line-height:1.2}.brand-block h1{font-size:22px}.task-nav{display:grid;grid-gap:7px;gap:7px}.add-button,.complete-button,.delete-button,.icon-button,.nav-item,.today-button{border:0}.nav-item{display:flex;align-items:center;justify-content:space-between;min-height:44px;padding:0 12px;border-radius:var(--radius);background:transparent;color:var(--text-muted);font-size:14px;font-weight:700}.nav-item span{display:inline-flex;align-items:center;gap:9px}.nav-item strong{min-width:28px;border-radius:999px;background:#eef1f4;color:var(--text-muted);font-size:12px;line-height:24px;text-align:center}.nav-item.active,.nav-item:hover{background:var(--surface-blue);color:var(--primary-dark)}.nav-item.active strong{background:var(--primary);color:#fff}.sidebar-summary{display:grid;grid-gap:9px;gap:9px;padding:12px;border:1px solid var(--border);border-radius:var(--radius);background:#fbfcfd}.sidebar-summary div{display:flex;align-items:center;justify-content:space-between;color:var(--text-muted);font-size:13px}.sidebar-summary strong{color:var(--text);font-size:15px}.outlook-sync-card{display:grid;grid-gap:7px;gap:7px;padding:12px;border:1px solid #b9d4ff;border-radius:var(--radius);background:var(--surface-blue);color:var(--primary-dark);font-size:12px;font-weight:800}.outlook-sync-card span{display:inline-flex;align-items:center;gap:7px}.outlook-sync-card strong{color:var(--text);font-size:13px}.outlook-sync-card p{margin:0;color:#7a4a07;font-size:12px;font-weight:700;line-height:1.4}.outlook-actions{display:grid;grid-template-columns:1fr 1fr;grid-gap:7px;gap:7px}.outlook-actions a,.outlook-actions button{display:inline-flex;align-items:center;justify-content:center;min-height:32px;border:1px solid rgba(43,107,232,.24);border-radius:7px;background:#fff;color:var(--primary-dark);cursor:pointer;font:inherit;font-size:12px;font-weight:900;text-decoration:none}.outlook-actions a[aria-disabled=true]{cursor:not-allowed;opacity:.55}.outlook-sync-card.warning{border-color:#f1c66a;background:var(--amber-soft);color:var(--amber)}.account-strip{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:auto;padding-top:14px;border-top:1px solid var(--border);color:var(--text-muted);font-size:13px}.account-strip span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.account-strip a{flex:0 0 auto;color:var(--primary-dark);font-weight:700;text-decoration:none}.calendar-board{display:flex;flex-direction:column;gap:12px;padding:18px}.board-toolbar,.panel-header{display:flex;align-items:center;justify-content:space-between;gap:16px}.toolbar-actions{display:inline-flex;align-items:center;gap:8px}.icon-button,.today-button{display:inline-grid;min-height:38px;place-items:center;border:1px solid var(--border);border-radius:var(--radius);background:#fff;color:var(--text)}.icon-button{width:38px;font-size:18px}.today-button{padding:0 14px;color:var(--primary-dark);font-size:13px;font-weight:800}.icon-button:hover,.today-button:hover{border-color:var(--primary);background:var(--surface-blue)}.month-grid,.weekday-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr))}.weekday-grid{gap:8px;color:var(--text-muted);font-size:12px;font-weight:800;text-align:center}.month-grid{flex:1 1;gap:8px;min-height:0}.calendar-cell{display:flex;min-height:104px;flex-direction:column;gap:8px;overflow:hidden;padding:9px;border:1px solid var(--border);border-radius:var(--radius);background:#fff;color:var(--text);text-align:left}.calendar-cell:hover{border-color:var(--primary);background:#fbfdff}.calendar-cell.selected{border-color:var(--primary);box-shadow:inset 0 0 0 1px var(--primary)}.calendar-cell.today{background:var(--surface-blue)}.calendar-cell.outside-month{color:#9da7b4;background:#f7f8fa}.calendar-cell-head{display:flex;align-items:center;justify-content:space-between;gap:6px;font-size:13px;font-weight:800}.calendar-cell-head strong{display:inline-grid;min-width:22px;height:22px;place-items:center;border-radius:999px;background:var(--green);color:#fff;font-size:11px}.calendar-task-stack{display:grid;grid-gap:5px;gap:5px}.calendar-pill{overflow:hidden;padding:4px 7px;border-radius:6px;background:var(--green-soft);color:#0d6d4d;font-size:11px;font-weight:800;line-height:1.2;text-overflow:ellipsis;white-space:nowrap}.calendar-pill[data-priority=high]{background:var(--red-soft);color:#a13a34}.calendar-pill[data-priority=medium]{background:var(--amber-soft);color:var(--amber)}.calendar-pill.outlook{background:var(--surface-blue);color:var(--primary-dark)}.day-panel{display:flex;min-height:0;flex-direction:column;gap:14px;padding:18px}.panel-meter{flex:0 0 auto;border-radius:999px;background:var(--surface-soft);color:var(--green);font-size:13px;font-weight:800;padding:7px 11px}.quick-add{display:grid;grid-gap:10px;gap:10px;padding:12px;border:1px solid var(--border);border-radius:var(--radius);background:#fbfcfd}.quick-add label{display:grid;grid-gap:5px;gap:5px;min-width:0}.quick-add label span{color:var(--text-muted);font-size:12px;font-weight:800}.quick-add input,.quick-add select{width:100%;min-height:40px;border:1px solid var(--border);border-radius:7px;background:#fff;color:var(--text);font-size:14px;outline:none;padding:0 10px}.quick-add input:focus,.quick-add select:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(43,107,232,.12)}.quick-controls{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);grid-gap:8px;gap:8px}.quick-controls .priority-control{grid-column:1/-1}.add-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:42px;border-radius:var(--radius);background:var(--primary);color:#fff;font-size:14px;font-weight:900}.add-button:hover{background:var(--primary-dark)}.task-list{display:flex;min-height:0;flex:1 1;flex-direction:column;gap:9px;overflow:auto;padding-right:2px}.panel-section{display:grid;grid-gap:9px;gap:9px;padding:12px;border:1px solid var(--border);border-radius:var(--radius);background:#fbfcfd}.panel-section.compact{flex:0 0 auto}.section-title-line{display:flex;align-items:center;justify-content:space-between;gap:12px}.section-title-line h3{margin:0;color:var(--text);font-size:14px;line-height:1.2}.section-link-button,.section-title-line span{color:var(--text-muted);font-size:12px;font-weight:800}.section-link-button{border:0;background:transparent;padding:0}.event-list,.mail-mini-list{display:grid;grid-gap:7px;gap:7px}.event-row{display:grid;grid-template-columns:92px minmax(0,1fr);grid-gap:10px;gap:10px;min-height:44px;align-items:center;padding:8px 10px;border:1px solid var(--border);border-radius:7px;background:#fff;text-decoration:none}.event-row:hover{border-color:var(--primary);background:#fbfdff}.event-time{color:var(--primary-dark);font-size:12px;font-weight:900}.event-row strong,.mail-mini-row strong{min-width:0;color:var(--text);font-size:13px}.event-row small,.event-row strong,.mail-mini-row strong{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.event-row small{color:var(--text-muted);font-size:12px}.mail-row{display:grid;grid-template-columns:34px minmax(0,1fr);grid-gap:11px;gap:11px;padding:12px;border:1px solid var(--border);border-left:4px solid var(--primary);border-radius:var(--radius);background:#fff;text-decoration:none}.mail-mini-row:hover,.mail-row:hover{border-color:var(--primary);background:#fbfdff}.mail-icon{display:grid;width:30px;height:30px;place-items:center;border-radius:7px;background:var(--surface-blue);color:var(--primary-dark);font-size:16px}.mail-content{display:grid;min-width:0;grid-gap:5px;gap:5px}.mail-title-line{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.mail-title-line strong{min-width:0;color:var(--text);font-size:14px;line-height:1.35;overflow-wrap:anywhere}.mail-chips{display:inline-flex;flex:0 0 auto;gap:4px}.mail-chips em{border-radius:999px;background:var(--surface-blue);color:var(--primary-dark);font-size:10px;font-style:normal;font-weight:900;padding:4px 6px}.mail-meta,.mail-mini-row span,.mail-preview{color:var(--text-muted);font-size:12px;line-height:1.4}.mail-preview{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2}.mail-mini-row{grid-gap:4px;gap:4px;padding:9px 10px;border:1px solid var(--border);border-radius:7px;text-decoration:none}.mail-mini-row,.task-row{display:grid;background:#fff}.task-row{grid-template-columns:30px minmax(0,1fr) 30px;align-items:start;grid-gap:10px;gap:10px;padding:12px;border:1px solid var(--border);border-left:4px solid var(--green);border-radius:var(--radius)}.task-row[data-priority=high]{border-left-color:var(--red)}.task-row[data-priority=medium]{border-left-color:#d99c1f}.task-row.completed{background:#f8faf9;opacity:.78}.complete-button{display:grid;width:26px;height:26px;place-items:center;border:2px solid var(--border-strong);border-radius:999px;background:#fff;color:#fff;font-size:15px}.task-row.completed .complete-button{border-color:var(--green);background:var(--green)}.task-content{min-width:0}.task-title-line{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.task-title-line strong{min-width:0;color:var(--text);font-size:15px;line-height:1.35;overflow-wrap:anywhere}.task-row.completed .task-title-line strong{color:var(--text-muted);text-decoration:line-through}.priority-chip{display:inline-flex;flex:0 0 auto;align-items:center;gap:4px;border-radius:999px;background:var(--green-soft);color:#0d6d4d;font-size:11px;font-weight:900;line-height:1;padding:5px 7px}.priority-chip[data-priority=high]{background:var(--red-soft);color:#a13a34}.priority-chip[data-priority=medium]{background:var(--amber-soft);color:var(--amber)}.task-content p{margin:6px 0 0;color:var(--text-muted);font-size:13px;line-height:1.45;overflow-wrap:anywhere}.task-meta{display:flex;flex-wrap:wrap;gap:7px;margin-top:9px}.task-meta span{display:inline-flex;align-items:center;gap:5px;color:var(--text-muted);font-size:12px;font-weight:700}.task-meta .overdue{color:var(--red)}.delete-button{display:grid;width:30px;height:30px;place-items:center;border-radius:7px;background:transparent;color:var(--text-muted);font-size:16px}.delete-button:hover{background:var(--red-soft);color:var(--red)}.empty-state{display:grid;grid-gap:6px;gap:6px;place-items:center;min-height:180px;border:1px dashed var(--border-strong);border-radius:var(--radius);color:var(--text-muted);text-align:center}.empty-state strong{color:var(--text);font-size:16px}.empty-state span{max-width:240px;font-size:13px;line-height:1.45}.login-container{display:flex;min-height:100svh;align-items:center;justify-content:center;padding:24px;background:var(--app-bg)}.login-card{width:min(100%,390px);border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow);padding:32px;text-align:center}.login-title{margin:0;color:var(--text);font-size:28px;letter-spacing:0}.login-accent{color:var(--primary)}.login-subtitle{margin:8px 0 0;color:var(--text-muted);font-size:15px}@media (max-width:1180px){.todo-shell{grid-template-columns:230px minmax(0,1fr)}.day-panel{grid-column:1/-1;min-height:460px}}@media (max-width:820px){.todo-shell{display:flex;flex-direction:column;gap:10px;padding:max(10px,env(safe-area-inset-top)) max(10px,env(safe-area-inset-right)) max(10px,env(safe-area-inset-bottom)) max(10px,env(safe-area-inset-left))}.task-sidebar{gap:12px;padding:14px}.brand-block{justify-content:space-between}.brand-mark{height:38px;width:38px}.task-nav{display:flex;gap:8px;overflow-x:auto;padding-bottom:2px}.nav-item{flex:0 0 auto;min-width:118px}.sidebar-summary{grid-template-columns:repeat(3,minmax(0,1fr))}.sidebar-summary div{display:grid;justify-items:center;grid-gap:4px;gap:4px}.account-strip{margin-top:0}.calendar-board,.day-panel{padding:14px}.board-toolbar,.panel-header{align-items:flex-start}.board-toolbar h2,.brand-block h1,.panel-header h2{font-size:20px}.toolbar-actions{gap:6px}.icon-button{width:36px}.calendar-cell{min-height:82px;padding:7px}.calendar-task-stack{gap:4px}.calendar-pill{padding:3px 5px;font-size:10px}.quick-controls{grid-template-columns:1fr}.task-row{grid-template-columns:28px minmax(0,1fr) 28px;padding:10px}.task-title-line{flex-direction:column;align-items:flex-start}}@media (max-width:520px){.month-grid,.weekday-grid{gap:4px}.calendar-cell{min-height:66px;gap:5px;padding:5px}.calendar-cell-head{font-size:12px}.calendar-cell-head strong{min-width:18px;height:18px;font-size:10px}.calendar-pill{display:none}.sidebar-summary{gap:6px;padding:10px}.account-strip{align-items:flex-start;flex-direction:column}}