
*,
*::before,
*::after{
  box-sizing: border-box;
}

html, body{
  height:100%;
}

body{
  margin:0;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  background: var(--bg);
  color: var(--text);
  line-height: 1.5;
}

/* =========================================================
   DOMAIN 2 — SHELL
   ========================================================= */

.header{
  position: sticky;
  top:0;
  z-index: 100;
  background: var(--panel);
  border-bottom: 1px solid var(--border);
}

.header-inner{
  max-width: 1200px;
  margin: 0 auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding:16px;
}

.brand{
  display:flex;
  align-items:center;
  gap:10px;
  min-width:0;
}

.logo-img{
  height:34px;
  width:auto;
  object-fit:contain;
  display:block;
  flex:0 0 auto;
}

.brand h1{
  margin:0;
  font-size:14px;
  line-height:1.1;
  letter-spacing:.4px;
  min-width:0;
  color: var(--text);
}

.brand small{
  display:block;
  margin-top:2px;
  font-size:12px;
  line-height:1.3;
  color:var(--muted);
}

.header-inner > div:last-child{
  display:flex;
  gap:10px;
  align-items:center;
}

.search{
  position:relative;
  flex:1;
  max-width:520px;
  min-height:42px;
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 12px;
  padding-right:56px;
  border-radius:14px;
  background: var(--panel);
  border: 1px solid var(--border);
}

.search input{
  width:100%;
  min-width:0;
  border:none;
  outline:none;
  background:transparent;
  color:var(--text);
  font-size:14px;
  line-height:1.2;
}

.search .pill{
  position:absolute;
  right:10px;
  top:50%;
  transform:translateY(-50%);
  margin:0;
  padding:3px 7px;
  font-size:10px;
  line-height:1.1;
  white-space:nowrap;
}

.header .pill:not(.auth-role){
  font-size:11px;
  padding:4px 8px;
}

#authArea{
  display:flex;
  align-items:center;
  gap:8px;
  flex:0 0 auto;
}

.auth-group{
  display:flex;
  align-items:center;
  gap:8px;
}

.auth-role{
  min-height:32px;
  padding:0 12px;
  border-radius:999px;
  border:1px solid var(--border);
  background: transparent;
  color: var(--muted);
  font-size:12px;
  line-height:1;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  white-space:nowrap;
  flex:0 0 auto;
}

.auth-push,
#pushBtn.push-icon-btn{
  width:32px;
  min-width:32px;
  height:32px;
  min-height:32px;
  padding:0;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  line-height:1;
  flex:0 0 auto;
}

.push-icon-btn {
  opacity: 0;
  transition: opacity 0.15s ease;
}

.push-icon-btn.is-ready {
  opacity: 1;
}

.auth-push svg,
#pushBtn.push-icon-btn svg{
  width:14px;
  height:14px;
  display:block;
  flex:0 0 auto;
}

#pushBtn.push-icon-btn.is-on{
  color:#FFF3EA;
  background: var(--accent);
  border-color: transparent;
  box-shadow: 0 0 0 1px var(--accent-12);
}

#pushBtn.push-icon-btn.is-on:hover{
  filter:brightness(1.04);
}

#pushBtn.push-icon-btn.is-off{
  color: var(--muted);
  background: transparent;
  border-color: var(--border);
}

#pushBtn.push-icon-btn.is-off:hover{
  color: var(--text);
  border-color: var(--accent-35);
  background: color-mix(in srgb, var(--card) 86%, var(--accent-08));
}

.auth-logout{
  min-height:32px;
  padding:7px 12px;
  border-radius:12px;
  line-height:1.2;
  flex:0 0 auto;
}

#authArea .btn,
#authArea button,
#authArea .pill,
#pushBtn{
  min-height:32px;
}

#authArea .btn,
#authArea button{
  padding:7px 10px;
}

.header-meta{
  display:flex;
  gap:10px;
  align-items:center;
}

.header-meta .auth-role,
#authArea .auth-role{
  border:none;
  background:none;
  box-shadow:none;
}

#pushBtn.push-icon-btn{
  opacity:0;
  transition:
    opacity .14s ease,
    border-color .16s ease,
    background-color .16s ease,
    color .16s ease,
    box-shadow .16s ease,
    filter .16s ease;
}

#pushBtn.push-icon-btn.is-ready{
  opacity:1;
}

.footer{
  padding:12px 16px;
  text-align:center;
  font-size:12px;
  color:var(--muted);
}

/* =========================================================
   DOMAIN 3 — LAYOUT
   ========================================================= */
   
.main{
  display:grid;
  grid-template-columns: 340px 1fr;
  gap:16px;
  padding:50px 16px 16px 16px;
  height: calc(100vh - 80px);
  max-width:1200px;
  margin:0 auto;
}

.panel{
  display:flex;
  flex-direction:column;
  background: var(--panel);
  border:1px solid var(--border);
  border-radius:16px;
  overflow:hidden;
}

.viewer{
  display:flex;
  flex-direction:column;
  gap:16px;
  padding:20px;
  background: var(--panel);
  border:1px solid var(--border);
  border-radius:16px;
  overflow:auto;
  min-height:0;
  box-shadow:
    0 10px 28px rgba(0,0,0,.22);
}

.zr-board-screen{
  display:grid;
  grid-template-rows:auto minmax(0,1fr);
  gap:0;
  width:100%;
  min-height:0;
}

#list{
  overflow:auto;
  flex:1;
}

#viewer{
  height:100%;
}
/* =========================================================
   DOMAIN 4 — SHARED CONTROLS
   ========================================================= */

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;

  min-height:36px;
  padding:8px 14px;

  border-radius:12px;
  border:1px solid var(--border);

  background: var(--card);
  color: var(--text);

  font-size:13px;
  font-weight:500;

  cursor:pointer;
  line-height:1.2;
  text-decoration:none;

  transition:
    border-color .16s ease,
    background-color .16s ease,
    box-shadow .16s ease,
    color .16s ease,
    transform .06s ease;
}

/* hover */
.btn:hover{
  border-color: var(--accent-35);
  background: color-mix(in srgb, var(--card) 82%, var(--accent-08));
}

/* active
.btn:active{
  transform: translateY(1px);
}

/* focus */
.btn:focus,
.btn:focus-visible{
  outline:none;
  border-color: var(--accent-55);
  box-shadow: 0 0 0 3px var(--accent-12);
}

/* PRIMARY */
.btn--primary{
  background: var(--accent);
  border-color: transparent;
  color:#fff;
  font-weight:600;
}

.btn--primary:hover{
  filter:brightness(1.05);
}

/* GHOST */
.btn--ghost{
  background: transparent;
  border-color: transparent;
  color: var(--muted);
}

.btn--ghost:hover{
  color: var(--text);
  background: var(--accent-08);
}

/* DANGER */
.btn--danger{
  background: rgba(255,120,80,.12);
  border-color: rgba(255,120,80,.28);
}

.btn--danger:hover{
  background: rgba(255,120,80,.18);
}

.tab{
  appearance:none;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:100%;
  min-width:0;
  min-height:38px;
  padding:9px 14px;
  border-radius:14px;
  border:1px solid transparent;
  background: rgba(255,243,234,.035);
  color: var(--text);
  cursor:pointer;
  line-height:1.15;
  text-align:center;
  white-space:nowrap;
  box-shadow:
    0 1px 0 rgba(255,243,234,.012),
    0 4px 10px rgba(0,0,0,.18);
  transition:
    background-color .16s ease,
    border-color .16s ease,
    box-shadow .16s ease,
    color .16s ease,
    opacity .16s ease;
}

.tab:hover{
  background: rgba(255,243,234,.05);
  border-color: rgba(255,243,234,.035);
  box-shadow:
    0 1px 0 rgba(255,243,234,.018),
    0 6px 14px rgba(0,0,0,.18);
}

.tab:focus,
.tab:focus-visible{
  outline:none;
  border-color: var(--accent-55);
  box-shadow:
    0 0 0 3px var(--accent-12),
    0 6px 14px rgba(0,0,0,.18);
}

.tab.is-active,
.tab.active{
  background: rgba(255,243,234,.07);
  border-color: var(--accent-35);
  box-shadow:
    0 0 0 1px var(--accent-12),
    0 6px 16px rgba(0,0,0,.20);
}

#tabs{
  display:flex;
  align-items:center;
  justify-content:center;
  align-content:flex-start;
  gap:10px;
  padding:14px 16px 16px 16px;
  margin:0 0 14px 0;
  background: color-mix(in srgb, var(--panel) 88%, var(--card) 12%);
  border:1px solid var(--border);
  border-radius:0;
  box-shadow:
    inset 0 1px 0 rgba(255,243,234,.02),
    0 8px 20px rgba(0,0,0,.12);
  flex-wrap:wrap;
}

#tabs > .tab{
  width:auto;
  min-width:0;
  flex:0 1 calc(50% - 5px);
  max-width:220px;
}

#tabs > .tab:first-child{
  flex:0 0 100%;
  max-width:none;
}

#tabs > .tab:hover{
  color:var(--headings);
  background:rgba(255,243,234,.05);
  border-color:rgba(255,243,234,.09);
  box-shadow:
    0 1px 0 rgba(255,243,234,.025),
    0 8px 18px rgba(0,0,0,.14);
  transform:translateY(-1px);
}

#panelTitle{
  display:none;
}

.pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:24px;
  padding:4px 8px;
  font-size:12px;
  line-height:1.2;
  border-radius:999px;
  border:0;
  background: rgba(255,243,234,.05);
  box-shadow:
    0 1px 0 rgba(255,243,234,.02),
    0 4px 10px rgba(0,0,0,.16);
  color: var(--muted);
  user-select:none;
}

.panel-head{
  padding:10px 12px 8px 12px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:8px;
  border-bottom:1px solid var(--border);
}

