:root{
  --brand-primary:#8f0b4e;
  --brand-primary-2:#b31262;
  --brand-accent:#d2a35d;
  --brand-accent-soft:#f3dfbf;
  --brand-dark:#4a1432;
  --brand-ink:#2b2430;
  --brand-surface:#fff;
  --brand-bg:#f7f1f4;
  --brand-line:#eadbe3;
  --ok:#0f766e;
  --warn:#b45309;
  --err:#991b1b;
  --shadow:0 10px 30px rgba(74,20,50,.10);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;max-width:100%;overflow-x:hidden}
body{margin:0;font-family:Arial,Helvetica,sans-serif;background:linear-gradient(180deg,#fbf7f9 0%,#f6eef3 100%);color:var(--brand-ink);max-width:100%;overflow-x:hidden}
a{text-decoration:none;color:var(--brand-primary)}
a:hover{opacity:.92}
.layout{display:flex;min-height:100vh}
.sidebar{width:290px;background:linear-gradient(180deg,var(--brand-dark) 0%,var(--brand-primary) 55%,#761346 100%);color:#fff;padding:18px;position:sticky;top:0;height:100vh;box-shadow:var(--shadow)}
.brand{display:flex;flex-direction:column;gap:12px;margin-bottom:18px}
.brand-logo-wrap{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);border-radius:18px;padding:14px;backdrop-filter:blur(2px)}
.brand-logo{display:block;max-width:100%;height:auto;object-fit:contain;filter:drop-shadow(0 4px 14px rgba(0,0,0,.18))}
.brand-kicker{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#f7d7a0}
.brand-title{font-size:21px;font-weight:700;line-height:1.15;margin:0}
.brand-subtitle{font-size:12px;line-height:1.45;color:rgba(255,255,255,.88)}
.sidebar nav{margin-top:8px}
.sidebar nav a{display:block;color:#f8e9f0;padding:11px 12px;border-radius:12px;margin-bottom:6px;border:1px solid transparent;transition:.18s ease}
.sidebar nav a:hover,.sidebar nav a.active{background:rgba(255,255,255,.10);border-color:rgba(255,255,255,.14);transform:translateX(2px)}
.content{flex:1;padding:24px 26px;overflow:auto;min-width:0;max-width:100%}
.page-hero{position:relative;overflow:hidden;background:linear-gradient(130deg,rgba(143,11,78,.95) 0%,rgba(179,18,98,.94) 68%,rgba(210,163,93,.78) 140%), url('../img/banner_renacimiento_maya.jpg') center/cover no-repeat;border-radius:22px;padding:24px 26px;color:#fff;box-shadow:var(--shadow);margin-bottom:22px}
.page-hero::after{content:'';position:absolute;inset:auto -40px -80px auto;width:220px;height:220px;border-radius:50%;background:rgba(255,255,255,.08)}
.page-hero h1,.page-hero h2{margin:0 0 8px;position:relative;z-index:1}
.page-hero p{margin:0;max-width:860px;color:rgba(255,255,255,.92);position:relative;z-index:1}
.content > h1{margin:0 0 16px;font-size:30px;line-height:1.1;color:var(--brand-dark);letter-spacing:-.02em}
.content > h1 + .card,.content > h1 + .grid,.content > h1 + .page-hero{margin-top:2px}
.card > h2,.card h2:first-child{margin:0 0 14px;font-size:19px;line-height:1.2;color:var(--brand-dark)}
.card > h3,.card h3:first-child{margin:0 0 10px;font-size:16px;color:var(--brand-dark)}
.card form{display:block}
.card form .row + .row{margin-top:10px}
.card input[type=text],.card input[type=password],.card input[type=file],.card input[type=number],.card select,.card textarea{background:#fffdfd}
.card .table-wrap{background:#fff;border-radius:16px}
.card .table th{font-weight:800}
.card .muted{margin-bottom:10px}
.hero-mini{font-size:12px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;color:#f7d7a0;margin-bottom:6px}
.card{background:var(--brand-surface);border-radius:18px;padding:18px;box-shadow:var(--shadow);margin-bottom:20px;border:1px solid rgba(143,11,78,.06)}
.grid{display:grid;gap:18px}.grid.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
label{display:block;font-weight:600;margin-bottom:6px;color:var(--brand-dark)}
input,select,textarea,button{font:inherit}
input[type=text],input[type=password],input[type=file],input[type=number],select,textarea{width:100%;padding:11px 12px;border:1px solid #d9c4d0;border-radius:12px;background:#fff}
input[type=text]:focus,input[type=password]:focus,input[type=file]:focus,input[type=number]:focus,select:focus,textarea:focus{outline:none;border-color:var(--brand-primary);box-shadow:0 0 0 3px rgba(143,11,78,.12)}
textarea{min-height:90px}
button,.btn{display:inline-block;padding:10px 14px;border:none;border-radius:12px;background:linear-gradient(180deg,var(--brand-primary-2),var(--brand-primary));color:#fff;cursor:pointer;box-shadow:0 6px 18px rgba(143,11,78,.18)}
button:hover,.btn:hover{filter:brightness(.98)}
.btn.secondary{background:#5f4b58;box-shadow:none}.btn.warn{background:#9a5b0d}.btn.light{background:#fff;color:var(--brand-primary);box-shadow:none;border:1px solid #ebd6e0}
.table-wrap{overflow:auto;border-radius:14px;border:1px solid var(--brand-line)}
.table{width:100%;border-collapse:collapse;background:#fff;min-width:720px}.table th,.table td{border-bottom:1px solid #efe3e9;padding:10px 8px;text-align:left;font-size:14px;vertical-align:top}.table th{background:#fbf6f8;position:sticky;top:0;color:var(--brand-dark)}
.alert{padding:12px 14px;border-radius:12px;margin-bottom:16px;border:1px solid transparent}.alert.success{background:#e5fbf6;color:#065f46;border-color:#b9ebdd}.alert.error{background:#fff0f0;color:#991b1b;border-color:#f3c1c1}
.kpis{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.kpi{background:#fff;border-radius:18px;padding:18px;box-shadow:var(--shadow);border:1px solid rgba(143,11,78,.06)}.kpi h3{margin:0 0 8px;font-size:13px;color:#7d6672;text-transform:uppercase;letter-spacing:.04em}.kpi strong{font-size:30px;color:var(--brand-dark)}
.badge{display:inline-block;padding:4px 9px;border-radius:999px;font-size:12px;font-weight:700}.badge.ok{background:#d1fae5;color:#065f46}.badge.warn{background:#fef3c7;color:#92400e}.badge.err{background:#fee2e2;color:#991b1b}
.row{display:flex;gap:12px;align-items:flex-end;flex-wrap:wrap}.row > div{flex:1 1 180px}
.login-wrap{max-width:980px;margin:36px auto;padding:0 18px}.login-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:18px;align-items:stretch}
.login-brand-panel{min-height:480px;display:flex;flex-direction:column;justify-content:flex-end;background:linear-gradient(180deg,rgba(74,20,50,.38),rgba(74,20,50,.68)), url('../img/banner_renacimiento_maya.jpg') center/cover no-repeat;border-radius:22px;padding:26px;color:#fff;box-shadow:var(--shadow)}
.login-brand-panel .logo{height:auto;max-width:290px;background:rgba(255,255,255,.9);padding:10px 12px;border-radius:16px;margin-bottom:16px}
.login-brand-panel h1{margin:0 0 8px;font-size:33px;line-height:1.05}.login-brand-panel p{margin:0;color:rgba(255,255,255,.92)}
.login-card{align-self:center}
.muted{color:#6b7280;font-size:14px}.actions{display:flex;gap:8px;flex-wrap:wrap}.actions.compact-actions > *{flex:0 0 auto}.text-right{text-align:right}.small{font-size:12px}.print-only{display:none}
.stack-actions{display:flex;flex-direction:column;gap:8px;min-width:220px}.stack-actions textarea{width:100%;min-height:62px}.badge{white-space:nowrap}
.label-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.label{border:1px dashed #c38ca7;padding:10px;border-radius:12px;background:#fff}.scan-box{font-size:28px;padding:12px;text-align:center}.result{padding:12px;border-radius:12px;margin-top:12px}
.result.ok{background:#d1fae5}.result.err{background:#fee2e2}.result.warn{background:#fef3c7}
video{width:100%;max-width:480px;border-radius:12px;background:#111}
.institutional-strip{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:10px 14px;border-radius:16px;background:linear-gradient(90deg,#fff 0%,#fcf6f8 100%);border:1px solid var(--brand-line);margin-bottom:18px}
.institutional-strip img{height:auto;max-width:100%;object-fit:contain}
.institutional-strip .title{font-size:14px;color:var(--brand-dark);font-weight:700}
.institutional-strip .subtitle{font-size:12px;color:#8a6f7b}
.report-header{display:flex;align-items:center;justify-content:space-between;gap:20px;border-bottom:3px solid var(--brand-accent);padding-bottom:14px;margin-bottom:18px}.report-header .logo{height:auto;max-width:320px;object-fit:contain}.report-header .meta{text-align:right}.report-header .meta strong{display:block;color:var(--brand-dark);font-size:17px}
.footer-note{margin-top:22px;padding-top:10px;border-top:1px solid var(--brand-line);font-size:12px;color:#7f6b76}
.barcode{display:flex;align-items:stretch;height:48px;background:#fff}.barcode .bar{display:inline-block;width:2px;background:#000}.barcode .space{display:inline-block;width:2px;background:#fff}.barcode .gap{display:inline-block;width:2px;background:#fff}
.label-grid-qr{grid-template-columns:repeat(3,minmax(0,1fr))}.label-qr{display:flex;flex-direction:column;min-height:320px}.qr-wrap{display:flex;justify-content:center;align-items:center;margin-top:10px;min-height:160px}.qr-image{width:150px;height:150px;display:block;object-fit:contain}.qr-wrap-overlay{position:relative;display:flex;justify-content:center;align-items:center}.qr-logo-badge{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:24%;max-width:42px;max-height:42px;aspect-ratio:1/1;object-fit:contain;background:#fff;border-radius:10px;padding:4px;box-shadow:0 0 0 2px rgba(255,255,255,.95),0 6px 14px rgba(74,20,50,.12)}.qr-text{margin-top:8px;font-size:12px;font-weight:700;letter-spacing:.4px;word-break:break-word;text-align:center}
.signature-grid{display:grid;grid-template-columns:1fr 1fr;gap:30px;margin-top:60px}.signature-line{padding-top:8px;border-top:1px solid #000;text-align:center}
@media (max-width: 1150px){
  .sidebar{width:235px}
  .grid.cols-3,.grid.cols-2,.kpis{grid-template-columns:1fr}
  .label-grid,.label-grid-qr{grid-template-columns:repeat(2,minmax(0,1fr))}
  .login-grid{grid-template-columns:1fr}
  .login-brand-panel{min-height:320px}
}
@media (max-width: 920px){
  .layout{flex-direction:column}
  .sidebar{width:100%;height:auto;position:relative;top:auto;padding:14px 14px 10px}
  .sidebar nav{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}
  .sidebar nav a{margin-bottom:0;text-align:center}
  .content{padding:16px}
  .institutional-strip{flex-direction:column;align-items:flex-start}
  .institutional-strip img{height:34px}
  .report-header{flex-direction:column;align-items:flex-start}
  .report-header .meta{text-align:left}
  .actions > a,.actions > button,.row > div:last-child button{flex:1 1 100%}
  .scan-box{font-size:22px}
  .signature-grid{grid-template-columns:1fr;gap:44px}
}
@media (max-width: 640px){
  .brand-title{font-size:18px}
  .brand-subtitle{font-size:11px}
  .sidebar nav{grid-template-columns:1fr}
  .content{padding:12px}
  .page-hero{padding:18px}
  .card{padding:14px;border-radius:16px}
  .table{min-width:640px}
  .table th,.table td{font-size:13px;padding:9px 7px}
  .label-grid,.label-grid-qr{grid-template-columns:1fr}
  .kpi strong{font-size:24px}
  .login-wrap{padding:0 12px}
  input[type=text],input[type=password],input[type=file],input[type=number],select,textarea,button{font-size:16px}
  .qr-image{width:132px;height:132px}
}
@media print {
  body{background:#fff}
  .sidebar,.no-print,.actions{display:none!important}
  .content{padding:0}
  .print-only{display:block}
  .card{box-shadow:none;border:1px solid #ddd}
  .page-hero{box-shadow:none;border:1px solid #ddd;background:linear-gradient(130deg,#8f0b4e 0%,#b31262 70%,#d2a35d 130%)!important}
  .institutional-strip{border-color:#ddd}
  .label-grid-qr{grid-template-columns:repeat(2,1fr)}
  .label-qr{border:1px solid #444;border-style:solid}
}
.menu-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;border-radius:999px;background:var(--brand-accent);color:#4a1432;font-size:11px;font-weight:800;vertical-align:middle}
.notice-list{display:grid;gap:10px;margin-top:14px}.notice-item{border:1px solid var(--brand-line);background:#fff8ef;border-radius:14px;padding:12px 14px}.notice-item strong{color:var(--brand-dark)}
.kpi.soft{background:linear-gradient(135deg,#fffaf2 0%,#fff 100%)}
.task-list{display:grid;gap:12px}.task-row{display:flex;justify-content:space-between;gap:14px;align-items:flex-start;padding:12px 14px;border:1px solid var(--brand-line);border-radius:14px;background:#fff}.task-row .meta{font-size:12px;color:#7f6b76}
@media (max-width: 640px){.task-row{flex-direction:column;align-items:stretch}.menu-badge{margin-left:4px}}

.toolbar-filter-row{margin-bottom:10px}
.toolbar-filter-row > div{flex:1 1 180px}
.toolbar-filter-row .toolbar-submit{flex:0 0 auto;min-width:120px}
.toolbar-actions{display:flex;align-items:center;gap:8px;flex-wrap:nowrap;overflow-x:auto;padding-bottom:2px;margin-top:4px}
.toolbar-actions > .btn,.toolbar-actions > button{flex:0 0 auto;white-space:nowrap;margin:0}
.toolbar-actions::-webkit-scrollbar{height:8px}
.toolbar-actions::-webkit-scrollbar-thumb{background:#d9c4d0;border-radius:999px}
.module-help{display:none!important}
@media (max-width: 920px){
  .toolbar-filter-row .toolbar-submit{min-width:unset}
}


.pagination-compact{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.pagination-compact .btn.sm{padding:8px 12px;font-size:13px;min-height:auto}
.pagination-compact .muted{font-size:13px;color:#6b7280}


/* Responsive mobile refinements v6.7.1b */
.mobile-topbar,.mobile-sidebar-backdrop,.mobile-menu-toggle{display:none}
.mobile-topbar{align-items:center;gap:12px;padding:10px 2px 16px;margin-bottom:10px}
.mobile-topbar-title{min-width:0;flex:1 1 auto}
.mobile-topbar-main{font-size:18px;font-weight:800;line-height:1.15;color:var(--brand-dark);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mobile-topbar-sub{font-size:11px;color:#8a6f7b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mobile-topbar-logo{flex:0 0 auto;max-width:112px;height:auto;object-fit:contain}
.mobile-menu-toggle{width:58px;height:58px;border-radius:18px;border:none;display:flex;align-items:center;justify-content:center;font-size:30px;font-weight:700;line-height:1;background:linear-gradient(180deg,var(--brand-primary-2),var(--brand-primary));color:#fff;box-shadow:0 10px 24px rgba(143,11,78,.25)}
body.menu-open{overflow:hidden}
@media (max-width: 920px){
  .mobile-topbar{display:flex}
  .institutional-strip{display:none}
  .layout{display:block;min-height:100vh}
  .sidebar{position:fixed;left:0;top:0;bottom:0;width:min(84vw,320px);height:100vh;overflow:auto;z-index:1200;transform:translateX(-102%);transition:transform .24s ease, box-shadow .24s ease;padding:18px 16px 24px}
  body.menu-open .sidebar{transform:translateX(0);box-shadow:0 18px 38px rgba(0,0,0,.28)}
  .mobile-sidebar-backdrop{display:block;position:fixed;inset:0;background:rgba(22,10,18,.42);backdrop-filter:blur(2px);opacity:0;pointer-events:none;z-index:1100;transition:opacity .22s ease}
  body.menu-open .mobile-sidebar-backdrop{opacity:1;pointer-events:auto}
  .sidebar nav{display:flex;flex-direction:column;gap:8px}
  .sidebar nav a{display:flex;align-items:center;justify-content:center;min-height:52px;font-size:18px;text-align:center}
  .content{padding:12px 12px 26px}
  .content > .page-hero{margin-top:0}
  .actions,.compact-module-actions,.toolbar-actions{gap:10px!important}
  .compact-module-actions > .btn,.compact-module-actions > button,
  .actions > .btn,.actions > button,.actions > a,
  .toolbar-actions > .btn,.toolbar-actions > button,.toolbar-actions > a{display:flex;align-items:center;justify-content:center;width:100%;max-width:100%;min-width:0;flex:1 1 100%;text-align:center;white-space:normal;word-break:break-word;line-height:1.2;padding:14px 16px}
  .compact-actions-gap{margin-top:8px!important}
  .kpis{grid-template-columns:1fr 1fr;gap:10px}
  .grid.cols-2,.grid.cols-3{grid-template-columns:1fr}
  .card{overflow:hidden}
  .table-wrap{overflow:auto;-webkit-overflow-scrolling:touch}
}
@media (max-width: 640px){
  .content{padding:10px 10px 22px}
  .page-hero{border-radius:20px;padding:18px 16px}
  .page-hero h1,.page-hero h2{font-size:28px;line-height:1.05}
  .kpis{grid-template-columns:1fr 1fr}
  .kpi{padding:16px 14px}
  .kpi strong{font-size:22px}
  .notice-list .notice-item{font-size:15px}
  .mobile-topbar-logo{max-width:96px}
}


/* v6.7.1c iOS menu + mobile actions hardening */
@media (max-width: 920px){
  .mobile-topbar{position:sticky;top:0;z-index:1000;background:linear-gradient(180deg,#fbf7f9 0%,rgba(251,247,249,.96) 100%);padding:12px 2px 14px;margin:0 0 12px}
  .mobile-menu-toggle{-webkit-appearance:none;appearance:none;touch-action:manipulation;cursor:pointer;position:relative;z-index:1305;flex:0 0 58px}
  .sidebar{z-index:1300}
  .mobile-sidebar-backdrop{z-index:1290}
  .actions,.compact-module-actions,.toolbar-actions{width:100%;display:grid!important;grid-template-columns:1fr!important;gap:10px!important;align-items:stretch}
  .actions > a,.actions > button,.actions > .btn,
  .compact-module-actions > a,.compact-module-actions > button,.compact-module-actions > .btn,
  .toolbar-actions > a,.toolbar-actions > button,.toolbar-actions > .btn{
    width:100%!important;max-width:100%!important;min-width:0!important;display:flex!important;align-items:center!important;justify-content:center!important;
    white-space:normal!important;overflow-wrap:anywhere!important;word-break:break-word!important;text-align:center!important;line-height:1.2!important;
    padding:15px 16px!important;margin:0!important;font-size:15px!important
  }
  .grid.cols-2,.grid.cols-3{grid-template-columns:1fr!important}
  .card .table{min-width:560px}
}
@media (max-width: 640px){
  .mobile-topbar{gap:10px}
  .mobile-topbar-main{font-size:16px}
  .mobile-topbar-logo{max-width:88px}
  .actions > a,.actions > button,.actions > .btn,
  .compact-module-actions > a,.compact-module-actions > button,.compact-module-actions > .btn,
  .toolbar-actions > a,.toolbar-actions > button,.toolbar-actions > .btn{font-size:14px!important;padding:14px 14px!important;border-radius:14px!important}
}

/* v6.7.1d mobile dashboard + iOS stability */
@media (max-width: 920px){
  html,body,.layout,.content,.grid,.kpis,.card{max-width:100%!important;min-width:0!important;}
  .content{overflow-x:hidden!important;padding-left:12px!important;padding-right:12px!important;}
  .page-hero,.institutional-strip,.card,.kpi,.table-wrap{max-width:100%!important;min-width:0!important;}
  .actions,.compact-module-actions,.toolbar-actions,.dashboard-actions-grid{width:100%!important;max-width:100%!important;display:grid!important;grid-template-columns:1fr!important;gap:10px!important;overflow:visible!important;}
  .actions > a,.actions > button,.actions > .btn,
  .compact-module-actions > a,.compact-module-actions > button,.compact-module-actions > .btn,
  .toolbar-actions > a,.toolbar-actions > button,.toolbar-actions > .btn,
  .dashboard-actions-grid > a,.dashboard-actions-grid > button,.dashboard-actions-grid > .btn{width:100%!important;max-width:100%!important;min-width:0!important;box-sizing:border-box!important;margin:0!important;justify-content:center!important;text-align:center!important;overflow-wrap:anywhere!important;word-break:break-word!important;white-space:normal!important;}
  .compact-mobile-table{min-width:0!important;width:100%!important;table-layout:fixed!important;}
  .compact-mobile-table th,.compact-mobile-table td{word-break:break-word;overflow-wrap:anywhere;}
}
@media (max-width: 640px){
  .mobile-topbar{padding-left:4px!important;padding-right:4px!important;}
  .mobile-topbar-title{min-width:0!important;max-width:calc(100vw - 170px)!important;}
  .mobile-topbar-main{font-size:15px!important;}
  .mobile-topbar-logo{max-width:84px!important;}
  .page-hero h1,.page-hero h2{font-size:24px!important;}
}
