  :root{
    --paper:#f7f5f0;--paper-2:#fbfaf7;--card:#ffffff;
    --ink:#1c1d1a;--ink-soft:#5c5e58;--ink-faint:#9a9b94;
    --line:#e6e3da;--line-soft:#efece4;
    --teal:#1f6f6b;--teal-soft:#e7f0ef;
    --amber:#bd8334;--amber-soft:#f6ecdc;
    --rose:#b1554f;--rose-soft:#f5e3e0;
    --radius:14px;
    --shadow:0 1px 2px rgba(28,29,26,.04), 0 4px 16px rgba(28,29,26,.05);
    --shadow-lift:0 6px 28px rgba(28,29,26,.12);
  }
  *{box-sizing:border-box;margin:0;padding:0}
  html,body{height:100%}
  body{font-family:'Hanken Grotesk',sans-serif;background:var(--paper);color:var(--ink);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;display:flex;height:100vh;overflow:hidden}
  ::selection{background:var(--teal);color:#fff}

  /* Sidebar */
  .sidebar{width:236px;flex-shrink:0;background:var(--paper-2);border-right:1px solid var(--line);display:flex;flex-direction:column;padding:22px 16px;overflow:hidden}
  .brand{display:flex;align-items:center;gap:10px;padding:4px 8px 22px}
  .brand .mark{width:30px;height:30px;border-radius:9px;background:var(--teal);color:#fff;display:grid;place-items:center;font-family:'Instrument Serif',serif;font-size:20px;box-shadow:var(--shadow)}
  .brand .name{font-family:'Instrument Serif',serif;font-size:23px;letter-spacing:.2px;line-height:1}
  .brand .sub{font-size:11px;color:var(--ink-faint);letter-spacing:.4px;text-transform:uppercase;margin-top:1px}
  .nav{display:flex;flex-direction:column;gap:2px;margin-top:6px;flex:1 1 auto;min-height:0;overflow-y:auto}
  .nav-label{font-size:10.5px;letter-spacing:1.2px;text-transform:uppercase;color:var(--ink-faint);padding:14px 10px 6px}
  .nav a{display:flex;align-items:center;gap:11px;padding:9px 10px;border-radius:9px;color:var(--ink-soft);text-decoration:none;font-weight:500;cursor:pointer;transition:background .15s,color .15s}
  .nav a svg{width:17px;height:17px;stroke-width:1.7;flex-shrink:0}
  .nav a:hover{background:var(--line-soft);color:var(--ink)}
  .nav a.active{background:var(--teal);color:#fff;box-shadow:var(--shadow)}
  .nav a .count{margin-left:auto;font-size:11px;background:rgba(0,0,0,.06);padding:1px 7px;border-radius:20px;font-weight:600}
  .nav a.active .count{background:rgba(255,255,255,.22)}
  .team-box{margin-top:18px;padding:12px;border:1px solid var(--line);border-radius:12px;background:var(--card);flex-shrink:0}
  .team-box #teamList{max-height:24vh;overflow-y:auto}
  .team-box .tt{font-size:10.5px;letter-spacing:1px;text-transform:uppercase;color:var(--ink-faint);margin-bottom:9px}
  .team-row{display:flex;align-items:center;gap:9px;padding:4px 0;font-size:12.5px;color:var(--ink-soft)}
  .team-row .dotc{width:9px;height:9px;border-radius:50%}
  .user{margin-top:12px;flex-shrink:0;display:flex;align-items:center;gap:10px;padding:10px;border-radius:11px;border:1px solid var(--line);background:var(--card)}
  .avatar{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;font-weight:700;font-size:13px}
  .user .meta{line-height:1.2;overflow:hidden}
  .user .meta b{font-size:13px;font-weight:600;display:block;white-space:nowrap;text-overflow:ellipsis;overflow:hidden}
  .user .meta span{font-size:11px;color:var(--ink-faint)}

  /* Main */
  .main{flex:1;display:flex;flex-direction:column;overflow:hidden}
  .topbar{height:64px;flex-shrink:0;display:flex;align-items:center;gap:18px;padding:0 30px;border-bottom:1px solid var(--line);background:var(--paper-2)}
  .topbar h1{font-family:'Instrument Serif',serif;font-size:27px;font-weight:400;letter-spacing:.2px}
  .search{margin-left:auto;display:flex;align-items:center;gap:9px;background:var(--card);border:1px solid var(--line);padding:8px 14px;border-radius:10px;width:248px;color:var(--ink-faint)}
  .search svg{width:15px;height:15px;stroke-width:1.8}
  .search input{border:0;outline:0;background:transparent;font-family:inherit;font-size:13px;color:var(--ink);width:100%}
  .btn{display:inline-flex;align-items:center;gap:7px;background:var(--teal);color:#fff;border:0;cursor:pointer;font-family:inherit;font-weight:600;font-size:13px;padding:9px 15px;border-radius:10px;box-shadow:var(--shadow);transition:transform .12s, filter .15s}
  .btn:hover{filter:brightness(1.07)}
  .btn:active{transform:translateY(1px)}
  .btn svg{width:15px;height:15px;stroke-width:2}
  .btn.ghost{background:var(--card);color:var(--ink);border:1px solid var(--line);box-shadow:none}
  .view{flex:1;overflow:auto;padding:26px 30px 40px}
  .view::-webkit-scrollbar{height:11px;width:11px}
  .view::-webkit-scrollbar-thumb{background:#dcd8cd;border-radius:20px;border:3px solid var(--paper)}
  .hidden{display:none !important}

  /* metrics */
  .metrics{display:flex;gap:14px;margin-bottom:24px;flex-wrap:wrap}
  .metric{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:15px 18px;min-width:158px;box-shadow:var(--shadow)}
  .metric .k{font-size:11px;letter-spacing:.4px;text-transform:uppercase;color:var(--ink-faint)}
  .metric .v{font-family:'Instrument Serif',serif;font-size:30px;line-height:1.1;margin-top:4px}
  .metric .v small{font-size:15px;color:var(--ink-faint)}
  .metric .d{font-size:12px;color:var(--teal);font-weight:600;margin-top:2px}

  /* Kanban */
  .board{display:flex;gap:16px;align-items:flex-start;min-height:0}
  .col{width:262px;flex-shrink:0}
  .col-head{display:flex;align-items:center;gap:8px;padding:0 4px 12px}
  .col-head .dot{width:8px;height:8px;border-radius:50%;background:var(--teal);flex-shrink:0}
  .col-head h3{font-size:12.5px;font-weight:700;letter-spacing:.2px}
  .col-head .sum{margin-left:auto;font-size:11px;color:var(--ink-faint);background:var(--line-soft);padding:1px 8px;border-radius:20px;font-weight:600}
  .col-body{display:flex;flex-direction:column;gap:10px;min-height:60px;padding:4px;border-radius:12px}
  .col-body.drop{background:var(--teal-soft);outline:1.5px dashed var(--teal)}
  .deal{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:13px 14px;box-shadow:var(--shadow);cursor:grab;transition:box-shadow .15s, transform .15s, border-color .15s;position:relative}
  .deal:hover{box-shadow:var(--shadow-lift);border-color:#d8d4c8;transform:translateY(-1px)}
  .deal.dragging{opacity:.4}
  .deal .title{font-weight:600;font-size:13.5px;line-height:1.3;margin-bottom:8px;padding-right:18px}
  .deal .org{display:flex;align-items:center;gap:7px;color:var(--ink-soft);font-size:12px;margin-bottom:11px}
  .deal .org .ic{width:21px;height:21px;border-radius:6px;background:var(--teal-soft);color:var(--teal);display:grid;place-items:center;font-weight:700;font-size:10px;flex-shrink:0}
  .deal .foot{display:flex;align-items:center;justify-content:space-between;padding-top:10px;border-top:1px solid var(--line-soft)}
  .deal .val{font-weight:700;font-size:13px}
  .deal .val.zero{color:var(--ink-faint);font-weight:500}
  .deal .del-deal{position:absolute;top:8px;right:8px;width:20px;height:20px;border-radius:6px;border:0;background:transparent;cursor:pointer;color:var(--ink-faint);opacity:0;display:grid;place-items:center;transition:.15s}
  .deal:hover .del-deal{opacity:1}
  .deal .del-deal:hover{color:var(--rose)}
  .deal .del-deal svg{width:13px;height:13px;stroke-width:2}
  .tag{font-size:10.5px;font-weight:600;padding:2px 8px;border-radius:20px;display:inline-flex;align-items:center;gap:4px}
  .tag.due{background:var(--rose-soft);color:var(--rose)}
  .tag.ok{background:var(--teal-soft);color:var(--teal)}
  .tag.soon{background:var(--amber-soft);color:var(--amber)}
  .col-x{width:20px;height:20px;border-radius:6px;border:1px solid transparent;background:transparent;cursor:pointer;display:grid;place-items:center;color:var(--ink-faint);opacity:0;transition:.15s}
  .col:hover .col-x{opacity:1}
  .col-x:hover{border-color:var(--rose);color:var(--rose)}
  .col-x svg{width:12px;height:12px;stroke-width:2.2}
  .add-deal{display:flex;align-items:center;gap:7px;padding:9px;border:1.5px dashed var(--line);border-radius:10px;color:var(--ink-faint);cursor:pointer;font-size:12.5px;font-weight:600;justify-content:center;transition:.15s}
  .add-deal:hover{border-color:var(--teal);color:var(--teal);background:var(--teal-soft)}
  .add-deal svg{width:13px;height:13px;stroke-width:2.4}
  .add-stage{width:50px;flex-shrink:0;border:1.6px dashed var(--line);border-radius:12px;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--ink-faint);min-height:160px;transition:.15s;font-family:inherit}
  .add-stage:hover{border-color:var(--teal);color:var(--teal);background:var(--teal-soft)}
  .add-stage svg{width:20px;height:20px;stroke-width:2}

  /* Contacts grid */
  .contacts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:14px}
  .contacts-grid.grouped{display:block}
  .cgroup{margin-bottom:24px}
  .cgroup-head{display:flex;align-items:center;gap:9px;margin-bottom:12px;padding-bottom:7px;border-bottom:2px solid var(--line-soft)}
  .cgroup-name{font-family:'Instrument Serif',serif;font-size:19px;font-weight:400;color:var(--ink)}
  .cgroup-n{font-size:11.5px;font-weight:700;color:var(--ink-faint);background:var(--line-soft);padding:1px 9px;border-radius:20px}
  .cgroup-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:14px}
  .contact{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow);transition:box-shadow .15s,transform .15s;cursor:pointer}
  .contact:hover{box-shadow:var(--shadow-lift);transform:translateY(-1px)}
  .contact .row1{display:flex;align-items:center;gap:12px;margin-bottom:14px}
  .contact .ava{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;font-family:'Instrument Serif',serif;font-size:20px;flex-shrink:0}
  .contact h3{font-size:15px;font-weight:600;line-height:1.2}
  .contact .role{font-size:12px;color:var(--ink-faint)}
  .contact .info{display:flex;flex-direction:column;gap:6px;font-size:12.5px;color:var(--ink-soft)}
  .contact .info div{display:flex;align-items:center;gap:8px}
  .contact .info svg{width:14px;height:14px;stroke-width:1.7;color:var(--ink-faint)}
  .contact .pills{display:flex;gap:6px;margin-top:14px;padding-top:13px;border-top:1px solid var(--line-soft);flex-wrap:wrap}
  .pill{font-size:11px;font-weight:600;padding:3px 9px;border-radius:8px;background:var(--line-soft);color:var(--ink-soft)}

  /* Contact detail */
  .back-btn{display:inline-flex;align-items:center;gap:7px;background:none;border:0;cursor:pointer;font-family:inherit;font-size:13px;font-weight:600;color:var(--ink-soft);margin-bottom:18px;padding:4px 0}
  .back-btn:hover{color:var(--teal)}
  .back-btn svg{width:16px;height:16px;stroke-width:2}
  .cd-layout{display:grid;grid-template-columns:1fr 320px;gap:24px;align-items:start;max-width:1080px}
  .cd-header{display:flex;align-items:center;gap:16px;margin-bottom:22px}
  .cd-header .ava{width:60px;height:60px;border-radius:16px;display:grid;place-items:center;font-family:'Instrument Serif',serif;font-size:30px;flex-shrink:0;box-shadow:var(--shadow)}
  .cd-header h2{font-family:'Instrument Serif',serif;font-size:30px;font-weight:400;line-height:1.1}
  .cd-header .role{color:var(--ink-faint);font-size:13px;margin-top:2px}
  .cd-header .hbtns{margin-left:auto;display:flex;gap:8px}
  .next-step{background:linear-gradient(110deg,#15514e,#1f6f6b);color:#fff;border-radius:var(--radius);padding:16px 20px;margin-bottom:24px;display:flex;align-items:center;gap:15px;box-shadow:var(--shadow)}
  .next-step .ic{width:38px;height:38px;border-radius:11px;background:rgba(255,255,255,.16);display:grid;place-items:center;flex-shrink:0}
  .next-step .ic svg{width:19px;height:19px;stroke-width:2}
  .next-step .ns-label{font-size:11px;letter-spacing:.6px;text-transform:uppercase;opacity:.8}
  .next-step .ns-text{font-size:15px;font-weight:600;margin-top:2px}
  .next-step .ns-text em{font-style:normal;opacity:.85;font-weight:500}
  .next-step .ns-when{margin-left:auto;text-align:right;flex-shrink:0}
  .next-step .ns-when b{font-family:'Instrument Serif',serif;font-size:18px;font-weight:400;display:block}
  .next-step .ns-when span{font-size:11px;opacity:.8}
  .feed-title{font-family:'Instrument Serif',serif;font-size:20px;margin-bottom:4px}
  .feed-sub{font-size:12.5px;color:var(--ink-faint);margin-bottom:18px}
  .feed{position:relative;padding-left:6px}
  .feed::before{content:"";position:absolute;left:19px;top:8px;bottom:8px;width:2px;background:var(--line)}
  .fitem{display:grid;grid-template-columns:40px 1fr;gap:14px;margin-bottom:18px;position:relative}
  .fitem .fico{width:40px;height:40px;border-radius:11px;display:grid;place-items:center;background:var(--card);border:1px solid var(--line);z-index:1;flex-shrink:0}
  .fitem .fico svg{width:17px;height:17px;stroke-width:1.8}
  .fico.email{color:var(--teal)} .fico.call{color:var(--amber)} .fico.meet{color:#7a5ea8} .fico.note{color:var(--ink-faint)} .fico.stage{color:#37b07a}
  .fcard{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:13px 16px;box-shadow:var(--shadow)}
  .fcard .fc-top{display:flex;align-items:center;gap:9px;margin-bottom:5px;flex-wrap:wrap}
  .fcard .fc-type{font-size:11px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;color:var(--ink-soft)}
  .fcard .who-chip{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:600;color:var(--ink-soft)}
  .fcard .who-chip .av{width:17px;height:17px;border-radius:50%;display:grid;place-items:center;font-size:8.5px;font-weight:700;color:#fff}
  .fcard .fc-time{margin-left:auto;font-size:11.5px;color:var(--ink-faint)}
  .fcard .fc-body{font-size:13px;color:var(--ink);line-height:1.45}
  .fcard .fc-body .subj{font-weight:600}
  .fcard .fc-snip{font-size:12.5px;color:var(--ink-soft);margin-top:3px;line-height:1.45}
  .auto-badge{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:700;letter-spacing:.3px;text-transform:uppercase;background:var(--teal-soft);color:var(--teal);padding:2px 7px;border-radius:6px}
  .auto-badge svg{width:11px;height:11px;stroke-width:2.4}
  .cd-side{display:flex;flex-direction:column;gap:16px}
  .side-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--shadow)}
  .side-card h4{font-size:11px;letter-spacing:.8px;text-transform:uppercase;color:var(--ink-faint);margin-bottom:12px}
  .side-card .field{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--ink-soft);padding:5px 0}
  .side-card .field svg{width:15px;height:15px;stroke-width:1.7;color:var(--ink-faint);flex-shrink:0}
  .side-deal{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--line-soft)}
  .side-deal:last-child{border-bottom:0}
  .side-deal .sd-stage{width:8px;height:8px;border-radius:50%;background:var(--teal);flex-shrink:0}
  .side-deal .sd-name{font-size:13px;font-weight:500;flex:1;line-height:1.25}
  .side-deal .sd-meta{font-size:11px;color:var(--ink-faint)}
  .side-deal .sd-val{font-size:12.5px;font-weight:700;color:var(--ink)}
  .side-task{display:flex;align-items:flex-start;gap:9px;padding:7px 0;font-size:12.5px}
  .side-task .tb{width:15px;height:15px;border-radius:5px;border:1.6px solid var(--line);flex-shrink:0;margin-top:1px}
  .side-task.done .tb{background:var(--teal);border-color:var(--teal)}
  .side-task.done span{text-decoration:line-through;color:var(--ink-faint)}
  .involved .av{width:28px;height:28px;border-radius:50%;display:inline-grid;place-items:center;font-size:10px;font-weight:700;color:#fff;border:2px solid var(--card);margin-left:-6px}
  .involved .av:first-child{margin-left:0}

  /* Tasks */
  .tasks-toolbar{display:flex;align-items:center;gap:14px;margin-bottom:18px;flex-wrap:wrap}
  .filter-chips{display:flex;gap:7px;align-items:center}
  .chip{display:inline-flex;align-items:center;gap:7px;padding:6px 12px;border-radius:20px;border:1px solid var(--line);background:var(--card);font-size:12.5px;font-weight:600;color:var(--ink-soft);cursor:pointer;transition:.15s}
  .chip .av{width:18px;height:18px;border-radius:50%;display:grid;place-items:center;font-size:9px;font-weight:700;color:#fff}
  .chip:hover{border-color:#d3cfc3}
  .chip.on{background:var(--ink);color:#fff;border-color:var(--ink)}
  .chip.all.on{background:var(--teal);border-color:var(--teal)}
  .tasks-wrap{display:grid;grid-template-columns:1fr 1fr;gap:20px;max-width:1060px}
  .task-col{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:visible}
  .task-col .head{padding:16px 20px;border-bottom:1px solid var(--line-soft);display:flex;align-items:center;gap:10px}
  .task-col .head .ic{width:26px;height:26px;border-radius:8px;display:grid;place-items:center}
  .task-col .head h3{font-family:'Instrument Serif',serif;font-size:19px;font-weight:400}
  .task-col .head .n{margin-left:auto;font-size:12px;color:var(--ink-faint);font-weight:600}
  .task-list{padding:8px}
  .task{display:flex;align-items:flex-start;gap:11px;padding:12px;border-radius:11px;transition:background .12s;border-left:3px solid transparent}
  .task:hover{background:var(--paper)}
  .task:hover .task-actions{opacity:1}
  .task .box{width:18px;height:18px;border-radius:6px;border:1.8px solid var(--line);flex-shrink:0;margin-top:1px;cursor:pointer;transition:.15s;display:grid;place-items:center}
  .task .box svg{width:11px;height:11px;stroke-width:3;color:#fff;opacity:0}
  .task.done .box{background:var(--teal);border-color:var(--teal)}
  .task.done .box svg{opacity:1}
  .task.done .t-main{color:var(--ink-faint);text-decoration:line-through}
  .task .t-body{flex:1;min-width:0}
  .task .t-main{font-size:13.5px;font-weight:500}
  .task .t-meta{display:flex;align-items:center;gap:8px;margin-top:7px;flex-wrap:wrap}
  .due-tag{font-size:11px;font-weight:600;color:var(--ink-faint);display:inline-flex;align-items:center;gap:5px}
  .due-tag svg{width:12px;height:12px;stroke-width:2}
  .due-tag.urgent{color:var(--rose)}
  .due-tag.sched{color:var(--teal)}
  .assignee{position:relative}
  .assignee-btn{display:inline-flex;align-items:center;gap:6px;padding:3px 9px 3px 4px;border-radius:20px;border:1px solid var(--line);background:var(--paper-2);cursor:pointer;font-size:11.5px;font-weight:600;color:var(--ink-soft);transition:.15s}
  .assignee-btn:hover{border-color:var(--teal);color:var(--teal)}
  .assignee-btn .av{width:18px;height:18px;border-radius:50%;display:grid;place-items:center;font-size:9px;font-weight:700;color:#fff}
  .assignee-btn .car{width:9px;height:9px;stroke-width:2.4;opacity:.5}
  .assignee-menu{position:absolute;top:calc(100% + 6px);left:0;z-index:30;background:var(--card);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow-lift);padding:6px;min-width:172px;display:none}
  .assignee-menu.open{display:block;animation:pop .12s ease}
  @keyframes pop{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}
  .assignee-menu .mlabel{font-size:10px;letter-spacing:.8px;text-transform:uppercase;color:var(--ink-faint);padding:6px 8px 4px}
  .assignee-menu .opt{display:flex;align-items:center;gap:9px;padding:7px 8px;border-radius:8px;cursor:pointer;font-size:13px;font-weight:500}
  .assignee-menu .opt:hover{background:var(--paper)}
  .assignee-menu .opt .av{width:22px;height:22px;border-radius:50%;display:grid;place-items:center;font-size:10px;font-weight:700;color:#fff}
  .assignee-menu .opt .chk{margin-left:auto;width:14px;height:14px;stroke-width:3;color:var(--teal);opacity:0}
  .assignee-menu .opt.sel .chk{opacity:1}
  .task-actions{margin-left:auto;display:flex;gap:5px;opacity:0;transition:opacity .15s}
  .icon-btn{display:inline-flex;align-items:center;gap:5px;padding:5px 9px;border-radius:8px;border:1px solid var(--line);background:var(--card);cursor:pointer;font-size:11px;font-weight:600;color:var(--ink-soft);transition:.15s}
  .icon-btn svg{width:13px;height:13px;stroke-width:1.9}
  .icon-btn.cal:hover{background:var(--teal);color:#fff;border-color:var(--teal)}
  .task-add{display:flex;align-items:center;gap:10px;padding:11px 12px;color:var(--ink-faint);cursor:pointer;border-radius:10px;font-size:13px}
  .task-add:hover{background:var(--paper);color:var(--teal)}
  .task-add .plus{width:18px;height:18px;border-radius:6px;border:1.8px dashed var(--line);display:grid;place-items:center}
  .task-add .plus svg{width:11px;height:11px;stroke-width:2.4}
  .section-title{font-family:'Instrument Serif',serif;font-size:21px;font-weight:400;margin-bottom:16px;display:flex;align-items:baseline;gap:10px}
  .section-title span{font-size:13px;color:var(--ink-faint);font-family:'Hanken Grotesk'}

  /* AI sources */
  .ai-sources{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:18px}
  .ai-sources .lbl{font-size:12px;color:var(--ink-faint);font-weight:600}
  .src-chip{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:600;color:var(--ink-soft);background:var(--card);border:1px solid var(--line);padding:5px 11px;border-radius:20px}
  .src-chip svg{width:13px;height:13px;stroke-width:1.9;color:var(--teal)}
  .src-chip .on-dot{width:7px;height:7px;border-radius:50%;background:#37b07a}

  /* editable controls */
  .tl-card .tc-edit{position:absolute;top:10px;right:10px;display:flex;gap:4px;opacity:0;transition:.15s}
  .tl-card:hover .tc-edit{opacity:1}
  .mini-btn{width:24px;height:24px;border-radius:7px;border:1px solid var(--line);background:var(--card);cursor:pointer;display:grid;place-items:center;color:var(--ink-faint);transition:.15s}
  .mini-btn svg{width:13px;height:13px;stroke-width:2}
  .mini-btn:hover{border-color:var(--teal);color:var(--teal)}
  .mini-btn.del:hover{border-color:var(--rose);color:var(--rose)}
  [contenteditable]{outline:none;border-radius:5px;transition:background .12s,box-shadow .12s;cursor:text}
  [contenteditable]:hover{background:var(--line-soft)}
  [contenteditable]:focus{background:#fff;box-shadow:0 0 0 2px var(--teal)}
  .tl-block.drag-handle .tl-card{cursor:grab}
  .tl-block.dragging{opacity:.4}
  .add-block{display:inline-flex;align-items:center;gap:8px;margin:6px 0 0 72px;padding:9px 14px;border:1.6px dashed var(--line);border-radius:10px;background:transparent;color:var(--ink-faint);cursor:pointer;font-family:inherit;font-size:13px;font-weight:600;transition:.15s}
  .add-block:hover{border-color:var(--teal);color:var(--teal);background:var(--teal-soft)}
  .add-block svg{width:14px;height:14px;stroke-width:2.4}

  /* AI day plan */
  .ai-banner{display:flex;align-items:center;gap:16px;background:linear-gradient(110deg,#15514e,#1f6f6b);color:#fff;border-radius:var(--radius);padding:18px 22px;margin-bottom:22px;box-shadow:var(--shadow);position:relative;overflow:hidden}
  .ai-banner::after{content:"";position:absolute;right:-40px;top:-40px;width:180px;height:180px;border-radius:50%;background:rgba(255,255,255,.06)}
  .ai-banner .spark{width:42px;height:42px;border-radius:12px;background:rgba(255,255,255,.16);display:grid;place-items:center;flex-shrink:0}
  .ai-banner .spark svg{width:22px;height:22px;stroke-width:1.8}
  .ai-banner .bt{flex:1}
  .ai-banner .bt b{font-family:'Instrument Serif',serif;font-size:20px;font-weight:400;display:block;line-height:1.15}
  .ai-banner .bt span{font-size:12.5px;opacity:.82}
  .ai-banner .gen{background:#fff;color:var(--teal);border:0;cursor:pointer;font-family:inherit;font-weight:700;font-size:13px;padding:11px 18px;border-radius:10px;display:inline-flex;align-items:center;gap:8px;z-index:1;transition:transform .12s}
  .ai-banner .gen:hover{transform:translateY(-1px)}
  .ai-banner .gen svg{width:15px;height:15px;stroke-width:2.2}
  .ai-banner .gen.loading{pointer-events:none;opacity:.7}
  .ai-meta{font-size:12px;color:var(--ink-faint);margin-bottom:16px;display:flex;align-items:center;gap:7px}
  .ai-meta svg{width:13px;height:13px;stroke-width:2;color:var(--teal)}
  .timeline{max-width:760px;position:relative;padding-left:8px}
  .timeline::before{content:"";position:absolute;left:62px;top:6px;bottom:0;width:2px;background:var(--line)}
  .tl-block{display:grid;grid-template-columns:54px 1fr;gap:18px;margin-bottom:14px;position:relative;opacity:0;transform:translateY(8px);animation:rise .4s ease forwards}
  @keyframes rise{to{opacity:1;transform:none}}
  .tl-time{text-align:right;font-size:12px;font-weight:700;color:var(--ink-soft);padding-top:14px}
  .tl-time small{display:block;font-size:10px;font-weight:500;color:var(--ink-faint)}
  .tl-card{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:13px 16px;box-shadow:var(--shadow);border-left:4px solid var(--teal);position:relative}
  .tl-card::before{content:"";position:absolute;left:-26px;top:18px;width:11px;height:11px;border-radius:50%;background:var(--card);border:3px solid var(--teal)}
  .tl-card.task{border-left-color:var(--amber)}
  .tl-card.task::before{border-color:var(--amber)}
  .tl-card.brk{border-left-color:var(--ink-faint);background:var(--paper-2)}
  .tl-card.brk::before{border-color:var(--ink-faint)}
  .tl-card .tc-head{display:flex;align-items:center;gap:9px;margin-bottom:3px}
  .tl-card .tc-head .typ{font-size:10px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;padding:2px 7px;border-radius:6px}
  .typ.meet{background:var(--teal-soft);color:var(--teal)}
  .typ.task{background:var(--amber-soft);color:var(--amber)}
  .typ.brk{background:var(--line-soft);color:var(--ink-faint)}
  .tl-card h4{font-size:14px;font-weight:600;line-height:1.3;padding-right:28px}
  .tl-card .tc-sub{font-size:12px;color:var(--ink-faint);margin-top:5px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
  .tl-card .who-chip{display:inline-flex;align-items:center;gap:5px;font-weight:600;color:var(--ink-soft)}
  .tl-card .who-chip .av{width:16px;height:16px;border-radius:50%;display:grid;place-items:center;font-size:8px;font-weight:700;color:#fff}
  .skeleton{background:linear-gradient(90deg,var(--line-soft) 25%,#f3f0e8 50%,var(--line-soft) 75%);background-size:200% 100%;animation:shimmer 1.2s infinite;border-radius:12px;height:70px;margin-bottom:14px;margin-left:72px}
  @keyframes shimmer{to{background-position:-200% 0}}

  /* Calendar */
  .cal-head{display:flex;align-items:center;gap:14px;margin-bottom:16px}
  .cal-head .wk{font-family:'Instrument Serif',serif;font-size:20px}
  .cal-nav{display:flex;gap:4px}
  .cal-nav button{width:30px;height:30px;border-radius:8px;border:1px solid var(--line);background:var(--card);cursor:pointer;display:grid;place-items:center;color:var(--ink-soft)}
  .cal-nav button:hover{border-color:var(--teal);color:var(--teal)}
  .cal-nav button svg{width:15px;height:15px;stroke-width:2}
  .legend{margin-left:auto;display:flex;gap:14px;font-size:12px;color:var(--ink-soft)}
  .legend span{display:inline-flex;align-items:center;gap:6px}
  .legend .sw{width:11px;height:11px;border-radius:4px}
  .cal-grid{display:grid;grid-template-columns:54px repeat(5,1fr);background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
  .cal-grid .corner{border-bottom:1px solid var(--line-soft);border-right:1px solid var(--line-soft)}
  .cal-col-h{padding:11px 10px;text-align:center;border-bottom:1px solid var(--line-soft);border-right:1px solid var(--line-soft)}
  .cal-col-h .dname{font-size:11px;letter-spacing:.5px;text-transform:uppercase;color:var(--ink-faint)}
  .cal-col-h .dnum{font-family:'Instrument Serif',serif;font-size:19px;margin-top:1px}
  .cal-col-h.today .dnum{color:var(--teal)}
  .cal-time{padding:7px 8px;text-align:right;font-size:10.5px;color:var(--ink-faint);border-right:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft)}
  .cal-cell{min-height:54px;border-right:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft);padding:3px;position:relative}
  .ev{border-radius:7px;padding:5px 7px;font-size:11px;font-weight:600;line-height:1.25;margin-bottom:3px;cursor:grab;border-left:3px solid}
  .ev.meet{background:var(--teal-soft);color:#15514e;border-color:var(--teal)}
  .ev.task{background:var(--amber-soft);color:#7d551c;border-color:var(--amber)}
  .ev .et{font-size:9.5px;font-weight:600;opacity:.7;display:block}
  .ev .who-dot{display:inline-block;width:7px;height:7px;border-radius:50%;margin-right:4px;vertical-align:middle}

  /* toast */
  .toast{position:fixed;bottom:26px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--ink);color:#fff;padding:12px 18px;border-radius:12px;font-size:13px;font-weight:500;box-shadow:var(--shadow-lift);opacity:0;pointer-events:none;transition:.25s;z-index:100;display:flex;align-items:center;gap:9px}
  .toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
  .toast svg{width:16px;height:16px;stroke-width:2.2;color:#7fd6c7}

/* ---------- LOGIN ---------- */
.auth-screen{position:fixed;inset:0;display:grid;place-items:center;background:var(--paper);z-index:200}
.auth-card{width:380px;max-width:92vw;background:var(--card);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow-lift);padding:34px 32px}
.auth-card .brand{justify-content:center;padding:0 0 8px}
.auth-card h2{font-family:'Instrument Serif',serif;font-size:25px;font-weight:400;text-align:center;margin-bottom:4px}
.auth-card .sub{text-align:center;color:var(--ink-faint);font-size:13px;margin-bottom:22px}
.auth-card label{display:block;font-size:12px;font-weight:600;color:var(--ink-soft);margin:12px 0 5px}
.auth-card input{width:100%;padding:11px 13px;border:1px solid var(--line);border-radius:10px;font-family:inherit;font-size:14px;outline:none;transition:.15s;background:var(--paper-2)}
.auth-card input:focus{border-color:var(--teal);box-shadow:0 0 0 3px var(--teal-soft);background:#fff}
.auth-card .btn{width:100%;justify-content:center;margin-top:20px;padding:12px}
.auth-err{background:var(--rose-soft);color:var(--rose);font-size:12.5px;font-weight:600;padding:9px 12px;border-radius:9px;margin-top:14px;text-align:center;display:none}
.auth-err.show{display:block}
.auth-toggle{text-align:center;font-size:12.5px;color:var(--ink-faint);margin-top:16px}
.auth-toggle a{color:var(--teal);font-weight:600;cursor:pointer}
.auth-hint{text-align:center;font-size:11.5px;color:var(--ink-faint);margin-top:18px;line-height:1.5;border-top:1px solid var(--line-soft);padding-top:14px}

/* google connect bar */
.gbar{display:flex;align-items:center;gap:12px;background:var(--card);border:1px solid var(--line);border-radius:12px;padding:12px 16px;margin-bottom:18px;box-shadow:var(--shadow)}
.gbar .gi{width:34px;height:34px;border-radius:9px;background:var(--teal-soft);color:var(--teal);display:grid;place-items:center;flex-shrink:0}
.gbar .gi svg{width:18px;height:18px;stroke-width:1.8}
.gbar .gt{flex:1;font-size:13px}
.gbar .gt b{display:block;font-weight:600}
.gbar .gt span{color:var(--ink-faint);font-size:12px}
.gbar .gbtn{background:var(--teal);color:#fff;border:0;border-radius:9px;padding:8px 14px;font-family:inherit;font-weight:600;font-size:12.5px;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;gap:6px}
.gbar .gbtn.ghost{background:var(--card);color:var(--ink-soft);border:1px solid var(--line)}
.logout-link{cursor:pointer}
.empty{color:var(--ink-faint);font-size:13px;padding:30px;text-align:center}

/* ---------- CALL MODULE ---------- */
.call-build{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:18px;background:var(--card);border:1px solid var(--line);border-radius:12px;padding:12px 16px;box-shadow:var(--shadow)}
.call-build select{font-family:inherit;font-size:13px;padding:8px 10px;border:1px solid var(--line);border-radius:8px;background:var(--paper-2)}
.call-build .prog{margin-left:auto;font-size:13px;color:var(--ink-soft);font-weight:600}
.call-card{display:flex;align-items:center;gap:14px;background:var(--card);border:1px solid var(--line);border-radius:12px;padding:13px 16px;box-shadow:var(--shadow);margin-bottom:10px;border-left:4px solid var(--teal)}
.call-card.done{opacity:.55;border-left-color:var(--ink-faint)}
.call-card.callback{border-left-color:var(--amber)}
.call-card .ci{width:40px;height:40px;border-radius:11px;display:grid;place-items:center;font-family:'Instrument Serif',serif;font-size:20px;flex-shrink:0;background:var(--teal-soft);color:var(--teal)}
.call-card .cmeta{flex:1;min-width:0}
.call-card .cname{font-weight:600;font-size:14px;cursor:pointer}
.call-card .cname:hover{color:var(--teal)}
.call-card .csub{font-size:12px;color:var(--ink-faint);margin-top:2px;display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.call-card .cphone{font-size:16px;font-weight:700;color:var(--teal);text-decoration:none;white-space:nowrap;margin-right:6px}
.call-card .cact{display:flex;gap:6px;flex-shrink:0;flex-wrap:wrap;justify-content:flex-end;max-width:320px}
.spec-pill{font-size:11px;font-weight:600;padding:2px 8px;border-radius:7px;background:var(--teal-soft);color:var(--teal)}
.cbtn{display:inline-flex;align-items:center;gap:5px;padding:7px 11px;border-radius:9px;border:1px solid var(--line);background:var(--card);cursor:pointer;font-family:inherit;font-size:12px;font-weight:600;color:var(--ink-soft);transition:.15s}
.cbtn svg{width:13px;height:13px;stroke-width:2}
.cbtn.ok:hover{background:var(--teal);color:#fff;border-color:var(--teal)}
.cbtn.no:hover{background:var(--rose);color:#fff;border-color:var(--rose)}
.cbtn.later:hover{background:var(--amber);color:#fff;border-color:var(--amber)}
.cbtn:hover{border-color:var(--teal);color:var(--teal)}
.cbtn.rm:hover{border-color:var(--rose);color:var(--rose)}
.add-contact-form{display:none;gap:8px;flex-wrap:wrap;align-items:center;background:var(--card);border:1px solid var(--line);border-radius:12px;padding:14px 16px;margin-bottom:16px;box-shadow:var(--shadow)}
.add-contact-form.show{display:flex}
.add-contact-form input,.add-contact-form select{font-family:inherit;font-size:13px;padding:8px 10px;border:1px solid var(--line);border-radius:8px}

.mark .logomark{width:18px;height:18px}
.auth-card .mark .logomark{width:18px;height:18px}

/* ---------- INTEGRATIONS ---------- */
.integ-block{padding:14px 0;border-bottom:1px solid var(--line-soft)}
.integ-block:last-child{border-bottom:0}
.integ-head{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.integ-head b{font-size:13.5px}
.integ-head .stat{font-size:11px;font-weight:700;padding:2px 9px;border-radius:20px}
.integ-head .stat.on{background:var(--teal-soft);color:var(--teal)}
.integ-head .stat.off{background:var(--line-soft);color:var(--ink-faint)}
.integ-head a{margin-left:auto;font-size:11.5px;color:var(--teal);font-weight:600;text-decoration:none}
.integ-row{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-bottom:8px}
.integ-row input{flex:1;min-width:160px;padding:8px 10px;border:1px solid var(--line);border-radius:8px;font-family:inherit;font-size:13px;background:var(--paper-2)}
.integ-row input:focus{border-color:var(--teal);outline:none;background:#fff}
.integ-hint{font-size:11.5px;color:var(--ink-faint);margin-bottom:8px;line-height:1.5}

/* ---------- CHAT (Discord) ---------- */
.chat-wrap{display:flex;flex-direction:column;height:calc(100vh - 190px);max-width:760px;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.chat-msgs{flex:1;overflow-y:auto;padding:18px 20px;display:flex;flex-direction:column;gap:12px}
.chat-msg{display:flex;flex-direction:column;max-width:78%}
.chat-msg.mine{align-self:flex-end;align-items:flex-end}
.chat-msg .meta{font-size:11px;color:var(--ink-faint);margin-bottom:3px;display:flex;align-items:center;gap:6px}
.chat-msg .meta .src{font-size:9px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;padding:1px 6px;border-radius:6px}
.chat-msg .meta .src.discord{background:#e8e6f6;color:#5865F2}
.chat-msg .meta .src.crm{background:var(--teal-soft);color:var(--teal)}
.chat-msg .bubble{background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:9px 13px;font-size:13.5px;line-height:1.45;word-break:break-word}
.chat-msg.mine .bubble{background:var(--teal);color:#fff;border-color:var(--teal)}
.chat-input{display:flex;gap:10px;padding:14px 16px;border-top:1px solid var(--line-soft);background:var(--paper-2)}
.chat-input input{flex:1;padding:11px 14px;border:1px solid var(--line);border-radius:10px;font-family:inherit;font-size:14px;outline:none}
.chat-input input:focus{border-color:var(--teal)}
.chat-empty{margin:auto;text-align:center;color:var(--ink-faint);font-size:13px;max-width:380px;line-height:1.6}
.chat-shell{display:flex;gap:16px;height:calc(100vh - 190px)}
.chat-side{width:240px;flex-shrink:0;display:flex;flex-direction:column;gap:10px;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:12px;overflow:hidden}
.chat-newgrp{display:flex;align-items:center;justify-content:center;gap:7px;padding:9px;border:1.5px dashed var(--line);border-radius:10px;background:transparent;color:var(--ink-soft);font-family:inherit;font-size:12.5px;font-weight:600;cursor:pointer;transition:.15s;flex-shrink:0}
.chat-newgrp:hover{border-color:var(--teal);color:var(--teal);background:var(--teal-soft)}
.chat-newgrp svg{width:14px;height:14px;stroke-width:2.4}
.chat-chans{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:3px}
.chat-chan{display:flex;align-items:center;gap:10px;padding:8px 9px;border:0;background:transparent;border-radius:10px;cursor:pointer;text-align:left;width:100%;transition:background .12s}
.chat-chan:hover{background:var(--paper)}
.chat-chan.on{background:var(--teal-soft)}
.chat-chan .ch-ic{width:30px;height:30px;border-radius:50%;flex-shrink:0;display:grid;place-items:center;font-size:11px;font-weight:700;color:#fff}
.chat-chan .ch-ic.team{background:var(--teal);font-size:15px}
.chat-chan .ch-ic.grp{background:var(--ink-soft)}
.chat-chan .ch-ic svg{width:15px;height:15px;stroke-width:2}
.chat-chan .ch-body{flex:1;min-width:0;display:flex;flex-direction:column}
.chat-chan .ch-name{font-size:13px;font-weight:600;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.chat-chan .ch-prev{font-size:11px;color:var(--ink-faint);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.chat-chan .ch-unread{flex-shrink:0;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:var(--rose);color:#fff;font-size:10.5px;font-weight:700;display:grid;place-items:center}
.chat-notify{display:flex;align-items:center;gap:8px;padding:8px 6px;border-top:1px solid var(--line-soft);font-size:11.5px;color:var(--ink-soft);cursor:pointer;flex-shrink:0}
.chat-notify input{width:14px;height:14px;accent-color:var(--teal);cursor:pointer;margin:0;flex-shrink:0}
.chat-notify svg{width:14px;height:14px;stroke-width:1.8;color:var(--ink-faint)}
.chat-shell .chat-wrap{flex:1;max-width:none;height:auto}
.chat-head{display:flex;align-items:center;gap:11px;padding:13px 18px;border-bottom:1px solid var(--line-soft);background:var(--paper-2)}
.chat-head .ch-ic{width:34px;height:34px;border-radius:50%;flex-shrink:0;display:grid;place-items:center;font-size:12px;font-weight:700;color:#fff}
.chat-head .ch-ic.team{background:var(--teal);font-size:17px}
.chat-head .ch-ic.grp{background:var(--ink-soft)}
.chat-head .ch-ic svg{width:17px;height:17px;stroke-width:2}
.chat-head .ch-head-name{font-size:15px;font-weight:600}
.chat-head .ch-head-sub{font-size:11.5px;color:var(--ink-faint)}
.team-row .tr-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.team-row .tr-chat{opacity:0;width:24px;height:24px;border:0;background:transparent;border-radius:7px;cursor:pointer;color:var(--ink-faint);display:grid;place-items:center;transition:.12s;flex-shrink:0}
.team-row .tr-chat svg{width:14px;height:14px;stroke-width:1.9}
.team-row:hover .tr-chat{opacity:1}
.team-row .tr-chat:hover{background:var(--teal-soft);color:var(--teal)}
/* chat: reply, pin, pildid, halda */
.chat-msg{position:relative}
.msg-acts{position:absolute;top:-12px;right:6px;display:none;gap:1px;background:var(--card);border:1px solid var(--line);border-radius:8px;padding:2px;box-shadow:var(--shadow);z-index:5}
.chat-msg:hover .msg-acts{display:flex}
.chat-msg.mine .msg-acts{right:auto;left:6px}
.msg-act{width:26px;height:26px;border:0;background:transparent;border-radius:6px;cursor:pointer;color:var(--ink-soft);display:grid;place-items:center}
.msg-act svg{width:14px;height:14px;stroke-width:1.9}
.msg-act:hover{background:var(--paper);color:var(--teal)}
.msg-quote{border-left:3px solid var(--teal);background:var(--paper);padding:5px 9px;border-radius:0 8px 8px 0;font-size:12px;color:var(--ink-soft);margin-bottom:4px;max-width:90%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.msg-quote b{color:var(--teal);font-weight:600}
.msg-img{max-width:260px;max-height:240px;border-radius:10px;border:1px solid var(--line);margin:2px 0;cursor:pointer;display:block}
.msg-file{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;background:var(--paper);border:1px solid var(--line);border-radius:10px;font-size:13px;color:var(--ink);text-decoration:none;margin:2px 0;max-width:260px}
.msg-file:hover{border-color:var(--teal);color:var(--teal)}
.msg-file svg{width:18px;height:18px;flex-shrink:0;color:var(--ink-faint)}
.msg-file span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pinned-dot{font-size:10px}
.chat-pinned{display:flex;align-items:center;gap:10px;padding:8px 16px;background:var(--paper-2);border-bottom:1px solid var(--line-soft);overflow-x:auto;font-size:12px}
.chat-pinned.hidden{display:none}
.chat-pinned .pin-ic{width:14px;height:14px;color:var(--amber);flex-shrink:0}
.pin-item{white-space:nowrap;color:var(--ink-soft)}
.pin-item b{color:var(--ink);font-weight:600}
.chat-replybar{display:flex;align-items:center;gap:8px;padding:8px 16px;background:var(--teal-soft);border-top:1px solid var(--line-soft);font-size:12.5px;color:var(--teal)}
.chat-replybar.hidden{display:none}
.chat-replybar>svg{width:15px;height:15px;flex-shrink:0}
.chat-replybar span{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.chat-reply-x{width:22px;height:22px;border:0;background:transparent;cursor:pointer;color:var(--teal);display:grid;place-items:center}
.chat-reply-x svg{width:13px;height:13px}
.chat-attach{width:42px;height:42px;border:1px solid var(--line);background:var(--card);border-radius:10px;cursor:pointer;color:var(--ink-soft);display:grid;place-items:center;flex-shrink:0}
.chat-attach svg{width:18px;height:18px;stroke-width:1.8}
.chat-attach:hover{border-color:var(--teal);color:var(--teal)}
.chat-head{position:relative}
.ch-cog{margin-left:auto;width:30px;height:30px;border:0;background:transparent;border-radius:8px;cursor:pointer;color:var(--ink-faint);display:grid;place-items:center;flex-shrink:0}
.ch-cog:hover{background:var(--paper);color:var(--ink)}
.ch-menu{position:absolute;top:50px;right:14px;background:var(--card);border:1px solid var(--line);border-radius:10px;box-shadow:var(--shadow);padding:4px;z-index:30;min-width:150px}
.ch-mi{display:block;width:100%;text-align:left;padding:8px 12px;border:0;background:transparent;border-radius:7px;cursor:pointer;font-family:inherit;font-size:13px;color:var(--ink)}
.ch-mi:hover{background:var(--paper)}
.ch-mi.danger{color:var(--rose)}
.ch-mi.disabled{color:var(--ink-faint);cursor:default;font-size:12px}
.ch-mi.disabled:hover{background:transparent}
/* loetud-kviitungid (Nähtud) */
.chat-seen{display:flex;align-items:center;gap:5px;align-self:flex-end;margin:2px 2px 6px;opacity:.85}
.seen-lbl{font-size:10.5px;color:var(--ink-faint);font-weight:600;margin-right:1px}
.seen-av{width:17px;height:17px;border-radius:50%;display:grid;place-items:center;font-size:7.5px;font-weight:700;color:#fff;box-shadow:0 0 0 1.5px var(--card)}
/* kalender: klikitav + Google sündmused */
.cal-cell{cursor:pointer;transition:background .1s}
.cal-cell:hover{background:var(--teal-soft)}
.cal-grid .ev{cursor:pointer}
.cal-grid .ev.google{background:var(--paper-2);border:1px dashed var(--ink-faint);color:var(--ink-soft);opacity:.92}
.cal-grid .ev.google .et svg{vertical-align:-1px}
.cal-grid .ev.synced{box-shadow:inset 3px 0 0 var(--teal)}
.cal-nav button{cursor:pointer}

/* ---------- MODAL (compose) ---------- */
.modal-overlay{position:fixed;inset:0;background:rgba(28,29,26,.45);display:none;align-items:center;justify-content:center;z-index:120;padding:20px}
.modal-overlay.show{display:flex}
.modal{background:var(--card);border-radius:16px;box-shadow:var(--shadow-lift);width:560px;max-width:100%;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}
.modal-head{display:flex;align-items:center;padding:16px 20px;border-bottom:1px solid var(--line-soft)}
.modal-head h3{font-family:'Instrument Serif',serif;font-size:20px;font-weight:400}
.modal-x{margin-left:auto;width:28px;height:28px;border-radius:8px;border:1px solid var(--line);background:var(--card);cursor:pointer;display:grid;place-items:center;color:var(--ink-soft)}
.modal-x svg{width:14px;height:14px;stroke-width:2}
.modal-x:hover{border-color:var(--rose);color:var(--rose)}
.modal-body{padding:18px 20px;overflow-y:auto}
.modal-body label{display:block;font-size:12px;font-weight:600;color:var(--ink-soft);margin:12px 0 5px}
.modal-body label:first-child{margin-top:0}
.modal-body input,.modal-body textarea{width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:9px;font-family:inherit;font-size:13.5px;outline:none;background:var(--paper-2)}
.modal-body input:focus,.modal-body textarea:focus{border-color:var(--teal);background:#fff}
.modal-body input[readonly]{color:var(--ink-faint)}
.modal-body textarea{resize:vertical;line-height:1.5}
.ai-compose{display:flex;gap:8px;margin:12px 0 4px}
.ai-compose input{flex:1}
.ai-compose .btn{white-space:nowrap}
.ai-compose .btn.loading{opacity:.7;pointer-events:none}
.modal-foot{display:flex;align-items:center;gap:10px;padding:14px 20px;border-top:1px solid var(--line-soft);background:var(--paper-2)}
.modal-foot #cmStatus{font-size:12px;color:var(--ink-faint);margin-right:auto}

/* ---------- DEAL DETAIL ---------- */
.deal-value{margin-left:auto;text-align:right;flex-shrink:0}
.deal-value span{display:block;font-size:11px;letter-spacing:.5px;text-transform:uppercase;color:var(--ink-faint)}
.deal-value b{font-family:'Instrument Serif',serif;font-size:26px;font-weight:400}
.log-activity{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:12px 14px;box-shadow:var(--shadow);margin-bottom:20px}
.la-types{display:flex;gap:6px;margin-bottom:10px;flex-wrap:wrap}
.la-type{padding:5px 12px;border-radius:20px;border:1px solid var(--line);background:var(--paper-2);font-family:inherit;font-size:12px;font-weight:600;color:var(--ink-soft);cursor:pointer;transition:.15s}
.la-type:hover{border-color:var(--teal);color:var(--teal)}
.la-type.on{background:var(--teal);color:#fff;border-color:var(--teal)}
.log-activity textarea{width:100%;border:1px solid var(--line);border-radius:9px;padding:10px 12px;font-family:inherit;font-size:13.5px;resize:vertical;min-height:60px;outline:none;background:var(--paper-2)}
.log-activity textarea:focus{border-color:var(--teal);background:#fff}
.la-foot{display:flex;align-items:center;gap:10px;margin-top:10px}
.la-foot input[type=date]{font-family:inherit;font-size:12.5px;padding:7px 9px;border:1px solid var(--line);border-radius:8px;background:var(--paper-2);color:var(--ink-soft)}
.la-foot .btn{margin-left:auto}
.dd-select{width:100%;font-family:inherit;font-size:13px;padding:9px 10px;border:1px solid var(--line);border-radius:9px;background:var(--paper-2);cursor:pointer;color:var(--ink)}
.dd-contact{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.dd-contact .ava-sm{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;font-family:'Instrument Serif',serif;font-size:17px;flex-shrink:0}
.ddc-name{font-weight:600;font-size:14px}
.ddc-role{font-size:12px;color:var(--ink-faint)}
.side-card .btn.ghost{width:100%;justify-content:center;margin-top:10px}
.dd-picker input{width:100%;padding:9px 11px;border:1px solid var(--line);border-radius:9px;font-family:inherit;font-size:13px;outline:none;background:var(--paper-2)}
.dd-picker input:focus{border-color:var(--teal);background:#fff}
.dd-results{margin-top:8px;max-height:230px;overflow:auto;display:flex;flex-direction:column;gap:2px}
.dd-results .ddr{display:flex;align-items:center;gap:9px;padding:8px;border-radius:8px;cursor:pointer;font-size:13px}
.dd-results .ddr:hover{background:var(--paper)}
.dd-results .ddr .av{width:24px;height:24px;border-radius:50%;display:grid;place-items:center;font-size:10px;font-weight:700;color:#fff;flex-shrink:0;background:var(--teal)}
.dd-results .ddr small{color:var(--ink-faint);margin-left:auto;white-space:nowrap}
.ddo-name{font-size:14px;font-weight:600;margin-bottom:8px}
.muted{color:var(--ink-faint)}
.dd-file{display:flex;align-items:center;gap:9px;padding:8px 0;border-bottom:1px solid var(--line-soft);font-size:12.5px;color:var(--ink-soft);text-decoration:none}
.dd-file:last-child{border-bottom:0}
.dd-file:hover{color:var(--teal)}
.dd-file svg{width:15px;height:15px;stroke-width:1.7;color:var(--ink-faint);flex-shrink:0}
.dd-file .fn{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dd-file .fs{margin-left:auto;font-size:11px;color:var(--ink-faint);flex-shrink:0}
.side-deal.clickable{cursor:pointer}
.side-deal.clickable:hover .sd-name{color:var(--teal)}

/* ---------- TASKS v2 ---------- */
.tasks-board{display:flex;gap:14px;align-items:flex-start;overflow-x:auto;padding-bottom:10px}
.tcol{width:304px;flex-shrink:0;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);display:flex;flex-direction:column;max-height:calc(100vh - 200px)}
.tcol-head{display:flex;align-items:center;gap:9px;padding:14px 16px;border-bottom:1px solid var(--line-soft);flex-shrink:0}
.tcol-head .tcol-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.tcol-head h3{font-family:'Instrument Serif',serif;font-size:18px;font-weight:400;flex:1;line-height:1}
.tcol-head .tcol-n{font-size:12px;color:var(--ink-faint);font-weight:600;background:var(--line-soft);padding:1px 9px;border-radius:20px}
.tcol-list{padding:8px;overflow-y:auto;display:flex;flex-direction:column;gap:2px}
.task.overdue{background:var(--rose-soft)}
.task .t-main{display:flex;align-items:center;gap:8px}
.prio{width:19px;height:19px;border-radius:6px;display:inline-grid;place-items:center;font-size:11px;font-weight:800;flex-shrink:0}
.due-tag.over{color:var(--rose);font-weight:700}
.task-add-wrap{padding:4px 2px}
.task-form{display:none;flex-direction:column;gap:8px;padding:11px;border:1px solid var(--line);border-radius:11px;margin-top:4px;background:var(--paper-2)}
.task-form.open{display:flex}
.task-form .tf-text{padding:9px 11px;border:1px solid var(--line);border-radius:8px;font-family:inherit;font-size:13px;outline:none;background:#fff}
.task-form .tf-text:focus{border-color:var(--teal)}
.task-form .tf-row{display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.task-form .tf-date,.task-form .tf-time{padding:7px 8px;border:1px solid var(--line);border-radius:8px;font-family:inherit;font-size:12px;background:#fff;color:var(--ink-soft)}
.task-form .tf-prio{display:flex;gap:4px;margin-left:auto}
.task-form .pbtn{width:30px;height:30px;border-radius:8px;border:1px solid var(--line);background:#fff;font-family:inherit;font-weight:800;font-size:12px;cursor:pointer;color:var(--ink-soft);transition:.12s}
.task-form .pbtn[data-p=A].on{background:var(--rose);color:#fff;border-color:var(--rose)}
.task-form .pbtn[data-p=B].on{background:var(--amber);color:#fff;border-color:var(--amber)}
.task-form .pbtn[data-p=C].on{background:var(--teal);color:#fff;border-color:var(--teal)}
.task-form .tf-foot{display:flex;gap:8px}
.task-form .tf-foot .btn{padding:8px 13px;font-size:12.5px}
.task-form .tf-foot .tf-add{flex:1;justify-content:center}
.icon-btn.del-task:hover{border-color:var(--rose);color:var(--rose)}
.task-form select{padding:7px 8px;border:1px solid var(--line);border-radius:8px;font-family:inherit;font-size:12px;background:#fff;color:var(--ink-soft)}
.tcol.drop{outline:2px dashed var(--teal);outline-offset:-4px;background:var(--teal-soft)}
.task[draggable=true]{cursor:grab}
.task.dragging{opacity:.4}
/* tühi suhtlusajalugu */
.feed-empty{text-align:center;padding:46px 24px;color:var(--ink-faint);max-width:440px;margin:0 auto}
.feed-empty svg{width:42px;height:42px;stroke-width:1.3;color:#d8d4c8;margin-bottom:12px}
.feed-empty p{font-family:'Instrument Serif',serif;font-size:19px;color:var(--ink-soft);margin-bottom:5px}
.feed-empty span{font-size:13px;line-height:1.5;display:block}
.feed:has(.feed-empty)::before{display:none}

/* ---------- PIPELINE filter + owner ---------- */
.pipe-toolbar{display:flex;align-items:center;gap:10px;margin-bottom:16px}
.pipe-toolbar .lbl{font-size:12px;color:var(--ink-faint);font-weight:600}
.deal .foot{gap:8px}
.deal .foot-r{display:flex;align-items:center;gap:8px;margin-left:auto}
.deal-owner{width:23px;height:23px;border-radius:50%;display:inline-grid;place-items:center;font-size:9.5px;font-weight:700;color:#fff;flex-shrink:0;border:2px solid var(--card);box-shadow:0 0 0 1px var(--line)}

/* ---------- LISA TEGEVUS modal ---------- */
.modal-body .la-types{margin-bottom:8px}
.act-opt{margin-top:14px;padding-top:12px;border-top:1px solid var(--line-soft)}
.cbx{display:flex;align-items:center;gap:9px;font-size:13px;font-weight:600;color:var(--ink-soft);cursor:pointer}
.cbx input{width:16px;height:16px;accent-color:var(--teal);cursor:pointer}
.act-sub{display:none;gap:8px;margin-top:10px;flex-wrap:wrap;align-items:center}
.act-sub.show{display:flex}
.act-sub select,.act-sub input{padding:8px 10px;border:1px solid var(--line);border-radius:8px;font-family:inherit;font-size:13px;background:var(--paper-2)}
.act-sub .tf-prio{display:flex;gap:4px}
.act-sub .pbtn{width:30px;height:30px;border-radius:8px;border:1px solid var(--line);background:#fff;font-family:inherit;font-weight:800;font-size:12px;cursor:pointer;color:var(--ink-soft)}
.act-sub .pbtn[data-p=A].on{background:var(--rose);color:#fff;border-color:var(--rose)}
.act-sub .pbtn[data-p=B].on{background:var(--amber);color:#fff;border-color:var(--amber)}
.act-sub .pbtn[data-p=C].on{background:var(--teal);color:#fff;border-color:var(--teal)}

/* ---------- KOOSOLEKUD / DAILY ---------- */
.series-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:16px;overflow:hidden}
.series-head{display:flex;align-items:center;gap:10px;padding:14px 18px;border-bottom:1px solid var(--line-soft)}
.series-head .series-dot{width:11px;height:11px;border-radius:50%;flex-shrink:0}
.series-head h3{font-family:'Instrument Serif',serif;font-size:20px;font-weight:400;outline:none}
.series-head .series-att{display:flex;margin-left:6px}
.series-head .series-att .av{width:24px;height:24px;border-radius:50%;display:grid;place-items:center;font-size:9px;font-weight:700;color:#fff;border:2px solid var(--card);margin-left:-6px}
.series-head .mtg-new{margin-left:auto}
.series-head .series-del{opacity:0;transition:.15s}
.series-card:hover .series-del{opacity:1}
.series-meetings{padding:8px 10px}
.mtg-row{display:flex;align-items:center;gap:12px;padding:10px 10px;border-radius:9px;cursor:pointer;transition:background .12s}
.mtg-row:hover{background:var(--paper)}
.mtg-row .mtg-date{font-weight:700;font-size:12.5px;color:var(--teal);min-width:92px}
.mtg-row .mtg-title{font-size:13.5px;color:var(--ink-soft)}
/* meetings: series tabs + panel */
.series-tabs{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:18px;border-bottom:1px solid var(--line-soft);padding-bottom:14px}
.series-tab{display:inline-flex;align-items:center;gap:7px;padding:9px 15px;border-radius:10px;border:1px solid var(--line);background:var(--card);color:var(--ink-soft);font-family:inherit;font-size:13.5px;font-weight:600;cursor:pointer;transition:.15s}
.series-tab:hover{border-color:var(--ink-faint);color:var(--ink)}
.series-tab .st-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.series-tab.on{background:var(--teal);border-color:var(--teal);color:#fff}
.series-tab.on .st-dot{background:#fff!important}
.series-tab.add{border-style:dashed;color:var(--ink-faint)}
.series-tab.add svg{width:14px;height:14px;stroke-width:2.2}
.series-tab.add:hover{border-color:var(--teal);color:var(--teal);background:var(--teal-soft)}
.series-head .series-cog{margin-left:auto;opacity:.55}
.series-head .series-cog:hover{opacity:1;border-color:var(--teal);color:var(--teal)}
.series-head .series-cog+.mtg-new{margin-left:10px}
.series-notes{padding:14px 18px;border-bottom:1px solid var(--line-soft);background:var(--paper)}
.sn-label{font-size:11px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;color:var(--ink-faint);margin-bottom:7px}
.sn-label span{text-transform:none;letter-spacing:0;font-weight:500;font-size:11px;margin-left:6px}
.sn-text{width:100%;border:1px solid var(--line);border-radius:9px;background:var(--card);padding:10px 12px;font-family:inherit;font-size:13.5px;line-height:1.55;resize:vertical;min-height:54px;color:var(--ink);outline:none;transition:.15s}
.sn-text:focus{border-color:var(--teal)}
.sn-vis{display:flex;align-items:center;gap:7px;margin-top:9px;font-size:12.5px;color:var(--ink-soft)}
.sn-vis svg{width:15px;height:15px;stroke-width:1.8;color:var(--ink-faint)}
.sn-vis b{font-weight:700;color:var(--ink)}
.sn-meet{display:flex;align-items:center;gap:9px;margin-bottom:12px}
.sn-meet>svg{width:18px;height:18px;color:var(--teal);flex-shrink:0}
.sn-meet-inp{flex:1;min-width:0;border:1px solid var(--line);border-radius:9px;background:var(--card);padding:9px 12px;font-family:inherit;font-size:13px;color:var(--ink);outline:none;transition:.15s}
.sn-meet-inp:focus{border-color:var(--teal)}
.sn-join{flex-shrink:0;padding:8px 16px}
.sn-join.off{opacity:.45;pointer-events:none}
.sn-meet-edit{flex-shrink:0;opacity:.55}
.sn-meet-edit:hover{opacity:1;color:var(--teal)}
.sn-meet-inp[readonly]{background:var(--paper-2);color:var(--ink-soft);cursor:default}
.sn-links{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:8px}
.sn-links.hidden{display:none}
.sn-links-lbl{font-size:11px;font-weight:600;color:var(--ink-faint)}
.sn-link{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;background:var(--teal-soft);color:var(--teal);border-radius:7px;font-size:12px;text-decoration:none;font-weight:500}
.sn-link:hover{background:var(--teal);color:#fff}
.sn-link svg{width:13px;height:13px}
.mtg-row .mtg-title{flex:1}
.mtg-row .mtg-chev{width:15px;height:15px;stroke-width:2;color:var(--ink-faint);opacity:0;transition:.12s}
.mtg-row:hover .mtg-chev{opacity:1}
.color-row{display:flex;flex-wrap:wrap;gap:8px}
.swatch{width:26px;height:26px;border-radius:8px;border:2px solid transparent;cursor:pointer;transition:.12s}
.swatch.on{border-color:var(--ink);transform:scale(1.08)}
.chk-list{display:flex;flex-direction:column;gap:4px;max-height:190px;overflow:auto}
.chk-list .chk{display:flex;align-items:center;gap:9px;margin:0;padding:7px 9px;border-radius:8px;cursor:pointer;font-size:13px;font-weight:500;color:var(--ink);text-transform:none;letter-spacing:0;transition:background .12s}
.chk-list .chk:hover{background:var(--paper)}
.chk-list .chk input{width:16px;height:16px;accent-color:var(--teal);cursor:pointer;margin:0;flex-shrink:0}
.chk-list .chk .av{width:24px;height:24px;border-radius:50%;display:grid;place-items:center;font-size:9px;font-weight:700;color:#fff;flex-shrink:0}
.lbl-hint{text-transform:none;letter-spacing:0;font-weight:500;color:var(--ink-faint);font-size:11px;margin-left:6px}
.btn.ghost.danger{color:var(--rose);border-color:transparent}
.btn.ghost.danger:hover{border-color:var(--rose)}
.perms-note{font-size:12px;color:var(--ink-faint);margin-bottom:12px;line-height:1.5}
.perms-user{font-size:11px}
/* koosolek: korduv-sektsioon, read-nupud, reaalaja-kohalolek */
.ms-recur{opacity:.4}
.ms-recur.on{opacity:1;color:var(--amber)}
.ms-recur:hover{opacity:1}
.mtg-acts{display:none;gap:2px}
.mtg-row:hover .mtg-acts{display:flex}
.mtg-act{width:26px;height:26px;border:0;background:transparent;border-radius:6px;cursor:pointer;color:var(--ink-faint);display:grid;place-items:center}
.mtg-act svg{width:14px;height:14px;stroke-width:1.9}
.mtg-act:hover{background:var(--card);color:var(--teal)}
.mtg-del:hover{color:var(--rose)!important}
.mtg-head-acts{display:flex;gap:4px;margin-left:10px}
.mtg-presence{display:flex;align-items:center;gap:14px;flex-wrap:wrap;padding:8px 14px;background:var(--teal-soft);border-radius:10px;margin:0 0 14px;font-size:12.5px}
.mtg-presence.hidden{display:none}
.pres-label{display:flex;align-items:center;gap:6px;font-weight:600;color:var(--teal)}
.pres-live{width:8px;height:8px;border-radius:50%;background:var(--teal);animation:presPulse 1.5s infinite}
@keyframes presPulse{0%,100%{opacity:1}50%{opacity:.25}}
.pres-user{display:inline-flex;align-items:center;gap:6px;color:var(--ink-soft)}
.pres-user .av{width:22px;height:22px;border-radius:50%;display:grid;place-items:center;font-size:9px;font-weight:700;color:#fff}
.pres-typing{color:var(--teal);font-style:italic}
.mtg-arch-toggle{display:inline-flex;align-items:center;gap:7px;margin:8px 10px;padding:6px 10px;font-size:12px;color:var(--ink-faint);cursor:pointer;border-radius:8px}
.mtg-arch-toggle svg{width:14px;height:14px}
.mtg-arch-toggle:hover,.mtg-arch-toggle.on{color:var(--teal);background:var(--teal-soft)}
.mtg-row.arch{opacity:.7}
.mtg-row.arch .mtg-restore{margin-left:auto;font-size:11.5px;padding:5px 10px}
/* meeting detail */
.mtg-head{display:flex;align-items:center;gap:14px;margin-bottom:6px}
.mtg-head .ava{width:54px;height:54px;border-radius:15px;display:grid;place-items:center;flex-shrink:0;color:#fff;box-shadow:var(--shadow)}
.mtg-head .ava svg{width:26px;height:26px;stroke-width:1.7}
.mtg-head h2{font-family:'Instrument Serif',serif;font-size:27px;font-weight:400}
.mtg-head input.mtg-date-in{font-family:inherit;font-size:13px;padding:7px 10px;border:1px solid var(--line);border-radius:8px;background:var(--paper-2);color:var(--ink-soft)}
.mtg-head .series-att{display:flex;margin-left:auto}
.mtg-head .series-att .av{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;font-size:11px;font-weight:700;color:#fff;border:2px solid var(--card);margin-left:-7px}
.mtg-layout{display:grid;grid-template-columns:1fr 380px;gap:24px;align-items:start;max-width:1140px;margin-top:18px}
.mtg-section{background:var(--card);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);margin-bottom:12px;overflow:hidden}
.mtg-section .ms-head{display:flex;align-items:center;gap:8px;padding:10px 12px;background:var(--paper-2);border-bottom:1px solid var(--line-soft)}
.mtg-section .ms-title{flex:1;border:0;background:transparent;font-family:'Hanken Grotesk';font-size:12.5px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;color:var(--teal);outline:none}
.mtg-section .ms-del{opacity:0;transition:.15s}
.mtg-section:hover .ms-del{opacity:1}
.mtg-section .ms-body{width:100%;border:0;outline:none;padding:12px 14px;font-family:inherit;font-size:13.5px;line-height:1.55;resize:vertical;min-height:64px;background:var(--card)}
.add-section{display:inline-flex;align-items:center;gap:8px;padding:9px 14px;border:1.5px dashed var(--line);border-radius:10px;background:transparent;color:var(--ink-faint);cursor:pointer;font-family:inherit;font-size:13px;font-weight:600;transition:.15s}
.add-section:hover{border-color:var(--teal);color:var(--teal);background:var(--teal-soft)}
.add-section svg{width:14px;height:14px;stroke-width:2.4}
.mtg-side .side-card h4{display:flex;align-items:center}
.ai-suggest-btn{margin-left:auto;font-size:11px;padding:4px 10px;border-radius:7px;border:1px solid var(--teal);background:var(--teal-soft);color:var(--teal);font-weight:700;cursor:pointer;text-transform:none;letter-spacing:0}
.ai-suggest-btn:hover{background:var(--teal);color:#fff}
.mtg-action{display:flex;align-items:center;gap:9px;padding:9px 0;border-bottom:1px solid var(--line-soft);font-size:13px}
.mtg-action:last-of-type{border-bottom:0}
.mtg-action .box{width:18px;height:18px;border-radius:6px;border:1.8px solid var(--line);flex-shrink:0;cursor:pointer;display:grid;place-items:center}
.mtg-action .box svg{width:11px;height:11px;stroke-width:3;color:#fff;opacity:0}
.mtg-action.done .box{background:var(--teal);border-color:var(--teal)}
.mtg-action.done .box svg{opacity:1}
.mtg-action.done .ma-text{text-decoration:line-through;color:var(--ink-faint)}
.mtg-action .ma-text{flex:1}
.mtg-action .ma-due{font-size:11px;color:var(--ink-faint)}
.mtg-action .ma-del{opacity:0;transition:.15s}
.mtg-action:hover .ma-del{opacity:1}
.ma-add{display:flex;flex-direction:column;gap:8px;margin-top:12px;padding-top:12px;border-top:1px solid var(--line-soft)}
.ma-add input,.ma-add select{padding:8px 10px;border:1px solid var(--line);border-radius:8px;font-family:inherit;font-size:13px;background:var(--paper-2)}
.ma-add .ma-row{display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.ma-add .tf-prio{display:flex;gap:4px}
.ma-add .pbtn{width:28px;height:28px;border-radius:7px;border:1px solid var(--line);background:#fff;font-family:inherit;font-weight:800;font-size:12px;cursor:pointer;color:var(--ink-soft)}
.ma-add .pbtn[data-p=A].on{background:var(--rose);color:#fff;border-color:var(--rose)}
.ma-add .pbtn[data-p=B].on{background:var(--amber);color:#fff;border-color:var(--amber)}
.ma-add .pbtn[data-p=C].on{background:var(--teal);color:#fff;border-color:var(--teal)}
.ai-sug{background:var(--teal-soft);border:1px solid #cfe3e0;border-radius:10px;padding:10px 12px;margin-top:10px}
.ai-sug .ais-item{display:flex;align-items:center;gap:8px;padding:6px 0;font-size:12.5px}
.ai-sug .ais-item .ais-add{margin-left:auto;font-size:11px;padding:3px 9px;border-radius:7px;border:1px solid var(--teal);background:#fff;color:var(--teal);font-weight:700;cursor:pointer}
.ai-sug .ais-item .ais-add:hover{background:var(--teal);color:#fff}

/* ---------- ÄRIREGISTER ---------- */
.ar-bar{display:flex;align-items:center;gap:12px;margin-bottom:18px}
.ar-search{width:480px;max-width:100%}
.reg-filter{display:flex;align-items:center;gap:7px;font-size:12.5px;font-weight:600;color:var(--ink-soft);cursor:pointer;white-space:nowrap;user-select:none}
.reg-filter input{width:15px;height:15px;cursor:pointer;accent-color:var(--rose)}
.ar-table{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.ar-row{display:grid;grid-template-columns:30px 1fr 120px 150px 1.4fr 110px;gap:14px;align-items:center;padding:12px 18px;border-bottom:1px solid var(--line-soft);font-size:13px}
.ar-row.sel{background:var(--teal-soft)}
.ar-check{display:flex;align-items:center}
.ar-check input{width:16px;height:16px;accent-color:var(--teal);cursor:pointer;margin:0}
.ar-selbar{display:flex;align-items:center;gap:14px;margin:-6px 0 16px;padding:10px 16px;background:var(--card);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow)}
.ar-selbar.hidden{display:none}
.ar-selall{display:flex;align-items:center;gap:7px;font-size:12.5px;color:var(--ink-soft);cursor:pointer}
.ar-selall input{width:15px;height:15px;accent-color:var(--teal);cursor:pointer;margin:0}
#arSelCount{font-size:12.5px;font-weight:700;color:var(--teal);margin-right:auto}
.ar-row:last-child{border-bottom:0}
.ar-row:hover{background:var(--paper)}
.ar-name{font-weight:600;display:flex;flex-direction:column;gap:2px}
.ar-name .ar-form{font-size:11.5px;color:var(--ink-faint);font-weight:500}
.ar-rk{font-family:'Hanken Grotesk';font-weight:600;color:var(--ink-soft)}
.ar-st{font-size:11.5px;font-weight:600;padding:2px 9px;border-radius:20px;justify-self:start}
.ar-st.on{background:var(--teal-soft);color:var(--teal)}
.ar-st.off{background:var(--rose-soft);color:var(--rose)}
.ar-addr{font-size:12px;color:var(--ink-soft);line-height:1.35}
.ar-link{font-size:12px;font-weight:600;color:var(--teal);text-decoration:none;justify-self:end;white-space:nowrap}
.ar-link:hover{text-decoration:underline}
@media(max-width:1100px){.ar-row{grid-template-columns:30px 1fr 110px 130px;gap:10px}.ar-addr,.ar-link{display:none}}

/* kampaaniad */
.camp-row{display:flex;align-items:center;gap:14px;background:var(--card);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);padding:14px 18px;margin-bottom:10px;cursor:pointer;transition:.12s}
.camp-row:hover{border-color:var(--teal)}
.camp-main{flex:1;min-width:0}
.camp-name{font-weight:600;font-size:14.5px}
.camp-sub{font-size:12px;color:var(--ink-faint);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.camp-chev{width:16px;height:16px;stroke-width:2;color:var(--ink-faint)}
.camp-badge{font-size:11px;font-weight:700;padding:4px 10px;border-radius:8px;white-space:nowrap}
.camp-badge.draft{background:var(--paper-2);color:var(--ink-soft)}
.camp-badge.sent{background:var(--teal-soft);color:var(--teal)}
.camp-badge.sending{background:#fae9cf;color:#9a6a12}
.camp-build{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:20px;align-items:start;margin-top:14px}
.camp-recip,.camp-compose{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px 18px}
.cb-head{font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--ink-faint);margin-bottom:12px;display:flex;justify-content:space-between}
#campCount{color:var(--teal);text-transform:none;letter-spacing:0}
.camp-filters{display:flex;flex-direction:column;gap:8px;margin-bottom:10px}
.camp-filters input,.camp-filters select{width:100%;padding:8px 10px;border:1px solid var(--line);border-radius:8px;font-family:inherit;font-size:13px;background:var(--card);outline:none}
.cb-chk{display:flex;align-items:center;gap:7px;font-size:12.5px;color:var(--ink-soft);cursor:pointer}
.cb-chk input{width:15px;height:15px;accent-color:var(--teal);margin:0}
.camp-selrow{display:flex;gap:8px;margin-bottom:10px}
.camp-selrow .btn{font-size:11.5px;padding:6px 10px}
.camp-list{max-height:440px;overflow-y:auto;display:flex;flex-direction:column;gap:2px}
.recip{display:flex;align-items:center;gap:10px;padding:7px 9px;border-radius:8px;cursor:pointer;font-size:12.5px;transition:background .1s}
.recip:hover{background:var(--paper)}
.recip.on{background:var(--teal-soft)}
.recip input{width:15px;height:15px;accent-color:var(--teal);margin:0;flex-shrink:0}
.recip-name{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:90px}
.recip-mail{flex:1;color:var(--ink-faint);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.recip-tag{font-size:10px;font-weight:700;padding:2px 7px;border-radius:6px;background:var(--paper-2);color:var(--ink-soft);flex-shrink:0}
.recip-tag.client{background:var(--teal-soft);color:var(--teal)}
.recip-more{padding:10px;text-align:center;font-size:11.5px;color:var(--ink-faint)}
.camp-compose label{display:block;font-size:12px;font-weight:600;color:var(--ink-soft);margin:12px 0 5px}
.camp-compose label:first-of-type{margin-top:0}
.cb-hint{font-weight:500;color:var(--ink-faint);text-transform:none;letter-spacing:0}
.camp-compose input,.camp-compose select,.camp-compose textarea{width:100%;padding:9px 11px;border:1px solid var(--line);border-radius:8px;font-family:inherit;font-size:13.5px;background:var(--card);outline:none;resize:vertical}
.camp-compose input:focus,.camp-compose textarea:focus{border-color:var(--teal)}
.camp-actions{display:flex;gap:10px;margin-top:14px}
.camp-note{font-size:11px;color:var(--ink-faint);margin-top:10px;line-height:1.5}
.camp-detail{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px 24px;margin-top:14px;max-width:760px}
.cd-head{display:flex;align-items:center;gap:14px;margin-bottom:12px}
.cd-head h2{font-family:'Instrument Serif',serif;font-size:24px;font-weight:400;flex:1}
.cd-meta{font-size:13px;margin-bottom:10px}
.cd-body{background:var(--paper);border:1px solid var(--line-soft);border-radius:10px;padding:14px 16px;font-size:13.5px;line-height:1.5;margin-bottom:12px;white-space:normal}
.cd-stats{font-size:12.5px;color:var(--ink-soft);margin-bottom:14px}
.cd-actions{display:flex;gap:10px;margin-bottom:16px}
.cd-recips{display:flex;flex-direction:column;gap:1px;max-height:340px;overflow-y:auto;border-top:1px solid var(--line-soft);padding-top:10px}
.cd-recip{display:flex;align-items:center;gap:12px;padding:7px 6px;font-size:12.5px;border-radius:6px}
.cd-recip .cd-rn{font-weight:600;min-width:120px}
.cd-recip .cd-mail{flex:1;color:var(--ink-faint)}
.cd-recip .cd-st{font-size:11.5px;font-weight:600}
.cd-recip.sent .cd-st{color:var(--teal)}
.cd-recip.failed .cd-st{color:var(--rose)}
.cd-recip.failed{background:#fbeeee}
@media(max-width:900px){.camp-build{grid-template-columns:1fr}}

/* registrid: tabid + MEDRE */
.reg-tabs{display:flex;gap:4px;border-bottom:1px solid var(--line-soft);margin-bottom:18px}
.reg-tab{padding:10px 16px;border:0;background:transparent;font-family:inherit;font-size:13.5px;font-weight:600;color:var(--ink-faint);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:.15s}
.reg-tab:hover{color:var(--ink-soft)}
.reg-tab.on{color:var(--teal);border-bottom-color:var(--teal)}
.reg-chbadge{display:inline-flex;align-items:center;justify-content:center;min-width:17px;height:17px;padding:0 5px;border-radius:9px;background:var(--rose);color:#fff;font-size:10px;font-weight:700;margin-left:5px}
.reg-pane.hidden{display:none}
.reg-status{margin-left:auto;font-size:12px;color:var(--ink-faint);white-space:nowrap}
.med-row{display:grid;grid-template-columns:30px 1.3fr 100px 1.4fr 1.6fr;gap:14px;align-items:center;padding:11px 18px;border-bottom:1px solid var(--line-soft);font-size:13px}
.med-row:last-child{border-bottom:0}
.med-row:hover{background:var(--paper)}
.med-row.sel{background:var(--teal-soft)}
.med-row.gp{grid-template-columns:30px 1.2fr 2.6fr 132px;align-items:start}
.med-row.gp .ar-check{padding-top:2px}
.med-row.gp .med-name{padding-top:1px}
.med-row.gp .med-as{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;line-height:1.45;max-height:5.4em}
.med-row.gp.miss{box-shadow:inset 3px 0 0 var(--rose)}
.gp-flag{justify-self:end;align-self:start;padding-top:1px}
.gp-miss{display:inline-block;font-size:10.5px;font-weight:700;color:var(--rose);background:var(--rose-soft);padding:3px 9px;border-radius:20px;white-space:nowrap}
.gp-has{display:inline-block;font-size:10.5px;font-weight:600;color:var(--teal);background:var(--teal-soft);padding:3px 9px;border-radius:20px;white-space:nowrap}
.reg-eriala{padding:9px 11px;border:1px solid var(--line);border-radius:9px;font-family:inherit;font-size:13px;background:var(--card);color:var(--ink);outline:none;max-width:230px;cursor:pointer}
.reg-eriala:focus{border-color:var(--teal)}
.reg-more{display:block;width:100%;padding:11px;border:0;border-top:1px solid var(--line-soft);background:var(--paper);color:var(--teal);font-family:inherit;font-size:13px;font-weight:600;cursor:pointer}
.reg-more:hover{background:var(--teal-soft)}
.reg-end{padding:11px;text-align:center;font-size:12px;color:var(--ink-faint)}
.dd-notes{width:100%;border:1px solid var(--line);border-radius:8px;padding:9px 11px;font-family:inherit;font-size:13px;line-height:1.5;resize:vertical;min-height:70px;background:var(--card);color:var(--ink);outline:none}
.dd-notes:focus{border-color:var(--teal)}
#ndNotes{width:100%;border:1px solid var(--line);border-radius:9px;padding:9px 11px;font-family:inherit;font-size:13.5px;line-height:1.5;resize:vertical;background:var(--card);color:var(--ink);outline:none}
#ndNotes:focus{border-color:var(--teal)}
/* Gmaili kahe-paneeli vaade */
.gmail-bar{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.gmail-search{flex:1;max-width:440px}
.gmail-shell{display:flex;height:calc(100vh - 210px);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--card);box-shadow:var(--shadow)}
.gmail-list{width:360px;flex-shrink:0;overflow-y:auto;border-right:1px solid var(--line-soft)}
.gmail-item{padding:12px 16px;border-bottom:1px solid var(--line-soft);cursor:pointer;transition:background .1s}
.gmail-item:hover{background:var(--paper)}
.gmail-item.active{background:var(--teal-soft)}
.gmail-item.unread .gi-from,.gmail-item.unread .gi-subj{font-weight:700}
.gmail-item.unread{box-shadow:inset 3px 0 0 var(--teal)}
.gi-top{display:flex;justify-content:space-between;gap:8px;margin-bottom:2px}
.gi-from{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gi-date{font-size:11px;color:var(--ink-faint);flex-shrink:0}
.gi-subj{font-size:13px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gi-snip{font-size:12px;color:var(--ink-faint);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}
.gmail-read{flex:1;overflow-y:auto;display:flex}
.gmail-empty{margin:auto;text-align:center;color:var(--ink-faint);font-size:13px;padding:40px 20px;line-height:1.6}
.gmail-msg{padding:24px 28px;width:100%}
.gm-subj{font-family:'Instrument Serif',serif;font-size:24px;font-weight:400;margin-bottom:12px}
.gm-meta{display:flex;justify-content:space-between;align-items:center;font-size:13px;margin-bottom:4px}
.gm-meta b{font-weight:600}
.gm-meta span{color:var(--ink-faint)}
.gm-to{font-size:12px;color:var(--ink-faint);margin-bottom:14px}
.gm-acts{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px;padding-bottom:16px;border-bottom:1px solid var(--line-soft)}
.gm-act{font-size:12.5px;padding:7px 12px}
.gm-act svg{width:14px;height:14px}
.gm-body{font-size:14px;line-height:1.6;white-space:pre-wrap;word-break:break-word}
/* koosta-modaal: ajasta */
.cmp-sched{display:flex;align-items:center;gap:10px;margin-top:12px;padding-top:12px;border-top:1px solid var(--line-soft)}
.cmp-sched.hidden{display:none}
.cmp-schedtoggle{display:flex;align-items:center;gap:7px;margin-right:auto;font-size:12.5px;font-weight:600;color:var(--ink-soft);cursor:pointer;user-select:none}
.cmp-schedtoggle input{width:15px;height:15px;cursor:pointer;accent-color:var(--teal)}
/* koosta: saaja-rida + cc/bcc + autocomplete */
.cmp-torow{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.cmp-cctoggle{display:flex;gap:4px}
.cmp-cctoggle button{border:0;background:transparent;font-family:inherit;font-size:12px;font-weight:600;color:var(--ink-faint);cursor:pointer;padding:2px 7px;border-radius:6px}
.cmp-cctoggle button:hover{background:var(--paper);color:var(--teal)}
.cmp-acwrap{position:relative}
.cmp-ac{position:absolute;top:calc(100% + 3px);left:0;right:0;background:var(--card);border:1px solid var(--line);border-radius:10px;box-shadow:var(--shadow-lift);z-index:30;overflow:hidden;max-height:250px;overflow-y:auto}
.cmp-ac.hidden{display:none}
.cmp-acitem{display:flex;align-items:center;gap:10px;padding:8px 11px;cursor:pointer}
.cmp-acitem:hover{background:var(--paper)}
.cmp-acitem .av{width:26px;height:26px;border-radius:50%;display:grid;place-items:center;font-size:10px;font-weight:700;flex-shrink:0}
.cmp-acmeta{min-width:0}
.cmp-acn{font-size:13px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cmp-ace{font-size:11.5px;color:var(--ink-faint);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
/* ajastatud kirjade nimekiri */
.sch-row{display:flex;align-items:center;gap:12px;padding:11px 13px;border:1px solid var(--line-soft);border-radius:10px;margin-bottom:8px}
.sch-main{flex:1;min-width:0}
.sch-to{font-weight:600;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sch-subj{font-size:12px;color:var(--ink-soft);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sch-at{font-size:12px;font-weight:600;color:var(--teal);white-space:nowrap;flex-shrink:0}
.sch-cancel{flex-shrink:0}
@media(max-width:900px){.gmail-list{width:210px}}
/* perearsti detail (register → CRM) */
.gpd-info{margin-bottom:14px}
.gpd-row{display:flex;align-items:center;gap:8px;font-size:13.5px;padding:3px 0;color:var(--ink)}
.gpd-row svg{width:16px;height:16px;color:var(--ink-faint);flex-shrink:0}
.gpd-contact{background:var(--teal-soft);border-radius:10px;padding:12px 14px;margin-bottom:14px}
.gpd-clabel{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--teal);margin-bottom:6px}
.gpd-hist{margin-bottom:16px}
.gpd-hlabel{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--ink-faint);margin-bottom:8px}
.gpd-act{display:flex;align-items:center;gap:10px;padding:6px 0;border-bottom:1px solid var(--line-soft);font-size:12.5px}
.gpd-asub{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.gpd-adate{color:var(--ink-faint);font-size:11.5px;flex-shrink:0}
.gpd-noc{font-size:13px;color:var(--ink-soft);background:var(--paper);border-radius:10px;padding:12px 14px;margin-bottom:14px}
.gpd-actions{display:flex;gap:10px}
.med-row.gp{cursor:pointer}
.med-row{cursor:pointer}
/* AI kontaktiotsing (rikastus) */
.enr-box{background:var(--paper);border:1px solid var(--line-soft);border-radius:12px;padding:14px;margin:14px 0}
.enr-head{display:flex;align-items:center;gap:7px;font-size:13px;font-weight:700;color:var(--ink)}
.enr-head svg{width:16px;height:16px;color:#7a5ea8}
.enr-hint{font-size:11.5px;color:var(--ink-faint);line-height:1.5;margin:6px 0 11px}
.enr-btn{width:100%;justify-content:center;background:#7a5ea8;border-color:#7a5ea8}
.enr-btn svg{width:15px;height:15px}
.enr-btn.loading{opacity:.6;pointer-events:none}
.enr-loading{font-size:12.5px;color:var(--ink-faint);padding:11px 2px;text-align:center}
.enr-fail{font-size:12.5px;color:var(--ink-soft);background:var(--rose-soft);border-radius:8px;padding:10px 12px;margin-top:11px;line-height:1.5}
.enr-fail a{color:var(--rose);font-weight:600}
.enr-result{margin-top:12px;display:flex;flex-direction:column;gap:2px}
.enr-conf{font-size:11px;font-weight:700;margin-bottom:5px}
.enr-f{display:flex;align-items:baseline;gap:10px;padding:5px 0;border-bottom:1px solid var(--line-soft);font-size:13px}
.enr-l{width:74px;flex-shrink:0;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;color:var(--ink-faint)}
.enr-v{color:var(--ink);word-break:break-all}
.enr-v.muted{color:var(--ink-faint)}
a.enr-v.link{color:var(--teal);font-weight:600;text-decoration:none}
a.enr-v.link:hover{text-decoration:underline}
.enr-notes{font-size:12px;color:var(--ink-soft);line-height:1.5;margin-top:9px;font-style:italic}
.enr-src{font-size:11px;color:var(--ink-faint);margin-top:8px}
.enr-src a{color:var(--ink-soft);text-decoration:underline;margin-right:4px}
.enr-apply{width:100%;justify-content:center;margin-top:13px}
.enr-apply svg{width:15px;height:15px}
/* töötaja CRM staatus */
.wrkd-status{margin:14px 0}
.wst{border-radius:12px;padding:13px 15px}
.wst-in{background:var(--teal-soft)}
.wst-out{background:var(--paper);border:1px dashed var(--line)}
.wst-head{display:flex;align-items:center;gap:9px;flex-wrap:wrap;margin-bottom:9px}
.wst-badge{font-size:10.5px;font-weight:700;padding:3px 9px;border-radius:20px}
.wst-badge.ok{background:var(--teal);color:#fff}
.wst-badge.call{background:#bd8334;color:#fff}
.wst-badge.new{background:var(--line-soft);color:var(--ink-soft)}
.wst-owner{font-size:11.5px;color:var(--ink-soft);font-weight:600}
.wst-out p{font-size:12.5px;color:var(--ink-soft);line-height:1.5;margin:8px 0 0}
.wst-row{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--ink);padding:2px 0}
.wst-row svg{width:15px;height:15px;color:var(--ink-faint);flex-shrink:0}
.wst-deals{display:flex;flex-wrap:wrap;gap:6px;margin-top:9px}
.wst-deal{font-size:11px;font-weight:600;background:var(--card);border:1px solid var(--line);border-radius:7px;padding:3px 9px;color:var(--ink-soft)}
.wst-acts{margin-top:10px;border-top:1px solid rgba(0,0,0,.06);padding-top:8px}
.wst-act{display:flex;justify-content:space-between;gap:10px;font-size:12px;padding:3px 0;color:var(--ink-soft)}
.wst-act span:first-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.wst-date{flex-shrink:0;color:var(--ink-faint)}
.wst-none{font-size:12px;color:var(--ink-faint);margin-top:8px}
.wst-open{margin-top:11px;width:100%;justify-content:center;font-size:12.5px}
/* AI kõnede-soovitused */
.cs-loading{padding:30px 10px;text-align:center;color:var(--ink-faint);font-size:13px}
.cs-row{display:flex;align-items:center;gap:11px;padding:10px 11px;border:1px solid var(--line-soft);border-radius:10px;margin-bottom:7px;cursor:pointer;transition:.12s}
.cs-row:hover{border-color:var(--line);background:var(--paper)}
.cs-row input{width:16px;height:16px;flex-shrink:0;accent-color:#7a5ea8;cursor:pointer}
.cs-rank{width:22px;height:22px;flex-shrink:0;border-radius:50%;background:#7a5ea8;color:#fff;display:grid;place-items:center;font-size:11px;font-weight:700}
.cs-main{flex:1;min-width:0}
.cs-name{font-weight:600;font-size:13.5px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.cs-reason{font-size:12px;color:var(--ink-soft);line-height:1.45;margin-top:2px}
.cs-device{flex-shrink:0;font-size:11px;font-weight:700;color:#7a5ea8;background:#f0ebf7;padding:4px 10px;border-radius:20px;white-space:nowrap;max-width:130px;overflow:hidden;text-overflow:ellipsis}
/* bulk AI kontaktiotsing */
.eb-prog{margin-bottom:16px}
.eb-bar{height:8px;background:var(--line-soft);border-radius:20px;overflow:hidden;margin-bottom:8px}
.eb-fill{height:100%;background:#7a5ea8;border-radius:20px;transition:width .4s}
.eb-nums{font-size:12.5px;color:var(--ink-soft);font-weight:600;text-align:center}
.eb-rlabel{font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.03em;color:var(--ink-faint);margin:6px 0 10px}
.eb-row{display:flex;align-items:center;gap:11px;padding:9px 11px;border:1px solid var(--line-soft);border-radius:10px;margin-bottom:7px;cursor:pointer}
.eb-row:hover{border-color:var(--line);background:var(--paper)}
.eb-row input{width:16px;height:16px;flex-shrink:0;accent-color:#7a5ea8;cursor:pointer}
.eb-main{flex:1;min-width:0}
.eb-name{font-weight:600;font-size:13.5px;display:flex;align-items:center;gap:7px}
.eb-conf{font-size:10px}
.eb-fields{display:flex;flex-wrap:wrap;gap:12px;font-size:12px;color:var(--ink-soft);margin-top:3px}
.eb-fields a{color:var(--teal);font-weight:600;text-decoration:none}
.med-name{font-weight:600;display:flex;flex-direction:column;gap:2px}
.med-name .med-kood{font-size:11px;color:var(--ink-faint);font-weight:500}
.med-kutse,.med-eri,.med-as{font-size:12px;color:var(--ink-soft)}
.reg-ch-head{font-size:12.5px;color:var(--ink-soft);margin-bottom:12px}
.ch-row{display:grid;grid-template-columns:84px 78px 1fr 90px;gap:12px;align-items:center;padding:10px 18px;border-bottom:1px solid var(--line-soft);font-size:13px}
.ch-row:last-child{border-bottom:0}
.ch-badge{font-size:10px;font-weight:700;padding:3px 8px;border-radius:7px;text-align:center;text-transform:uppercase;letter-spacing:.3px}
.ch-badge.added{background:var(--teal-soft);color:var(--teal)}
.ch-badge.removed{background:#fbeeee;color:var(--rose)}
.ch-badge.changed{background:#fae9cf;color:#9a6a12}
.ch-ds{font-size:11.5px;color:var(--ink-faint);font-weight:600}
.ch-name{font-weight:600}
.ch-when{font-size:11.5px;color:var(--ink-faint);text-align:right}
@media(max-width:1100px){.med-row{grid-template-columns:30px 1.3fr 1.5fr}.med-kutse,.med-as{display:none}}

/* lisa tehing modaal */
.nd-row{display:flex;gap:12px}
.nd-mode{display:flex;gap:6px;margin-bottom:8px}
.nd-m{padding:6px 12px;border:1px solid var(--line);border-radius:8px;background:var(--card);font-family:inherit;font-size:12.5px;font-weight:600;color:var(--ink-soft);cursor:pointer;transition:.12s}
.nd-m.on{background:var(--teal);border-color:var(--teal);color:#fff}
.nd-results{margin-top:6px;max-height:200px;overflow-y:auto;display:flex;flex-direction:column;gap:2px}
.ndr{display:flex;align-items:center;gap:9px;padding:7px 9px;border-radius:8px;cursor:pointer;font-size:13px;transition:background .1s}
.ndr:hover{background:var(--paper)}
.ndr .av{width:24px;height:24px;border-radius:50%;display:grid;place-items:center;font-size:9px;font-weight:700;color:#fff;background:var(--teal);flex-shrink:0}
.ndr .ndr-n{font-weight:600}
.ndr small{color:var(--ink-faint);margin-left:auto}
.nd-picked{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--teal);border-radius:10px;background:var(--teal-soft);margin-bottom:6px}
.nd-picked.hidden{display:none}
.nd-picked .av{width:32px;height:32px;border-radius:50%;display:grid;place-items:center;font-size:11px;font-weight:700;color:#fff;background:var(--teal);flex-shrink:0}
.ndp-n{font-weight:600;font-size:13.5px}
.ndp-s{font-size:11.5px;color:var(--ink-soft)}
/* arhiiv */
.arch-list{display:flex;flex-direction:column;gap:6px;max-height:60vh;overflow-y:auto}
.arch-row{display:flex;align-items:center;gap:12px;padding:11px 14px;border:1px solid var(--line);border-radius:10px;cursor:pointer;transition:.12s}
.arch-row:hover{border-color:var(--teal);background:var(--paper)}
.arch-main{flex:1;min-width:0}
.arch-title{font-weight:600;font-size:13.5px}
.arch-sub{font-size:11.5px;color:var(--ink-faint)}
.arch-badge{font-size:10.5px;font-weight:700;padding:3px 9px;border-radius:7px;white-space:nowrap}
.arch-badge.won{background:var(--teal-soft);color:var(--teal)}
.arch-badge.lost{background:#fbeeee;color:var(--rose)}
.arch-badge.removed{background:var(--paper-2);color:var(--ink-soft)}
.arch-restore{font-size:11.5px;padding:6px 11px;flex-shrink:0}
.dd-cbtns{display:flex;gap:8px;margin-top:4px}
.dd-cbtns .btn{flex:1;justify-content:center;font-size:12px;padding:7px 8px}
/* ülesannete tahvli muudetavus */
.tcol-x{opacity:0;width:22px;height:22px;border:0;background:transparent;border-radius:6px;cursor:pointer;color:var(--ink-faint);display:grid;place-items:center;flex-shrink:0;transition:.12s}
.tcol-x svg{width:13px;height:13px;stroke-width:2}
.tcol-head:hover .tcol-x{opacity:.65}
.tcol-x:hover{opacity:1;background:var(--paper);color:var(--rose)}
.tcol-add{flex-shrink:0;width:230px;display:flex;flex-direction:column;gap:14px;padding:8px}
.tca-new{display:flex;flex-direction:column;gap:8px}
.tca-input{padding:9px 11px;border:1px dashed var(--line);border-radius:9px;font-family:inherit;font-size:13px;background:transparent;outline:none}
.tca-input:focus{border-color:var(--teal);border-style:solid}
.tca-add{justify-content:center;font-size:12.5px}
.tca-ppl{border-top:1px solid var(--line-soft);padding-top:12px;display:flex;flex-direction:column;gap:6px}
.tca-lbl{font-size:11px;color:var(--ink-faint);font-weight:600}
.tca-person{display:flex;align-items:center;gap:8px;padding:6px 9px;border:1px solid var(--line);border-radius:8px;background:var(--card);font-family:inherit;font-size:12.5px;font-weight:600;color:var(--ink-soft);cursor:pointer;transition:.12s}
.tca-person:hover{border-color:var(--teal);color:var(--teal)}
.tca-person .av{width:20px;height:20px;border-radius:50%;display:grid;place-items:center;font-size:8px;font-weight:700;color:#fff}
/* veeru päevavaate nupp */
.tcol-open{opacity:0;width:22px;height:22px;border:0;background:transparent;border-radius:6px;cursor:pointer;color:var(--ink-faint);display:grid;place-items:center;flex-shrink:0;transition:.12s}
.tcol-open svg{width:14px;height:14px;stroke-width:1.8}
.tcol-head:hover .tcol-open{opacity:.6}
.tcol-open:hover{opacity:1;background:var(--paper);color:var(--teal)}
/* väike "Uus nimekiri" nupp */
.tca-plus{display:flex;align-items:center;gap:7px;padding:9px 12px;border:1px dashed var(--line);border-radius:9px;background:transparent;font-family:inherit;font-size:12.5px;font-weight:600;color:var(--ink-faint);cursor:pointer;transition:.14s}
.tca-plus svg{width:15px;height:15px;stroke-width:2}
.tca-plus:hover{border-color:var(--teal);border-style:solid;color:var(--teal);background:var(--teal-soft)}
/* modaali väljad */
.fld-lbl{display:block;font-size:11.5px;font-weight:700;color:var(--ink-soft);margin-bottom:6px;letter-spacing:.01em}
.fld-in{width:100%;padding:10px 12px;border:1.5px solid var(--line);border-radius:9px;font-family:inherit;font-size:14px;background:var(--card);color:var(--ink);outline:none;transition:.14s}
.fld-in:focus{border-color:var(--teal)}
.fld-hint{font-size:11.5px;color:var(--ink-faint);line-height:1.5;margin:10px 0 0}
/* nimekirja päevavaade */
.ld-group{margin-bottom:18px}
.ld-group:last-child{margin-bottom:0}
.ld-glabel{display:flex;align-items:center;gap:8px;font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-soft);margin-bottom:9px}
.ld-glabel span{font-size:11px;color:var(--ink-faint);background:var(--line-soft);padding:1px 8px;border-radius:20px;font-weight:600;letter-spacing:0}
.ld-group.overdue .ld-glabel{color:var(--rose)}
.ld-group.today .ld-glabel{color:var(--teal)}
.ld-task{display:flex;align-items:center;gap:10px;padding:9px 11px;border:1px solid var(--line-soft);border-radius:9px;background:var(--card);margin-bottom:6px;transition:.12s}
.ld-task:hover{border-color:var(--line)}
.ld-task.done{opacity:.5}
.ld-task.done .ld-text{text-decoration:line-through}
.ld-box{width:20px;height:20px;flex-shrink:0;border:1.5px solid var(--line);border-radius:6px;display:grid;place-items:center;cursor:pointer;color:transparent;transition:.12s}
.ld-box svg{width:13px;height:13px;stroke-width:2.5}
.ld-box:hover{border-color:var(--teal)}
.ld-task.done .ld-box{background:var(--teal);border-color:var(--teal);color:#fff}
.ld-text{flex:1;font-size:13.5px;color:var(--ink);min-width:0}
.ld-who{flex-shrink:0}
.ld-who .av{width:22px;height:22px;border-radius:50%;display:grid;place-items:center;font-size:9px;font-weight:700;color:#fff}
.ld-due{flex-shrink:0;font-size:11.5px;color:var(--ink-faint);font-weight:600;white-space:nowrap}

/* ---------- tehingu sulgemine ---------- */
.close-opts{display:flex;gap:8px;margin-bottom:14px}
.close-opt{flex:1;display:flex;flex-direction:column;align-items:center;gap:7px;padding:15px 8px;border:1.5px solid var(--line);border-radius:12px;background:var(--card);cursor:pointer;font-family:inherit;font-size:12.5px;font-weight:700;color:var(--ink-soft);transition:.15s}
.close-opt svg{width:21px;height:21px;stroke-width:2}
.close-opt.won:hover{border-color:var(--teal);background:var(--teal-soft);color:var(--teal)}
.close-opt.lost:hover{border-color:var(--rose);background:var(--rose-soft);color:var(--rose)}
.close-opt.rm:hover{border-color:var(--ink-faint);background:var(--line-soft);color:var(--ink)}

/* e-kirja mallid */
.tmpl-row{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--line-soft)}
.tmpl-row:last-child{border-bottom:0}
.tmpl-info{flex:1;min-width:0}
.tmpl-info b{font-size:13px;display:block}
.tmpl-info span{font-size:11.5px;color:var(--ink-faint);display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tmpl-row .tmpl-del:hover{border-color:var(--rose);color:var(--rose)}
#cmTemplate{width:100%;padding:9px 12px;border:1px solid var(--line);border-radius:9px;font-family:inherit;font-size:13.5px;background:var(--paper-2);margin-bottom:4px}
