/* ============================================================
   NAVI-OS — retro-cyberpunk personal desktop
   Palette
   ============================================================ */
:root{
  --bg:        #04080a;   /* CRT void                  */
  --panel:     #08120f;   /* window body               */
  --panel-2:   #0c1a14;   /* raised surface            */
  --green:     #46ff8e;   /* atlas primary          */
  --green-dim: #1f7a4a;   /* atlas low              */
  --green-ink: #0c2b1a;   /* atlas shadow           */
  --orange:    #ff7a1a;   /* EVA warning accent        */
  --red:       #ff3b3b;   /* alert                     */
  --grid:      #11271c;
  --font-d: 'VT323', monospace;
  --font-b: 'Share Tech Mono', monospace;
  --tb-h: 46px;
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{height:100%}
body{
  background:var(--bg);
  color:var(--green);
  font-family:var(--font-b);
  font-size:15px;
  overflow:hidden;
  text-shadow:0 0 6px rgba(70,255,142,.35);
}
::selection{background:var(--green);color:var(--bg);text-shadow:none}
button{font-family:inherit;color:inherit;background:none;border:none;cursor:pointer}
button:focus-visible,a:focus-visible,[tabindex]:focus-visible{outline:2px solid var(--orange);outline-offset:2px}
a{color:var(--green)}

/* ---------- CRT overlay --------------------------------- */
.crt::before{
  content:"";position:fixed;inset:0;z-index:9000;pointer-events:none;
  background:repeating-linear-gradient(0deg,rgba(0,0,0,.22) 0 1px,transparent 1px 3px);
  mix-blend-mode:multiply;
}
.crt::after{
  content:"";position:fixed;inset:0;z-index:9001;pointer-events:none;
  background:radial-gradient(ellipse at center,transparent 58%,rgba(0,0,0,.55) 100%);
  animation:flicker 4s infinite steps(60);
}
@keyframes flicker{
  0%,100%{opacity:1} 92%{opacity:1} 93%{opacity:.86} 94%{opacity:1} 97%{opacity:.93} 98%{opacity:1}
}
@media (prefers-reduced-motion:reduce){
  .crt::after{animation:none}
  *,*::before,*::after{animation-duration:.001s !important;transition-duration:.001s !important}
}

/* ---------- boot screen ---------------------------------- */
#boot{
  position:fixed;inset:0;z-index:8000;background:var(--bg);
  padding:6vh 6vw;font-family:var(--font-d);font-size:clamp(18px,2.6vw,26px);
  line-height:1.45;cursor:pointer;
}
#boot .cursor{display:inline-block;width:.6em;height:1em;background:var(--green);
  vertical-align:-2px;animation:blink 1s steps(1) infinite}
@keyframes blink{50%{opacity:0}}
#boot .ok{color:var(--orange)}
#boot-hint{position:absolute;bottom:6vh;left:6vw;color:var(--green-dim);font-size:.8em}

/* ---------- desktop --------------------------------------- */
#desktop{
  position:fixed;inset:0 0 var(--tb-h) 0;
  background:
    linear-gradient(rgba(4,8,10,.92),rgba(4,8,10,.92)),
    repeating-linear-gradient(0deg,var(--grid) 0 1px,transparent 1px 44px),
    repeating-linear-gradient(90deg,var(--grid) 0 1px,transparent 1px 44px);
  overflow:hidden;
}
#wallpaper-sigil{
  position:absolute;right:4vw;top:8vh;width:min(34vw,300px);opacity:.16;pointer-events:none;
}
#icons{
  position:absolute;top:18px;left:14px;display:grid;gap:6px;
  grid-template-columns:repeat(1,86px);
}
.icon{
  width:86px;padding:10px 4px;display:flex;flex-direction:column;align-items:center;gap:6px;
  color:var(--green);border:1px solid transparent;
}
.icon:hover,.icon:focus-visible{border-color:var(--green-dim);background:rgba(70,255,142,.06)}
.icon svg{width:38px;height:38px;stroke:var(--green);fill:none;stroke-width:1.4;
  filter:drop-shadow(0 0 4px rgba(70,255,142,.5))}
.icon span{font-family:var(--font-d);font-size:16px;letter-spacing:1px;text-align:center}
.icon.maze svg{stroke:var(--orange);filter:drop-shadow(0 0 5px rgba(255,122,26,.55))}
.icon.maze span{color:var(--orange)}

