/* ============================================================
   ArquiPro — Design System
   Editorial / luxo · marfim, grafite, terracota
   ============================================================ */
:root{
  --bg:#F3EFE9;
  --paper:#FBF9F5;
  --ink:#1E1B17;
  --ink-soft:#6B6258;
  --line:#E3DCD1;
  --line-strong:#D4C9B8;
  --clay:#B26B43;
  --clay-d:#965436;
  --sage:#6E7E63;
  --gold:#C9A24B;
  --danger:#B0473C;
  --ok:#5C7A52;
  --warn:#C08A2B;
  --blue:#4A6175;
  --radius:16px;
  --radius-sm:10px;
  --shadow:0 1px 2px rgba(30,27,23,.04), 0 8px 30px -12px rgba(30,27,23,.18);
  --shadow-lg:0 30px 70px -25px rgba(30,27,23,.45);
  --serif:"Fraunces",Georgia,serif;
  --sans:"Manrope",system-ui,sans-serif;
  --ease:cubic-bezier(.4,.05,.05,1);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--sans);
  background:var(--bg);
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
  font-size:14.5px;
  line-height:1.5;
}
a{color:inherit;text-decoration:none}
input,select,textarea,button{font-family:inherit;font-size:inherit;color:inherit}
h1,h2,h3,h4{margin:0;font-weight:500;letter-spacing:-.01em}
::selection{background:var(--clay);color:#fff}

/* ---------- App loader ---------- */
.app-loader{
  position:fixed;inset:0;z-index:9999;background:var(--bg);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;
  transition:opacity .6s var(--ease),visibility .6s;
}
.app-loader.hide{opacity:0;visibility:hidden}
.loader-mark svg{width:60px;height:60px;fill:none;stroke:var(--clay);stroke-width:3;stroke-linecap:round;stroke-linejoin:round}
.loader-mark polyline,.loader-mark line{
  stroke-dasharray:130;stroke-dashoffset:130;
  animation:draw 1.4s var(--ease) infinite alternate;
}
.loader-mark line{animation-delay:.2s}
@keyframes draw{to{stroke-dashoffset:0}}
.loader-word{font-family:var(--serif);font-size:20px;letter-spacing:.32em;text-transform:uppercase;color:var(--ink-soft);
  opacity:0;animation:fadeUp .8s .3s forwards}

/* ---------- Brand mark ---------- */
.brand-mark{
  width:46px;height:46px;border-radius:13px;display:grid;place-items:center;
  background:linear-gradient(145deg,var(--clay),var(--clay-d));color:#fff;
  font-family:var(--serif);font-size:24px;font-weight:600;box-shadow:0 8px 20px -8px rgba(178,107,67,.7)}
.brand-mark.sm{width:38px;height:38px;border-radius:11px;font-size:20px}

/* ===================== LOGIN ===================== */
.login-body{font-family:var(--sans);overflow:hidden}
.login-grain{position:fixed;inset:0;pointer-events:none;opacity:.4;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.5'/%3E%3C/svg%3E")}
.login-wrap{display:grid;grid-template-columns:1.05fr .95fr;min-height:100vh}
.login-art{position:relative;background:radial-gradient(120% 120% at 20% 10%,#2A2620,#15120E);color:#F3EFE9;overflow:hidden}
.login-art::after{content:"";position:absolute;right:-15%;top:-10%;width:60%;height:120%;
  background:radial-gradient(circle,rgba(178,107,67,.35),transparent 70%);filter:blur(20px)}
.login-art-inner{position:relative;z-index:2;height:100%;display:flex;flex-direction:column;justify-content:center;padding:8vw}
.login-art .brand-mark{margin-bottom:30px}
.login-art-title{font-family:var(--serif);font-size:clamp(40px,6vw,72px);font-weight:300;line-height:1}
.login-art-sub{letter-spacing:.28em;text-transform:uppercase;font-size:11px;color:#A99C8B;margin-top:14px}
.login-lines{display:flex;gap:8px;margin:40px 0}
.login-lines span{height:1px;background:rgba(243,239,233,.4);display:block}
.login-lines span:nth-child(1){width:70px}.login-lines span:nth-child(2){width:32px}.login-lines span:nth-child(3){width:14px}
.login-quote{font-family:var(--serif);font-style:italic;font-size:22px;line-height:1.5;color:#D8CDBD;max-width:340px}
.login-form-side{display:flex;align-items:center;justify-content:center;background:var(--paper);padding:6vw}
.login-card{width:100%;max-width:360px;animation:fadeUp .7s var(--ease) both}
.login-eyebrow{letter-spacing:.2em;text-transform:uppercase;font-size:11px;color:var(--clay);font-weight:700;margin:0 0 8px}
.login-h2{font-family:var(--serif);font-size:32px;font-weight:400;margin-bottom:28px}
.login-err{background:#F7E4E1;color:var(--danger);padding:11px 14px;border-radius:10px;font-size:13px;margin-bottom:18px}
.login-hint{margin-top:20px;font-size:12.5px;color:var(--ink-soft);text-align:center}
.fld{display:block;margin-bottom:16px}
.fld>span{display:block;font-size:12.5px;font-weight:600;color:var(--ink-soft);margin-bottom:6px}
.fld input,.fld select,.fld textarea{
  width:100%;padding:12px 14px;border:1px solid var(--line-strong);border-radius:11px;background:#fff;
  transition:border-color .2s,box-shadow .2s}
.fld input:focus,.fld select:focus,.fld textarea:focus{outline:none;border-color:var(--clay);box-shadow:0 0 0 4px rgba(178,107,67,.12)}
.fld textarea{resize:vertical;min-height:74px}

/* ===================== BUTTONS ===================== */
.btn-primary,.btn-ghost,.btn-soft,.btn-clay,.btn-danger{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;border:none;cursor:pointer;
  padding:11px 18px;border-radius:11px;font-weight:600;font-size:13.5px;white-space:nowrap;line-height:1;
  text-decoration:none;transition:transform .15s var(--ease),box-shadow .2s,background .2s,color .2s}
.btn-primary{background:var(--ink);color:#F3EFE9;box-shadow:0 8px 20px -10px rgba(30,27,23,.6)}
.btn-primary:hover{transform:translateY(-2px);background:#000}
.btn-primary svg{stroke:currentColor}
.btn-block{width:100%;justify-content:center;padding:14px}
.btn-soft{background:var(--paper);border:1px solid var(--line-strong);color:var(--ink)}
.btn-soft:hover{border-color:var(--clay);color:var(--clay)}
.btn-ghost{background:transparent;color:var(--ink-soft);padding:8px 12px}
.btn-ghost:hover{color:var(--clay);background:rgba(178,107,67,.08)}
.btn-clay{background:linear-gradient(145deg,var(--clay),var(--clay-d));color:#fff}
.btn-clay:hover{transform:translateY(-2px);box-shadow:0 12px 24px -10px rgba(178,107,67,.7)}
.btn-sm{padding:7px 12px;font-size:12.5px;border-radius:9px}
.btn-danger{background:#F7E4E1;color:var(--danger)}
.btn-danger:hover{background:var(--danger);color:#fff}
.icon-btn{width:34px;height:34px;display:grid;place-items:center;border-radius:9px;border:1px solid var(--line);
  background:var(--paper);cursor:pointer;color:var(--ink-soft);transition:.18s}
.icon-btn:hover{color:var(--clay);border-color:var(--clay)}
.icon-btn svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}

/* ===================== SHELL ===================== */
.shell{display:grid;grid-template-columns:230px 1fr;min-height:100vh}
.sidebar{position:sticky;top:0;height:100vh;background:var(--paper);border-right:1px solid var(--line);
  display:flex;flex-direction:column;padding:18px 14px;gap:6px}
.side-brand{display:flex;align-items:center;gap:12px;padding:6px 8px 16px;border-bottom:1px solid var(--line);margin-bottom:6px}
.side-brand strong{display:block;font-family:var(--serif);font-size:19px;font-weight:600;line-height:1}
.side-brand span{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-soft)}
.side-nav{display:flex;flex-direction:column;gap:3px;flex:1}
.side-foot{display:flex;flex-direction:column;gap:3px;border-top:1px solid var(--line);padding-top:8px}
.nav-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:11px;color:var(--ink-soft);
  font-weight:600;font-size:13.5px;position:relative;transition:.18s}
.nav-item i{width:20px;height:20px;display:grid;place-items:center;flex:none}
.nav-item i svg{width:19px;height:19px}
.nav-item:hover{background:rgba(178,107,67,.08);color:var(--ink)}
.nav-item.active{background:var(--ink);color:#F3EFE9}
.nav-item.active i{color:var(--clay)}

.main{display:flex;flex-direction:column;min-width:0}
.topbar{display:flex;align-items:center;gap:16px;padding:14px 30px;border-bottom:1px solid var(--line);
  background:rgba(251,249,245,.8);backdrop-filter:blur(10px);position:sticky;top:0;z-index:40}
.menu-toggle{display:none;background:none;border:none;cursor:pointer;color:var(--ink)}
.menu-toggle svg{width:24px;height:24px}
.topbar-title{flex:1}
.crumb{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--clay);font-weight:700}
.topbar-title h1{font-family:var(--serif);font-size:22px;font-weight:400;margin-top:1px}
.topbar-user{display:flex;align-items:center;gap:11px}
.avatar{width:38px;height:38px;border-radius:11px;background:var(--ink);color:#F3EFE9;display:grid;place-items:center;
  font-weight:700;font-family:var(--serif)}
.user-meta strong{display:block;font-size:13.5px}
.user-meta span{font-size:12px;color:var(--ink-soft)}
.page{padding:22px 30px;animation:fadeUp .5s var(--ease) both}

/* ===================== CARDS / GRID ===================== */
.grid{display:grid;gap:16px}
.cols-4{grid-template-columns:repeat(4,1fr)}
.cols-3{grid-template-columns:repeat(3,1fr)}
.cols-2{grid-template-columns:repeat(2,1fr)}
.card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.card-pad{padding:20px}
.section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;gap:14px;flex-wrap:wrap}
.section-head h2{font-family:var(--serif);font-size:20px;font-weight:400}
.section-head .sub{font-size:13px;color:var(--ink-soft)}

/* stat cards */
.stat{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:17px 18px;position:relative;overflow:hidden;
  transition:transform .25s var(--ease),box-shadow .25s}
.stat:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.stat .ic{width:36px;height:36px;border-radius:11px;display:grid;place-items:center;margin-bottom:11px;
  background:rgba(178,107,67,.12);color:var(--clay)}
.stat .ic svg{width:19px;height:19px;fill:none;stroke:currentColor;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.stat .val{font-family:var(--serif);font-size:25px;font-weight:500;line-height:1}
.stat .lbl{font-size:12px;color:var(--ink-soft);margin-top:5px;font-weight:600}
.stat.green .ic{background:rgba(92,122,82,.14);color:var(--ok)}
.stat.gold .ic{background:rgba(201,162,75,.16);color:var(--gold)}
.stat.blue .ic{background:rgba(74,97,117,.14);color:var(--blue)}

/* ===================== TABLE ===================== */
.tbl-wrap{overflow-x:auto}
table.tbl{width:100%;border-collapse:collapse}
.tbl th{text-align:left;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);
  font-weight:700;padding:11px 14px;border-bottom:1px solid var(--line)}
.tbl td{padding:11px 14px;border-bottom:1px solid var(--line);vertical-align:middle}
.tbl tbody tr{transition:background .15s}
.tbl tbody tr:hover{background:rgba(178,107,67,.05)}
.tbl tr.row-link{cursor:pointer}
.tbl tbody tr:last-child td{border-bottom:none}
.tbl .strong{font-weight:700}
.cell-sub{font-size:12px;color:var(--ink-soft)}
.row-actions{display:flex;gap:6px;justify-content:flex-end}

/* ===================== BADGES ===================== */
.badge{display:inline-flex;align-items:center;gap:6px;padding:4px 11px;border-radius:30px;font-size:11.5px;font-weight:700;
  background:var(--line);color:var(--ink-soft)}
.badge::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;opacity:.8}
.badge.b-ok{background:rgba(92,122,82,.15);color:var(--ok)}
.badge.b-warn{background:rgba(192,138,43,.16);color:var(--warn)}
.badge.b-danger{background:rgba(176,71,60,.14);color:var(--danger)}
.badge.b-blue{background:rgba(74,97,117,.14);color:var(--blue)}
.badge.b-clay{background:rgba(178,107,67,.15);color:var(--clay-d)}
.badge.b-muted{background:var(--line);color:var(--ink-soft)}

/* ===================== EMPTY ===================== */
.empty{text-align:center;padding:60px 20px;color:var(--ink-soft)}
.empty svg{width:54px;height:54px;stroke:var(--line-strong);fill:none;stroke-width:1.4;margin-bottom:14px}
.empty h3{font-family:var(--serif);font-size:20px;color:var(--ink);font-weight:400}
.empty p{margin:6px 0 18px;font-size:13.5px}

/* ===================== MODAL ===================== */
.modal-back{position:fixed;inset:0;z-index:200;background:rgba(21,18,14,.45);backdrop-filter:blur(4px);
  display:flex;align-items:flex-start;justify-content:center;padding:40px 18px;overflow-y:auto;
  opacity:0;transition:opacity .25s}
.modal-back.show{opacity:1}
.modal{background:var(--paper);width:100%;max-width:600px;border-radius:20px;box-shadow:var(--shadow-lg);
  transform:translateY(24px) scale(.98);opacity:0;transition:transform .35s var(--ease),opacity .3s;
  border:1px solid var(--line);margin:auto 0}
.modal.lg{max-width:840px}
.modal.xl{max-width:980px}

/* Modal de tarefa em 2 colunas (estilo Perfex) */
.tk-grid{display:grid;grid-template-columns:1fr 290px;gap:24px}
.tk-main{min-width:0}
.tk-title{width:100%;font-family:var(--serif);font-size:21px;font-weight:500;border:none;border-bottom:1px solid var(--line);
  padding:4px 0 10px;background:none;margin-bottom:16px}
.tk-title:focus{outline:none;border-bottom-color:var(--clay)}
.tk-label{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);font-weight:700;margin:18px 0 8px}
.tk-main textarea{width:100%;min-height:70px;padding:11px 13px;border:1px solid var(--line-strong);border-radius:11px;background:#fff;resize:vertical}
.tk-main textarea:focus{outline:none;border-color:var(--clay)}
.tk-check-head{display:flex;justify-content:space-between;align-items:center;margin:20px 0 8px}
.tk-check-head .t{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);font-weight:700}
.tk-check-head .p{font-size:12.5px;color:var(--clay);font-weight:700}
.ck-item{display:flex;align-items:flex-start;gap:10px;padding:9px 0;border-bottom:1px solid var(--line)}
.ck-item:last-child{border-bottom:none}
.ck-item input[type=checkbox]{margin-top:2px;width:17px;height:17px;flex:none;accent-color:var(--clay)}
.ck-item .txt{flex:1;font-size:13.5px;line-height:1.4}
.ck-item.done .txt{text-decoration:line-through;color:var(--ink-soft)}
.ck-item .it-del{flex:none}
.ck-add{display:flex;gap:8px;margin-top:12px}
.ck-add input{flex:1;padding:9px 12px;border:1px solid var(--line-strong);border-radius:9px}
.ck-add input:focus{outline:none;border-color:var(--clay)}
.tk-side{background:var(--bg);border:1px solid var(--line);border-radius:14px;padding:18px;align-self:start}
.tk-side h4{font-family:var(--serif);font-size:15px;font-weight:500;margin-bottom:14px;display:flex;align-items:center;gap:8px}
.tk-side .fld{margin-bottom:13px}
@media(max-width:760px){.tk-grid{grid-template-columns:1fr}}
.modal-back.show .modal{transform:translateY(0) scale(1);opacity:1}
.modal-head{display:flex;align-items:flex-start;justify-content:space-between;padding:24px 26px 0}
.modal-head .eyebrow{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--clay);font-weight:700}
.modal-head h3{font-family:var(--serif);font-size:24px;font-weight:400;margin-top:4px}
.modal-x{background:none;border:none;cursor:pointer;color:var(--ink-soft);padding:6px;border-radius:8px;transition:.15s}
.modal-x:hover{background:var(--line);color:var(--ink)}
.modal-x svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:2}
.modal-body{padding:20px 26px}
.modal-foot{padding:16px 26px 24px;display:flex;gap:10px;justify-content:flex-end;border-top:1px solid var(--line);margin-top:6px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}
.full{grid-column:1/-1}

/* items editor */
.items-tbl{width:100%;border-collapse:collapse;margin-top:6px}
.items-tbl th{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-soft);text-align:left;padding:6px 6px;font-weight:700}
.items-tbl td{padding:4px}
.items-tbl input{width:100%;padding:9px 10px;border:1px solid var(--line-strong);border-radius:9px;background:#fff}
.items-tbl input:focus{outline:none;border-color:var(--clay)}
.items-tbl .ti-total{font-weight:700;white-space:nowrap;text-align:right;padding-right:8px}
.it-del{cursor:pointer;color:var(--ink-soft);border:none;background:none;padding:6px}
.it-del:hover{color:var(--danger)}
.totals-box{margin-top:14px;margin-left:auto;width:280px;font-size:14px}
.totals-box .tr{display:flex;justify-content:space-between;padding:6px 0}
.totals-box .grand{border-top:1px solid var(--line-strong);margin-top:6px;padding-top:10px;font-family:var(--serif);font-size:22px}

/* ===================== FULL-PAGE FORMS ===================== */
.form-wrap{max-width:940px;margin:0 auto}
.page-form-head{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-bottom:18px}
.page-form-head .back{font-size:12.5px}
.form-sec{display:flex;align-items:center;gap:11px;margin:30px 0 16px}
.form-sec:first-of-type{margin-top:6px}
.form-sec h3{font-family:var(--serif);font-size:17px;font-weight:500;white-space:nowrap}
.form-sec-ic{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;background:rgba(178,107,67,.12);color:var(--clay);flex:none}
.form-sec-ic svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.form-sec .ln{flex:1;height:1px;background:var(--line)}
.fgrid{display:grid;grid-template-columns:repeat(12,1fr);gap:14px 18px}
.fgrid .fld{margin-bottom:0}
.c2{grid-column:span 2}.c3{grid-column:span 3}.c4{grid-column:span 4}
.c5{grid-column:span 5}.c6{grid-column:span 6}.c7{grid-column:span 7}
.c8{grid-column:span 8}.c12{grid-column:span 12}
.form-actions{display:flex;justify-content:flex-end;gap:10px;border-top:1px solid var(--line);margin-top:28px;padding-top:20px}
@media(max-width:780px){.fgrid>*{grid-column:span 12 !important}}

/* ===================== SEARCHABLE SELECT ===================== */
.ss{position:relative;width:100%}
.ss-btn{width:100%;display:flex;align-items:center;justify-content:space-between;gap:8px;
  padding:12px 14px;border:1px solid var(--line-strong);border-radius:11px;background:#fff;cursor:pointer;
  font:inherit;color:var(--ink);text-align:left;transition:border-color .2s,box-shadow .2s}
.ss-btn:hover{border-color:var(--clay)}
.ss.open .ss-btn{border-color:var(--clay);box-shadow:0 0 0 4px rgba(178,107,67,.12)}
.ss-val{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ss-caret{flex:none;color:var(--ink-soft);transition:transform .2s}
.ss.open .ss-caret{transform:rotate(180deg)}
.ss-pop{position:absolute;top:calc(100% + 6px);left:0;right:0;z-index:30;background:var(--paper);
  border:1px solid var(--line-strong);border-radius:12px;box-shadow:var(--shadow-lg);padding:8px;
  opacity:0;visibility:hidden;transform:translateY(-6px);transition:.18s var(--ease)}
.ss.open .ss-pop{opacity:1;visibility:visible;transform:translateY(0)}
.ss-search{width:100%;padding:9px 12px;border:1px solid var(--line);border-radius:9px;background:#fff;margin-bottom:6px}
.ss-search:focus{outline:none;border-color:var(--clay)}
.ss-list{max-height:230px;overflow-y:auto}
.ss-opt{padding:9px 12px;border-radius:8px;cursor:pointer;font-size:13.5px;transition:background .12s}
.ss-opt:hover{background:rgba(178,107,67,.1)}
.ss-opt.sel{background:var(--ink);color:#F3EFE9;font-weight:600}
.ss-empty{padding:12px;text-align:center;color:var(--ink-soft);font-size:13px}

/* ===================== TOAST ===================== */
#toast-root{position:fixed;bottom:26px;right:26px;z-index:500;display:flex;flex-direction:column;gap:10px}
.toast{background:var(--ink);color:#F3EFE9;padding:13px 18px;border-radius:12px;box-shadow:var(--shadow-lg);
  font-size:13.5px;font-weight:600;display:flex;align-items:center;gap:10px;
  animation:toastIn .4s var(--ease);min-width:240px}
.toast.ok{background:var(--ok)}.toast.err{background:var(--danger)}
.toast svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2.2}
@keyframes toastIn{from{transform:translateX(40px);opacity:0}to{transform:translateX(0);opacity:1}}

/* ===================== MISC ===================== */
.flex{display:flex;align-items:center;gap:10px}
.between{justify-content:space-between}
.wrap{flex-wrap:wrap}
.gap-s{gap:6px}
.mt{margin-top:20px}.mb{margin-bottom:20px}
.muted{color:var(--ink-soft)}
.right{text-align:right}
/* Abas do projeto (navegação) — distintas das pílulas de etapa */
.tabnav{display:flex;gap:2px;flex-wrap:wrap;border-bottom:1px solid var(--line);margin-bottom:20px}
.tabnav .tab{display:inline-flex;align-items:center;gap:7px;padding:11px 15px;font-weight:600;font-size:13.5px;
  color:var(--ink-soft);background:none;border:none;cursor:pointer;position:relative;
  border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .18s,border-color .18s}
.tabnav .tab svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.tabnav .tab:hover{color:var(--ink)}
.tabnav .tab.active{color:var(--ink);border-bottom-color:var(--clay)}
.tabnav .tab.active svg{color:var(--clay)}

.pill-filter{display:flex;gap:6px;flex-wrap:wrap}
.pill{padding:7px 14px;border-radius:30px;border:1px solid var(--line-strong);background:var(--paper);
  cursor:pointer;font-size:12.5px;font-weight:600;color:var(--ink-soft);transition:.18s}
.pill:hover{border-color:var(--clay)}
.pill.active{background:var(--ink);color:#F3EFE9;border-color:var(--ink)}
#msFilter.hide-generic .ms-generic{display:none}
.ms-toggle{flex:none}
#msFilter.hide-generic .ms-toggle{color:var(--clay);border-color:var(--clay)}
.search{display:flex;align-items:center;gap:8px;background:var(--paper);border:1px solid var(--line-strong);
  border-radius:11px;padding:9px 14px;min-width:230px}
.search svg{width:17px;height:17px;stroke:var(--ink-soft);fill:none;stroke-width:2}
.search input{border:none;background:none;width:100%}
.search input:focus{outline:none}
.kanban{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.kcol{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:16px;min-height:200px}
.kcol h4{font-size:12px;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-soft);margin-bottom:14px;display:flex;justify-content:space-between}
.kcol.kover{background:rgba(178,107,67,.08);border-color:var(--clay);border-style:dashed}
.kbody{min-height:8px}
.kempty{border:1.5px dashed var(--line-strong);border-radius:12px;padding:18px 0;text-align:center;
  font-size:12.5px;color:var(--ink-soft);margin-top:4px}
.kcard{background:#fff;border:1px solid var(--line);border-radius:12px;padding:13px 14px;margin-bottom:10px;cursor:grab;
  transition:transform .15s,box-shadow .15s,opacity .15s;user-select:none}
.kcard:active{cursor:grabbing}
.kcard:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.kcard.dragging{opacity:.4;transform:rotate(1.5deg) scale(.98);box-shadow:var(--shadow-lg)}
.kcard .kt{font-weight:700;font-size:13.5px;margin-bottom:4px}
.kcard .km{font-size:11.5px;color:var(--ink-soft)}
.progress{height:7px;background:var(--line);border-radius:30px;overflow:hidden;margin-top:8px}
.progress>span{display:block;height:100%;background:linear-gradient(90deg,var(--clay),var(--gold));border-radius:30px;transition:width .6s var(--ease)}
.skeleton{background:linear-gradient(90deg,var(--line) 25%,#EEE8DD 50%,var(--line) 75%);background-size:200% 100%;
  animation:shimmer 1.3s infinite;border-radius:8px}
@keyframes shimmer{to{background-position:-200% 0}}

.spin{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;vertical-align:-2px}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
.stagger>*{opacity:0;animation:fadeUp .5s var(--ease) forwards}
.stagger>*:nth-child(1){animation-delay:.04s}
.stagger>*:nth-child(2){animation-delay:.10s}
.stagger>*:nth-child(3){animation-delay:.16s}
.stagger>*:nth-child(4){animation-delay:.22s}
.stagger>*:nth-child(5){animation-delay:.28s}
.stagger>*:nth-child(6){animation-delay:.34s}

/* ===================== RESPONSIVE ===================== */
@media(max-width:1100px){.cols-4{grid-template-columns:repeat(2,1fr)}.cols-3{grid-template-columns:1fr}.kanban{grid-template-columns:1fr}}
@media(max-width:920px){
  .shell{grid-template-columns:1fr}
  .sidebar{position:fixed;left:-280px;z-index:120;width:260px;transition:left .3s var(--ease)}
  body.nav-open .sidebar{left:0}
  body.nav-open::after{content:"";position:fixed;inset:0;background:rgba(21,18,14,.4);z-index:110}
  .menu-toggle{display:block}
  .login-wrap{grid-template-columns:1fr}.login-art{display:none}
  .page{padding:22px 18px}.topbar{padding:16px 18px}
  .form-row,.form-row-3{grid-template-columns:1fr}
  .cols-2{grid-template-columns:1fr}
}
