@font-face {
  font-family: 'BayerSans';
  src: url('../fonts/BayerSansWeb-Thin.woff2') format('woff2');
  font-weight: 100;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'BayerSans';
  src: url('../fonts/BayerSansWeb-ThinItalic.woff2') format('woff2');
  font-weight: 100;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: 'BayerSans';
  src: url('../fonts/BayerSansWeb-ExtraLight.woff2') format('woff2');
  font-weight: 200;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'BayerSans';
  src: url('../fonts/BayerSansWeb-ExtraLightItalic.woff2') format('woff2');
  font-weight: 200;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: 'BayerSans';
  src: url('../fonts/BayerSansWeb-Light.woff2') format('woff2');
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'BayerSans';
  src: url('../fonts/BayerSansWeb-LightItalic.woff2') format('woff2');
  font-weight: 300;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: 'BayerSans';
  src: url('../fonts/BayerSansWeb-Regular.woff2') format('woff2');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'BayerSans';
  src: url('../fonts/BayerSansWeb-Italic.woff2') format('woff2');
  font-weight: 400;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: 'BayerSans';
  src: url('../fonts/BayerSansWeb-Medium.woff2') format('woff2');
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'BayerSans';
  src: url('../fonts/BayerSansWeb-MediumItalic.woff2') format('woff2');
  font-weight: 500;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: 'BayerSans';
  src: url('../fonts/BayerSansWeb-Bold.woff2') format('woff2');
  font-weight: 600 700;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'BayerSans';
  src: url('../fonts/BayerSansWeb-BoldItalic.woff2') format('woff2');
  font-weight: 600 700;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: 'BayerSans';
  src: url('../fonts/BayerSansWeb-Heavy.woff2') format('woff2');
  font-weight: 800;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'BayerSans';
  src: url('../fonts/BayerSansWeb-HeavyItalic.woff2') format('woff2');
  font-weight: 800;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: 'BayerSans';
  src: url('../fonts/BayerSansWeb-Black.woff2') format('woff2');
  font-weight: 900;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'BayerSans';
  src: url('../fonts/BayerSansWeb-BlackItalic.woff2') format('woff2');
  font-weight: 900;
  font-style: italic;
  font-display: swap;
}

:root {
  /* Paleta Bayer Agro */
  --navy:        #10384F;
  --navy-73:     rgba(16,56,79,.73);
  --navy-38:     rgba(16,56,79,.38);
  --navy-12:     rgba(16,56,79,.12);
  --teal:        #006F9B;
  --teal-soft:   rgba(0,111,155,.10);
  --red:         #D30F4B;
  --red-soft:    rgba(211,15,75,.10);
  --green:       #2B6636;
  --green-soft:  rgba(43,102,54,.10);
  --lime:        #89D329;
  --plum:        #624963;
  --plum-soft:   rgba(98,73,99,.10);

  /* Superficie */
  --bg:          #fafafa;
  --surface:     #FFFFFF;
  --surface-2:   #F5F5F5;
  --border:      #E0E0E0;
  --border-strong: rgba(16,56,79,.25);

  /* Texto */
  --text:        #10384F;
  --text-2:      rgba(16,56,79,.73);
  --text-3:      rgba(16,56,79,.38);

  /* Aliases para compatibilidad */
  --accent:      #10384F;
  --accent-soft: rgba(16,56,79,.08);
  --blue:        #006F9B;
  --blue-soft:   rgba(0,111,155,.10);
  --amber:       #624963;
  --amber-soft:  rgba(98,73,99,.10);
  --gray:        #696969;
  --gray-soft:   #F5F5F5;

  --shadow-sm: 0 1px 2px rgba(16,56,79,.06), 0 1px 4px rgba(16,56,79,.04);
  --shadow-md: 0 4px 16px rgba(16,56,79,.10), 0 1px 4px rgba(16,56,79,.06);
  --radius:    4px;
  --radius-sm: 2px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:'BayerSans',Helvetica,Arial,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;line-height:1.5;letter-spacing:-.25px}

/* ── LAYOUT ── */
.container{max-width:1440px;margin:0 auto;padding:32px 32px 80px}