/* ---------- windows --------------------------------------- */
.window{
  position:absolute;min-width:280px;
  background:var(--panel);
  border:1px solid var(--green-dim);
  box-shadow:0 0 0 1px var(--green-ink),0 0 24px rgba(70,255,142,.12),12px 12px 0 rgba(0,0,0,.45);
  display:none;flex-direction:column;
}
.window.open{display:flex}
.titlebar{
  display:flex;align-items:center;gap:8px;
  background:linear-gradient(90deg,var(--green-ink),var(--panel-2));
  border-bottom:1px solid var(--green-dim);
  padding:5px 8px;cursor:grab;user-select:none;touch-action:none;
}
.titlebar:active{cursor:grabbing}
.titlebar .tag{
  font-family:var(--font-d);font-size:18px;letter-spacing:2px;flex:1;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.titlebar .tag b{color:var(--orange);font-weight:normal}
.tb-btn{
  width:24px;height:22px;border:1px solid var(--green-dim);
  font-family:var(--font-d);font-size:16px;line-height:1;color:var(--green);
  background:var(--panel);flex:none;
}
.tb-btn:hover{background:var(--green);color:var(--bg);text-shadow:none}
.tb-btn.close:hover{background:var(--red);border-color:var(--red)}
.win-body{padding:14px;overflow:auto;flex:1;min-height:0}
.win-body h2{font-family:var(--font-d);font-size:24px;letter-spacing:2px;color:var(--orange);
  border-bottom:1px dashed var(--green-dim);padding-bottom:6px;margin-bottom:10px}
.win-body p{margin-bottom:10px;line-height:1.55;color:#9df3bf}
.win-body .dim{color:var(--green-dim)}

/* about */
#win-about{width:480px;top:8%;left:16%}
.id-row{display:flex;gap:14px;margin-bottom:12px}
.id-photo{
  width:96px;height:96px;flex:none;border:1px solid var(--green-dim);
  display:flex;align-items:center;justify-content:center;
  background:repeating-linear-gradient(45deg,var(--green-ink) 0 6px,var(--panel) 6px 12px);
  font-family:var(--font-d);font-size:14px;color:var(--green-dim);text-align:center;
  overflow:hidden;
}
.id-photo img{width:100%;height:100%;object-fit:cover;display:block;}
.kv{font-size:13px;line-height:1.7}
.kv b{color:var(--orange);font-weight:normal}

/* projects */
#win-projects{width:430px;top:14%;left:42%}
.proj{
  display:block;border:1px solid var(--green-dim);padding:10px 12px;margin-bottom:10px;
  text-decoration:none;position:relative;
}
.proj:hover{background:rgba(70,255,142,.07);border-color:var(--green)}
.proj h3{font-family:var(--font-d);font-size:20px;letter-spacing:2px}
.proj h3 i{font-style:normal;color:var(--orange)}
.proj p{margin:2px 0 0;font-size:13px;color:var(--green-dim)}
.proj::after{content:"->";position:absolute;right:12px;top:12px;color:var(--orange)}

/* calendar */
#win-calendar{width:340px;top:30%;left:8%}
.cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.cal-head .m{font-family:var(--font-d);font-size:22px;letter-spacing:2px;color:var(--orange)}
.cal-nav{border:1px solid var(--green-dim);padding:2px 10px;font-family:var(--font-d);font-size:18px}
.cal-nav:hover{background:var(--green);color:var(--bg);text-shadow:none}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;text-align:center}
.cal-grid .dow{color:var(--green-dim);font-size:11px;padding:4px 0}
.cal-grid .day{padding:7px 0;border:1px solid transparent;font-size:13px}
.cal-grid .day:hover{border-color:var(--green-dim)}
.cal-grid .day.blank{visibility:hidden}
.cal-grid .day.today{border-color:var(--orange);color:var(--orange)}
.cal-grid .day.sel{background:var(--green);color:var(--bg);text-shadow:none}
#cal-readout{margin-top:8px;font-size:12px;color:var(--green-dim);min-height:1.2em}

/* notepad */
#win-notepad{width:420px;height:340px;top:20%;left:55%}
#note-area{
  flex:1;width:100%;resize:none;background:var(--bg);color:var(--green);
  border:1px solid var(--green-dim);padding:10px;font-family:var(--font-b);font-size:14px;
  line-height:1.5;text-shadow:inherit;
}
#note-area:focus{outline:1px solid var(--green)}
.note-foot{display:flex;justify-content:space-between;margin-top:8px;font-size:12px;color:var(--green-dim)}
.note-foot button{border:1px solid var(--green-dim);padding:2px 10px}
.note-foot button:hover{background:var(--red);border-color:var(--red);color:#fff;text-shadow:none}

/* calculator */
#win-calc{width:280px;top:42%;left:36%}
#calc-display{
  background:var(--bg);border:1px solid var(--green-dim);padding:10px 12px;margin-bottom:10px;
  font-family:var(--font-d);font-size:32px;text-align:right;overflow:hidden;white-space:nowrap;
  min-height:54px;
}
.calc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}
.calc-grid button{
  border:1px solid var(--green-dim);padding:12px 0;font-family:var(--font-d);font-size:22px;
  background:var(--panel-2);
}
.calc-grid button:hover{background:var(--green);color:var(--bg);text-shadow:none}
.calc-grid button.op{color:var(--orange);border-color:#5a3517}
.calc-grid button.op:hover{background:var(--orange);color:var(--bg)}
.calc-grid button.eq{grid-column:span 2;background:var(--green-ink)}

/* maze launcher window */
#win-maze{width:380px;top:34%;left:50%}
#win-maze .big{
  width:100%;border:1px solid var(--orange);color:var(--orange);
  font-family:var(--font-d);font-size:24px;letter-spacing:3px;padding:12px 0;margin-top:6px;
}
#win-maze .big:hover{background:var(--orange);color:var(--bg);text-shadow:none}

