/*
  Puertoriente | Sistema visual unificado
  Base tomada del index del módulo Comercial para homogeneizar módulos.
*/
:root{
  --orange:#f36a21;
  --accent:#0f3b6b;
  --max-width:1100px;
  --header-pad-y:18px;
}
body.light{
  --bg:#f4f8ff;
  --bg-alt:#eaf2ff;
  --text:#0b2540;
  --text-muted:#2f4f72;
  --card-bg:#fbfdff;
  --border:rgba(15,59,107,0.18);
  --header-bg:rgba(244,248,255,.78);
  --header-border:rgba(15,59,107,.12);
  --shadow:0 10px 26px rgba(15,59,107,.10);
}
body.dark{
  --bg:#071427;
  --bg-alt:#0b2540;
  --text:#ffffff;
  --text-muted:#dbeafc;
  --card-bg:#0e1a2d;
  --border:rgba(255,255,255,0.14);
  --header-bg:rgba(7,20,39,.55);
  --header-border:rgba(255,255,255,.14);
  --shadow:0 10px 30px rgba(0,0,0,.25);
}
html,body{margin:0;padding:0;background:var(--bg);min-height:100%;}
*{box-sizing:border-box;}
body{
  font-family:'Source Sans 3', system-ui, Arial, sans-serif !important;
  color:var(--text);
  transition:background .3s,color .3s;
  line-height:1.5;
}
a{color:inherit;text-decoration:none;}
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{
  outline:2px solid var(--orange);
  outline-offset:2px;
  border-radius:8px;
}
.container{max-width:var(--max-width) !important;margin:0 auto;padding:24px;}
header{
  position:sticky;
  top:0;
  z-index:1000;
  background:var(--header-bg) !important;
  -webkit-backdrop-filter:saturate(180%) blur(10px);
  backdrop-filter:saturate(180%) blur(10px);
  border-bottom:1px solid var(--header-border) !important;
}
.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:var(--header-pad-y) 0;
}
.brand{display:flex;align-items:center;gap:12px;min-width:0;}
.brand img{height:60px;width:auto;display:block;}
.brand-title{font-family:'Source Sans 3', system-ui, Arial, sans-serif !important;font-weight:700 !important;font-size:20px !important;white-space:nowrap;}
.brand-sub{font-size:12px !important;color:var(--text-muted) !important;margin-top:2px;font-weight:400 !important;font-family:'Source Sans 3', system-ui, Arial, sans-serif !important;}
.right-controls{display:flex;align-items:center;gap:8px;flex:0 0 auto;}
nav.primary ul{display:flex;gap:8px;list-style:none;margin:0;padding:0;align-items:center;}
nav.primary a,
.nav-pill{
  font-weight:900;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid var(--border);
  background:color-mix(in srgb,var(--card-bg) 75%,transparent);
  display:block;
  white-space:nowrap;
}
nav.primary a:hover,.nav-pill:hover{background:var(--bg-alt);}
nav.primary a.active{border-color:color-mix(in srgb,var(--orange) 80%,var(--border));background:rgba(243,106,33,.16);}
.theme-ctrl{
  display:flex;
  align-items:center;
  gap:10px;
  background:color-mix(in srgb,var(--card-bg) 80%,transparent);
  padding:8px 10px;
  border:1px solid var(--border);
  border-radius:12px;
}
.theme-ctrl .theme-label,.theme-label{font-weight:900;font-size:14px;}
.theme-toggle{
  width:54px;
  height:28px;
  background:var(--orange);
  border-radius:50px;
  border:none;
  cursor:pointer;
  position:relative;
  transition:background .3s;
  padding:0;
  box-shadow:none;
}
.theme-toggle::after{
  content:"";
  position:absolute;
  top:3px;
  left:3px;
  width:22px;
  height:22px;
  background:#fff;
  border-radius:50%;
  transition:transform .3s;
  box-shadow:0 1px 2px rgba(0,0,0,.25);
}
.theme-toggle::before{content:"🌙";position:absolute;right:7px;top:3px;font-size:16px;line-height:22px;opacity:.9;}
body.light .theme-toggle{background:#333;}
body.light .theme-toggle::after{transform:translateX(26px);}
body.light .theme-toggle::before{content:"☀️";left:7px;right:auto;}
.page-head{margin-top:16px;display:flex;align-items:flex-start;justify-content:space-between;gap:14px;flex-wrap:wrap;}
.page-title{margin:0;font-family:'Montserrat', system-ui, Arial, sans-serif !important;font-size:clamp(20px,2.2vw,30px) !important;letter-spacing:.2px;font-weight:700;}
.page-sub{margin:6px 0 0;color:var(--text-muted);font-weight:400;}
.card{
  margin-top:18px;
  background:color-mix(in srgb,var(--card-bg) 92%,transparent) !important;
  border:1px solid var(--border) !important;
  border-radius:18px !important;
  padding:18px;
  box-shadow:var(--shadow) !important;
}
body.light .card{box-shadow:0 10px 26px rgba(15,59,107,.10) !important;}
.btn,
a.btn,
button.btn{
  background:var(--orange);
  color:#fff;
  padding:12px 16px;
  border-radius:14px;
  font-weight:900;
  border:none;
  cursor:pointer;
  box-shadow:0 2px 8px rgba(0,0,0,.35);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  white-space:nowrap;
  text-decoration:none;
}
.btn.secondary,
a.btn.secondary,
button.btn.secondary{
  background:transparent;
  border:1px solid var(--border);
  color:var(--text);
  box-shadow:none;
}
.btn:hover{filter:brightness(1.03);}
.btn:disabled,button:disabled{opacity:.6;cursor:not-allowed;}
.grid{margin-top:18px;display:grid;grid-template-columns:repeat(3,1fr);gap:14px;}
.cc-card,.cc-item,.module-card{
  border:1px solid var(--border) !important;
  background:color-mix(in srgb,var(--bg) 70%,transparent) !important;
  border-radius:16px !important;
  padding:12px;
  cursor:pointer;
  transition:transform .08s ease,border-color .15s ease,background .15s ease;
  box-shadow:none !important;
  display:block;
  min-height:auto;
}
.module-card{padding:16px;min-height:138px;display:flex;flex-direction:column;gap:8px;}
.cc-card:hover,.cc-item:hover,.module-card:hover{
  transform:translateY(-1px);
  border-color:color-mix(in srgb,var(--orange) 70%,var(--border)) !important;
}
.cc-code,.module-title{font-family:'Montserrat',system-ui !important;font-weight:900;letter-spacing:.4px;}
.cc-meta,.cc-serv,.note,.hint,.muted,.module-desc{color:var(--text-muted);font-weight:650;}
.list-controls{display:flex;gap:10px;align-items:flex-end;flex-wrap:wrap;margin-bottom:12px;}
.list-controls .field{flex:1 1 320px;max-width:520px;margin:0;}
.field{display:flex;flex-direction:column;gap:6px;}
label,.label{font-weight:900;font-size:13px;color:var(--text);}
input,select,textarea,
.sol-input,.sol-textarea,.status-select,.sol-filter-input,.sol-filter-select{
  width:100%;
  padding:12px 12px;
  border-radius:14px;
  border:1px solid var(--border);
  background:color-mix(in srgb,var(--bg) 65%,transparent);
  color:var(--text);
  font:inherit;
}
textarea,.sol-textarea{min-height:110px;resize:vertical;}
input[readonly],textarea[readonly]{color:var(--text-muted);}
select option{color:#0b2540;}
.table-wrap{overflow:auto;border:1px solid var(--border);border-radius:16px;background:color-mix(in srgb,var(--bg) 65%,transparent);}
table{width:100%;border-collapse:collapse;min-width:980px;}
th,td{border-bottom:1px solid var(--border);padding:11px 10px;vertical-align:middle;}
th{text-align:left;color:var(--text-muted);font-size:12px;text-transform:uppercase;letter-spacing:.06em;font-weight:900;}
tbody tr{transition:background .12s;}
tbody tr:hover{background:rgba(243,106,33,.08);}
.empty{padding:24px;text-align:center;color:var(--text-muted);font-weight:800;}
.pill,.status-badge,.status{
  display:inline-flex;
  align-items:center;
  gap:7px;
  border-radius:999px;
  padding:7px 10px;
  border:1px solid var(--border);
  background:rgba(243,106,33,.12);
  font-size:12px;
  font-weight:900;
}
.dot,.status-dot{width:9px;height:9px;border-radius:999px;background:var(--orange);display:inline-block;}
.metrics{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;}
.metric{
  border:1px solid var(--border);
  border-radius:16px;
  padding:14px;
  background:color-mix(in srgb,var(--bg) 70%,transparent);
}
.metric .k{font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);font-weight:900;}
.metric .v{font-family:'Montserrat',system-ui;font-weight:900;font-size:24px;margin-top:5px;}
.metric .s{font-size:12px;color:var(--text-muted);font-weight:650;margin-top:2px;}
.filters,.form-grid{display:grid;grid-template-columns:repeat(5,1fr) auto;gap:10px;align-items:end;}
.filters .btn{min-height:47px;}
.money{font-family:'Montserrat',system-ui;font-weight:900;text-align:right;}
.nowrap{white-space:nowrap;}
.mini{font-size:12px;color:var(--text-muted);font-weight:800;}
.toast{
  position:fixed;
  left:50%;
  bottom:22px;
  transform:translateX(-50%) translateY(20px);
  opacity:0;
  pointer-events:none;
  background:#111827;
  color:white;
  border:1px solid rgba(255,255,255,.16);
  border-radius:14px;
  padding:11px 14px;
  font-weight:900;
  box-shadow:0 14px 30px rgba(0,0,0,.35);
  z-index:3000;
  transition:.2s;
}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0);display:block;}
.backdrop{position:fixed;inset:0;background:rgba(0,0,0,.55);backdrop-filter:blur(2px);display:none;align-items:center;justify-content:center;padding:18px;z-index:2000;}
.backdrop.open{display:flex;}
.modal{width:min(860px,100%);background:var(--card-bg);border:1px solid var(--border);border-radius:18px;box-shadow:0 20px 60px rgba(0,0,0,.55);overflow:hidden;display:flex;flex-direction:column;max-height:calc(100vh - 36px);}
.modal.small{width:min(640px,100%);}
.modal-header{padding:16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px;}
.modal-title{margin:0;font-family:'Montserrat';font-size:18px;}
.icon-btn{width:42px;height:42px;border-radius:12px;border:1px solid var(--border);background:transparent;color:var(--text);cursor:pointer;font-size:22px;line-height:1;box-shadow:none;padding:0;}
.modal-body{padding:16px;overflow:auto;flex:1 1 auto;min-height:0;}
.actions{display:flex;justify-content:flex-end;gap:10px;padding:16px;border-top:1px solid var(--border);flex-wrap:wrap;}
.drawer{position:fixed;inset:0;z-index:1600;display:none;}
.drawer.show{display:block;}
.drawer-back{position:absolute;inset:0;background:rgba(0,0,0,.55);}
.drawer-panel{position:absolute;right:0;top:0;bottom:0;width:min(720px,100%);background:var(--bg);border-left:1px solid var(--border);box-shadow:-12px 0 40px rgba(0,0,0,.28);overflow:auto;}
.drawer-head{position:sticky;top:0;background:var(--header-bg);-webkit-backdrop-filter:saturate(180%) blur(10px);backdrop-filter:saturate(180%) blur(10px);border-bottom:1px solid var(--border);padding:18px;display:flex;justify-content:space-between;gap:12px;align-items:flex-start;z-index:2;}
.drawer-body{padding:18px;}
.detail-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;}
.detail-grid .field{border:1px solid var(--border);border-radius:14px;padding:11px;background:color-mix(in srgb,var(--card-bg) 88%,transparent);display:block;}
.detail-grid .field .lk{font-size:11px;color:var(--text-muted);font-weight:900;text-transform:uppercase;letter-spacing:.06em;}
.detail-grid .field .lv{margin-top:3px;font-weight:800;}
.span2,.form-grid .full{grid-column:1/-1;}
.section-title{font-family:'Montserrat',system-ui;font-size:16px;font-weight:900;margin:20px 0 10px;}
.file-list,.log-list{display:grid;gap:8px;}
.file-item,.log-item{display:flex;justify-content:space-between;gap:10px;border:1px solid var(--border);border-radius:13px;padding:10px;background:color-mix(in srgb,var(--card-bg) 86%,transparent);}
.file-item a{text-decoration:underline;text-decoration-color:var(--orange);font-weight:900;}
/* Operaciones - solicitudes: se conserva lógica, pero se normaliza look & feel */
.sol-paper{border:1px solid var(--border);border-radius:18px;overflow:visible;background:color-mix(in srgb,var(--card-bg) 92%,transparent);}
.sol-strip{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;padding:14px 16px;border-bottom:1px solid var(--border);background:color-mix(in srgb,var(--bg) 70%,transparent);border-radius:18px 18px 0 0;}
.sol-title{font-family:'Montserrat',system-ui;font-weight:900;letter-spacing:.3px;}
.sol-form{padding:16px;}
.sol-field,.sol-filter-field,.sol-item{border:1px solid var(--border);background:color-mix(in srgb,var(--bg) 70%,transparent);border-radius:16px;}
.sol-field{padding:12px;min-width:0;transition:border-color .15s ease,transform .08s ease;}
.sol-field:hover{border-color:color-mix(in srgb,var(--orange) 45%,var(--border));}
.sol-grid-form{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;}
.sol-field.span-2{grid-column:span 2;}
.sol-field.span-4{grid-column:span 4;}
.sol-filter-panel{display:grid;grid-template-columns:minmax(260px,1.6fr) repeat(4,minmax(130px,.8fr)) auto;gap:10px;align-items:end;margin-bottom:12px;}
.sol-filter-field{padding:9px 10px;min-width:0;}
.sol-list{display:flex;flex-direction:column;gap:7px;margin-top:0;max-height:none;overflow:visible;padding-right:0;}
.sol-item{padding:9px 10px;cursor:pointer;transition:transform .08s ease,border-color .15s ease,background .15s ease;}
.sol-item:hover{transform:translateY(-1px);border-color:color-mix(in srgb,var(--orange) 70%,var(--border));background:color-mix(in srgb,var(--orange) 7%,var(--bg));}
@media (max-width:1100px){
  .metrics{grid-template-columns:repeat(2,1fr);}
  .filters{grid-template-columns:1fr 1fr;}
  .filters .btn{width:100%;}
  .sol-filter-panel{grid-template-columns:repeat(2,minmax(0,1fr));}
}
@media (max-width:980px){
  .grid{grid-template-columns:repeat(2,1fr);}
}
@media (max-width:720px){
  .brand-title,.brand-sub,.theme-label{display:none !important;}
  .container{padding:18px;}
  .right-controls{flex-wrap:wrap;justify-content:flex-end;}
  nav.primary ul{flex-wrap:wrap;justify-content:flex-end;}
  .grid,.metrics,.filters,.detail-grid,.form-grid,.sol-grid-form,.sol-filter-panel{grid-template-columns:1fr;}
  .span2,.form-grid .full,.sol-field.span-2,.sol-field.span-4{grid-column:auto;}
  .drawer-panel{width:100%;}
}
@media (prefers-reduced-motion:reduce){*{transition:none !important;animation:none !important;}}

