/* ================================================================
   DESKTOP DEAR — a retro love-letter OS
   Win95 chrome · mint CRT · IBM Plex Mono
   ================================================================ */

:root{
  --page:#ececea;
  --bezel:#eae8e2;
  --bezel-edge:#a5a29a;
  --mint:#35c9a3;          /* boot / lock wallpaper  */
  --teal:#17a596;          /* desktop wallpaper      */
  --silver:#d6d2c9;        /* window chrome          */
  --silver-2:#cbc7be;
  --s-hi:#ffffff;
  --s-mid:#e9e6df;
  --s-lo:#8a887f;
  --s-dk:#3f3d38;
  --navy:#00007f;
  --navy-2:#1272cf;
  --ink:#1d1d1b;
  --note:#ffe14f;
  --widget:#0c3b33;
  --red:#d23a2a;
  --seg:#2a51e0;
  --mono:'IBM Plex Mono', ui-monospace, 'Cascadia Mono', Menlo, Consolas, monospace;
}

*{ margin:0; padding:0; box-sizing:border-box; }
[hidden]{ display:none !important; }
html,body{ height:100%; }
body{
  background:var(--page);
  font-family:var(--mono);
  color:var(--ink);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}

#page{
  min-height:100vh;
  display:flex;
  justify-content:center;
  align-items:flex-start;
  overflow:hidden;
}

/* fixed-size stage, scaled by JS to fit any viewport */
#stage{
  width:872px;
  height:756px;
  flex:0 0 auto;
  transform-origin:top center;
  padding-top:14px;
}

#pageTitle{
  text-align:center;
  font-size:12px;
  color:#8f8d89;
  letter-spacing:.3px;
  margin-bottom:20px;
}

/* ---------------------------------------------------------------
   CRT MONITOR
   --------------------------------------------------------------- */
.dither{
  background-image:conic-gradient(#ffffff 25%, #d8d6cf 0 50%, #ffffff 0 75%, #d8d6cf 0);
  background-size:4px 4px;
}

#monitor{ width:872px; margin:0 auto; }

#bezel{
  padding:22px 22px 42px;
  background:var(--bezel);
  border:1px solid var(--bezel-edge);
  outline:10px solid transparent;
  position:relative;
  /* dithered halo frame */
  box-shadow:0 0 0 1px var(--bezel-edge);
  background-clip:padding-box;
}
#bezel::before{            /* checkered border around the whole bezel */
  content:"";
  position:absolute;
  inset:-11px;
  z-index:-1;
  background-image:conic-gradient(#ffffff 25%, #cfcdc6 0 50%, #ffffff 0 75%, #cfcdc6 0);
  background-size:4px 4px;
  border:1px solid #c2c0b8;
}

#screen{
  position:relative;
  width:826px;
  height:580px;
  background:var(--mint);
  border:2px solid #141414;
  overflow:hidden;
}

.screen-layer{ position:absolute; inset:0; }

.bezel-caption{
  position:absolute;
  left:0; right:0; bottom:13px;
  display:flex;
  justify-content:center;
  align-items:center;
  gap:8px;
  font-size:11px;
  font-weight:600;
  letter-spacing:5px;
  color:#75736c;
  user-select:none;
}
.bezel-dot{ width:8px; height:8px; background:var(--teal); display:inline-block; }

#standNeck{
  width:96px; height:15px;
  margin:6px auto 0;
  border:1px solid #c6c4bc;
}
#standBase{
  width:216px; height:15px;
  margin:3px auto 0;
  border:1px solid #c6c4bc;
  transform:translateX(-26px);
}

/* ---------------------------------------------------------------
   WIN95 PRIMITIVES
   --------------------------------------------------------------- */
.raised{
  background:var(--silver);
  box-shadow:inset -1px -1px var(--s-dk),
             inset  1px  1px var(--s-hi),
             inset -2px -2px var(--s-lo),
             inset  2px  2px var(--s-mid);
}
.sunken{
  background:#fff;
  box-shadow:inset -1px -1px var(--s-hi),
             inset  1px  1px var(--s-dk),
             inset -2px -2px var(--s-mid),
             inset  2px  2px var(--s-lo);
}
.raised-thin{
  background:var(--silver);
  box-shadow:inset -1px -1px var(--s-lo), inset 1px 1px var(--s-hi);
}
.sunken-thin{
  box-shadow:inset -1px -1px var(--s-hi), inset 1px 1px var(--s-lo);
}