.panel-head h2{
  margin:0;
  font-size:13px;
  line-height:1.2;
  letter-spacing:.3px;
  color:var(--muted);
  text-transform:uppercase;
}

input,
textarea,
select{
  font: inherit;
}

/* =========================================================
   DOMAIN 5 — CONTENT SURFACES
   ========================================================= */
   
   /* generic content card */
.zr-card{
  background: var(--card);
  border-radius: 12px;
  padding:16px;
}

/* section variants */
.zr-card--section{
  background: var(--card);
}

.zr-card--subtle{
  background: var(--item);
}

/* section header */
.zr-section-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom:10px;
}

.zr-section-title{
  font-size:11px;
  line-height:1.15;
  font-weight:600;
  letter-spacing:.05em;
  text-transform:uppercase;
  color: color-mix(in srgb, var(--muted) 88%, transparent);
}

.zr-viewer-title-row{
  display:block;
  min-width:0;
}

.article-sub{
  margin:0;
  font-size:11px;
  line-height:1.2;
  color: var(--muted);
  white-space:nowrap;
}

.zr-viewer-header-row{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  grid-template-areas:
    ". actions"
    "main main";
  align-items:start;
  gap:14px 16px;
}

.zr-viewer-header-main{
  grid-area:main;
  min-width:0;
  display:flex;
  flex-direction:column;
  gap:8px;
}

.zr-viewer-header-actions{
  grid-area:actions;
  display:flex;
  align-items:flex-start;
  justify-content:flex-end;
  gap:8px;
  flex-wrap:wrap;
  align-self:start;
}

/* text content */
.zr-planner-body-text{
  font-size:14px;
  line-height:1.5;
  color: var(--text);
}

/* muted text */
.zr-planner-muted{
  opacity:.6;
  font-size:13px;
}

/* markdown / article baseline */
.markdown{
  font-size:15px;
  line-height:1.72;
}

.markdown h1,
.markdown h2,
.markdown h3{
  margin-bottom:.4em;
}

.markdown h2{
  margin-top:28px;
  margin-bottom:12px;
  font-size:18px;
}

.markdown h3{
  margin-top:22px;
  margin-bottom:10px;
  font-size:15px;
}

.markdown p{
  margin:0 0 14px 0;
}

.markdown ul{
  padding-left:18px;
}

.markdown li + li{
  margin-top:6px;
}

.markdown code{
  background: var(--surface-soft);
  padding:2px 4px;
  border-radius:4px;
}

.viewer > *{
  min-width:0;
}

.article-layout,
.zr-planner-detail,
.zr-planner-grid,
.zr-planner-maincol,
.zr-planner-sidecol,
.zr-planner-logcol{
  min-width:0;
}

.article-layout{
  display:grid;
  grid-template-columns:minmax(0, 1fr) 260px;
  gap:18px;
  align-items:start;
}

.article-main{
  min-width:0;
}

.article-toc{
  position:sticky;
  top:12px;
  align-self:start;
  padding:12px;
  border-radius:14px;
  border:1px solid var(--border);
  background: var(--item);
  overscroll-behavior: contain;
}

.article-toc-title{
  margin:0 0 10px 0;
  font-size:12px;
  line-height:1.2;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--muted);
}

.article-toc a{
  display:block;
  padding:8px 10px;
  border-radius:10px;
  border:1px solid transparent;
  text-decoration:none;
  color:var(--muted);
  font-size:12px;
  line-height:1.35;
  touch-action:manipulation;
  -webkit-tap-highlight-color:transparent;
  transition:
    border-color .16s ease,
    background-color .16s ease,
    color .16s ease;
}

.article-toc a:hover{
  color:var(--text);
  border-color:var(--border);
}

.article-toc a.is-active{
  color:var(--accent-95);
  background:var(--accent-08);
  border-color:var(--accent-35);
}

#plActivity{
  max-height:132px;
  overflow:auto;
  padding-right:4px;
}

/* === EMPTY STATE (planner / lists) === */

.empty{
  padding: 28px 24px;
  margin: 40px auto;

  max-width: 520px;

  border-radius: 16px;
  border: 1px solid rgba(255,255,255,0.06);
  background: rgba(255,255,255,0.025);

  text-align: center;
}

.empty h2{
  margin-bottom: 10px;
}

.empty p{
  margin: 6px 0;
  color: var(--muted);
}

/* === PLANNER DETAIL: activity scrollbar polish === */

#plActivity{
  scrollbar-width:thin;
  scrollbar-color:rgba(255,243,234,.22) transparent;
}

/* Chrome / Edge / Safari */
#plActivity::-webkit-scrollbar{
  width:6px;
}

#plActivity::-webkit-scrollbar-track{
  background:transparent;
}

#plActivity::-webkit-scrollbar-thumb{
  background:rgba(255,243,234,.18);
  border-radius:6px;
}

#plActivity::-webkit-scrollbar-thumb:hover{
  background:rgba(255,243,234,.32);
}

#plActivity .zr-planner-activity{
  display:flex;
  flex-direction:column;
  gap:4px;
}

#plActivity .zr-card.zr-card--row.zr-planner-activity-row{
  display:grid;
  grid-template-columns:auto minmax(0,1fr);
  gap:8px;
  align-items:start;
  padding:7px 0;
  background:transparent;
  border:0;
  border-radius:0;
  box-shadow:none;
}

#plActivity .zr-card.zr-card--row.zr-planner-activity-row + .zr-card.zr-card--row.zr-planner-activity-row{
  border-top:1px solid rgba(255,243,234,.04);
}

#plActivity .zr-planner-activity-time{
  font-size:10px;
  line-height:1.25;
  color:var(--muted);
  white-space:nowrap;
}

#plActivity .zr-planner-activity-text{
  font-size:11px;
  line-height:1.4;
  color: color-mix(in srgb, var(--muted) 82%, var(--text) 18%);
}

@media (max-width: 960px){
  .article-layout{
    grid-template-columns:1fr;
  }

  .article-toc{
    position:relative;
    top:0;
  }
}

.zr-stack-md{
  display:flex;
  flex-direction:column;
  gap:10px;
}

.zr-stack-sm{
  display:flex;
  flex-direction:column;
  gap:6px;
}

.zr-stack-lg{
  display:flex;
  flex-direction:column;
  gap:12px;
}

.zr-viewer-shell{
  width:100%;
}

.zr-editorial-body{
  width:100%;
}

.zr-editorial-body > :first-child{
  margin-top:0;
}

.zr-editorial-body > :last-child{
  margin-bottom:0;
}

.zr-admin-editor{
  width:100%;
}

.zr-admin-mode-tabs{
  display:flex;
  align-items:flex-start;
  flex-wrap:wrap;
  gap:8px;
  min-height:0;
  padding:0;
  margin:0;
  border-radius:0;
  background:transparent;
  border:none;
}

.zr-admin-content-tabs{
  display:none;
  margin-top:-2px;
  padding:8px 6px 5px 14px;
  border-radius:0 0 12px 12px;
  background:rgba(255,243,234,.018);
}

.zr-admin-editor__hero{
  padding:12px 14px;
}

.zr-admin-editor__hero-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:8px;
  flex-wrap:wrap;
}

.zr-admin-editor__hero-main{
  flex:1 1 320px;
  min-width:0;
}

.zr-admin-editor__hero-meta{
  display:flex;
  align-items:center;
  gap:6px;
  flex-wrap:wrap;
  min-height:20px;
}

.zr-admin-editor__section{
  padding:10px 12px;
}

.zr-admin-editor__grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:8px 10px;
  align-items:start;
}

.zr-admin-editor__field{
  min-width:0;
  display:flex;
  flex-direction:column;
  gap:3px;
}

.zr-admin-editor__field--full{
  grid-column:1 / -1;
}

.zr-admin-editor__field-label{
  display:block;
  margin:0 0 2px 2px;
  font-size:11px;
  line-height:1.2;
  font-weight:600;
  color:var(--text);
}

.zr-admin-editor__field-help{
  margin-top:4px;
  padding-left:2px;
  font-size:11px;
  line-height:1.3;
}

.zr-admin-editor__id-row{
  display:grid;
  grid-template-columns:minmax(0,1fr) 170px;
  gap:8px;
  align-items:end;
}

.zr-admin-editor__choice-row{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  padding:4px 0 0 2px;
}

.zr-admin-editor__content{
  min-height:180px;
}

.zr-admin-editor__actions{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:8px;
  flex-wrap:wrap;
}

.zr-admin-editor__actions .btn:last-child{
  background:rgba(210,120,90,.14);
  border-color:rgba(210,120,90,.28);
}

.zr-admin-editor__tags-meta{
  margin-top:6px;
  font-size:11px;
  line-height:1.3;
}

.zr-admin-checklist-items{
  display:flex;
  flex-direction:column;
  gap:8px;
}

.zr-admin-checklist-items__list{
  display:flex;
  flex-direction:column;
  gap:8px;
}

.zr-admin-checklist-item{
  display:grid;
  grid-template-columns:24px minmax(0,1fr) auto;
  gap:8px;
  align-items:start;
  padding:8px 10px;
  border:1px solid rgba(255,243,234,.08);
  border-radius:12px;
  background:rgba(255,243,234,.025);
}

.zr-admin-checklist-item__index{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:34px;
  font-size:11px;
  line-height:1;
  font-weight:600;
  color:var(--muted);
}

.zr-admin-checklist-item__actions{
  display:flex;
  align-items:center;
  gap:6px;
  min-height:34px;
}

.zr-admin-checklist-empty{
  padding:10px 12px;
  border:1px dashed rgba(255,243,234,.10);
  border-radius:12px;
  color:var(--muted);
  background:rgba(255,243,234,.02);
}

@media (max-width: 860px){
  .zr-admin-editor__grid{
    grid-template-columns:1fr;
  }

  .zr-admin-editor__id-row{
    grid-template-columns:1fr;
  }

  .zr-admin-checklist-item{
    grid-template-columns:24px minmax(0,1fr);
  }

  .zr-admin-checklist-item__actions{
    grid-column:2;
    justify-content:flex-end;
  }
}