/* Ajuste 2026-05-13: tipografía más limpia y menos pesada */
body{font-weight:400 !important;}
.brand-title{
  font-family:'Source Sans 3', system-ui, Arial, sans-serif !important;
  font-weight:700 !important;
  letter-spacing:.08px !important;
}
.brand-sub{
  font-family:'Source Sans 3', system-ui, Arial, sans-serif !important;
  font-weight:400 !important;
  letter-spacing:0 !important;
}
nav.primary a,
.nav-pill{
  font-weight:600 !important;
  letter-spacing:0 !important;
}
.theme-ctrl .theme-label,
.theme-label{
  font-weight:600 !important;
}
.page-title{
  font-family:'Source Sans 3', system-ui, Arial, sans-serif !important;
  font-weight:700 !important;
  letter-spacing:0 !important;
}
.page-sub,
.module-desc,
.cc-meta,
.cc-serv,
.note,
.hint,
.muted,
.metric .s,
.mini{
  font-weight:400 !important;
}
.module-title,
.cc-code,
.sol-title,
.modal-title,
.section-title,
.metric .v,
.money,
.code,
.contact-name,
.lookup-title{
  font-family:'Source Sans 3', system-ui, Arial, sans-serif !important;
  font-weight:700 !important;
  letter-spacing:0 !important;
}
.btn,
a.btn,
button.btn,
button,
.pill,
.status-badge,
.status,
.bulk-count,
.file-item a{
  font-weight:600 !important;
  letter-spacing:0 !important;
}
label,
.label,
th,
.metric .k,
.field .lk,
.sol-field label,
.sol-filter-field label{
  font-weight:600 !important;
}
.empty,
.toast,
.err,
.ok{
  font-weight:600 !important;
}