/* ---------- taskbar ---------------------------------------- */
#taskbar{
  position:fixed;left:0;right:0;bottom:0;height:var(--tb-h);z-index:7000;
  background:var(--panel-2);border-top:1px solid var(--green-dim);
  display:flex;align-items:stretch;gap:6px;padding:5px 6px;
}
#tb-root{
  border:1px solid var(--orange);color:var(--orange);font-family:var(--font-d);
  font-size:20px;letter-spacing:2px;padding:0 14px;flex:none;
}
#tb-root:hover{background:var(--orange);color:var(--bg);text-shadow:none}
#tb-tasks{display:flex;gap:6px;flex:1;overflow-x:auto;scrollbar-width:none}
#tb-tasks::-webkit-scrollbar{display:none}
.tb-task{
  border:1px solid var(--green-dim);padding:0 12px;font-family:var(--font-d);font-size:17px;
  letter-spacing:1px;white-space:nowrap;color:var(--green-dim);
}
.tb-task.active{color:var(--green);border-color:var(--green);background:rgba(70,255,142,.07)}
#tb-clock{
  flex:none;display:flex;flex-direction:column;justify-content:center;align-items:flex-end;
  padding:0 10px;font-size:12px;line-height:1.25;color:var(--green);
  border-left:1px solid var(--green-dim);
}
#tb-clock .t{font-family:var(--font-d);font-size:18px;letter-spacing:2px}

/* ---------- maze overlay ------------------------------------ */
#maze-layer{position:fixed;inset:0;z-index:8500;background:#000;display:none}
#maze-layer.on{display:block}
#maze-canvas{width:100%;height:100%;display:block;touch-action:none}
.hud{position:absolute;pointer-events:none;font-family:var(--font-d);letter-spacing:2px}
#hud-top{top:12px;left:14px;font-size:20px;color:var(--green)}
#hud-top b{color:var(--orange);font-weight:normal}
#hud-msg{
  top:42%;left:0;right:0;text-align:center;font-size:clamp(26px,6vw,52px);
  color:var(--orange);opacity:0;transition:opacity .3s;
}
#hud-msg.show{opacity:1}
#maze-ui{position:absolute;top:10px;right:12px;display:flex;gap:8px}
#maze-ui button{
  border:1px solid var(--green-dim);background:rgba(4,8,10,.8);padding:8px 14px;
  font-family:var(--font-d);font-size:18px;letter-spacing:2px;color:var(--green);
}
#maze-ui button:hover{background:var(--green);color:var(--bg);text-shadow:none}
#btn-vr{color:var(--orange) !important;border-color:var(--orange) !important}
#btn-vr:hover{background:var(--orange) !important;color:var(--bg) !important}
#maze-help{
  position:absolute;bottom:14px;left:0;right:0;text-align:center;
  color:var(--green-dim);font-size:12px;pointer-events:none;
}
/* virtual joystick */
#joy{
  position:absolute;bottom:86px;left:26px;width:120px;height:120px;border-radius:50%;
  border:1px solid var(--green-dim);background:rgba(70,255,142,.05);touch-action:none;
  display:none;
}
#joy .nub{
  position:absolute;width:48px;height:48px;border-radius:50%;left:36px;top:36px;
  background:rgba(70,255,142,.25);border:1px solid var(--green);
}
.touch #joy{display:block}
/* turn buttons for touch */
#turnpad{position:absolute;bottom:96px;right:26px;display:none;gap:10px}
.touch #turnpad{display:flex}
#turnpad button{
  width:64px;height:64px;border-radius:50%;border:1px solid var(--green-dim);
  background:rgba(70,255,142,.07);font-family:var(--font-d);font-size:26px;color:var(--green);
}

/* ---------- mobile ------------------------------------------ */
@media (max-width:760px){
  #icons{grid-template-columns:repeat(3,minmax(86px,1fr));left:8px;right:8px;gap:2px}
  .window{
    left:4px !important;right:4px !important;top:4px !important;
    bottom:calc(var(--tb-h) + 4px) !important;width:auto !important;height:auto !important;
    min-width:0;
  }
  .titlebar{cursor:default}
  #wallpaper-sigil{right:2vw;top:auto;bottom:10vh}
}
