:root{--bg:#f5f7fb;--surface:#fff;--surface-2:#f8fafc;--text:#0f172a;--muted:#64748b;--border:#e2e8f0;--primary:#2563eb;--primary-dark:#1d4ed8;--danger:#dc2626;--success:#16a34a;--warning:#d97706;--purple:#7c3aed;--shadow:0 18px 45px rgba(15,23,42,.08);--soft:0 10px 25px rgba(15,23,42,.06);--radius:22px}*{box-sizing:border-box}body{margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;background:var(--bg);color:var(--text)}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}input,select,textarea{width:100%;border:1px solid var(--border);border-radius:13px;padding:10px 12px;background:#fff;color:var(--text)}textarea{min-height:110px;resize:vertical}label{display:grid;gap:7px;color:#334155;font-weight:800;font-size:13px}small{color:var(--muted)}.muted{color:var(--muted)}.app-shell{display:grid;grid-template-columns:268px 1fr;min-height:100vh}.sidebar{position:sticky;top:0;height:100vh;background:#0f172a;color:#e2e8f0;padding:18px;display:flex;flex-direction:column;gap:20px}.workspace-mark{display:flex;align-items:center;gap:12px;padding:10px;border-radius:18px;background:rgba(255,255,255,.04)}.workspace-mark strong{display:block;color:#fff}.workspace-mark small{display:block;color:#94a3b8}.logo-badge{width:42px;height:42px;display:inline-grid;place-items:center;border-radius:14px;background:linear-gradient(135deg,#2563eb,#7c3aed);color:#fff;font-weight:950;box-shadow:0 12px 25px rgba(37,99,235,.25)}.logo-badge.xl{width:64px;height:64px;border-radius:20px;font-size:22px}.side-nav{display:grid;gap:6px}.side-nav a{display:flex;align-items:center;gap:11px;color:#cbd5e1;padding:11px 12px;border-radius:14px;font-weight:850;transition:.15s}.side-nav a span{width:22px;text-align:center}.side-nav a:hover,.side-nav a.active{background:rgba(255,255,255,.08);color:#fff;transform:translateX(2px)}.sidebar-footer{margin-top:auto}.mini-user{display:flex;align-items:center;gap:10px;padding:10px;border-top:1px solid rgba(255,255,255,.08)}.mini-user strong{display:block;color:#fff}.mini-user small{display:block;color:#94a3b8}.main-wrap{min-width:0}.topbar{height:70px;position:sticky;top:0;z-index:10;background:rgba(255,255,255,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:16px;padding:0 26px}.hamburger{display:none;border:0;background:#e2e8f0;border-radius:12px;padding:9px 12px}.global-search{flex:1;max-width:740px}.global-search input{background:#f8fafc}.top-actions{margin-left:auto;display:flex;gap:10px;align-items:center}.icon-btn{position:relative;border:1px solid var(--border);background:#fff;border-radius:14px;padding:10px 12px;box-shadow:var(--soft)}.icon-btn em{position:absolute;top:-7px;right:-7px;background:var(--danger);color:#fff;border-radius:999px;font-size:11px;min-width:19px;height:19px;display:grid;place-items:center;font-style:normal}.page{padding:26px;display:grid;gap:22px}.btn{border:1px solid var(--border);background:#fff;color:var(--text);border-radius:14px;padding:10px 14px;font-weight:900;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:6px;transition:.15s;white-space:nowrap}.btn:hover{transform:translateY(-1px);box-shadow:var(--soft)}.btn.primary{background:var(--primary);border-color:var(--primary);color:#fff}.btn.primary:hover{background:var(--primary-dark)}.btn.ghost{background:#fff}.btn.danger-soft{background:#fef2f2;color:#b91c1c;border-color:#fecaca}.btn.success-soft{background:#f0fdf4;color:#15803d;border-color:#bbf7d0}.btn.full{width:100%}.btn.tiny{padding:6px 9px;border-radius:10px;font-size:12px}.button-row{display:flex;gap:10px;flex-wrap:wrap}.flash{padding:13px 15px;border-radius:16px;border:1px solid #bfdbfe;background:#eff6ff;color:#1e40af;font-weight:800}.flash.error{background:#fef2f2;border-color:#fecaca;color:#b91c1c}.flash.success{background:#f0fdf4;border-color:#bbf7d0;color:#15803d}.hero-card,.page-head,.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}.hero-card,.page-head{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:24px}.hero-card h1,.page-head h1{margin:4px 0 8px;font-size:34px;letter-spacing:-.055em;line-height:1}.hero-card p,.page-head p{margin:0;color:var(--muted)}.eyebrow{font-size:12px;text-transform:uppercase;letter-spacing:.13em;font-weight:950;color:var(--primary)}.panel{padding:20px}.panel h2{margin:0 0 14px;font-size:20px;letter-spacing:-.03em}.panel-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.panel-head h2{margin:0}.stats-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}.stats-grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}.stat-card{background:#fff;border:1px solid var(--border);border-radius:22px;padding:18px;box-shadow:var(--shadow);display:grid;gap:6px}.stat-card small{text-transform:uppercase;font-size:11px;letter-spacing:.1em;font-weight:950}.stat-card strong{font-size:38px;letter-spacing:-.06em}.stat-card span{color:var(--muted);font-size:13px}.stat-card.danger strong{color:var(--danger)}.content-grid{display:grid;gap:18px}.content-grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}.content-grid.three{grid-template-columns:1.2fr .8fr .8fr}.stack-list{display:grid;gap:9px}.list-item{display:flex;justify-content:space-between;align-items:center;gap:12px;border:1px solid var(--border);background:#fff;border-radius:16px;padding:13px;transition:.15s}.list-item:hover{transform:translateY(-1px);box-shadow:var(--soft)}.list-item strong{display:block}.list-item small{display:block;margin-top:3px}.list-item.unread{border-color:#93c5fd;background:#eff6ff}.badge,.pill{display:inline-flex;align-items:center;border-radius:999px;padding:5px 9px;font-size:12px;font-weight:950;font-style:normal;background:#e2e8f0;color:#334155}.badge-high,.badge-urgent{background:#fee2e2;color:#b91c1c}.badge-normal{background:#dbeafe;color:#1d4ed8}.badge-low{background:#dcfce7;color:#15803d}.badge-guest{background:#f1f5f9}.badge-staff{background:#dbeafe}.badge-manager{background:#fef3c7;color:#92400e}.badge-admin,.badge-owner{background:#ede9fe;color:#5b21b6}.avatar{width:32px;height:32px;border-radius:999px;background:var(--avatar,#2563eb);color:#fff;display:inline-grid;place-items:center;font-weight:950;font-size:12px;box-shadow:0 8px 18px rgba(15,23,42,.12)}.avatar.xl{width:60px;height:60px;font-size:18px}.form-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;align-items:end}.form-grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}.form-grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}.form-grid .wide{grid-column:span 2}.filters{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.filters select,.filters input{max-width:210px}.login-body{min-height:100vh;display:grid;place-items:center;background:radial-gradient(circle at top left,#dbeafe,transparent 36%),radial-gradient(circle at bottom right,#f3e8ff,transparent 30%),var(--bg);padding:24px}.login-shell{width:min(980px,100%);display:grid;grid-template-columns:1.15fr .85fr;gap:26px;align-items:stretch}.login-hero,.login-card{background:rgba(255,255,255,.86);backdrop-filter:blur(12px);border:1px solid rgba(226,232,240,.9);border-radius:32px;box-shadow:var(--shadow);padding:34px}.login-hero h1{font-size:48px;line-height:1;letter-spacing:-.06em;margin:18px 0 14px}.login-hero p{font-size:17px;color:var(--muted)}.feature-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:24px}.feature-grid span{background:#eff6ff;color:#1e40af;border:1px solid #bfdbfe;border-radius:999px;padding:10px;text-align:center;font-weight:850}.board-wrap{display:grid;grid-template-columns:repeat(var(--cols,5),minmax(275px,1fr));gap:16px;overflow-x:auto;padding-bottom:6px}.kanban-column{background:#f8fafc;border:1px solid var(--border);border-radius:22px;min-height:520px;display:flex;flex-direction:column}.kanban-column header{display:flex;align-items:center;justify-content:space-between;padding:16px 16px 10px;border-top:5px solid var(--status,#2563eb);border-radius:22px 22px 0 0}.kanban-column h2{font-size:16px;margin:0}.kanban-tasks{display:grid;gap:12px;padding:12px;min-height:450px;align-content:start}.task-card{background:#fff;border:1px solid var(--border);border-radius:18px;padding:14px;box-shadow:var(--soft);cursor:grab;transition:.15s}.task-card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}.task-card.dragging{opacity:.45}.task-card h3{margin:5px 0 7px;font-size:16px}.task-card p{margin:0 0 10px;color:#475569;font-size:13px}.card-meta{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.card-foot{display:flex;align-items:center;justify-content:space-between;margin-top:12px;color:var(--muted);font-size:12px}.drop-hover{outline:3px dashed #93c5fd;outline-offset:-8px}.table-wrap{overflow:auto}.data-table{width:100%;border-collapse:separate;border-spacing:0 8px}.data-table th{text-align:left;font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:#64748b;padding:0 12px}.data-table td{background:#fff;border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:12px;vertical-align:middle}.data-table td:first-child{border-left:1px solid var(--border);border-radius:14px 0 0 14px}.data-table td:last-child{border-right:1px solid var(--border);border-radius:0 14px 14px 0}.calendar-grid{display:grid;grid-template-columns:repeat(7,minmax(140px,1fr));gap:8px}.calendar-day{background:#fff;border:1px solid var(--border);border-radius:16px;min-height:130px;padding:10px}.calendar-day.out{opacity:.45}.calendar-day strong{display:block;margin-bottom:8px}.cal-chip{display:block;border-radius:9px;padding:6px 8px;margin:5px 0;background:#eff6ff;color:#1e40af;font-size:12px;font-weight:800}.cal-chip.event{background:#fef3c7;color:#92400e}.task-layout{display:grid;grid-template-columns:1.35fr .65fr;gap:18px}.comment{border:1px solid var(--border);background:#fff;border-radius:16px;padding:12px}.check-row{display:flex;align-items:center;gap:10px;border:1px solid var(--border);border-radius:13px;padding:10px;background:#fff}.check-row input{width:auto}.progress{height:9px;background:#e2e8f0;border-radius:999px;overflow:hidden}.progress span{display:block;height:100%;background:var(--success);width:var(--p,0)}.team-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}.team-card{text-align:center;display:grid;gap:8px;place-items:center}.team-card h2{margin:6px 0 0}.team-meta{display:flex;gap:6px;flex-wrap:wrap;justify-content:center}.project-cards,.template-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.project-card{display:grid;gap:12px}.color-dot{width:13px;height:13px;border-radius:999px;background:var(--c,#2563eb);display:inline-block}.tabs{display:flex;gap:8px;flex-wrap:wrap}.tab{padding:9px 12px;border:1px solid var(--border);border-radius:999px;background:#fff;font-weight:850}.tab.active{background:#eff6ff;color:#1d4ed8;border-color:#bfdbfe}.section-title{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:0}.empty{border:1px dashed var(--border);background:#fff;border-radius:18px;padding:24px;text-align:center;color:var(--muted)}.file-list{display:grid;gap:8px}.work-sections{display:grid;gap:18px}.compact-list .list-item{padding:10px 12px}.dark-mode{--bg:#0b1220;--surface:#111827;--surface-2:#0f172a;--text:#f8fafc;--muted:#94a3b8;--border:#1f2937}.dark-mode input,.dark-mode select,.dark-mode textarea,.dark-mode .btn,.dark-mode .task-card,.dark-mode .list-item,.dark-mode .calendar-day,.dark-mode .data-table td{background:#111827;color:#f8fafc;border-color:#1f2937}.dark-mode .topbar{background:rgba(17,24,39,.9)}
@media(max-width:1100px){.app-shell{grid-template-columns:1fr}.sidebar{position:fixed;left:-290px;z-index:30;transition:.2s}.sidebar.open{left:0}.hamburger{display:inline-block}.stats-grid,.stats-grid.three,.content-grid.two,.content-grid.three,.project-cards,.template-grid,.team-grid,.task-layout{grid-template-columns:1fr}.form-grid,.form-grid.two,.form-grid.three{grid-template-columns:1fr}.form-grid .wide{grid-column:auto}.hero-card,.page-head{align-items:flex-start;flex-direction:column}.calendar-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.login-shell{grid-template-columns:1fr}.feature-grid{grid-template-columns:repeat(2,1fr)}}
/* StaffFlow V3.2 UI finish */
.task-card-top{display:flex;align-items:center;justify-content:space-between;gap:8px}.compact-task-card{padding:12px}.compact-task-card h3{font-size:15px;line-height:1.22}.card-actions{display:flex;gap:7px;flex-wrap:wrap;margin-top:10px}.card-actions form{margin:0}.link-button{border:0;background:transparent;color:var(--primary);font-weight:900;cursor:pointer;padding:0}.quick-create-panel{position:sticky;top:86px;z-index:8}.modal-backdrop{position:fixed;inset:0;background:rgba(15,23,42,.52);display:none;align-items:center;justify-content:center;padding:22px;z-index:80;backdrop-filter:blur(8px)}.modal-backdrop.open{display:flex}.modal-card{width:min(760px,100%);max-height:88vh;overflow:auto;background:var(--surface);border:1px solid var(--border);border-radius:28px;box-shadow:0 30px 80px rgba(0,0,0,.28);padding:22px}.modal-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:16px}.modal-head h2{margin:3px 0 0;font-size:28px;letter-spacing:-.04em}.command-card{width:min(680px,100%)}.command-list{display:grid;gap:8px;margin-top:14px}.command-list a{display:flex;align-items:center;justify-content:space-between;gap:16px;border:1px solid var(--border);background:var(--surface-2);border-radius:16px;padding:13px 14px;font-weight:950}.command-list a:hover{border-color:#93c5fd;box-shadow:var(--soft);transform:translateY(-1px)}.command-list small{font-weight:700}.preview-meta{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}.preview-desc{white-space:pre-wrap;line-height:1.6;color:var(--muted);background:var(--surface-2);border:1px solid var(--border);border-radius:18px;padding:16px}.public-body{min-height:100vh;background:radial-gradient(circle at top left,#dbeafe,transparent 35%),var(--bg)}.public-shell{width:min(1180px,100%);margin:0 auto;padding:28px}.public-hero{background:rgba(255,255,255,.88);backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:30px;padding:28px;box-shadow:var(--shadow);display:flex;align-items:center;justify-content:space-between;gap:18px}.public-hero h1{margin:4px 0 8px;font-size:38px;letter-spacing:-.06em}.public-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin-top:20px}.public-card{background:var(--surface);border:1px solid var(--border);border-radius:22px;padding:18px;box-shadow:var(--soft);display:grid;gap:10px}.public-card h2{margin:0;font-size:18px}.public-card p{margin:0;color:var(--muted);line-height:1.5}.public-detail{width:min(900px,100%);margin:34px auto;background:var(--surface);border:1px solid var(--border);border-radius:30px;box-shadow:var(--shadow);padding:30px}.public-detail h1{font-size:40px;letter-spacing:-.06em;margin:8px 0 14px}.public-meta{display:flex;gap:8px;flex-wrap:wrap}.public-desc{white-space:pre-wrap;line-height:1.7;color:var(--text);background:var(--surface-2);border:1px solid var(--border);border-radius:20px;padding:18px;margin-top:20px}.empty strong{color:var(--text)}.dark-mode .sidebar{background:#020617}.dark-mode .public-hero{background:rgba(17,24,39,.88)}.dark-mode .stat-card,.dark-mode .panel,.dark-mode .hero-card,.dark-mode .page-head,.dark-mode .public-card,.dark-mode .public-detail,.dark-mode .modal-card{background:#111827;border-color:#1f2937}.dark-mode .kanban-column{background:#0f172a}.dark-mode .global-search input{background:#0f172a}.dark-mode .empty,.dark-mode .preview-desc,.dark-mode .public-desc,.dark-mode .command-list a{background:#0f172a;border-color:#1f2937}.dark-mode label{color:#cbd5e1}.dark-mode .task-card p{color:#cbd5e1}.dark-mode .badge,.dark-mode .pill{background:#1f2937;color:#e5e7eb}@media(max-width:800px){.topbar{height:auto;min-height:64px;padding:10px 14px;flex-wrap:wrap}.global-search{order:3;max-width:none;width:100%;flex-basis:100%}.top-actions{gap:6px}.top-actions .btn.ghost,.top-actions .btn.danger-soft{display:none}.page{padding:16px}.board-wrap{grid-template-columns:repeat(var(--cols,5),minmax(255px,86vw))}.calendar-grid{grid-template-columns:1fr}.public-grid{grid-template-columns:1fr}.public-hero{align-items:flex-start;flex-direction:column}.quick-create-panel{position:relative;top:auto}.data-table{min-width:920px}.modal-card{padding:18px;border-radius:22px}.hero-card h1,.page-head h1,.public-detail h1{font-size:30px}.public-shell{padding:16px}}

/* V3.2.1 isPublic controls */
.check-toggle{display:flex;align-items:center;gap:12px;border:1px solid var(--border);background:var(--surface-2);border-radius:16px;padding:12px 14px;cursor:pointer;line-height:1.25}
.check-toggle input{width:18px;height:18px;accent-color:var(--primary)}
.check-toggle span{display:grid;gap:2px}
.check-toggle small{color:var(--muted);font-size:12px;font-weight:700}
.compact-public-toggle{min-width:160px}
.inline-public-form{margin:0;display:inline-flex;align-items:center}
.switch-line{display:inline-flex;align-items:center;gap:8px;font-weight:900;color:var(--text);cursor:pointer;white-space:nowrap}
.switch-line input{width:18px;height:18px;accent-color:var(--primary)}
.public-card-actions{align-items:center;justify-content:space-between}
.dark-mode .check-toggle{background:#0f172a;border-color:#1f2937}
@media(max-width:800px){.compact-public-toggle{min-width:0;width:100%}.public-card-actions{align-items:flex-start;flex-direction:column}}


/* StaffFlow V3.3 Cases */
.case-layout .side-panel{align-self:start;position:sticky;top:1rem}
.case-layout textarea{min-height:110px}
.case-kpi{display:flex;gap:.75rem;flex-wrap:wrap}
.timeline-dot{width:.75rem;height:.75rem;border-radius:50%;background:var(--accent,#2563eb);display:inline-block}
.case-confidential{border:1px solid rgba(220,38,38,.22);background:rgba(220,38,38,.06);padding:.65rem .8rem;border-radius:14px}
body.dark-mode .case-confidential{background:rgba(248,113,113,.1)}
@media (max-width:900px){.case-layout{display:block}.case-layout .side-panel{position:static;margin-top:1rem}}


/* V3.4 Training Gateway */
.timeline.compact{display:grid;gap:12px}
.timeline.compact>div{padding:12px;border:1px solid var(--border);border-radius:16px;background:var(--panel-soft)}
.timeline.compact strong{display:block;margin-bottom:4px}
.callout{padding:14px;border:1px dashed var(--border);border-radius:16px;background:var(--panel-soft);margin:10px 0}
.code-block{white-space:pre-wrap;background:var(--panel-soft);border:1px solid var(--border);padding:14px;border-radius:16px;overflow:auto}
.form-inline{display:grid;grid-template-columns:1fr minmax(120px,180px) minmax(160px,1.2fr) auto;gap:10px;align-items:center}
.small-stat{font-size:1rem!important;line-height:1.2}.danger-text{color:#ef4444}.compact-stats{grid-template-columns:repeat(4,minmax(0,1fr))}
@media (max-width:900px){.form-inline{grid-template-columns:1fr}.compact-stats{grid-template-columns:1fr 1fr}}


/* V3.6 Owner User Management */
.user-admin-grid{align-items:start}
.profile-admin-head{display:flex;align-items:center;gap:14px;margin-bottom:14px}
.profile-admin-head h2{margin-bottom:4px}.profile-admin-head p{margin:0}
.danger-zone{border-color:#fecaca;background:linear-gradient(180deg,#fff,#fff7f7)}
.danger-zone hr{border:0;border-top:1px solid var(--border);margin:18px 0}
.dark-mode .danger-zone{background:#111827;border-color:#7f1d1d}
.dark-mode .profile-admin-head p{color:var(--muted)}


/* StaffFlow V3.7 rank structure */
.rank-pill{display:inline-flex;align-items:center;gap:.4rem;border:1px solid color-mix(in srgb,var(--rank,#2563eb),transparent 65%);background:color-mix(in srgb,var(--rank,#2563eb),transparent 88%);color:var(--text);border-radius:999px;padding:.25rem .55rem;font-size:.78rem;white-space:nowrap}
.rank-pill strong{color:var(--rank,#2563eb);font-weight:800;letter-spacing:.04em}
.rank-ladder{display:grid;gap:.65rem}
.rank-step{padding:.85rem 1rem;border-radius:1rem;border:1px solid color-mix(in srgb,var(--rank,#2563eb),transparent 55%);background:linear-gradient(135deg,color-mix(in srgb,var(--rank,#2563eb),transparent 86%),var(--panel));display:flex;justify-content:space-between;align-items:center;gap:1rem}
.rank-step strong{font-size:1rem}.rank-step small{color:var(--muted)}
.assignment-line{font-size:12px;color:var(--muted);background:var(--surface-2);border:1px dashed var(--border);border-radius:12px;padding:8px 10px;margin:8px 0}.assignment-line strong{color:var(--text)}select[multiple]{min-height:120px;padding:8px}.bug-severity-urgent{background:#fee2e2;color:#991b1b}.bug-severity-high{background:#ffedd5;color:#9a3412}.bug-severity-normal{background:#dbeafe;color:#1d4ed8}.bug-severity-low{background:#dcfce7;color:#166534}.mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono",monospace}.api-note{border:1px solid var(--border);background:var(--surface-2);border-radius:16px;padding:14px;color:var(--muted)}


/* StaffFlow V3.8.1 board quick-create modal polish */
.board-head-actions{align-items:center}.task-create-modal{width:min(1040px,100%);padding:0;overflow:visible}.task-create-head{padding:24px 26px 18px;margin:0;border-bottom:1px solid var(--border);background:linear-gradient(135deg,rgba(37,99,235,.08),transparent 55%);border-radius:28px 28px 0 0}.task-create-head p{margin:6px 0 0;color:var(--muted);font-weight:700}.task-create-form{padding:22px 26px 24px}.task-create-grid{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(320px,.9fr);gap:18px}.task-create-section{display:grid;gap:14px;align-content:start;border:1px solid var(--border);background:var(--surface-2);border-radius:22px;padding:18px}.task-create-section h3{margin:0;font-size:14px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}.task-create-section textarea{min-height:118px;resize:vertical}.mini-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:18px;padding-top:18px;border-top:1px solid var(--border)}
.chip-field{display:grid;gap:8px;color:var(--text);font-weight:900}.chip-select{position:relative}.chip-select select[multiple]{display:none}.chip-control{min-height:46px;display:flex;align-items:center;border:1px solid var(--border);background:var(--surface);border-radius:16px;padding:7px 9px;box-shadow:0 1px 0 rgba(15,23,42,.02);cursor:text}.chip-select.open .chip-control{border-color:#93c5fd;box-shadow:0 0 0 4px rgba(37,99,235,.10)}.chip-list{display:flex;align-items:center;gap:6px;flex-wrap:wrap;width:100%}.chip-list input{border:0!important;box-shadow:none!important;background:transparent!important;padding:6px!important;min-width:140px;flex:1;height:30px}.chip-list input:focus{outline:0}.chip-token{display:inline-flex;align-items:center;gap:7px;border:1px solid rgba(37,99,235,.18);background:rgba(37,99,235,.10);color:var(--primary);border-radius:999px;padding:6px 9px;font-weight:950;font-size:12px;cursor:pointer}.chip-token b{font-size:14px;line-height:1}.chip-options{position:absolute;left:0;right:0;top:calc(100% + 8px);z-index:90;display:none;max-height:230px;overflow:auto;background:var(--surface);border:1px solid var(--border);border-radius:18px;box-shadow:0 20px 50px rgba(15,23,42,.16);padding:8px}.chip-select.open .chip-options{display:grid;gap:6px}.chip-option{display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%;border:0;background:transparent;color:var(--text);border-radius:12px;padding:10px 11px;text-align:left;font-weight:850;cursor:pointer}.chip-option:hover,.chip-option.selected{background:var(--surface-2)}.chip-option b{font-size:11px;color:var(--primary);text-transform:uppercase;letter-spacing:.06em}.chip-empty{padding:12px;color:var(--muted);font-weight:800;text-align:center}.visibility-switch{display:flex;align-items:center;gap:12px;border:1px solid var(--border);background:var(--surface);border-radius:18px;padding:13px 14px;cursor:pointer}.visibility-switch input{position:absolute;opacity:0;pointer-events:none}.visibility-switch .switch-ui{width:46px;height:26px;border-radius:999px;background:#cbd5e1;position:relative;flex:0 0 auto;transition:.18s}.visibility-switch .switch-ui:after{content:"";position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:0 2px 8px rgba(15,23,42,.22);transition:.18s}.visibility-switch input:checked+.switch-ui{background:var(--primary)}.visibility-switch input:checked+.switch-ui:after{transform:translateX(20px)}.visibility-switch strong{display:block}.visibility-switch small{display:block;color:var(--muted);font-size:12px;font-weight:750;margin-top:2px}.inline-visibility{grid-column:1/-1}.quick-create-panel{display:none}
.dark-mode .task-create-head{background:linear-gradient(135deg,rgba(37,99,235,.18),transparent 55%)}.dark-mode .task-create-section,.dark-mode .chip-option:hover,.dark-mode .chip-option.selected{background:#0f172a}.dark-mode .chip-control,.dark-mode .chip-options,.dark-mode .visibility-switch{background:#111827;border-color:#1f2937}.dark-mode .chip-token{background:rgba(96,165,250,.14);border-color:rgba(96,165,250,.24);color:#93c5fd}
@media(max-width:900px){.task-create-grid{grid-template-columns:1fr}.task-create-modal{width:min(720px,100%)}.task-create-head{padding:20px}.task-create-form{padding:18px}.mini-grid{grid-template-columns:1fr}.modal-actions{flex-direction:column-reverse}.modal-actions .btn{width:100%}.board-head-actions{width:100%;align-items:stretch}.board-head-actions .btn,.board-head-actions form,.board-head-actions select{width:100%}}

.close-task-inline{display:inline-flex;margin:0}.task-card .btn.success-soft{background:#f0fdf4;color:#15803d;border-color:#bbf7d0}.data-table form.inline-public-form{display:inline-flex;margin:0}

/* V3.8.4 visible task IDs */
.task-id-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  white-space: nowrap;
  border-radius: 999px;
  border: 1px solid rgba(37, 99, 235, 0.22);
  background: rgba(37, 99, 235, 0.08);
  color: #1d4ed8;
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
  padding: 5px 8px;
  letter-spacing: 0.01em;
}
.task-id-badge-large {
  font-size: 14px;
  padding: 7px 12px;
}
.task-id-help.compact {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: -4px;
  margin-bottom: 8px;
  color: #64748b;
  font-size: 12px;
}
.task-id-copy {
  border: 1px solid rgba(148, 163, 184, 0.35);
  background: #f8fafc;
  color: #334155;
  border-radius: 999px;
  padding: 5px 9px;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
}
.task-id-copy:hover {
  background: #eef2ff;
  border-color: rgba(37, 99, 235, 0.28);
  color: #1d4ed8;
}
.task-id-col {
  width: 84px;
  white-space: nowrap;
}
.task-id-col .list-copy {
  display: block;
  margin-top: 6px;
}
.task-id-panel {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
  margin: 10px 0;
}
.task-id-label {
  color: #64748b;
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.task-id-panel small {
  color: #64748b;
}
.task-card-top {
  gap: 6px;
  flex-wrap: wrap;
}
@media (max-width: 720px) {
  .task-id-col {
    width: auto;
  }
}


/* V3.8.5 task detail cleanup */
.task-hero {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 20px;
  padding: 26px;
}
.task-hero-copy {
  min-width: 0;
  flex: 1 1 auto;
}
.task-hero-copy h1 {
  margin: 6px 0 10px;
  font-size: 34px;
  line-height: 1.05;
  letter-spacing: -.05em;
}
.task-hero-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 10px;
}
.meta-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 11px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: var(--surface-2);
  color: #334155;
  font-size: 12px;
  font-weight: 900;
}
.meta-chip.priority.priority-high,
.meta-chip.priority.priority-urgent {
  background: #fee2e2;
  border-color: #fecaca;
  color: #b91c1c;
}
.meta-chip.priority.priority-normal {
  background: #dbeafe;
  border-color: #bfdbfe;
  color: #1d4ed8;
}
.meta-chip.priority.priority-low {
  background: #dcfce7;
  border-color: #bbf7d0;
  color: #15803d;
}
.task-hero-summary {
  margin-top: 8px !important;
}
.task-hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: flex-end;
  flex: 0 0 auto;
}
.task-hero-actions form {
  margin: 0;
}
.task-summary-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
}
.summary-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: 18px;
  box-shadow: var(--soft);
  display: grid;
  gap: 6px;
}
.summary-card small {
  text-transform: uppercase;
  font-size: 11px;
  letter-spacing: .09em;
  font-weight: 950;
}
.summary-card strong {
  font-size: 28px;
  letter-spacing: -.05em;
}
.summary-card span {
  color: var(--muted);
  font-size: 13px;
}
.task-detail-shell {
  display: grid;
  grid-template-columns: minmax(0, 1.45fr) minmax(320px, .75fr);
  gap: 20px;
  align-items: start;
}
.task-detail-main,
.task-detail-side {
  display: grid;
  gap: 18px;
}
.detail-panel {
  padding: 22px;
}
.detail-panel-head {
  align-items: flex-start;
  margin-bottom: 16px;
}
.detail-panel-head h2 {
  margin-bottom: 4px;
}
.detail-panel-head p {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
}
.detail-form-stack {
  display: grid;
  gap: 18px;
}
.detail-section {
  border: 1px solid var(--border);
  background: var(--surface-2);
  border-radius: 20px;
  padding: 18px;
}
.detail-section-head {
  margin-bottom: 14px;
}
.detail-section-head h3 {
  margin: 0 0 4px;
  font-size: 16px;
  letter-spacing: -.02em;
}
.detail-section-head p {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
}
.detail-grid {
  align-items: start;
}
.detail-grid label {
  gap: 8px;
}
.detail-grid textarea {
  min-height: 132px;
}
.detail-toggle {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 15px 16px;
  border: 1px solid var(--border);
  background: #fff;
  border-radius: 18px;
}
.detail-toggle input {
  width: auto;
  margin-top: 3px;
}
.detail-toggle span {
  display: grid;
  gap: 2px;
}
.detail-toggle strong {
  color: var(--text);
}
.detail-form-actions {
  display: flex;
  justify-content: flex-end;
}
.view-only-kv {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
.view-only-kv > div,
.info-row {
  border: 1px solid var(--border);
  background: #fff;
  border-radius: 16px;
  padding: 13px 14px;
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: center;
}
.view-only-kv span,
.info-row span {
  color: var(--muted);
  font-size: 13px;
}
.view-only-kv strong,
.info-row strong {
  display: block;
  text-align: right;
}
.info-row span small {
  display: block;
  margin-top: 4px;
}
.info-stack {
  display: grid;
  gap: 10px;
}
.info-stack.compact .info-row {
  padding: 12px 13px;
}
.task-checklist-list {
  margin-top: 12px;
}
.detail-check-row {
  min-height: 48px;
  border-radius: 16px;
  border: 1px solid var(--border);
  background: #fff;
  padding: 0 14px;
  display: flex;
  align-items: center;
  gap: 12px;
}
.detail-add-row {
  margin-top: 14px;
}
.comment-compose {
  margin-bottom: 14px;
}
.detail-comment {
  padding: 16px;
  border-radius: 18px;
  background: var(--surface-2);
}
.comment-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 8px;
}
.comment-head strong {
  display: flex;
  align-items: center;
  gap: 9px;
}
.empty-state-lite {
  border: 1px dashed var(--border);
  background: var(--surface-2);
  border-radius: 16px;
  padding: 15px;
  color: var(--muted);
  font-weight: 700;
  text-align: center;
}
.file-row-clean {
  align-items: flex-start;
}
.sticky-side-block {
  position: sticky;
  top: 90px;
}
.upload-form-clean input[type="file"] {
  background: #fff;
}
.detail-description-block {
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid var(--border);
}
.detail-description-block h3 {
  margin: 0 0 8px;
  font-size: 15px;
}
.log-row {
  align-items: flex-start;
}
@media (max-width: 1100px) {
  .task-summary-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .task-detail-shell {
    grid-template-columns: 1fr;
  }
  .sticky-side-block {
    position: static;
  }
}
@media (max-width: 760px) {
  .task-hero {
    flex-direction: column;
    padding: 20px;
  }
  .task-hero-actions {
    width: 100%;
    justify-content: stretch;
  }
  .task-hero-actions .btn,
  .task-hero-actions form {
    width: 100%;
  }
  .task-summary-grid,
  .view-only-kv {
    grid-template-columns: 1fr;
  }
  .detail-panel {
    padding: 18px;
  }
  .detail-section {
    padding: 15px;
  }
  .comment-head,
  .info-row,
  .view-only-kv > div {
    flex-direction: column;
    align-items: flex-start;
  }
  .view-only-kv strong,
  .info-row strong {
    text-align: left;
  }
  .detail-form-actions .btn {
    width: 100%;
  }
}


/* V3.8.6 board card cleanup + hide closed from panel */
.task-card-polished {
  padding: 16px;
}
.clean-top-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 8px;
}
.task-card-top-left,
.task-card-top-right {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.task-id-row.compact {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin: 0 0 10px;
  color: var(--muted);
  font-size: 12px;
}
.task-id-inline-label {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}
.task-id-inline-label strong {
  color: var(--text);
  font-weight: 900;
}
.task-id-copy-inline {
  padding: 6px 10px;
  line-height: 1;
  white-space: nowrap;
}
.clean-card-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 10px;
}
.clean-card-actions .inline-public-form {
  display: inline-flex;
  align-items: center;
  margin: 0;
}
.clean-card-actions .switch-line {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 10px;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: var(--surface-2);
}
.clean-card-actions .switch-line input {
  width: auto;
  margin: 0;
}
.compact-task-card .assignment-line {
  margin: 10px 0;
}
.compact-task-card .card-meta {
  margin-bottom: 10px;
}
.compact-task-card .card-foot {
  margin-top: 10px;
}
@media (max-width: 720px) {
  .task-id-row.compact,
  .clean-card-actions,
  .clean-top-row {
    flex-direction: column;
    align-items: flex-start;
  }
  .task-id-copy-inline,
  .clean-card-actions .btn {
    width: auto;
  }
}


/* V3.8.6.1 copy button hotfix */
.task-id-copy,
.task-id-copy-inline {
  -webkit-appearance: none;
  appearance: none;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  width: auto !important;
  min-width: 0;
  height: 28px;
  padding: 0 10px;
  margin: 0;
  border: 1px solid rgba(37, 99, 235, 0.14);
  border-radius: 999px;
  background: #eff6ff;
  color: #1d4ed8;
  box-shadow: none;
  font-size: 11px;
  font-weight: 900;
  line-height: 1;
  letter-spacing: .01em;
  white-space: nowrap;
  vertical-align: middle;
  flex: 0 0 auto;
}
.task-id-copy:hover,
.task-id-copy-inline:hover {
  background: #dbeafe;
  border-color: rgba(37, 99, 235, 0.22);
  color: #1d4ed8;
  transform: none;
}
.task-id-copy:focus,
.task-id-copy-inline:focus {
  outline: 2px solid rgba(37, 99, 235, 0.22);
  outline-offset: 2px;
}
.task-id-row.compact {
  align-items: center;
}
.task-id-inline-label {
  font-size: 12px;
}
.task-card-polished .task-id-row.compact {
  padding: 2px 0 0;
}


/* V3.9 Governance + Bot Access */
.gov-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}.gov-card{background:#fff;border:1px solid var(--border);border-radius:22px;padding:18px;box-shadow:var(--soft);display:grid;gap:6px}.gov-card small{text-transform:uppercase;letter-spacing:.09em;font-weight:950}.gov-card strong{font-size:30px;letter-spacing:-.05em}.governance-table .data-table td{vertical-align:top}.command-toggle{display:flex;align-items:center;gap:10px}.command-toggle input{width:auto}.access-pill{display:inline-flex;align-items:center;border-radius:999px;padding:5px 9px;font-size:12px;font-weight:900;background:#eff6ff;color:#1d4ed8}.access-pill.off{background:#fef2f2;color:#b91c1c}.bot-health{display:flex;gap:10px;flex-wrap:wrap}.bot-health .pill{background:#dcfce7;color:#15803d}.bot-health .pill.offline{background:#fee2e2;color:#b91c1c}.log-success{color:#15803d;font-weight:900}.log-denied,.log-error{color:#b91c1c;font-weight:900}.mono-small{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:12px}.governance-actions{display:flex;gap:10px;flex-wrap:wrap}.closed-task-row{opacity:.92}.security-callout{border:1px solid #bfdbfe;background:#eff6ff;color:#1e40af;border-radius:18px;padding:14px;font-weight:800}.security-callout.danger{border-color:#fecaca;background:#fef2f2;color:#991b1b}@media(max-width:900px){.gov-grid{grid-template-columns:1fr 1fr}}@media(max-width:620px){.gov-grid{grid-template-columns:1fr}}


/* V3.9.1 header governance icons */
.header-control-icons {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 4px;
  border: 1px solid rgba(148, 163, 184, 0.28);
  background: rgba(248, 250, 252, 0.78);
  border-radius: 18px;
}
.header-control-icons .header-tool {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  min-height: 40px;
  padding: 9px 10px;
  border-radius: 14px;
  box-shadow: none;
  text-decoration: none;
}
.header-control-icons .header-tool span {
  display: inline-grid;
  place-items: center;
  width: 18px;
  height: 18px;
  line-height: 1;
}
.header-control-icons .header-tool b {
  color: var(--text);
  font-size: 12px;
  font-weight: 950;
  letter-spacing: -.01em;
}
.header-control-icons .header-tool:hover,
.header-control-icons .header-tool.active {
  border-color: rgba(37, 99, 235, .28);
  background: #eff6ff;
  color: var(--primary);
}
.header-control-icons .header-tool:hover b,
.header-control-icons .header-tool.active b {
  color: var(--primary);
}
.dark-mode .header-control-icons {
  background: rgba(15, 23, 42, .85);
  border-color: #1f2937;
}
.dark-mode .header-control-icons .header-tool {
  background: #111827;
}
.dark-mode .header-control-icons .header-tool b {
  color: #e5e7eb;
}
.dark-mode .header-control-icons .header-tool:hover,
.dark-mode .header-control-icons .header-tool.active {
  background: rgba(37, 99, 235, .18);
}
@media(max-width:1180px){
  .header-control-icons .header-tool b{display:none}
  .header-control-icons .header-tool{padding:9px 11px}
}
@media(max-width:800px){
  .header-control-icons{order:2;max-width:100%;overflow-x:auto}
  .header-control-icons .header-tool{flex:0 0 auto}
}

/* V3.9.2 profile identity and security */
.profile-hero {display:flex;align-items:center;justify-content:space-between;gap:24px;padding:28px;}
.profile-identity {display:flex;align-items:center;gap:20px;min-width:0;}
.profile-identity h1 {margin:4px 0 6px;font-size:34px;letter-spacing:-.05em;}
.profile-identity p {margin:0;color:var(--muted);font-weight:700;}
.profile-photo-xl {width:104px;height:104px;border-radius:28px;object-fit:cover;border:1px solid var(--border);box-shadow:var(--soft);flex:0 0 auto;background:#fff;}
.profile-photo-fallback {display:inline-flex;align-items:center;justify-content:center;background:var(--avatar,#2563eb);color:#fff;font-size:32px;font-weight:950;}
.profile-pill-row {display:flex;flex-wrap:wrap;gap:8px;margin-top:12px;}
.profile-grid {display:grid;grid-template-columns:minmax(0,1.35fr) minmax(320px,.65fr);gap:20px;align-items:start;}
.profile-main-stack,.profile-side-stack {display:grid;gap:18px;}
.profile-panel {padding:24px;}
.profile-panel .panel-head {align-items:flex-start;margin-bottom:18px;}
.profile-panel .panel-head h2 {margin:0 0 5px;font-size:22px;letter-spacing:-.03em;}
.profile-panel .panel-head p {margin:0;color:var(--muted);font-size:14px;}
.profile-form textarea {min-height:120px;}
.profile-form small {color:var(--muted);font-weight:600;margin-top:4px;}
.profile-readonly-card {border:1px solid var(--border);background:var(--surface-2);border-radius:18px;padding:14px 16px;display:grid;gap:4px;}
.profile-readonly-card span {font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:900;}
.profile-readonly-card strong {font-size:16px;}
.profile-readonly-card small {color:var(--muted);}
.security-card {position:relative;}
.twofa-setup {display:grid;gap:14px;}
.twofa-setup img {width:180px;height:180px;border:1px solid var(--border);border-radius:18px;background:#fff;padding:8px;}
.recovery-box {border:1px solid #fde68a;background:#fffbeb;color:#92400e;border-radius:18px;padding:16px;margin-bottom:16px;display:grid;gap:8px;}
.recovery-box p {margin:0;color:#92400e;}
.recovery-box code {display:block;background:#fff;border:1px solid #fde68a;border-radius:10px;padding:8px 10px;color:#111827;font-weight:900;letter-spacing:.04em;}
.twofa-login-card {max-width:430px;margin:auto;}
@media (max-width:1000px){.profile-grid{grid-template-columns:1fr}.profile-hero{flex-direction:column;align-items:flex-start}.profile-identity{align-items:flex-start}.profile-photo-xl{width:86px;height:86px;border-radius:24px}.profile-identity h1{font-size:28px}}
@media (max-width:680px){.profile-identity{flex-direction:column}.profile-panel{padding:20px}.profile-hero{padding:22px}.profile-hero .button-row,.profile-hero .btn{width:100%}}


/* V3.9.4 profile picture in header/sidebar */
.header-profile-photo,
.header-avatar-fallback {
  width: 36px;
  height: 36px;
  min-width: 36px;
  border-radius: 999px;
  object-fit: cover;
  border: 2px solid rgba(255,255,255,.22);
  box-shadow: 0 10px 22px rgba(15,23,42,.18);
}
.header-avatar-fallback {
  display: inline-grid;
  place-items: center;
  color: #fff;
  font-size: 12px;
  font-weight: 950;
  background: var(--avatar,#2563eb);
}
.mini-user {
  border-radius: 18px;
  transition: .15s ease;
}
.mini-user:hover {
  background: rgba(255,255,255,.06);
  transform: translateY(-1px);
}
.profile-top-link {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  min-height: 42px;
  padding: 6px 12px 6px 7px;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: #fff;
  box-shadow: var(--soft);
  font-weight: 900;
}
.profile-top-link .header-profile-photo,
.profile-top-link .header-avatar-fallback {
  width: 30px;
  height: 30px;
  min-width: 30px;
  border: 0;
  box-shadow: none;
}
.profile-top-link:hover {
  transform: translateY(-1px);
  box-shadow: var(--shadow);
}
.dark-mode .profile-top-link {
  background: #111827;
  border-color: #1f2937;
}
@media (max-width: 760px) {
  .profile-top-link span { display: none; }
  .profile-top-link { padding: 6px; }
}


/* V3.9.5 profile pictures in users and team pages */
.user-list-identity {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-width: 220px;
}
.user-list-photo,
.user-list-photo-fallback {
  width: 38px;
  height: 38px;
  min-width: 38px;
  border-radius: 999px;
  object-fit: cover;
  border: 2px solid #fff;
  box-shadow: 0 10px 22px rgba(15,23,42,.16);
}
.user-list-photo-fallback {
  display: inline-grid;
  place-items: center;
  color: #fff;
  font-size: 12px;
  font-weight: 950;
  background: var(--avatar,#2563eb);
}
.team-photo-wrap {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 12px;
}
.team-card-photo,
.team-card-photo-fallback {
  width: 64px;
  height: 64px;
  min-width: 64px;
  border-radius: 22px;
  object-fit: cover;
  border: 3px solid #fff;
  box-shadow: 0 14px 30px rgba(15,23,42,.18);
}
.team-card-photo-fallback {
  display: inline-grid;
  place-items: center;
  color: #fff;
  font-size: 18px;
  font-weight: 950;
  background: var(--avatar,#2563eb);
}
.team-card:hover .team-card-photo,
.team-card:hover .team-card-photo-fallback,
.user-list-identity:hover .user-list-photo,
.user-list-identity:hover .user-list-photo-fallback {
  transform: translateY(-1px);
}
.dark-mode .user-list-photo,
.dark-mode .user-list-photo-fallback,
.dark-mode .team-card-photo,
.dark-mode .team-card-photo-fallback {
  border-color: rgba(255,255,255,.16);
}
@media (max-width: 720px) {
  .user-list-identity { min-width: 0; }
  .team-card-photo,
  .team-card-photo-fallback { width: 56px; height: 56px; min-width: 56px; border-radius: 18px; }
}


/* V4.0 access-control suite */
.v4-grid{grid-template-columns:repeat(4,minmax(0,1fr));}.split-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:start}.security-chip{display:inline-flex;margin:2px 4px 2px 0;border-radius:999px;padding:5px 9px;font-size:12px;font-weight:900}.security-chip.ok{background:#dcfce7;color:#15803d}.security-chip.danger{background:#fee2e2;color:#b91c1c}.inline-form{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.inline-form input,.inline-form select{min-width:150px}.v4-muted{color:var(--muted);font-weight:700}.support-ticket-desc{max-width:420px;white-space:pre-wrap}.header-control-icons{max-width:min(1160px,62vw);overflow-x:auto;scrollbar-width:thin}.header-control-icons .header-tool{flex:0 0 auto}.header-control-icons::-webkit-scrollbar{height:5px}.header-control-icons::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:999px}.txadmin-planning-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}@media(max-width:1180px){.v4-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.split-grid{grid-template-columns:1fr}.header-control-icons{max-width:100%;order:2}}@media(max-width:720px){.v4-grid{grid-template-columns:1fr}.inline-form{display:grid}.inline-form input,.inline-form select{min-width:0;width:100%}}

/* StaffFlow V4.0.1 navigation cleanup: dropdown tools + collapsible sidebar */
.header-control-icons{display:none!important}.header-tools-dropdown{position:relative;display:inline-flex}.header-tools-dropdown summary{list-style:none;cursor:pointer}.header-tools-dropdown summary::-webkit-details-marker{display:none}.header-tools-trigger{display:inline-flex;align-items:center;gap:7px}.header-tools-trigger b{font-size:13px}.header-tools-trigger i{font-style:normal;color:var(--muted);font-size:11px}.header-tools-dropdown[open] .header-tools-trigger{border-color:#bfdbfe;background:#eff6ff;color:#1d4ed8}.header-tools-panel{position:absolute;right:0;top:calc(100% + 10px);z-index:200;width:min(720px,calc(100vw - 32px));max-height:calc(100vh - 100px);overflow:auto;background:rgba(255,255,255,.98);backdrop-filter:blur(16px);border:1px solid var(--border);border-radius:22px;box-shadow:0 24px 70px rgba(15,23,42,.20);padding:16px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.tool-menu-section{display:grid;gap:8px;align-content:start}.tool-menu-section>span{font-size:11px;text-transform:uppercase;letter-spacing:.12em;font-weight:950;color:var(--muted);padding:0 4px}.tool-menu-item{display:grid;grid-template-columns:34px 1fr;grid-template-areas:"icon title" "icon desc";column-gap:10px;align-items:center;border:1px solid var(--border);background:#fff;border-radius:16px;padding:10px 11px;transition:.15s}.tool-menu-item:hover,.tool-menu-item.active{transform:translateY(-1px);box-shadow:var(--soft);border-color:#bfdbfe;background:#eff6ff}.tool-menu-item>b{grid-area:icon;width:34px;height:34px;border-radius:12px;display:grid;place-items:center;background:var(--surface-2);font-size:17px}.tool-menu-item strong{grid-area:title;font-size:13px}.tool-menu-item small{grid-area:desc;font-size:12px;line-height:1.25}.sidebar-collapse-toggle{position:absolute;top:14px;right:-14px;z-index:50;width:30px;height:30px;border-radius:999px;border:1px solid rgba(226,232,240,.24);background:#fff;color:#0f172a;box-shadow:0 10px 25px rgba(15,23,42,.18);display:grid;place-items:center;font-size:20px;line-height:1;cursor:pointer;transition:.15s}.sidebar-collapse-toggle:hover{transform:scale(1.04);background:#eff6ff;color:#1d4ed8}.app-shell{transition:grid-template-columns .18s ease}.sidebar{transition:width .18s ease,padding .18s ease}.app-shell.sidebar-collapsed{grid-template-columns:76px 1fr}.app-shell.sidebar-collapsed .sidebar{padding:16px 10px;align-items:center;gap:16px}.app-shell.sidebar-collapsed .workspace-mark{width:54px;height:54px;padding:6px;justify-content:center}.app-shell.sidebar-collapsed .workspace-mark>span:not(.logo-badge){display:none}.app-shell.sidebar-collapsed .logo-badge{width:42px;height:42px}.app-shell.sidebar-collapsed .side-nav{width:100%;gap:8px}.app-shell.sidebar-collapsed .side-nav a{justify-content:center;padding:12px 8px;font-size:0;gap:0}.app-shell.sidebar-collapsed .side-nav a span{width:auto;font-size:18px}.app-shell.sidebar-collapsed .side-nav a:hover,.app-shell.sidebar-collapsed .side-nav a.active{transform:none}.app-shell.sidebar-collapsed .sidebar-footer{width:100%;display:grid;gap:10px}.app-shell.sidebar-collapsed .sidebar-footer .btn.full{width:100%;height:44px;padding:0;font-size:0}.app-shell.sidebar-collapsed .sidebar-footer .btn.full:before{content:"+";font-size:22px;line-height:1}.app-shell.sidebar-collapsed .mini-user{justify-content:center;padding:8px 0;border-top:1px solid rgba(255,255,255,.08)}.app-shell.sidebar-collapsed .mini-user span:not(.avatar){display:none}.app-shell.sidebar-collapsed .sidebar-collapse-toggle{right:-15px}.app-shell.sidebar-collapsed .sidebar-collapse-toggle{background:#eff6ff;color:#1d4ed8}.profile-top-link{display:inline-flex;align-items:center;gap:8px}.header-profile-photo{object-fit:cover}.top-actions{min-width:0}.topbar{overflow:visible}.main-wrap{min-width:0}.sidebar{overflow:visible}.side-nav{overflow-y:auto;overflow-x:hidden;padding-right:2px}.side-nav::-webkit-scrollbar,.header-tools-panel::-webkit-scrollbar{width:8px}.side-nav::-webkit-scrollbar-thumb,.header-tools-panel::-webkit-scrollbar-thumb{background:rgba(148,163,184,.45);border-radius:999px}
@media (max-width:1100px){.header-tools-panel{grid-template-columns:1fr;width:min(420px,calc(100vw - 24px))}.header-tools-trigger b{display:none}.global-search{max-width:none}.top-actions{gap:8px}.profile-top-link span{display:none}}
@media (max-width:780px){.app-shell,.app-shell.sidebar-collapsed{grid-template-columns:1fr}.sidebar{position:fixed;left:-286px;top:0;width:268px;height:100vh;z-index:300;transition:left .2s ease}.sidebar.open{left:0}.sidebar-collapse-toggle{display:none}.hamburger{display:inline-flex}.app-shell.sidebar-collapsed .sidebar{width:268px;padding:18px;align-items:stretch}.app-shell.sidebar-collapsed .workspace-mark>span:not(.logo-badge),.app-shell.sidebar-collapsed .mini-user span:not(.avatar){display:block}.app-shell.sidebar-collapsed .side-nav a{justify-content:flex-start;font-size:inherit;gap:11px;padding:11px 12px}.app-shell.sidebar-collapsed .side-nav a span{width:22px;font-size:inherit}.app-shell.sidebar-collapsed .sidebar-footer .btn.full{font-size:inherit}.app-shell.sidebar-collapsed .sidebar-footer .btn.full:before{content:none}.topbar{padding:0 14px;gap:10px}.global-search{display:none}.header-tools-panel{right:-90px;width:calc(100vw - 20px);max-height:calc(100vh - 85px)}.top-actions .btn.primary{display:none}}

/* StaffFlow V4.0.2 txAdmin multi-server + nav cleanup */
.txadmin-head .button-row{align-self:center}.txadmin-summary-grid{margin-bottom:18px}.txadmin-layout{align-items:start}.txadmin-panel .panel-head p{margin:4px 0 0;color:var(--muted);font-size:13px}.txadmin-server-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.txadmin-server-card{border:1px solid var(--border);border-radius:22px;background:#fff;padding:18px;box-shadow:var(--soft);display:grid;gap:10px}.txadmin-server-card.is-off{opacity:.76;background:var(--surface-2)}.tx-server-top{display:flex;gap:8px;align-items:center;flex-wrap:wrap;justify-content:space-between}.server-env{display:inline-flex;align-items:center;border-radius:999px;padding:5px 9px;text-transform:uppercase;letter-spacing:.08em;font-weight:950;font-size:11px;background:#dbeafe;color:#1d4ed8}.server-env.dev{background:#fef3c7;color:#92400e}.server-env.staging{background:#ede9fe;color:#6d28d9}.server-env.other{background:#e2e8f0;color:#334155}.txadmin-server-card h3{margin:0;font-size:20px;letter-spacing:-.03em}.txadmin-server-card p{margin:0;color:var(--muted);font-size:13px;line-height:1.45}.txadmin-server-card code{font-size:12px;background:var(--surface-2);border:1px solid var(--border);border-radius:8px;padding:2px 6px;color:#0f172a;word-break:break-all}.txadmin-edit{margin-top:4px}.txadmin-edit summary{list-style:none;cursor:pointer;display:inline-flex}.txadmin-edit summary::-webkit-details-marker{display:none}.mt-12{margin-top:12px}.empty-state-lite{border:1px dashed var(--border);background:var(--surface-2);border-radius:16px;padding:15px;color:var(--muted);font-weight:700;text-align:center}.side-nav a[href$="public-board.php"]{display:none!important}@media(max-width:1100px){.txadmin-server-grid{grid-template-columns:1fr}}@media(max-width:720px){.txadmin-server-card{padding:15px}.tx-server-top{justify-content:flex-start}.txadmin-server-card .button-row{display:grid}.txadmin-server-card .button-row form,.txadmin-server-card .button-row .btn{width:100%}}

/* V4.0.3 txAdmin complete integration */
.txadmin-head .button-row { align-items: center; }
.txadmin-server-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 16px;
}
.txadmin-server-card {
  border: 1px solid var(--border);
  background: #fff;
  border-radius: 22px;
  padding: 18px;
  box-shadow: var(--soft);
  display: grid;
  gap: 12px;
}
.txadmin-server-card.is-disabled { opacity: .76; }
.tx-card-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}
.tx-card-head h3 { margin: 3px 0 0; }
.tx-live-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 15px;
  border-radius: 18px;
  background: linear-gradient(135deg, rgba(37,99,235,.10), rgba(16,185,129,.08));
  border: 1px solid rgba(37,99,235,.14);
}
.tx-live-row strong {
  font-size: 22px;
  letter-spacing: -.04em;
  text-transform: capitalize;
}
.tx-live-row span { color: var(--muted); font-weight: 800; }
.tx-error {
  padding: 10px 12px;
  border-radius: 14px;
  background: #fef2f2;
  border: 1px solid #fecaca;
  color: #991b1b;
  font-weight: 800;
}
.tx-table-wrap { overflow: auto; max-height: 520px; }
.txadmin-edit { margin-top: 4px; }
.txadmin-edit summary { width: max-content; cursor: pointer; }
.txadmin-edit[open] summary { margin-bottom: 12px; }
.txadmin-panel code {
  background: #f8fafc;
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 2px 6px;
  color: #334155;
  word-break: break-all;
}
.txadmin-panel .data-table small { max-width: 340px; display: inline-block; overflow-wrap: anywhere; }
@media (max-width: 760px) {
  .tx-card-head,
  .tx-live-row { flex-direction: column; align-items: flex-start; }
}


/* V4.0.4 collapsed sidebar cleanup */
.sidebar{position:sticky;overflow:hidden}
.sidebar-collapse-toggle{top:10px;right:10px;left:auto;width:26px;height:26px;font-size:16px;line-height:1;border-radius:999px;z-index:60}
.workspace-mark{margin-top:20px}
.app-shell.sidebar-collapsed .sidebar{padding:10px 8px 12px;gap:10px;align-items:center;overflow:hidden}
.app-shell.sidebar-collapsed .sidebar-collapse-toggle{left:50%;right:auto;top:8px;transform:translateX(-50%)}
.app-shell.sidebar-collapsed .workspace-mark{margin-top:26px;width:44px;height:44px;padding:0;min-height:44px;border-radius:14px}
.app-shell.sidebar-collapsed .logo-badge{width:36px;height:36px;border-radius:12px;font-size:14px}
.app-shell.sidebar-collapsed .side-nav{width:100%;display:flex;flex-direction:column;align-items:center;gap:4px;overflow:visible;padding:0;margin:0}
.app-shell.sidebar-collapsed .side-nav a{width:44px;min-height:34px;padding:8px 0;border-radius:12px;justify-content:center;font-size:0;gap:0;flex:0 0 auto}
.app-shell.sidebar-collapsed .side-nav a span{width:auto;font-size:17px;line-height:1}
.app-shell.sidebar-collapsed .sidebar-footer{width:100%;display:grid;gap:8px;margin-top:auto}
.app-shell.sidebar-collapsed .sidebar-footer .btn.full{height:38px;border-radius:14px;padding:0}
.app-shell.sidebar-collapsed .mini-user{justify-content:center;padding:2px 0 0;border-top:0}
.app-shell.sidebar-collapsed .mini-user .avatar,.app-shell.sidebar-collapsed .mini-user .header-profile-photo{width:36px;height:36px}
.app-shell.sidebar-collapsed .mini-user .header-profile-photo{display:block;border-radius:999px;object-fit:cover;box-shadow:0 8px 18px rgba(15,23,42,.22)}
.app-shell.sidebar-collapsed .mini-user span:not(.avatar){display:none}
@media (min-height: 880px){.app-shell.sidebar-collapsed .side-nav{gap:6px}.app-shell.sidebar-collapsed .side-nav a{min-height:36px}}
@media (max-height: 760px){.app-shell.sidebar-collapsed .workspace-mark{margin-top:24px;width:40px;height:40px;min-height:40px}.app-shell.sidebar-collapsed .logo-badge{width:34px;height:34px;font-size:13px}.app-shell.sidebar-collapsed .side-nav{gap:2px}.app-shell.sidebar-collapsed .side-nav a{width:40px;min-height:31px;padding:6px 0}.app-shell.sidebar-collapsed .side-nav a span{font-size:16px}.app-shell.sidebar-collapsed .sidebar-footer{gap:6px}.app-shell.sidebar-collapsed .sidebar-footer .btn.full{height:34px;border-radius:12px}.app-shell.sidebar-collapsed .mini-user .avatar,.app-shell.sidebar-collapsed .mini-user .header-profile-photo{width:32px;height:32px}}


/* V4.0.5 cases hub + branded logo */
.brand-logo-wrap{background:transparent!important;box-shadow:none!important;padding:0;overflow:hidden;border-radius:14px}
.brand-logo-img{width:100%;height:100%;display:block;object-fit:contain;border-radius:14px;filter:drop-shadow(0 8px 18px rgba(15,23,42,.22))}
.workspace-mark strong{line-height:1.1}
.workspace-mark small{line-height:1.2;margin-top:3px}
.cases-hub-panel{display:grid;gap:16px}
.cases-hub-tabs{display:flex;gap:10px;flex-wrap:wrap;padding-bottom:4px}
.cases-tab{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--border);background:#f8fafc;border-radius:14px;padding:10px 14px;font-weight:900;color:#334155;box-shadow:var(--soft)}
.cases-tab span{display:inline-grid;place-items:center;min-width:22px;height:22px;border-radius:999px;background:#e2e8f0;font-size:12px;color:#0f172a;padding:0 6px}
.cases-tab.active{background:#eff6ff;border-color:#bfdbfe;color:#1d4ed8}
.cases-tab.active span{background:#dbeafe;color:#1d4ed8}
.app-shell.sidebar-collapsed .brand-logo-wrap{width:36px;height:36px;border-radius:12px}
@media (max-width:780px){.cases-hub-tabs{display:grid;grid-template-columns:1fr 1fr}.cases-tab{justify-content:center}}


/* V4.0.6 Discord ticket channel sync */
.ticket-console {
  display: grid;
  grid-template-columns: 340px minmax(0,1fr);
  gap: 18px;
  align-items: start;
}
.ticket-list-panel,
.ticket-conversation-panel {
  border: 1px solid var(--border);
  border-radius: 22px;
  background: #fff;
  box-shadow: var(--soft);
  padding: 18px;
}
.ticket-list-panel h2,
.ticket-conversation-panel h2 {
  margin: 0 0 12px;
}
.ticket-list-item {
  display: grid;
  gap: 4px;
  border: 1px solid var(--border);
  background: var(--surface-2);
  border-radius: 16px;
  padding: 12px;
}
.ticket-list-item.active,
.ticket-list-item:hover {
  background: #eff6ff;
  border-color: #bfdbfe;
  color: #1d4ed8;
}
.ticket-head {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: flex-start;
  border-bottom: 1px solid var(--border);
  padding-bottom: 16px;
  margin-bottom: 16px;
}
.ticket-head h2 {
  margin: 4px 0 6px;
}
.ticket-head p {
  margin: 0 0 4px;
  color: var(--muted);
}
.ticket-status-form {
  display: grid;
  gap: 8px;
  width: min(320px, 100%);
}
.ticket-messages {
  display: grid;
  gap: 12px;
  max-height: 520px;
  overflow: auto;
  padding-right: 6px;
}
.ticket-message {
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: 14px 15px;
  background: var(--surface-2);
}
.ticket-message.staff {
  background: #eff6ff;
  border-color: #bfdbfe;
}
.ticket-message.user {
  background: #fff;
}
.ticket-message-meta {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 8px;
}
.ticket-message p {
  margin: 0;
  white-space: pre-wrap;
  line-height: 1.55;
}
.ticket-reply-box {
  display: grid;
  gap: 12px;
  margin-top: 16px;
  border-top: 1px solid var(--border);
  padding-top: 16px;
}
.ticket-reply-box textarea {
  min-height: 130px;
}
@media(max-width: 980px) {
  .ticket-console {
    grid-template-columns: 1fr;
  }
  .ticket-head {
    flex-direction: column;
  }
  .ticket-status-form {
    width: 100%;
  }
}


/* StaffFlow V4.0.7 responsive polish + persisted night mode */
html.dark-mode-ready body{background:#0b1220;color:#f8fafc}
.theme-toggle{min-width:44px}.theme-toggle.active{background:#eff6ff;border-color:#bfdbfe;color:#1d4ed8}.dark-mode .theme-toggle.active{background:#1e293b;border-color:#334155;color:#f8fafc}.dark-mode .header-tools-dropdown[open] .header-tools-trigger{background:#1e293b;border-color:#334155;color:#f8fafc}.dark-mode .header-tools-panel{background:rgba(17,24,39,.98);border-color:#1f2937}.dark-mode .tool-menu-item{background:#111827;border-color:#1f2937}.dark-mode .tool-menu-item:hover,.dark-mode .tool-menu-item.active{background:#0f172a;border-color:#334155}.dark-mode .tool-menu-item>b{background:#0f172a}.dark-mode .tab{background:#111827;border-color:#1f2937}.dark-mode .tab.active{background:#172554;border-color:#1d4ed8;color:#bfdbfe}.dark-mode .txadmin-server-card,.dark-mode .ticket-message.user{background:#111827;border-color:#1f2937}.dark-mode .ticket-message.staff{background:#0f172a;border-color:#334155}.dark-mode .txadmin-panel code,.dark-mode .txadmin-server-card code{background:#0f172a;border-color:#1f2937;color:#cbd5e1}.dark-mode .progress{background:#1f2937}.dark-mode .login-body,.dark-mode .public-body{background:radial-gradient(circle at top left,rgba(37,99,235,.18),transparent 36%),radial-gradient(circle at bottom right,rgba(124,58,237,.14),transparent 30%),var(--bg)}.dark-mode .login-hero,.dark-mode .login-card{background:rgba(17,24,39,.88);border-color:#1f2937}.dark-mode .feature-grid span{background:#172554;border-color:#1d4ed8;color:#bfdbfe}
img,video,canvas,svg{max-width:100%;height:auto}.page,.main-wrap,.panel,.hero-card,.page-head{min-width:0}.button-row,.filters,.top-actions{min-width:0}.table-wrap{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}.data-table{min-width:760px}.form-grid>*{min-width:0}
@media(max-width:1180px){.stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.content-grid.three{grid-template-columns:1fr 1fr}.team-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.project-cards,.template-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.task-layout{grid-template-columns:1fr}.calendar-grid{grid-template-columns:repeat(4,minmax(150px,1fr))}.hero-card,.page-head{align-items:flex-start}.hero-card .button-row,.page-head .button-row{justify-content:flex-start}.form-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:900px){.content-grid.two,.content-grid.three{grid-template-columns:1fr}.team-grid,.project-cards,.template-grid{grid-template-columns:1fr 1fr}.calendar-grid{grid-template-columns:repeat(2,minmax(150px,1fr))}.hero-card,.page-head{flex-direction:column}.hero-card h1,.page-head h1{font-size:clamp(28px,7vw,34px)}.login-shell{grid-template-columns:1fr}.login-hero h1{font-size:clamp(34px,8vw,48px)}.feature-grid{grid-template-columns:repeat(2,1fr)}.modal-backdrop{align-items:flex-start}.modal-card{margin-top:20px}.form-grid.three{grid-template-columns:repeat(2,minmax(0,1fr))}.header-tools-panel{left:auto;right:0}}
@media(max-width:780px){body.sidebar-open{overflow:hidden}.sidebar.open:after{content:"";position:fixed;left:268px;top:0;width:calc(100vw - 268px);height:100vh;background:rgba(15,23,42,.45)}.topbar{height:auto;min-height:64px;padding:10px 12px;gap:8px;flex-wrap:nowrap}.hamburger,.icon-btn,.profile-top-link{min-width:42px;min-height:42px}.top-actions{margin-left:auto;gap:7px;justify-content:flex-end}.top-actions .btn.danger-soft{display:none}.header-tools-trigger b,.profile-top-link span{display:none}.header-tools-panel{position:fixed;left:10px;right:10px;top:70px;width:auto;max-height:calc(100vh - 90px);grid-template-columns:1fr}.page{padding:16px;gap:16px}.panel{padding:16px;border-radius:18px}.stats-grid,.stats-grid.three{grid-template-columns:1fr 1fr;gap:12px}.stat-card{padding:15px;border-radius:18px}.stat-card strong{font-size:30px}.form-grid,.form-grid.two,.form-grid.three{grid-template-columns:1fr}.form-grid .wide{grid-column:auto}.filters{display:grid;grid-template-columns:1fr;align-items:stretch}.filters select,.filters input,.filters .btn{max-width:none;width:100%}.button-row{display:grid;grid-template-columns:1fr}.button-row .btn,.button-row form{width:100%}.list-item{align-items:flex-start;flex-direction:column}.list-item .button-row,.list-item form{width:100%}.card-foot{align-items:flex-start;flex-direction:column;gap:8px}.board-wrap{grid-template-columns:repeat(var(--cols,5),minmax(260px,86vw));scroll-snap-type:x mandatory}.kanban-column{min-height:420px;scroll-snap-align:start}.kanban-tasks{min-height:340px}.task-card{cursor:default}.public-hero,.ticket-head,.tx-card-head,.tx-live-row{flex-direction:column;align-items:flex-start}.public-detail{padding:20px;border-radius:22px}.quick-create-panel{position:relative;top:auto}.modal-card{width:100%;max-height:calc(100vh - 40px);border-radius:20px}.modal-head{align-items:flex-start}.modal-head h2{font-size:24px}.data-table{min-width:680px}.tx-table-wrap{max-height:none}}
@media(max-width:560px){.topbar{position:sticky}.top-actions{gap:6px}.top-actions .icon-btn:not(.theme-toggle):first-child{display:none}.theme-toggle{padding:9px 10px}.hero-card,.page-head{padding:18px;border-radius:20px}.hero-card h1,.page-head h1,.public-hero h1,.public-detail h1{font-size:28px;line-height:1.05}.stats-grid,.stats-grid.three,.team-grid,.project-cards,.template-grid,.calendar-grid,.txadmin-server-grid{grid-template-columns:1fr}.feature-grid{grid-template-columns:1fr}.login-body{padding:14px}.login-hero,.login-card{padding:24px;border-radius:24px}.public-shell{padding:14px}.public-grid{gap:12px}.tool-menu-item{grid-template-columns:30px 1fr;padding:9px}.tool-menu-item>b{width:30px;height:30px}.profile-top-link{padding:8px}.avatar{width:30px;height:30px}.data-table{min-width:620px}.chip-control{min-height:44px}.ticket-message-meta{flex-direction:column}.calendar-day{min-height:100px}.btn{white-space:normal}}

/* V4.0.8 dark mode fixes for cases hub / ticket console */
.dark-mode .gov-card,
.dark-mode .ticket-list-panel,
.dark-mode .ticket-conversation-panel {
  background:#111827;
  border-color:#1f2937;
  color:#f8fafc;
}
.dark-mode .gov-card small,
.dark-mode .ticket-head p,
.dark-mode .ticket-head small,
.dark-mode .ticket-list-item small,
.dark-mode .ticket-message-meta small,
.dark-mode .governance-table .data-table th {
  color:#94a3b8;
}
.dark-mode .gov-card strong,
.dark-mode .ticket-list-item strong,
.dark-mode .ticket-head h2,
.dark-mode .ticket-message-meta strong,
.dark-mode .ticket-message p {
  color:#f8fafc;
}
.dark-mode .cases-tab {
  background:#111827;
  border-color:#1f2937;
  color:#cbd5e1;
}
.dark-mode .cases-tab span {
  background:#1f2937;
  color:#e5e7eb;
}
.dark-mode .cases-tab.active {
  background:#172554;
  border-color:#1d4ed8;
  color:#bfdbfe;
}
.dark-mode .cases-tab.active span {
  background:rgba(59,130,246,.18);
  color:#bfdbfe;
}
.dark-mode .ticket-list-item {
  background:#0f172a;
  border-color:#1f2937;
  color:#e5e7eb;
}
.dark-mode .ticket-list-item.active,
.dark-mode .ticket-list-item:hover {
  background:#172554;
  border-color:#1d4ed8;
  color:#bfdbfe;
}
.dark-mode .ticket-head,
.dark-mode .ticket-reply-box {
  border-color:#1f2937;
}
.dark-mode .governance-table .data-table td {
  background:#111827;
  border-color:#1f2937;
  color:#f8fafc;
}
.dark-mode .access-pill {
  background:#172554;
  color:#bfdbfe;
}
.dark-mode .access-pill.off {
  background:rgba(127,29,29,.28);
  color:#fecaca;
}
.dark-mode .ticket-status-form input::placeholder,
.dark-mode .ticket-reply-box textarea::placeholder {
  color:#64748b;
}

/* V4.0.9 kanban dark mode readability polish */
.dark-mode .board-wrap {
  gap: 18px;
  padding-bottom: 14px;
}
.dark-mode .kanban-column {
  background: linear-gradient(180deg,#101827 0%,#0b1220 100%);
  border-color:#26354b;
  box-shadow:0 20px 42px rgba(0,0,0,.24);
}
.dark-mode .kanban-column header {
  border-bottom:1px solid #223047;
  padding-bottom:14px;
}
.dark-mode .kanban-column h2 {
  color:#f8fafc;
  letter-spacing:-.02em;
}
.dark-mode .kanban-column header .pill {
  background:#1e293b;
  border:1px solid #334155;
  color:#dbeafe;
  min-width:26px;
  justify-content:center;
}
.dark-mode .kanban-tasks {
  gap:14px;
  padding:14px;
}
.dark-mode .task-card,
.dark-mode .task-card-polished,
.dark-mode .compact-task-card {
  background:linear-gradient(180deg,#111c2e 0%,#0f172a 100%);
  border-color:#2a3a52;
  box-shadow:0 16px 34px rgba(0,0,0,.22);
}
.dark-mode .task-card:hover,
.dark-mode .task-card-polished:hover {
  border-color:#3b82f6;
  box-shadow:0 22px 42px rgba(0,0,0,.32),0 0 0 1px rgba(59,130,246,.16) inset;
}
.dark-mode .task-card h3,
.dark-mode .task-card h3 a {
  color:#f8fafc;
}
.dark-mode .task-card p {
  color:#d6e1f0;
  line-height:1.48;
}
.dark-mode .task-card .eyebrow {
  color:#60a5fa;
}
.dark-mode .task-id-badge {
  background:#172554;
  border-color:#1d4ed8;
  color:#bfdbfe;
}
.dark-mode .task-id-row.compact,
.dark-mode .task-id-inline-label,
.dark-mode .card-foot,
.dark-mode .card-foot span,
.dark-mode .task-card small {
  color:#9fb2c9;
}
.dark-mode .task-id-inline-label strong,
.dark-mode .assignment-line strong {
  color:#f8fafc;
}
.dark-mode .assignment-line {
  background:rgba(15,23,42,.72);
  border-color:#2a3a52;
  color:#cbd5e1;
  border-style:solid;
}
.dark-mode .task-card .badge,
.dark-mode .task-card .pill {
  border:1px solid rgba(148,163,184,.18);
}
.dark-mode .task-card .badge-normal,
.dark-mode .task-card .pill {
  background:#1e293b;
  color:#dbeafe;
}
.dark-mode .task-card .badge-high,
.dark-mode .task-card .badge-urgent {
  background:rgba(248,113,113,.14);
  border-color:rgba(248,113,113,.28);
  color:#fecaca;
}
.dark-mode .task-card .badge-low {
  background:rgba(74,222,128,.13);
  border-color:rgba(74,222,128,.25);
  color:#bbf7d0;
}
.dark-mode .task-id-copy,
.dark-mode .task-id-copy-inline {
  background:#dbeafe;
  border-color:#bfdbfe;
  color:#1d4ed8;
}
.dark-mode .task-id-copy:hover,
.dark-mode .task-id-copy-inline:hover {
  background:#bfdbfe;
  color:#1e40af;
}
.dark-mode .progress {
  background:#273449;
  border:1px solid rgba(148,163,184,.12);
}
.dark-mode .progress span {
  background:linear-gradient(90deg,#22c55e,#10b981);
  box-shadow:0 0 18px rgba(34,197,94,.28);
}
.dark-mode .link-button {
  color:#60a5fa;
}
.dark-mode .link-button:hover {
  color:#93c5fd;
}
.dark-mode .clean-card-actions .switch-line {
  background:#0f172a;
  border-color:#2a3a52;
  color:#dbeafe;
}
.dark-mode .clean-card-actions .switch-line span {
  color:#dbeafe;
}
.dark-mode .task-card .btn.ghost,
.dark-mode .task-card .btn.tiny.ghost {
  background:#0f172a;
  border-color:#2a3a52;
  color:#dbeafe;
}
.dark-mode .task-card .btn.ghost:hover,
.dark-mode .task-card .btn.tiny.ghost:hover {
  background:#172554;
  border-color:#1d4ed8;
  color:#bfdbfe;
}
.dark-mode .task-card .btn.success-soft {
  background:rgba(34,197,94,.16);
  border-color:rgba(74,222,128,.32);
  color:#bbf7d0;
}
.dark-mode .task-card .btn.success-soft:hover {
  background:rgba(34,197,94,.24);
  border-color:rgba(74,222,128,.44);
}
.dark-mode .task-card .avatar {
  box-shadow:0 0 0 2px #0f172a,0 8px 18px rgba(0,0,0,.28);
}
.dark-mode .drop-hover {
  outline-color:#60a5fa;
  background:rgba(37,99,235,.1);
}
@media(max-width:780px){
  .dark-mode .board-wrap{gap:14px;}
  .dark-mode .kanban-column{min-height:380px;}
  .dark-mode .kanban-tasks{padding:12px;}
}


/* V4.1.0 topbar dark mode polish */
.dark-mode .topbar {
  background: rgba(2, 6, 23, .92);
  border-bottom-color: #172033;
  box-shadow: 0 14px 36px rgba(0, 0, 0, .22);
}
.dark-mode .icon-btn,
.dark-mode .header-tools-trigger,
.dark-mode .profile-top-link {
  background: #0f172a;
  color: #f8fafc;
  border-color: #243041;
  box-shadow: 0 10px 24px rgba(2, 6, 23, .26);
}
.dark-mode .icon-btn:hover,
.dark-mode .header-tools-trigger:hover,
.dark-mode .profile-top-link:hover {
  background: #132033;
  border-color: #334155;
}
.dark-mode .header-tools-trigger i {
  color: #94a3b8;
}
.dark-mode .btn.primary {
  background: linear-gradient(135deg, #2563eb, #1d4ed8);
  border-color: #2563eb;
  color: #ffffff;
}
.dark-mode .btn.primary:hover {
  background: linear-gradient(135deg, #1d4ed8, #1e40af);
  border-color: #1d4ed8;
}
.dark-mode .btn.danger-soft {
  background: rgba(127, 29, 29, .18);
  color: #fecaca;
  border-color: rgba(248, 113, 113, .32);
}
.dark-mode .btn.danger-soft:hover {
  background: rgba(127, 29, 29, .28);
  border-color: rgba(248, 113, 113, .45);
}
.dark-mode .top-actions .icon-btn em {
  box-shadow: 0 0 0 3px #020617;
}
@media (max-width: 780px) {
  .dark-mode .topbar {
    background: rgba(2, 6, 23, .96);
  }
}


/* V4.1.1 task detail dark mode cleanup */
.dark-mode .summary-card {
  background: #111827;
  border-color: #1f2937;
  color: #f8fafc;
}
.dark-mode .summary-card small,
.dark-mode .summary-card span,
.dark-mode .detail-panel-head p,
.dark-mode .detail-section-head p,
.dark-mode .info-row span,
.dark-mode .view-only-kv span,
.dark-mode .info-row span small {
  color: #94a3b8;
}
.dark-mode .summary-card strong,
.dark-mode .detail-panel h2,
.dark-mode .detail-section h3,
.dark-mode .info-row strong,
.dark-mode .view-only-kv strong,
.dark-mode .detail-check-row span,
.dark-mode .detail-toggle strong,
.dark-mode .detail-description-block h3 {
  color: #f8fafc;
}
.dark-mode .detail-section,
.dark-mode .detail-toggle,
.dark-mode .view-only-kv > div,
.dark-mode .info-row,
.dark-mode .detail-check-row,
.dark-mode .upload-form-clean input[type="file"] {
  background: #0f172a;
  border-color: #1f2937;
}
.dark-mode .detail-comment {
  background: #0f172a;
  border-color: #1f2937;
}
.dark-mode .detail-toggle small,
.dark-mode .detail-description-block p,
.dark-mode .detail-comment p {
  color: #cbd5e1;
}
.dark-mode .task-checklist-list .check-row input[type="checkbox"],
.dark-mode .detail-toggle input[type="checkbox"] {
  accent-color: #3b82f6;
}
.dark-mode .detail-grid select[multiple],
.dark-mode .detail-grid select[size],
.dark-mode .detail-grid select[multiple] option,
.dark-mode .detail-grid select[size] option {
  background: #0b1220;
  color: #f8fafc;
}
.dark-mode .detail-grid select[multiple],
.dark-mode .detail-grid select[size] {
  border-color: #1f2937;
}
.dark-mode .detail-grid select[multiple] option:checked,
.dark-mode .detail-grid select[size] option:checked {
  background: #1d4ed8;
  color: #ffffff;
}
.dark-mode input[type="date"],
.dark-mode input[type="file"],
.dark-mode input[type="number"],
.dark-mode input[type="text"],
.dark-mode input:not([type]),
.dark-mode textarea,
.dark-mode select {
  background: #111827;
  color: #f8fafc;
  border-color: #1f2937;
}
.dark-mode input::placeholder,
.dark-mode textarea::placeholder {
  color: #64748b;
}
.dark-mode input[type="date"]::-webkit-calendar-picker-indicator {
  filter: invert(1) brightness(.9);
  opacity: .85;
}
.dark-mode .upload-form-clean input[type="file"]::file-selector-button {
  background: #172554;
  color: #dbeafe;
  border: 1px solid #334155;
  border-radius: 10px;
  padding: 8px 12px;
  margin-right: 10px;
  cursor: pointer;
}
.dark-mode .upload-form-clean input[type="file"]::-webkit-file-upload-button {
  background: #172554;
  color: #dbeafe;
  border: 1px solid #334155;
  border-radius: 10px;
  padding: 8px 12px;
  margin-right: 10px;
  cursor: pointer;
}
.dark-mode .log-row strong,
.dark-mode .file-row-clean strong {
  color: #f8fafc;
}
.dark-mode .file-row-clean small {
  color: #94a3b8;
}
.dark-mode .file-row-clean:hover {
  background: #101a2d;
  border-color: #334155;
}