/* Comercial: selección masiva opcional, no permanente */
.bulk-panel{display:none !important;}
body.bulk-mode .bulk-panel{display:flex !important;}
.cc-select{display:none !important;}
body.bulk-mode .cc-select{display:inline-flex !important;}
body:not(.bulk-mode) .cc-card.selected{border-color:var(--border) !important;background:color-mix(in srgb,var(--bg) 70%,transparent) !important;}
body.bulk-mode .cc-card.selected{border-color:color-mix(in srgb,var(--orange) 82%,var(--border)) !important;background:color-mix(in srgb,var(--orange) 10%,var(--bg)) !important;}



/* Ajuste 2026-05-19: logos centralizados por tema */
.po-logo-wrap{display:inline-flex;align-items:center;line-height:0;vertical-align:middle;}
.po-logo-wrap img{max-width:100%;}
.po-logo-dark{display:block !important;}
.po-logo-light{display:none !important;}
body.light .po-logo-dark{display:none !important;}
body.light .po-logo-light{display:block !important;}

/* Comercial: accesos internos fuera del header principal */
.comercial-shortcuts{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
  margin:4px 0 16px;
  padding:10px;
  border:1px solid var(--border);
  border-radius:16px;
  background:color-mix(in srgb,var(--card-bg) 86%,transparent);
  box-shadow:var(--shadow);
}
.comercial-shortcuts .shortcut-label{
  color:var(--text-muted);
  font-size:12px;
  font-weight:600;
  margin-right:2px;
  text-transform:uppercase;
  letter-spacing:.04em;
}
.comercial-shortcuts a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:34px;
  padding:7px 10px;
  border:1px solid var(--border);
  border-radius:999px;
  background:color-mix(in srgb,var(--bg) 70%,transparent);
  color:var(--text);
  font-weight:600;
  text-decoration:none;
  white-space:nowrap;
}
.comercial-shortcuts a:hover,
.comercial-shortcuts a.active{
  border-color:color-mix(in srgb,var(--orange) 75%,var(--border));
  background:rgba(243,106,33,.14);
}
@media(max-width:720px){.comercial-shortcuts{align-items:flex-start}.comercial-shortcuts .shortcut-label{width:100%;}}

