/* ============================================================
   Сходки — design system
   Подключение в base.html:
   <link href="https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,500;12..96,600;12..96,700;12..96,800&display=swap" rel="stylesheet">
   <link rel="stylesheet" href="{{ url_for('static', filename='css/shodki.css') }}">
   ============================================================ */
:root{
  --paper:#F7F5F1;
  --surface:#FFFFFF;
  --ink:#1E2420;
  --muted:#6E726B;
  --faint:#9A9D96;
  --line:#E9E5DD;
  --line-soft:#F0EDE6;

  --pine:#2C6E49;
  --pine-deep:#1F4D34;
  --pine-tint:#E7F0EA;

  --honey:#D9943B;
  --danger:#C0544A;
  --danger-tint:#F7E7E5;

  --cat-ice:#4F86B3;     --cat-ice-bg:#E6EFF6;
  --cat-banya:#C56B4A;   --cat-banya-bg:#F8E9E2;
  --cat-velo:#3F9266;    --cat-velo-bg:#E4F1E9;
  --cat-show:#7A66AE;    --cat-show-bg:#EEEAF6;
  --cat-default:#C08A3E; --cat-default-bg:#F6EEE0;

  --r-lg:22px; --r-md:16px; --r-sm:11px;
  --shadow:0 1px 2px rgba(31,40,33,.04), 0 8px 24px -12px rgba(31,40,33,.18);
  --shadow-pop:0 12px 40px -10px rgba(31,40,33,.30);

  --bar-bg:rgba(247,245,241,.82);
  --toast-bg:#1E2420;
  --app-glow:0 0 60px rgba(31,40,33,.06);
  --add-bg:#FCFBF9;
}

/* ---------- тёмная тема (настройка theme=dark в БД) ---------- */
html[data-theme="dark"]{
  --paper:#15181C;
  --surface:#1F242A;
  --ink:#E8EBE5;
  --muted:#9BA199;
  --faint:#727870;
  --line:#333A42;
  --line-soft:#272D33;

  --pine:#3E9A66;
  --pine-deep:#2C6E49;
  --pine-tint:#1C2C24;

  --danger:#E0786C;
  --danger-tint:#3A2420;

  --cat-ice-bg:#1B2A36;
  --cat-banya-bg:#33231C;
  --cat-velo-bg:#1B2C22;
  --cat-show-bg:#262035;
  --cat-default-bg:#332B1C;

  --shadow:0 1px 2px rgba(0,0,0,.30), 0 8px 24px -12px rgba(0,0,0,.60);
  --shadow-pop:0 12px 40px -10px rgba(0,0,0,.70);
  --bar-bg:rgba(21,24,28,.82);
  --toast-bg:#2C3037;
  --app-glow:0 0 60px rgba(0,0,0,.45);
  --add-bg:#191D22;
}

*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;touch-action:manipulation;}
/* тонкая полоска прогресса PJAX-навигации (вверху экрана) */
.pjax-bar{position:fixed;top:0;left:0;right:0;height:2.5px;background:var(--pine);z-index:99999;
  transform:scaleX(0);transform-origin:0 50%;opacity:0;pointer-events:none;}
.pjax-bar.run{opacity:1;transform:scaleX(.9);transition:transform 6s cubic-bezier(.05,.7,.1,1);}
.pjax-bar.done{opacity:0;transform:scaleX(1);transition:transform .2s ease,opacity .35s ease .1s;}
html,body{margin:0;padding:0;}
body{
  font-family:-apple-system,BlinkMacSystemFont,"Inter","Segoe UI",Roboto,sans-serif;
  background:var(--paper);color:var(--ink);
  font-size:16px;line-height:1.4;-webkit-font-smoothing:antialiased;letter-spacing:-0.01em;
}
.brand-font{font-family:"Bricolage Grotesque",sans-serif;letter-spacing:-0.02em;}

.app{
  max-width:480px;margin:0 auto;min-height:100vh;background:var(--paper);position:relative;
  display:flex;flex-direction:column;box-shadow:var(--app-glow);
}

/* ---------- top bar ---------- */
.bar{
  position:sticky;top:0;z-index:30;
  background:var(--bar-bg);
  backdrop-filter:saturate(180%) blur(14px);-webkit-backdrop-filter:saturate(180%) blur(14px);
  border-bottom:1px solid var(--line-soft);padding:max(10px,env(safe-area-inset-top)) 18px 0;
}
.bar-top{display:flex;align-items:center;justify-content:space-between;height:46px;}
.wordmark{display:flex;align-items:center;gap:9px;text-decoration:none;color:inherit;}
.wordmark .dot{
  width:26px;height:26px;border-radius:9px;background:linear-gradient(150deg,var(--pine),var(--pine-deep));
  display:grid;place-items:center;color:#fff;box-shadow:0 2px 6px -1px rgba(44,110,73,.5);
}
.wordmark .dot svg{width:15px;height:15px;}
.wordmark h1{font-size:21px;font-weight:700;margin:0;}
.menu-btn{width:38px;height:38px;border:none;background:transparent;border-radius:11px;display:grid;place-items:center;color:var(--ink);cursor:pointer;}
.menu-btn:active{background:var(--line-soft);}
.menu-btn svg{width:22px;height:22px;}