/* === ADMIN: article excerpt clamp === */

.zr-excerpt{
  margin-top:4px;

  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;

  overflow:hidden;
}

/* =========================================================
   DOMAIN 6 — PLANNER LEFT
   ========================================================= */

#plLeftList,
#list{
  display:flex;
  flex-direction:column;
  gap:8px;
  padding:6px 10px 10px 10px;
}

#list > .actions{
  padding:0;
  margin:0;
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  background:transparent;
  border:none;
}

#list .actions{
  background:transparent;
  border:none;
}

.zr-admin-mode-tabs .btn,
.zr-admin-list-tools .btn{
  flex:0 0 auto;
  min-height:30px;
  padding:4px 8px;
  border-radius:10px;
  font-size:12px;
  line-height:1.2;
}

.item,
.zr-list-row{
  display:block;
  min-width:0;
  padding:12px 13px;
  border:1px solid transparent;
  border-radius:14px;
  background: rgba(42,40,38,.88);
  color: var(--text);
  text-decoration:none;
  box-shadow:
    0 1px 0 rgba(255,243,234,.012),
    0 10px 24px rgba(0,0,0,.18);
  transition:
    background-color .12s ease,
    border-color .12s ease,
    box-shadow .12s ease,
    opacity .12s ease,
    color .12s ease;
}

.item:hover,
.zr-list-row:hover{
  background: rgba(48,46,43,.92);
  border-color: rgba(255,243,234,.04);
  box-shadow:
    0 1px 0 rgba(255,243,234,.018),
    0 12px 28px rgba(0,0,0,.22);
}

.item:focus,
.item:focus-visible,
.zr-list-row:focus,
.zr-list-row:focus-visible{
  outline:none;
  border-color: var(--accent-55);
  box-shadow:
    0 0 0 3px var(--accent-12),
    0 10px 24px rgba(0,0,0,.22);
}

.zr-list-intro{
  padding:12px 13px;
  border:1px solid rgba(255,243,234,.035);
  border-radius:14px;
  background: rgba(26,25,24,.38);
  box-shadow:
    0 1px 0 rgba(255,243,234,.012),
    0 8px 20px rgba(0,0,0,.14);
}

.zr-list-intro .zr-section-head{
  margin-bottom:6px;
}

.item.zr-list-row--active,
.zr-list-row.zr-list-row--active{
  background: rgba(57,53,49,.94);
  border-color: var(--accent-35);
  box-shadow:
    inset 0 0 0 1px rgba(255,243,234,.045),
    0 10px 24px rgba(0,0,0,.22);
}

.item.zr-list-row--active:hover,
.zr-list-row.zr-list-row--active:hover{
  background: rgba(55,51,48,.94);
  border-color: var(--accent-55);
  box-shadow:
    inset 0 0 0 1px rgba(255,243,234,.045),
    0 10px 24px rgba(0,0,0,.22);
}

.item.zr-list-row--active .item-title,
.item.zr-list-row--active .zr-list-row-title,
.zr-list-row.zr-list-row--active .item-title,
.zr-list-row.zr-list-row--active .zr-list-row-title{
  color: var(--headings);
  opacity: 0.92;
}

.item.zr-list-row--active .item-meta,
.item.zr-list-row--active .zr-list-row-meta,
.item.zr-list-row--active .zr-list-row-tags,
.zr-list-row.zr-list-row--active .item-meta,
.zr-list-row.zr-list-row--active .zr-list-row-meta,
.zr-list-row.zr-list-row--active .zr-list-row-tags{
  color: rgba(255,243,234,.82);
}

.zr-list-row-tags{
  margin-top:7px;
  display:flex;
  flex-wrap:wrap;
  gap:6px;
}

.item-title,
.zr-list-row-title{
  display:flex;
  align-items:flex-start;
  gap:6px;
  flex-wrap:wrap;
  margin:0;
  font-size:13px;
  line-height:1.3;
  font-weight:600;
  color: var(--headings);
}

.item-title .kb-updated-badge,
.zr-list-row-title .kb-updated-badge{
  flex:0 0 auto;
  margin-left:0;
  font-weight:500;
}

/* === ARTICLES: inline updates + updated badge === */

.kb-newmark{
  padding:0 .14em;
  border-radius:.18em;

  background:linear-gradient(
    to top,
    rgba(255,243,234,.15) 0%,
    rgba(255,243,234,.15) 58%,
    transparent 58%,
    transparent 100%
  );

  color:inherit;
  box-shadow:none;
}

.markdown mark.kb-newmark{
  padding:0 .14em;
  border-radius:.18em;

  background:linear-gradient(
    to top,
    rgba(255,243,234,.15) 0%,
    rgba(255,243,234,.15) 58%,
    transparent 58%,
    transparent 100%
  );

  color:inherit;
  box-shadow:none;
}

.item-title .kb-updated-badge,
.zr-list-row-title .kb-updated-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;

  min-height:18px;
  padding:2px 8px;
  border-radius:999px;
  margin-left:8px;

  border:1px solid var(--border);
  background:rgba(255,243,234,.06);

  color:var(--muted);
  font-size:10px;
  line-height:1;
  font-weight:500;
  letter-spacing:.04em;
  text-transform:uppercase;

  vertical-align:middle;
}

.item-meta,
.zr-list-row-meta{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:5px;
  margin-top:5px;
  font-size:10px;
  line-height:1.3;
  color: color-mix(in srgb, var(--muted) 88%, transparent);
}

.tag{
  display:inline-flex;
  align-items:center;
  padding:2px 6px;
  border-radius:999px;
  background: rgba(255,243,234,.04);
  color: color-mix(in srgb, var(--muted) 92%, transparent);
  font-size:9px;
  line-height:1.15;
  border:0;
}

.tag.accent{
  background: rgba(255,243,234,.08);
  color: color-mix(in srgb, var(--text) 86%, transparent);
}

.tag.warn{
  background: rgba(255,120,80,.08);
  color: color-mix(in srgb, var(--muted) 88%, rgba(255,180,140,.9));
}

/* =========================================================
   DOMAIN 7 — PLANNER BOARD
   ========================================================= */

#plBoard{
  display:flex;
  flex-direction:column;
  flex:1 1 auto;
  min-width:0;
  min-height:0;
  height:100%;
  gap:14px;
}

#plBoard,
#plBoard > *{
  min-width:0;
}

#plBoard > .zr-board-row{
  display:flex;
  align-items:stretch;
  gap:12px;
  flex:0 0 auto;
  min-width:0;
  min-height:0;
  overflow-x:hidden;
  overflow-y:visible;
  padding:0 12px 12px 12px;
}

.pl-head{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:12px;
  align-items:start;
}

.pl-head-left{
  min-width:0;
}

.pl-head-actions{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  align-items:center;
  justify-content:flex-end;
}

.zr-panel-topline{
  font-size:14px;
  font-weight:700;
  letter-spacing:.04em;
}

.zr-panel-subline{
  margin-top:4px;
  font-size:12px;
  color: var(--muted);
  line-height:1.4;
}

.zr-board-col{
  flex:1 1 0;
  align-self:stretch;
  min-width:0;
  min-height:320px;
  display:flex;
  flex-direction:column;
  gap:10px;
  padding:10px 12px;
  border-radius:16px;
  background: var(--panel);
  box-shadow:
    inset 0 1px 0 rgba(255,243,234,.02),
    0 10px 24px rgba(0,0,0,.18);
}

.zr-board-col-head{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap:10px;
}

.zr-board-col-title{
  font-size:14px;
  font-weight:650;
}

.zr-board-col-count{
  font-size:11px;
  color: color-mix(in srgb, var(--muted) 88%, transparent);
}

.zr-board-col-empty{
  padding:10px 2px;
  font-size:12px;
  color: color-mix(in srgb, var(--muted) 88%, transparent);
}

/* =========================================================
   DOMAIN 8 — PLANNER DETAIL
   ========================================================= */

.zr-planner-detail{
  display:flex;
  flex-direction:column;
  gap:10px;
  width:100%;
  max-width:980px;
  margin:0 auto;
  padding:6px 8px 8px 8px;
}

.zr-planner-hero{
  display:flex;
  flex-direction:column;

  /* tighter inside header */
  gap:6px;

  padding:14px 14px 12px 14px;
}

/* add breathing space before actions */
.zr-planner-hero > .zr-planner-actions{
  margin-top:6px;
}

.zr-planner-hero-top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
  flex-wrap:wrap;
}

.zr-planner-hero-main{
  flex:1;
  min-width:240px;
}

.zr-planner-title{
  margin:0;
  font-size:18px;
  line-height:1.24;
  font-weight:650;
  color:var(--headings);
}

.zr-planner-meta{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  margin-top:10px;
}

.zr-planner-actions{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
}

.zr-planner-status-note{
  min-height:18px;
}

.zr-planner-grid{
  display:grid;
  grid-template-columns:minmax(0, 1.45fr) minmax(240px, .78fr);
  gap:10px;
  align-items:start;
}

.zr-planner-maincol,
.zr-planner-sidecol,
.zr-planner-logcol{
  display:flex;
  flex-direction:column;
  gap:10px;
  min-width:0;
}

.zr-planner-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}

.zr-planner-section{
  min-width:0;
}

.zr-planner-assignee{
  font-size:13px;
  line-height:1.4;
}

.zr-planner-detail .zr-card--section{
  background: rgba(255,255,255,.025);
  border:0;
  border-radius:16px;
  padding:12px 14px;
  box-shadow:
    0 1px 0 rgba(255,243,234,.02),
    0 6px 16px rgba(0,0,0,.14);
}