/* =====================================================================
   Ajuste responsive móvil integral | 2026-05-19
   Objetivo: que la plataforma principal pueda operarse desde celular
   sin romper encabezados, grillas, formularios, modales, drawers o tablas.
   ===================================================================== */
html{
  width:100%;
  max-width:100%;
  -webkit-text-size-adjust:100%;
  text-size-adjust:100%;
  overflow-x:hidden;
}
body{
  width:100%;
  max-width:100%;
  overflow-x:hidden;
  word-break:normal;
  overflow-wrap:anywhere;
}
img,svg,canvas,video,iframe{max-width:100%;height:auto;}
button,input,select,textarea{max-width:100%;font-size:16px;}
.container,.card,.sol-paper,.drawer-panel,.modal,.table-wrap{min-width:0;}
.card,.module-card,.cc-card,.cc-item,.sol-field,.sol-item,.metric,.file-item,.log-item{overflow-wrap:anywhere;}
.page-title,.page-sub,.module-title,.module-desc,.sol-title,.brand-title,.brand-sub{overflow-wrap:anywhere;}

/* Botones y acciones táctiles */
.btn,a.btn,button.btn,.nav-pill,nav.primary a,.icon-btn,.theme-toggle{
  touch-action:manipulation;
  -webkit-tap-highlight-color:rgba(243,106,33,.18);
}
.btn,a.btn,button.btn{min-height:44px;}
.actions,.mini-actions,.row,.list-controls,.bulk-panel,.toolbar,.form-actions{
  min-width:0;
}