.tabs{display:flex;align-items:center;gap:4px;padding:10px 0 0;}
/* круглые кнопки создания в строке вкладок */
.tabs-gap{flex:1;}
.tabs .menu-btn{flex:0 0 auto;margin-left:4px;margin-bottom:5px;}
.tab-add-form{display:flex;}
.tab-add-form + .tab-add-form{margin-left:8px;}
.tab-add{width:34px;height:34px;border-radius:50%;border:none;cursor:pointer;display:grid;
  place-items:center;margin-bottom:7px;transition:transform .12s;}
.tab-add:active{transform:scale(.92);}
.tab-add svg{width:18px;height:18px;}
.tab-add-event{background:linear-gradient(160deg,var(--pine),var(--pine-deep));color:#fff;
  box-shadow:0 3px 9px -3px rgba(44,110,73,.55);}
.tab-add-person{background:var(--surface);color:var(--ink);border:1px solid var(--line);}
.tab{
  border:none;background:transparent;cursor:pointer;text-decoration:none;
  font-size:15px;font-weight:600;color:var(--faint);padding:8px 2px 13px;position:relative;
  margin-right:18px;letter-spacing:-0.01em;font-family:inherit;transition:color .18s ease;
}
.tab.active{color:var(--ink);}
.tab::after{content:"";position:absolute;left:0;right:0;bottom:0;height:2.5px;border-radius:3px;
  background:var(--pine);transform:scaleX(0);transform-origin:center;transition:transform .22s cubic-bezier(.2,.7,.3,1);}
.tab.active::after{transform:scaleX(1);}

/* ---------- screens ---------- */
.screen{flex:1;padding:18px 18px calc(28px + env(safe-area-inset-bottom));animation:fade .28s ease;}
@keyframes fade{from{opacity:0;transform:translateY(6px);}to{opacity:1;transform:none;}}

.section-head{display:flex;align-items:baseline;justify-content:space-between;margin:6px 2px 14px;}
.section-head h2{font-size:27px;font-weight:800;margin:0;}
.section-head .count{font-size:13px;color:var(--faint);font-weight:600;}

/* quick add row */
.quickadd{display:flex;gap:9px;margin-bottom:18px;}
.quickadd input{
  flex:1;border:1px solid var(--line);background:var(--surface);border-radius:14px;
  padding:14px 16px;font-size:16px;color:var(--ink);font-family:inherit;transition:border-color .15s,box-shadow .15s;
}
.quickadd input::placeholder{color:var(--faint);}
.quickadd input:focus{outline:none;border-color:var(--pine);box-shadow:0 0 0 3px var(--pine-tint);}
.iconbtn-primary{
  flex:0 0 52px;border:none;border-radius:50%;cursor:pointer;
  background:linear-gradient(160deg,var(--pine),var(--pine-deep));color:#fff;display:grid;place-items:center;
  box-shadow:0 4px 12px -3px rgba(44,110,73,.55);transition:transform .12s;
}
.iconbtn-primary:active{transform:scale(.94);}
.iconbtn-primary svg{width:22px;height:22px;}

/* ---------- event card (единый стиль со списком людей) ---------- */
.cards{display:flex;flex-direction:column;gap:2px;background:var(--surface);border:1px solid var(--line-soft);border-radius:var(--r-md);padding:5px;box-shadow:var(--shadow);}
.card{
  background:transparent;border-radius:12px;padding:11px;min-height:66px;
  display:flex;align-items:center;gap:12px;cursor:pointer;
  transition:background .12s;text-decoration:none;color:inherit;
}
.card:active{background:var(--line-soft);}
.card + .card{border-top:1px solid var(--line-soft);}

/* category classes — поставь одну на .card (см. фильтр category в jinja_helpers.py) */
.cat-ice{--cat:var(--cat-ice);--cat-bg:var(--cat-ice-bg);}
.cat-banya{--cat:var(--cat-banya);--cat-bg:var(--cat-banya-bg);}
.cat-velo{--cat:var(--cat-velo);--cat-bg:var(--cat-velo-bg);}
.cat-show{--cat:var(--cat-show);--cat-bg:var(--cat-show-bg);}
.cat-def{--cat:var(--cat-default);--cat-bg:var(--cat-default-bg);}

