/* calendar.css — Raise OS calendar view · warm beige + clay system */

/* ── sync bar ────────────────────────────────────────────────────── */
.calsync{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:9px 26px;background:var(--surface-2);border-bottom:1px solid var(--border);flex:none;flex-wrap:wrap;row-gap:8px;}
.cs-left{display:flex;align-items:center;gap:12px;flex-wrap:wrap;min-width:0;}
.cs-status{display:flex;align-items:center;gap:7px;font-size:12.5px;font-weight:600;color:var(--green);white-space:nowrap;}
.cs-status.off{color:var(--ink-3);font-weight:500;}
.cs-status.busy{color:var(--amber);}
.cs-gmark{display:flex;align-items:center;}
.cs-tick{font-size:13px;}
.cs-acct{font-size:11.5px;color:var(--ink-3);}
.cs-spin{width:12px;height:12px;border:2px solid var(--amber);border-top-color:transparent;border-radius:50%;animation:cspin .7s linear infinite;}
@keyframes cspin{to{transform:rotate(360deg)}}
.cs-conflict{display:flex;align-items:center;gap:5px;font-size:12px;font-weight:600;color:var(--primary-2);background:var(--primary-tint);border:1px solid var(--primary-tint-2);padding:4px 10px;border-radius:20px;white-space:nowrap;}
.cs-conflict:hover{background:var(--primary-tint-2);}
.cs-right{display:flex;align-items:center;gap:7px;}
.cs-btn{font-size:12.5px;font-weight:500;color:var(--ink-2);background:var(--surface);border:1px solid var(--border-strong);padding:6px 12px;border-radius:8px;transition:background .12s,border-color .12s;white-space:nowrap;}
.cs-btn:hover:not(:disabled){background:var(--surface-3);}
.cs-btn:disabled{opacity:.5;cursor:default;}
.cs-btn.primary{background:var(--primary);color:#fff;border-color:var(--primary);}
.cs-btn.primary:hover{background:var(--primary-2);}

/* ── toolbar ─────────────────────────────────────────────────────── */
.caltool{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:12px 26px;border-bottom:1px solid var(--border);background:var(--surface);flex:none;flex-wrap:wrap;row-gap:10px;}
.ct-nav{display:flex;align-items:center;gap:8px;}
.ct-today{font-size:12.5px;font-weight:600;color:var(--ink);background:var(--surface);border:1px solid var(--border-strong);padding:6px 13px;border-radius:8px;white-space:nowrap;}
.ct-today:hover{background:var(--surface-2);}
.ct-arrow{width:30px;height:30px;border-radius:8px;border:1px solid var(--border-strong);background:var(--surface);color:var(--ink-2);font-size:18px;line-height:1;display:flex;align-items:center;justify-content:center;}
.ct-arrow:hover{background:var(--surface-2);color:var(--ink);}
.ct-title{margin:0 0 0 6px;font-size:18px;font-weight:600;letter-spacing:-.02em;white-space:nowrap;}
.ct-right{display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.ct-cals{display:flex;align-items:center;gap:4px;flex-wrap:wrap;}
.ct-cal{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:500;color:var(--ink-2);background:none;border:none;padding:4px 8px;border-radius:7px;transition:background .1s,color .1s;}
.ct-cal:hover{background:var(--surface-2);}
.ct-cal.off{color:var(--ink-3);}
.ct-cal-box{width:13px;height:13px;border-radius:4px;border:1.5px solid;flex:none;transition:background .1s;}
.ct-cal-g{font-size:9px;font-weight:700;color:#fff;background:#4a78c8;border-radius:3px;width:13px;height:13px;display:flex;align-items:center;justify-content:center;}
.ct-todobtn{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:500;color:var(--ink-3);background:var(--surface-2);border:1px solid var(--border);padding:5px 11px;border-radius:8px;white-space:nowrap;}
.ct-todobtn.on{color:var(--amber);background:var(--amber-tint);border-color:var(--amber-tint);}
.ct-todobtn-c{width:11px;height:11px;border-radius:3px;border:1.5px solid currentColor;flex:none;}
.ct-new{font-size:12.5px;font-weight:600;color:#fff;background:var(--primary);border:none;padding:7px 14px;border-radius:8px;white-space:nowrap;}
.ct-new:hover{background:var(--primary-2);}

.calbody{flex:1;min-height:0;overflow:hidden;display:flex;}
body.cal-dragging{cursor:grabbing;user-select:none;-webkit-user-select:none;}
body.cal-dragging .tg-col{cursor:grabbing;}

/* ── time grid (week / day) ─────────────────────────────────────── */
.tgrid{flex:1;display:flex;flex-direction:column;min-height:0;background:var(--surface);}
.tgwrap{flex:1;display:flex;min-height:0;min-width:0;}
.tg-scroll{flex:1;overflow-y:auto;overflow-x:hidden;}
.tg-sticky{position:sticky;top:0;z-index:9;background:var(--surface);box-shadow:0 1px 0 var(--border-strong);}
.tg-head{display:grid;grid-template-columns:62px repeat(7,minmax(0,1fr));border-bottom:1px solid var(--border);}
.tg-corner{border-right:1px solid var(--border);}
.tg-dh{text-align:center;padding:8px 4px;border-right:1px solid var(--border);display:flex;flex-direction:column;align-items:center;gap:1px;min-width:0;}
.tg-dh:last-child{border-right:none;}
.tg-dn{font-size:11px;font-weight:600;color:var(--ink-3);text-transform:uppercase;letter-spacing:.04em;}
.tg-dnum{font-size:18px;font-weight:600;letter-spacing:-.02em;color:var(--ink);width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;}
.tg-dh.today .tg-dn{color:var(--primary-2);}
.tg-dh.today .tg-dnum{background:var(--primary);color:#fff;}

.tg-allday{display:grid;grid-template-columns:62px repeat(7,minmax(0,1fr));border-bottom:1px solid var(--border-strong);min-height:30px;background:var(--surface-2);}
.tg-allday-lab{border-right:1px solid var(--border);font-size:9.5px;color:var(--ink-3);text-transform:uppercase;letter-spacing:.04em;display:flex;align-items:center;justify-content:flex-end;padding-right:7px;}
.tg-allday-cell{border-right:1px solid var(--border);padding:3px 4px;display:flex;flex-direction:column;gap:2px;min-width:0;}
.tg-allday-cell:last-child{border-right:none;}
.todochip{display:flex;align-items:center;gap:5px;font-size:11px;font-weight:500;color:var(--amber);background:var(--amber-tint);border-radius:5px;padding:2px 7px;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;border:1px solid #eddcb6;}
.todochip:hover{filter:brightness(.97);}
.tc-dot{width:7px;height:7px;border:1.5px solid var(--amber);border-radius:2px;flex:none;}

.tg-body{display:grid;grid-template-columns:62px repeat(7,minmax(0,1fr));position:relative;}
.tg-gutter{border-right:1px solid var(--border);}
.tg-hr{position:relative;border-bottom:1px solid var(--border);}
.tg-hr span{position:absolute;top:-7px;right:8px;font-size:10.5px;color:var(--ink-3);font-family:var(--mono);background:var(--surface);padding:0 2px;}
.tg-col{position:relative;border-right:1px solid var(--border);min-width:0;cursor:default;touch-action:none;}
.tg-col:last-child{border-right:none;}
.tg-col.today{background:rgba(201,100,66,.035);}
.tg-cell{border-bottom:1px solid var(--border);}
.tg-cell:nth-child(odd){background:rgba(0,0,0,.008);}

.tg-now{position:absolute;left:0;right:0;height:0;border-top:2px solid var(--rose);z-index:6;pointer-events:none;}
.tg-now span{position:absolute;left:-4px;top:-5px;width:8px;height:8px;border-radius:50%;background:var(--rose);}

/* event blocks */
.evblk{position:absolute;border-radius:7px;border:none;text-align:left;padding:4px 7px;overflow:visible;display:flex;flex-direction:column;gap:1px;z-index:4;transition:filter .1s;min-height:20px;cursor:grab;touch-action:none;}
.evblk:hover{filter:brightness(.97);z-index:7;}
.evblk:active{cursor:grabbing;}
.evblk.dragging{z-index:30;cursor:grabbing;box-shadow:0 6px 20px rgba(40,30,20,.22),inset 3px 0 0 var(--cc) !important;filter:brightness(1.02);transition:none;}
.evblk-t,.evblk-time{overflow:hidden;text-overflow:ellipsis;}
.tg-rs{position:absolute;left:0;right:0;height:8px;z-index:6;cursor:ns-resize;touch-action:none;}
.tg-rs.top{top:-2px;}
.tg-rs.bot{bottom:-2px;}
.tg-rs::after{content:'';position:absolute;left:50%;transform:translateX(-50%);bottom:1px;width:22px;height:3px;border-radius:3px;background:currentColor;opacity:0;transition:opacity .1s;}
.tg-rs.top::after{bottom:auto;top:1px;}
.evblk:hover .tg-rs::after,.tg-todoblk:hover .tg-rs::after{opacity:.5;}
.evblk-t{font-size:12px;font-weight:600;color:inherit;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.evblk-time{font-size:10.5px;color:inherit;opacity:.78;font-family:var(--mono);display:flex;align-items:center;gap:4px;}
.evblk-time2{font-weight:400;opacity:.72;font-family:var(--mono);font-size:10px;}
.evblk.tiny{padding-top:2px;padding-bottom:2px;justify-content:center;}
.evblk-z{font-size:7px;color:#2D8CFF;}
.evblk.g{border:1px dashed currentColor;}
.evblk.conflict{outline:1.5px solid var(--rose);outline-offset:-1px;}
.evblk.syncing{opacity:.6;animation:evpulse 1.1s ease-in-out infinite;}
@keyframes evpulse{50%{opacity:.95}}
.evblk-flag{position:absolute;top:3px;right:4px;font-size:10px;color:var(--rose);}

.tg-todo{position:absolute;left:3px;right:3px;height:18px;display:flex;align-items:center;gap:5px;font-size:11px;font-weight:500;color:var(--amber);background:var(--amber-tint);border:1px dashed #d9b96a;border-radius:5px;padding:0 6px;z-index:5;cursor:pointer;white-space:nowrap;overflow:hidden;}
.tg-todo-check{width:9px;height:9px;border:1.5px solid var(--amber);border-radius:2px;flex:none;}

/* scheduled to-do blocks (drag/resize like events) */
.tg-todoblk{position:absolute;left:2px;width:calc(100% - 6px);border-radius:7px;border:1px dashed #d9b96a;background:repeating-linear-gradient(135deg,var(--amber-tint),var(--amber-tint) 7px,#f6ecd4 7px,#f6ecd4 14px);text-align:left;padding:4px 7px;overflow:visible;display:flex;align-items:flex-start;gap:5px;z-index:5;color:var(--amber);cursor:grab;touch-action:none;min-height:20px;transition:filter .1s;}
.tg-todoblk:hover{filter:brightness(.98);z-index:8;}
.tg-todoblk:active{cursor:grabbing;}
.tg-todoblk.dragging{z-index:30;cursor:grabbing;box-shadow:0 6px 20px rgba(40,30,20,.2);transition:none;}
.tg-todoblk-c{width:11px;height:11px;border:1.5px solid var(--amber);border-radius:3px;flex:none;margin-top:1px;}
.tg-todoblk-t{font-size:11.5px;font-weight:600;line-height:1.25;color:#9a6a1f;display:flex;flex-direction:column;gap:1px;min-width:0;overflow:hidden;}
.tg-todoblk-time{font-size:10px;font-weight:500;opacity:.8;font-family:var(--mono);}
.tg-todoblk.tiny{align-items:center;padding-top:2px;padding-bottom:2px;}
.tg-todoblk.tiny .tg-todoblk-t{flex-direction:row;white-space:nowrap;}

/* drag previews */
.tg-prev{position:absolute;left:2px;right:4px;border-radius:7px;z-index:25;pointer-events:none;display:flex;align-items:flex-start;padding:3px 7px;}
.tg-prev.create{background:rgba(201,100,66,.16);border:1.5px solid var(--primary);}
.tg-prev.drop{background:repeating-linear-gradient(135deg,rgba(217,185,106,.28),rgba(217,185,106,.28) 7px,rgba(246,236,212,.7) 7px,rgba(246,236,212,.7) 14px);border:1.5px dashed var(--amber);}
.tg-prev span{font-size:10.5px;font-weight:600;font-family:var(--mono);color:var(--primary-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.tg-prev.drop span{color:#9a6a1f;font-family:inherit;}

/* floating ghost while dragging a tray to-do */
.tray-ghost{position:fixed;z-index:300;pointer-events:none;display:flex;align-items:center;gap:7px;max-width:220px;font-size:12px;font-weight:600;color:#9a6a1f;background:#fbf3df;border:1px solid #e7cf95;border-radius:8px;padding:7px 11px;box-shadow:0 8px 24px rgba(40,30,20,.22);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}

/* to-do tray (right rail) */
.cal-tray{width:238px;flex:none;display:flex;flex-direction:column;min-height:0;border-left:1px solid var(--border-strong);background:var(--surface-2);transition:background .12s,box-shadow .12s;}
.cal-tray.dropping{background:var(--green-tint);box-shadow:inset 3px 0 0 var(--green);}
.ctray-head{display:flex;align-items:center;gap:8px;padding:13px 16px 2px;white-space:nowrap;}
.ctray-title{font-size:13px;font-weight:700;color:var(--ink);letter-spacing:-.01em;white-space:nowrap;}
.ctray-count{font-size:10.5px;font-weight:700;color:var(--amber);background:var(--amber-tint);border-radius:20px;padding:1px 8px;}
.ctray-hint{font-size:10.5px;color:var(--ink-3);padding:0 16px 10px;line-height:1.4;}
.ctray-list{flex:1;overflow-y:auto;padding:0 10px 16px;display:flex;flex-direction:column;gap:12px;}
.ctray-empty{font-size:12px;color:var(--ink-3);text-align:center;padding:24px 8px;}
.ctray-group{display:flex;flex-direction:column;gap:3px;}
.ctray-glabel{display:flex;align-items:center;gap:6px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-3);padding:2px 4px 3px;}
.ctray-gdot{width:8px;height:8px;border-radius:50%;flex:none;}
.ctray-item{display:flex;align-items:center;gap:7px;padding:7px 8px;border-radius:8px;background:var(--surface);border:1px solid var(--border);box-shadow:inset 3px 0 0 var(--lc);cursor:grab;touch-action:none;transition:background .1s,border-color .1s;}
.ctray-item:hover{background:var(--surface-3);border-color:var(--border-strong);}
.ctray-item:active{cursor:grabbing;}
.ctray-grip{display:flex;flex-direction:column;gap:2px;flex:none;opacity:.4;}
.ctray-grip i{width:9px;height:1.5px;border-radius:2px;background:var(--ink-3);}
.ctray-c{width:13px;height:13px;border:1.6px solid var(--amber);border-radius:4px;flex:none;}
.ctray-txt{font-size:12px;font-weight:500;color:var(--ink);flex:1;min-width:0;line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.ctray-flag{font-size:8px;color:var(--primary);flex:none;}

/* ── month ───────────────────────────────────────────────────────── */
.mgrid{flex:1;display:flex;flex-direction:column;min-height:0;background:var(--surface);}
.mg-head{display:flex;border-bottom:1px solid var(--border);flex:none;}
.mg-hd{flex:1;text-align:center;padding:7px;font-size:11px;font-weight:600;color:var(--ink-3);text-transform:uppercase;letter-spacing:.04em;}
.mg-body{flex:1;display:flex;flex-direction:column;min-height:0;}
.mg-row{flex:1;display:flex;border-bottom:1px solid var(--border);min-height:0;}
.mg-cell{flex:1;border-right:1px solid var(--border);padding:4px 5px;overflow:hidden;display:flex;flex-direction:column;gap:2px;cursor:pointer;transition:background .1s;min-width:0;}
.mg-cell:last-child{border-right:none;}
.mg-cell:hover{background:var(--surface-2);}
.mg-cell.out{background:var(--surface-2);}
.mg-cell.out .mg-dnum{color:var(--ink-3);}
.mg-dnum{font-size:12.5px;font-weight:600;color:var(--ink-2);width:23px;height:23px;display:flex;align-items:center;justify-content:center;border-radius:50%;flex:none;}
.mg-cell.today .mg-dnum{background:var(--primary);color:#fff;}
.mg-evs{display:flex;flex-direction:column;gap:2px;overflow:hidden;}
.mg-ev{display:flex;align-items:center;gap:4px;background:none;border:none;text-align:left;padding:1px 3px;border-radius:4px;width:100%;}
.mg-ev:hover{background:var(--surface-2);}
.mg-ev-dot{width:7px;height:7px;border-radius:50%;background:var(--cc);flex:none;}
.mg-ev-t{font-size:11px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.mg-ev.cf{box-shadow:inset 0 0 0 1px var(--rose);border-radius:4px;}
.mg-ev-z{font-size:7px;color:#2D8CFF;}
.mg-more{font-size:10.5px;color:var(--ink-3);font-weight:500;padding-left:3px;}
.mg-todo{display:flex;align-items:center;gap:4px;font-size:10.5px;color:var(--amber);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding-left:3px;}
.mg-todo-c{width:7px;height:7px;border:1.5px solid var(--amber);border-radius:2px;flex:none;}

/* ── agenda ──────────────────────────────────────────────────────── */
.agenda{flex:1;overflow-y:auto;padding:8px 26px 24px;background:var(--surface);}
.ag-day{display:flex;gap:18px;padding:14px 0;border-bottom:1px solid var(--border);}
.ag-date{width:64px;flex:none;display:flex;flex-direction:column;align-items:center;gap:0;padding-top:2px;}
.ag-dn{font-size:10.5px;font-weight:600;color:var(--ink-3);text-transform:uppercase;letter-spacing:.04em;}
.ag-num{font-size:24px;font-weight:600;letter-spacing:-.02em;color:var(--ink);line-height:1.1;}
.ag-mo{font-size:10.5px;color:var(--ink-3);font-family:var(--mono);}
.ag-date.today .ag-num{color:var(--primary-2);}
.ag-date.today .ag-dn{color:var(--primary-2);}
.ag-items{flex:1;display:flex;flex-direction:column;gap:5px;min-width:0;}
.ag-ev{display:flex;align-items:center;gap:11px;background:var(--surface-2);border:1px solid var(--border);border-radius:9px;padding:9px 13px;text-align:left;width:100%;transition:border-color .1s,box-shadow .1s;}
.ag-ev:hover{border-color:var(--border-strong);box-shadow:var(--shadow);}
.ag-ev-time{font-size:12px;color:var(--ink-2);width:64px;flex:none;}
.ag-ev-bar{width:4px;height:24px;border-radius:3px;flex:none;}
.ag-ev-t{font-size:13.5px;font-weight:500;color:var(--ink);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.ag-ev-z{font-size:10.5px;font-weight:600;color:#2D8CFF;background:#e8f2ff;border-radius:5px;padding:2px 7px;flex:none;}
.ag-todo{display:flex;align-items:center;gap:11px;padding:7px 13px;border:1px dashed #d9b96a;border-radius:9px;background:var(--amber-tint);cursor:pointer;}
.ag-todo-c{width:11px;height:11px;border:1.5px solid var(--amber);border-radius:3px;flex:none;}

/* ── sync pill ───────────────────────────────────────────────────── */
.syncpill{display:inline-flex;align-items:center;gap:5px;font-size:10.5px;font-weight:600;padding:2px 8px;border-radius:20px;margin-left:auto;}
.syncpill .sd{width:6px;height:6px;border-radius:50%;}
.syncpill.ok{color:var(--green);background:var(--green-tint);}
.syncpill.busy{color:var(--amber);background:var(--amber-tint);}
.syncpill.idle{color:var(--ink-3);background:var(--surface-3);}
.syncpill.warn{color:var(--primary-2);background:var(--primary-tint);}

/* ── modals (shared shell) ───────────────────────────────────────── */
.modal-back{position:fixed;inset:0;background:rgba(40,30,20,.32);backdrop-filter:blur(2px);z-index:200;display:flex;align-items:center;justify-content:center;padding:24px;animation:mfade .15s ease-out;}
@keyframes mfade{from{opacity:0}}
.gmodal,.setmodal,.cfmodal{background:var(--surface);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow-lg);width:100%;animation:mpop .18s cubic-bezier(.2,.7,.3,1);}
@keyframes mpop{from{transform:translateY(8px) scale(.98);opacity:0}}
.xbtn{width:26px;height:26px;border-radius:7px;border:none;background:var(--surface-2);color:var(--ink-2);font-size:13px;}
.xbtn:hover{background:var(--surface-3);}

/* google connect modal */
.gmodal{max-width:412px;padding:22px;}
.gmodal-head{display:flex;align-items:center;gap:13px;margin-bottom:18px;}
.gmark{width:42px;height:42px;border-radius:11px;background:var(--surface-2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;flex:none;}
.gmodal-head b{font-size:15px;font-weight:600;display:block;letter-spacing:-.01em;}
.gmodal-head span{font-size:12px;color:var(--ink-3);}
.gacct-label{font-size:11px;font-weight:600;color:var(--ink-3);text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px;}
.gacct-list{display:flex;flex-direction:column;gap:6px;}
.gacct{display:flex;align-items:center;gap:11px;padding:11px 13px;border-radius:11px;border:1px solid var(--border);background:var(--surface);text-align:left;transition:border-color .1s,background .1s;}
.gacct:hover{background:var(--surface-2);}
.gacct.on{border-color:var(--primary);background:var(--primary-tint);}
.gacct-av{width:32px;height:32px;border-radius:50%;color:#fff;font-weight:600;font-size:15px;display:flex;align-items:center;justify-content:center;flex:none;}
.gacct-nm{font-size:13.5px;font-weight:600;color:var(--ink);flex:1;}
.gacct-nm small{display:block;font-size:11px;font-weight:400;color:var(--ink-3);}
.gradio{width:18px;height:18px;border-radius:50%;border:2px solid var(--border-strong);flex:none;}
.gradio.on{border-color:var(--primary);background:radial-gradient(circle,var(--primary) 0 5px,transparent 6px);}
.gscope{font-size:11.5px;color:var(--ink-2);background:var(--surface-2);border-radius:9px;padding:10px 12px;margin:14px 0 16px;line-height:1.5;}
.gscope b{color:var(--ink);font-weight:600;}
.gbtns,.evform-btns,.evview-btns{display:flex;gap:8px;}
.gbtns{justify-content:flex-end;}
.gbtn{font-size:13px;font-weight:600;padding:8px 16px;border-radius:9px;border:1px solid var(--border-strong);background:var(--surface);color:var(--ink-2);transition:background .12s,border-color .12s;}
.gbtn:hover:not(:disabled){background:var(--surface-2);}
.gbtn:disabled{opacity:.5;cursor:default;}
.gbtn.primary{background:var(--primary);color:#fff;border-color:var(--primary);}
.gbtn.primary:hover:not(:disabled){background:var(--primary-2);}
.gbtn.ghost{background:none;}
.gbtn.danger{color:var(--rose);border-color:transparent;}
.gbtn.danger:hover{background:var(--rose-tint);}
.gbtn.wide{width:100%;justify-content:center;text-align:center;}
.ggrant{display:flex;flex-direction:column;align-items:center;gap:10px;padding:26px 0 18px;}
.ggrant b{font-size:14px;}
.ggrant span{font-size:12px;color:var(--ink-3);}
.gspin{width:30px;height:30px;border:3px solid var(--primary-tint-2);border-top-color:var(--primary);border-radius:50%;animation:cspin .7s linear infinite;}

/* sync settings modal */
.setmodal{max-width:520px;padding:20px 22px 16px;}
.setmodal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;}
.setmodal-head b{font-size:16px;font-weight:600;letter-spacing:-.01em;}
.setrow-top{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;background:var(--surface-2);border-radius:11px;margin-bottom:18px;}
.setacct{display:flex;align-items:center;gap:11px;}
.syncbig{width:34px;height:34px;border-radius:9px;background:#eaf3ee;border:1px solid var(--border);flex:none;}
.setacct b{font-size:13.5px;font-weight:600;display:block;}
.setacct span{font-size:11.5px;color:var(--ink-3);}
.setmap-h{font-size:11px;font-weight:600;color:var(--ink-3);text-transform:uppercase;letter-spacing:.04em;}
.setmap-sub{font-size:12px;color:var(--ink-2);margin:4px 0 12px;line-height:1.5;}
.setmap-list{display:flex;flex-direction:column;gap:8px;}
.maprow{display:flex;align-items:center;gap:9px;padding:9px 11px;border:1px solid var(--border);border-radius:10px;flex-wrap:wrap;}
.mapdot{width:11px;height:11px;border-radius:50%;flex:none;}
.mapname{font-size:13px;font-weight:600;color:var(--ink);flex:1;min-width:90px;}
.maparrow{color:var(--ink-3);flex:none;}
.mapsel{font-size:12.5px;padding:6px 9px;border:1px solid var(--border-strong);border-radius:8px;background:var(--surface);color:var(--ink);font-family:inherit;}
.twbtn{display:flex;align-items:center;gap:5px;font-size:11.5px;font-weight:600;color:var(--ink-3);background:var(--surface-2);border:1px solid var(--border);padding:5px 9px;border-radius:8px;}
.twbtn.on{color:var(--green);background:var(--green-tint);border-color:#cfe6d2;}
.twbtn:disabled{opacity:.4;cursor:default;}
.setmodal-foot{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:18px;padding-top:14px;border-top:1px solid var(--border);}
.zoomline{font-size:12.5px;color:var(--ink-2);}
.zoomline b{color:var(--ink);}

/* conflict modal */
.cfmodal{max-width:520px;padding:22px;}
.cfhead{text-align:center;margin-bottom:18px;}
.cfbadge{display:inline-block;font-size:10px;font-weight:700;letter-spacing:.06em;color:var(--primary-2);background:var(--primary-tint);padding:3px 10px;border-radius:20px;margin-bottom:9px;}
.cfhead b{display:block;font-size:16px;font-weight:600;letter-spacing:-.01em;}
.cfhead span{font-size:12.5px;color:var(--ink-2);}
.cfcols{display:flex;align-items:stretch;gap:12px;}
.cfcard{flex:1;border:1px solid var(--border);border-radius:12px;padding:14px;display:flex;flex-direction:column;gap:7px;}
.cfcard.mine{background:var(--primary-tint);border-color:var(--primary-tint-2);}
.cfcard.theirs{background:var(--surface-2);}
.cfk{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-3);}
.cftime{font-size:14px;font-weight:600;color:var(--ink);}
.cfnote{font-size:11.5px;color:var(--ink-2);line-height:1.5;flex:1;}
.cfvs{display:flex;align-items:center;font-size:11px;font-weight:600;color:var(--ink-3);text-transform:uppercase;}
.cffoot{margin-top:16px;}

/* ── event popover / editor ──────────────────────────────────────── */
.pop-back{position:fixed;inset:0;z-index:150;}
.evpop{position:fixed;z-index:160;width:320px;background:var(--surface);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow-lg);padding:16px 16px 14px;animation:mpop .15s cubic-bezier(.2,.7,.3,1);}
.evpop-bar{position:absolute;left:0;top:14px;bottom:14px;width:4px;border-radius:0 3px 3px 0;}
.evpop-x{position:absolute;top:10px;right:10px;width:24px;height:24px;border-radius:7px;border:none;background:var(--surface-2);color:var(--ink-3);font-size:12px;}
.evpop-x:hover{background:var(--surface-3);color:var(--ink);}
.evview h4{margin:0 8px 8px 4px;font-size:16px;font-weight:600;letter-spacing:-.01em;line-height:1.25;padding-right:22px;}
.evv-time{font-size:13px;color:var(--ink-2);margin:0 0 10px 4px;}
.evv-dur{color:var(--ink-3);}
.evv-cal{display:flex;align-items:center;gap:7px;font-size:12.5px;color:var(--ink);margin:0 0 10px 4px;}
.evv-dot{width:11px;height:11px;border-radius:50%;flex:none;}
.cfbtn{display:flex;align-items:center;gap:6px;width:100%;justify-content:center;font-size:12.5px;font-weight:600;color:var(--primary-2);background:var(--primary-tint);border:1px solid var(--primary-tint-2);border-radius:9px;padding:8px;margin:0 0 10px;}
.cfbtn:hover{background:var(--primary-tint-2);}
.evv-person{margin:0 0 10px 2px;}
.evv-loc{font-size:12.5px;color:var(--ink-2);margin:0 0 10px 4px;}
.evv-zoom{display:flex;align-items:center;gap:10px;text-decoration:none;background:#e8f2ff;border:1px solid #cfe2fb;border-radius:10px;padding:9px 11px;margin:0 0 11px;}
.evv-zoom:hover{background:#ddecfd;}
.evv-zoom-t b{font-size:13px;color:#1a6fd4;display:block;}
.evv-zoom-t small{font-size:10.5px;color:#5b88c4;}
.evv-notes{font-size:12.5px;color:var(--ink-2);line-height:1.55;background:var(--surface-2);border-radius:9px;padding:10px 12px;margin-bottom:12px;white-space:pre-wrap;}
.evview-btns{padding-top:2px;}

/* editor form */
.evtitle-in{width:100%;border:none;border-bottom:2px solid var(--border);background:none;font-family:inherit;font-size:16px;font-weight:600;color:var(--ink);padding:2px 4px 7px;margin-bottom:11px;outline:none;}
.evtitle-in:focus{border-color:var(--primary);}
.evf-row{display:flex;align-items:center;gap:9px;margin-bottom:9px;}
.evf-ic{font-size:13px;width:16px;text-align:center;flex:none;opacity:.7;}
.evf-day{font-size:12.5px;color:var(--ink-2);}
.evtime-in,.evf-sel{font-family:inherit;font-size:12.5px;color:var(--ink);border:1px solid var(--border-strong);border-radius:7px;padding:5px 8px;background:var(--surface);}
.evf-dash{color:var(--ink-3);}
.evf-sel{flex:1;}
.evf-grow{flex:1;min-width:0;}
.zoomtoggle{display:flex;align-items:center;gap:10px;padding:9px 11px;border:1px solid var(--border);border-radius:10px;margin:5px 0 8px;background:var(--surface-2);}
.zoomtoggle.on{background:#e8f2ff;border-color:#cfe2fb;}
.zt-ic{flex:none;display:flex;}
.zt-txt{flex:1;}
.zt-txt b{font-size:12.5px;display:block;color:var(--ink);}
.zt-txt span{font-size:11px;color:var(--ink-3);}
.switch{width:38px;height:22px;border-radius:13px;background:var(--surface-3);border:none;position:relative;flex:none;transition:background .15s;}
.switch.on{background:#2D8CFF;}
.switch:disabled{opacity:.4;cursor:default;}
.switch i{position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:#fff;box-shadow:0 1px 2px rgba(0,0,0,.2);transition:left .15s;}
.switch.on i{left:18px;}
.zoomdetail{font-size:10.5px;color:#5b88c4;background:#eef5ff;border-radius:8px;padding:8px 10px;margin-bottom:9px;line-height:1.6;word-break:break-all;}
.evnote-in{width:100%;min-height:54px;resize:vertical;border:1px solid var(--border-strong);border-radius:9px;padding:8px 10px;font-family:inherit;font-size:12.5px;color:var(--ink);background:var(--surface);margin-bottom:11px;outline:none;}
.evnote-in:focus{border-color:var(--primary);}
.evform-btns{align-items:center;}
.evform-spacer{flex:1;}

@media (max-width:720px){
  .cfcols{flex-direction:column;}
  .cfvs{justify-content:center;padding:2px 0;}
  .ct-cals{display:none;}
}
