:root{
  --bg:#fcfcfc;
  --bg-soft:#f9fdff;
  --panel:#ffffff;
  --panel-soft:#f3f7fb;
  --line:#f2f6fa;
  --line-strong:#dfeaf5;
  --text:#162729;
  --text-soft:#4f6465;
  --text-muted:#728584;
  --sidebar:#15282a;
  --sidebar-soft:#244649;
  --primary:#215a5e;
  --primary-strong:#163d40;
  --primary-soft:#dcebea;
  --mint:#5e9d9c;
  --mint-soft:#dff0ee;
  --gold:#b98a22;
  --gold-soft:#f6ead1;
  --danger:#b8473f;
  --danger-soft:#f8e1df;
  --warning:#a66b1f;
  --warning-soft:#f7ead8;
  --success:#2f7a5f;
  --success-soft:#e2f2ea;
  --shadow:0 10px 30px rgba(18,39,41,.08);
  --radius:18px;
  --radius-sm:12px;
  --space-1:4px;
  --space-2:8px;
  --space-3:12px;
  --space-4:16px;
  --space-5:20px;
  --space-6:24px;
  --space-7:32px;
  --space-8:40px;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:Arial,sans-serif;
  font-size:16px;
  line-height:1.55;
  color:var(--text);
  background:linear-gradient(180deg,var(--bg) 0%, var(--bg-soft) 100%);
}
a{color:var(--primary);text-decoration:none}
a:hover{text-decoration:none}
p{margin:0;line-height:1.65}
h1,h2,h3{margin:0;line-height:1.2;color:var(--primary-strong)}
strong{font-weight:800}
img{max-width:100%;display:block}
button,input,select,textarea{font:inherit}

