:root{
  /* Todoist palette */
  --red:#DC4C3E;
  --red-press:#C53929;
  --red-tint:#FCE9E7;
  --p1:#D1453B;
  --p2:#EB8909;
  --p3:#246FE0;
  --green-done:#058527;

  /* Surfaces */
  --bg:#FFFFFF;
  --surface:#FFFFFF;
  --surface-2:#FAFAFA;
  --surface-3:#F5F5F5;

  /* Text */
  --text:#202020;
  --text-2:#808080;
  --text-3:#A0A0A0;

  /* Hairline */
  --line:#EEEEEE;
  --line-strong:#DDDDDD;

  /* Radii (very subtle) */
  --r-sm:6px;
  --r-md:8px;
  --r-lg:10px;
  --r-pill:999px;
}

*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;padding:0}
body{
  font-family:-apple-system,BlinkMacSystemFont,"SF Pro Text","Inter","Helvetica Neue",sans-serif;
  background:#F0F0F0;color:var(--text);min-height:100vh;-webkit-font-smoothing:antialiased;
  font-feature-settings:'ss01','cv11';
}
svg{display:inline-block;flex:0 0 auto;vertical-align:middle;width:18px;height:18px}
button{font-family:inherit;background:none;border:none;color:inherit;padding:0;cursor:pointer}