.btn95{
  font-family:var(--mono);
  font-size:12.5px;
  font-weight:600;
  color:var(--ink);
  background:var(--silver);
  border:none;
  padding:5px 14px 6px;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  box-shadow:inset -1px -1px var(--s-dk),
             inset  1px  1px var(--s-hi),
             inset -2px -2px var(--s-lo),
             inset  2px  2px var(--s-mid);
  user-select:none;
  white-space:nowrap;
}
.btn95:active, .btn95.pressed{
  box-shadow:inset -1px -1px var(--s-hi),
             inset  1px  1px var(--s-dk),
             inset -2px -2px var(--s-mid),
             inset  2px  2px var(--s-lo);
  padding:6px 13px 5px 15px;
}
.btn95:focus-visible{ outline:1px dotted #333; outline-offset:-5px; }

.input95{
  font-family:var(--mono);
  font-size:12.5px;
  color:var(--ink);
  background:#fff;
  border:none;
  width:100%;
  padding:8px 9px;
  box-shadow:inset -1px -1px var(--s-hi),
             inset  1px  1px var(--s-dk),
             inset -2px -2px var(--s-mid),
             inset  2px  2px var(--s-lo);
}
.input95::placeholder{ color:#9a978f; }
.input95:focus{ outline:2px solid #2a6ee8; outline-offset:0; }

/* ---------------------------------------------------------------
   WINDOWS
   --------------------------------------------------------------- */
.window{
  position:absolute;
  background:var(--silver);
  box-shadow:inset -1px -1px var(--s-dk),
             inset  1px  1px var(--s-hi),
             inset -2px -2px var(--s-lo),
             inset  2px  2px var(--s-mid);
  padding:3px;
  filter:drop-shadow(3px 3px 0 rgba(10,44,38,.30));
}
.titlebar{
  height:24px;
  background:linear-gradient(90deg, var(--navy), var(--navy-2));
  color:#fff;
  display:flex;
  align-items:center;
  gap:6px;
  padding:0 3px 0 5px;
  cursor:grab;
  user-select:none;
}
.titlebar:active{ cursor:grabbing; }
.tb-ico{ width:15px; height:15px; flex:0 0 auto; display:grid; place-items:center; }
.tb-ico svg{ width:15px; height:15px; display:block; }
.tb-title{
  font-size:12.5px;
  font-weight:700;
  letter-spacing:.2px;
  flex:1 1 auto;
  overflow:hidden;
  white-space:nowrap;
  text-overflow:ellipsis;
}
.tb-x{
  width:19px; height:17px;
  flex:0 0 auto;
  font-size:11px;
  font-weight:700;
  line-height:1;
  padding:0;
  display:grid;
  place-items:center;
  font-family:var(--mono);
  color:var(--ink);
  background:var(--silver);
  border:none;
  cursor:pointer;
  box-shadow:inset -1px -1px var(--s-dk),
             inset  1px  1px var(--s-hi),
             inset -2px -2px var(--s-lo),
             inset  2px  2px var(--s-mid);
}
.tb-x:active{
  box-shadow:inset -1px -1px var(--s-hi), inset 1px 1px var(--s-dk);
}
.win-body{ position:relative; }

/* ---- media player ---- */
.media-body{ padding:10px; width:396px; }
.media-frame{ background:#0d1a2b; }
.media-frame iframe{ display:block; width:100%; height:152px; border:0; }
.media-caption{
  margin-top:9px;
  padding:7px 9px;
  font-size:12px;
  color:#3c3a34;
  background:#f3f1ea;
  box-shadow:inset -1px -1px var(--s-hi), inset 1px 1px var(--s-lo);
}

/* ---- my pictures ---- */
.pics-body{ padding:12px; width:502px; }
.pics-row{
  display:flex;
  gap:14px;
  overflow-x:auto;
  padding:4px 2px 10px;
}
.pics-row::-webkit-scrollbar{ height:15px; }
.pics-row::-webkit-scrollbar-track{
  background:#efede6;
  box-shadow:inset 1px 1px var(--s-lo), inset -1px -1px var(--s-hi);
}
.pics-row::-webkit-scrollbar-thumb{
  background:var(--silver);
  box-shadow:inset -1px -1px var(--s-dk), inset 1px 1px var(--s-hi),
             inset -2px -2px var(--s-lo), inset 2px 2px var(--s-mid);
}
.polaroid{
  flex:0 0 auto;
  max-width:206px;
  background:#fff;
  border:1px solid #a9a69d;
  padding:7px 7px 6px;
  box-shadow:2px 2px 0 rgba(20,40,34,.22);
}
.polaroid .ph{
  width:116px; height:106px;
  display:block;
  margin:0 auto;
  background:#dfe8e6;
  border:1px solid #c4c1b8;
  object-fit:cover;
}
.polaroid figcaption{
  margin-top:6px;
  text-align:center;
  font-size:11.5px;
  line-height:1.5;
  color:#403e38;
}

/* ---- inbox ---- */
.inbox-body{ padding:12px; width:436px; }
.mail-sheet{
  background:#fff;
  box-shadow:inset -1px -1px var(--s-hi), inset 1px 1px var(--s-dk),
             inset -2px -2px var(--s-mid), inset 2px 2px var(--s-lo);
  padding:15px 17px 17px;
  font-size:12.5px;
  line-height:1.65;
}
.mail-head{ margin-bottom:13px; }
.mail-head b{ font-weight:700; }
.mail-body p{ margin-top:13px; }
.mail-body p:first-child{ margin-top:0; }

/* ---- calendar ---- */
.cal-body{ padding:10px; width:404px; }
.cal-head{
  height:27px;
  background:linear-gradient(90deg, var(--navy), var(--navy-2));
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0 6px;
  font-size:12.5px;
  font-weight:700;
}
.cal-nav{
  background:none; border:none; color:#fff;
  font-family:var(--mono); font-size:12px; font-weight:700;
  cursor:pointer; padding:2px 8px;
}
.cal-nav:hover{ background:rgba(255,255,255,.18); }
.cal-grid{
  display:grid;
  grid-template-columns:repeat(7,1fr);
  gap:4px;
  margin-top:9px;
}
.cal-dow{
  text-align:center;
  font-size:11px;
  font-weight:700;
  padding:3px 0 4px;
  color:#2e2c28;
}
.cal-dow.wk-end{ color:var(--red); }
.cal-cell{
  height:27px;
  font-family:var(--mono);
  font-size:12px;
  font-weight:500;
  color:var(--ink);
  background:var(--silver);
  border:none;
  cursor:default;
  position:relative;
  box-shadow:inset -1px -1px var(--s-lo), inset 1px 1px var(--s-hi);
}
.cal-cell.blank{ background:transparent; box-shadow:none; }
.cal-cell.is-today{ /* kept subtle: no marker, matches reference */ }
.cal-cell.is-date{
  color:#fff;
  background:var(--red);
  box-shadow:inset -1px -1px #7e1d12, inset 1px 1px #ef7f70;
  font-weight:700;
}
.cal-cell.is-date::after{
  content:"♥";
  position:absolute;
  top:-7px; right:-4px;
  font-size:11px;
  color:var(--red);
  text-shadow:0 0 2px #fff, 0 0 2px #fff;
}

/* ask / result panel that floats above the calendar */
.ask-panel{
  position:absolute;
  left:50%; top:50%;
  transform:translate(-50%,-52%);
  width:300px;
  padding:17px 16px 15px;
  z-index:6;
  background:var(--silver);
  box-shadow:inset -1px -1px var(--s-dk), inset 1px 1px var(--s-hi),
             inset -2px -2px var(--s-lo), inset 2px 2px var(--s-mid);
  filter:drop-shadow(3px 3px 0 rgba(10,44,38,.30));
}
.ask-q{
  font-size:13px;
  font-weight:700;
  line-height:1.5;
  white-space:pre-line;
}
.ask-btns{
  position:relative;
  height:44px;
  margin-top:12px;
}
.ask-yes{ position:absolute; left:14px; top:8px; min-width:72px; }
.ask-no{ position:absolute; left:150px; top:8px; min-width:64px; transition:left .09s steps(2), top .09s steps(2); }
.no-ghost{
  position:absolute;
  border:1px dashed #6f6d66;
  pointer-events:none;
  opacity:.9;
}
.ask-done{
  text-align:center;
  font-size:12.5px;
  line-height:1.7;
}
.ask-done .btn95{ margin-top:12px; min-width:76px; }

/* ---- mystery / gates ---- */
.gate-body{ padding:15px 15px 13px; }
.gate-lead{ font-size:12.5px; margin-bottom:9px; }
.gate-q{ font-size:12.5px; margin-bottom:11px; }
.gate-q b, .gate-lead b{ font-weight:700; }
.gate-row{ margin-top:12px; display:flex; justify-content:flex-end; gap:8px; }
.gate-err{
  margin-top:9px;
  font-size:11.5px;
  color:var(--red);
  display:none;
}
.gate-err.show{ display:block; }
.shake{ animation:shake .32s; }
@keyframes shake{
  0%,100%{ transform:translateX(0); }
  20%{ transform:translateX(-7px); }
  40%{ transform:translateX(6px); }
  60%{ transform:translateX(-4px); }
  80%{ transform:translateX(3px); }
}

/* ---- voucher ---- */
.voucher-body{ padding:12px; width:428px; }
.voucher-sheet{
  background:#f6f4ee;
  box-shadow:inset -1px -1px var(--s-hi), inset 1px 1px var(--s-dk),
             inset -2px -2px var(--s-mid), inset 2px 2px var(--s-lo);
  padding:20px 18px 18px;
  text-align:center;
}
.voucher-tag{
  font-size:11px;
  font-weight:600;
  letter-spacing:5px;
  color:#8b887e;
  margin-bottom:12px;
}
.voucher-line{ font-size:12.5px; line-height:1.6; }
.voucher-prize{
  font-size:19px;
  font-weight:700;
  margin:13px 0 15px;
}
.voucher-note{ font-size:11.5px; color:#7c796f; margin-top:10px; display:none; }
.voucher-note.show{ display:block; }

/* ---------------------------------------------------------------
   BOOT SEQUENCE
   --------------------------------------------------------------- */
#bootLayer{ display:grid; place-items:center; background:var(--mint); }
.boot-dialog{ position:static; }
.load-wrap{ text-align:center; color:#fff; }
.load-text{ font-size:13px; letter-spacing:.4px; margin-bottom:14px; }
.load-bar{
  width:384px; height:30px;
  margin:0 auto;
  border:2px solid #fff;
  background:#060b0a;
  padding:3px;
  display:flex;
  gap:3px;
}
.load-seg{
  flex:0 0 13px;
  height:100%;
  background:var(--seg);
  box-shadow:inset 1px 1px #6f8cf1, inset -1px -1px #1d3390;
}
.load-pct{ margin-top:10px; font-size:12px; }

/* ---------------------------------------------------------------
   DESKTOP
   --------------------------------------------------------------- */
#desktopLayer{ background:var(--teal); }

.dicon{
  position:absolute;
  width:84px;
  background:none;
  border:none;
  font-family:var(--mono);
  cursor:pointer;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:5px;
  padding:6px 2px;
}
.dicon-img{ width:46px; height:46px; }
.dicon-img svg{ width:46px; height:46px; display:block; }
.dicon-label{
  font-size:12px;
  color:#0e2b25;
  padding:1px 4px;
  line-height:1.3;
}
.dicon.selected .dicon-label{
  background:var(--navy);
  color:#fff;
  outline:1px dotted #efe;
}
.dicon:active .dicon-img{ filter:brightness(.85); }

#metWidget{
  position:absolute;
  top:26px; right:26px;
  padding:4px;
  filter:drop-shadow(3px 3px 0 rgba(9,40,34,.3));
}
.met-inner{
  background:var(--widget);
  color:#e9fdf5;
  text-align:center;
  padding:13px 30px 12px;
}
.met-cap{ font-size:11.5px; letter-spacing:1px; }
.met-num{ font-size:42px; font-weight:700; line-height:1.15; }

#stickyNote{
  position:absolute;
  right:30px; bottom:64px;
  width:240px;
  min-height:126px;
  background:var(--note);
  padding:22px 60px 18px 20px;
  box-shadow:4px 4px 0 rgba(20,44,36,.24);
  font-size:12.5px;
  line-height:1.65;
  color:#5d5340;
}
#noteClose{
  position:absolute;
  top:5px; right:8px;
  border:none; background:none;
  font-family:var(--mono);
  font-size:13px;
  color:#b3985c;
  cursor:pointer;
}

/* taskbar */
#taskbar{
  position:absolute;
  left:0; right:0; bottom:0;
  height:40px;
  background:var(--silver);
  border-top:1px solid var(--s-hi);
  box-shadow:0 -1px 0 var(--s-lo);
  display:flex;
  align-items:center;
  gap:6px;
  padding:4px 6px;
  z-index:900;
}
#startBtn{ font-weight:700; flex:0 0 auto; }
#startFlag{ width:17px; height:15px; display:inline-block; }
#startFlag svg{ width:17px; height:15px; display:block; }
#taskButtons{
  display:flex;
  gap:5px;
  flex:1 1 auto;
  min-width:0;
  overflow:hidden;
}
.taskbtn{
  flex:0 1 152px;
  min-width:56px;
  justify-content:flex-start;
  overflow:hidden;
}
.taskbtn .t-ico{ width:14px; height:14px; flex:0 0 auto; }
.taskbtn .t-ico svg{ width:14px; height:14px; display:block; }
.taskbtn .t-label{
  overflow:hidden;
  white-space:nowrap;
  text-overflow:clip;
  font-weight:600;
}
.taskbtn.pressed{ background:var(--silver-2); font-weight:700; }
#clock{
  flex:0 0 auto;
  font-size:12px;
  padding:6px 11px;
  background:var(--silver);
}