/* ── HERO / HEADER ── */
header.hero{display:flex;align-items:flex-start;justify-content:space-between;gap:24px;margin-bottom:28px;flex-wrap:wrap}
.hero-left h1{font-size:32px;font-weight:700;letter-spacing:-.5px;margin:0;line-height:1.2em;color:var(--navy)}
.hero-left .subtitle{color:var(--navy);font-size:18px;margin:0 0 24px;font-weight:400}
.hero-meta{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.pill{display:inline-flex;align-items:center;gap:6px;background:var(--surface);border:1px solid var(--border-strong);color:var(--text-2);padding:4px 12px;border-radius:999px;font-size:12px;font-weight:500}
.pill .dot{width:6px;height:6px;border-radius:50%;background:var(--teal)}
.hero-right{display:flex;flex-direction:column;align-items:flex-end;gap:10px;color:var(--text-3);font-size:12px}
.hero-right .date{color:var(--text-2);font-weight:500;font-size:12px}
.hero-actions{display:flex;gap:8px;align-items:center}

/* ── BOTONES ── */
.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 16px;border-radius:2px;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;border:1px solid var(--navy);background:transparent;color:var(--navy);text-decoration:none;transition:all .15s;letter-spacing:.01em}
.btn:hover{background:var(--navy-12)}
.btn-primary{background:var(--navy);color:#fff;border-color:var(--navy)}
.btn-primary:hover{background:#0c2d3f}
.btn-ghost{background:transparent;border-color:transparent;color:var(--text-2)}
.btn-ghost:hover{background:var(--navy-12)}
.btn .spin{animation:spin 1s linear infinite}
.btn[disabled]{opacity:.5;cursor:wait}
.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;border:1px solid var(--border-strong);background:var(--surface);color:var(--text-2);cursor:pointer;font-family:inherit;text-decoration:none;transition:background .15s,color .15s,border-color .15s;flex-shrink:0}
.btn-icon:hover{background:var(--navy-12);color:var(--navy);border-color:var(--navy)}
.btn-icon[disabled]{opacity:.5;cursor:wait}
.btn-icon .spin{animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

.user-chip{display:inline-flex;align-items:center;gap:6px;height:32px;box-sizing:border-box;padding:0 12px 0 8px;font-size:12px;color:var(--text-2);background:var(--surface);border:1px solid var(--border-strong);border-radius:999px}
.user-chip svg{opacity:.5}

/* ── KPIs ── */
.kpis{display:grid;grid-template-columns:repeat(6,1fr);gap:12px;margin-bottom:12px}
@media (max-width:1200px){.kpis{grid-template-columns:repeat(3,1fr)}}
@media (max-width:640px){.kpis{grid-template-columns:repeat(2,1fr)}}
.kpis-metrics{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:28px}
@media (max-width:640px){.kpis-metrics{grid-template-columns:1fr}}
.kpi{background:var(--surface);border:1px solid var(--border);border-top:3px solid var(--navy);border-radius:var(--radius);padding:20px 18px;min-height:180px;position:relative;overflow:hidden}
.kpi.blue{border-top-color:var(--navy)}
.kpi.green{border-top-color:var(--green)}
.kpi.amber{border-top-color:var(--plum)}
.kpi.red{border-top-color:var(--red)}
.kpi.indigo{border-top-color:var(--navy)}
.kpi.gray{border-top-color:var(--navy)}
.kpi .label{font-size:16px;color:var(--navy);font-weight:600;margin-bottom:8px}
.kpi .value{font-size:48px;font-weight:700;letter-spacing:-.02em;line-height:1;color:var(--navy)}
.kpi.red .value{color:var(--red)}
.kpi .delta{font-size:16px;color:var(--text-3);margin-top:6px}
.kpi .icon{position:absolute;top:14px;right:14px;width:30px;height:30px;border-radius:2px;display:grid;place-items:center;font-size:14px;background:var(--navy-12);color:var(--navy)}
.kpi.blue .icon{background:var(--navy-12);color:var(--navy)}
.kpi.green .icon{background:var(--green-soft);color:var(--green)}
.kpi.amber .icon{background:var(--plum-soft);color:var(--plum)}
.kpi.red .icon{background:var(--red-soft);color:var(--red)}
.kpi.indigo .icon{background:var(--navy-12);color:var(--navy)}
.kpi.gray .icon{background:var(--navy-12);color:var(--navy)}
.kpi-metric{border-top-color:var(--lime)!important}
.kpi-metric .icon{background:rgba(137,211,41,.12)!important;color:var(--lime)!important}
.kpi-metric .value{color:var(--lime)}

/* ── SECTION TITLES ── */
.section-title{display:flex;align-items:center;justify-content:space-between;margin:28px 0 12px}
.section-title h2{font-size:22px;font-weight:700;margin:0;letter-spacing:-.5px;color:var(--navy)}
.section-title .hint{font-size:12px;color:var(--text-3)}

/* ── CHARTS ── */
.charts{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:12px}
@media (max-width:1100px){.charts{grid-template-columns:1fr 1fr}}
@media (max-width:640px){.charts{grid-template-columns:1fr}}
#mapCard{display:flex;flex-direction:column}
#projectsMap{flex:1;min-height:280px}
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px}
.card h3{font-size:16px;font-weight:700;letter-spacing:-.5px;color:var(--navy);margin:0 -20px 18px;padding:0 20px 14px;border-bottom:1px solid var(--border)}
.chart-wrap{position:relative;height:240px}

.phases-card .phase-row{display:flex;align-items:center;gap:12px;padding:8px 0;border-bottom:1px solid var(--border)}
.phases-card .phase-row:last-child{border-bottom:none}
.phase-name{flex:1;font-size:13px;color:var(--text)}
.phase-bar{flex:0 0 140px;height:6px;background:var(--navy-12);border-radius:999px;overflow:hidden}
.phase-bar>span{display:block;height:100%;background:var(--navy);border-radius:999px}
.phase-count{width:56px;text-align:right;font-size:12px;color:var(--text-2);font-variant-numeric:tabular-nums;font-weight:500}

/* ── TOOLBAR ── */
.toolbar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:12px 16px;display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:12px}
.toolbar .search{flex:1;min-width:220px;position:relative}
.toolbar input[type="search"]{width:100%;height:36px;box-sizing:border-box;padding:0 12px 0 34px;border:1px solid var(--border-strong);border-radius:var(--radius-sm);font-size:13px;font-family:inherit;background:var(--surface-2);color:var(--text)}
.toolbar input[type="search"]:focus{outline:none;border-color:var(--navy);box-shadow:0 0 0 3px var(--navy-12);background:#fff}
.toolbar .search svg{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-3)}
.toolbar select{height:36px;box-sizing:border-box;padding:0 30px 0 12px;border:1px solid var(--border-strong);border-radius:var(--radius-sm);font-size:13px;font-family:inherit;background-color:var(--surface-2);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2310384F' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 9px center;color:var(--text);cursor:pointer;-webkit-appearance:none;appearance:none}
.toolbar select:focus{outline:none;border-color:var(--navy)}
.toolbar .btn-clear{height:36px;box-sizing:border-box;padding:0 14px;border:1px solid var(--border-strong);border-radius:var(--radius-sm);background:var(--surface);cursor:pointer;font-family:inherit;font-size:13px;color:var(--text-2);font-weight:500}
.toolbar .btn-clear:hover{background:var(--gray-soft)}
.toolbar .count{margin-left:auto;font-size:12px;color:var(--text-3);font-weight:500}

/* ── TABLA ── */
.table-card{padding:0;overflow:hidden}
table.proyectos{width:100%;border-collapse:collapse;font-size:13.5px}
table.proyectos thead th{background:var(--navy);text-align:left;padding:11px 16px;font-size:11px;font-weight:600;color:#fff;text-transform:uppercase;letter-spacing:.06em;border-bottom:none;white-space:nowrap;vertical-align:bottom;line-height:1em}
table.proyectos thead th[data-col]{cursor:pointer;user-select:none}
table.proyectos thead th[data-col]:hover{background:var(--teal)}
table.proyectos thead th .sort-icon{font-size:10px;opacity:.8}
table.proyectos tbody td{padding:13px 16px;border-bottom:1px solid var(--border);vertical-align:middle}
table.proyectos tbody tr:last-child td{border-bottom:none}
table.proyectos tbody tr.proyecto-row{cursor:pointer;transition:background .12s}
table.proyectos tbody tr.proyecto-row:hover{background:#EEF4F7}
table.proyectos tbody tr.proyecto-row.row-open{background:#EEF4F7}
.proyecto-name{font-size:14px;font-weight:600;color:var(--navy)}
.proyecto-sub{font-size:12px;color:var(--text-3);margin-top:2px}

/* ── STATUS BADGES ── */
.status-badge{display:inline-flex;align-items:center;gap:5px;height:20px;padding:0 9px;border-radius:2px;font-size:11px;font-weight:600;line-height:1;white-space:nowrap;box-sizing:border-box}
.status-badge .dot{width:5px;height:5px;border-radius:50%}
.status-analisis{background:rgba(0,188,255,.12);color:#0098CC}.status-analisis .dot{background:#00BCFF}
.status-desarrollo{background:rgba(137,211,41,.12);color:#5A9E1F}.status-desarrollo .dot{background:#89D329}
.status-standby{background:var(--red-soft);color:var(--red)}.status-standby .dot{background:var(--red)}
.status-aprobado{background:rgba(0,111,155,.12);color:var(--teal)}.status-aprobado .dot{background:var(--teal)}
.status-implementado{background:var(--green-soft);color:var(--green)}.status-implementado .dot{background:var(--green)}
.status-otros{background:rgba(0,152,204,.12);color:#0098CC}.status-otros .dot{background:#0098CC}

/* ── PRIORITY ── */
.priority-badge{display:inline-flex;align-items:center;gap:5px;height:20px;padding:0 9px;border-radius:2px;font-size:11px;font-weight:600;line-height:1;box-sizing:border-box}
.priority-high{background:var(--navy);color:#fff}
.priority-low{background:#EEEEEE;color:var(--gray)}
.priority-urgent{background:var(--red-soft);color:var(--red)}
.priority-normal{background:var(--teal-soft);color:var(--teal)}
.priority-none{color:var(--text-3);font-size:12px;font-weight:500}

/* ── EARLY ADOPTER ── */
.tag-ea-yes{display:inline-flex;align-items:center;height:20px;padding:0 9px;background:var(--navy);color:#fff;border-radius:2px;font-size:11px;font-weight:600;line-height:1;box-sizing:border-box}
.tag-ea-no{display:inline-flex;align-items:center;height:20px;padding:0 9px;background:#EEEEEE;color:var(--gray);border-radius:2px;font-size:11px;font-weight:600;line-height:1;box-sizing:border-box}

/* ── PROGRESS ── */
.progress-cell{display:flex;align-items:center;gap:10px;min-width:130px}
.progress-bar{flex:1;height:6px;background:var(--navy-12);border-radius:999px;overflow:hidden}
.progress-bar>span{display:block;height:100%;border-radius:999px;background:var(--navy);transition:width .3s}
.progress-text{font-size:11.5px;color:var(--text-2);font-variant-numeric:tabular-nums;min-width:36px;text-align:right;font-weight:500}
.age-cell{font-size:12.5px;color:var(--text-2);font-variant-numeric:tabular-nums}
.impl-date-cell{font-size:12.5px;color:var(--text-2);font-variant-numeric:tabular-nums;white-space:nowrap}
.impl-check-on{font-size:16px;color:var(--green)}
.impl-check-off{font-size:16px;color:var(--border-strong)}
.age-stale{color:var(--red);font-weight:600}
.age-warn{color:var(--amber);font-weight:600}

/* ── DETAIL ROW ── */
tr.detail-row{display:none;background:#F9FBFC}
tr.detail-row.open{display:table-row}
tr.detail-row td{padding:0!important;border-bottom:1px solid var(--border)}
.detail-content{padding:20px 24px 24px;display:grid;grid-template-columns:1fr 0.7fr 1.5fr 1fr;gap:20px;border-top:2px solid var(--teal)}
@media (max-width:900px){.detail-content{grid-template-columns:1fr}}
.detail-block h4{font-size:14px;font-weight:700;color:var(--navy-73);margin:0 0 10px;padding-bottom:6px;border-bottom:1px solid var(--border)}
.detail-block .desc{font-size:13px;color:var(--text);white-space:pre-wrap;line-height:1.55;background:#fff;padding:12px 14px;border-radius:2px;border:1px solid var(--border);max-height:200px;overflow:auto}
.detail-block .desc.empty{color:var(--text-3);font-style:italic}
.contact-item{display:flex;gap:8px;align-items:flex-start;font-size:13px;padding:6px 0;color:var(--text);border-bottom:1px solid var(--border)}
.contact-item:last-child{border-bottom:none}
.contact-item .key{color:var(--text-3);min-width:70px;font-size:11px;padding-top:2px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.contact-item a{color:var(--teal);text-decoration:none;word-break:break-all}
.contact-item a:hover{text-decoration:underline}

/* ── COMMENTS ── */
.comment-item{padding:8px 0;border-bottom:1px solid var(--border)}
.comment-item:last-child{border-bottom:none}
.comment-date{font-size:10px;color:var(--text-3);font-weight:700;margin-bottom:4px;font-variant-numeric:tabular-nums;letter-spacing:.04em;text-transform:uppercase}
.comment-text{font-size:13px;color:var(--text);line-height:1.55;white-space:pre-wrap}

/* ── CHECKLIST ── */
.checklist{display:flex;flex-direction:column;gap:6px}
.checklist-group-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-3);margin-top:10px;padding-bottom:4px;border-bottom:1px solid var(--border)}.checklist-group-label:first-child{margin-top:0}
.check-item{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--text)}
.check-box{width:16px;height:16px;border-radius:2px;border:1.5px solid var(--border-strong);background:#fff;display:grid;place-items:center;flex-shrink:0}
.check-box.done{background:var(--green);border-color:var(--green);color:#fff}
.check-item.done .label{color:var(--text-3);text-decoration:line-through}

/* ── LINKS ── */
.ext-link{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;color:var(--teal);background:var(--teal-soft);padding:6px 12px;border-radius:2px;text-decoration:none;font-weight:600;border:1px solid rgba(0,111,155,.2)}
.ext-link:hover{background:rgba(0,111,155,.18)}
.drive-pill{display:inline-flex;align-items:center;gap:7px;height:28px;padding:0 12px;border-radius:999px;border:1px solid var(--border-strong);background:var(--surface);color:var(--text-2);font-size:12.5px;font-weight:600;text-decoration:none;transition:background .15s,border-color .15s}
.drive-pill:hover{background:var(--navy-12);border-color:var(--navy);color:var(--navy)}
.drive-pill .fa-google-drive{font-size:13px;color:#4285F4}

/* ── COMEX ── */
.comex-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px;margin-bottom:28px}
.comex-card{background:var(--surface);border:1px solid var(--border);border-top:3px solid var(--teal);border-radius:var(--radius);padding:18px 20px}
.comex-header{display:flex;flex-direction:column;align-items:flex-start;gap:6px;margin-bottom:16px}
.comex-title{font-size:16px;font-weight:700;color:var(--navy)}
.comex-arribo{display:flex;flex-direction:column;line-height:1em}
.comex-arribo-label{font-size:13px;font-weight:400;color:var(--text-2)}
.comex-arribo-date{font-size:13px;font-weight:400;color:var(--text-2)}
.comex-track{position:relative;height:28px;display:flex;align-items:center;margin-bottom:4px}
.comex-line{width:100%;height:3px;background:var(--navy-12);border-radius:999px}
.comex-ship{position:absolute;font-size:18px;top:50%;margin-top:-9px}
.comex-status-label{font-size:11px;color:var(--text-3);margin-bottom:14px}
.comex-projects{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px;border-top:1px solid var(--border);padding-top:14px}
.comex-projects li{display:flex;justify-content:space-between;align-items:center;gap:8px}
.comex-projects .proyecto-name{font-size:12.5px;font-weight:500;color:var(--navy);flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* ── FOOTER ── */
.footer{text-align:center;margin-top:40px;font-size:12px;color:var(--text-3)}
.footer a{color:var(--teal);text-decoration:none}
.empty{padding:60px 20px;text-align:center;color:var(--text-3);font-size:14px}

/* ── MOBILE ── */
@media (max-width:640px){
  .container{padding:16px 16px 60px}
  .col-hide-mobile{display:none}
  .section-title{flex-direction:column;align-items:flex-start;gap:4px}
  header.hero{flex-direction:column;gap:12px}
  .hero-right{order:-1;width:100%;flex-direction:column;align-items:flex-start;gap:6px}
  .hero-left{width:100%}
  .kpi{display:flex;flex-direction:column;align-items:flex-start}
  .kpi .icon{position:static;margin-bottom:10px}
  .kpi .label{line-height:1em}
  .table-card{overflow-x:auto}
  table.proyectos{min-width:480px}
  .chart-wrap{overflow:hidden}
  .card{padding:14px 14px}
}

/* ── STICKY ACTIONS ── */
.sticky-actions{position:fixed;top:20px;right:32px;display:flex;gap:8px;align-items:center;z-index:2000;opacity:0;transform:translateY(-8px);transition:opacity .2s,transform .2s;pointer-events:none;background:rgba(250,250,250,.75);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(16,56,79,.10);border-radius:999px;padding:6px 8px}
.sticky-actions.sticky-visible{opacity:1;transform:translateY(0);pointer-events:auto}

/* ── LOADING / ERROR ── */
.state-overlay{position:fixed;inset:0;background:rgba(245,245,245,.88);backdrop-filter:blur(2px);display:none;align-items:center;justify-content:center;flex-direction:column;gap:14px;z-index:100}
.state-overlay.visible{display:flex}
.loading-dot{width:36px;height:36px;border:3px solid var(--navy-12);border-top-color:var(--navy);border-radius:50%;animation:spin .8s linear infinite}
.state-overlay .msg{font-size:14px;color:var(--text-2);font-weight:500}
.error-banner{background:var(--red-soft);border:1px solid rgba(222,0,67,.3);color:var(--red);padding:12px 16px;border-radius:var(--radius);margin-bottom:16px;font-size:13px;display:none}
.error-banner.visible{display:block}