.zr-planner-detail .zr-card--subtle{
  background: rgba(255,255,255,.02);
  border:0;
  border-radius:16px;
  padding:12px 14px;
  box-shadow:
    0 1px 0 rgba(255,243,234,.018),
    0 4px 12px rgba(0,0,0,.12);
}

.zr-planner-detail .zr-planner-body-text{
  font-size:13px;
  line-height:1.45;
}

.zr-planner-detail .btn{
  border:0;
  background: rgba(255,243,234,.07);
  color: var(--text);
  box-shadow:
    0 1px 0 rgba(255,243,234,.02),
    0 4px 10px rgba(0,0,0,.18);
}

.zr-planner-detail .btn:hover{
  background: rgba(255,243,234,.10);
  box-shadow:
    0 1px 0 rgba(255,243,234,.025),
    0 6px 14px rgba(0,0,0,.20);
}

/* === BUTTON HIERARCHY — PLANNER ONLY === */

/* Primary */
.zr-planner-detail .btn--primary{
  background: rgba(255,243,234,.16);
  box-shadow:
    0 1px 0 rgba(255,243,234,.04),
    0 8px 22px rgba(0,0,0,.26);
  font-weight:600;
}

.zr-planner-detail .btn--primary:hover{
  background: rgba(255,243,234,.20);
  box-shadow:
    0 1px 0 rgba(255,243,234,.05),
    0 10px 26px rgba(0,0,0,.28);
}

/* Secondary */
.zr-planner-detail .btn--secondary{
  background: rgba(255,243,234,.07);
  box-shadow:
    0 1px 0 rgba(255,243,234,.02),
    0 4px 10px rgba(0,0,0,.18);
}

/* Danger soft */
.zr-planner-detail .btn--danger{
  background: rgba(255,120,80,.10);
  color: var(--text);
  box-shadow:
    0 1px 0 rgba(255,120,80,.12),
    0 4px 10px rgba(0,0,0,.18);
}

.zr-planner-detail .btn--danger:hover{
  background: rgba(255,120,80,.16);
}

/* Minor */
.zr-planner-detail .btn--ghost{
  background: rgba(255,243,234,.04);
  opacity:.8;
  box-shadow:none;
}

/* Planner detail — action hierarchy by container */
.zr-planner-actions-admin .btn{
  background: rgba(255,243,234,.06);
  box-shadow:
    0 1px 0 rgba(255,243,234,.02),
    0 3px 10px rgba(0,0,0,.14);
  font-weight:500;
}

.zr-planner-actions-admin .btn:hover{
  background: rgba(255,243,234,.08);
  box-shadow:
    0 1px 0 rgba(255,243,234,.025),
    0 5px 12px rgba(0,0,0,.16);
}

.zr-planner-actions-status .btn{
  background: rgba(255,243,234,.11);
  box-shadow:
    0 1px 0 rgba(255,243,234,.03),
    0 6px 16px rgba(0,0,0,.20);
  font-weight:600;
}

.zr-planner-actions-status .btn:hover{
  background: rgba(255,243,234,.14);
  box-shadow:
    0 1px 0 rgba(255,243,234,.035),
    0 8px 18px rgba(0,0,0,.22);
}

#plBack{
  background: rgba(255,243,234,.04);
  box-shadow:none;
  opacity:.82;
}

#plBack:hover{
  background: rgba(255,243,234,.06);
  box-shadow:
    0 1px 0 rgba(255,243,234,.02),
    0 3px 8px rgba(0,0,0,.12);
  opacity:1;
}

#plAddDocBtn,
#plAddChecklistBtn{
  background: rgba(255,243,234,.04);
  box-shadow:none;
  opacity:.84;
}

#plAddDocBtn:hover,
#plAddChecklistBtn:hover{
  background: rgba(255,243,234,.06);
  box-shadow:
    0 1px 0 rgba(255,243,234,.02),
    0 3px 8px rgba(0,0,0,.12);
  opacity:1;
}

/* =========================================================
   DOMAIN 9 — PLANNER SUB-SURFACES
   Minimal parity only
   ========================================================= */

#plChecklist,
#plDocs,
#plComments{
  min-height:72px;
  min-width:0;
}

#plChecklist:empty,
#plDocs:empty,
#plComments:empty{
  opacity:.65;
}

/* Planner dialogs: task create/edit + link/checklist add */
.zr-planner-dialog{
  max-height:calc(100vh - 96px);
  overflow:auto;
  border:1px solid var(--border);
  border-radius:18px;
  background:var(--card);
  color:var(--text);
  box-shadow:0 18px 40px rgba(0,0,0,.32);
  transition:none;
}

.zr-planner-dialog:hover{
  background:var(--card);
  border:1px solid var(--border);
  box-shadow:0 18px 40px rgba(0,0,0,.32);
  transform:none;
}

.zr-planner-dialog,
.zr-planner-dialog .pl-control,
.zr-planner-dialog .btn,
.zr-planner-dialog select,
.zr-planner-dialog textarea,
.zr-planner-dialog input{
  font:inherit;
}

.zr-planner-dialog-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  padding-bottom:10px;
  margin-bottom:14px;
  border-bottom:1px solid rgba(255,243,234,.06);
}

.zr-planner-dialog-body{
  display:flex;
  flex-direction:column;
  gap:12px;
}

.zr-planner-dialog-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:10px;
}

.zr-planner-dialog-choice-row{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.zr-planner-dialog-actions{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:10px;
  margin-top:8px;
  padding-top:2px;
}

.zr-planner-dialog-actions .muted{
  margin-right:auto;
}

.zr-planner-dialog .pl-control{
  width:100%;
  min-height:38px;
  padding:8px 11px;
  border-radius:12px;
  transition:
    border-color .16s ease,
    box-shadow .16s ease,
    background-color .16s ease;
}

.zr-planner-dialog .pl-control:hover{
  border-color:rgba(255,243,234,.14);
}

.zr-planner-dialog .pl-control:focus,
.zr-planner-dialog .pl-control:focus-visible{
  outline:none;
  border-color:var(--accent-35);
  box-shadow:0 0 0 2px rgba(192,58,20,.10);
}

.zr-planner-dialog textarea.pl-control,
.zr-planner-dialog .pl-textarea{
  min-height:84px;
  padding:10px 12px;
  line-height:1.4;
  resize:vertical;
}

.zr-planner-dialog label{
  display:flex;
  align-items:center;
  gap:8px;
  user-select:none;
}

.zr-planner-dialog input[type="checkbox"],
.zr-planner-dialog input[type="radio"]{
  flex:0 0 auto;
  margin:0;
}

@media (max-width: 720px){
  .zr-planner-dialog-grid{
    grid-template-columns:1fr;
  }
}

/* Checklist: task points owner */
.zr-planner-checklist,
.zr-planner-checklist-list,
.zr-planner-inline-cl-list,
.zr-planner-inline-checklists{
  display:flex;
  flex-direction:column;
  gap:10px;
}

.zr-planner-checklist-row,
.zr-planner-inline-cl-row{
  display:flex;
  align-items:flex-start;
  gap:12px;
  min-width:0;
  padding:10px 12px;
  border:1px solid transparent;
  border-radius:12px;
  background:rgba(255,243,234,.02);
  transition:
    background-color .16s ease,
    border-color .16s ease,
    opacity .16s ease;
}

.zr-planner-checklist-row input,
.zr-planner-inline-cl-row input{
  flex:0 0 auto;
  width:16px;
  height:16px;
  margin:2px 0 0 0;
}

.zr-planner-checklist-text,
.zr-planner-inline-cl-text{
  display:block;
  flex:1 1 auto;
  min-width:0;
  font-size:13px;
  line-height:1.5;
  color:var(--text);
}

.zr-planner-checklist-text.is-done{
  opacity:.66;
  text-decoration:line-through;
  text-decoration-thickness:1px;
}

.zr-planner-inline-cl{
  padding:12px 14px;
}

.zr-planner-inline-cl-toggle{
  padding:4px 0;
  min-height:auto;
  border:0;
  background:transparent;
  box-shadow:none;
  font-weight:600;
}

.zr-planner-inline-cl-toggle:hover,
.zr-planner-inline-cl-toggle:focus,
.zr-planner-inline-cl-toggle:focus-visible{
  background:transparent;
  border:0;
  box-shadow:none;
}

.zr-planner-inline-cl-body{
  margin-top:10px;
}

.zr-planner-inline-cl-row{
  min-width:0;
  padding:8px 10px;
  background:rgba(255,243,234,.02);
  border:1px solid transparent;
  border-radius:10px;
}

.zr-planner-inline-cl-row .tag{
  display:none;
}

.zr-planner-inline-cl-text{
  display:block;
  flex:1 1 auto;
  min-width:0;
  line-height:1.55;
}


.zr-planner-checklist-row:hover,
.zr-planner-inline-cl-row:hover{
  background:rgba(255,243,234,.04);
  border-color:rgba(255,243,234,.08);
}

.zr-planner-checklist-row:has(input[type="checkbox"]:checked){
  background:rgba(255,243,234,.05);
  border-color:rgba(255,243,234,.10);
}

.zr-planner-inline-cl-row:has(input[type="checkbox"]:checked){
  background:rgba(255,243,234,.05);
  border-color:rgba(255,243,234,.10);
}

.zr-planner-inline-cl-row:has(input[type="checkbox"]:checked) .zr-planner-inline-cl-text{
  opacity:.66;
  text-decoration:line-through;
  text-decoration-thickness:1px;
}
.zr-planner-inline-cl-status{
  display:block;
  width:100%;
  margin-top:6px;
  padding-left:2px;
  font-size:10px;
  line-height:1.3;
  color: color-mix(in srgb, var(--muted) 78%, transparent);
  white-space:normal;
  opacity:.82;
}

.zr-planner-inline-cl-status[data-tone="saving"],
.zr-planner-inline-cl-status[data-tone="success"],
.zr-planner-inline-cl-status[data-tone="error"]{
  color: color-mix(in srgb, var(--muted) 82%, transparent);
}

.zr-planner-inline-cl.is-saving .zr-planner-inline-cl-body{
  pointer-events:none;
}

.zr-planner-inline-cl.is-saving .zr-planner-inline-cl-row{
  opacity:1;
}

.zr-planner-inline-cl.is-saving input[type="checkbox"]{
  filter:none;
  opacity:1;
}

#plChecklist{
  min-width:0;
}