/* ─── DEMO PAGE CHROME (kept neutral) ─── */
.page{max-width:1240px;margin:0 auto;padding:28px 24px 56px}
.page-h h1{font-size:28px;font-weight:700;margin:0 0 6px;letter-spacing:-0.02em;color:var(--text)}
.page-h p{color:var(--text-2);font-size:13.5px;line-height:1.55;margin:0 0 4px;max-width:820px}
.page-h .note{font-size:12px;color:var(--text-3);font-style:italic;margin:6px 0 0}
.vsw{display:flex;gap:6px;align-items:center;flex-wrap:wrap;margin:0 0 20px;padding:6px 8px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-pill);width:max-content;font-size:12px}
.vsw .vlabel{color:var(--text-3);padding:0 8px 0 6px;letter-spacing:0.04em;text-transform:uppercase;font-size:10px;font-weight:700}
.vsw a{padding:6px 12px;border-radius:var(--r-pill);color:var(--text-2);font-weight:500;text-decoration:none;font-size:12px}
.vsw a[aria-current]{background:var(--red);color:#fff;font-weight:700}
.persona-row{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin:18px 0 22px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden}
@media(max-width:760px){.persona-row{grid-template-columns:1fr 1fr}}
.pb{padding:14px 16px;text-align:left;border-right:1px solid var(--line);background:var(--surface)}
.pb:last-child{border-right:none}
.pb:hover{background:var(--surface-2)}
.pb.active{background:var(--red-tint)}
.pb.active .pb-name{color:var(--red);font-weight:700}
.pb-row{display:flex;align-items:center;gap:8px}
.pb-tag{width:20px;height:20px;border-radius:50%;background:var(--text-3);color:#fff;font-size:11px;font-weight:700;text-align:center;line-height:20px}
.pb.active .pb-tag{background:var(--red)}
.pb-name{font-size:13.5px;font-weight:600;color:var(--text)}
.pb-sub{font-size:11.5px;color:var(--text-2);margin-top:4px;line-height:1.45}
.stage{display:grid;grid-template-columns:380px 1fr;gap:36px;align-items:start}
@media(max-width:900px){.stage{grid-template-columns:1fr}}

/* ─── PHONE ─── */
.phone{
  width:380px;height:780px;border-radius:46px;background:var(--surface);
  box-shadow:0 24px 50px rgba(20,21,26,0.12), 0 4px 12px rgba(20,21,26,0.06);
  border:1px solid var(--line);position:relative;overflow:hidden;display:flex;flex-direction:column;
}
.phone::before{
  content:"";position:absolute;top:14px;left:50%;transform:translateX(-50%);
  width:96px;height:26px;background:#0F0F12;border-radius:14px;z-index:50;
}
.hdr{flex:0 0 auto;padding:38px 16px 10px;display:flex;align-items:center;gap:8px;background:var(--surface);border-bottom:1px solid var(--line)}
.body{flex:1;overflow:auto;background:var(--bg);position:relative;scrollbar-width:none}
.body::-webkit-scrollbar{display:none}
.tabs{flex:0 0 auto;display:flex;background:var(--surface);border-top:1px solid var(--line);padding:8px 4px 14px;justify-content:space-around;position:relative}

/* ─── HEADER ─── */
.hdr-back{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--text)}
.hdr-back:active{background:var(--surface-2)}
.hdr-title{font-size:17px;font-weight:700;flex:1;letter-spacing:-0.015em;color:var(--text)}
.hdr-title.center{text-align:center}
.hdr-greet{flex:1;display:flex;align-items:center;gap:10px;min-width:0;cursor:pointer;padding:4px}
.hdr-avatar{width:32px;height:32px;border-radius:50%;flex:0 0 auto;display:flex;align-items:center;justify-content:center;color:#fff;font-size:12px;font-weight:700;background:linear-gradient(135deg,#5B6068,#2C2E33);position:relative}
.hdr-avatar.tier-l1{background:linear-gradient(135deg,#DC4C3E,#B83A2C)}
.hdr-avatar .tier-pip{position:absolute;bottom:-2px;right:-2px;background:#fff;border:1.5px solid var(--surface);border-radius:50%;width:14px;height:14px;font-size:8px;font-weight:700;display:flex;align-items:center;justify-content:center;color:var(--text)}
.hdr-name{font-size:14px;font-weight:700;line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hdr-sub{font-size:11px;color:var(--text-3);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hdr-btn{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;position:relative;color:var(--text-2)}
.hdr-btn:active{background:var(--surface-2)}
.hdr-btn.has-dot::after{content:"";position:absolute;top:8px;right:9px;width:7px;height:7px;background:var(--red);border-radius:50%;border:2px solid var(--surface)}

/* ─── TABS (line icons, red on active) ─── */
.tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:6px 2px;color:var(--text-3);min-width:0;position:relative}
.tab svg{width:22px;height:22px;color:currentColor}
.tab .tab-l{font-size:10.5px;font-weight:500;letter-spacing:-0.005em}
.tab.active{color:var(--red)}
.tab.active .tab-l{font-weight:700}
.tab .tab-badge{position:absolute;top:2px;right:14px;background:var(--red);color:#fff;border-radius:var(--r-pill);font-size:9px;font-weight:700;padding:1px 5px;min-width:16px;text-align:center;border:2px solid var(--surface)}

/* ─── BODY COMMON ─── */
.body-pad{padding:16px 18px 100px}
.h-screen{font-size:26px;font-weight:700;letter-spacing:-0.02em;margin:8px 0 14px;color:var(--text)}
.h-section{font-size:13px;font-weight:700;color:var(--text);margin:24px 0 8px;letter-spacing:-0.005em;display:flex;align-items:baseline;gap:6px}
.h-section.first{margin-top:6px}
.h-section .count{color:var(--text-3);font-size:12px;font-weight:600}
.h-block{font-size:14px;font-weight:700;color:var(--text);margin:20px 0 8px;letter-spacing:-0.005em}
.h-block:first-child{margin-top:6px}
.row-between{display:flex;justify-content:space-between;align-items:center;gap:8px}
.see-all{font-size:13px;font-weight:500;color:var(--text-2);display:flex;align-items:center;gap:2px;cursor:pointer}
.see-all:hover{color:var(--red)}

/* ─── SEARCH (subtle, no shadow) ─── */
.search{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--surface-2);border-radius:var(--r-md);font-size:14px;color:var(--text-3);margin:0 0 14px;cursor:pointer}
.search svg{color:var(--text-3);width:16px;height:16px}
.search:active{background:var(--surface-3)}

/* ─── CHIPS (very minimal) ─── */
.chips{display:flex;gap:6px;overflow-x:auto;padding:2px 0 6px;scrollbar-width:none}
.chips::-webkit-scrollbar{display:none}
.chip{flex-shrink:0;padding:6px 13px;border-radius:var(--r-pill);background:transparent;border:1px solid var(--line);font-size:12.5px;color:var(--text-2);font-weight:500;white-space:nowrap;cursor:pointer}
.chip.active{background:var(--text);color:#fff;border-color:var(--text);font-weight:600}
.chip:not(.active):active{background:var(--surface-2)}

/* ─── TASK ROW (Todoist circle + hairline) ─── */
.task-row{display:flex;align-items:flex-start;gap:14px;padding:12px 0;border-bottom:1px solid var(--line);cursor:pointer;min-height:48px}
.task-row:last-child{border-bottom:none}
.task-row:active{background:var(--surface-2);margin:0 -18px;padding-left:18px;padding-right:18px}
.task-row .check{width:18px;height:18px;border-radius:50%;border:1.5px solid var(--text-3);flex:0 0 auto;margin-top:3px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all 0.15s}
.task-row .check:hover{border-color:var(--text)}
.task-row .check.p1{border-color:var(--p1);background:rgba(209,69,59,0.06)}
.task-row .check.p2{border-color:var(--p2);background:rgba(235,137,9,0.06)}
.task-row .check.p3{border-color:var(--p3);background:rgba(36,111,224,0.06)}
.task-row.done .check{background:var(--green-done);border-color:var(--green-done)}
.task-row.done .check::after{content:"";width:5px;height:9px;border:solid #fff;border-width:0 1.5px 1.5px 0;transform:rotate(45deg);margin-top:-2px}
.task-row .t-body{flex:1;min-width:0}
.task-row .t-title{font-size:14.5px;font-weight:500;color:var(--text);line-height:1.4;word-break:break-word}
.task-row.done .t-title{text-decoration:line-through;color:var(--text-3)}
.task-row .t-meta{display:flex;gap:8px;align-items:center;font-size:12px;color:var(--text-2);margin-top:3px;flex-wrap:wrap}
.task-row .t-due{color:var(--red);font-weight:500}
.task-row .t-due.tomorrow{color:var(--p2)}
.task-row .t-due.later{color:var(--text-2)}
.task-row .t-project{display:inline-flex;align-items:center;gap:3px}
.task-row .t-project .proj-dot{width:6px;height:6px;border-radius:50%;background:var(--p3)}
.task-row .t-actions{display:flex;align-items:center;gap:4px;flex:0 0 auto;color:var(--text-3);margin-top:1px}
.task-row .t-actions svg{width:14px;height:14px}
.task-row .t-join{font-size:12px;font-weight:600;color:var(--red);padding:5px 11px;border-radius:6px;border:1px solid var(--line)}
.task-row .t-join:active{background:var(--red-tint)}

/* ─── PUNCH BLOCK (Todoist-clean, big number + red action) ─── */
.punch-block{padding:8px 0 20px;border-bottom:1px solid var(--line);margin-bottom:8px}
.punch-status{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--green-done);text-transform:uppercase;letter-spacing:0.05em;margin-bottom:8px}
.punch-status .dot{width:7px;height:7px;border-radius:50%;background:var(--green-done)}
.punch-status.out{color:var(--text-3)}
.punch-status.out .dot{background:var(--text-3)}
.punch-elapsed{display:flex;align-items:baseline;gap:6px;margin-bottom:6px}
.punch-elapsed .pe-h{font-size:42px;font-weight:700;letter-spacing:-0.03em;color:var(--text);font-feature-settings:'tnum'}
.punch-elapsed .pe-of{font-size:15px;color:var(--text-3);font-weight:500}
.punch-bar{height:4px;background:var(--surface-3);border-radius:2px;margin-bottom:16px;overflow:hidden}
.punch-bar .pb-fill{height:100%;background:var(--green-done);border-radius:2px}
.punch-meta{display:flex;gap:14px;font-size:12px;color:var(--text-2);margin-bottom:14px}
.punch-meta b{color:var(--text);font-weight:600;font-feature-settings:'tnum'}
.punch-actions{display:flex;gap:10px;align-items:center}
.punch-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:12px;background:var(--red);color:#fff;font-size:14px;font-weight:600;border-radius:var(--r-md);position:relative;overflow:hidden}
.punch-btn:active{background:var(--red-press)}
.punch-btn.out{background:var(--red)}
.punch-btn.in{background:var(--green-done)}
.punch-btn.in:active{background:#04691F}
.punch-btn .hold-fill{position:absolute;inset:0;background:rgba(255,255,255,0.25);transform-origin:left;transform:scaleX(0)}
.punch-block.hold .punch-btn .hold-fill{animation:holdfill 1.1s linear forwards}
@keyframes holdfill{to{transform:scaleX(1)}}
.punch-aux{padding:11px 14px;font-size:13px;font-weight:500;color:var(--text);border:1px solid var(--line);border-radius:var(--r-md);display:flex;align-items:center;gap:5px}
.punch-aux:active{background:var(--surface-2)}

/* ─── QUICK ACTIONS (text-only row, like Todoist's natural-language hints) ─── */
.qa-list{display:flex;flex-direction:column;border-top:1px solid var(--line);border-bottom:1px solid var(--line);margin:8px 0 14px}
.qa-list .qa-row{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--line);cursor:pointer}
.qa-list .qa-row:last-child{border-bottom:none}
.qa-list .qa-row:active{background:var(--surface-2);margin:0 -18px;padding-left:18px;padding-right:18px}
.qa-list .qa-row .qa-i{width:24px;height:24px;display:flex;align-items:center;justify-content:center;color:var(--text-2);flex:0 0 auto}
.qa-list .qa-row .qa-i svg{width:18px;height:18px}
.qa-list .qa-row .qa-t{flex:1;font-size:14px;font-weight:500;color:var(--text)}
.qa-list .qa-row .qa-c{font-size:12px;color:var(--text-3)}

/* ─── ANNOUNCE CAROUSEL (lightweight, no boxed cards) ─── */
.ann-track{display:flex;gap:0;overflow-x:auto;padding:0;margin:0 -18px;scroll-snap-type:x mandatory;scrollbar-width:none}
.ann-track::-webkit-scrollbar{display:none}
.ann-card{flex:0 0 86%;scroll-snap-align:start;padding:14px 18px;border-right:1px solid var(--line);cursor:pointer}
.ann-card:last-child{border-right:none}
.ann-card .ann-tag{display:inline-block;font-size:11px;color:var(--red);font-weight:700;text-transform:uppercase;letter-spacing:0.05em;margin-bottom:6px}
.ann-card .ann-title{font-size:15px;font-weight:700;color:var(--text);line-height:1.35;margin-bottom:4px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.ann-card .ann-body-text{font-size:12.5px;color:var(--text-2);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* ─── BIRTHDAY ROW (minimal text-row, no avatar art) ─── */
.bday-list{display:flex;flex-direction:column}
.bday-row{display:flex;align-items:center;gap:12px;padding:10px 0;cursor:pointer;border-bottom:1px solid var(--line)}
.bday-row:last-child{border-bottom:none}
.bday-row .bd-av{width:30px;height:30px;border-radius:50%;background:var(--surface-3);color:var(--text-2);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex:0 0 auto}
.bday-row .bd-name{font-size:14px;font-weight:500;color:var(--text);flex:1}
.bday-row .bd-action{font-size:12px;color:var(--red);font-weight:600}

/* ─── AVATARS (muted gradient, no rainbow) ─── */
.av{border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;flex:0 0 auto}
.av.av1{background:#4A4A4A}
.av.av2{background:#5B6068}
.av.av3{background:#7A7A82}
.av.av4{background:#3E3E3E}
.av.av5{background:#6A6A6A}
.av.av6{background:#525252}
.av.ai{background:conic-gradient(from 0deg,#F43F5E,#A855F7,#6366F1,#F43F5E)}
.av.channel{background:var(--red);position:relative}

/* ─── LOCKED (super minimal) ─── */
.locked{padding:14px 16px;border:1px dashed var(--line-strong);border-radius:var(--r-md);display:flex;gap:12px;align-items:flex-start;margin-bottom:14px;background:var(--surface-2)}
.locked .lk-icon{width:24px;height:24px;color:var(--text-3);display:flex;align-items:center;justify-content:center;flex:0 0 auto;margin-top:1px}
.locked .lk-body{flex:1;min-width:0}
.locked .lk-title{font-size:14px;font-weight:700;color:var(--text);line-height:1.3}
.locked .lk-sub{font-size:12.5px;color:var(--text-2);margin-top:3px;line-height:1.5}
.locked .lk-learn{font-size:12.5px;font-weight:600;color:var(--red);margin-top:6px;display:inline-block;cursor:pointer}

/* ─── PAYROLL BLOCK (no card — typographic) ─── */
.payroll-block{padding:6px 0 18px;border-bottom:1px solid var(--line);margin-bottom:14px}
.payroll-month{font-size:12px;font-weight:700;color:var(--red);text-transform:uppercase;letter-spacing:0.05em;display:flex;align-items:center;gap:4px;cursor:pointer;margin-bottom:8px}
.payroll-amt{font-size:42px;font-weight:700;letter-spacing:-0.03em;color:var(--text);font-feature-settings:'tnum';line-height:1}
.payroll-amt small{font-size:22px;color:var(--text-3);font-weight:600;margin-right:4px}
.payroll-label{font-size:13px;color:var(--text-2);margin-top:4px}
.payroll-split{display:flex;gap:20px;margin-top:14px;font-size:12.5px;color:var(--text-2)}
.payroll-split b{color:var(--text);font-weight:600;display:block;font-size:14px;margin-top:1px;font-feature-settings:'tnum'}
.payroll-cta{display:inline-flex;align-items:center;gap:4px;font-size:13px;font-weight:600;color:var(--red);margin-top:14px;cursor:pointer}

/* ─── APPROVAL ROW (list-style, inline actions) ─── */
.appr-row{padding:14px 0;border-bottom:1px solid var(--line)}
.appr-row:last-child{border-bottom:none}
.appr-head{display:flex;align-items:flex-start;gap:12px;margin-bottom:10px}
.appr-av{width:34px;height:34px;font-size:12px;flex:0 0 auto}
.appr-name{font-size:14.5px;font-weight:600;color:var(--text);line-height:1.3;display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.appr-meta{font-size:12px;color:var(--text-2);margin-top:2px;line-height:1.4}
.appr-tier{display:inline-flex;align-items:center;font-size:10px;font-weight:700;padding:2px 7px;border-radius:var(--r-pill);background:var(--p3);color:#fff;letter-spacing:0.05em;text-transform:uppercase}
.appr-type{font-size:13px;color:var(--text);margin-bottom:8px;padding-left:46px}
.appr-acts{display:flex;gap:14px;padding-left:46px}
.btn-approve{padding:7px 14px;background:var(--green-done);color:#fff;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer}
.btn-approve:active{background:#04691F}
.btn-reject{padding:7px 14px;background:transparent;color:var(--text-2);border:1px solid var(--line);border-radius:6px;font-size:13px;font-weight:500;cursor:pointer}
.btn-reject:active{background:var(--surface-2)}

/* ─── ATTENDANCE PULSE (typographic) ─── */
.pulse-block{padding:6px 0 14px;border-bottom:1px solid var(--line);margin-bottom:14px}
.pulse-num{font-size:34px;font-weight:700;color:var(--text);letter-spacing:-0.03em;font-feature-settings:'tnum';line-height:1.1}
.pulse-num small{color:var(--text-3);font-weight:500;font-size:18px;margin-left:4px}
.pulse-sub{font-size:12.5px;color:var(--text-2);margin-top:4px}
.pulse-bar{height:5px;border-radius:3px;background:var(--surface-3);display:flex;gap:1px;overflow:hidden;margin-top:14px}
.pulse-bar .pb-s{height:100%}
.pulse-bar .s-p{background:var(--green-done)}
.pulse-bar .s-a{background:var(--p1)}
.pulse-bar .s-l{background:var(--p3)}
.pulse-legend{display:flex;gap:14px;flex-wrap:wrap;font-size:11.5px;color:var(--text-2);margin-top:10px}
.pulse-legend .lg-d{width:7px;height:7px;border-radius:50%;display:inline-block;margin-right:5px;vertical-align:middle}

/* ─── MANAGE LIST (flat list of options) ─── */
.manage-list{display:flex;flex-direction:column;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.manage-row{display:flex;align-items:center;gap:14px;padding:14px 0;border-bottom:1px solid var(--line);cursor:pointer}
.manage-row:last-child{border-bottom:none}
.manage-row:active{background:var(--surface-2);margin:0 -18px;padding-left:18px;padding-right:18px}
.manage-row .mr-i{width:24px;height:24px;color:var(--text);display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.manage-row .mr-i.locked{color:var(--text-3)}
.manage-row .mr-body{flex:1;min-width:0}
.manage-row .mr-title{font-size:14.5px;font-weight:500;color:var(--text)}
.manage-row .mr-title.locked{color:var(--text-3)}
.manage-row .mr-meta{font-size:12px;color:var(--text-2);margin-top:1px}
.manage-row .mr-badge{background:var(--red);color:#fff;font-size:11px;font-weight:700;padding:2px 8px;border-radius:var(--r-pill);flex:0 0 auto}
.manage-row .mr-chev{color:var(--text-3);flex:0 0 auto}

/* ─── PROFILE HERO (typographic) ─── */
.profile-hero{display:flex;align-items:center;gap:14px;padding:14px 0 18px;border-bottom:1px solid var(--line);margin-bottom:14px}
.profile-hero .ph-av{width:56px;height:56px;font-size:17px;flex:0 0 auto;background:linear-gradient(135deg,#3E3E3E,#1A1A1A)}
.profile-hero .ph-av.tier-l1{background:linear-gradient(135deg,#DC4C3E,#9C2A1F)}
.profile-hero .ph-name{font-size:17px;font-weight:700;letter-spacing:-0.01em}
.profile-hero .ph-role{font-size:13px;color:var(--text-2);margin-top:2px;line-height:1.4}
.profile-hero .ph-pills{display:flex;gap:6px;margin-top:5px}

/* ─── PILLS (very subtle) ─── */
.pill{display:inline-flex;align-items:center;font-size:10.5px;font-weight:700;padding:2px 8px;border-radius:var(--r-pill);text-transform:uppercase;letter-spacing:0.04em;background:var(--surface-3);color:var(--text-2)}
.pill.green{background:rgba(5,133,39,0.10);color:var(--green-done)}
.pill.red{background:var(--red-tint);color:var(--red)}
.pill.blue{background:rgba(36,111,224,0.10);color:var(--p3)}
.pill.amber{background:rgba(235,137,9,0.10);color:var(--p2)}

/* ─── BRANCH CHIP (minimal) ─── */
.branch-chip{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--line);margin-bottom:14px}
.branch-chip .bc-name{font-size:15px;font-weight:700}
.branch-chip .bc-sub{font-size:12px;color:var(--text-2);margin-top:1px}
.branch-chip .bc-change{margin-left:auto;font-size:13px;font-weight:600;color:var(--red);cursor:pointer}

/* ─── CHAT ROW (list-style) ─── */
.chat-row{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--line);cursor:pointer}
.chat-row:active{background:var(--surface-2);margin:0 -18px;padding-left:18px;padding-right:18px}
.chat-row:last-child{border-bottom:none}
.chat-row .av{width:42px;height:42px;font-size:13px}
.chat-row .c-body{flex:1;min-width:0}
.chat-row .c-name{font-size:14.5px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;gap:5px}
.chat-row .c-name .c-tag{font-size:9px;font-weight:700;padding:1px 5px;border-radius:3px;background:var(--red-tint);color:var(--red);letter-spacing:0.02em;text-transform:uppercase}
.chat-row .c-prev{font-size:13px;color:var(--text-2);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.chat-row .c-meta{display:flex;flex-direction:column;align-items:flex-end;gap:5px;flex:0 0 auto}
.chat-row .c-time{font-size:11px;color:var(--text-3)}
.chat-row .unread{background:var(--red);color:#fff;font-size:10.5px;font-weight:700;min-width:20px;height:20px;border-radius:var(--r-pill);display:flex;align-items:center;justify-content:center;padding:0 6px}

/* ─── ADD-TASK BAR (sticky top of Tasks) ─── */
.add-bar{display:flex;align-items:center;gap:12px;padding:14px 0 14px;cursor:pointer;border-bottom:1px solid var(--line);margin-bottom:8px}
.add-bar .add-i{width:24px;height:24px;border-radius:50%;background:var(--red);color:#fff;display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.add-bar .add-i svg{width:14px;height:14px}
.add-bar .add-l{font-size:14.5px;font-weight:600;color:var(--red)}

/* ─── DATE STRIP ─── */
.date-strip{display:flex;gap:0;margin:14px 0 12px;overflow-x:auto;scrollbar-width:none;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:6px 0}
.date-strip::-webkit-scrollbar{display:none}
.day-pill{flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 14px;cursor:pointer;min-width:50px;color:var(--text-2)}
.day-pill .dp-d{font-size:11px;font-weight:600;letter-spacing:0.02em}
.day-pill .dp-n{font-size:17px;font-weight:700;font-feature-settings:'tnum'}
.day-pill.today .dp-d,.day-pill.today .dp-n{color:var(--red)}
.day-pill .dp-dot{width:4px;height:4px;border-radius:50%;background:var(--red);margin-top:1px}
.day-pill:not(.has-events) .dp-dot{visibility:hidden}

/* ─── FORM ─── */
.field{margin-bottom:14px}
.field label{display:block;font-size:12px;color:var(--text-2);font-weight:600;margin-bottom:6px}
.field input,.field textarea,.field select{width:100%;padding:11px 14px;border-radius:var(--r-md);border:1px solid var(--line);background:var(--surface);color:var(--text);font-size:14.5px;font-family:inherit;color-scheme:light}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--text)}
.field-row{display:flex;gap:8px}
.field-row .field{flex:1}
.btn-primary{display:block;width:100%;padding:13px;background:var(--red);color:#fff;border-radius:var(--r-md);font-size:14px;font-weight:600;font-family:inherit}
.btn-primary:active{background:var(--red-press)}
.btn-secondary{display:block;width:100%;padding:13px;background:transparent;color:var(--text);border:1px solid var(--line);border-radius:var(--r-md);font-size:14px;font-weight:600;font-family:inherit}
.btn-block{display:flex;width:100%;justify-content:center;align-items:center;gap:6px;padding:13px;border-radius:var(--r-md);font-size:14px;font-weight:500;border:1px solid var(--line);background:transparent;color:var(--text);font-family:inherit}
.btn-block:active{background:var(--surface-2)}

/* ─── TOAST ─── */
.toast{position:fixed;left:50%;bottom:96px;transform:translate(-50%,12px);background:var(--text);color:#fff;font-size:13px;font-weight:500;padding:10px 18px;border-radius:var(--r-pill);box-shadow:0 8px 24px rgba(0,0,0,0.15);opacity:0;pointer-events:none;z-index:1000;transition:opacity 0.18s, transform 0.18s;white-space:nowrap}
.toast.show{opacity:1;transform:translate(-50%,0)}
.toast.success{background:var(--green-done)}
.toast.danger{background:var(--red)}

/* ─── NOTIFICATIONS SHEET ─── */
.sheet{position:absolute;inset:0;background:rgba(0,0,0,0.35);z-index:30;display:flex;align-items:flex-end;animation:fadein 0.18s}
@keyframes fadein{from{opacity:0}to{opacity:1}}
.sheet-panel{width:100%;background:var(--surface);border-radius:18px 18px 0 0;max-height:80%;display:flex;flex-direction:column;animation:slideup 0.22s cubic-bezier(0.2,0.8,0.2,1)}
@keyframes slideup{from{transform:translateY(40px);opacity:0}to{transform:translateY(0);opacity:1}}
.sheet-handle{width:36px;height:4px;border-radius:2px;background:var(--line-strong);margin:8px auto 4px}
.sheet-head{display:flex;align-items:center;justify-content:space-between;padding:8px 18px 12px;border-bottom:1px solid var(--line)}
.sheet-head h3{font-size:17px;font-weight:700;margin:0;letter-spacing:-0.01em}
.sheet-body{flex:1;overflow:auto;padding:4px 0}
.sheet-body::-webkit-scrollbar{display:none}
.notif-row{display:flex;align-items:flex-start;gap:12px;padding:14px 18px;cursor:pointer;border-bottom:1px solid var(--line)}
.notif-row:last-child{border-bottom:none}
.notif-row .nr-dot{width:8px;height:8px;border-radius:50%;background:transparent;flex:0 0 auto;margin-top:6px}
.notif-row.unread .nr-dot{background:var(--red)}
.notif-row .nr-title{font-size:14px;font-weight:600;color:var(--text);line-height:1.35}
.notif-row .nr-meta{font-size:12px;color:var(--text-2);margin-top:2px}

/* ─── FAB (the iconic red + button) ─── */
.fab{position:absolute;right:18px;bottom:90px;width:56px;height:56px;border-radius:50%;background:var(--red);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 22px rgba(220,76,62,0.40), 0 2px 6px rgba(220,76,62,0.20);z-index:20;cursor:pointer}
.fab:active{transform:scale(0.95);background:var(--red-press)}
.fab svg{width:24px;height:24px}

/* ─── INFO PANEL ─── */
.info{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:18px 22px;align-self:start}
.info h3{font-size:11px;font-weight:700;color:var(--text-3);margin:0 0 10px;letter-spacing:0.06em;text-transform:uppercase}
.info section{padding:14px 0;border-bottom:1px solid var(--line)}
.info section:first-of-type{padding-top:0}
.info section:last-of-type{border-bottom:none;padding-bottom:0}
.info-row{display:flex;justify-content:space-between;font-size:13px;padding:4px 0;color:var(--text-2)}
.info-row b{color:var(--text);font-weight:600}
.info p{font-size:12.5px;color:var(--text-2);line-height:1.6;margin:6px 0 0}
.info code{font-size:11px;background:var(--surface-2);color:var(--text);padding:2px 6px;border-radius:4px;font-family:ui-monospace,'SF Mono',monospace}

/* ─── EMPTY (friendly, Todoist-style) ─── */
.empty{padding:50px 16px;text-align:center}
.empty-t{font-size:15px;font-weight:600;color:var(--text);margin-bottom:6px}
.empty-s{font-size:13px;color:var(--text-2);line-height:1.55}

/* ─── PERMISSION-NOTE BANNER ─── */
.perm-banner{padding:14px 16px;border:1px dashed var(--line-strong);border-radius:var(--r-md);background:var(--surface-2);display:flex;gap:12px;align-items:flex-start;margin-bottom:14px}
.perm-banner .pb-i{width:24px;height:24px;color:var(--text-3);display:flex;align-items:center;justify-content:center;flex:0 0 auto;margin-top:1px}
.perm-banner .pb-title{font-size:14px;font-weight:700;color:var(--text)}
.perm-banner .pb-sub{font-size:12.5px;color:var(--text-2);margin-top:3px;line-height:1.5}

/* ─── COMPAT (v7 list-card / lr* classes — render in Todoist style) ─── */
.list-card{border-top:1px solid var(--line);border-bottom:1px solid var(--line);margin-bottom:14px}
.lr{display:flex;align-items:center;gap:14px;padding:14px 0;border-bottom:1px solid var(--line);cursor:pointer}
.lr:last-child{border-bottom:none}
.lr:active{background:var(--surface-2);margin:0 -18px;padding-left:18px;padding-right:18px}
.lr .lr-i{width:24px;height:24px;color:var(--text);display:flex;align-items:center;justify-content:center;flex:0 0 auto;background:transparent !important}
.lr .lr-i svg{width:18px;height:18px}
.lr .lr-i.blue,.lr .lr-i.amber,.lr .lr-i.red,.lr .lr-i.purple,.lr .lr-i.pink,.lr .lr-i.gray{color:var(--text)}
.lr .lr-body{flex:1;min-width:0}
.lr .lr-title{font-size:14.5px;font-weight:500;color:var(--text);line-height:1.35}
.lr .lr-sub{font-size:12px;color:var(--text-2);margin-top:1px;line-height:1.4}
.lr .lr-trail{font-size:13px;color:var(--text-2);font-feature-settings:'tnum';flex:0 0 auto}
.lr > svg:last-child{color:var(--text-3)}

/* ─── THREAD ─── */
.thread-day{text-align:center;font-size:11px;color:var(--text-3);font-weight:600;margin:8px 0;letter-spacing:0.04em;text-transform:uppercase}
.msg{display:flex;flex-direction:column;max-width:78%;margin-bottom:6px}
.msg.in{align-self:flex-start}
.msg.out{align-self:flex-end;align-items:flex-end}
.bubble{padding:9px 13px;font-size:14px;border-radius:14px;line-height:1.4}
.msg.in .bubble{background:var(--surface-2);color:var(--text);border-bottom-left-radius:4px}
.msg.out .bubble{background:var(--red);color:#fff;border-bottom-right-radius:4px}
.msg .ts{font-size:11px;color:var(--text-3);margin:2px 6px 0}
