:root{
  --desk: #5454d1; --win: #ececec; --light:#fff; --dark:#999; --darker:#555;
  --text:#000; --titlebar:#000080; --titlebar-inactive:#666;
  --titletext:#fff; --taskbar:#c0c0c0; --accent:#ffeb3b; --accent-dim:#d4c23d;
}
*{box-sizing:border-box; user-select:none}
html,body{height:100%}
body{margin:0; font:14px/1 "Jersey 20", sans-serif; color:var(--text); background:var(--desk)}

.desktop{position:fixed; inset:0; overflow:hidden}
.wallpaper{position:absolute; inset:0; background-color:var(--desk); background-image:url("assets/img/logo.png"); background-repeat:repeat; background-size:128px;}

/* Desktop icons */
.desktop, .icon {
  touch-action:none;
}

.icon {
  position:absolute;
  width:240px;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:4px;
  padding:4px;
  border-radius:4px;
  cursor:grab;
}
.icon:focus {
  outline:2px dotted var(--accent);
  outline-offset:2px;
}
.icon img, .icon svg {
  width:192px;
  height:192px;
  image-rendering:pixelated;
  object-fit:contain;
  pointer-events: none;
  -webkit-user-drag: none;
  user-select: none;
}
.icon svg {
  stroke:#fff;           /* 👈 white stroke (hard to see on yellow) */
  fill:none;
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.icon .label {
  color:#fff;            /* 👈 white text (hard to see on yellow) */
  font-family:"Honk", "Atomic Age", "Segoe UI", sans-serif;
  font-size:32px;
  text-shadow:1px 1px 0 #000;
  text-align:center;
}
/* Windows */
.window{position:absolute; min-width:320px; min-height:160px; max-width:min(90vw, 900px); max-height:calc(100vh - 80px); background:var(--win); border:2px solid var(--dark); box-shadow:4px 4px 0 var(--darker); border-top-color:var(--light); border-left-color:var(--light); border-right-color:var(--dark); border-bottom-color:var(--dark); resize: both; overflow: auto}
.titlebar{display:flex; align-items:center; justify-content:space-between; padding:2px 6px; background:var(--titlebar); color:var(--titletext); cursor:move; touch-action:none}
.titlebar.inactive{background:var(--titlebar-inactive)}
.titlebar .title{display:flex; align-items:center; gap:6px}
.titlebar .controls{display:flex; gap:2px}
.btn{width:20px; height:20px; display:grid; place-items:center; background:var(--win); border:1px solid var(--dark); font-weight:bold}
/* Button size overrides for Start & taskbar buttons */
.btn.start, .btn.task-btn{width:auto; height:26px; padding:0 10px; display:inline-flex; align-items:center; justify-content:center;}
.btn.task-btn{max-width:200px; min-width:120px}
.btn.start{font-weight:800; letter-spacing:0.5px;}
.btn:active{background:var(--accent)}
.content{padding:10px}

/* Taskbar */
.taskbar{position:fixed; left:0; right:0; bottom:0; height:32px; background:var(--taskbar); border-top:2px solid var(--light); display:flex; align-items:center; gap:4px; padding:2px}
.start{margin-left:4px; background:var(--win); border:2px outset var(--light); box-shadow:inset -1px -1px 0 var(--dark), inset 1px 1px 0 var(--light)}
.task-btn{max-width:200px; min-width:120px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; background:var(--win); border:2px outset var(--light)}
.status{margin-left:auto; padding:0 8px}

/* Marquee selection */
.selection-marquee{position:absolute; border:1px dashed #000; background:rgba(255,235,59,.18); display:none; pointer-events:none; z-index:5}
.icon.selected{outline:2px dashed var(--accent); outline-offset:2px; filter:drop-shadow(0 0 2px #000)}

/* Start menu */
.start-menu{position:fixed; left:6px; bottom:36px; width:220px; background:#f0f0f0; border:2px solid var(--dark); border-top-color:var(--light); border-left-color:var(--light); box-shadow:4px 4px 0 var(--darker); display:none; z-index:9999}
.start-menu .start-blurb{padding:10px 12px 8px; font-size:12px; line-height:1.4; margin:0; border-bottom:1px solid #ccc}
.start-menu header{background:var(--titlebar); color:var(--titletext); padding:4px 6px; font-weight:700; border-bottom:1px solid #335}
.start-menu .item{display:flex; align-items:center; gap:8px; padding:8px; cursor:pointer}
.start-menu .item:hover{background:#dcdcdc}
.start-menu .item svg{width:18px; height:18px; stroke:#000}
.start-menu .hr{height:1px; background:#ccc; margin:4px 0}

/* Sticky notes */

/* About window */
.content-section.about .about-hero{display:flex; flex-direction:column; align-items:center; gap:16px; margin:0 0 16px}
.content-section.about .about-portrait{display:flex; flex-direction:column; align-items:center; gap:12px}
.content-section.about .about-hero img{width:160px; max-width:100%; height:auto; border:2px solid var(--dark); border-radius:12px; background:var(--light); box-shadow:inset -2px -2px 0 rgba(0,0,0,0.18)}
.content-section.about .about-social{width:100%; display:flex; justify-content:center}
.content-section.about .about-social ul{list-style:none; display:flex; flex-direction:column; gap:10px; padding:0; margin:0; width:100%}
.content-section.about .about-social a{display:block; padding:8px 14px; color:#000; text-decoration:none; background:linear-gradient(145deg, #fefefe, #d9d9d9); border:2px solid var(--dark); border-radius:8px; box-shadow:inset -1px -1px 0 var(--light), inset 1px 1px 0 rgba(0,0,0,0.2); text-align:center}
.content-section.about .about-social a:focus-visible{outline:2px dashed var(--titlebar); outline-offset:3px}
.content-section.about .about-social a:hover,
.content-section.about .about-social a:focus{background:linear-gradient(145deg, var(--accent), #f1d85a)}
.content-section.about .about-social a:active{box-shadow:inset 2px 2px 0 rgba(0,0,0,0.18); background:linear-gradient(145deg, #f1d85a, var(--accent-dim))}
.content-section.about .about-blurb{display:flex; flex-direction:column; gap:12px; max-width:65ch; text-align:left}
.content-section.about .about-columns{display:flex; flex-direction:column; gap:16px}
.content-section.about .about-panels{flex:1; min-width:0}
.about-options{display:flex; flex-direction:column; gap:8px; align-self:flex-start}
.about-option{padding:8px 12px; border:2px solid var(--dark); background:var(--win); text-align:left; cursor:pointer; font:inherit}
.about-option.is-active{background:var(--accent); border-color:var(--accent-dim)}
.about-option:focus-visible{outline:2px dashed var(--titlebar); outline-offset:2px}
.about-panel{display:none}
.about-panel.is-active{display:block}

@media (min-width:640px){
  .content-section.about .about-hero{flex-direction:row; align-items:flex-start; gap:24px}
  .content-section.about .about-portrait{align-items:center}
  .content-section.about .about-social ul{align-items:stretch}
  .content-section.about .about-hero img{width:200px; flex:0 0 auto}
  .content-section.about .about-blurb{align-items:flex-start}
  .content-section.about .about-columns{flex-direction:row; align-items:flex-start}
  .about-options{min-width:140px}
}
/* Publishers window */
.publishers-intro, .publishers-outro{max-width:62ch}
.publisher-carousel{margin-top:20px; display:flex; flex-direction:column; gap:12px}
.publisher-viewport{position:relative; overflow:hidden; border:2px solid var(--dark); border-radius:18px; background:linear-gradient(145deg, #fefefe, #e4e4e4); box-shadow:inset -2px -2px 0 rgba(0,0,0,0.18)}
.publisher-viewport:focus-visible{outline:2px dashed var(--titlebar); outline-offset:4px}
.publisher-track{display:flex; gap:18px; list-style:none; margin:0; padding:24px; transition:transform 800ms cubic-bezier(.33,.11,.15,.99)}
.publisher-slide{flex:0 0 clamp(240px, 60vw, 320px); display:flex; align-items:stretch}
.publisher-slide figure{margin:0; display:flex; flex-direction:column; gap:12px; width:100%; transition:transform 400ms ease, box-shadow 400ms ease}
.publisher-slide img{width:100%; height:auto; border-radius:14px; border:2px solid var(--dark); box-shadow:0 4px 12px rgba(0,0,0,.22)}
.publisher-slide figcaption{display:flex; flex-direction:column; gap:6px}
.publisher-slide h3{margin:0; font-size:18px}
.publisher-slide p{margin:0; font-size:14px; line-height:1.45}
.publisher-slide.is-active figure{transform:translateY(-6px); box-shadow:0 10px 20px rgba(0,0,0,.25)}
.publisher-controls{display:flex; justify-content:center; gap:12px}
.publisher-nav{width:40px; height:40px; border-radius:50%; border:2px solid var(--dark); background:var(--win); font-weight:700; cursor:pointer; display:flex; align-items:center; justify-content:center; box-shadow:inset -1px -1px 0 var(--light), inset 1px 1px 0 rgba(0,0,0,0.25)}
.publisher-nav:focus-visible{outline:2px dashed var(--titlebar); outline-offset:2px}
.publisher-nav:active{background:var(--accent)}

@media (prefers-reduced-motion: reduce){
  .publisher-track{transition:none}
  .publisher-slide figure{transition:none}
}

/* Placements window */
.content-section.projects .placements-list{display:flex; flex-direction:column; gap:24px; max-width:720px; margin:0 auto}
.placements-card{border:2px solid var(--dark); border-radius:14px; background:linear-gradient(135deg, #fefefe, #e3e3e3); box-shadow:inset -2px -2px 0 rgba(0,0,0,.18); padding:18px 20px; display:flex; flex-direction:column; gap:16px}
.placements-card h3{margin:0; font-size:20px}
.placements-details{display:flex; flex-direction:column; gap:18px}
.placements-copy{display:flex; flex-direction:column; gap:18px}
.placements-blurb{margin:0}
.placements-tracks{margin:0; padding:0; list-style:none; display:flex; flex-direction:column; gap:18px}
.placements-tracks li{display:flex; flex-direction:column; gap:8px}
.placements-track-description{font-weight:600}
.placements-tracks audio{width:100%; max-width:100%}
.placements-figure{margin:0; display:flex; flex-direction:column; gap:8px}
.placements-image{display:block; width:100%; height:auto; border-radius:8px}
.placements-image:not(img){aspect-ratio:3/2; border:2px dashed var(--dark); background:repeating-linear-gradient(135deg, rgba(0,0,0,.08) 0, rgba(0,0,0,.08) 16px, transparent 16px, transparent 32px)}
.placements-tracklist{display:grid; gap:8px; padding:12px; border:1px solid var(--dark); border-radius:10px; background:rgba(255,255,255,.72)}
.placements-tracklist h4{margin:0; font-size:16px}
.placements-tracklist p{margin:0}

@media (min-width:640px){
  .placements-card{gap:22px}
  .placements-card h3{font-size:22px}
  .placements-details{flex-direction:row; align-items:flex-start; gap:24px}
  .placements-figure{flex:0 0 260px; max-width:320px}
  .placements-copy{flex:1}
}

/* Solitaire window */
.window.solitaire .content{
  padding:0;
  background:radial-gradient(circle at top left, #3fa55b, #0b4a1d 70%);
  color:#fff;
}

.window.solitaire .solitaire-board{
  --card-width:88px;
  --card-height:124px;
  --tableau-faceup-offset:32px;
  --tableau-facedown-offset:18px;
  --solitaire-gap:clamp(10px, 2vw, 20px);
  display:flex;
  flex-direction:column;
  gap:var(--solitaire-gap);
  padding:18px;
  min-height:100%;
  box-sizing:border-box;
  user-select:none;
  position:relative;
}

.window.solitaire .solitaire-top-row{
  display:flex;
  align-items:flex-start;
  gap:var(--solitaire-gap);
}

.window.solitaire .foundation-group{
  display:flex;
  gap:var(--solitaire-gap);
  margin-left:auto;
}

.window.solitaire .solitaire-tableau{
  display:grid;
  grid-template-columns:repeat(7, var(--card-width));
  gap:var(--solitaire-gap);
  justify-content:flex-start;
}

.window.solitaire .pile{
  position:relative;
  width:var(--card-width);
  min-height:var(--card-height);
  border-radius:10px;
  border:2px dashed rgba(255,255,255,0.4);
  background:rgba(255,255,255,0.08);
  box-shadow:inset 0 0 0 1px rgba(0,0,0,0.25);
  transition:border-color 0.2s ease;
}

.window.solitaire .pile::before{
  content:'';
  position:absolute;
  inset:6px;
  border-radius:8px;
  border:1px dashed rgba(255,255,255,0.2);
  pointer-events:none;
}

.window.solitaire .pile.is-empty{
  border-color:rgba(255,255,255,0.65);
}

.window.solitaire .pile[data-pile-type="tableau"]{
  min-height:calc(var(--computed-height, var(--card-height)));
}

.window.solitaire .pile[data-pile-type="stock"],
.window.solitaire .pile[data-pile-type="waste"],
.window.solitaire .pile[data-pile-type="foundation"]{
  min-height:var(--card-height);
}

.window.solitaire .solitaire-card{
  position:absolute;
  top:0;
  left:0;
  width:var(--card-width);
  height:var(--card-height);
  border-radius:12px;
  border:2px solid rgba(255,255,255,0.9);
  background:rgba(255,255,255,0.85);
  background-image:url('assets/img/logo.png');
  background-size:cover;
  background-position:center;
  box-shadow:0 6px 12px rgba(0,0,0,0.35);
  display:flex;
  align-items:flex-start;
  justify-content:flex-start;
  padding:6px;
  box-sizing:border-box;
  transition:transform 0.15s ease, box-shadow 0.15s ease;
}

.window.solitaire .solitaire-card.is-face-down{
  filter:saturate(0.3) brightness(0.75);
}

.window.solitaire .solitaire-card.is-face-up{
  filter:none;
}

.window.solitaire .solitaire-card.is-hidden{
  display:none;
}

.window.solitaire .solitaire-card .card-label{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:28px;
  padding:2px 6px;
  border-radius:6px;
  background:rgba(255,255,255,0.85);
  color:#111;
  font-weight:700;
  font-size:clamp(0.7rem, 1.4vw, 1rem);
  box-shadow:0 1px 3px rgba(0,0,0,0.35);
}

.window.solitaire .solitaire-card.is-face-down .card-label{
  opacity:0;
}

.window.solitaire .solitaire-card:focus-visible{
  outline:3px solid #ffe066;
  outline-offset:2px;
}

.window.solitaire .solitaire-drag-ghost{
  position:fixed;
  pointer-events:none;
  z-index:10000;
}

.window.solitaire .solitaire-drag-ghost .ghost-card{
  position:absolute;
  pointer-events:none;
  filter:drop-shadow(0 8px 10px rgba(0,0,0,0.45));
}

.window.solitaire .solitaire-board.is-complete::after{
  content:'You win!';
  position:absolute;
  inset:auto 18px 18px auto;
  background:rgba(255,255,255,0.85);
  color:#064420;
  padding:10px 18px;
  border-radius:12px;
  font-weight:700;
  font-size:1rem;
  box-shadow:0 10px 20px rgba(0,0,0,0.35);
}

.window.solitaire .pile[data-pile-type="waste"] .solitaire-card{
  transition:none;
}

@media (max-width:900px){
  .window.solitaire .solitaire-board{
    padding:14px;
  }
  .window.solitaire .solitaire-tableau{
    gap:clamp(8px, 1.5vw, 14px);
  }
  .window.solitaire .foundation-group{
    gap:clamp(8px, 1.5vw, 14px);
  }
}
