/* ============================================================
   AFTER HOURS ARCADE — Desktop Shell
   Simulated retro KDE Plasma: login -> desktop -> Firefox -> flyer.
   Pure HTML/CSS/JS. This is the Electron entry page.
   ============================================================ */

:root{
  --kde-blue:    #3c7fb8;   /* plasma accent */
  --kde-blue-d:  #2b5c87;
  --kde-blue-l:  #5b9fd6;
  --panel-bg:    #2b3038;   /* dark steel panel */
  --panel-bg-2:  #20242b;
  --panel-line:  #11141a;
  --win-bg:      #e9eaec;
  --win-chrome:  #d3d6db;
  --win-chrome-2:#c2c6cd;
  --win-line:    #9aa0a8;
  --txt:         #1c2026;
  --txt-dim:     #5c636d;
  --shadow:      rgba(0,0,0,.45);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;height:100%;overflow:hidden;background:#0a0c10}
body{
  font-family:'Segoe UI','DejaVu Sans','Noto Sans',system-ui,sans-serif;
  color:var(--txt);-webkit-font-smoothing:antialiased;user-select:none;
}
.hidden{display:none !important}
button{font-family:inherit}

/* ============================================================
   1) LOGIN SCREEN (SDDM / KDE greeter look)
   ============================================================ */
#login{
  position:fixed;inset:0;z-index:100;
  background:
    radial-gradient(1200px 700px at 50% 18%, rgba(91,159,214,.30), transparent 60%),
    linear-gradient(160deg,#1b2330 0%,#0d1119 70%);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  transition:opacity .6s ease;
}
#login.fade-out{opacity:0;pointer-events:none}
.greeter-clock{position:absolute;top:48px;left:0;right:0;text-align:center;color:#dce6f2}
.greeter-clock .gc-time{font-size:64px;font-weight:200;letter-spacing:.02em;text-shadow:0 2px 12px rgba(0,0,0,.5)}
.greeter-clock .gc-date{font-size:17px;color:#9fb4cd;margin-top:4px;font-weight:300}

.login-card{
  width:340px;text-align:center;color:#eef4fb;
  display:flex;flex-direction:column;align-items:center;gap:14px;
}
.avatar{
  width:104px;height:104px;border-radius:50%;background:#11151c;
  border:3px solid rgba(255,255,255,.28);box-shadow:0 8px 26px var(--shadow);
  display:grid;place-items:center;overflow:hidden;
}
.avatar img{width:76px;height:76px;object-fit:contain}
.login-user{font-size:21px;font-weight:400;letter-spacing:.01em}
.login-host{font-size:12px;color:#8fa6c2;letter-spacing:.12em;text-transform:uppercase;margin-top:-8px}
.login-fields{width:100%;display:flex;flex-direction:column;gap:10px;margin-top:6px}
.login-fields input{
  width:100%;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.22);
  border-radius:6px;padding:11px 14px;color:#fff;font-size:15px;outline:none;
  transition:border-color .15s,background .15s;
}
.login-fields input::placeholder{color:#9fb0c6}
.login-fields input:focus{border-color:var(--kde-blue-l);background:rgba(255,255,255,.16)}
.login-row{display:flex;gap:8px;align-items:stretch}
.login-row input{flex:1}
.login-go{
  background:var(--kde-blue);border:1px solid var(--kde-blue-d);border-radius:6px;
  color:#fff;font-size:17px;width:46px;cursor:pointer;transition:background .15s;
}
.login-go:hover{background:var(--kde-blue-l)}
.login-err{color:#ff8d8d;font-size:13px;min-height:18px;letter-spacing:.02em}
.login-hint{font-size:12px;color:#7e93ad;line-height:1.5;margin-top:4px}
.login-hint b{color:#aebfd4;font-weight:600}
.greeter-foot{position:absolute;bottom:18px;left:0;right:0;display:flex;justify-content:space-between;
  align-items:center;padding:0 22px;color:#7488a1;font-size:12px}
.greeter-foot .gf-actions{display:flex;gap:18px}
.greeter-foot .gf-actions span{cursor:default;opacity:.85}

/* ============================================================
   2) DESKTOP (Plasma wallpaper + icons + panel)
   ============================================================ */
#desktop{
  position:fixed;inset:0;z-index:10;
  background:#10243a center/cover no-repeat;
  display:none;opacity:0;transition:opacity .6s ease;
}
#desktop.show{display:block;opacity:1}

/* desktop icons */
.desk-icons{position:absolute;top:18px;left:14px;display:flex;flex-direction:column;gap:6px}
.desk-icon{
  width:92px;padding:9px 6px 7px;border-radius:8px;text-align:center;cursor:pointer;
  border:1px solid transparent;transition:background .12s,border-color .12s;
}
.desk-icon:hover{background:rgba(120,170,225,.20);border-color:rgba(150,195,240,.35)}
.desk-icon .di-glyph{
  width:50px;height:50px;margin:0 auto 6px;border-radius:12px;display:grid;place-items:center;
  font-size:28px;box-shadow:0 3px 8px rgba(0,0,0,.35);
}
.di-glyph.firefox{background:radial-gradient(circle at 35% 30%,#ffb84d,#e25c1e 70%);}
.di-glyph.folder{background:linear-gradient(180deg,#7bb1e0,#3c7fb8)}
.di-glyph.trash{background:linear-gradient(180deg,#9aa0a8,#6b7178)}
.di-glyph.term{background:linear-gradient(180deg,#2b3038,#11141a);color:#5fe06f;font-family:'VT323',monospace;font-size:30px}
.desk-icon .di-label{
  font-size:12px;color:#fff;line-height:1.25;
  text-shadow:0 1px 3px rgba(0,0,0,.9),0 0 6px rgba(0,0,0,.6);
}

/* panel / taskbar */
.panel{
  position:absolute;left:0;right:0;bottom:0;height:42px;z-index:50;
  background:linear-gradient(180deg,var(--panel-bg) 0%,var(--panel-bg-2) 100%);
  border-top:1px solid rgba(255,255,255,.08);box-shadow:0 -2px 10px rgba(0,0,0,.4);
  display:flex;align-items:center;padding:0 6px;gap:6px;
}
.kmenu{
  display:flex;align-items:center;gap:7px;height:32px;padding:0 12px 0 8px;border-radius:6px;
  cursor:pointer;color:#dfe6ee;font-size:13px;font-weight:600;letter-spacing:.02em;
  background:linear-gradient(180deg,rgba(91,159,214,.32),rgba(60,127,184,.20));
  border:1px solid rgba(120,175,225,.3);transition:filter .12s;
}
.kmenu:hover{filter:brightness(1.18)}
.kmenu img{width:20px;height:20px;object-fit:contain}
.panel-tasks{flex:1;display:flex;align-items:center;gap:5px;padding:0 6px;height:100%}
.task-btn{
  display:flex;align-items:center;gap:7px;height:30px;padding:0 12px;border-radius:5px;cursor:pointer;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.07);color:#cfd6df;font-size:12.5px;
  max-width:230px;overflow:hidden;white-space:nowrap;transition:background .12s;
}
.task-btn:hover{background:rgba(255,255,255,.12)}
.task-btn.active{background:linear-gradient(180deg,rgba(91,159,214,.35),rgba(60,127,184,.22));border-color:rgba(120,175,225,.4);color:#fff}
.task-btn .tb-ico{width:16px;height:16px;display:grid;place-items:center;font-size:13px}
.systray{display:flex;align-items:center;gap:12px;padding:0 12px;color:#aeb8c4;font-size:12px}
.systray .tray-ico{opacity:.8;font-size:14px}
.panel-clock{
  color:#e8eef5;font-size:12.5px;text-align:right;line-height:1.15;padding:0 12px 0 8px;
  border-left:1px solid rgba(255,255,255,.08);min-width:78px;
}
.panel-clock .pc-date{font-size:10.5px;color:#9aa6b4}

/* kicker / start menu popup */
.kicker{
  position:absolute;left:6px;bottom:48px;width:300px;z-index:60;
  background:linear-gradient(180deg,#30353d,#23272e);border:1px solid var(--panel-line);
  border-radius:8px;box-shadow:0 14px 40px rgba(0,0,0,.6);overflow:hidden;
  transform-origin:bottom left;animation:kickin .14s ease;
}
@keyframes kickin{from{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:none}}
.kicker-head{display:flex;align-items:center;gap:10px;padding:12px 14px;background:rgba(0,0,0,.2);border-bottom:1px solid rgba(255,255,255,.06)}
.kicker-head img{width:34px;height:34px;border-radius:50%;background:#11151c;padding:3px}
.kicker-head .kh-name{color:#eef4fb;font-size:14px;font-weight:600}
.kicker-head .kh-host{color:#8b9bb0;font-size:11px;letter-spacing:.08em}
.kicker-list{padding:6px}
.kicker-item{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:6px;cursor:pointer;color:#d7dee7;font-size:13.5px}
.kicker-item:hover{background:var(--kde-blue)}
.kicker-item .ki-ico{width:26px;height:26px;border-radius:6px;display:grid;place-items:center;font-size:15px}
.kicker-foot{border-top:1px solid rgba(255,255,255,.06);padding:6px}
.kicker-foot .kicker-item{color:#f3b6b6}
.kicker-foot .kicker-item:hover{background:#a23a3a}

/* ============================================================
   3) WINDOWS (generic draggable window + Firefox)
   ============================================================ */
.window{
  position:absolute;background:var(--win-bg);border:1px solid var(--win-line);
  border-radius:8px 8px 6px 6px;box-shadow:0 20px 60px var(--shadow),0 0 0 1px rgba(0,0,0,.2);
  display:flex;flex-direction:column;overflow:hidden;z-index:40;
  animation:winopen .18s cubic-bezier(.2,.7,.3,1);min-width:420px;min-height:300px;
}
@keyframes winopen{from{opacity:0;transform:scale(.97) translateY(10px)}to{opacity:1;transform:none}}
.window.max{border-radius:0}
.titlebar{
  height:34px;display:flex;align-items:center;gap:8px;padding:0 6px 0 12px;cursor:default;
  background:linear-gradient(180deg,#f3f4f6,#dfe2e7);border-bottom:1px solid var(--win-line);
}
.titlebar .tb-title{flex:1;font-size:13px;font-weight:600;color:#33373d;display:flex;align-items:center;gap:8px;overflow:hidden;white-space:nowrap}
.titlebar .tb-title .tbt-ico{width:16px;height:16px;display:grid;place-items:center;font-size:13px}
.win-btns{display:flex;gap:6px}
.win-btn{width:22px;height:22px;border-radius:50%;border:none;cursor:pointer;font-size:12px;line-height:1;color:#3a3f46;display:grid;place-items:center}
.win-btn.min{background:#e6c14b}
.win-btn.maxb{background:#5fb15f;color:#1f4720}
.win-btn.close{background:#e06d5a;color:#5a1d12}
.win-btn:hover{filter:brightness(1.08)}
.win-body{flex:1;background:#fff;overflow:hidden;position:relative}

/* ---- Firefox chrome ---- */
.ff-tabsbar{display:flex;align-items:flex-end;gap:2px;height:34px;padding:4px 6px 0;background:linear-gradient(180deg,#d3d6db,#c6cad0)}
.ff-tab{
  display:flex;align-items:center;gap:8px;height:30px;padding:0 12px;min-width:170px;max-width:230px;
  background:#eef0f2;border:1px solid #b6bbc2;border-bottom:none;border-radius:7px 7px 0 0;
  font-size:12.5px;color:#33373d;position:relative;top:1px;
}
.ff-tab .fft-fav{width:15px;height:15px;border-radius:3px;background:radial-gradient(circle at 35% 30%,#ffb84d,#e25c1e);display:grid;place-items:center;font-size:9px}
.ff-tab .fft-x{margin-left:auto;color:#7a8089;cursor:pointer;font-size:13px}
.ff-newtab{width:26px;height:26px;border:none;background:transparent;color:#5c636d;font-size:18px;cursor:pointer;border-radius:5px}
.ff-newtab:hover{background:rgba(0,0,0,.08)}

.ff-toolbar{display:flex;align-items:center;gap:8px;height:42px;padding:0 10px;background:linear-gradient(180deg,#f4f5f7,#e7e9ec);border-bottom:1px solid #c2c6cd}
.ff-navbtn{width:30px;height:30px;border:none;background:transparent;border-radius:6px;color:#5c636d;font-size:16px;cursor:pointer;display:grid;place-items:center}
.ff-navbtn:hover{background:rgba(0,0,0,.07);color:#2b2f35}
.ff-navbtn:disabled{opacity:.4;cursor:default}
.ff-urlwrap{flex:1;position:relative;display:flex;align-items:center;background:#fff;border:1px solid #b6bbc2;border-radius:20px;height:32px;padding:0 12px;transition:border-color .15s,box-shadow .15s}
.ff-urlwrap.focus{border-color:var(--kde-blue-l);box-shadow:0 0 0 3px rgba(91,159,214,.25)}
.ff-lock{color:#5fa55f;font-size:12px;margin-right:8px}
.ff-url{flex:1;border:none;outline:none;font-size:13.5px;color:#1c2026;background:transparent;font-family:inherit}
.ff-url::placeholder{color:#9aa0a8}
.ff-star{color:#9aa0a8;font-size:14px;cursor:pointer}
.ff-suggest{
  position:absolute;left:0;right:0;top:38px;background:#fff;border:1px solid #c2c6cd;
  border-radius:10px;box-shadow:0 12px 34px rgba(0,0,0,.22);overflow:hidden;z-index:5;
}
.ff-sug-item{display:flex;align-items:center;gap:10px;padding:9px 14px;font-size:13.5px;color:#2b2f35;cursor:pointer}
.ff-sug-item .ss-ico{width:20px;height:20px;border-radius:4px;background:radial-gradient(circle at 35% 30%,#ffb84d,#e25c1e);display:grid;place-items:center;font-size:11px;color:#fff}
.ff-sug-item .ss-url{color:var(--kde-blue);font-weight:600}
.ff-sug-item .ss-tag{margin-left:auto;font-size:11px;color:#9aa0a8;letter-spacing:.04em}
.ff-sug-item.sel,.ff-sug-item:hover{background:#eaf2fb}

.ff-viewport{position:absolute;inset:0;background:#fff;overflow:hidden}
.ff-viewport iframe{width:100%;height:100%;border:0;display:block}
/* new-tab / start page */
.ff-newtabpage{position:absolute;inset:0;background:linear-gradient(180deg,#f7f8fa,#eceef1);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:22px;padding:30px;text-align:center}
.ff-ntp-logo{font-size:13px;letter-spacing:.3em;color:#9aa0a8;text-transform:uppercase}
.ff-ntp-search{width:min(520px,86%);height:46px;border:1px solid #c2c6cd;border-radius:24px;background:#fff;
  display:flex;align-items:center;padding:0 18px;color:#9aa0a8;font-size:14px;box-shadow:0 4px 14px rgba(0,0,0,.06)}
.ff-shortcuts{display:flex;gap:18px;flex-wrap:wrap;justify-content:center}
.ff-shortcut{display:flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer;width:92px}
.ff-shortcut .fs-tile{width:64px;height:64px;border-radius:14px;display:grid;place-items:center;font-size:30px;
  background:#fff;border:1px solid #dfe2e7;box-shadow:0 4px 12px rgba(0,0,0,.07);transition:transform .12s,box-shadow .12s}
.ff-shortcut:hover .fs-tile{transform:translateY(-3px);box-shadow:0 10px 20px rgba(0,0,0,.12)}
.ff-shortcut .fs-name{font-size:12.5px;color:#5c636d}
.ff-loading{position:absolute;top:0;left:0;height:3px;background:linear-gradient(90deg,#e25c1e,#ffb84d);width:0;z-index:6;transition:width .25s ease;opacity:0}

/* notification toast on desktop */
.kde-toast{
  position:absolute;right:14px;bottom:54px;z-index:80;width:300px;
  background:linear-gradient(180deg,#30353d,#23272e);border:1px solid var(--panel-line);
  border-radius:8px;box-shadow:0 12px 34px rgba(0,0,0,.5);color:#dfe6ee;padding:12px 14px;
  display:flex;gap:11px;animation:toastin .25s ease;
}
@keyframes toastin{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:none}}
.kde-toast .kt-ico{width:34px;height:34px;border-radius:8px;background:var(--kde-blue);display:grid;place-items:center;font-size:18px;flex:none}
.kde-toast .kt-title{font-size:13px;font-weight:600;margin-bottom:2px}
.kde-toast .kt-body{font-size:12px;color:#a9b4c2;line-height:1.4}

@media (max-width:760px){
  .window{min-width:0}
  .ff-tab{min-width:120px}
  .greeter-clock .gc-time{font-size:46px}
}
