/* Комната проектов — room_next.css · стиль C. Адрес /glava/room/next.
   Линкуется ПОСЛЕ cockpit_next.css (берёт оттуда токены, .topbar, .pill-btn,
   .status-pill, .card-glyph). Здесь — только специфика Комнаты. */

.room-head{ margin-top:var(--sp-5); margin-bottom:var(--sp-4); }
.room-head h1{ font-size:20px; font-weight:700; color:var(--text-strong); margin:0; letter-spacing:.01em; }
.room-head p{ font-size:13px; color:var(--text-muted); margin:6px 0 0; }

.room-grid{ display:grid; grid-template-columns:1fr; gap:var(--sp-4); }
@media (min-width:720px){ .room-grid{ grid-template-columns:repeat(2,1fr); } }
@media (min-width:1180px){ .room-grid{ grid-template-columns:repeat(3,1fr); } }

.room-card{ position:relative; display:flex; flex-direction:column; border:1px solid var(--border);
  border-radius:var(--r-lg); background:linear-gradient(180deg,var(--c-850),var(--c-900));
  overflow:hidden; box-shadow:var(--shadow-tile); transition:border-color .2s var(--ease), transform .2s var(--ease); }
.room-card:hover{ border-color:var(--border-strong); }
.room-card::before{ content:""; position:absolute; left:0; top:0; right:0; height:2px;
  background:linear-gradient(90deg,var(--acc),transparent 80%); opacity:.7; }

.room-card-head{ display:flex; align-items:flex-start; gap:11px; padding:var(--sp-4) var(--sp-4) var(--sp-3); }
.room-card-titles{ min-width:0; flex:1; }
.room-card-title{ font-size:15.5px; font-weight:600; color:var(--text-strong); line-height:1.2; }
.room-card-tag{ font-size:12px; color:var(--text-muted); margin-top:3px; }

/* живое превью */
.room-preview{ position:relative; margin:0 var(--sp-4); height:188px; border-radius:var(--r-md);
  overflow:hidden; border:1px solid var(--border-soft); background:var(--bg-inset); cursor:pointer; }
.room-preview .ph{ position:absolute; inset:0; display:grid; place-items:center; gap:8px; color:var(--text-faint);
  font-size:12px; padding:16px; text-align:center; }
.room-frame{ position:absolute; top:0; left:0; width:1400px; height:900px; border:0;
  transform:scale(.30); transform-origin:top left; pointer-events:none; background:#fff; }
.room-preview .hoverhint{ position:absolute; inset:0; display:grid; place-items:center; opacity:0;
  background:linear-gradient(180deg,rgba(8,9,11,.1),rgba(8,9,11,.55)); transition:opacity .2s var(--ease); }
.room-preview:hover .hoverhint{ opacity:1; }
.room-preview .hoverhint span{ display:inline-flex; align-items:center; gap:7px; font-size:12.5px; font-weight:600;
  color:var(--text-strong); padding:8px 14px; border-radius:var(--r-pill);
  background:rgba(13,14,17,.78); border:1px solid var(--border-strong); }

/* лёгкая заглушка превью на телефоне (без live-iframe) */
.room-ph-static{ position:absolute; inset:0; display:grid; place-items:center; align-content:center; gap:9px;
  background:radial-gradient(120% 120% at 50% 0%, color-mix(in srgb,var(--acc) 8%,transparent), transparent 60%); }
.room-ph-static .lk-glyph{ width:44px;height:44px;border-radius:13px; display:grid; place-items:center;
  background:color-mix(in srgb,var(--acc) 14%,var(--c-800)); border:1px solid color-mix(in srgb,var(--acc) 30%,transparent); color:var(--acc); }
.room-ph-t{ font-size:13px; font-weight:600; color:var(--text-strong); }
.room-ph-s{ font-size:11px; color:var(--text-faint); }

/* для preview=link — статичная заглушка-кнопка */
.room-linkbox{ margin:0 var(--sp-4); height:188px; border-radius:var(--r-md); border:1px dashed var(--border);
  background:var(--bg-inset); display:grid; place-items:center; gap:10px; text-align:center; padding:18px; }
.room-linkbox .lk-glyph{ width:42px;height:42px;border-radius:12px; display:grid; place-items:center;
  background:color-mix(in srgb,var(--acc) 14%,var(--c-800)); border:1px solid color-mix(in srgb,var(--acc) 30%,transparent); color:var(--acc); }
.room-linkbox .lk-t{ font-size:12.5px; color:var(--text-muted); }

/* preview=image — статичная картинка (напр. замороженный проект) */
.room-preview--img{ cursor:default; }
.room-img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; display:block; }