#plChecklist .zr-planner-inline-checklists{
  gap:14px;
}

#plChecklist .zr-planner-inline-cl{
  position:relative;
  padding:14px 16px 44px 16px;
  background:rgba(255,243,234,.035);
  border-radius:16px;
  box-shadow:
    inset 0 0 0 1px rgba(255,243,234,.04),
    0 8px 20px rgba(0,0,0,.14);
}

#plChecklist .zr-planner-inline-cl-head{
  display:grid;
  grid-template-columns:minmax(0,1fr) 96px;
  align-items:start;
  column-gap:12px;
  row-gap:0;
  min-width:0;
}

#plChecklist .zr-planner-inline-cl-toggle{
  grid-column:1;
  grid-row:1;
  display:flex;
  align-items:center;
  justify-content:flex-start;
  width:100%;
  min-height:32px;
  padding:0;
  border:0;
  border-radius:0;
  background:transparent;
  box-shadow:none;
  color:var(--text);
  font-size:13px;
  line-height:1.4;
  font-weight:600;
  min-width:0;
  text-align:left;
}

#plChecklist .zr-planner-inline-meta{
  grid-column:2;
  grid-row:1;
  display:block;
  width:96px;
  min-width:96px;
  max-width:96px;
}

#plChecklist .zr-planner-inline-cl-toggle:hover,
#plChecklist .zr-planner-inline-cl-toggle:focus,
#plChecklist .zr-planner-inline-cl-toggle:focus-visible,
#plChecklist .zr-planner-inline-cl-toggle:active{
  border:0;
  background:transparent;
  box-shadow:none;
  transform:none;
}

#plChecklist .zr-planner-inline-cl-status{
  display:block;
  width:100%;
  height:16px;
  margin:0;
  padding:0;
  font-size:11px;
  line-height:16px;
  text-align:right;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  opacity:.86;
  color:rgba(255,243,234,.88);
  font-weight:600;
}

#plChecklist .pl-btn-danger-soft[data-inline-cl-remove]{
  position:absolute;
  right:14px;
  bottom:12px;
  width:72px;
  min-width:72px;
  height:24px;
  min-height:24px;
  padding:0;
  border-radius:999px;
  font-size:11px;
  line-height:1;
  opacity:.78;
  box-shadow:none;
}

#plChecklist .zr-planner-inline-cl-body{
  margin-top:10px;
  padding-left:14px;
  min-width:0;
}

#plChecklist .zr-planner-inline-cl-group + .zr-planner-inline-cl-group{
  margin-top:12px;
}

#plChecklist .zr-planner-inline-cl-group-title{
  margin-bottom:7px;
}

#plChecklist .zr-planner-inline-cl-list{
  gap:10px;
}

#plChecklist .zr-planner-inline-cl-row{
  width:100%;
  min-width:0;
  align-items:flex-start;
  padding:10px 12px;
  background:rgba(255,243,234,.03);
  border-radius:12px;
}

#plChecklist .zr-planner-inline-cl-text{
  flex:1 1 auto;
  min-width:0;
  font-size:13px;
  line-height:1.5;
  color:rgba(255,243,234,.96);
}

@media (max-width: 960px){
  #plChecklist .zr-planner-inline-checklists{
    gap:10px;
  }

  #plChecklist .zr-planner-inline-cl{
    padding:10px 12px 40px 12px;
  }

  #plChecklist .zr-planner-inline-cl-head{
    grid-template-columns:minmax(0,1fr) 88px;
    column-gap:10px;
  }

  #plChecklist .zr-planner-inline-meta{
    width:88px;
    min-width:88px;
    max-width:88px;
  }

  #plChecklist .pl-btn-danger-soft[data-inline-cl-remove]{
    right:12px;
    bottom:10px;
    width:68px;
    min-width:68px;
  }

  #plChecklist .zr-planner-inline-cl-body{
    padding-left:12px;
  }
}

/* Comments: compose area only */
.zr-planner-comments{
  display:flex;
  flex-direction:column;
  gap:10px;
}

.zr-planner-comment-compose{
  display:flex;
  flex-direction:column;
  gap:10px;
  margin-top:8px;
  padding-top:10px;
  border-top:1px solid rgba(255,243,234,.06);
}

#plComments .zr-planner-comment-compose #plCommentInput.pl-control.pl-textarea{
  width:100%;
  min-height:86px;
  padding:14px 16px;
  border-radius:16px;
  resize:vertical;
  background: rgba(26,23,20,.42);
  border:1px solid rgba(255,243,234,.08);
  color:var(--text);
  line-height:1.45;
  box-shadow:none;
}

/* Comments: row ownership */
#plComments .zr-planner-comment-meta .zr-planner-comment-author{
  display:none;
}

#plComments .zr-card.zr-card--row.zr-planner-comment-row{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto auto;
  align-items:start;
  column-gap:10px;
  row-gap:0;
  padding:9px 12px;
  border-radius:8px;
}

#plComments .zr-card.zr-card--row.zr-planner-comment-row + .zr-card.zr-card--row.zr-planner-comment-row{
  margin-top:8px;
}

#plComments .zr-planner-comment-meta{
  display:contents;
}

#plComments .zr-planner-comment-main{
  grid-column:1;
  grid-row:1;
  min-width:0;
  padding-top:1px;
  font-size:12px;
  line-height:1.38;
  color:var(--text);
  white-space:normal;
  word-break:break-word;
  overflow-wrap:anywhere;
}

#plComments .zr-planner-comment-author-inline,
#plComments .zr-planner-comment-body-inline{
  display:inline;
  white-space:normal;
  word-break:break-word;
  overflow-wrap:anywhere;
  vertical-align:top;
}

#plComments .zr-planner-comment-author-inline{
  font-weight:600;
  color:var(--text);
  margin-right:5px;
}

#plComments .zr-planner-comment-body-inline{
  color:rgba(255,243,234,.90);
}

#plComments .zr-planner-comment-time{
  grid-column:2;
  grid-row:1;
  align-self:start;
  justify-self:end;
  display:inline-flex;
  align-items:center;
  height:22px;
  margin:0;
  font-size:10px;
  line-height:1;
  color:var(--muted);
  white-space:nowrap;
  opacity:.78;
}

#plComments .pl-comment-delete{
  grid-column:3;
  grid-row:1;
  align-self:start;
  justify-self:end;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  height:22px;
  min-height:22px;
  padding:0 8px;
  border-radius:999px;
  font-size:10px;
  line-height:1;
  opacity:.78;
}

#plComments .zr-planner-comments{
  gap:8px;
}

#plComments .zr-planner-comment-compose{
  margin-top:6px;
  padding-top:8px;
}

#plComments .zr-planner-comment-compose #plCommentInput.pl-control.pl-textarea{
  min-height:72px;
  padding:12px 14px;
  border-radius:14px;
}

/* Documents: narrow parity baseline */
.zr-planner-docs-list{
  display:flex;
  flex-direction:column;
  gap:10px;
}

.zr-planner-doc-card,
.zr-planner-doc-row{
  position:relative;
  min-width:0;
}

.zr-planner-doc-link{
  width:100%;
  min-height:54px;
  padding:10px 34px 10px 12px;
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  justify-content:center;
  text-align:left;
  white-space:normal;
  overflow:hidden;
  text-overflow:clip;
}

.zr-planner-doc-meta{
  display:block;
  margin:0 0 3px 0;
  padding:0;
  font-size:10px;
  line-height:1.1;
  text-transform:uppercase;
  opacity:.52;
}

.zr-planner-doc-label{
  display:block;
  margin:0;
  padding:0;
  max-width:100%;
  font-size:13px;
  line-height:1.28;
  font-weight:600;
  word-break:break-word;
}

.zr-planner-doc-remove{
  position:absolute;
  top:10px;
  right:10px;
  width:20px;
  height:20px;
  min-width:20px;
  min-height:20px;
  padding:0;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  line-height:1;
}

/* =========================================================
   DOMAIN 10 — STATES
   ========================================================= */

.pl-archived{
  opacity:.82;
}

.pl-archived .item{
  opacity:.92;
}

.pl-readonly-disabled,
.is-disabled{
  opacity:.55;
  pointer-events:none;
}

.pl-due.is-overdue{
  color: var(--accent);
  font-weight:600;
}

.btn:disabled,
.btn[disabled],
button:disabled,
input:disabled,
textarea:disabled,
select:disabled{
  opacity:.55;
  pointer-events:none;
}

.pl-archived #plComments button,
.pl-archived #plComments .btn,
.pl-archived #plComments textarea,
.pl-archived #plComments input,
.pl-archived #plDocs button:not(#plBack):not(#plArchiveTask),
.pl-archived #plChecklist button,
.pl-archived #plChecklist input{
  opacity:.55;
  pointer-events:none;
}

.pl-archived #plBack,
.pl-archived #plArchiveTask{
  opacity:1;
  pointer-events:auto;
}

/* =========================================================
   DOMAIN 11 — MOBILE
   (not implemented yet)
   ========================================================= */

/* === TEMPLATES FORM SYSTEM === */

.zr-form-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:14px 16px;
  align-items:start;
}

.zr-field{
  min-width:0;
  display:flex;
  flex-direction:column;
  gap:6px;
}

.zr-span-full{
  grid-column:1 / -1;
}

.zr-label{
  display:block;
  margin:0;
  font-size:13px;
  line-height:1.35;
  font-weight:500;
  color:var(--text);
}

