    :root{--bg:#f6f7f8;--paper:#fff;--ink:#0f1113;--muted:#4b5563;--line:#d5dbe3;--line-strong:#a9b3c2;--c-green:#0b7e59;--c-blue:#3763e0;--c-amber:#d97706;--c-red:#c0352b;--c-grey:#616e7c;--c-charcoal:#111314;--c-silver:#cfd6de;--font-sans: "IBM Plex Sans", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans";--font-mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, Consolas, "Liberation Mono", monospace;--fs-1:.8125rem;--fs-3:1rem;--fs-4:1.125rem;--fs-h1:clamp(1.75rem,3.2vw,2.25rem);--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-12:3rem;--container:1160px;--radius:0;--shadow:none}
    @media (prefers-color-scheme:dark){:root{--bg:#0c0d0f;--paper:#111316;--ink:#e9eef2;--muted:#9aa4b2;--line:#2a2f37;--line-strong:#3a414c;--c-silver:#555e6b}}
    /* Forzado por toggle */
    html[data-theme="dark"]{--bg:#0c0d0f;--paper:#111316;--ink:#e9eef2;--muted:#9aa4b2;--line:#2a2f37;--line-strong:#3a414c;--c-silver:#555e6b}
    html[data-theme="light"]{--bg:#f6f7f8;--paper:#fff;--ink:#0f1113;--muted:#4b5563;--line:#d5dbe3;--line-strong:#a9b3c2}
    /* Auto sigue el SO: claro base + override con media query */
    html[data-theme="auto"]{--bg:#f6f7f8;--paper:#fff;--ink:#0f1113;--muted:#4b5563;--line:#d5dbe3;--line-strong:#a9b3c2}
    @media (prefers-color-scheme:dark){html[data-theme="auto"]{--bg:#0c0d0f;--paper:#111316;--ink:#e9eef2;--muted:#9aa4b2;--line:#2a2f37;--line-strong:#3a414c;--c-silver:#555e6b}}
    *{box-sizing:border-box}
    html,body{height:100%}
    body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--font-sans);font-size:var(--fs-3);line-height:1.62;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;padding-bottom:var(--space-12)}
    img,svg,video{max-width:100%;height:auto;display:block}
    .container{max-width:var(--container);margin:0 auto;padding:0 var(--space-4)}
    h1{font-size:var(--fs-h1);line-height:1.05;margin:var(--space-6) 0 var(--space-4)}
    h2{font-size:1.5rem;margin:var(--space-6) 0 var(--space-3)}
    h1,h2{font-weight:800;letter-spacing:.2px}
    p{margin:.85rem 0}
    a{color:var(--c-blue);text-decoration:underline;text-decoration-thickness:.08em;text-underline-offset:2px}
    a:hover{text-decoration:underline}
    td a{word-break:break-word;overflow-wrap:anywhere}
    small,.small{font-size:var(--fs-1);color:var(--muted)}
    .muted{color:var(--muted)}
    /* Vistas */
    .desktop-only{display:block}
    .mobile-only{display:none}
    /* Tabla desktop sin sliders */
    .table-wrap{width:100%;overflow-x:visible;margin-bottom:var(--space-6)}
    table{width:100%;border-collapse:collapse;font-variant-numeric:tabular-nums}
    thead th{white-space:normal;word-break:keep-all;overflow-wrap:anywhere}
    .status-table thead th:nth-child(2){white-space:nowrap;word-break:keep-all;hyphens:none}
    .status-table{font-size:.9375rem}
    /* Mantener celdas clave en 1 línea */
    .status-table tbody td:nth-child(1), /* Servicio */
    .status-table tbody td:nth-child(3), /* Estado */
    .status-table tbody td:nth-child(8), /* URL */
    .status-table tbody td:nth-child(9)  /* Git */{white-space:nowrap}
    .status-table tbody td:nth-child(8) a{white-space:nowrap;word-break:normal;overflow-wrap:normal}
    /* Estrechar columnas de checks */
    .status-table th:nth-child(4), .status-table td:nth-child(4),
    .status-table th:nth-child(5), .status-table td:nth-child(5),
    .status-table th:nth-child(6), .status-table td:nth-child(6),
    .status-table th:nth-child(7), .status-table td:nth-child(7){width:120px}
    th,td{border:1px solid var(--line);padding:.6rem .75rem;vertical-align:top}
    thead th{background:#eef1f5;text-align:left;position:sticky;top:0;z-index:1}
    tr:nth-child(odd) td{background:#fff}
    tr:nth-child(even) td{background:#f9fafb}
    @media (prefers-color-scheme:dark){thead th{background:#14171c} tr:nth-child(even) td{background:#0f1113} tr:nth-child(odd) td{background:transparent}}
    html[data-theme="light"] thead th{background:#eef1f5}
    html[data-theme="light"] tr:nth-child(odd) td{background:#fff}
    html[data-theme="light"] tr:nth-child(even) td{background:#f9fafb}
    html[data-theme="dark"] thead th{background:#14171c}
    html[data-theme="dark"] tr:nth-child(even) td{background:#0f1113}
    html[data-theme="dark"] tr:nth-child(odd) td{background:transparent}
    .topbar{border-bottom:1px solid var(--line);padding:calc(var(--space-12) + .5rem) 0 var(--space-5)}
    main.container{padding-bottom: var(--space-12)}
    .brand-title{font-size:clamp(2rem,5vw,3rem);font-weight:900;line-height:1.03}
    .brand-sep{display:flex;gap:6px;margin:.5rem 0}
    .brand-sep .sw{width:42px;height:10px;border:1px solid var(--line)}
    .brand-sub{font-size:1.05rem;font-weight:700;color:var(--muted)}
    .nav{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:var(--space-3)}
    .nav #themeToggle{margin-left:auto}
    .svc-summary{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}
    .svc-summary .svc-break{flex-basis:100%;height:0}
    .tab{padding:.35rem .6rem;border:1px solid var(--line-strong);text-decoration:none;color:inherit;border-radius:var(--radius);background:var(--paper);font-weight:600;font-size:.95rem}
    .routebar{margin:var(--space-3) 0 var(--space-6);background:var(--paper);border:1px solid var(--line-strong);padding:.5rem .75rem;display:flex;flex-wrap:wrap;gap:.5rem}
    .routebar .domain{font-weight:800}
    .routebar .sep{color:var(--muted)}
    .pill{display:inline-block;padding:.15rem .5rem;border:1px solid var(--line-strong);background:var(--paper);font-weight:600}
    .pill--ok{color:var(--c-green);border-color:var(--c-green)}
    .pill--err{color:var(--c-red);border-color:var(--c-red)}
    .dot{width:12px;height:12px;border-radius:999px;display:inline-block;border:1px solid var(--line);vertical-align:middle;margin-right:.35rem}
    .dot.ok{background:var(--c-green)}
    .dot.err{background:var(--c-red)}
    /* Móvil: usar lista expandible y ocultar tabla */
    details.svc{margin:0 0 var(--space-4);border-top:1px solid var(--line);padding-top:.25rem}
    .svc-summary{display:flex;gap:.5rem;align-items:center}
    .svc-summary .svc-url{margin-left:auto}
    .svc-body{padding:.5rem 0 0 .25rem}
    @media (max-width: 768px){
      body{font-size:0.9375rem}
      .container{padding:0 var(--space-4)}
      th,td{padding:.5rem .5rem}
      .tab{font-size:.875rem}
      .desktop-only{display:none}
      .mobile-only{display:block}
      #mobileList{margin:var(--space-4) 0 var(--space-6)}
      .brand-title{padding-top: var(--space-4)}
    }