.app-shell{display:flex;min-height:100vh}
.sidebar{
  width:286px;
  background:linear-gradient(180deg,#132325 0%, #173437 100%);
  color:#fff;
  padding:28px 20px;
  transition:transform .25s ease;
  box-shadow:18px 0 40px rgba(0,0,0,.12);
}
.brand-wrap{margin-bottom:28px}
.brand-logo-box{
  background:#fff;
  border-radius:16px;
  padding:12px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  margin-bottom:14px;
  border:1px solid rgba(255,255,255,.18);
}
.brand-logo{display:block;max-width:170px;width:100%;height:auto}
.brand{font-size:1.85rem;font-weight:800;letter-spacing:-.03em;color:#fff}
.brand-sub{color:#9ab0af;font-size:.96rem;margin-top:8px}

.nav{display:grid;gap:8px}
.nav a,
.nav-link{
  color:#dbe6e5;
  padding:13px 14px;
  border-radius:14px;
  font-weight:700;
  display:flex;
  align-items:center;
  gap:12px;
  transition:background .18s ease,color .18s ease, transform .18s ease;
}
.nav a:hover,
.nav-link:hover{background:rgba(255,255,255,.08);color:#fff;transform:translateX(1px)}
.nav-link::before{
  content:"";
  width:18px;
  height:18px;
  flex:0 0 18px;
  background-repeat:no-repeat;
  background-size:18px 18px;
  background-position:center;
  opacity:.92;
}
.nav-dashboard::before{background-image:url('icons/dashboard.svg')}
.nav-projects::before{background-image:url('icons/projects.svg')}
.nav-project-create::before{background-image:url('icons/plus.svg')}
.nav-industries::before{background-image:url('icons/library.svg')}
.nav-sources::before{background-image:url('icons/sources.svg')}
.nav-users::before{background-image:url('icons/users.svg')}
.nav-logout::before{background-image:url('icons/logout.svg')}

.main{flex:1;padding:30px}
.main-auth{display:grid;place-items:center}
.mobile-topbar{
  display:none;
  align-items:center;
  gap:14px;
  padding:14px 16px;
  background:linear-gradient(180deg,#132325 0%, #173437 100%);
  color:#fff;
  position:sticky;
  top:0;
  z-index:40;
  box-shadow:0 6px 20px rgba(0,0,0,.12);
}
.mobile-brand{display:flex;align-items:center;gap:10px;font-weight:800}
.brand-logo-mobile{
  width:36px;height:36px;border-radius:10px;background:#fff;padding:5px;border:1px solid rgba(255,255,255,.12)
}
.burger{
  border:none;background:rgba(255,255,255,.1);color:#fff;border-radius:12px;padding:10px 12px;font-size:1.1rem;cursor:pointer
}
.nav-overlay{display:none;position:fixed;inset:0;background:rgba(15,23,42,.45);z-index:30}
.nav-overlay.is-open{display:block}

.card{
  background:var(--panel);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:var(--space-6);
}
.auth-card,.narrow-card{max-width:520px;width:100%}

.page-head{
  display:flex;
  justify-content:space-between;
  gap:var(--space-5);
  align-items:flex-start;
  margin-bottom:22px;
}
.page-head h1{margin-top:2px;font-size:2rem;letter-spacing:-.03em}
.page-actions{display:flex;gap:10px;flex-wrap:wrap}
.eyebrow{color:var(--mint);font-size:.8rem;text-transform:uppercase;letter-spacing:.14em;font-weight:800;margin-bottom:7px}
.muted{color:var(--text-muted)}
.table-sub,.helper,.modal-note{color:var(--text-muted);font-size:.92rem;line-height:1.55}

.btn{
  display:inline-flex;align-items:center;justify-content:center;
  border:none;background:var(--primary);color:#fff;
  padding:12px 16px;border-radius:14px;font-weight:800;cursor:pointer;
  box-shadow:none;
}
.btn:hover{background:var(--primary-strong)}
.btn.secondary{background:var(--sidebar-soft)}
.btn.ghost{background:var(--panel-soft);color:var(--primary-strong);border:1px solid var(--line)}
.btn.small{padding:10px 12px;border-radius:12px}

.form-grid{display:grid;gap:18px}
.form-grid.two-col{grid-template-columns:repeat(2,minmax(0,1fr))}
.form-grid.one-col{grid-template-columns:1fr}
label{display:grid;gap:8px;font-size:.95rem;font-weight:700;color:var(--primary-strong)}
input[type=text],input[type=password],select,textarea{
  width:100%;border:1px solid var(--line);border-radius:14px;padding:13px 14px;background:#fff;color:var(--text);
}
input[type=text]:focus,input[type=password]:focus,select:focus,textarea:focus{
  outline:none;border-color:var(--mint);box-shadow:0 0 0 4px rgba(94,157,156,.13)
}
textarea{resize:vertical;line-height:1.6;min-height:110px}
.full-width{grid-column:1/-1}
.field-title{font-weight:800;margin-bottom:10px;color:var(--primary-strong)}
.checkbox-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px 16px}
.checkbox-grid.three-col{grid-template-columns:repeat(3,minmax(0,1fr))}
.checkbox-grid.four-col{grid-template-columns:repeat(4,minmax(0,1fr))}
.checkbox{
  display:flex;align-items:flex-start;gap:10px;font-weight:600;background:var(--panel-soft);border:1px solid var(--line);border-radius:14px;padding:12px 14px;
}
.checkbox input{margin-top:3px}
.actions-row{display:flex;justify-content:flex-end}
.top-space{margin-top:20px}.top-space-sm{margin-top:14px}.top-space-lg{margin-top:28px}

.alert{padding:14px 16px;border-radius:14px;margin-bottom:16px;font-weight:700}
.alert-success{background:var(--success-soft);color:var(--success);border:1px solid #b9dfcf}
.alert-error{background:var(--danger-soft);color:var(--danger);border:1px solid #e7b9b5}

.stats-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin-bottom:20px}
.stats-grid.five,.stats-grid.compact.five{grid-template-columns:repeat(5,minmax(0,1fr))}
.stat-card{display:grid;gap:8px;padding:20px;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.stat-card span{color:var(--text-muted);font-weight:700;letter-spacing:.01em}
.stat-card strong{font-size:1.9rem;color:var(--primary-strong)}
.stat-card-small strong{font-size:1.45rem}

.table-wrap{overflow:auto;-webkit-overflow-scrolling:touch}
.table{width:100%;border-collapse:collapse}
.table th,.table td{text-align:left;padding:16px 12px;border-bottom:1px solid var(--line);vertical-align:top}
.table th{color:var(--text-soft);font-size:.88rem;text-transform:uppercase;letter-spacing:.08em}
.table-head{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:14px}

.project-meta-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}
.meta-card{padding:22px 20px}
.meta-label{display:block;color:var(--text-muted);font-size:.86rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase;margin-bottom:10px}
.meta-value{display:block;color:var(--primary-strong);font-size:1.08rem;line-height:1.45;letter-spacing:-.01em;word-break:break-word}
.meta-card .table-sub{margin-top:8px}

.filter-card{margin-bottom:18px}
.filters-inline{display:flex;gap:12px;align-items:end;flex-wrap:wrap}
.filters-inline label{min-width:180px}

.task-stack{display:grid;gap:18px}
.task-top{display:flex;justify-content:space-between;gap:20px;margin-bottom:14px}
.task-top h3{margin:30px 0px 10px 0px;font-size:1.45rem;letter-spacing:-.02em}
.task-top .muted{font-size:1rem;line-height:1.65}
.task-badges-row{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.task-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px 20px;margin:18px 0 18px}
.task-grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.task-grid > div{
  background:var(--panel-soft);border:1px solid var(--line);border-radius:16px;padding:16px 16px 14px;
}
.detail-label{display:block;margin-bottom:8px;color:var(--primary-strong);font-size:.96rem}
.detail-text{color:var(--text);word-break:break-word}
.inline-form{display:flex;gap:12px;align-items:end;border-top:1px solid var(--line);padding-top:18px;margin-top:4px}
.inline-form .grow{flex:1}
.inline-form label{font-size:.9rem}
.inline-form textarea{min-height:78px}

.badge,.status-badge,.target-chip{
  display:inline-flex;align-items:center;padding:7px 11px;border-radius:999px;font-size:.82rem;font-weight:800;line-height:1.2;border:1px solid transparent
}
.badge-core{background:#202020;color:#ffffff}
.badge-very_important{background:#ece4f5;color:#6f3d96}
.badge-nice_to_have{background:#e2f2f3;color:#1c6668}
.badge-later{background:var(--gold-soft);color:var(--warning)}
.badge-avoid{background:var(--danger-soft);color:var(--danger)}
.badge-quality{background:var(--mint-soft);color:var(--primary-strong)}
.badge-approval{background:#edf0ef;color:var(--primary-strong)}
.badge-conditional{background:var(--warning-soft);color:var(--warning)}
.badge-neutral{background:#ecebe7;color:var(--text-soft)}
.status-open{background:var(--danger-soft);color:var(--danger);border-color:#e9bdb8}
.status-in_progress{background:#e2f2f3;color:#1c6668;border-color:#bfdfde}
.status-deferred{background:var(--warning-soft);color:var(--warning);border-color:#ead4b8}
.status-not_relevant{background:#ecebe7;color:#5f6868;border-color:#ded8d0}
.status-done{background:var(--success-soft);color:var(--success);border-color:#c5e1d4}

.split-layout{display:grid;grid-template-columns:320px 1fr;gap:20px}
.list-card{padding:10px;max-height:calc(100vh - 160px);overflow:auto}
.industry-link{display:grid;gap:4px;padding:14px;border-radius:14px;color:var(--text)}
.industry-link span{color:var(--text-muted);font-size:.9rem}
.industry-link:hover,.industry-link.active{background:var(--panel-soft)}
.task-mini{border:1px solid var(--line);border-radius:16px;padding:16px;background:#fff}
.task-mini-top{display:flex;gap:8px;align-items:center;margin-bottom:10px;flex-wrap:wrap}
.task-mini h3,.task-mini-rich h3{font-size:1.08rem;margin:8px 0 6px}
.mini-meta{color:var(--text-muted);font-size:.92rem;margin-top:8px;line-height:1.55}
.target-list{display:flex;flex-wrap:wrap;gap:10px}
.target-chip{background:var(--panel-soft);color:var(--primary-strong);border-color:var(--line)}

.source-link-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:2px}
.source-chip{
  display:inline-flex;align-items:center;gap:8px;padding:10px 13px;border-radius:999px;background:var(--panel-soft);color:var(--primary-strong);font-weight:800;border:1px solid var(--line)
}
.source-chip::before{content:"";width:16px;height:16px;background-repeat:no-repeat;background-size:16px 16px;background-position:center}
.source-chip-website::before,.source-chip.primary::before{background-image:url('icons/external.svg')}
.source-chip.primary{background:#e3efee;color:var(--primary-strong);border-color:#bfd5d4}

.score-pill{border:1px solid transparent;border-radius:999px;padding:7px 11px;font-weight:800;cursor:pointer;background:#f0f2ef}
.score-excellent{background:#d9efe7;color:var(--success);border-color:#bddfd0}
.score-good{background:#dff0ee;color:var(--primary-strong);border-color:#bfd9d8}
.score-ok{background:var(--gold-soft);color:var(--warning);border-color:#e7d0ac}
.score-weak{background:#fde8d7;color:#9b5517;border-color:#f0c89d}
.score-bad{background:var(--danger-soft);color:var(--danger);border-color:#e8bdb8}

.score-dialog{width:min(760px,92vw);border:0;border-radius:22px;padding:0;overflow:hidden;box-shadow:0 25px 60px rgba(0,0,0,.25)}
.score-dialog::backdrop{background:rgba(10,20,22,.48)}
.dialog-head{display:flex;justify-content:space-between;align-items:center;padding:18px 20px;border-bottom:1px solid var(--line);background:#fff}
.dialog-close{border:0;background:transparent;font-size:28px;cursor:pointer;line-height:1;color:var(--text-soft)}
.score-breakdown{padding:18px 20px;display:grid;gap:14px;background:var(--panel)}
.score-row{display:grid;grid-template-columns:200px 1fr 54px;gap:12px;align-items:center}
.score-row span{font-weight:700;color:var(--primary-strong)}
.score-bar{height:10px;background:#ece7e0;border-radius:999px;overflow:hidden}
.score-bar-fill{height:100%;background:linear-gradient(90deg,var(--mint) 0%, var(--primary) 100%);border-radius:999px}

.users-grid{display:grid;gap:16px;grid-template-columns:1fr 1fr}

.is-hidden{display:none!important}

@media (max-width:1260px){
  .task-grid-3{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width:1100px){
  .stats-grid,.stats-grid.five,.stats-grid.compact.five,.project-meta-grid,.form-grid.two-col,.task-grid,.task-grid-3,.split-layout{grid-template-columns:1fr}
  .checkbox-grid.three-col,.checkbox-grid.four-col{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width:860px){
  .mobile-topbar{display:flex}
  .app-shell{display:block}
  .sidebar{position:fixed;top:0;left:0;bottom:0;z-index:50;transform:translateX(-100%);width:290px;overflow:auto}
  .sidebar.is-open{transform:translateX(0)}
  .main{padding:18px}
  .page-head,.inline-form,.filters-inline,.table-head{flex-direction:column;align-items:stretch}
  .checkbox-grid,.checkbox-grid.three-col,.checkbox-grid.four-col{grid-template-columns:1fr}
  .responsive-table thead{display:none}
  .responsive-table,.responsive-table tbody,.responsive-table tr,.responsive-table td{display:block;width:100%}
  .responsive-table tr{padding:12px 0;border-bottom:1px solid var(--line)}
  .responsive-table td{border-bottom:none;padding:8px 0}
  .responsive-table td::before{content:attr(data-label);display:block;font-size:.76rem;color:var(--text-muted);font-weight:800;text-transform:uppercase;letter-spacing:.08em;margin-bottom:5px}
  .source-link-row .source-chip{width:100%;justify-content:center}
}
@media (max-width:768px){
  .page-head h1{font-size:1.72rem}
  .filters-inline label{min-width:100%}
  .users-grid{grid-template-columns:1fr}
  .score-row{grid-template-columns:1fr}
  .task-top{flex-direction:column}
  .card{padding:20px}
  .meta-card{padding:18px}
}
@media print{
  .sidebar,.mobile-topbar,.nav-overlay,.btn,.inline-form,.filter-card,.source-link-row{display:none!important}
  .main{padding:0}
  body{background:#fff}
  .card,.stat-card{box-shadow:none}
}

.cards-grid.two{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.cards-grid.three{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.project-meta-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.chart-row{display:flex;gap:18px;align-items:center;flex-wrap:wrap}.chart-donut{width:180px;height:180px;border-radius:50%;flex:0 0 180px;border:1px solid var(--line)}.chart-legend{display:grid;gap:10px;flex:1}.chart-legend-item{display:flex;align-items:center;gap:10px}.chart-legend-item strong{margin-left:auto}.chart-dot{width:12px;height:12px;border-radius:999px;display:inline-block}.prompt-box{width:100%;border:1px solid var(--line);border-radius:14px;padding:14px;background:#fff;min-height:220px}.is-hidden{display:none!important}.tabs-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}.task-grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}.meta-card .btn{justify-self:start}.target-list{display:flex;flex-wrap:wrap;gap:8px}.source-link-row{display:flex;gap:10px;flex-wrap:wrap}.source-chip{display:inline-flex;align-items:center;padding:8px 12px;border-radius:999px;border:1px solid var(--line);background:var(--panel-soft);font-weight:700}.source-chip.primary{background:var(--primary);color:#fff;border-color:var(--primary)}@media (max-width: 900px){.project-meta-grid,.cards-grid.two,.cards-grid.three,.stats-grid.three{grid-template-columns:1fr 1fr}.chart-row{flex-direction:column;align-items:flex-start}}