.zr-row-2{
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:12px;
}

.zr-input{
  width:100%;
  min-width:0;
  min-height:42px;
  padding:10px 12px;
  border:1px solid var(--border);
  border-radius:12px;
  background:rgba(26,23,20,.60);
  color:var(--text);
  font:inherit;
  line-height:1.35;
  outline:none;
  box-shadow:none;
}

.zr-input:hover{
  border-color:var(--accent-35);
}

.zr-input:focus,
.zr-input:focus-visible{
  border-color:var(--accent-55);
  box-shadow:0 0 0 3px var(--accent-12);
}

.zr-textarea{
  min-height:110px;
  resize:vertical;
}

.zr-actions-right{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  justify-content:flex-start;
}

@media (max-width: 860px){
  .zr-form-grid,
  .zr-row-2{
    grid-template-columns:1fr;
  }
}

.zr-board-toolbar{
  position:sticky;
  top:-20px;
  z-index:8;

  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  align-items:center;
  gap:12px;

  margin:0 0 12px 0;
  padding:8px 22px 10px 22px;

  background:rgba(31,30,29,.88);
  border-bottom:1px solid rgba(255,243,234,.05);
}

.zr-board-toolbar{
  box-shadow:0 8px 18px rgba(0,0,0,.10);
}

.zr-board-toolbar__left{
  min-width:0;
  display:flex;
  align-items:center;
}

.zr-board-toolbar__right{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:8px;
  flex-wrap:wrap;
}

.zr-board-toolbar__date{
  font-size:12px;
  line-height:1.2;
  color:var(--muted);
  white-space:nowrap;
}

/* ===== PLANNER DETAIL – SAFE VISUAL CLEANUP ===== */

.zr-planner-detail .zr-planner-detail-section{
  background:transparent;
  border:none;
  padding:0;
  margin:0;
}

.zr-planner-detail .zr-planner-detail-section h3{
  font-size:13px;
  font-weight:600;
  opacity:0.7;
  margin-bottom:8px;
}

.zr-planner-hero-top-actions,
.zr-planner-actions-admin,
.zr-planner-actions-status{
  display:flex;
  align-items:center;
  gap:6px;
  flex-wrap:wrap;
}

.zr-planner-hero-top-actions .btn,
.zr-planner-actions-admin .btn,
.zr-planner-actions-status .btn,
#plAddDocBtn,
#plAddChecklistBtn,
#plRemoveChecklistBtn{
  min-height:30px;
  height:30px;
  padding:0 10px;
  border:0;
  border-radius:10px;

  display:inline-flex;
  align-items:center;
  justify-content:center;

  font-family:"Segoe UI", Arial, sans-serif;
  font-size:12px;
  line-height:1;
  font-weight:600;
  letter-spacing:0;

  white-space:nowrap;
  box-shadow:none;
  transition:
    background-color .16s ease,
    color .16s ease,
    opacity .16s ease,
    transform .06s ease;
}

/* ghost: navigation / helper actions */
.zr-planner-hero-top-actions .btn--ghost,
.zr-planner-actions-admin .btn--ghost,
.zr-planner-actions-status .btn--ghost,
#plAddDocBtn,
#plAddChecklistBtn,
#plRemoveChecklistBtn,
#plBack,
#plEditTask{
  background:rgba(255,243,234,.055);
  color:rgba(255,243,234,.82);
  opacity:.92;
}

.zr-planner-hero-top-actions .btn--ghost:hover,
.zr-planner-actions-admin .btn--ghost:hover,
.zr-planner-actions-status .btn--ghost:hover,
#plAddDocBtn:hover,
#plAddChecklistBtn:hover,
#plRemoveChecklistBtn:hover,
#plBack:hover,
#plEditTask:hover{
  background:rgba(255,243,234,.085);
  color:rgba(255,243,234,.96);
  opacity:1;
}

/* primary: main positive action */
.zr-planner-hero-top-actions .btn--primary,
.zr-planner-actions-admin .btn--primary,
.zr-planner-actions-status .btn--primary{
  background:rgba(255,243,234,.16);
  color:var(--headings);
  opacity:1;
}

.zr-planner-hero-top-actions .btn--primary:hover,
.zr-planner-actions-admin .btn--primary:hover,
.zr-planner-actions-status .btn--primary:hover{
  background:rgba(255,243,234,.22);
}

/* danger: archive / cancel only */
.zr-planner-hero-top-actions .btn--danger,
.zr-planner-actions-admin .btn--danger,
.zr-planner-actions-status .btn--danger{
  background:rgba(160,88,70,.20);
  color:rgba(255,243,234,.94);
  opacity:1;
}

.zr-planner-hero-top-actions .btn--danger:hover,
.zr-planner-actions-admin .btn--danger:hover,
.zr-planner-actions-status .btn--danger:hover{
  background:rgba(160,88,70,.28);
}

/* warning: problem-state action */
.zr-planner-hero-top-actions .btn--warning,
.zr-planner-actions-admin .btn--warning,
.zr-planner-actions-status .btn--warning{
  background:rgba(196,126,86,.18);
  color:rgba(255,243,234,.96);
  opacity:1;
}

.zr-planner-hero-top-actions .btn--warning:hover,
.zr-planner-actions-admin .btn--warning:hover,
.zr-planner-actions-status .btn--warning:hover{
  background:rgba(196,126,86,.24);
}

/* === PLANNER DETAIL: calm meta pills === */

.zr-planner-detail .pill{
  min-height:auto;
  padding:0;
  background:transparent;
  box-shadow:none;
  border:0;

  font-size:10px;
  line-height:1.15;
  font-weight:500;
  color:rgba(255,243,234,.30);
}

.zr-planner-detail .zr-planner-meta{
  gap:8px;
}

/* === PLANNER DETAIL: meta separators === */

.zr-planner-detail .pill{
  position:relative;
}

/* добавляем точку между элементами */
.zr-planner-detail .pill:not(:last-child)::after{
  content:"•";
  margin:0 6px;
  color:rgba(255,243,234,.28);
}

/* === PLANNER DETAIL: checklist emphasis + quiet empty description === */

.zr-planner-maincol > .zr-planner-section:nth-child(3){
  background:rgba(255,243,234,.04);
  box-shadow:
    inset 0 0 0 1px rgba(255,243,234,.045),
    0 10px 24px rgba(0,0,0,.16);
}

.zr-planner-maincol > .zr-planner-section:nth-child(3) .zr-section-title{
  color:rgba(255,243,234,.88);
}

.zr-planner-maincol > .zr-planner-section:nth-child(2) .zr-planner-muted{
  opacity:.48;
  font-size:12px;
}

/* === PLANNER DETAIL: document cards (clean) === */

#plDocs .zr-planner-doc-link{
  min-height:54px;
  padding:10px 32px 10px 12px;
  align-items:flex-start;
  justify-content:center;
  text-align:left;
}

#plDocs .zr-planner-doc-meta{
  margin:0 0 3px 0;
  padding:0;
  font-size:10px;
  line-height:1.1;
  opacity:.52;
}

#plDocs .zr-planner-doc-label{
  margin:0;
  padding:0;
  font-size:13px;
  line-height:1.28;
  font-weight:600;
  letter-spacing:.01em;
}

#plDocs .zr-planner-doc-remove{
  top:10px;
  right:10px;
  width:20px;
  height:20px;
  min-width:20px;
  min-height:20px;
  padding:0;
}

#plDocs .zr-planner-doc-link{
  font-family:inherit;
}

#plComments{
  position:relative;
  overflow:hidden;
  border-radius:8px;

  background-image:url("/assets/bg/comments-pattern.webp");
  background-size:460px;
  background-repeat:repeat;
  background-position:0 0;
}

#plComments::before{
  content:"";
  position:absolute;
  inset:0;
  background:rgba(24,22,20,.78);
  pointer-events:none;
}

#plComments > *{
  position:relative;
  z-index:1;
}

#plComments .zr-planner-muted{
  color:rgba(255,243,234,.82);
  opacity:1;
}

#plComments .zr-planner-muted{
  letter-spacing:.01em;
}

.zr-planner-docs-section .zr-section-head--docs{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  flex-wrap:wrap;
}

.zr-planner-docs-head-actions{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}

.zr-section-title--toggle{
  appearance:none;
  padding:0;
  border:0;
  background:transparent;
  cursor:pointer;
  text-align:left;
}

.zr-section-title--toggle:hover{
  opacity:.92;
}

.zr-section-title--toggle:focus,
.zr-section-title--toggle:focus-visible{
  outline:none;
  box-shadow:none;
}

#plDocsSection.is-collapsed #plDocs{
  display:none;
}

#plDocsSection:not(.is-collapsed) #plDocs{
  display:block;
}

#plDocsSection.is-collapsed{
  padding-bottom:12px;
}

.zr-section-title--toggle{
  appearance:none;
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:0;
  border:0;
  background:transparent;
  cursor:pointer;
  text-align:left;
  color:rgba(255,243,234,.90);
}

.zr-section-title--toggle::before{
  content:"";
  width:7px;
  height:7px;
  border-right:1.5px solid rgba(255,243,234,.58);
  border-bottom:1.5px solid rgba(255,243,234,.58);
  transform:rotate(-45deg);
  transform-origin:center;
  transition:transform .16s ease, opacity .16s ease;
  opacity:.9;
  margin-top:-1px;
}

#plDocsSection:not(.is-collapsed) .zr-section-title--toggle::before{
  transform:rotate(45deg);
}

.zr-section-title-toggle__label{
  color:rgba(255,243,234,.90);
}

.zr-section-title-toggle__count{
  color:rgba(255,243,234,.46);
  font-weight:500;
}

.zr-section-title--toggle:hover .zr-section-title-toggle__label{
  color:rgba(255,243,234,.98);
}

.zr-section-title--toggle:hover::before{
  border-color:rgba(255,243,234,.78);
}