.room-bullets{ list-style:none; margin:var(--sp-4) 0 0; padding:0 var(--sp-4); display:flex; flex-direction:column; gap:7px; }
.room-bullets li{ display:flex; align-items:flex-start; gap:8px; font-size:12.5px; color:var(--text-muted); }
.room-bullets li .bd{ width:5px;height:5px;border-radius:50%; background:var(--acc); margin-top:6px; flex:0 0 auto; opacity:.8; }

.room-foot{ display:flex; align-items:center; gap:var(--sp-2); margin-top:auto; padding:var(--sp-4);
  padding-top:var(--sp-3); }
.room-foot .grow{ flex:1; }
.room-btn-sm{ display:inline-flex; align-items:center; gap:6px; font-size:12px; font-weight:500; cursor:pointer;
  color:var(--text); text-decoration:none; padding:7px 12px; border-radius:var(--r-pill);
  background:var(--bg-raised); border:1px solid var(--border); transition:border-color .18s var(--ease), color .18s var(--ease); }
.room-btn-sm:hover{ border-color:var(--border-strong); color:var(--text-strong); }
.room-btn-sm svg{ color:var(--text-muted); }
.room-btn-primary{ color:var(--text-strong); background:color-mix(in srgb,var(--acc) 12%,var(--c-800)); border-color:color-mix(in srgb,var(--acc) 30%,transparent); }
.room-btn-primary svg{ color:var(--acc); }

/* статус-точка живости (health) */
.room-live{ display:inline-flex; align-items:center; gap:6px; font-size:10.5px; font-weight:600; letter-spacing:.06em;
  text-transform:uppercase; padding:4px 9px 4px 8px; border-radius:var(--r-pill); flex:0 0 auto; white-space:nowrap; }
.room-live .d{ width:6px;height:6px;border-radius:50%; }
.room-live.up{ color:var(--s-live); background:color-mix(in srgb,var(--s-live) 10%,transparent); border:1px solid color-mix(in srgb,var(--s-live) 24%,transparent); }
.room-live.up .d{ background:var(--s-live); box-shadow:0 0 6px var(--s-live); }
.room-live.down{ color:var(--s-cold); background:color-mix(in srgb,var(--s-cold) 12%,transparent); border:1px solid color-mix(in srgb,var(--s-cold) 22%,transparent); }
.room-live.down .d{ background:var(--s-cold); }
.room-live.unknown{ color:var(--text-faint); background:var(--c-800); border:1px solid var(--border); }
.room-live.unknown .d{ background:var(--text-ghost); }

/* модалка на весь экран */
.room-modal{ position:fixed; inset:0; z-index:90; display:none; }
.room-modal.open{ display:block; }
.room-modal-back{ position:absolute; inset:0; background:rgba(0,0,0,.7); backdrop-filter:blur(4px); }
.room-modal-panel{ position:absolute; inset:18px; border-radius:var(--r-lg); overflow:hidden; display:flex; flex-direction:column;
  background:var(--c-900); border:1px solid var(--border-strong); box-shadow:var(--shadow-float); }
.room-modal-bar{ display:flex; align-items:center; gap:10px; padding:11px var(--sp-4); border-bottom:1px solid var(--border-soft);
  background:var(--bg-chrome); }
