:root{--bg:#0f1224;--panel:#3f2e64;--card:#1b2142;--line:#2a2f52;--text:#e9ecf5;--muted:#aab2c7;--accent:#3f2e64}
*{box-sizing:border-box}
body{margin:0;font-family:system-ui,Segoe UI,Roboto,Arial,sans-serif;background:var(--bg);color:var(--text);line-height:1.5}

/* Layout plein écran */
html,body{height:100%}
body{min-height:100vh;display:flex;flex-direction:column}
header{padding:14px 16px;background:var(--panel);border-bottom:1px solid var(--line)}
h1{margin:0;font-size:18px}
main{flex:1;min-height:0;display:flex;flex-direction:column;max-width:1200px;margin:0 auto;padding:12px}

/* Switch d’affichage global */
.layout-switch{display:flex;gap:8px;flex-wrap:wrap;margin:0 0 10px}
.layout-switch button{padding:6px 10px;border:1px solid var(--line);background:#1b2142;color:var(--text);border-radius:8px;cursor:pointer}
.layout-switch button.active{background:var(--accent);border-color:var(--accent)}

/* Tabs icône seule sauf actif */
.tabs{display:flex;gap:8px;overflow:auto;padding-bottom:8px;border-bottom:1px solid var(--line);flex-wrap:nowrap}
.tab{padding:8px 12px;border:1px solid var(--line);border-radius:10px;background:#1b2142;color:var(--text);cursor:pointer;white-space:nowrap;display:inline-flex;align-items:center;gap:6px}
.tab .t{display:none}
.tab.active .t{display:inline}
.tab.active{background:var(--accent);color:#fff;border-color:var(--accent)}

/* Panels + iframe */
.panel{display:none;flex:1;min-height:0;margin-top:12px;background:var(--panel);border:1px solid var(--line);border-radius:12px;position:relative}
.panel.active{display:flex}
.panel .inner{flex:1;min-height:0;overflow:auto;padding:12px}
.loader{position:absolute;inset:0;display:grid;place-items:center;font-size:13px;color:var(--muted)}
iframe.live{display:block;width:100%;height:100%;border:0;background:#0c1130}
@media (max-width:720px){iframe.live{height:72vh}}

/* Liens neutres */
a{color:inherit;text-decoration:none}
a:visited{color:inherit}
a:hover{text-decoration:underline}

/* Code lisible dans contenus externes éventuels */
pre,code{line-height:1.6;padding:6px 8px;display:block;white-space:pre-wrap;word-wrap:break-word}
.card pre{margin:6px 0}
.card{overflow:hidden}

/* Modes d’affichage appliqués à tout le site via body[data-view] */
body[data-view="block"] .inner .grid{display:grid;gap:14px}
body[data-view="line"]  .inner .grid{display:flex;flex-direction:column;gap:10px}
body[data-view="grid"]  .inner .grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