.card-av{width:40px;height:40px;font-size:15px;}

.card-body{flex:1;min-width:0;}
.card-title{font-weight:700;font-size:16px;color:var(--ink);margin:0 0 4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.card-meta{display:flex;align-items:center;gap:8px;min-width:0;}
.card-date{font-size:12.5px;color:var(--muted);font-weight:500;white-space:nowrap;flex:0 0 auto;}
.card-cat{font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--cat,var(--cat-default));white-space:nowrap;flex:0 0 auto;}

.stack{display:flex;flex:0 0 auto;}
.stack .av{width:24px;height:24px;font-size:10px;margin-left:-7px;border:2px solid var(--surface);}
.stack .av:first-child{margin-left:0;}
.who{font-size:12.5px;color:var(--muted);font-weight:500;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.who.empty{color:var(--faint);}

.av{width:30px;height:30px;border-radius:50%;flex:0 0 auto;display:grid;place-items:center;font-size:12px;font-weight:700;color:#fff;}
.chev{color:var(--faint);flex:0 0 auto;}
.chev svg{width:18px;height:18px;display:block;}

.empty-state{text-align:center;padding:54px 24px;color:var(--muted);border:1.5px dashed var(--line);border-radius:var(--r-lg);background:#fcfbf9;}
.empty-state .ico{font-size:34px;margin-bottom:10px;opacity:.8;}
.empty-state b{display:block;color:var(--ink);font-size:16px;margin-bottom:4px;font-weight:700;}
.empty-state span{font-size:13.5px;}

/* ---------- people list ---------- */
.people{display:flex;flex-direction:column;gap:2px;background:var(--surface);border:1px solid var(--line-soft);border-radius:var(--r-md);padding:5px;box-shadow:var(--shadow);}
.person{display:flex;align-items:center;gap:13px;padding:11px 11px 11px 4px;min-height:66px;border-radius:12px;transition:background .12s;text-decoration:none;color:inherit;}
.person:active{background:var(--line-soft);}
.p-av{flex:0 0 auto;display:flex;text-decoration:none;}
.p-av .av{width:40px;height:40px;font-size:15px;}
.person-info{flex:1;min-width:0;}
.person-name{font-weight:600;font-size:16px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.person-handle{font-size:13px;color:var(--faint);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.person-stat{font-size:12px;color:var(--muted);font-weight:600;background:var(--line-soft);padding:5px 10px;border-radius:20px;white-space:nowrap;}

/* ---------- detail ---------- */
.detail-head{display:flex;align-items:center;gap:6px;margin:2px 0 18px;}
.back{width:40px;height:40px;border:none;background:var(--surface);border:1px solid var(--line);border-radius:50%;display:grid;place-items:center;cursor:pointer;color:var(--ink);flex:0 0 auto;transition:background .12s;text-decoration:none;}
.back:active{background:var(--line-soft);}
.back svg{width:20px;height:20px;}
.detail-cat{font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--cat,var(--cat-default));display:flex;align-items:center;gap:7px;}
.detail-cat .pip{width:9px;height:9px;border-radius:50%;background:var(--cat,var(--cat-default));}

.field{margin-bottom:18px;}
.field label{display:block;font-size:13px;font-weight:600;color:var(--muted);margin:0 0 7px 2px;}
.field input,.field textarea{width:100%;border:1px solid var(--line);background:var(--surface);border-radius:14px;padding:14px 16px;font-size:16px;color:var(--ink);font-family:inherit;resize:none;transition:border-color .15s,box-shadow .15s;}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--pine);box-shadow:0 0 0 3px var(--pine-tint);}
.field .title-input{font-size:19px;font-weight:700;font-family:"Bricolage Grotesque";}
/* «убрать» — пилюля у правого края поля названия/имени */
.title-wrap{position:relative;flex:1;min-width:0;}
.title-wrap .title-input{width:100%;padding-right:90px;}
.del-inline{position:absolute;right:7px;top:50%;transform:translateY(-50%);border:none;
  background:var(--line-soft);color:var(--muted);font-size:14px;font-weight:600;padding:9px 17px;
  border-radius:22px;cursor:pointer;font-family:inherit;transition:background .12s,color .12s;}
.del-inline:active{background:var(--danger-tint);color:var(--danger);}
.field textarea{min-height:96px;line-height:1.45;}
.field textarea.tall{min-height:200px;}
/* дата: аккуратный текст под названием + ссылка «Изменить дату»; поле прячется */
.date-line{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin:-8px 0 18px 2px;}
.date-text{font-size:15px;color:var(--ink);font-weight:600;}
.date-edit{border:none;background:transparent;color:var(--pine);font-size:13.5px;font-weight:600;
  font-family:inherit;cursor:pointer;padding:2px 0;text-decoration:underline;text-underline-offset:2px;}
.date-reset{border:none;background:transparent;color:var(--muted);font-size:13.5px;font-weight:600;
  font-family:inherit;cursor:pointer;padding:2px 0;text-decoration:underline;text-underline-offset:2px;}
/* Прозрачный input[type=date] поверх ссылки «Изменить дату» — тап открывает пикер */
.date-edit-overlay{position:relative;display:inline-flex;align-items:center;}
.date-edit-overlay input[type=date]{position:absolute;inset:0;width:100%;height:100%;opacity:0;
  margin:0;padding:0;border:0;cursor:pointer;-webkit-appearance:none;appearance:none;}
/* индикатор «есть ещё текст» в textarea */
.ta-wrap{position:relative;}
.ta-wrap textarea{padding-bottom:64px;}
.ta-more{position:absolute;left:11px;bottom:13px;width:24px;height:24px;border-radius:50%;
  background:var(--surface);border:1px solid var(--line);color:var(--muted);
  display:none;align-items:center;justify-content:center;pointer-events:none;
  box-shadow:0 1px 4px rgba(31,40,33,.12);animation:fade .2s ease;}
.ta-wrap.more .ta-more{display:flex;}
/* круглая «Сохранить» — в правом нижнем углу поля ввода */
.ta-save{position:absolute;right:10px;bottom:10px;z-index:2;}
/* богатое поле (Описание/Заметка): блочный редактор как в Заметках iOS — пункты
   списка рисуются кружками, «[ ]» в тексте не видно. Каждая строка — мини-textarea. */
.ta-wrap.rich textarea[data-rich]{display:none;}
.ta-wrap.rich .ta-more{display:none;}
.cl-editor{width:100%;min-height:200px;max-height:470px;overflow-y:auto;
  border:1px solid var(--line);background:var(--surface);border-radius:14px;
  padding:9px 14px 56px;font-size:16px;color:var(--ink);cursor:text;
  transition:border-color .15s,box-shadow .15s;}
.cl-editor:focus-within{border-color:var(--pine);box-shadow:0 0 0 3px var(--pine-tint);}
.cl-row{display:flex;align-items:flex-start;gap:10px;}
.cl-line{flex:1;min-width:0;min-height:1.35em;outline:none;font-family:inherit;font-size:16px;
  line-height:1.4;color:var(--ink);padding:2px 0;white-space:pre-wrap;word-break:break-word;
  -webkit-user-modify:read-write-plaintext-only;}
.cl-line:empty:before{content:attr(data-ph);color:var(--faint);pointer-events:none;}
.cl-line:focus,.cl-line:focus-visible{outline:none;}  /* фокус показывает рамка всего .cl-editor, не каждая строка */
.cl-box{flex:0 0 auto;width:23px;height:23px;margin-top:3px;border-radius:50%;
  border:2px solid var(--faint);background:transparent;color:#fff;cursor:pointer;
  display:grid;place-items:center;padding:0;transition:background .12s,border-color .12s;}
.cl-box svg{width:15px;height:15px;opacity:0;transition:opacity .12s;}
.cl-item.done .cl-box{background:var(--pine);border-color:var(--pine);}
.cl-item.done .cl-box svg{opacity:1;}
.cl-item.done .cl-line{color:var(--faint);text-decoration:line-through;}
/* Кластер круглых кнопок редактора: [Отменить] [Вернуть] [Применить] — виден после правки */
.cl-actions{position:absolute;right:10px;bottom:10px;z-index:2;display:flex;gap:8px;}
.cl-act{width:54px;height:54px;border-radius:50%;border:none;padding:0;cursor:pointer;
  display:grid;place-items:center;transition:transform .12s,opacity .12s;}
.cl-act:active{transform:scale(.94);}
.cl-act svg{width:22px;height:22px;}
.cl-act-nav{background:var(--surface);color:var(--ink);border:1px solid var(--line);box-shadow:var(--shadow);}
.cl-act-nav:disabled{opacity:.4;cursor:default;}
.cl-act-apply{background:linear-gradient(160deg,var(--pine),var(--pine-deep));color:#fff;
  box-shadow:0 5px 14px -4px rgba(44,110,73,.5);}
/* кнопка «Пункт списка» под полем */
.cl-add{display:inline-flex;align-items:center;gap:7px;margin-top:10px;border:1px solid var(--line);
  background:var(--surface);color:var(--muted);font-size:13.5px;font-weight:600;font-family:inherit;
  padding:8px 14px;border-radius:22px;cursor:pointer;transition:background .12s,color .12s,border-color .12s;}
.cl-add:active{background:var(--pine-tint);color:var(--pine);border-color:var(--pine);}
.cl-add-ic{display:grid;place-items:center;}
.cl-add-ic svg{width:17px;height:17px;}
/* iOS: значение date-инпута прижималось вправо и вылезало за край */
.field input[type=date]{-webkit-appearance:none;appearance:none;text-align:left;min-width:0;}
.field input[type=date]::-webkit-date-and-time-value{text-align:left;}
.field-row{display:flex;gap:11px;min-width:0;}
.field-row .field{flex:1;min-width:0;}

.actions{display:flex;flex-wrap:wrap;gap:11px;margin:8px 0 28px;}
.btn{border:none;border-radius:999px;padding:15px 22px;font-size:16px;font-weight:600;cursor:pointer;font-family:inherit;letter-spacing:-0.01em;transition:transform .12s,background .15s;display:flex;align-items:center;justify-content:center;gap:8px;text-decoration:none;}
.btn:active{transform:scale(.97);}
.btn-primary{flex:1;background:linear-gradient(160deg,var(--pine),var(--pine-deep));color:#fff;box-shadow:0 5px 14px -4px rgba(44,110,73,.5);}
.btn-ghost-danger{flex:0 0 auto;padding:15px 20px;background:transparent;color:var(--danger);border:1px solid var(--danger-tint);}
.btn-ghost-danger:active{background:var(--danger-tint);}
.btn-undo{flex:0 0 auto;padding:15px 20px;background:#FBEAD2;color:#7C571E;border:1px solid #ECD4AF;}
.btn-undo:active{background:#F4DCBC;}
/* круглая иконочная кнопка (Сохранить) — только значок, без текста */
.btn-icon{flex:0 0 auto;width:54px;height:54px;padding:0;border-radius:50%;}
.btn-icon svg{width:22px;height:22px;}
.undo-cap{font-size:13px;color:var(--muted);margin:6px 4px 24px;}

.sub-h{font-size:15px;font-weight:700;margin:0 0 11px 2px;display:flex;align-items:center;gap:8px;}
.sub-h .pill{font-size:12px;font-weight:600;color:var(--muted);background:var(--line-soft);padding:2px 9px;border-radius:20px;}

.attendees{display:flex;flex-direction:column;gap:2px;background:var(--surface);border:1px solid var(--line-soft);border-radius:var(--r-md);padding:5px;margin-bottom:22px;box-shadow:var(--shadow);}
.attendee{display:flex;align-items:center;gap:10px;padding:9px 8px 9px 9px;border-radius:11px;}
.attendee + .attendee{border-top:1px solid var(--line-soft);}
.attendee .p-av .av{width:36px;height:36px;font-size:13.5px;}
.attendee-link{display:flex;align-items:center;gap:12px;flex:1;min-width:0;text-decoration:none;color:inherit;border-radius:9px;transition:background .12s;}
.attendee-link:active{background:var(--line-soft);}
.attendee-info{flex:1;min-width:0;}
.attendee-name{font-weight:600;font-size:15.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.attendee-handle{font-size:12.5px;color:var(--faint);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.remove{border:none;background:var(--line-soft);color:var(--muted);font-size:13px;font-weight:600;padding:8px 14px;border-radius:20px;cursor:pointer;font-family:inherit;transition:background .12s,color .12s;flex:0 0 auto;}
.remove:active{background:var(--danger-tint);color:var(--danger);}
.attendees-empty{padding:18px;text-align:center;color:var(--faint);font-size:14px;}

.add-block{background:var(--add-bg);border:1px solid var(--line-soft);border-radius:var(--r-md);padding:16px;}
.add-block .grp{margin-bottom:16px;}
.add-block .grp:last-child{margin-bottom:0;}
.add-block .grp-label{font-size:13px;font-weight:600;color:var(--muted);margin:0 0 9px 2px;}
.inline{display:flex;gap:9px;align-items:flex-start;}
.inline .multi-add{flex:1;min-width:0;border:1px solid var(--line);background:var(--surface);
  border-radius:13px;padding:13px 15px;font-size:15.5px;color:var(--ink);font-family:inherit;
  resize:none;line-height:1.4;min-height:48px;max-height:160px;overflow-y:auto;
  transition:border-color .15s,box-shadow .15s;}
.inline .multi-add:focus{outline:none;border-color:var(--pine);box-shadow:0 0 0 3px var(--pine-tint);}
.inline .multi-add::placeholder{color:var(--faint);}
.grp-hint{font-weight:500;color:var(--faint);font-size:12px;}
.inline input,.inline select{flex:1;min-width:0;border:1px solid var(--line);background:var(--surface);border-radius:13px;padding:13px 15px;font-size:15.5px;color:var(--ink);font-family:inherit;transition:border-color .15s,box-shadow .15s;-webkit-appearance:none;appearance:none;}
.inline select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236E726B' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:40px;}
.inline input:focus,.inline select:focus{outline:none;border-color:var(--pine);box-shadow:0 0 0 3px var(--pine-tint);}
.inline .add-go{flex:0 0 auto;border:none;border-radius:999px;padding:0 20px;cursor:pointer;background:var(--ink);color:#fff;font-size:15px;font-weight:600;font-family:inherit;display:grid;place-items:center;transition:transform .12s,opacity .15s;}
.inline .add-go.plus{width:50px;height:48px;padding:0;border-radius:50%;background:linear-gradient(160deg,var(--pine),var(--pine-deep));}
.inline .add-go.plus svg{width:21px;height:21px;}
.inline .add-go:active{transform:scale(.95);}

.quick-chips{display:flex;flex-direction:column;gap:8px;}
.chip{display:flex;align-items:center;gap:10px;width:100%;border:1px solid var(--line);background:var(--surface);border-radius:13px;padding:11px 14px;cursor:pointer;font-family:inherit;font-size:15px;font-weight:600;color:var(--ink);text-align:left;transition:border-color .14s,background .14s,transform .1s;}
.chip:active{transform:scale(.985);}
.chip:hover{border-color:color-mix(in srgb,var(--pine) 35%,var(--line));}
.chip .plus-ic{width:22px;height:22px;border-radius:7px;background:var(--pine-tint);color:var(--pine);display:grid;place-items:center;flex:0 0 auto;}
.chip .plus-ic svg{width:15px;height:15px;}
.chip .av{width:24px;height:24px;font-size:10.5px;}
.chip-name{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.chip-date{flex:0 0 auto;margin-left:8px;color:var(--faint);font-weight:500;font-size:13px;white-space:nowrap;}

/* живые подсказки под полем «Новый участник/событие» */
.suggest{list-style:none;margin:8px 0 0;padding:6px;display:flex;flex-direction:column;gap:2px;
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);
  box-shadow:var(--shadow-pop);max-height:296px;overflow:auto;}
.suggest[hidden]{display:none;}
.suggest-item{display:flex;align-items:center;gap:6px;padding:9px 10px;border-radius:11px;cursor:pointer;}
.suggest-main{flex:1;min-width:0;display:flex;align-items:center;gap:10px;}
.suggest-item .av{width:28px;height:28px;font-size:11px;}
.suggest-name{flex:1;min-width:0;font-weight:600;font-size:15px;color:var(--ink);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.suggest-hint{flex:0 0 auto;margin-left:8px;color:var(--faint);font-weight:500;font-size:13px;white-space:nowrap;}
.suggest-item.on,.suggest-item:hover{background:var(--line-soft);}
.suggest-fill{flex:0 0 auto;width:32px;height:32px;display:flex;align-items:center;justify-content:center;
  border:none;background:transparent;color:var(--muted);border-radius:9px;cursor:pointer;}
.suggest-fill svg{width:17px;height:17px;}
.suggest-fill:hover,.suggest-fill:active{background:var(--line);color:var(--ink);}

/* ---------- bottom sheet ---------- */
.scrim{position:fixed;inset:0;background:rgba(31,40,33,.32);backdrop-filter:blur(2px);z-index:50;opacity:0;pointer-events:none;transition:opacity .22s;}
.scrim.open{opacity:1;pointer-events:auto;}
.sheet{position:fixed;left:0;right:0;bottom:0;z-index:51;max-width:480px;margin:0 auto;background:var(--surface);border-radius:24px 24px 0 0;padding:8px 14px calc(20px + env(safe-area-inset-bottom));box-shadow:var(--shadow-pop);transform:translateY(110%);transition:transform .3s cubic-bezier(.2,.8,.2,1);}
.sheet.open{transform:translateY(0);}
.sheet .grab{width:38px;height:4px;border-radius:3px;background:var(--line);margin:8px auto 12px;}
.sheet-item{display:flex;align-items:center;gap:14px;padding:15px 12px;border-radius:13px;cursor:pointer;font-size:16px;font-weight:600;color:var(--ink);transition:background .12s;text-decoration:none;border:none;background:transparent;width:100%;font-family:inherit;text-align:left;}
.sheet-item:active{background:var(--line-soft);}
.sheet-item + .sheet-item{border-top:1px solid var(--line-soft);}
.sheet-item .si-ic{width:34px;height:34px;border-radius:10px;background:var(--line-soft);display:grid;place-items:center;color:var(--ink);flex:0 0 auto;}
.sheet-item .si-ic svg{width:19px;height:19px;}
.sheet-item.danger{color:var(--danger);}
.sheet-item.danger .si-ic{background:var(--danger-tint);color:var(--danger);}

/* toast */
.toast{position:fixed;left:50%;bottom:calc(28px + env(safe-area-inset-bottom));transform:translateX(-50%) translateY(20px);background:var(--toast-bg);color:#fff;padding:12px 20px;border-radius:14px;font-size:14.5px;font-weight:600;z-index:60;opacity:0;pointer-events:none;transition:opacity .25s,transform .25s;box-shadow:var(--shadow-pop);display:flex;align-items:center;gap:9px;max-width:90%;}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0);}
.toast svg{width:17px;height:17px;color:#8fd3ab;}

/* ---------- баннер «Отменить» ---------- */
.undo-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;
  margin:14px 18px 0;padding:12px 12px 12px 16px;border-radius:var(--r-md);
  background:#FBEAD2;border:1px solid #ECD4AF;box-shadow:var(--shadow);animation:fade .25s ease;}
.undo-text{font-size:14px;font-weight:600;color:#7C571E;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.undo-actions{display:flex;align-items:center;gap:6px;flex:0 0 auto;}
.undo-btn{border:none;border-radius:13px;padding:13px 20px;font-size:15.5px;font-weight:700;font-family:inherit;
  background:linear-gradient(160deg,var(--pine),var(--pine-deep));color:#fff;cursor:pointer;min-height:48px;
  box-shadow:0 4px 12px -3px rgba(44,110,73,.5);transition:transform .12s;}
.undo-btn:active{transform:scale(.96);}
.undo-x{border:none;background:transparent;color:#A9854D;font-size:15px;cursor:pointer;width:40px;height:40px;border-radius:11px;flex:0 0 auto;}
.undo-x:active{background:#F0DcC0;}

/* ---------- значок пола (кликабельный, переключается) ---------- */
.gender-ic{flex:0 0 auto;width:24px;height:24px;border-radius:50%;border:1px solid var(--line);
  background:var(--surface);cursor:pointer;display:grid;place-items:center;font-size:14px;line-height:1;
  padding:0;font-family:inherit;color:var(--muted);transition:transform .1s;}
/* значок пола — теперь картинка (inline SVG), ровно по центру кружка */
.gender-ic svg{width:60%;height:60%;display:block;}
.gender-ic:active{transform:scale(.9);}
.gender-ic.gm{color:#4F86B3;border-color:#cfe0ee;background:#eef5fb;}
.gender-ic.gf{color:#C56B8A;border-color:#f0d4de;background:#fbeef3;}
.gender-ic.gu{color:var(--faint);border-color:var(--line);background:var(--surface);}

/* имя на карточке человека: значок пола слева от поля */
.name-row{display:flex;align-items:center;gap:10px;}
.name-row .gender-ic{width:34px;height:34px;font-size:18px;}
.name-row .title-input{flex:1;min-width:0;}

/* строка списка людей: аватар + ссылка-карточка + значок пола справа */
.person-row{display:flex;align-items:center;gap:10px;padding-left:9px;padding-right:11px;border-radius:12px;}
.person-row + .person-row{border-top:1px solid var(--line-soft);}
.person-row .person{flex:1;min-width:0;}
.person-row .gender-ic,.attendee .gender-ic{margin-left:2px;}

/* ненавязчивый индикатор автосохранения */
.save-flag{position:fixed;left:50%;bottom:calc(28px + env(safe-area-inset-bottom));
  transform:translateX(-50%) translateY(16px);background:var(--toast-bg);color:#fff;padding:8px 16px;
  border-radius:12px;font-size:13px;font-weight:600;z-index:55;opacity:0;pointer-events:none;
  transition:opacity .2s,transform .2s;box-shadow:var(--shadow-pop);}
.save-flag.show{opacity:.92;transform:translateX(-50%) translateY(0);}

@media (prefers-reduced-motion:reduce){*{animation-duration:.001s !important;transition-duration:.01s !important;}}
:focus-visible{outline:2.5px solid var(--pine);outline-offset:2px;border-radius:6px;}

/* ---------- экран входа ---------- */
.login{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;
  padding:24px;background:radial-gradient(125% 80% at 50% -10%,var(--pine-tint) 0%,transparent 55%),var(--paper);}
.login-card{width:100%;max-width:380px;background:var(--surface);border:1px solid var(--line-soft);
  border-radius:24px;box-shadow:var(--shadow-pop);padding:38px 28px 30px;text-align:center;}
.login-logo{width:66px;height:66px;border-radius:20px;margin:0 auto 18px;
  background:linear-gradient(150deg,var(--pine),var(--pine-deep));display:grid;place-items:center;
  color:#fff;box-shadow:0 12px 26px -8px rgba(44,110,73,.6);}
.login-logo svg{width:34px;height:34px;}
.login-title{margin:0;font-size:30px;font-weight:800;color:var(--ink);}
.login-sub{margin:7px 0 26px;color:var(--muted);font-size:14.5px;}
.login-form{display:flex;flex-direction:column;gap:12px;text-align:left;}
.login-input{width:100%;border:1px solid var(--line);background:var(--paper);border-radius:14px;
  padding:15px 16px;font-size:16px;color:var(--ink);font-family:inherit;transition:border-color .15s,box-shadow .15s;}
.login-input::placeholder{color:var(--faint);}
.login-input:focus{outline:none;border-color:var(--pine);box-shadow:0 0 0 3px var(--pine-tint);}
.login-btn{width:100%;border:none;border-radius:14px;padding:15px;font-size:16px;font-weight:700;
  font-family:inherit;cursor:pointer;color:#fff;letter-spacing:-0.01em;
  background:linear-gradient(160deg,var(--pine),var(--pine-deep));
  box-shadow:0 9px 20px -6px rgba(44,110,73,.55);transition:transform .12s,opacity .15s;}
.login-btn:active{transform:scale(.985);}
.login-btn:disabled{opacity:.65;cursor:default;}
.login-error{color:var(--danger);font-size:13.5px;font-weight:600;text-align:center;margin:2px 0 -2px;}

/* ---- Окно подбора участников (RosterReview) — оверлей на .scrim/.sheet ---- */
.roster-sheet{max-height:82vh;display:flex;flex-direction:column;}
.roster-head{display:flex;align-items:baseline;justify-content:space-between;gap:10px;padding:2px 6px 10px;}
.roster-title{font-size:18px;font-weight:700;color:var(--ink);font-family:"Bricolage Grotesque";}
.roster-sub{font-size:13px;color:var(--muted);font-weight:600;flex:0 0 auto;}
.roster-list{overflow:auto;display:flex;flex-direction:column;gap:2px;-webkit-overflow-scrolling:touch;}
.roster-row{display:flex;align-items:center;gap:9px;padding:8px 6px;border-radius:11px;min-height:52px;}
.roster-row + .roster-row{border-top:1px solid var(--line-soft);}
.roster-row.skipped{opacity:.42;}
.roster-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px;}
.roster-name{font-weight:600;font-size:15px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.roster-from{font-size:12px;color:var(--faint);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.roster-input{width:100%;border:1px solid var(--line);background:var(--surface);border-radius:10px;padding:8px 11px;font-size:15px;color:var(--ink);font-family:inherit;-webkit-appearance:none;appearance:none;}
.roster-input:focus{outline:none;border-color:var(--pine);box-shadow:0 0 0 3px var(--pine-tint);}
.roster-badge{flex:0 0 auto;font-size:11px;font-weight:700;color:var(--pine);background:var(--pine-tint);border-radius:8px;padding:3px 7px;}
.roster-select{max-width:100%;font-weight:600;font-size:15px;color:var(--ink);font-family:inherit;border:1px solid var(--line);background:var(--surface);border-radius:10px;padding:6px 26px 6px 9px;-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23999' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 7px center;background-size:14px;}
.roster-select:focus{outline:none;border-color:var(--pine);box-shadow:0 0 0 3px var(--pine-tint);}
.roster-ic{flex:0 0 auto;width:36px;height:36px;padding:0;border:1px solid var(--line);background:var(--surface);border-radius:10px;display:grid;place-items:center;color:var(--muted);cursor:pointer;transition:transform .1s,background .12s,color .12s,border-color .12s;}
.roster-ic svg{width:19px;height:19px;}
.roster-ic:active{transform:scale(.9);}
.roster-ic.on{background:var(--pine-tint);border-color:var(--pine-tint);color:var(--pine);}
.roster-foot{display:flex;gap:10px;justify-content:flex-end;padding:12px 6px 2px;}
.roster-ic.big{width:52px;height:52px;border-radius:50%;border:none;}
.roster-ic.big svg{width:23px;height:23px;}
.roster-ic.big.cancel{background:var(--line-soft);color:var(--muted);}
.roster-ic.big.go{background:linear-gradient(160deg,var(--pine),var(--pine-deep));color:#fff;box-shadow:0 4px 12px -3px rgba(44,110,73,.55);}
