/* ============================================================================
   Gestor d'assets gràfics — estils
   ============================================================================ */
:root{
  --bg:#0f1220; --bg-accent:#1d2240; --surface:#1a1e33; --surface-2:#232842; --line:#313862;
  --text:#e9ecf7; --muted:#9aa3c7; --brand:#3b4a99; --brand-2:#2f3c80;
  /* Blau accessible per a TEXT/accents/contorns sobre fons fosc (el --brand sòlid es reserva per a fons de botó) */
  --brand-ink:#9aa8ee;
  --topbar:rgba(15,18,32,.85);
  --ok:#2bb673; --warn:#f0a020; --pend:#8a93b8; --danger:#e0556b; --danger-text:#ffb3c0;
  --radius:14px; --shadow:0 8px 30px rgba(0,0,0,.35);
  --maxw:1180px; font-synthesis:none;
}
body.light{
  --bg:#eef1f8; --bg-accent:#dde4f5; --surface:#ffffff; --surface-2:#f1f4fb; --line:#d7deec;
  --text:#1b2138; --muted:#5c647d; --brand:#3b4a99; --brand-2:#2f3c80;
  --brand-ink:#3b4a99;   /* en clar, el blau de marca ja té bon contrast */
  --topbar:rgba(255,255,255,.85);
  --shadow:0 8px 24px rgba(40,50,90,.10);
  --danger-text:#c0283f;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:"Inter",system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  background:radial-gradient(1200px 600px at 80% -10%, var(--bg-accent) 0%, var(--bg) 55%);
  color:var(--text); min-height:100vh; line-height:1.5;
}
a{color:var(--brand-ink)}
button{font-family:inherit}
.hidden{display:none !important}