/* Tablas: mantienen la información completa con scroll horizontal controlado */
.table-wrap{
  width:100%;
  max-width:100%;
  overflow-x:auto !important;
  overflow-y:visible;
  -webkit-overflow-scrolling:touch;
}
.table-wrap table,
.card table,
table{
  max-width:none;
}
th,td{overflow-wrap:normal;word-break:normal;}
td .btn,td a.btn,td button.btn{white-space:nowrap;}

/* Formularios y grillas genéricas */
.field,.sol-field,.sol-filter-field,.form-grid > *,.filters > *,.grid > *,.metrics > *,.detail-grid > *{
  min-width:0 !important;
}
input[type="file"]{padding:10px;background:color-mix(in srgb,var(--bg) 78%,transparent);}
input[type="checkbox"],input[type="radio"]{width:auto;min-height:auto;}
textarea{max-width:100%;}

@media (max-width:1100px){
  :root{--max-width:100%;}
  .container{width:100%;}
  .grid{grid-template-columns:repeat(2,minmax(0,1fr)) !important;}
  .metrics{grid-template-columns:repeat(2,minmax(0,1fr)) !important;}
  .filters,.form-grid,.sol-filter-panel{grid-template-columns:repeat(2,minmax(0,1fr)) !important;}
  .filters .btn,.sol-filter-panel .btn{width:100%;}
}