.zr-planner-details-section{
  padding:12px 14px;
}

.zr-planner-details-section .zr-section-head--details{
  margin-bottom:0;
}

.zr-planner-details-body{
  display:flex;
  flex-direction:column;
  gap:10px;
  margin-top:10px;
}

#plDetailsSection.is-collapsed .zr-planner-details-body{
  display:none;
}

#plDetailsSection.is-collapsed{
  padding-bottom:12px;
}

#plDetailsSection .zr-section-title--toggle{
  appearance:none;
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:0;
  border:0;
  background:transparent;
  cursor:pointer;
  text-align:left;
  color:rgba(255,243,234,.90);
}

#plDetailsSection .zr-section-title--toggle::before{
  content:"";
  width:7px;
  height:7px;
  border-right:1.5px solid rgba(255,243,234,.58);
  border-bottom:1.5px solid rgba(255,243,234,.58);
  transform:rotate(45deg);
  transform-origin:center;
  transition:transform .16s ease, opacity .16s ease;
  opacity:.9;
  margin-top:-1px;
}

#plDetailsSection.is-collapsed .zr-section-title--toggle::before{
  transform:rotate(-45deg);
}

#plDetailsSection .zr-section-title--toggle:hover .zr-section-title-toggle__label{
  color:rgba(255,243,234,.98);
}

#plDetailsSection .zr-section-title--toggle:hover::before{
  border-color:rgba(255,243,234,.78);
}

.zr-planner-grid.zr-planner-grid--compact-top{
  grid-template-columns:1fr;
  gap:10px;
}

.zr-planner-grid.zr-planner-grid--compact-top .zr-planner-maincol,
.zr-planner-grid.zr-planner-grid--compact-top .zr-planner-sidecol{
  display:contents;
}

.zr-planner-grid.zr-planner-grid--compact-top #plDetailsSection,
.zr-planner-grid.zr-planner-grid--compact-top #plDocsSection{
  display:flex;
  align-items:center;
  min-height:48px;
  padding:12px 14px;
}

.zr-planner-grid.zr-planner-grid--compact-top #plDetailsSection{
  grid-column:1;
  grid-row:1;
}

.zr-planner-grid.zr-planner-grid--compact-top #plDocsSection{
  grid-column:1;
  grid-row:2;
}

.zr-planner-grid.zr-planner-grid--compact-top .zr-planner-section--fullwidth{
  grid-column:1;
  grid-row:3;
}

.zr-planner-grid.zr-planner-grid--compact-top #plDetailsSection .zr-section-head--details,
.zr-planner-grid.zr-planner-grid--compact-top #plDocsSection .zr-section-head--docs{
  width:100%;
  margin-bottom:0;
}

.zr-planner-grid.zr-planner-grid--compact-top #plDetailsSection.is-collapsed,
.zr-planner-grid.zr-planner-grid--compact-top #plDocsSection.is-collapsed{
  padding-bottom:12px;
}

/* ===== PLANNER BOARD FILL FIX ===== */

#viewer:has(.zr-board-screen){
  padding:0;
}

#viewer:has(.zr-board-screen) .zr-board-screen{
  flex:1 1 auto;
  height:100%;
  min-height:100%;
  margin:0;
  padding:12px 20px 20px 20px;
}

/* ===== PLANNER DIALOG SELECT POLISH ===== */

.zr-planner-dialog select.pl-control,
.zr-planner-dialog .pl-control[type="date"]{
  appearance:none;
  -webkit-appearance:none;
  -moz-appearance:none;
  background:
    linear-gradient(45deg, transparent 50%, rgba(255,243,234,.62) 50%),
    linear-gradient(135deg, rgba(255,243,234,.62) 50%, transparent 50%),
    linear-gradient(to right, transparent, transparent);
  background-position:
    calc(100% - 16px) calc(50% - 2px),
    calc(100% - 11px) calc(50% - 2px),
    100% 0;
  background-size:
    5px 5px,
    5px 5px,
    2.5em 100%;
  background-repeat:no-repeat;
  padding-right:34px;
}

.zr-planner-dialog select.pl-control option,
.zr-planner-dialog select.pl-control optgroup{
  background:var(--card);
  color:var(--text);
}

.zr-planner-dialog select.pl-control:focus,
.zr-planner-dialog select.pl-control:focus-visible{
  outline:none;
}

/* ===== PLANNER DIALOG CUSTOM DATE FIELD ===== */

.zr-date-field{
  position:relative;
}

.zr-date-field__text{
  padding-right:40px !important;
  font-variant-numeric:tabular-nums;
}

.zr-date-field__button{
  position:absolute;
  top:50%;
  right:10px;
  transform:translateY(-50%);
  width:20px;
  height:20px;
  min-width:20px;
  min-height:20px;
  padding:0;
  border:0;
  background:transparent;
  color:var(--muted);
  cursor:pointer;
  line-height:1;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  opacity:.9;
}

.zr-date-field__button:hover{
  color:var(--text);
  opacity:1;
}

.zr-date-field__button:focus,
.zr-date-field__button:focus-visible{
  outline:none;
  box-shadow:none;
}

.zr-date-field__native{
  position:absolute;
  inset:0;
  opacity:0;
  pointer-events:none;
}

/* ===== PLANNER DETAIL: no-details layout fix ===== */

.zr-planner-grid.zr-planner-grid--no-details{
  grid-template-columns:1fr;
}

.zr-planner-grid.zr-planner-grid--no-details .zr-planner-maincol,
.zr-planner-grid.zr-planner-grid--no-details .zr-planner-sidecol{
  width:100%;
}

/* === Planner: no side column (auto-collapse docs) === */
.zr-planner-grid.zr-planner-grid--no-sidecol{
  grid-template-columns:1fr;
}

.zr-planner-grid.zr-planner-grid--no-sidecol .zr-planner-maincol{
  width:100%;
}

/* safety: hide sidecol completely when disabled */
.zr-planner-sidecol[style*="display: none"]{
  display:none;
}

.zr-admin-home__content-actions{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:14px;
}

.zr-admin-home__content-actions .btn{
  min-height:30px;
  padding:4px 8px;
  border-radius:10px;
  font-size:12px;
  line-height:1.2;
}

@media (max-width: 760px){
  .zr-admin-home__grid{
    grid-template-columns:1fr;
  }

  .zr-admin-home__card--content{
    grid-column:auto;
  }
}

/* === ADMIN COMPACT BUTTONS FIX === */

.zr-admin-mode-tabs .btn,
.zr-admin-list-tools .btn{
  min-height:28px;
  padding:3px 8px;
  border-radius:10px;
  font-size:12px;
  line-height:1.2;
}
.zr-admin-list-tools .btn{
  opacity:.9;
}

/* === ADMIN: list tools isolation === */

.zr-admin-list-tools{
  display:flex;
  gap:8px;
  align-items:center;
  padding:8px 0;
}

/* === ADMIN TABS STABLE FIX (NO IMPORTANT) === */
#list{
  display:flex;
  flex-direction:column;
}

#list > .actions.zr-admin-mode-tabs{
  display:flex;
  flex-wrap:wrap;
  align-items:flex-start;
  align-content:flex-start;
  gap:8px;
  row-gap:8px;
  column-gap:8px;
  padding:0 0 12px 0;
  margin:0 0 12px 0;
  min-height:56px;
  overflow:visible;
  height:auto;
}

#list > .actions.zr-admin-mode-tabs + .item,
#list > .actions.zr-admin-mode-tabs + .zr-list-row,
#list > .actions.zr-admin-mode-tabs + .empty{
  margin-top:0;
}

/* === ADMIN HOME CONTENT POLISH === */

.zr-admin-home__card{
  text-align:left;
}

.zr-admin-home__card .zr-admin-home__card-title,
.zr-admin-home__card .zr-admin-home__card-sub{
  width:100%;
}

.zr-admin-home__card[type="button"],
button.zr-admin-home__card{
  border:1px solid rgba(255,243,234,.04);
}

.zr-admin-home__content-list{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:10px 14px;
  align-items:start;
  margin-top:14px;
}

.zr-admin-home__content-note{
  align-self:center;
  min-width:0;
  color:var(--muted);
  font-size:12px;
  line-height:1.35;
}

.zr-admin-home__content-list .btn{
  justify-self:start;
}

@media (max-width: 760px){
  .zr-admin-home__content-list{
    grid-template-columns:1fr;
    gap:8px;
  }

  .zr-admin-home__content-note{
    margin-top:-2px;
    margin-bottom:4px;
  }
}

/* === ADMIN HOME BUTTON SIZE ALIGN === */

.zr-admin-home__card{
  padding:10px 12px;
  border-radius:10px;
}

.zr-admin-home__card-title{
  font-size:14px;
  line-height:1.2;
}

.zr-admin-home__card-sub{
  font-size:12px;
  line-height:1.3;
  margin-top:4px;
  color:var(--muted);
}

/* === ADMIN HOME FINAL CLEAN === */

.zr-admin-home{
  display:flex;
  flex-direction:column;
  gap:16px;
}

.zr-admin-home .item{
  background:transparent;
  border:none;
  padding:0;
  box-shadow:none;
}

.zr-admin-home__hero{
  padding:18px 20px;
  border-radius:16px;
  background:rgba(42,40,38,.88);
}

.zr-admin-home__hero-title{
  font-size:20px;
  font-weight:700;
  line-height:1.2;
}

.zr-admin-home__hero-sub{
  margin-top:8px;
  color:var(--muted);
  line-height:1.45;
}

.zr-admin-home__card{
  padding:16px;
  border-radius:14px;
  background:rgba(42,40,38,.9);
  text-align:left;
}

.zr-admin-home__card-title{
  font-size:15px;
  font-weight:700;
  line-height:1.2;
}

.zr-admin-home__card-sub{
  margin-top:6px;
  color:var(--muted);
  line-height:1.35;
  font-size:12px;
}