/* start menu */
#startMenu{
  position:absolute;
  left:6px; bottom:44px;
  width:212px;
  z-index:950;
  display:flex;
  background:var(--silver);
  box-shadow:inset -1px -1px var(--s-dk), inset 1px 1px var(--s-hi),
             inset -2px -2px var(--s-lo), inset 2px 2px var(--s-mid);
  padding:3px;
  filter:drop-shadow(3px 3px 0 rgba(10,44,38,.3));
}
.sm-banner{
  width:26px;
  background:linear-gradient(0deg, var(--navy), var(--navy-2));
  position:relative;
}
.sm-banner span{
  position:absolute;
  left:50%; bottom:8px;
  transform:translateX(-50%) rotate(180deg);
  writing-mode:vertical-rl;
  color:#fff;
  font-size:12.5px;
  font-weight:700;
  letter-spacing:1px;
  white-space:nowrap;
}
.sm-items{ flex:1; padding:5px 4px; display:flex; flex-direction:column; }
.sm-item{
  display:flex;
  align-items:center;
  gap:9px;
  padding:9px 8px;
  border:none;
  background:none;
  font-family:var(--mono);
  font-size:12.5px;
  font-weight:600;
  color:var(--ink);
  cursor:pointer;
  text-align:left;
}
.sm-item:hover{ background:var(--navy); color:#fff; }
.sm-sep{
  height:0;
  border-top:1px solid var(--s-lo);
  border-bottom:1px solid var(--s-hi);
  margin:4px 2px;
}
.sm-ico{ width:15px; height:15px; display:inline-block; }
.sm-ico svg{ width:15px; height:15px; display:block; }
.sm-item:hover .sm-ico svg .ink-f{ fill:#fff; }
.sm-item:hover .sm-ico svg .ink-s{ stroke:#fff; }

/* shutdown */
#shutdownLayer{
  background:#000;
  display:grid;
  place-items:center;
  text-align:center;
  cursor:pointer;
  z-index:2000;
}
.shut-msg{
  color:#ffb63f;
  font-size:17px;
  font-weight:600;
  line-height:1.8;
}
.shut-sub{ color:#8d7a55; font-size:11.5px; margin-top:18px; }

/* confetti */
#confettiLayer{
  position:absolute;
  inset:0;
  pointer-events:none;
  z-index:3000;
  overflow:hidden;
}
.cf-heart{
  position:absolute;
  top:-20px;
  animation:cf-fall linear forwards;
}
.cf-heart svg{ display:block; }
@keyframes cf-fall{
  0%  { transform:translateY(-24px) translateX(0) rotate(0deg); opacity:1; }
  80% { opacity:1; }
  100%{ transform:translateY(640px) translateX(var(--sway)) rotate(var(--spin)); opacity:0; }
}