@media (max-width:820px){
  .page-head{flex-direction:column;align-items:stretch !important;}
  .page-head > *{max-width:100%;}
  .list-controls{align-items:stretch !important;}
  .list-controls .field{flex:1 1 100% !important;max-width:100% !important;}
  .list-controls .btn{width:100%;}
  .detail-grid{grid-template-columns:1fr !important;}
  .drawer-panel{width:100% !important;border-left:0 !important;}
  .drawer-head,.drawer-body{padding:14px !important;}
  .file-item,.log-item{flex-direction:column;align-items:flex-start;}
}

@media (max-width:720px){
  body{font-size:15.5px;}
  .container{padding:14px !important;}
  header{position:sticky;top:0;}
  .header-inner{
    width:100%;
    padding:12px 0 !important;
    display:flex !important;
    flex-direction:column;
    align-items:stretch !important;
    justify-content:flex-start !important;
    gap:10px !important;
  }
  .brand{width:100%;justify-content:flex-start;gap:10px !important;}
  .brand img,.po-logo-wrap img{height:44px !important;width:auto !important;max-width:180px !important;object-fit:contain;}
  .brand-title{font-size:16px !important;white-space:normal !important;line-height:1.05;}
  .brand-sub{font-size:11px !important;line-height:1.1;}
  .right-controls{
    width:100%;
    display:flex !important;
    align-items:center !important;
    justify-content:space-between !important;
    gap:8px !important;
    flex-wrap:nowrap !important;
    min-width:0;
  }
  nav.primary{flex:1 1 auto;min-width:0;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:1px;}
  nav.primary ul{
    display:flex !important;
    flex-wrap:nowrap !important;
    justify-content:flex-start !important;
    gap:7px !important;
    min-width:max-content;
  }
  nav.primary a,.nav-pill{padding:9px 10px !important;font-size:13px !important;border-radius:11px !important;white-space:nowrap !important;}
  .theme-ctrl{flex:0 0 auto;padding:7px 8px !important;gap:6px !important;}
  .theme-label{display:none !important;}
  .theme-toggle{width:48px !important;height:26px !important;}
  .theme-toggle::after{width:20px !important;height:20px !important;}
  body.light .theme-toggle::after{transform:translateX(22px) !important;}

  .page-head{margin-top:12px !important;gap:10px !important;}
  .page-title{font-size:clamp(20px,6vw,25px) !important;line-height:1.1 !important;}
  .page-sub{font-size:14px !important;line-height:1.35 !important;}
  .card{margin-top:14px !important;padding:14px !important;border-radius:16px !important;}
  .grid,.metrics,.filters,.form-grid,.sol-grid-form,.sol-filter-panel,.contacts-grid,.report-meta-grid,.report-meta-grid.compact{
    grid-template-columns:1fr !important;
  }
  .span2,.span-2,.span-3,.span-4,.form-grid .full,.sol-field.span-2,.sol-field.span-4{
    grid-column:1 / -1 !important;
  }
  .module-card,.cc-card,.cc-item{min-height:auto !important;padding:14px !important;}
  .metric .v{font-size:21px !important;}
  .filters .btn,.form-grid .btn,.sol-filter-panel .btn,.actions .btn,.actions a.btn,.mini-actions .btn,.mini-actions a.btn{
    width:100%;
  }
  .actions,.mini-actions{display:grid !important;grid-template-columns:1fr !important;padding:14px !important;}
  .btn,a.btn,button.btn{width:auto;justify-content:center;text-align:center;white-space:normal;line-height:1.15;padding:11px 13px;}
  .pill,.status-badge,.status{white-space:normal;line-height:1.15;}

  .sol-strip{align-items:flex-start !important;flex-direction:column !important;padding:12px !important;}
  .sol-form{padding:12px !important;}
  .sol-field,.sol-filter-field{padding:10px !important;border-radius:14px !important;}
  .sol-list{gap:9px !important;}
  .sol-item{padding:11px !important;}

  .table-wrap{border-radius:14px !important;margin-top:10px;}
  table{min-width:760px !important;font-size:14px;}
  th,td{padding:9px 8px !important;}

  .backdrop{align-items:flex-end !important;justify-content:center !important;padding:8px !important;}
  .modal{
    width:100% !important;
    max-height:calc(100svh - 16px) !important;
    border-radius:20px 20px 0 0 !important;
  }
  .modal-header{padding:13px 14px !important;}
  .modal-title{font-size:16px !important;line-height:1.2;}
  .modal-body{padding:14px !important;}
  .icon-btn{width:40px !important;height:40px !important;min-width:40px;}

  .drawer-head{align-items:flex-start !important;}
  .drawer-head .btn,.drawer-head a.btn,.drawer-head button.btn{width:auto;}
  .drawer-body{padding-bottom:calc(18px + env(safe-area-inset-bottom));}

  .comercial-shortcuts{margin:8px 0 12px !important;padding:9px !important;overflow-x:auto;flex-wrap:nowrap !important;-webkit-overflow-scrolling:touch;}
  .comercial-shortcuts .shortcut-label{width:auto !important;flex:0 0 auto;white-space:nowrap;}
  .comercial-shortcuts a{flex:0 0 auto;}
}

