
:root{
  --bg:#f5f7fb;
  --panel:#ffffff;
  --panel-2:#f8fafc;
  --border:#e6ebf3;
  --text:#152033;
  --muted:#667085;
  --primary:#16a34a;
  --primary-2:#22c55e;
  --accent:#0ea5e9;
  --role-superadmin:#5b21b6;
  --role-admin:#1d4ed8;
  --role-director:#be185d;
  --role-pr:#0f766e;
  --role-creative:#e11d48;
  --role-designer:#7c3aed;
  --role-copywriter:#c2410c;
  --role-consultant:#15803d;
  --role-advertiser:#0369a1;
  --role-client:#334155;
  --role-readonly:#475569;
  --danger:#ef4444;
  --warning:#f59e0b;
  --radius:22px;
  --shadow:0 10px 30px rgba(16,24,40,.06);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:linear-gradient(180deg,#f6f8fc 0%,#eef3f7 100%);color:var(--text);font-family:Inter,Segoe UI,Arial,sans-serif}
a{color:inherit;text-decoration:none}
code,pre{font-family:ui-monospace,SFMono-Regular,Consolas,monospace}
.public-wrapper{max-width:1180px;margin:0 auto;padding:40px 20px 24px}
.site-footer{max-width:1180px;margin:10px auto 40px;padding:0 20px;display:flex;justify-content:space-between;gap:16px;color:var(--muted);font-size:.9rem}
.footer-links{display:flex;gap:16px;flex-wrap:wrap}
.footer-links a,.site-footer a{color:inherit;text-decoration:underline;text-underline-offset:3px}
.footer-preview{padding:14px 16px;border:1px dashed var(--border);border-radius:18px;background:rgba(255,255,255,.72);color:var(--text);line-height:1.6}
.footer-preview a{font-weight:700}
.table-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.app-layout{display:grid;grid-template-columns:290px 1fr;min-height:calc(100vh - 90px)}
.sidebar{padding:28px 22px;border-right:1px solid var(--border);background:rgba(255,255,255,.75);backdrop-filter:blur(18px);display:flex;flex-direction:column;gap:24px}
.brand{display:flex;align-items:center;gap:14px}
.brand-mark{width:48px;height:48px;border-radius:16px;background:linear-gradient(135deg,var(--accent),var(--primary-2));display:grid;place-items:center;color:#fff;font-weight:800;box-shadow:var(--shadow)}
.brand small{display:block;color:var(--muted);margin-top:3px}
.side-nav{display:flex;flex-direction:column;gap:10px}
.side-link{padding:14px 16px;border-radius:16px;color:var(--muted);font-weight:600}
.side-link:hover,.side-link.active{background:#fff;color:var(--text);box-shadow:var(--shadow)}
.sidebar-footer{margin-top:auto;display:grid;gap:16px}
.mini-user{display:flex;gap:12px;align-items:center;padding:14px;background:#fff;border:1px solid var(--border);border-radius:18px}
.avatar{width:42px;height:42px;border-radius:14px;background:linear-gradient(135deg,color-mix(in srgb,var(--accent) 18%, white),color-mix(in srgb,var(--primary-2) 22%, white));display:grid;place-items:center;font-weight:800;overflow:hidden;flex:none}
.avatar-image img{width:100%;height:100%;object-fit:cover;display:block}
.ghost-link{padding:12px 14px;border:1px solid var(--border);border-radius:14px;text-align:center;background:#fff;color:var(--muted)}
.main-panel{padding:22px 24px 30px}
.topbar{display:flex;justify-content:space-between;align-items:flex-start;gap:18px;margin-bottom:20px}
.topbar h1{margin:0;font-size:2rem}
.topbar p{margin:6px 0 0;color:var(--muted)}
.topbar-actions{display:flex;gap:12px;flex-wrap:wrap}
.content{display:grid;gap:18px}
.panel{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:22px}
.panel-public{padding:34px}
.panel.narrow{max-width:740px;margin:0 auto}
.center{text-align:center}
.hero-public{display:grid;grid-template-columns:1.3fr .9fr;gap:22px;align-items:center;min-height:58vh}
.hero-public h1{font-size:3rem;margin:10px 0}
.hero-card{background:#fff;border:1px solid var(--border);border-radius:28px;padding:24px;box-shadow:var(--shadow)}
.eyebrow{display:inline-flex;padding:8px 12px;border-radius:999px;background:#ecfeff;color:#0f766e;font-weight:700;font-size:.85rem}
.lead{font-size:1.12rem;color:var(--muted)}
.promo-highlight{display:inline-block;margin:14px 0;padding:12px 18px;border-radius:16px;background:linear-gradient(135deg,#dcfce7,#dbeafe);font-weight:800;font-size:1.4rem}
.cards{display:grid;gap:16px}
.cards.three{grid-template-columns:repeat(3,1fr)}
.cards.four{grid-template-columns:repeat(4,1fr)}
.stat-card{background:linear-gradient(180deg,#fff,#f7fbff);border:1px solid var(--border);border-radius:22px;box-shadow:var(--shadow);padding:20px;display:grid;gap:8px}
.stat-card span{color:var(--muted);font-size:.92rem}
.stat-card strong{font-size:2rem}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.panel-head{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:18px}
.panel-head h2,.panel h2,.panel h3{margin:0}
.field{display:grid;gap:8px}
.field label{font-weight:700;font-size:.95rem}
.field input,.field select,.field textarea,.code-box{
  width:100%;background:#fff;border:1px solid var(--border);border-radius:16px;padding:14px 16px;color:var(--text);font:inherit
}
.field textarea{resize:vertical}
.checkbox-field label{display:flex;align-items:center;gap:10px;font-weight:600}
.checkbox-field input{width:auto}
.grid-form{display:grid;gap:16px}
.grid-form.two{grid-template-columns:1fr 1fr}
.grid-form .full{grid-column:1/-1}
.inline-fields{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.stack{display:grid;gap:16px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;border-radius:16px;padding:12px 16px;font-weight:700;border:1px solid transparent;cursor:pointer}
.btn-primary{background:linear-gradient(135deg,var(--primary),var(--primary-2));color:#fff;box-shadow:0 10px 24px rgba(34,197,94,.25)}
.btn-soft{background:#fff;border-color:var(--border);color:var(--text)}
.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;box-shadow:0 10px 24px rgba(239,68,68,.22)}
.btn-block{width:100%}
.filters .filter-form{display:grid;grid-template-columns:1.2fr 1fr 1fr auto;gap:14px;align-items:end}
.filters .grow{grid-column:auto}
.actions{align-self:end}
.table-wrap{overflow:auto}
table{width:100%;border-collapse:separate;border-spacing:0}
th,td{padding:14px 12px;border-bottom:1px solid var(--border);text-align:left;vertical-align:top}
th{font-size:.88rem;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}
.item-row,.agenda-row{display:flex;justify-content:space-between;gap:16px;align-items:center;padding:14px 0;border-bottom:1px solid var(--border)}
.item-row:last-child,.agenda-row:last-child{border-bottom:none}
.item-card{padding:16px;border:1px solid var(--border);border-radius:18px;background:var(--panel-2);display:grid;gap:8px;margin-bottom:14px}
.item-card p{margin:0;color:var(--muted)}
.dot{width:12px;height:12px;border-radius:999px;display:inline-block;flex:none}
.badge{display:inline-flex;align-items:center;justify-content:center;padding:6px 10px;border-radius:999px;background:#dcfce7;color:#166534;font-size:.8rem;font-weight:700}
.badge-soft{background:#eff6ff;color:#1d4ed8}
.alert{padding:14px 16px;border-radius:16px;border:1px solid var(--border);margin-bottom:16px}
.alert-success{background:#f0fdf4;color:#166534;border-color:#bbf7d0}
.alert-danger{background:#fef2f2;color:#991b1b;border-color:#fecaca}
.alert-warning{background:#fffbeb;color:#92400e;border-color:#fde68a}
.calendar-toolbar{display:flex;justify-content:space-between;align-items:center;gap:18px}
.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:10px}
.calendar-head{padding:10px 12px;color:var(--muted);font-weight:700}
.calendar-day{min-height:170px;background:#fff;border:1px solid var(--border);border-radius:20px;padding:12px;display:grid;grid-template-rows:auto 1fr}
.calendar-day header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.muted-day{opacity:.55}
.calendar-events{display:grid;gap:8px;align-content:start}
.event-pill{display:grid;gap:4px;border-radius:14px;padding:10px;background:color-mix(in srgb, var(--pill-color) 12%, white);border-left:4px solid var(--pill-color)}
.event-pill span{font-size:.78rem;color:var(--muted)}
.event-pill strong{font-size:.9rem}
.company-hero{display:flex;justify-content:space-between;gap:18px;align-items:flex-start}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap}
.subtabs{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px}
.subtabs a{padding:10px 14px;border-radius:14px;background:#f8fafc;color:var(--muted);font-weight:700}
.subtabs a.active{background:#111827;color:#fff}
.subtabs.vertical{flex-direction:column;margin-top:0}
.details-list{display:grid;gap:14px}
.details-list div{padding:12px 0;border-bottom:1px solid var(--border)}
.details-list dt{font-size:.82rem;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}
.details-list dd{margin:6px 0 0;font-weight:700}
.sep{border:none;border-top:1px solid var(--border);margin:18px 0}
.qr-preview{max-width:280px;width:100%;height:auto;border-radius:22px;border:1px solid var(--border);padding:10px;background:#fff}
.prose{line-height:1.7}
.prose.small{font-size:.92rem}
.prose h1,.prose h2,.prose h3{margin-top:0}
.muted{color:var(--muted)}
.code-box{background:#0f172a;color:#e2e8f0;overflow:auto}
@media (max-width:1100px){
  .cards.four,.cards.three,.grid-2,.hero-public,.grid-form.two,.filters .filter-form{grid-template-columns:1fr}
  .app-layout{grid-template-columns:1fr}
  .sidebar{border-right:none;border-bottom:1px solid var(--border)}
  .calendar-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:720px){
  .calendar-grid{grid-template-columns:1fr}
  .topbar,.company-hero,.site-footer{flex-direction:column}
  .main-panel{padding:18px 14px 26px}
  .public-wrapper{padding:24px 14px}
  .hero-public h1{font-size:2.1rem}
}


.role-chip{
  display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;font-size:.78rem;font-weight:800;line-height:1;border:1px solid transparent
}
.role-super_admin{background:color-mix(in srgb,var(--role-superadmin) 14%, white);color:var(--role-superadmin);border-color:color-mix(in srgb,var(--role-superadmin) 28%, white)}
.role-admin,.tone-admin{background:color-mix(in srgb,var(--role-admin) 14%, white);color:var(--role-admin);border-color:color-mix(in srgb,var(--role-admin) 28%, white)}
.role-director,.tone-creative{background:color-mix(in srgb,var(--role-director) 14%, white);color:var(--role-director);border-color:color-mix(in srgb,var(--role-director) 28%, white)}
.role-pr,.tone-pr{background:color-mix(in srgb,var(--role-pr) 14%, white);color:var(--role-pr);border-color:color-mix(in srgb,var(--role-pr) 28%, white)}
.role-creative{background:color-mix(in srgb,var(--role-creative) 14%, white);color:var(--role-creative);border-color:color-mix(in srgb,var(--role-creative) 28%, white)}
.role-designer,.tone-design{background:color-mix(in srgb,var(--role-designer) 14%, white);color:var(--role-designer);border-color:color-mix(in srgb,var(--role-designer) 28%, white)}
.role-copywriter,.tone-copy{background:color-mix(in srgb,var(--role-copywriter) 14%, white);color:var(--role-copywriter);border-color:color-mix(in srgb,var(--role-copywriter) 28%, white)}
.role-consultant,.tone-consulting{background:color-mix(in srgb,var(--role-consultant) 14%, white);color:var(--role-consultant);border-color:color-mix(in srgb,var(--role-consultant) 28%, white)}
.role-advertiser,.tone-adv{background:color-mix(in srgb,var(--role-advertiser) 14%, white);color:var(--role-advertiser);border-color:color-mix(in srgb,var(--role-advertiser) 28%, white)}
.role-client{background:color-mix(in srgb,var(--role-client) 12%, white);color:var(--role-client);border-color:color-mix(in srgb,var(--role-client) 26%, white)}
.role-readonly{background:color-mix(in srgb,var(--role-readonly) 12%, white);color:var(--role-readonly);border-color:color-mix(in srgb,var(--role-readonly) 26%, white)}
.role-cards{margin-top:2px}
.role-card{
  border-radius:24px;border:1px solid var(--border);padding:20px;display:grid;gap:8px;box-shadow:var(--shadow);background:#fff
}
.role-card span{font-size:.88rem;font-weight:700;opacity:.9}
.role-card strong{font-size:2rem;line-height:1}
.role-card small{color:var(--muted)}
.task-card{
  border:1px solid var(--border);border-radius:22px;padding:18px 18px 16px;background:linear-gradient(180deg,#fff, #fbfdff);display:grid;gap:10px;margin-bottom:14px
}
.task-head{display:flex;justify-content:space-between;gap:16px;align-items:flex-start}
.task-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.task-meta{color:var(--muted);font-size:.92rem}
.status-chip{
  display:inline-flex;align-items:center;padding:8px 11px;border-radius:999px;background:#f8fafc;border:1px solid var(--border);font-size:.78rem;font-weight:800;text-transform:uppercase;letter-spacing:.04em
}
.status-todo,.status-proposed,.status-planned{background:#fff7ed;color:#9a3412;border-color:#fed7aa}
.status-assigned,.status-writing,.status-active,.status-in_progress,.status-shared{background:#eff6ff;color:#1d4ed8;border-color:#bfdbfe}
.status-draft_ready,.status-review,.status-to_verify,.status-paused{background:#fefce8;color:#854d0e;border-color:#fde68a}
.status-approved,.status-done,.status-completed,.status-ready_to_publish{background:#f0fdf4;color:#166534;border-color:#bbf7d0}
.status-delivered,.status-published,.status-archived{background:#f8fafc;color:#475569;border-color:#cbd5e1}
.status-rejected,.status-blocked,.status-cancelled{background:#fef2f2;color:#991b1b;border-color:#fecaca}
.side-link[href*="design"]{border-left:4px solid #a855f7}
.side-link[href*="copy"]{border-left:4px solid #f97316}
.side-link[href*="consulting"]{border-left:4px solid #22c55e}
.side-link[href*="ads"]{border-left:4px solid #0ea5e9}
.side-link[href*="movements"]{border-left:4px solid #14b8a6}
.side-link[href*="calendar"]{border-left:4px solid #111827}
.task-card p{margin:0;color:var(--text);line-height:1.55}
@media (max-width:720px){
  .task-head{flex-direction:column}
}

/* ===== Responsive patch 1.2.1 ===== */
body.nav-open{overflow:hidden}
.topbar-main{display:flex;align-items:flex-start;gap:14px}
.mobile-nav-toggle{display:none;width:48px;height:48px;border:1px solid var(--border);border-radius:16px;background:#fff;box-shadow:var(--shadow);font-size:1.2rem;line-height:1;cursor:pointer;color:var(--text);flex:none}
.mobile-backdrop{display:none}
.filters .filter-form{grid-template-columns:repeat(4,minmax(0,1fr)) auto}
.filters .filter-form .grow{grid-column:span 2}
.table-wrap{width:100%}
.table-wrap table{min-width:100%}
.btn{white-space:nowrap}
.calendar-toolbar h2{text-transform:capitalize;font-size:1.9rem;line-height:1.05;margin:0}
.calendar-day header span:first-child{font-weight:800}
.calendar-day.today{border-color:#bbf7d0;box-shadow:0 0 0 1px #bbf7d0 inset, var(--shadow)}
@media (max-width:1180px){
  .filters .filter-form{grid-template-columns:repeat(2,minmax(0,1fr))}
  .filters .filter-form .grow,.filters .filter-form .actions{grid-column:auto}
}
@media (max-width:960px){
  .app-layout{grid-template-columns:1fr;min-height:100vh}
  .sidebar{position:fixed;top:0;left:0;bottom:0;width:min(86vw,320px);z-index:60;transform:translateX(-104%);transition:transform .22s ease;padding-top:20px;overflow:auto;border-right:1px solid var(--border);border-bottom:none;background:rgba(255,255,255,.96)}
  body.nav-open .sidebar{transform:translateX(0)}
  .mobile-backdrop{position:fixed;inset:0;background:rgba(15,23,42,.28);backdrop-filter:blur(2px);z-index:50}
  body.nav-open .mobile-backdrop{display:block}
  .main-panel{padding:14px 12px 24px}
  .topbar{position:sticky;top:0;z-index:30;background:rgba(245,247,251,.92);backdrop-filter:blur(12px);padding:10px 0 12px;margin-bottom:14px;align-items:flex-start}
  .topbar h1{font-size:1.45rem;line-height:1.05}
  .topbar p{font-size:.92rem;margin-top:4px}
  .topbar-actions{width:100%;display:grid;grid-template-columns:1fr 1fr}
  .topbar-actions .btn{width:100%}
  .topbar-main{width:100%}
  .mobile-nav-toggle{display:inline-grid;place-items:center}
  .panel{padding:18px}
  .panel-public{padding:24px}
  .company-hero,.panel-head{align-items:flex-start}
  .company-hero,.topbar,.site-footer{flex-direction:column}
  .hero-actions,.subtabs{width:100%}
  .subtabs a{flex:1 1 auto;text-align:center}
  .calendar-toolbar{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:10px}
  .calendar-toolbar .btn{padding:12px 10px;min-height:60px;white-space:normal;text-align:left}
  .calendar-toolbar .btn:last-child{text-align:right;justify-content:flex-end}
  .calendar-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}
  .calendar-day{min-height:160px;padding:10px;border-radius:18px}
  .grid-form.two,.inline-fields,.grid-2,.cards.four,.cards.three,.hero-public{grid-template-columns:1fr}
}
@media (max-width:720px){
  .public-wrapper{padding:20px 12px}
  .hero-public{min-height:auto}
  .hero-public h1{font-size:2rem;line-height:1.02}
  .lead{font-size:1rem}
  .topbar-actions{grid-template-columns:1fr}
  .filters .filter-form{grid-template-columns:1fr}
  .calendar-toolbar{grid-template-columns:1fr 1fr;gap:10px}
  .calendar-toolbar h2{grid-column:1 / -1;order:-1;font-size:1.65rem}
  .calendar-grid{grid-template-columns:1fr}
  .calendar-head{display:none}
  .calendar-day{min-height:auto}
  .calendar-day header{display:grid;grid-template-columns:auto auto;align-items:center;gap:6px 10px;margin-bottom:10px}
  .calendar-day header::before{content:attr(data-weekday);grid-column:1 / -1;font-size:.84rem;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}
  .event-pill{padding:10px 12px}
  .table-wrap{overflow:visible}
  .table-wrap table,.table-wrap thead,.table-wrap tbody,.table-wrap tr,.table-wrap th,.table-wrap td{display:block;width:100%}
  .table-wrap thead{position:absolute;left:-9999px;top:-9999px}
  .table-wrap tbody{display:grid;gap:14px}
  .table-wrap tr{border:1px solid var(--border);border-radius:20px;background:#fff;box-shadow:var(--shadow);padding:8px 0}
  .table-wrap td{border-bottom:1px solid var(--border);padding:12px 14px}
  .table-wrap td:last-child{border-bottom:none;padding-top:14px}
  .table-wrap td::before{content:attr(data-label);display:block;font-size:.75rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-bottom:6px}
  .table-wrap td[data-label="Azioni"] .btn,.table-wrap td:last-child .btn{width:100%}
  .site-footer{padding:0 12px 28px}
}

/* ===== Theme + Chat 1.3.0 ===== */
html[data-theme="dark"]{
  --bg:#0b1220;
  --panel:#121a2a;
  --panel-2:#0f1726;
  --border:#223049;
  --text:#e5eefc;
  --muted:#9fb0ca;
  --shadow:0 16px 36px rgba(0,0,0,.24);
}
html[data-theme="dark"] body,
html[data-theme="dark"] html,body[data-theme="dark"]{background:linear-gradient(180deg,#0a1020 0%,#10192c 100%);color:var(--text)}
html[data-theme="dark"] .sidebar,
html[data-theme="dark"] .topbar,
html[data-theme="dark"] .hero-card,
html[data-theme="dark"] .mini-user,
html[data-theme="dark"] .ghost-link,
html[data-theme="dark"] .field input,
html[data-theme="dark"] .field select,
html[data-theme="dark"] .field textarea,
html[data-theme="dark"] .panel,
html[data-theme="dark"] .stat-card,
html[data-theme="dark"] .task-card,
html[data-theme="dark"] .calendar-day,
html[data-theme="dark"] .role-card,
html[data-theme="dark"] .table-wrap tr,
html[data-theme="dark"] .side-link:hover,
html[data-theme="dark"] .side-link.active,
html[data-theme="dark"] .btn-soft,
html[data-theme="dark"] .theme-toggle,
html[data-theme="dark"] .chat-thread-item,
html[data-theme="dark"] .chat-bubble.theirs,
html[data-theme="dark"] .chat-bubble.mine,
html[data-theme="dark"] .chat-messages,
html[data-theme="dark"] .chat-compose textarea{background:var(--panel);color:var(--text);border-color:var(--border)}
html[data-theme="dark"] .side-link{color:#a9b6ca}
html[data-theme="dark"] .subtabs a{background:#0d1627;color:#a8b5cc}
html[data-theme="dark"] .subtabs a.active{background:#e5eefc;color:#0b1220}
html[data-theme="dark"] .event-pill{background:color-mix(in srgb, var(--pill-color) 20%, #0f1726)}
html[data-theme="dark"] .mobile-nav-toggle,
html[data-theme="dark"] .theme-toggle{background:var(--panel);color:var(--text);border-color:var(--border)}
html[data-theme="dark"] .code-box{background:#020817;color:#dbeafe}
html[data-theme="dark"] .site-footer,html[data-theme="dark"] .footer-links a{color:var(--muted)}
.theme-toggle{min-width:54px}
.theme-toggle.floating{position:fixed;top:18px;right:18px;z-index:40}
.chat-shell{display:grid;grid-template-columns:320px minmax(0,1fr) 300px;gap:18px;min-height:calc(100vh - 220px)}
.chat-sidebar,.chat-main,.chat-meta{display:flex;flex-direction:column;min-height:0}
.chat-sidebar-top,.chat-main-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;margin-bottom:16px}
.chat-sidebar-top h2,.chat-main-head h2{margin:0}
.chat-search{margin-bottom:14px}
.chat-thread-list{display:grid;gap:10px;overflow:auto;padding-right:2px}
.chat-thread-item{display:grid;grid-template-columns:56px minmax(0,1fr);gap:12px;padding:14px;border:1px solid var(--border);border-radius:20px;background:linear-gradient(180deg,#fff,#fbfdff);box-shadow:var(--shadow)}
.chat-thread-item.active{border-color:#86efac;box-shadow:0 0 0 1px #86efac inset,var(--shadow)}
.chat-thread-avatar{width:56px;height:56px;border-radius:18px;display:grid;place-items:center;font-weight:800;font-size:1.05rem;border:1px solid var(--border)}
.chat-thread-copy{min-width:0}
.chat-thread-copy p{margin:.35rem 0 0;color:var(--muted);font-size:.92rem}
.chat-thread-line{display:flex;justify-content:space-between;gap:10px;align-items:center}
.chat-thread-line strong,.chat-thread-line span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.chat-thread-line small{color:var(--muted);flex:none}
.chat-thread-line.secondary{margin-top:4px;color:var(--muted);font-size:.88rem}
.chat-unread{display:inline-grid;place-items:center;min-width:24px;height:24px;border-radius:999px;background:linear-gradient(135deg,var(--primary),var(--primary-2));color:#fff;font-size:.78rem;font-weight:800;padding:0 6px}
.chat-main{padding-bottom:16px}
.chat-messages{display:grid;gap:12px;overflow:auto;padding:6px 2px 18px;min-height:440px;max-height:calc(100vh - 390px);background:linear-gradient(180deg,rgba(14,165,233,.02),rgba(34,197,94,.02));border-radius:22px}
.chat-bubble{max-width:min(78%,680px);padding:14px 16px;border-radius:22px;border:1px solid var(--border);box-shadow:var(--shadow)}
.chat-bubble.mine{margin-left:auto;background:linear-gradient(135deg,rgba(34,197,94,.12),rgba(14,165,233,.10))}
.chat-bubble.theirs{margin-right:auto;background:linear-gradient(180deg,#fff,#f8fbff)}
.chat-bubble-meta{display:flex;justify-content:space-between;gap:12px;font-size:.8rem;color:var(--muted);margin-bottom:8px}
.chat-bubble-body{line-height:1.6;word-break:break-word}
.chat-compose{display:grid;gap:12px;margin-top:14px}
.chat-compose textarea{width:100%;border:1px solid var(--border);border-radius:20px;padding:16px;font:inherit;min-height:110px;resize:vertical;background:#fff;color:var(--text)}
.chat-compose-actions{display:flex;justify-content:space-between;gap:12px;align-items:center;flex-wrap:wrap}
.chat-meta .details-list.compact div{padding:10px 0}
.compact-stack{gap:10px}
.role-line{padding:10px 12px}
.empty-chat,.chat-empty-state{display:grid;place-items:center;min-height:220px;text-align:center}
.side-link[href*="chat"]{border-left:4px solid #6366f1}
@media (max-width:1240px){
  .chat-shell{grid-template-columns:300px minmax(0,1fr)}
  .chat-meta{grid-column:1 / -1}
}
@media (max-width:960px){
  .chat-shell{grid-template-columns:1fr}
  .chat-thread-list{max-height:none}
  .chat-messages{max-height:none;min-height:280px}
}
@media (max-width:720px){
  .theme-toggle.floating{top:12px;right:12px}
  .chat-bubble{max-width:100%}
  .chat-main-head,.chat-sidebar-top,.chat-compose-actions{flex-direction:column;align-items:stretch}
}

/* ===== Chat refinement 1.3.1 ===== */
.chat-shell{grid-template-columns:340px minmax(0,1fr) 280px;align-items:stretch}
.chat-main{padding:0;overflow:hidden}
.chat-main-head{padding:22px 22px 14px;border-bottom:1px solid var(--border);background:linear-gradient(180deg,rgba(255,255,255,.72),rgba(248,250,252,.9))}
html[data-theme="dark"] .chat-main-head{background:linear-gradient(180deg,rgba(18,26,42,.95),rgba(15,23,38,.92))}
.chat-messages.messenger-style{display:flex;flex-direction:column;align-items:flex-start;gap:10px;padding:22px;min-height:360px;max-height:calc(100vh - 420px);overflow:auto;background:linear-gradient(180deg,rgba(14,165,233,.03),rgba(34,197,94,.03))}
.chat-bubble{display:flex;flex-direction:column;align-self:flex-start;width:auto;max-width:min(62%,520px);padding:10px 12px;border-radius:18px;border:1px solid var(--border);box-shadow:0 10px 24px rgba(15,23,42,.08)}
.chat-bubble.mine{align-self:flex-end;background:linear-gradient(135deg,rgba(34,197,94,.14),rgba(14,165,233,.12))}
.chat-bubble.theirs{align-self:flex-start;background:linear-gradient(180deg,#fff,#f8fbff)}
.chat-bubble.compact{max-width:min(76%,320px);padding:9px 11px;border-radius:16px}
.chat-bubble-meta{display:flex;gap:10px;justify-content:space-between;font-size:.78rem;color:var(--muted);margin-bottom:6px}
.chat-bubble-meta span:last-child{flex:none}
.chat-bubble-body{line-height:1.45}
.chat-compose{padding:14px 22px 20px;border-top:1px solid var(--border);background:rgba(255,255,255,.68)}
html[data-theme="dark"] .chat-compose{background:rgba(18,26,42,.9)}
.chat-compose textarea{min-height:84px}
.chat-thread-item{transition:transform .14s ease,border-color .14s ease,box-shadow .14s ease}
.chat-thread-item:hover{transform:translateY(-1px)}
.chat-thread-item.active{border-color:#86efac;box-shadow:0 0 0 1px #86efac inset,0 16px 32px rgba(34,197,94,.10)}
.chat-head-actions{display:flex;gap:10px;flex-wrap:wrap}

.chat-dock{position:fixed;right:18px;bottom:18px;z-index:90}
.chat-fab{display:inline-flex;align-items:center;gap:10px;border:none;border-radius:999px;padding:14px 18px;background:linear-gradient(135deg,var(--primary),var(--primary-2));color:#fff;font-weight:800;box-shadow:0 18px 36px rgba(34,197,94,.28);cursor:pointer}
.chat-fab-icon{font-size:1.05rem}
.chat-fab-badge{display:inline-grid;place-items:center;min-width:22px;height:22px;padding:0 6px;border-radius:999px;background:#fff;color:#0f172a;font-size:.76rem;font-weight:900}
.chat-dock-window{position:absolute;right:0;bottom:76px;width:min(390px,calc(100vw - 24px));height:min(72vh,620px);display:flex;flex-direction:column;border:1px solid var(--border);border-radius:24px;background:rgba(255,255,255,.98);box-shadow:0 24px 64px rgba(15,23,42,.22);overflow:hidden;backdrop-filter:blur(14px)}
html[data-theme="dark"] .chat-dock-window{background:rgba(18,26,42,.98)}
.chat-window-head{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--border);background:linear-gradient(180deg,rgba(248,250,252,.95),rgba(255,255,255,.82))}
html[data-theme="dark"] .chat-window-head{background:linear-gradient(180deg,rgba(18,26,42,.96),rgba(15,23,38,.94))}
.chat-window-head-copy{display:grid;gap:2px;min-width:0}
.chat-window-head-copy strong,.chat-window-head-copy small{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.chat-window-head-copy small{color:var(--muted)}
.chat-window-actions{display:flex;gap:8px}
.icon-btn{display:inline-grid;place-items:center;width:34px;height:34px;border-radius:12px;border:1px solid var(--border);background:transparent;color:var(--text);text-decoration:none;font-weight:700}
.chat-window-context{padding:10px 16px;font-size:.85rem;color:var(--muted);border-bottom:1px solid var(--border)}
.chat-window-messages{display:flex;flex-direction:column;align-items:flex-start;gap:10px;flex:1;overflow:auto;padding:14px;background:linear-gradient(180deg,rgba(14,165,233,.03),rgba(34,197,94,.03))}
.chat-window-empty{margin:auto;text-align:center;color:var(--muted);max-width:240px;line-height:1.45}
.chat-window-compose{display:grid;gap:10px;padding:12px;border-top:1px solid var(--border);background:rgba(255,255,255,.9)}
html[data-theme="dark"] .chat-window-compose{background:rgba(18,26,42,.95)}
.chat-window-compose textarea{width:100%;border:1px solid var(--border);border-radius:16px;padding:12px 14px;font:inherit;resize:none;min-height:72px;background:var(--panel);color:var(--text)}
.chat-window-compose-actions{display:flex;justify-content:space-between;gap:10px}
.chat-dock.is-open .chat-fab{box-shadow:0 12px 22px rgba(15,23,42,.18)}

@media (max-width:1240px){
  .chat-shell{grid-template-columns:320px minmax(0,1fr)}
  .chat-meta{grid-column:1 / -1}
}
@media (max-width:960px){
  .chat-shell{grid-template-columns:1fr}
  .chat-main{order:2}
  .chat-sidebar{order:1}
  .chat-meta{order:3}
  .chat-messages.messenger-style{max-height:none;min-height:300px}
  .chat-dock{right:12px;left:12px;bottom:12px}
  .chat-fab{width:100%;justify-content:center}
  .chat-dock-window{right:0;left:0;bottom:70px;width:auto;height:min(74vh,640px)}
}
@media (max-width:720px){
  .chat-bubble,.chat-bubble.compact{max-width:86%}
  .chat-main-head,.chat-compose-actions,.chat-window-compose-actions{flex-direction:column;align-items:stretch}
  .chat-window-head{padding:12px}
  .chat-window-context{padding:10px 12px}
}


/* ===== Chat controls fix 1.3.2 ===== */
.chat-window-actions .icon-btn{cursor:pointer;user-select:none;-webkit-user-select:none;appearance:none;-webkit-appearance:none;line-height:1;position:relative;z-index:3}
.chat-window-actions .icon-btn:hover{background:rgba(15,23,42,.06)}
html[data-theme="dark"] .chat-window-actions .icon-btn:hover{background:rgba(255,255,255,.08)}
.chat-window-actions .icon-btn.danger:hover{background:rgba(239,68,68,.12);border-color:rgba(239,68,68,.28);color:#b91c1c}
html[data-theme="dark"] .chat-window-actions .icon-btn.danger:hover{background:rgba(239,68,68,.18);color:#fecaca}
.chat-window-head{position:relative;z-index:2}
.chat-dock-window[hidden]{display:none !important}


.brand-mark-image{width:48px;height:48px;border-radius:16px;background:#fff;display:grid;place-items:center;overflow:hidden;box-shadow:var(--shadow)}
.brand-mark-image img{width:100%;height:100%;object-fit:contain}
.public-branding{display:flex;justify-content:center;padding:1.5rem 1rem .5rem}
.public-branding img{max-width:min(280px,70vw);max-height:84px;object-fit:contain;filter:drop-shadow(0 10px 24px rgba(15,23,42,.08))}
.divider-soft{border:0;border-top:1px solid var(--border);margin:.25rem 0}
.subsection-title{margin:0 0 .35rem 0;font-size:1.05rem}
.muted{color:var(--muted);margin:0}
.stack-lg{display:grid;gap:1.25rem}
.brand-upload-preview{margin-top:.75rem;display:flex;align-items:center;justify-content:center;min-height:112px;padding:1rem;border:1px dashed var(--border);border-radius:18px;background:rgba(255,255,255,.55)}
.brand-upload-preview img{max-width:100%;max-height:72px;object-fit:contain}
.brand-upload-preview-public{min-height:130px}
.brand-upload-preview-public img{max-height:88px}
.brand-upload-preview-dark{background:linear-gradient(135deg,#0f172a,#1e293b)}
.brand-upload-preview-icon{justify-content:flex-start;min-height:auto;width:max-content}
.brand-upload-preview-icon img{width:48px;height:48px;border-radius:12px}
.check-inline{display:flex;align-items:center;gap:.55rem;margin-top:.65rem;color:var(--muted);font-size:.95rem}
.check-inline input{width:auto}
@media (max-width: 760px){
  .public-branding{padding:1rem 1rem .25rem}
  .public-branding img{max-width:72vw;max-height:72px}
  .brand-upload-preview{min-height:88px}
}

/* ===== Copy board 1.4.0 ===== */
.copy-week-toolbar{display:grid;grid-template-columns:auto 1fr auto;gap:16px;align-items:center;margin:18px 0 22px}
.copy-week-title{display:grid;gap:6px;text-align:center}
.copy-week-title h2{margin:0;font-size:1.35rem}
.copy-week-title p{margin:0;color:var(--muted)}
.copy-board-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:16px;align-items:start}
.copy-day-card{display:grid;gap:14px;padding:16px;border:1px solid var(--border);border-radius:24px;background:linear-gradient(180deg,rgba(255,255,255,.92),rgba(248,250,252,.96));box-shadow:var(--shadow);min-height:280px}
.copy-day-card.is-today{box-shadow:0 0 0 2px rgba(34,197,94,.18),var(--shadow)}
.copy-day-head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding-bottom:12px;border-bottom:1px solid var(--border)}
.copy-day-head strong{display:block;font-size:1.02rem}
.copy-day-weekday{display:block;color:var(--muted);font-size:.82rem;text-transform:uppercase;letter-spacing:.08em;margin-bottom:2px}
.copy-slot-empty{display:grid;place-items:center;min-height:140px;border:1px dashed var(--border);border-radius:18px;color:var(--muted);text-align:center;padding:16px}
.copy-slot-card{display:grid;gap:14px;padding:14px;border-radius:20px;border:1px solid var(--border);background:rgba(255,255,255,.92);box-shadow:0 12px 24px rgba(15,23,42,.06)}
.copy-slot-card.status-collecting_titles{border-color:rgba(245,158,11,.28)}
.copy-slot-card.status-title_approved,.copy-slot-card.status-writing{border-color:rgba(14,165,233,.25)}
.copy-slot-card.status-draft_ready,.copy-slot-card.status-published{border-color:rgba(34,197,94,.25)}
.copy-slot-top{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}
.copy-slot-client{font-weight:800;font-size:1rem}
.copy-slot-meta,.copy-slot-context{display:flex;flex-wrap:wrap;gap:8px 12px;color:var(--muted);font-size:.9rem}
.copy-slot-brief{margin:0;color:var(--text);line-height:1.55}
.approved-title-box{display:grid;gap:6px;padding:12px 14px;border-radius:18px;background:linear-gradient(135deg,rgba(34,197,94,.1),rgba(14,165,233,.1));border:1px solid rgba(14,165,233,.14)}
.approved-title-box small{color:var(--muted);text-transform:uppercase;letter-spacing:.08em;font-size:.72rem}
.proposal-stack{display:grid;gap:10px}
.proposal-empty{padding:12px;border-radius:14px;background:rgba(15,23,42,.03);color:var(--muted);font-size:.92rem}
.proposal-card{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;padding:12px;border-radius:16px;background:rgba(248,250,252,.92);border:1px solid var(--border)}
.proposal-card.is-approved{background:linear-gradient(135deg,rgba(34,197,94,.12),rgba(255,255,255,.96));border-color:rgba(34,197,94,.28)}
.proposal-copy{display:grid;gap:4px;min-width:0}
.proposal-copy strong{line-height:1.4}
.proposal-copy small{color:var(--muted)}
.proposal-copy p{margin:0;color:var(--text);line-height:1.45}
.copy-proposal-form{display:grid;gap:10px;padding-top:6px;border-top:1px solid var(--border)}
.copy-slot-actions{display:flex;gap:8px;flex-wrap:wrap}
.btn-mini{padding:.6rem .85rem;border-radius:12px;font-size:.88rem}
.inline-form{display:inline-flex;align-items:center}
.inline-actions{display:flex;gap:10px;flex-wrap:wrap}
.agenda-row-editorial{border-left:4px solid #f59e0b;padding-left:10px}
.event-pill-editorial{background:linear-gradient(135deg,rgba(245,158,11,.18),rgba(255,255,255,.92));border:1px solid rgba(245,158,11,.25)}
.event-pill-editorial small{font-size:.72rem;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.06em}

@media (max-width:1600px){
  .copy-board-grid{grid-template-columns:repeat(4,minmax(0,1fr))}
}
@media (max-width:1220px){
  .copy-week-toolbar{grid-template-columns:1fr;justify-items:stretch}
  .copy-board-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width:760px){
  .copy-board-grid{grid-template-columns:1fr}
  .copy-day-card{min-height:0;padding:14px}
  .proposal-card,.copy-slot-top,.copy-slot-actions,.inline-actions{flex-direction:column;align-items:stretch}
}


.profile-avatar-card{display:grid;gap:12px;align-content:start}
.profile-avatar-preview{display:flex;align-items:center;gap:14px;padding:16px;border:1px dashed var(--border);border-radius:18px;background:rgba(255,255,255,.55)}
.profile-avatar-preview .avatar{width:72px;height:72px;border-radius:22px;font-size:1.35rem}
.profile-avatar-preview img{width:100%;height:100%;object-fit:cover}
.color-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}
.color-chip-field input[type="color"]{padding:0;border-radius:16px;height:54px;background:transparent}
.color-chip-field small{color:var(--muted)}
@media (max-width: 960px){
  .color-grid{grid-template-columns:1fr 1fr}
}
@media (max-width: 640px){
  .color-grid{grid-template-columns:1fr}
}
