:root{font-family:Segoe UI,PingFang SC,sans-serif;color:#4a4458;background:#fff7fb}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:radial-gradient(circle at 20% 10%,#ffe9f7,#f7f3ff 50%,#eef7ff)}a{color:inherit;text-decoration:none}.shell{max-width:1100px;margin:0 auto;padding:20px}.topbar{display:flex;justify-content:space-between;align-items:center;padding:12px 18px;border-radius:16px;background:#ffffffd9;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);margin-bottom:16px}.brand{margin:0;font-size:22px}.nav{display:flex;align-items:center;gap:14px}.content{min-height:calc(100vh - 120px)}.card{background:#ffffffe6;border-radius:20px;padding:20px;box-shadow:0 12px 35px #6c6a9224}.login-wrap{display:grid;place-items:center;min-height:78vh}.login-card{width:360px}.login-form{display:grid;gap:12px;margin-top:18px}input,button{border:none;border-radius:12px;padding:10px 12px;font-size:14px}button{cursor:pointer;transition:transform .12s ease,box-shadow .2s ease,filter .2s ease,background .2s ease}button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 18px #6c6a9233}button:active:not(:disabled){transform:translateY(1px) scale(.98);box-shadow:0 3px 8px #6c6a9233}button:focus-visible{outline:2px solid #b598ff;outline-offset:2px}button:disabled{cursor:not-allowed;opacity:.65;filter:saturate(.75)}input{width:100%;margin-top:6px;background:#f8f4ff}.primary-btn{background:linear-gradient(90deg,#ff8fd1,#a996ff);color:#fff}.primary-btn:hover:not(:disabled){filter:brightness(1.04)}.ghost-btn{background:#f2eeff;color:#5e5898}.ghost-btn:hover:not(:disabled){background:#eae3ff}.calendar-page{display:grid;gap:16px}.calendar-layout{display:grid;grid-template-columns:2fr 1fr;gap:16px}.month-header{display:flex;align-items:center;justify-content:space-between}.week-row,.grid{display:grid;grid-template-columns:repeat(7,1fr);gap:8px;margin-top:12px}.week-row span{text-align:center;color:#9c95b6}.day-cell{min-height:62px;background:#f9f5ff;position:relative}.day-cell.empty{opacity:.35;cursor:default}.day-cell.active{outline:2px solid #b598ff}.day-cell:hover:not(.empty){background:#f4edff}.dot-group{display:flex;gap:4px;position:absolute;bottom:8px;right:8px}.dot-group i{width:8px;height:8px;border-radius:999px}.details-card{max-height:70vh;overflow:auto}.event-list{list-style:none;padding:0;margin:0;display:grid;gap:10px}.event-list li{background:#f8f4ff;border-radius:14px;padding:10px}.event-list li.active{outline:2px solid #b598ff}.event-list h4{margin:0}.event-list h4.done{text-decoration:line-through;opacity:.75}.event-list p{margin:6px 0 0;color:#6c6689}.event-meta{display:flex;align-items:center;gap:8px}.event-tag{color:#fff;border-radius:999px;padding:2px 8px;font-size:12px}.event-status{color:#5e5898;font-size:12px}.timeline-card{max-height:460px;overflow:hidden}.all-day-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:10px}.timeline-pill{background:#fff;border:2px solid #e7dfff;color:#5e5898;padding:4px 10px;border-radius:999px}.timeline-pill.done{text-decoration:line-through;opacity:.75}.timeline-pill.active{box-shadow:0 0 0 2px #b598ff4d}.timeline-wrap{display:grid;grid-template-columns:62px 1fr;gap:8px;max-height:350px;overflow:auto}.timeline-scale{display:grid;grid-auto-rows:44px}.timeline-scale span{font-size:12px;color:#8f88aa;transform:translateY(-8px)}.timeline-body{position:relative;border-left:1px solid #e3daf6;background:linear-gradient(#fbf8ff,#fff);border-radius:10px}.timeline-line{position:absolute;left:0;right:0;border-top:1px dashed #ece5fb}.timeline-item{position:absolute;border:2px solid #d7c8ff;border-left-width:4px;background:#fffffff2;color:#4a4458;border-radius:10px;padding:6px 8px;text-align:left;overflow:hidden}.timeline-item strong,.timeline-item small{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.timeline-item small{color:#7b7396;margin-top:3px;font-size:11px}.timeline-item.done strong{text-decoration:line-through;opacity:.75}.timeline-item.active{box-shadow:0 0 0 2px #b598ff47}.settings-card{max-width:780px}.settings-list{display:grid;gap:12px}.settings-subtitle{margin:4px 0 0}.row{display:grid;gap:6px}.row strong{color:#5e5898}.row-actions{display:flex;gap:8px}.chips{display:flex;gap:8px;flex-wrap:wrap}.chip{width:24px;height:24px;border-radius:999px;border:2px solid #fff;box-shadow:0 0 0 1px #d8d2eb;cursor:pointer}.error-text{color:#d64c8b}.muted{color:#8f88aa}@media(max-width:900px){.calendar-layout{grid-template-columns:1fr}.timeline-wrap{grid-template-columns:52px 1fr}}