@media (max-width:520px){
  .container{padding:12px !important;}
  .right-controls{align-items:stretch !important;}
  .brand img,.po-logo-wrap img{height:40px !important;max-width:150px !important;}
  nav.primary a,.nav-pill{font-size:12.5px !important;padding:8px 9px !important;}
  .theme-ctrl{align-self:flex-start;}
  .card{padding:12px !important;}
  .page-title{font-size:21px !important;}
  input,select,textarea{min-height:44px;padding:11px 11px !important;}
  .btn,a.btn,button.btn{min-height:44px;padding:10px 12px !important;}
  table{min-width:680px !important;font-size:13.5px;}
  .modal{max-height:calc(100svh - 10px) !important;}
  .modal-body{padding:12px !important;}
  .drawer-head,.drawer-body{padding:12px !important;}
}

@media (max-width:380px){
  .container{padding:10px !important;}
  .brand img,.po-logo-wrap img{height:36px !important;max-width:132px !important;}
  nav.primary a,.nav-pill{font-size:12px !important;padding:8px !important;}
  .theme-toggle{width:44px !important;height:24px !important;}
  .theme-toggle::after{width:18px !important;height:18px !important;}
  body.light .theme-toggle::after{transform:translateX(20px) !important;}
  table{min-width:620px !important;}
}