.zr-admin-home__card--content{
  cursor:default;
}

.zr-admin-home__content-list{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:10px 14px;
  align-items:start;
  margin-top:14px;
}

.zr-admin-home__content-note{
  align-self:center;
  min-width:0;
  color:var(--muted);
  font-size:12px;
  line-height:1.35;
}

.zr-admin-home__content-list .btn{
  justify-self:start;
}

.zr-admin-home__content-list .btn:hover,
.zr-admin-home__content-list .btn:focus,
.zr-admin-home__content-list .btn:active{
  border-color:var(--border);
  background:var(--card);
  box-shadow:none;
  transform:none;
}

@media (max-width: 760px){
  .zr-admin-home__content-list{
    grid-template-columns:1fr;
    gap:8px;
  }

  .zr-admin-home__content-note{
    margin-top:-2px;
    margin-bottom:4px;
  }
}

/* === ARTICLES: CALLOUTS === */

.kb-callout{
  margin:14px 0;
  padding:12px 14px;
  border-left:2px solid var(--border);
  border-radius:0 12px 12px 0;
  background:rgba(255,243,234,.04);
}

.kb-callout-title{
  display:block;
  margin-bottom:6px;
  font-size:11px;
  line-height:1.2;
  font-weight:700;
  letter-spacing:.05em;
  text-transform:uppercase;
  color:var(--headings);
}

.kb-callout-body{
  font-size:14px;
  line-height:1.55;
  color:var(--text);
}

.kb-callout.kb-important{
  border-left-color:var(--accent-35);
  background:rgba(255,243,234,.045);
}

.kb-callout.kb-remember{
  border-left-color:rgba(255,243,234,.22);
  background:rgba(255,243,234,.035);
}

.kb-callout.kb-caution{
  border-left-color:rgba(var(--accent-rgb), .45);
  background:rgba(var(--accent-rgb), .08);
}

/* =========================================================
   MOBILE SHELL — SAFE P0
   ========================================================= */

@media (max-width: 900px){

  .header-inner{
    display:grid;
    grid-template-columns:minmax(0,1fr) auto;
    grid-template-areas:
      "brand auth"
      "search search";
    align-items:center;
    gap:10px;
    padding:10px 12px;
  }

  .brand{
    grid-area:brand;
    display:flex;
    align-items:center;
    gap:10px;
    min-width:0;
  }

  .brand > div{
    min-width:0;
  }

  .logo-img{
    height:72px;
    width:auto;
    object-fit:contain;
    display:block;
    flex:0 0 auto;
  }

  .brand h1{
    margin:0;
    font-size:18px;
    line-height:1;
    letter-spacing:.04em;
    color:rgba(255,243,234,.64);
  }

  .brand small{
    display:none;
  }

  .header-inner > div:last-child{
    grid-area:auth;
    display:flex;
    align-items:center;
    gap:6px;
    justify-content:flex-end;
  }

  .search{
    grid-area:search;
    width:100%;
    max-width:none;
    flex:1 1 100%;
  }

  #authArea{
    gap:6px;
    flex-wrap:wrap;
    justify-content:flex-end;
  }

  .main{
    grid-template-columns:1fr;
    gap:12px;
    padding:12px;
    height:auto;
    max-width:100%;
  }

  .panel,
  .viewer{
    min-width:0;
    width:100%;
    max-width:100%;
  }

  .viewer{
    padding:14px;
    overflow:visible;
  }

  #viewer{
    height:auto;
    min-height:420px;
  }

  #tabs{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:8px;
  }

  #tabs > .tab{
    width:100%;
    margin:0;
    max-width:none;
  }

  #tabs > .tab:first-child{
    grid-column:1 / -1;
  }

  #list{
    overflow:visible;
  }

  body:has(#viewer .zr-board-screen) #list,
  body:has(#viewer .zr-planner-detail) #list{
    display:none;
  }

  .zr-board-toolbar{
    position:static;
    top:auto;
    grid-template-columns:1fr;
    gap:10px;
    padding:0 0 10px 0;
    background:transparent;
    border-bottom:0;
    box-shadow:none;
  }

  .zr-board-toolbar__right{
    justify-content:flex-start;
  }

  #plBoard{
    overflow:visible;
  }

  #plBoard > .zr-board-row{
    display:flex;
    flex-direction:column;
    gap:12px;
  }

  #plBoard > .zr-board-row > .zr-board-col{
    width:100% !important;
    max-width:100% !important;
    min-width:0 !important;
    flex:none !important;
    min-height:0;
  }

  .zr-planner-grid,
  .zr-planner-grid.zr-planner-grid--compact-top,
  .zr-planner-grid.zr-planner-grid--no-details,
  .zr-planner-grid.zr-planner-grid--no-sidecol{
    grid-template-columns:1fr;
  }

  .zr-planner-row,
  .zr-row-2,
  .zr-form-grid{
    grid-template-columns:1fr;
  }

  .zr-planner-hero{
    padding:12px;
  }

  .zr-planner-hero-top{
    display:flex;
    flex-direction:row;
    align-items:flex-start;
    justify-content:space-between;
    gap:10px;
  }

  .zr-planner-hero-main{
    flex:1;
    min-width:0;
  }

  #plBack{
    flex:0 0 auto;
    align-self:flex-start;
  }

  .zr-planner-hero-top-actions,
  .zr-planner-actions-admin,
  .zr-planner-actions-status,
  .zr-viewer-header-actions,
  .zr-actions-right{
    width:100%;
    display:flex;
    flex-wrap:wrap;
    justify-content:flex-start;
    gap:8px;
  }

  .zr-planner-hero-top-actions #plBack{
    margin-left:auto;
    order:-1;
  }

  .zr-viewer-header-row{
    flex-direction:column;
    align-items:flex-start;
    gap:10px;
  }

  .zr-viewer-header-main{
    width:100%;
  }

  .article-layout{
    grid-template-columns:1fr !important;
  }

  .article-toc{
    position:relative;
    top:auto;
    width:100%;
  }

  .zr-admin-home__content-list{
    grid-template-columns:1fr;
  }

  .zr-admin-mode-tabs,
  .zr-admin-content-tabs,
  #list > .actions.zr-admin-mode-tabs{
    display:flex;
    flex-wrap:wrap;
    gap:8px;
    min-height:0;
  }

  .zr-admin-editor__grid,
  .zr-admin-editor__row{
    grid-template-columns:1fr;
  }

  /* === PLANNER DETAIL MOBILE: ACTIONS LAYOUT === */

  .zr-planner-hero-top{
    display:grid;
    grid-template-columns:minmax(0,1fr) auto;
    grid-template-areas:
      "title back"
      "admin admin";
    gap:8px 10px;
    align-items:start;
  }

  .zr-planner-hero-main{
    grid-area:title;
    min-width:0;
  }

  .zr-planner-hero-top-actions{
    display:contents;
  }

  .zr-planner-hero-top-nav{
    grid-area:back;
    display:flex;
    justify-content:flex-end;
    align-self:start;
  }

  .zr-planner-hero-top-admin{
    grid-area:admin;
    display:flex;
    justify-content:flex-start;
    width:100%;
  }

  #plBack{
    margin-left:0;
    width:auto;
  }

  #plEditTask{
    width:auto;
  }

  /* общая вертикальная колонка блоков */
  .zr-planner-actions{
    display:flex;
    flex-direction:column;
    gap:10px;
    width:100%;
  }

  /* статусные кнопки всегда выше */
  .zr-planner-actions-status{
    order:1;
    display:flex;
    flex-direction:column;
    gap:8px;
    width:100%;
  }

  .zr-planner-actions-status .btn{
    width:100%;
    min-width:0;
    justify-content:center;
  }

  /* админские кнопки ниже, в 2 колонки */
  .zr-planner-actions-admin{
    order:2;
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:8px;
    width:100%;
  }

  .zr-planner-actions-admin .btn{
    width:100%;
    min-width:0;
    justify-content:center;
  }

  /* если в админском блоке внезапно останется одна кнопка */
  .zr-planner-actions-admin .btn:only-child{
    grid-column:1 / -1;
  }

  input,
  select,
  textarea{
    max-width:100%;
  }
}

/* =========================================================
   Update notice — app version refresh
   ========================================================= */

#zrUpdateNotice{
  position: fixed;
  right: 24px;
  bottom: 24px;
  z-index: 99999;

  width: min(360px, calc(100vw - 32px));
  padding: 14px 14px 14px 16px;

  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;

  background:
    linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.015)),
    var(--brand-panel);
  border: 1px solid var(--brand-border-accent);
  border-radius: 18px;

  color: var(--text);
  box-shadow:
    0 24px 70px rgba(0,0,0,.42),
    0 0 0 1px rgba(255,255,255,.035) inset;

  backdrop-filter: blur(14px);
}

.zr-update-notice__text{
  font-size: 13px;
  line-height: 1.35;
  color: var(--brand-text);
}

.zr-update-notice__btn{
  border: 0;
  outline: 0;
  flex: 0 0 auto;

  padding: 9px 13px;
  border-radius: 999px;

  background: var(--brand-accent);
  color: #fff;

  font-size: 13px;
  font-weight: 600;
  line-height: 1;

  cursor: pointer;
  transition:
    transform .14s ease,
    filter .14s ease,
    background-color .14s ease;
}

.zr-update-notice__btn:hover{
  filter: brightness(1.08);
}

.zr-update-notice__btn:active{
  transform: translateY(1px);
}

@media (max-width: 640px){
  #zrUpdateNotice{
    left: 12px;
    right: 12px;
    bottom: 12px;
    width: auto;
    padding: 13px;
    border-radius: 16px;
  }

  .zr-update-notice__text{
    font-size: 12px;
  }

  .zr-update-notice__btn{
    padding: 8px 12px;
    font-size: 12px;
  }
}