/* ---- layout: panell lateral fix ---- */
:root{ --sbw:230px }
body{ padding-left:var(--sbw) }
.sidebar{
  position:fixed; top:0; left:0; bottom:0; width:var(--sbw); z-index:30;
  display:flex; flex-direction:column; gap:6px; padding:14px 10px;
  background:var(--surface); border-right:1px solid var(--line); overflow:visible;
}
.sidebar .brand{padding:2px 6px 8px}
.sidebar-foot{margin-top:auto}
.brand{display:flex; flex-direction:column; align-items:flex-start; text-align:left; gap:8px; font-weight:700; letter-spacing:.2px}
.brand .logo{
  width:34px; height:34px; border-radius:9px;
  background:var(--brand);
  display:grid; place-items:center; font-size:16px;
}
.brand .logo-img{ width:72px; height:72px; object-fit:contain; display:block; }
.brand .brand-name{ font-size:18px; line-height:1.2; }
.brand .brand-sub{ font-size:11.5px; font-weight:500; line-height:1.35; color:var(--muted); letter-spacing:0; }
body.light .brand .logo-img{ content:url("../assets/logo-dark.svg"); }
.brand .logo-img.custom, body.light .brand .logo-img.custom{ content:normal !important; }
/* Els logos personalitzats solen ser horitzontals: deixa'ls créixer en comptes d'encaixonar-los */
.brand .logo-img.custom{ width:auto; height:auto; max-width:100%; max-height:88px; }
.topnav{display:flex; flex-direction:column; align-items:stretch; gap:3px}
.navlink{display:inline-flex; align-items:center; gap:10px; width:100%; text-align:left; background:transparent; border:none; color:var(--muted); padding:9px 12px; border-radius:9px; cursor:pointer; font-weight:600; font-size:14px; font-family:inherit; transition:.15s}
.navlink:hover{background:var(--surface-2); color:var(--text)}
.navlink.active{background:var(--bg-accent); color:var(--text); font-weight:700}
.navlink.active .ti{color:var(--brand-ink)}
.navlink .ti{font-size:18px; flex:none}
@media(max-width:820px){
  :root{ --sbw:62px }
  .sidebar{padding:14px 8px}
  .brand{align-items:center; text-align:center}
  .brand span{display:none}
  .brand .logo-img{width:36px; height:36px}
  .navlink span{display:none}
  .navlink{justify-content:center; padding:10px 0}
  .sidebar .userbox .uname, .sidebar .userbox .ti-chevron-down{display:none}
  .sidebar .user-btn{justify-content:center; padding:5px}
}
.brand-logo-prev{width:48px; height:48px; border:1px solid var(--line); border-radius:10px; background:var(--surface-2); display:grid; place-items:center; overflow:hidden; flex:none}
.brand-logo-prev img{max-width:100%; max-height:100%; object-fit:contain}
.brand-logo-prev i{color:var(--muted); font-size:20px}
.userbox{display:flex; align-items:center; gap:10px; font-size:14px; color:var(--muted)}
.sidebar .userbox{width:100%}
.sidebar .userbox > div{width:100%}
.sidebar .user-btn{width:100%}
.user-btn{display:flex; align-items:center; gap:9px; background:var(--surface-2); border:1px solid var(--line); border-radius:999px; padding:5px 12px 5px 5px; cursor:pointer; color:var(--text)}
.user-btn:hover{border-color:var(--brand-ink)}
.user-btn .uname{font-size:13.5px; font-weight:600; flex:1; min-width:0; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; text-align:left}
.user-btn .ti{color:var(--muted); font-size:15px}
.avatar{width:28px; height:28px; border-radius:50%; background:var(--brand); color:#fff; display:grid; place-items:center; font-size:12px; font-weight:700; flex:none}
.avatar.lg{width:40px; height:40px; font-size:15px}
.user-menu{position:absolute; top:46px; right:0; width:280px; background:var(--surface); border:1px solid var(--line); border-radius:14px; box-shadow:var(--shadow); padding:8px; z-index:60}
.sidebar .user-menu{top:auto; bottom:calc(100% + 8px); right:auto; left:0; width:300px; min-width:0; max-width:calc(100vw - 24px)}
.um-head{display:flex; align-items:center; gap:11px; padding:10px 8px 12px}
.um-name{font-weight:600; font-size:14px; color:var(--text)}
.um-role{font-size:12px; color:var(--muted)}
.um-sec{padding:10px 8px; border-top:1px solid var(--line)}
.um-lbl{display:block; font-size:11px; color:var(--muted); margin-bottom:5px}
.um-row{display:flex; align-items:center; justify-content:space-between; font-size:13.5px; color:var(--text)}
.um-link{background:none; border:none; color:var(--brand-ink); cursor:pointer; font-size:13px; padding:0; display:inline-flex; align-items:center; gap:6px}
.user-menu input{width:100%; background:var(--surface); border:1px solid var(--line); color:var(--text); border-radius:8px; padding:0 9px; font-size:13px; font-family:inherit}
.role-pill{
  font-size:11px; text-transform:uppercase; letter-spacing:.6px; font-weight:700;
  padding:4px 9px; border-radius:999px; background:var(--surface-2); color:var(--text);
  border:1px solid var(--line);
}
.wrap{max-width:1900px; margin:0 auto; padding:34px 40px 80px}

/* ---- buttons ---- */
.btn{
  height:36px; border:1px solid var(--line); background:var(--surface); color:var(--text);
  padding:0 14px; border-radius:10px; cursor:pointer; font-size:14px; font-weight:600;
  transition:.15s; display:inline-flex; align-items:center; justify-content:center; gap:7px;
}
.btn:hover{border-color:var(--brand-ink); transform:translateY(-1px)}
.btn:not(.primary):not(.danger):hover{background:var(--surface-2)}
.btn.icon-x{color:var(--muted); background:transparent; border:none; padding:0; width:30px; height:30px; border-radius:8px}
.btn.icon-x .ti{font-size:19px}
.btn.icon-x:hover{color:var(--text); background:transparent; transform:none}
.btn.primary{background:linear-gradient(135deg,var(--brand),var(--brand-2)); border:none; color:#fff}
.btn.primary .ti{color:#fff}
.btn .ti{font-size:15px}
.btn.sm .ti{font-size:14px}
.btn.ghost{background:transparent}
.btn.danger{border-color:var(--danger); color:var(--danger-text)}
.btn.danger:hover{background:var(--danger); color:#fff; border-color:var(--danger)}
.btn.danger:hover .ti{color:#fff}
.btn:focus-visible,.kebab:focus-visible,.year-tab:focus-visible,.lang-switch button:focus-visible,.menu button:focus-visible,
.navlink:focus-visible,.dd-toggle:focus-visible,.dd-opt:focus-visible,.proj-tab:focus-visible,.user-btn:focus-visible,.pill-btn:focus-visible,.cm-toggle:focus-visible,.card.click:focus-visible,.add-card:focus-visible,.fmt-pick-card:focus-visible,.logo-pick:focus-visible,.brand:focus-visible,input:focus-visible,textarea:focus-visible{outline:2px solid var(--brand-ink); outline-offset:2px}
.btn.sm{padding:0 10px; font-size:12.5px}
.btn:disabled{opacity:.4; cursor:not-allowed; transform:none}
.lang-switch{display:flex; border:1px solid var(--line); border-radius:9px; overflow:hidden}
.lang-switch button{background:transparent;border:none;color:var(--muted);padding:6px 10px;cursor:pointer;font-weight:700;font-size:12px}
.lang-switch button.active{background:var(--surface-2);color:var(--text)}

/* ---- cards / grid ---- */
.grid{display:grid; gap:16px}
.grid.cards{grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}
.card{
  background:var(--surface); border:1px solid var(--line); border-radius:var(--radius);
  padding:18px; box-shadow:var(--shadow); transition:.15s;
}
.card.click{cursor:pointer}
.card.click:hover{border-color:var(--brand-ink); transform:translateY(-2px)}
.card h3{margin:0 0 6px; font-size:17px}
.card p{margin:0; color:var(--muted); font-size:13.5px}
.card .meta{margin-top:12px; display:flex; gap:8px; flex-wrap:wrap; font-size:12px; color:var(--muted)}

/* targeta de projecte amb thumbnail i menú */
.card.proj{position:relative; padding:0; overflow:visible}
.card.proj .thumb{position:relative; height:120px; background:var(--surface-2); display:grid; place-items:center; color:var(--muted); border-bottom:1px solid var(--line); border-radius:14px 14px 0 0; overflow:hidden}
.card.proj .thumb i{font-size:32px; opacity:.7}
.card.proj .thumb img{width:100%; height:100%; object-fit:cover}
.thumb-ph{width:100%; height:100%; display:grid; place-items:center; background:linear-gradient(135deg, #aab6ef 0%, #6675c9 55%, #4a59ab 100%)}
.card.proj .thumb-ph .ph-logo{width:auto; height:50px; max-width:62%; object-fit:contain; filter:brightness(0) invert(1) drop-shadow(0 2px 6px rgba(20,25,60,.28)); opacity:.95}
.card.proj .card-body{padding:16px 18px}
/* kebab: ghost, en línia amb el títol */
.kebab{width:30px; height:30px; border-radius:8px; border:none; background:transparent; color:var(--muted); cursor:pointer; display:grid; place-items:center; font-size:18px; flex:none}
.kebab:hover{background:var(--surface-2); color:var(--text)}
.card-title-row{display:flex; align-items:flex-start; justify-content:space-between; gap:8px}
.card-title-row h3{margin:0; min-width:0}
.kebab-wrap{position:relative; flex:none}
.kebab-wrap .menu{top:calc(100% + 4px); right:0}
/* pill d'estat sobre el thumbnail */
.thumb-status{position:absolute; top:8px; right:8px; z-index:2}
.card .thumb-status .badge{font-size:10px; font-weight:700; padding:3px 10px; border:none; color:#fff; box-shadow:0 1px 6px rgba(20,25,50,.35)}
.card .thumb-status .badge.pendent{background:#e0922a; color:#fff}
.card .thumb-status .badge.en_proces{background:#5566c9; color:#fff}
.card .thumb-status .badge.aprovat{background:#2bb673; color:#fff}
.card .thumb-status .badge.bloquejat{background:#e0556b; color:#fff}
.thumb-wrap{position:relative}
.edit-overlay{position:absolute; top:8px; right:8px; width:30px; height:30px; border-radius:8px; background:var(--surface); color:var(--brand-ink); display:grid; place-items:center; box-shadow:var(--shadow); opacity:0; transition:opacity .15s; z-index:3; font-size:17px}
.fmt-card.click:hover .edit-overlay{opacity:1}
.card-evt{font-size:12px; font-weight:600; color:var(--muted); margin-bottom:4px}
.asset-pills{display:flex; flex-wrap:wrap; gap:6px; overflow:hidden}
.badge.more{cursor:default; opacity:.85}
.add-card{display:flex; flex-direction:column; align-items:center; justify-content:center; gap:8px; min-height:170px; border:2px dashed var(--line); background:transparent; color:var(--muted); cursor:pointer; border-radius:14px; font-weight:600; font-size:13.5px}
.add-card:hover{border-color:var(--brand-ink); color:var(--brand-ink)}
.add-card .ti{font-size:26px}
.ah-titlewrap.proj-titlewrap{flex-direction:column; align-items:flex-start; gap:3px}
.asset-header.proj-header{gap:16px}
.asset-header.proj-header h2{font-size:28px; max-width:48vw}
.asset-header.proj-header .ah-cover.sq{width:80px; height:80px}
.ah-eventdate{font-size:12px; font-weight:700; letter-spacing:.5px; text-transform:uppercase; color:var(--brand-ink)}
.proj-title-row{display:flex; align-items:center; gap:10px; min-width:0; flex-wrap:wrap}
.ah-desc{font-size:12.5px; color:var(--muted); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width:42vw}
.rc-pill{flex:none; font-size:11px; font-weight:700; color:var(--brand-ink); background:var(--bg-accent); border:1px solid var(--line); border-radius:999px; padding:4px 10px; white-space:nowrap}
.ah-meta{display:flex; gap:10px; flex:none}
.ah-metabox{height:80px; min-width:100px; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:4px; padding:8px 14px; background:var(--bg-accent); border:1px solid var(--line); border-radius:12px}
.ah-metabox .amb-label{font-size:11px; font-weight:700; letter-spacing:.5px; text-transform:uppercase; color:var(--muted)}
.ah-metabox .amb-val{font-size:14px; font-weight:700; color:var(--text); white-space:nowrap}
.cm-head{display:flex; align-items:center; justify-content:space-between; gap:8px; margin-bottom:12px}
.cm-badge{position:absolute; top:2px; right:2px; min-width:16px; height:16px; padding:0 4px; background:var(--danger); color:#fff; border-radius:999px; font-size:10px; font-weight:700; display:grid; place-items:center}
body:not(.comments-collapsed) .cm-badge{display:none}
.menu{position:absolute; top:48px; right:10px; background:var(--surface); border:1px solid var(--line); border-radius:10px; box-shadow:var(--shadow); padding:6px; z-index:6; min-width:150px}
.menu button{display:flex; align-items:center; gap:9px; width:100%; text-align:left; background:transparent; border:none; color:var(--text); padding:8px 10px; border-radius:7px; cursor:pointer; font-size:13.5px}
.menu button:hover{background:var(--surface-2)}
.menu button.danger{color:var(--danger)}

.year-tabs{display:flex; gap:8px; flex-wrap:wrap; margin:0 0 20px}
.year-tab{background:transparent; border:1px solid var(--line); color:var(--muted); padding:7px 16px; border-radius:999px; cursor:pointer; font-size:13px; font-weight:600; transition:.15s}
.year-tab:hover{border-color:var(--brand-ink); color:var(--text)}
.year-tab.active{background:var(--brand); border-color:var(--brand-ink); color:#fff}
.proj-tabs{display:flex; gap:2px}
.proj-header .proj-tabs{margin:2px -46px -14px -28px; padding:0 28px; border-top:1px solid var(--line); background:var(--surface)}
.proj-tab{background:transparent; border:none; border-bottom:2px solid transparent; color:var(--muted); padding:11px 16px; cursor:pointer; font-size:14px; font-weight:600; font-family:inherit; transition:.15s}
.proj-tab:hover{color:var(--text)}
.proj-tab.active{color:var(--brand-ink); border-bottom-color:var(--brand-ink)}
.tab-count{font-weight:600; color:var(--muted); font-size:13px}
.proj-tab.active .tab-count{color:var(--brand-ink)}
.tab-pane{animation:fadeIn .15s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(2px)}to{opacity:1;transform:none}}
.section-head{display:flex; align-items:center; gap:14px; margin:6px 0 6px}
.section-head + .crumbs{margin-bottom:24px}
.section-head h2{margin:0; font-size:22px}
.section-head .spacer{flex:1}
.crumbs{font-size:13px; color:var(--muted); margin-bottom:10px}
.crumbs a{cursor:pointer; border-radius:4px}
.crumbs a:hover{color:var(--brand-ink); text-decoration:underline}
.crumbs a:focus-visible{outline:2px solid var(--brand-ink); outline-offset:2px}

/* ---- badges ---- */
.badge{font-size:11.5px; font-weight:700; padding:4px 9px; border-radius:999px; border:1px solid var(--line)}
.badge.pendent{background:rgba(240,160,32,.16); color:#ffd58a; border-color:#5a4a22}      /* taronja */
.badge.en_proces{background:rgba(91,124,250,.18); color:#bcd0ff; border-color:#33407e}    /* blau */
.badge.aprovat{background:rgba(43,182,115,.15); color:#9ff0c6; border-color:#235a3f}       /* verd */
.badge.bloquejat{background:rgba(224,85,107,.18); color:#ffb3c0; border-color:#7a2a39}     /* vermell */
.badge.type{background:var(--surface-2); color:var(--muted)}
.pill-btn{background:none; border:none; cursor:pointer; display:inline-flex; align-items:center; gap:6px; padding:0; font:inherit}
.pill-btn .badge{pointer-events:none}
.deadline{font-size:12px; color:var(--muted)}
.deadline.soon{color:#ffd58a}
.deadline.late{color:#ffb8c3}

/* ---- asset detail ---- */
.detail{display:grid; grid-template-columns:1.3fr .9fr; gap:20px; align-items:start}
@media(max-width:880px){ .detail{grid-template-columns:1fr} }

/* inputs dins de panells (sense .field) també amb estil de l'app */
.panel input:not([type=checkbox]):not([type=file]), .panel select, .panel textarea{
  width:100%; background:var(--surface); border:1px solid var(--line); color:var(--text);
  border-radius:9px; padding:9px 11px; font-size:14px; font-family:inherit;
}
.panel textarea{min-height:70px; resize:vertical}

/* detall d'asset: header full-width sticky + sidebar de comentaris fix */
:root{ --cw:0px }
body.asset-mode{ --cw:344px }
body.asset-mode.comments-collapsed{ --cw:48px }
body.asset-mode .wrap{ max-width:none; padding:0 calc(var(--cw) + 28px) 60px 28px }
.asset-header{position:sticky; top:var(--topbarH, 58px); z-index:25; display:flex; flex-direction:column; gap:6px;
  margin-left:-28px; margin-right:-46px;
  background:var(--surface); border-bottom:1px solid var(--line);
  padding:14px 46px 14px 28px; box-shadow:var(--shadow); margin-bottom:18px}
.ah-crumbs{font-size:12.5px; color:var(--muted)}
.ah-crumbs a{cursor:pointer; border-radius:4px}
.ah-crumbs a:hover{color:var(--brand-ink); text-decoration:underline}
.ah-crumbs a:focus-visible{outline:2px solid var(--brand-ink); outline-offset:2px}
.ah-main{display:flex; align-items:center; gap:12px; flex-wrap:nowrap}
.ah-main .spacer{flex:1}
.ah-kebab{margin-left:6px; flex:none}
.ah-cover{height:74px; border-radius:8px; overflow:hidden; background:var(--surface-2); border:1px solid var(--line); display:grid; place-items:center; flex:none}
.ah-cover img{width:100%; height:100%; object-fit:cover; display:block}
.ah-cover.placeholder{color:var(--muted); font-size:22px}
.ah-cover.sq{width:60px; height:60px}
.ah-titlewrap{display:flex; align-items:center; gap:6px; min-width:0}
.asset-header #editTitle, .asset-header #assetKebab, .asset-header #projKebab{border:none; background:transparent; color:var(--muted)}
.asset-header #editTitle:hover, .asset-header #assetKebab:hover, .asset-header #projKebab:hover{color:var(--brand-ink); background:var(--surface-2)}
.asset-header h2{margin:0; font-size:20px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width:32vw}
.asset-main{display:grid; grid-template-columns:2fr 1fr; gap:18px; align-items:start}
.am-left,.am-right,.zone{display:flex; flex-direction:column; gap:18px; min-width:0}
.am-left-row{display:grid; grid-template-columns:1fr 1fr; gap:18px}
/* Tab "Contingut": les 3 seccions omplen la pantalla amb espai uniforme.
   L'alçada exacta la calcula fitContentPane() per respectar el marge inferior. */
.content-pane{display:flex; flex-direction:column}
.content-pane .content-zone{flex:1; gap:18px}
.content-pane #docPanel{flex:1; display:flex; flex-direction:column}
/* El dropzone omple la card (caixa gran) */
.content-pane #docPanel .dropbox{flex:1}
/* Quan ja hi ha un Word pujat, la previsualització omple la card */
.content-pane #docPanel .doc-wrap{flex:1; min-height:0}
@media(max-width:900px){ .asset-main{grid-template-columns:1fr} .am-left-row{grid-template-columns:1fr} }
.zone-head{display:flex; align-items:center; gap:10px; padding:0 2px}
.zone-title{font-size:13px; font-weight:700; letter-spacing:.4px; text-transform:uppercase; color:var(--muted)}
.zone-check{margin-left:auto; font-size:12px; font-weight:600; color:var(--muted); display:inline-flex; align-items:center; gap:5px}
.zone-check.done{color:var(--ok)}
.zone-check .ti{font-size:17px}
/* botons només-icona ghost: mateixa mida d'icona */
.cm-toggle{width:32px; height:32px}
.cm-toggle .ti, .asset-header #editTitle .ti, .asset-header #assetKebab .ti, #um_theme .ti{font-size:18px}
/* sidebar fix de comentaris */
.asset-comments{position:fixed; top:var(--topbarH, 58px); right:0; bottom:0; width:340px; z-index:26; margin:0;
  background:var(--surface); border:none; border-left:1px solid var(--line); border-radius:0; box-shadow:none;
  overflow:hidden; padding:16px; display:flex; flex-direction:column}
.cm-body{flex:1; display:flex; flex-direction:column; min-height:0; padding-top:4px}
.cm-body .commentlist{flex:1; overflow-y:auto; min-height:0}
.cm-body #newComment{resize:none; height:74px; max-height:120px; overflow-y:auto}
.cm-toggle{position:absolute; top:10px; right:12px; width:34px; height:34px; border:none;
  background:transparent; color:var(--muted); border-radius:8px; cursor:pointer; display:grid; place-items:center; font-size:22px}
.cm-toggle:hover{color:var(--brand-ink)}
.cm-body{padding-top:4px}
body.asset-mode.comments-collapsed .asset-comments{width:48px; padding:0; cursor:pointer}
body.asset-mode.comments-collapsed .asset-comments:hover{background:var(--surface-2)}
body.asset-mode.comments-collapsed .cm-body{display:none}
body.asset-mode.comments-collapsed .cm-toggle{position:absolute; inset:0; width:100%; height:100%; margin:0; border-radius:0; place-items:start center; padding-top:14px}
.input-row{display:flex; gap:8px; align-items:center}
.input-row input{flex:1; min-width:0}
.cover-ratio{overflow:hidden; border-radius:4px; border:1px solid var(--line); background:var(--surface-2)}
.cover-ratio img{width:100%; height:100%; object-fit:cover; display:block}
.panel{background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:18px; box-shadow:var(--shadow)}
.panel h4{margin:0 0 14px; font-size:15px; letter-spacing:.3px; color:var(--muted); text-transform:uppercase}
.field{margin-bottom:12px}
.field label{display:block; font-size:12px; color:var(--muted); margin-bottom:4px}
.sublabel{font-size:12px; color:var(--muted); margin-bottom:8px; opacity:.85}
.field input,.field textarea,.field select{
  width:100%; background:var(--surface); border:1px solid var(--line); color:var(--text);
  border-radius:9px; padding:9px 11px; font-size:14px; font-family:inherit;
}
/* alçada uniforme amb els botons (36px) + fons blanc i hover gris clar */
.field input:not([type=checkbox]):not([type=file]), .field select,
.panel input:not([type=checkbox]):not([type=file]), .panel select,
.user-menu input, .modal input:not([type=checkbox]):not([type=file]), .modal select{
  height:36px; padding-top:0; padding-bottom:0; background:var(--surface);
}
.field input:hover, .field textarea:hover, .field select:hover,
.panel input:hover, .panel textarea:hover, .panel select:hover,
.user-menu input:hover, .modal input:hover, .modal textarea:hover, .modal select:hover{
  background:var(--surface-2);
}
.field select, .panel select, .user-menu select{
  -webkit-appearance:none; appearance:none; padding-right:38px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%238b93ad' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 13px center; background-size:15px;
}
input[type="date"]::-webkit-calendar-picker-indicator{ filter:invert(1); opacity:.85; cursor:pointer; }
body.light input[type="date"]::-webkit-calendar-picker-indicator{ filter:none; }
.field textarea{min-height:80px; resize:vertical}
.row2{display:grid; grid-template-columns:1fr 1fr; gap:12px}
.fmt-list{display:flex; flex-direction:column; gap:6px; max-height:58vh; overflow:auto; margin-bottom:14px; border:1px solid var(--line); border-radius:10px; padding:8px}
.fmt-opt{display:flex; align-items:flex-start; gap:10px; padding:9px 10px; border-radius:8px; cursor:pointer}
.fmt-opt:hover{background:var(--surface-2)}
.fmt-opt input{margin-top:3px; width:16px; height:16px; flex:none}
.fmt-opt span{display:flex; flex-direction:column; font-size:14px}
.fmt-opt small{color:var(--muted); font-size:12px}
.fmt-cat-h{font-size:11px; letter-spacing:.6px; text-transform:uppercase; color:var(--muted); font-weight:700; padding:10px 10px 4px}
.fmt-pick-grid{display:grid; grid-template-columns:repeat(auto-fill,minmax(140px,1fr)); gap:10px; margin:6px 4px 14px}
.fmt-pick-card{border:1px solid var(--line); border-radius:10px; overflow:hidden; cursor:pointer; background:var(--bg); transition:.12s; position:relative}
.fmt-pick-card:hover{border-color:var(--brand-ink)}
.fmt-pick-card.selected{border-color:var(--brand-ink); box-shadow:0 0 0 2px rgba(91,124,250,.35)}
.fmt-pick-card.selected::after{content:"✓"; position:absolute; top:6px; right:6px; width:20px; height:20px; background:var(--brand); color:#fff; border-radius:50%; display:grid; place-items:center; font-size:12px; z-index:2}
.fmt-pick-card .fmt-prev{height:auto; min-height:84px; border-radius:0; border:none; border-bottom:1px solid var(--line); padding:10px}
.fpc-body{padding:8px 10px}
.fpc-name{font-size:13px; font-weight:600}
.fpc-sub{font-size:11px; color:var(--muted); margin-top:2px}
/* biblioteca de logos */
.logo-card{position:relative; padding:0; overflow:visible}
.logo-thumb{height:120px; background:#eef0f4; border:1px solid var(--line); border-bottom:none; border-radius:14px 14px 0 0; display:grid; place-items:center; padding:14px}
.logo-thumb img{max-width:100%; max-height:100%; object-fit:contain}
.logo-card .card-body{padding:10px 14px}
.logo-pick-grid{display:grid; grid-template-columns:repeat(auto-fill,minmax(110px,1fr)); gap:10px; max-height:340px; overflow:auto; margin-bottom:14px}
.logo-pick{border:1px solid var(--line); border-radius:10px; padding:10px; cursor:pointer; text-align:center; background:#eef0f4; position:relative}
.logo-pick img{width:100%; height:70px; object-fit:contain}
.logo-pick span{display:block; font-size:11px; color:#5c647d; margin-top:6px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis}
.logo-pick .pack-count{display:block; font-size:10px; color:var(--muted); margin-top:2px}
.logo-pick.selected{border-color:var(--brand-ink); box-shadow:0 0 0 2px rgba(91,124,250,.35)}
.zone-shared{margin-left:10px; font-size:11px; font-weight:600; color:var(--muted); background:var(--surface-2); border:1px solid var(--line); border-radius:999px; padding:2px 9px}
.opt-tag{font-size:10.5px; font-weight:600; text-transform:uppercase; letter-spacing:.4px; color:var(--muted); background:var(--surface-2); border:1px solid var(--line); border-radius:999px; padding:1px 8px; vertical-align:middle}
/* Dropdown personalitzat */
.dd{position:relative}
.dd-toggle{width:100%; display:flex; align-items:center; justify-content:space-between; gap:8px; background:var(--surface); border:1px solid var(--line); border-radius:10px; padding:10px 12px; cursor:pointer; color:var(--text); font:inherit; font-size:14px; transition:.15s}
.dd-toggle:hover{border-color:var(--brand-ink)}
.dd-val{overflow:hidden; text-overflow:ellipsis; white-space:nowrap}
.dd-caret{color:var(--muted); font-size:18px; flex:none}
.dd-menu{position:absolute; top:calc(100% + 5px); left:0; right:0; background:var(--surface); border:1px solid var(--line); border-radius:11px; box-shadow:var(--shadow); padding:6px; z-index:60; max-height:260px; overflow:auto}
.dd-opt{display:flex; align-items:center; gap:8px; width:100%; text-align:left; background:transparent; border:none; color:var(--text); padding:9px 10px; border-radius:8px; cursor:pointer; font:inherit; font-size:13.5px}
.dd-opt:hover{background:var(--surface-2)}
.dd-opt.active{color:var(--brand-ink); font-weight:600}
.dd-opt .dd-check{width:16px; flex:none; display:grid; place-items:center; color:var(--brand-ink)}
.dd-opt.dd-new{color:var(--brand-ink); border-top:1px solid var(--line); border-radius:0 0 8px 8px; margin-top:4px; padding-top:11px}
.dd-static{padding:6px 2px}
.seg{display:inline-flex; border:1px solid var(--line); border-radius:9px; overflow:hidden; background:var(--surface)}
.seg button{background:transparent; border:none; color:var(--muted); padding:7px 14px; cursor:pointer; font-weight:600; font-size:13px}
.seg button+button{border-left:1px solid var(--line)}
.seg button.active{background:var(--brand); color:#fff}
.pack-block{background:var(--surface); border:1px solid var(--line); border-radius:16px; padding:16px 18px 18px; margin-bottom:20px}
.pack-block .logo-card{box-shadow:none}
.pack-head{display:flex; align-items:center; gap:12px; margin:0 0 14px}
.pack-head .cat-h{flex:none; margin:0; text-transform:none; font-size:14px}
.pack-block .grid.cards{gap:14px}
/* hover: tot element interactiu s'enfosqueix lleugerament */
.card.click{cursor:pointer; transition:transform .15s, box-shadow .15s, border-color .15s}
.card.click:hover{border-color:var(--brand-ink); box-shadow:var(--shadow); transform:translateY(-2px)}
.btn.primary:hover{filter:brightness(.93)}
.btn.danger:hover{filter:brightness(.96)}
.year-tab{transition:.15s}
.year-tab:hover{color:var(--text); background:var(--surface-2)}
.navlink:active,.btn:active{filter:brightness(.9)}
.logo-card{position:relative}
.logo-check{position:absolute; top:8px; left:8px; z-index:3; width:26px; height:26px; display:grid; place-items:center; background:var(--surface); border:1px solid var(--line); border-radius:7px; cursor:pointer}
.logo-check input{width:16px; height:16px; cursor:pointer; margin:0}
.logo-card.sel{outline:2px solid var(--brand-ink); outline-offset:1px; border-color:var(--brand-ink)}
.bulk-bar{display:flex; align-items:center; gap:10px; position:sticky; top:64px; z-index:20; background:var(--surface); border:1px solid var(--brand); border-radius:12px; padding:8px 12px; margin-bottom:14px; box-shadow:var(--shadow)}
.bulk-bar .bulk-count{font-weight:700; font-size:14px}
.logo-pick.selected::after{content:"✓"; position:absolute; top:4px; right:4px; width:18px; height:18px; background:var(--brand); color:#fff; border-radius:50%; display:grid; place-items:center; font-size:11px}
.dragover{outline:2px dashed var(--brand); outline-offset:-6px}
/* secció portada i caixes drag&drop */
.dropbox{border:1.5px dashed var(--line); border-radius:12px; min-height:150px; display:grid; place-items:center; background:var(--surface); overflow:hidden; padding:10px; cursor:pointer; transition:border-color .15s, background .15s}
.dropbox:hover{border-color:var(--brand-ink); background:var(--bg-accent)}
.dropbox.dragover{border-color:var(--brand-ink); background:rgba(91,124,250,.06); outline:none}
.dz-empty{display:flex; flex-direction:column; align-items:center; gap:10px; color:var(--muted); font-size:12.5px; text-align:center; padding:14px}
.dz-empty > i{font-size:30px; width:64px; height:64px; border-radius:50%; display:grid; place-items:center;
  color:var(--brand-ink); background:var(--bg-accent); box-shadow:0 0 0 6px color-mix(in srgb, var(--brand) 7%, transparent); margin-bottom:12px}
.dropbox:hover .dz-empty > i{background:var(--surface)}
.cover-img{max-width:100%; max-height:320px; object-fit:contain; border-radius:8px}
.dz-sub{font-size:11px; opacity:.7}
.cover-preview{background:var(--surface-2); border:1px solid var(--line); border-radius:10px; padding:10px; display:grid; place-items:center; margin-bottom:10px; min-height:120px}
.attach-list{display:flex; flex-direction:column; gap:8px; margin-top:14px}
.attach{display:flex; align-items:center; gap:10px; background:var(--bg); border:1px solid var(--line); border-radius:10px; padding:9px 12px}
.attach.active{border-color:var(--brand-ink)}
.attach > .ti{font-size:22px; color:var(--brand-ink); flex:none}
.attach-thumb{width:46px; height:46px; flex:none; border-radius:8px; overflow:hidden; background:var(--surface-2); border:1px solid var(--line); display:grid; place-items:center}
.attach-thumb img{width:100%; height:100%; object-fit:cover; display:block}
.at-info{flex:1; min-width:0}
.at-name{font-size:13.5px; font-weight:600; display:flex; align-items:center; gap:8px}
.at-meta{font-size:11.5px; color:var(--muted)}
.cover-thumb{height:150px; background:var(--surface-2); border-bottom:1px solid var(--line); border-radius:14px 14px 0 0; overflow:hidden; display:grid; place-items:center; padding:8px}
.cover-thumb img{max-width:100%; max-height:100%; object-fit:contain; display:block}

/* targeta de format del catàleg */
.cat-h{font-size:13px; letter-spacing:.4px; text-transform:uppercase; color:var(--muted); margin:6px 0 12px; font-weight:700}
.cat-h + .grid{margin-bottom:26px}
.card.fmt-card{position:relative; padding:0; overflow:visible}
.fmt-prev{height:150px; background:var(--surface-2); border-bottom:1px solid var(--line); border-radius:14px 14px 0 0; display:grid; place-items:center; padding:14px; overflow:hidden}
.fmt-box{background:var(--surface); border:1.5px solid var(--brand); border-radius:3px; display:flex; align-items:center; justify-content:center; max-width:100%}
.fmt-box span{font-size:11px; color:var(--muted); text-align:center; padding:2px 4px; line-height:1.2}
.fmt-box.noratio{width:84px; height:108px; color:var(--muted)}
.fmt-box.noratio i{font-size:30px}
.fmt-box.multi{box-shadow:5px 5px 0 -1px var(--surface-2), 5px 5px 0 0 var(--brand), 10px 10px 0 -1px var(--surface-2), 10px 10px 0 0 var(--brand)}
.card.fmt-card .card-body{padding:16px 18px}

.filelist,.commentlist{display:flex; flex-direction:column; gap:10px}
.fileitem{display:flex; align-items:center; gap:10px; background:var(--bg); border:1px solid var(--line); border-radius:10px; padding:10px 12px}
.fileitem.col{flex-direction:column; align-items:stretch}
.prev{position:relative; width:100%; height:150px; border-radius:9px; overflow:hidden; background:var(--surface-2); border:1px solid var(--line); display:grid; place-items:center}
.prev img{width:100%; height:100%; object-fit:cover; display:block}
.prev .pf{display:none; color:var(--muted); font-size:13px; padding:0 10px; text-align:center}
.prev .pf .ti{font-size:26px; display:block; margin-bottom:6px}
.prev.noimg img{display:none}
.prev.noimg .pf{display:block}
.fileitem .fi{flex:1; min-width:0}
.fileitem .fn{font-size:13.5px; font-weight:600; white-space:nowrap; overflow:hidden; text-overflow:ellipsis}
.fileitem .fm{font-size:11.5px; color:var(--muted)}
.comment{position:relative; background:var(--surface); border:1px solid var(--line); border-radius:12px; padding:12px 38px 12px 14px; box-shadow:0 1px 2px rgba(40,50,90,.05)}
body:not(.light) .comment{background:var(--surface-2)}
.comment .ch{display:flex; gap:6px 8px; align-items:center; flex-wrap:wrap; margin-bottom:6px; font-size:12px}
.comment .ca{font-weight:700; font-size:13px}
.comment .role-pill{font-size:9.5px; padding:2px 7px; letter-spacing:.4px}
.comment .ct{color:var(--muted); white-space:nowrap}
.comment .cb{font-size:14px; line-height:1.5; white-space:pre-wrap}
.comment .icon-x{position:absolute; top:6px; right:6px}
.pdf-preview{margin-top:12px; border:1px solid var(--line); border-radius:10px; overflow:hidden; background:#eef0f4}
.pdf-preview iframe{width:100%; height:460px; border:0; display:block}

/* ---- auth ---- */
.auth{max-width:380px; margin:8vh auto; }
.auth .panel{padding:26px}
.auth h1{font-size:22px; margin:0 0 4px}
.auth .sub{color:var(--muted); font-size:13.5px; margin-bottom:18px}
.auth .toggle{text-align:center; margin-top:14px; font-size:13px; color:var(--muted)}
.auth .toggle a{cursor:pointer}

/* ---- login (pantalla dividida) ---- */
body.pre-auth{ padding-left:0 }
body.pre-auth .sidebar{ display:none }
body.pre-auth .wrap{ max-width:none; margin:0; padding:0 }
.login{ display:flex; min-height:100vh; position:relative; }
/* Panell de marca (esquerra) — degradat blau viu, sense zona fosca */
.login-brand{
  flex:1 1 46%; min-width:0; position:relative; overflow:hidden;
  display:flex; flex-direction:column; justify-content:space-between;
  padding:54px 52px; color:#fff;
  background:linear-gradient(135deg, #5e6fd0 0%, var(--brand) 48%, var(--brand-2) 100%);
  background-size:170% 170%;
  animation:loginGradient 18s ease infinite;
}
/* Bombolles de llum que suren */
.login-brand::before{
  content:""; position:absolute; width:440px; height:440px; border-radius:50%;
  top:-130px; right:-90px; pointer-events:none;
  background:radial-gradient(circle, rgba(255,255,255,.22), transparent 64%);
  animation:loginFloat1 15s ease-in-out infinite;
}
.login-brand::after{
  content:""; position:absolute; width:340px; height:340px; border-radius:50%;
  bottom:-110px; left:-70px; pointer-events:none;
  background:radial-gradient(circle, rgba(150,175,255,.24), transparent 66%);
  animation:loginFloat2 19s ease-in-out infinite;
}
.login-brand > *{ position:relative; z-index:1 }
@keyframes loginGradient{ 0%{background-position:0% 50%} 50%{background-position:100% 50%} 100%{background-position:0% 50%} }
@keyframes loginFloat1{ 0%,100%{transform:translate(0,0)} 50%{transform:translate(-34px,42px)} }
@keyframes loginFloat2{ 0%,100%{transform:translate(0,0)} 50%{transform:translate(44px,-30px)} }
/* Entrada esglaonada del contingut explicatiu */
@keyframes loginUp{ from{opacity:0; transform:translateY(16px)} to{opacity:1; transform:translateY(0)} }
.login-brand-top, .login-tagline, .login-points li, .login-brand-foot, .login-card{ animation:loginUp .6s cubic-bezier(.22,.61,.36,1) both }
.login-brand-top{ animation-delay:.05s }
.login-tagline{ animation-delay:.16s }
.login-points li:nth-child(1){ animation-delay:.30s }
.login-points li:nth-child(2){ animation-delay:.40s }
.login-points li:nth-child(3){ animation-delay:.50s }
.login-brand-foot{ animation-delay:.62s }
.login-card{ animation-delay:.12s }
/* Botó de tema (icona sol/lluna) */
.login-theme{
  position:absolute; top:16px; right:16px; z-index:5;
  width:38px; height:38px; border-radius:10px;
  border:1px solid var(--line); background:var(--surface); color:var(--text);
  display:grid; place-items:center; cursor:pointer; font-size:18px; transition:.15s;
}
.login-theme:hover{ border-color:var(--brand-ink); color:var(--brand-ink) }
/* Camp de contrasenya amb icona d'ull */
.pw-wrap{ position:relative }
.pw-wrap input{ width:100%; padding-right:42px !important }
.pw-eye{
  position:absolute; top:0; right:0; height:100%; width:40px;
  display:grid; place-items:center; background:none; border:none;
  color:var(--muted); cursor:pointer; font-size:17px; transition:.15s;
}
.pw-eye:hover{ color:var(--brand-ink) }
@media(prefers-reduced-motion:reduce){
  .login-brand, .login-brand::before, .login-brand::after,
  .login-brand-top, .login-tagline, .login-points li, .login-brand-foot, .login-card{ animation:none }
}
.login-brand-top{ display:flex; align-items:center; gap:14px }
.login-brand-top .login-logo{ width:48px; height:48px; object-fit:contain; border-radius:12px; display:block }
.login-brand-name{ font-size:24px; font-weight:700; letter-spacing:.2px }
.login-brand-mid{ max-width:420px }
.login-tagline{ font-size:30px; line-height:1.22; font-weight:700; margin:0 0 28px; letter-spacing:-.4px }
.login-points{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:14px }
.login-points li{ display:flex; align-items:flex-start; gap:11px; font-size:15px; color:rgba(255,255,255,.92) }
.login-points li .ti{ font-size:20px; flex:none; margin-top:1px; color:rgba(255,255,255,.85) }
.login-brand-foot{ font-size:12.5px; color:rgba(255,255,255,.62); letter-spacing:.2px }
/* Costat del formulari (dreta) */
.login-form-side{ flex:1 1 54%; min-width:0; display:flex; align-items:center; justify-content:center; padding:40px 28px; background:var(--bg) }
.login-card{ width:100%; max-width:380px }
.login-card-head{ margin-bottom:22px }
.login-card-logo{ width:46px; height:46px; object-fit:contain; border-radius:11px; display:none; margin-bottom:14px }
.login-card h1{ font-size:25px; margin:0 0 5px; letter-spacing:-.3px }
.login-card .sub{ color:var(--muted); font-size:14px; margin:0 }
.login-card form{ margin-top:8px }
.login-submit{ width:100%; justify-content:center; margin-top:6px; padding:11px; font-size:14.5px }
/* Responsiu: amaga el panell de marca, mostra el logo dins la targeta */
@media(max-width:860px){
  .login-brand{ display:none }
  .login-form-side{ background:transparent }
  .login-card-logo{ display:block }
}
.note{font-size:12.5px; color:#bcd0ff; background:rgba(91,124,250,.12); border:1px solid #33407e; border-radius:9px; padding:10px 12px; margin-top:14px}
body.light .note{ color:#2f3c80; background:rgba(59,74,153,.08); border-color:#b9c2ec }

/* ---- modal ---- */
.modal-bg{position:fixed; inset:0; background:rgba(5,7,15,.6); backdrop-filter:blur(3px); display:grid; place-items:center; z-index:50}
.modal{background:var(--surface); border:1px solid var(--line); border-radius:16px; padding:22px; width:min(520px,92vw); box-shadow:var(--shadow)}
.modal.wide{width:min(900px,94vw)}
.modal h3{margin:0 0 16px}
.modal .actions{display:flex; justify-content:flex-end; gap:10px; margin-top:18px}

/* ---- Responsive: telèfon ---- */
@media(max-width:640px){
  .wrap{padding:16px 16px 56px}
  .asset-header{margin-left:-16px; margin-right:-16px; padding:14px 16px}
  .ah-main{flex-wrap:wrap; gap:10px}
  .ah-main .spacer{display:none}
  .asset-header h2{max-width:none; white-space:normal}
  .asset-header.proj-header h2{font-size:22px}
  .ah-cover{order:0}
  .ah-titlewrap{order:1; flex:1 1 55%}
  .ah-kebab{order:2; margin-left:auto}
  .ah-meta{order:3; width:100%}
  .ah-metabox{flex:1; min-width:0; height:auto; padding:8px 10px}
  .proj-header .proj-tabs{margin:2px -16px -14px -16px; padding:0 16px; overflow-x:auto}
  .proj-tab{white-space:nowrap}
  /* Comentaris: overlay lliscant, no resten amplada al contingut */
  body.asset-mode{ --cw:0px }
  body.asset-mode .wrap{ padding:0 16px 56px 16px }
  .asset-comments{width:300px; max-width:88vw; box-shadow:-6px 0 18px rgba(20,25,60,.18)}
  body.asset-mode.comments-collapsed .asset-comments{width:44px; box-shadow:none}
  /* Formularis i taules */
  .row2{grid-template-columns:1fr}
  .modal{max-height:90vh; overflow:auto}
  table.users{font-size:12.5px}
  table.users td, table.users th{word-break:break-word}
}

/* ---- misc ---- */
.toast{position:fixed; bottom:22px; left:50%; transform:translateX(-50%); background:var(--surface-2); border:1px solid var(--line); padding:12px 18px; border-radius:10px; box-shadow:var(--shadow); z-index:80; font-size:14px}
.toast.err{border-color:var(--danger)}
.empty{color:var(--muted); text-align:center; padding:40px; border:1px dashed var(--line); border-radius:var(--radius)}
.blocked-note{display:flex; align-items:center; gap:8px; margin:0 0 16px; padding:11px 14px; border-radius:10px; font-size:14px;
  background:rgba(224,85,107,.14); border:1px solid #7a2a39; color:#ffb3c0}
body.light .blocked-note{background:rgba(192,40,63,.08); border-color:#f0a9b3; color:#b3261e}
.tag-input{display:flex; gap:8px; flex-wrap:wrap; align-items:center}
.spin{display:inline-block;width:16px;height:16px;border:2px solid var(--muted);border-top-color:transparent;border-radius:50%;animation:sp .7s linear infinite}
@keyframes sp{to{transform:rotate(360deg)}}
.center{display:grid;place-items:center;min-height:60vh}
table.users{width:100%; border-collapse:collapse}
table.users th,table.users td{text-align:left; padding:10px 8px; border-bottom:1px solid var(--line); font-size:14px}
table.users th{color:var(--muted); font-weight:600; font-size:12px; text-transform:uppercase}

/* ---- ajustos per al mode clar ---- */
body.light .badge.pendent{ background:rgba(240,160,32,.16); color:#8a5610; border-color:#e7c98a }
body.light .badge.en_proces{ background:rgba(59,74,153,.12); color:#2f3c80; border-color:#b9c2ec }
body.light .badge.aprovat{ background:rgba(15,110,86,.12); color:#0f6e56; border-color:#9fe1cb }
body.light .badge.bloquejat{ background:rgba(192,40,63,.10); color:#b3261e; border-color:#f0a9b3 }
body.light .deadline.soon{ color:#8a5610 }
body.light .deadline.late{ color:#b3261e }
.theme-btn{ display:inline-flex; align-items:center; justify-content:center; width:34px; height:34px; padding:0; font-size:16px }
.brand{cursor:pointer}

/* document Word (estil Google Docs) */
.doc-wrap{display:grid; grid-template-columns:1fr 290px; gap:16px; align-items:start}
@media(max-width:900px){ .doc-wrap{grid-template-columns:1fr} }
.doc-body{background:#fff; color:#1b2138; border:1px solid var(--line); border-radius:10px; padding:26px 30px; max-height:620px; overflow:auto; font-size:14px; line-height:1.65}
.doc-body :is(h1,h2,h3,h4){color:#10142a; margin:0 0 8px}
.doc-body p{margin:0 0 10px}
.doc-body img{max-width:100%}
.doc-body mark.hl{background:#ffe08a; color:inherit; border-radius:2px; padding:0 1px; cursor:pointer}
.doc-body mark.hl.active{background:#ffc53d}
.doc-comments{display:flex; flex-direction:column; gap:10px}
.dc{position:relative; background:var(--surface); border:1px solid var(--line); border-radius:12px; padding:10px 36px 10px 12px; cursor:pointer}
body:not(.light) .dc{background:var(--surface-2)}
.dc .icon-x{position:absolute; top:6px; right:6px}
.dc:hover{border-color:var(--brand-ink)}
.dc.active{border-color:var(--brand-ink); box-shadow:0 0 0 2px rgba(91,124,250,.25)}
.dc .q{font-size:12px; color:var(--muted); border-left:2px solid var(--brand); padding-left:7px; margin-bottom:5px}
.dc .b{font-size:13.5px}
.docselbtn{box-shadow:var(--shadow)}