.room-modal-bar .mt{ font-size:13.5px; font-weight:600; color:var(--text-strong); }
.room-modal-bar .grow{ flex:1; }
.room-modal-frame{ flex:1; width:100%; border:0; background:#fff; }

/* 🟥 бейдж заявок от Анны на карточке + модалка списка */
.room-task-badge{ flex:0 0 auto; min-width:22px; height:22px; padding:0 6px; border-radius:11px;
  background:#e5484d; color:#fff; font-size:12px; font-weight:800; border:none; cursor:pointer;
  display:inline-flex; align-items:center; justify-content:center;
  box-shadow:0 0 0 3px color-mix(in srgb,#e5484d 22%,transparent);
  animation:taskpulse 1.6s ease-in-out infinite; }
.room-task-badge:hover{ background:#ff5c61; }
@keyframes taskpulse{ 0%,100%{ transform:scale(1); } 50%{ transform:scale(1.13); } }

.tasks-modal{ position:fixed; inset:0; z-index:95; display:none; }
.tasks-modal.open{ display:block; }
.tasks-back{ position:absolute; inset:0; background:rgba(0,0,0,.7); backdrop-filter:blur(4px); }
.tasks-panel{ position:absolute; left:50%; top:50%; transform:translate(-50%,-50%);
  width:min(560px,92vw); max-height:84vh; display:flex; flex-direction:column; overflow:hidden;
  border-radius:var(--r-lg); background:var(--c-900); border:1px solid var(--border-strong); box-shadow:var(--shadow-float); }
.tasks-bar{ display:flex; align-items:center; gap:10px; padding:12px var(--sp-4); border-bottom:1px solid var(--border-soft); background:var(--bg-chrome); }
.tasks-title{ font-size:14px; font-weight:700; color:var(--text-strong); }
.tasks-bar .grow{ flex:1; }
.tasks-list{ overflow-y:auto; padding:var(--sp-4); display:flex; flex-direction:column; gap:10px; }
.tasks-empty{ color:var(--text-muted); font-size:13px; text-align:center; padding:20px; }
.task-item{ background:var(--bg-raised); border:1px solid var(--border); border-radius:12px; padding:12px; }
.task-head{ display:flex; align-items:center; gap:8px; margin-bottom:6px; }
.task-title{ font-size:13.5px; font-weight:700; color:var(--text-strong); }
.task-st{ font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.04em; padding:3px 7px; border-radius:var(--r-pill); white-space:nowrap; }
.task-st-new{ color:#ff8a8f; background:color-mix(in srgb,#e5484d 16%,transparent); }
.task-st-prog{ color:#f5c451; background:color-mix(in srgb,#f5c451 16%,transparent); }
.task-st-done{ color:var(--s-live); background:color-mix(in srgb,var(--s-live) 14%,transparent); }
.task-details{ font-size:12.5px; color:var(--text); line-height:1.5; }
.task-ex{ font-size:12px; color:var(--text-muted); margin-top:5px; font-style:italic; }
.task-meta{ font-size:11px; color:var(--text-faint); margin-top:7px; }
.task-act{ display:flex; gap:7px; margin-top:9px; }
.task-btn{ font-size:11.5px; font-weight:600; cursor:pointer; padding:6px 11px; border-radius:var(--r-pill);
  color:var(--text); background:var(--bg-raised); border:1px solid var(--border); }
.task-btn:hover{ border-color:var(--border-strong); color:var(--text-strong); }
.task-btn-done{ color:#7ee0a6; border-color:color-mix(in srgb,var(--s-live) 30%,transparent);
  background:color-mix(in srgb,var(--s-live) 10%,transparent); }
.task-btn-copy{ color:var(--text-strong); border-color:color-mix(in srgb,var(--acc) 36%,transparent);
  background:color-mix(in srgb,var(--acc) 16%,var(--c-800)); font-weight:700; }
.task-btn-copy:hover{ border-color:var(--acc); background:color-mix(in srgb,var(--acc) 24%,var(--c-800)); }
.room-modal-close{ width:32px;height:32px;border-radius:9px; cursor:pointer; display:grid; place-items:center;
  color:var(--text-muted); background:var(--c-800); border:1px solid var(--border); }
