/* ============================================================
   NETDECK — start page · Cyberpunk 2077  (v2 — deep redesign)
   ============================================================ */
:root{
  --bg:#04050a; --panel:rgba(8,11,17,.74); --panel2:rgba(10,14,21,.9);
  --line:#1b3a52; --line2:#22304a;
  --yellow:#fcee0a; --cyan:#05d9e8; --pink:#ff2a6d; --red:#ff003c; --green:#27ff9e; --purple:#b14aed;
  --txt:#eaf2f8; --muted:#8aa0b4; --dim:#46586d;
  --gy:rgba(252,238,10,.6); --gc:rgba(5,217,232,.55); --gp:rgba(255,42,109,.5);
  --mono:'JetBrains Mono','Share Tech Mono',ui-monospace,Consolas,monospace;
  --tech:'Rajdhani',var(--mono);
  --disp:'Orbitron',var(--tech);
  --clip:polygon(0 0, calc(100% - 14px) 0, 100% 14px, 100% 100%, 14px 100%, 0 calc(100% - 14px));
  --clip-l:polygon(0 0, 100% 0, 100% calc(100% - 14px), calc(100% - 14px) 100%, 0 100%);
}
*{box-sizing:border-box}
html,body{margin:0;min-height:100%}
body{background:var(--bg);color:var(--txt);font-family:var(--mono);font-size:14px;
  -webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3{margin:0}
button{font-family:var(--mono);cursor:pointer;color:inherit}
input{font-family:var(--mono)}
a{color:var(--cyan);text-decoration:none}
::selection{background:var(--yellow);color:#000}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{background:#070b11}
::-webkit-scrollbar-thumb{background:#1d3650;border:1px solid #0a0e16}
::-webkit-scrollbar-thumb:hover{background:var(--cyan)}
.ico{width:1.1em;height:1.1em;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex:none;vertical-align:-.18em}

/* ===== FONDO (wallpaper + overlays) ===== */
.bg{position:fixed;inset:0;z-index:0;overflow:hidden;background:#04050a}
.bg-img{position:absolute;inset:-2%;background-size:cover;background-position:center;opacity:0;
  transition:opacity 1.1s ease;will-change:transform,opacity;animation:kenburns 38s ease-in-out infinite alternate}
.bg-img.show{opacity:1}
@keyframes kenburns{from{transform:scale(1.02) translate(0,0)}to{transform:scale(1.1) translate(-1.5%,-1%)}}
.bg-grade{position:absolute;inset:0;background:
  linear-gradient(180deg, rgba(4,5,10,.55) 0%, rgba(4,5,10,.12) 30%, rgba(4,5,10,.55) 78%, rgba(4,5,10,.92) 100%),
  radial-gradient(120% 80% at 80% 0%, rgba(255,42,109,.14), transparent 55%),
  radial-gradient(90% 70% at 0% 100%, rgba(252,238,10,.10), transparent 55%),
  radial-gradient(80% 60% at 50% 50%, transparent 40%, rgba(4,5,10,.5) 100%)}
.fx-scan{position:fixed;inset:0;z-index:2;pointer-events:none;
  background:repeating-linear-gradient(0deg,rgba(0,0,0,.16) 0 1px,transparent 1px 3px);opacity:.4;mix-blend-mode:multiply}
.fx-grain{position:fixed;inset:0;z-index:2;pointer-events:none;opacity:.05;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  animation:grain .4s steps(2) infinite}
@keyframes grain{to{transform:translate(-6px,4px)}}
.fx-sweep{position:fixed;left:0;right:0;height:140px;z-index:2;pointer-events:none;top:-160px;
  background:linear-gradient(180deg,transparent,rgba(5,217,232,.10),rgba(252,238,10,.05),transparent);
  animation:sweep 9s linear infinite}
@keyframes sweep{0%{top:-160px}100%{top:100%}}
.fx-vig{position:fixed;inset:0;z-index:2;pointer-events:none;
  background:radial-gradient(ellipse 130% 100% at 50% 40%,transparent 55%,rgba(0,0,0,.7) 100%)}
.fx-flicker{position:fixed;inset:0;z-index:2;pointer-events:none;background:rgba(5,217,232,.018);animation:flick 7s steps(1) infinite}
@keyframes flick{0%,96%,100%{opacity:0}97%{opacity:1}98%{opacity:0}99%{opacity:.6}}

/* esquinas HUD */
.hud-corners i{position:fixed;width:34px;height:34px;z-index:3;pointer-events:none;border:2px solid var(--yellow);opacity:.5;filter:drop-shadow(0 0 6px var(--gy))}
.hud-corners .tl{top:10px;left:10px;border-right:0;border-bottom:0}
.hud-corners .tr{top:10px;right:10px;border-left:0;border-bottom:0}
.hud-corners .bl{bottom:10px;left:10px;border-right:0;border-top:0}
.hud-corners .br{bottom:10px;right:10px;border-left:0;border-top:0}

/* glitch */
.glitch{position:relative;text-shadow:0 0 12px var(--gy)}
.glitch::before,.glitch::after{content:attr(data-text);position:absolute;left:0;top:0;width:100%;overflow:hidden;text-shadow:none}
.glitch::before{color:var(--cyan);animation:gl1 4.2s infinite linear alternate}
.glitch::after{color:var(--pink);animation:gl2 3.3s infinite linear alternate}
@keyframes gl1{0%,92%,100%{clip-path:inset(0 0 100% 0);transform:translate(0)}93%{clip-path:inset(0 0 60% 0);transform:translate(-2px,-1px)}97%{clip-path:inset(45% 0 25% 0);transform:translate(2px,1px)}}
@keyframes gl2{0%,90%,100%{clip-path:inset(100% 0 0 0);transform:translate(0)}94%{clip-path:inset(25% 0 55% 0);transform:translate(2px,0)}98%{clip-path:inset(65% 0 10% 0);transform:translate(-2px,1px)}}

/* ===== TOP HUD ===== */
.top{position:relative;z-index:10;display:flex;align-items:center;gap:16px;padding:16px 24px}
.logo{font-family:var(--disp);font-weight:900;font-size:23px;color:var(--yellow);display:flex;align-items:center;gap:8px;letter-spacing:.06em}
.logo i{color:var(--cyan);font-style:normal;font-family:var(--mono);font-weight:400}
.logo .loc{color:var(--cyan);font-size:12px;font-family:var(--mono);opacity:.85;letter-spacing:.02em}
.sys{display:flex;align-items:center;gap:10px;font-size:12px;color:var(--muted);
  background:rgba(6,10,16,.5);border:1px solid var(--line2);padding:5px 12px;clip-path:var(--clip);backdrop-filter:blur(6px)}
.sys-clock{color:var(--cyan);font-weight:600;letter-spacing:.06em}
.sys-ping{color:var(--green)}
.top-right{margin-left:auto;display:flex;align-items:center;gap:9px}
.chip{position:relative;display:flex;align-items:center;gap:8px;background:linear-gradient(135deg,rgba(17,22,31,.82),rgba(8,11,17,.82));
  border:1px solid var(--line);color:var(--txt);font-size:12.5px;padding:9px 13px;clip-path:var(--clip);
  transition:.16s;backdrop-filter:blur(8px)}
.chip::before{content:"";position:absolute;top:0;left:10px;right:10px;height:2px;background:var(--cyan);transform:scaleX(0);transform-origin:left;transition:.2s;box-shadow:0 0 8px var(--gc)}
.chip:hover{border-color:var(--cyan);box-shadow:0 0 16px -4px var(--gc),inset 0 0 20px -14px var(--cyan)}
.chip:hover::before{transform:scaleX(1)}
.chip.icon{padding:9px;clip-path:none;border-radius:4px}
.chip.icon::before{display:none}
.chip.weather b{color:var(--cyan)} .chip.weather .ico{color:var(--yellow)} .chip.weather span{color:var(--muted)}
.chip.profile{padding:6px 8px 6px 6px;border-color:var(--yellow)}
.chip.profile::before{background:var(--yellow);box-shadow:0 0 8px var(--gy)}
.chip.profile:hover{box-shadow:0 0 16px -4px var(--gy)}
.avatar{width:26px;height:26px;border-radius:3px;background:#0a1018;display:grid;place-items:center;color:var(--yellow);overflow:hidden;flex:none}
.avatar img{width:100%;height:100%;object-fit:cover}
.avatar.big{width:46px;height:46px}
.chip.profile .me{font-size:9px;font-weight:700;color:#05060a;background:var(--yellow);padding:2px 5px;letter-spacing:.1em}

/* ===== DECK ===== */
.deck{position:relative;z-index:5;max-width:1120px;margin:0 auto;padding:26px 24px 6px}

/* buscador */
.searchbar{position:relative;display:flex;align-items:center;gap:13px;height:60px;padding:0 8px 0 0;
  background:linear-gradient(135deg,rgba(10,14,22,.82),rgba(7,10,16,.82));border:1px solid var(--line);
  clip-path:var(--clip);box-shadow:0 18px 60px -24px #000, inset 0 0 30px -22px var(--cyan);
  transition:.18s;backdrop-filter:blur(12px);overflow:hidden}
.searchbar:focus-within{border-color:var(--yellow);box-shadow:0 0 30px -6px var(--gy), inset 0 0 30px -20px var(--yellow)}
.sb-tag{align-self:stretch;display:flex;align-items:center;padding:0 14px;font-family:var(--disp);font-weight:700;font-size:12px;
  letter-spacing:.12em;color:#05060a;background:var(--yellow);clip-path:polygon(0 0,100% 0,calc(100% - 13px) 100%,0 100%)}
.searchbar .g{width:23px;height:23px;flex:none}
.searchbar input{flex:1;background:transparent;border:0;outline:none;color:var(--txt);font-size:16px;height:100%;letter-spacing:.01em}
.searchbar input::placeholder{color:var(--dim)}
.searchbar .caret{width:9px;height:20px;background:var(--cyan);box-shadow:0 0 10px var(--gc);animation:blink 1.1s steps(1) infinite;margin-left:-8px}
.searchbar:focus-within .caret{display:none}
@keyframes blink{50%{opacity:0}}
.searchbar .go{background:var(--yellow);color:#05060a;border:0;width:46px;height:44px;display:grid;place-items:center;
  clip-path:polygon(0 0,100% 0,100% 100%,11px 100%,0 calc(100% - 11px));transition:.15s}
.searchbar .go:hover{box-shadow:0 0 18px var(--gy);filter:brightness(1.1)}
.sb-scan{position:absolute;left:0;bottom:0;height:2px;width:40%;background:linear-gradient(90deg,transparent,var(--cyan),transparent);animation:sbscan 3.5s linear infinite}
@keyframes sbscan{0%{left:-40%}100%{left:100%}}

/* ticker */
.ticker{display:flex;align-items:center;gap:0;margin-top:14px;border:1px solid var(--line2);
  background:rgba(6,10,16,.6);clip-path:var(--clip);backdrop-filter:blur(6px);overflow:hidden;height:34px}
.ticker-lbl{flex:none;align-self:stretch;display:flex;align-items:center;padding:0 12px;font-family:var(--disp);font-weight:700;
  font-size:11px;letter-spacing:.18em;color:#05060a;background:var(--pink);box-shadow:0 0 14px var(--gp)}
.ticker-vp{flex:1;overflow:hidden;position:relative;height:100%}
.ticker-track{position:absolute;top:0;left:0;height:100%;display:flex;align-items:center;gap:34px;white-space:nowrap;
  font-size:12px;color:var(--muted);animation:tick 60s linear infinite;padding-left:100%}
.ticker:hover .ticker-track{animation-play-state:paused}
.ticker-track b{color:var(--cyan);margin-right:8px}
.ticker-track a{color:var(--txt)}
.ticker-track .sep{color:var(--yellow);opacity:.7}
@keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* sub-headers */
.sub-h{display:flex;align-items:center;gap:11px;margin:30px 2px 14px;color:var(--cyan);
  font-family:var(--disp);font-weight:700;font-size:13px;letter-spacing:.18em;text-transform:uppercase}
.sub-h i{flex:1;height:1px;background:linear-gradient(90deg,var(--line),transparent)}
.dot-acc{width:9px;height:9px;background:var(--cyan);box-shadow:0 0 10px var(--gc);transform:rotate(45deg)}
.dot-acc.c2{background:var(--yellow);box-shadow:0 0 10px var(--gy)}
.dot-acc.c3{background:var(--pink);box-shadow:0 0 10px var(--gp)}

/* speed dial */
.dial{display:grid;grid-template-columns:repeat(6,1fr);gap:16px}
.dial.small{grid-template-columns:repeat(8,1fr);gap:13px}
.tile{position:relative;display:flex;flex-direction:column;align-items:center;gap:9px;cursor:pointer;background:none;border:0;padding:0}
.tile .face{position:relative;width:100%;aspect-ratio:16/10;border:1px solid var(--line);clip-path:var(--clip);
  background:linear-gradient(150deg,rgba(18,26,38,.85),rgba(8,12,19,.92));display:grid;place-items:center;overflow:hidden;transition:.18s}
.dial.small .tile .face{aspect-ratio:16/11}
.tile .face::before{content:"";position:absolute;inset:0;background:linear-gradient(115deg,transparent 30%,rgba(5,217,232,.18) 48%,transparent 60%);
  transform:translateX(-120%);transition:transform .5s}
.tile:hover .face::before{transform:translateX(120%)}
.tile .face::after{content:"";position:absolute;top:6px;left:6px;width:13px;height:13px;border-top:2px solid var(--cyan);border-left:2px solid var(--cyan);opacity:0;transition:.16s}
.tile:hover .face{border-color:var(--cyan);transform:translateY(-3px);box-shadow:0 12px 26px -14px var(--gc),inset 0 0 24px -16px var(--cyan)}
.tile:hover .face::after{opacity:.8}
.tile .face img{width:48px;height:48px;object-fit:contain;filter:drop-shadow(0 2px 8px rgba(0,0,0,.7))}
.dial.small .tile .face img{width:34px;height:34px}
.tile .face .ltr{font-family:var(--disp);font-weight:900;font-size:30px;color:var(--yellow);text-shadow:0 0 14px var(--gy)}
.tile .lbl{font-size:11.5px;color:var(--txt);max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:.02em}
.tile .ops{position:absolute;top:6px;right:6px;display:flex;gap:4px;opacity:0;transition:.15s;z-index:2}
.tile:hover .ops{opacity:1}
.tile .ops button{background:rgba(0,0,0,.75);border:1px solid var(--line2);color:var(--cyan);padding:3px;display:grid;border-radius:3px}
.tile .ops button:hover{border-color:var(--cyan)}
.tile .ops button.del:hover{color:var(--pink);border-color:var(--pink)}
.tile.add .face{border-style:dashed;color:var(--dim)}
.tile.add:hover .face{color:var(--cyan)}
.tile.add .ico{width:30px;height:30px}

/* ===== NEWS ===== */
.news{position:relative;z-index:5;max-width:1120px;margin:6px auto 30px;padding:0 24px}
.cats{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:16px}
.cat{background:rgba(8,12,19,.6);border:1px solid var(--line2);color:var(--muted);font-size:11.5px;padding:6px 12px;
  clip-path:var(--clip);transition:.14s;text-transform:uppercase;letter-spacing:.04em;backdrop-filter:blur(4px)}
.cat:hover{color:var(--txt);border-color:var(--cyan)}
.cat.on{background:var(--yellow);border-color:var(--yellow);color:#05060a;font-weight:700;box-shadow:0 0 14px -4px var(--gy)}
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.ncard{position:relative;background:var(--panel);border:1px solid var(--line);clip-path:var(--clip);padding:15px;
  display:flex;flex-direction:column;gap:8px;transition:.16s;min-height:104px;backdrop-filter:blur(8px);overflow:hidden}
.ncard::after{content:"";position:absolute;top:7px;right:7px;width:12px;height:12px;border-top:2px solid var(--pink);border-right:2px solid var(--pink);opacity:0;transition:.16s}
.ncard:hover{border-color:var(--pink);box-shadow:0 12px 26px -14px var(--gp);transform:translateY(-2px)}
.ncard:hover::after{opacity:.8}
.ncard .src{font-size:10.5px;color:var(--pink);letter-spacing:.08em;text-transform:uppercase;font-weight:600}
.ncard .ttl{font-size:13px;color:var(--txt);line-height:1.42;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.ncard .when{font-size:10.5px;color:var(--dim);margin-top:auto}
.news-grid .empty{grid-column:1/-1;text-align:center;color:var(--muted);padding:24px;background:var(--panel);border:1px dashed var(--line2);clip-path:var(--clip)}

.foot{position:relative;z-index:5;text-align:center;color:var(--dim);font-size:11px;padding:14px;letter-spacing:.05em}
.foot a{color:var(--muted)}

/* ===== PANELES LATERALES ===== */
.gpanel,.wpanel{position:fixed;top:0;right:0;height:100%;width:370px;max-width:92vw;z-index:40;
  background:linear-gradient(180deg,rgba(8,11,18,.97),rgba(5,7,12,.98));border-left:1px solid var(--yellow);
  box-shadow:-24px 0 70px -22px #000;transform:translateX(102%);transition:transform .32s ease;
  display:flex;flex-direction:column;padding:16px;backdrop-filter:blur(12px)}
.gpanel.open,.wpanel.open{transform:translateX(0)}
.wpanel{border-left-color:var(--cyan)}
.gp-h{display:flex;align-items:center;gap:12px;padding-bottom:14px;border-bottom:1px solid var(--line)}
.gp-user{display:flex;align-items:center;gap:11px;flex:1;min-width:0}
.gp-user b{display:block;font-size:14px;color:var(--txt);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gp-user span{font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}
.gp-actions{padding:20px 0}
.hint{font-size:11px;color:var(--muted);margin:12px 0 0;text-align:center}
.gp-body{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:12px;padding-top:14px}
.gcard{background:var(--panel2);border:1px solid var(--line);clip-path:var(--clip);padding:12px}
.gc-h{display:flex;align-items:center;gap:8px;font-family:var(--disp);font-size:14px;color:var(--cyan);margin-bottom:9px;letter-spacing:.05em;font-weight:700}
.gc-h .badge{background:var(--pink);color:#fff;font-size:10px;padding:1px 7px;border-radius:10px;font-family:var(--mono)}
.gc-h .open{margin-left:auto;color:var(--muted)} .gc-h .open:hover{color:var(--cyan)}
.gc-list{display:flex;flex-direction:column;gap:6px}
.gc-item{display:block;padding:7px 9px;background:rgba(10,15,23,.7);border-left:2px solid var(--line2);font-size:11.5px;color:var(--txt);transition:.12s}
.gc-item:hover{border-left-color:var(--cyan);background:rgba(12,18,28,.9)}
.gc-item .m1{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gc-item .m2{font-size:10px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gc-item .tm{color:var(--yellow)}
.gc-empty{font-size:11px;color:var(--dim);padding:6px 2px}

/* wallpaper panel */
.wp-toggle{display:flex;align-items:center;gap:9px;margin:14px 0;font-size:12.5px;color:var(--txt);cursor:pointer;user-select:none}
.wp-toggle input{display:none}
.wp-toggle span{width:38px;height:20px;background:#0a0f17;border:1px solid var(--line);border-radius:11px;position:relative;transition:.18s;flex:none}
.wp-toggle span::after{content:"";position:absolute;top:2px;left:2px;width:14px;height:14px;background:var(--muted);border-radius:50%;transition:.18s}
.wp-toggle input:checked + span{border-color:var(--cyan);box-shadow:0 0 12px -3px var(--gc)}
.wp-toggle input:checked + span::after{left:20px;background:var(--cyan)}
.wp-grid{flex:1;overflow-y:auto;display:grid;grid-template-columns:1fr 1fr;gap:10px;padding-top:4px;align-content:start}
.wp-thumb{position:relative;aspect-ratio:16/9;border:1px solid var(--line);clip-path:var(--clip);overflow:hidden;cursor:pointer;transition:.16s;background:#0a0e16 center/cover}
.wp-thumb:hover{border-color:var(--cyan);transform:translateY(-2px)}
.wp-thumb.on{border-color:var(--yellow);box-shadow:0 0 16px -4px var(--gy)}
.wp-thumb .nm{position:absolute;left:0;right:0;bottom:0;font-size:10px;color:#fff;background:linear-gradient(0deg,rgba(0,0,0,.85),transparent);padding:12px 7px 5px;letter-spacing:.03em}
.wp-thumb.on .nm{color:var(--yellow)}
.wp-custom{padding-top:12px;border-top:1px solid var(--line)}
.wp-custom label{display:block;font-size:11px;color:var(--cyan);text-transform:uppercase;letter-spacing:.06em;margin-bottom:7px}
.wp-custom input{flex:1;background:#0a1018;border:1px solid var(--line);color:var(--txt);font-family:var(--mono);font-size:12px;padding:9px;outline:none}
.wp-custom input:focus{border-color:var(--cyan)}

.scrim{position:fixed;inset:0;z-index:35;background:rgba(2,4,8,.6);backdrop-filter:blur(3px);opacity:0;pointer-events:none;transition:.3s}
.scrim.on{opacity:1;pointer-events:auto}

/* botones / modal */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid var(--line);
  background:rgba(11,18,28,.8);color:var(--txt);font-size:12px;padding:10px 14px;clip-path:var(--clip);transition:.15s;
  text-transform:uppercase;letter-spacing:.05em}
.btn:hover{border-color:var(--cyan);box-shadow:0 0 14px -4px var(--gc)}
.btn.block{width:100%}
.btn-primary{background:var(--yellow);color:#05060a;border-color:var(--yellow);font-weight:700}
.btn-primary:hover{box-shadow:0 0 20px -2px var(--gy)}
.row2{display:flex;gap:10px} .row2 .btn{flex:1} .row2 input{flex:1}
.overlay{position:fixed;inset:0;z-index:60;display:none;align-items:center;justify-content:center;background:rgba(2,4,8,.8);backdrop-filter:blur(5px);padding:20px}
.overlay.open{display:flex}
.modal-box{width:min(560px,94vw);background:rgba(10,14,22,.97);border:1px solid var(--cyan);clip-path:var(--clip);box-shadow:0 0 50px -10px var(--gc);max-height:88vh;overflow:auto}
.modal-h{display:flex;align-items:center;padding:14px 18px;border-bottom:1px solid var(--line);font-family:var(--disp);font-size:18px;color:var(--yellow);text-transform:uppercase;letter-spacing:.06em;font-weight:700}
.modal-h button{margin-left:auto}
.modal-body{padding:18px}
.modal-body p{color:var(--muted);font-size:12.5px;margin:0 0 12px}
.modal-body label{display:block;font-size:11px;color:var(--cyan);text-transform:uppercase;letter-spacing:.08em;margin:10px 0 6px}
.modal-body input{width:100%;background:#0a1018;border:1px solid var(--line);color:var(--txt);font-family:var(--mono);font-size:13px;padding:10px;outline:none;margin-bottom:6px}
.modal-body input:focus{border-color:var(--cyan)}
.modal-body code{color:var(--yellow);background:#0a1018;padding:1px 5px;font-size:11px;word-break:break-all}
.modal-body ol{color:var(--muted);font-size:12px;padding-left:18px;line-height:1.7}

/* toasts */
.toasts{position:fixed;bottom:22px;left:50%;transform:translateX(-50%);z-index:70;display:flex;flex-direction:column;gap:10px;align-items:center}
.toast{background:rgba(10,15,24,.95);border:1px solid var(--cyan);border-left:3px solid var(--cyan);color:var(--txt);padding:11px 16px;font-size:12.5px;clip-path:var(--clip);box-shadow:0 0 20px -8px var(--gc);animation:slidein .3s ease}
.toast.err{border-color:var(--pink);border-left-color:var(--pink)} .toast.ok{border-color:var(--green);border-left-color:var(--green)}
@keyframes slidein{from{transform:translateY(14px);opacity:0}}

/* ===== BOOT ===== */
#boot{position:fixed;inset:0;z-index:200;background:#04050a;display:flex;flex-direction:column;align-items:center;justify-content:center;
  transition:opacity .55s ease;overflow:hidden}
#boot.done{opacity:0;pointer-events:none}
.boot-grid{position:absolute;inset:0;opacity:.25;
  background-image:linear-gradient(var(--line2) 1px,transparent 1px),linear-gradient(90deg,var(--line2) 1px,transparent 1px);
  background-size:44px 44px;-webkit-mask-image:radial-gradient(ellipse 60% 60% at 50% 50%,#000,transparent 80%);mask-image:radial-gradient(ellipse 60% 60% at 50% 50%,#000,transparent 80%)}
.boot-inner{position:relative;z-index:1;width:min(520px,88vw);text-align:center}
.boot-logo{font-family:var(--disp);font-weight:900;font-size:clamp(40px,9vw,76px);color:var(--yellow);letter-spacing:.08em}
.boot-sub{color:var(--cyan);font-size:12px;letter-spacing:.28em;margin:6px 0 22px;text-transform:uppercase}
#bootlog{text-align:left;font-size:12px;color:var(--muted);min-height:120px;margin:0 auto;max-width:440px;white-space:pre-wrap;line-height:1.7}
#bootlog .ok{color:var(--green)} #bootlog .hl{color:var(--cyan)}
.boot-bar{width:min(440px,86vw);height:8px;background:#0a0e16;border:1px solid var(--line);margin:14px auto 8px;clip-path:polygon(0 0,100% 0,calc(100% - 6px) 100%,0 100%)}
.boot-bar i{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--cyan),var(--yellow));box-shadow:0 0 14px var(--gy);transition:width .2s}
.boot-status{font-family:var(--disp);font-weight:700;letter-spacing:.2em;color:var(--yellow);font-size:14px}
.boot-skip{position:absolute;bottom:22px;right:26px;color:var(--dim);font-size:11px;z-index:1;cursor:pointer}

/* responsive */
@media (prefers-reduced-motion:reduce){.glitch::before,.glitch::after,.fx-grain,.fx-sweep,.fx-flicker,.bg-img,.sb-scan,.ticker-track{animation:none!important}.bg-img{opacity:1}.bg-img.layB{display:none}}
@media (max-width:1000px){ .dial{grid-template-columns:repeat(4,1fr)} .dial.small{grid-template-columns:repeat(5,1fr)} .news-grid{grid-template-columns:repeat(2,1fr)} .sys{display:none} }
@media (max-width:640px){
  .dial{grid-template-columns:repeat(3,1fr)} .dial.small{grid-template-columns:repeat(4,1fr)}
  .news-grid{grid-template-columns:1fr}
  .logo .loc{display:none} .chip.weather span{display:none}
  .wp-grid{grid-template-columns:1fr 1fr}
  .deck{padding-top:14px}
}
