/* ============================================================
   Olive Garden — hi-fi portfolio OS
   Moss dominant · terracotta accent · Martian Mono
   ============================================================ */
@font-face {
  font-family: 'Martian Mono';
  src: url('fonts/MartianMono.ttf') format('truetype-variations');
  font-weight: 100 800;
  font-stretch: 75% 112.5%;
  font-style: normal;
  font-display: swap;
}

:root{
  /* moss desktop */
  --bg:        #3a4525;   /* the desktop floor */
  --bg-2:      #2c3520;   /* deeper moss */
  --bg-3:      #232b18;   /* sidebar */
  --surface:   #46532e;
  --moss-light:#a8b582;
  --sage:      #c8cfa8;

  /* paper / windows */
  --paper:     #f1ead0;
  --paper-2:   #e6dcba;
  --paper-3:   #d8cda6;

  /* ink */
  --ink:       #1d1c1a;
  --ink-2:     #3a352e;
  --muted:     #7a7468;

  /* terracotta accent */
  --accent:    #c0623a;
  --accent-deep: #8a3f23;
  --accent-light:#e9a682;
  --accent-dim:#39250f;

  /* borders */
  --border-paper: rgba(29,28,26,.16);
  --border-paper-strong: rgba(29,28,26,.5);
  --border-moss: rgba(168,181,130,.18);

  /* type */
  --font:'Martian Mono', ui-monospace, SFMono-Regular, Menlo, monospace;
  --t-xxs: 8px;
  --t-xs:  9px;
  --t-sm:  10px;
  --t-md:  11px;
  --t-base:12.5px;
  --t-lg:  15px;
  --t-xl:  20px;
  --t-display: clamp(62px, 13.5vw, 196px);

  --ls-cap-sm:  0.13em;
  --ls-cap:     0.18em;
  --ls-cap-wide:0.22em;
  --ls-cap-x:   0.26em;
  --ls-display: -0.03em;
}

*, *::before, *::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  background:var(--bg);
  color:var(--moss-light);
  font-family:var(--font);
  font-size:var(--t-base);
  line-height:1.6;
  font-weight:400;
  overflow:hidden;
  cursor:none;
}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:none}

/* ============================================================
   Custom cursor — precise dot + magnetic ring + ink ripple
   No mix-blend-mode; hotspot always matches real mouse position
   ============================================================ */

/* Fixed 30×30 container always centred on exact mouse position.
   No transform transition — position is set synchronously in JS. */
.cursor{
  position:fixed;top:0;left:0;
  width:30px;height:30px;
  pointer-events:none;z-index:2147483647;
  will-change:transform;
}

/* The visual part lives in ::before so it can animate independently
   without disturbing the hotspot container size/position */
.cursor::before{
  content:'';
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:7px;height:7px;
  border-radius:50%;
  background:var(--accent);
  transition:width .13s ease, height .13s ease,
             background .13s ease, border .13s ease,
             border-radius .13s ease, opacity .13s ease;
}

/* Magnetic zone — dot expands into a ring */
.cursor.near::before{
  width:20px;height:20px;
  background:transparent;
  border:1.5px solid var(--accent);
}

/* Directly over interactive element — ring grows slightly */
.cursor.hov::before{
  width:26px;height:26px;
  background:transparent;
  border:2px solid var(--accent-light);
}

/* Slight shrink on press */
body:active .cursor::before{opacity:.55;transform:translate(-50%,-50%) scale(.75)}

/* Ink ripple spawned at exact click position */
.cursor-ripple{
  position:fixed;pointer-events:none;z-index:2147483646;
  width:44px;height:44px;
  margin:-22px 0 0 -22px;
  border:1.5px solid var(--accent);
  border-radius:50%;
  animation:cursor-ripple-go .55s ease-out forwards;
}
@keyframes cursor-ripple-go{
  0%  {transform:scale(.08);opacity:.9}
  100%{transform:scale(2.2);opacity:0}
}

/* ============================================================
   Desktop canvas (ASCII donut)
   ============================================================ */
.donut{
  position:fixed;inset:0;width:100%;height:100%;z-index:0;
  pointer-events:auto;
}
.donut.takeover{z-index:9990}

/* Scanlines overlay — over everything except cursor */
.scanlines::after{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:900;
  background:repeating-linear-gradient(to bottom, transparent 0 3px, rgba(0,0,0,.10) 3px 4px);
}

/* ============================================================
   Menu bar (top)
   ============================================================ */
.menubar{
  position:fixed;top:0;left:0;right:0;height:30px;z-index:300;
  display:flex;align-items:center;gap:18px;padding:0 18px;
  font-size:var(--t-sm);letter-spacing:var(--ls-cap);text-transform:uppercase;
  color:var(--moss-light);
  background:rgba(0,0,0,.18);
  backdrop-filter:none;
  border-bottom:1px solid var(--border-moss);
}
.menubar .logo{
  display:flex;align-items:center;gap:8px;color:var(--paper);font-weight:700;letter-spacing:var(--ls-cap-wide);
}
.menubar .logo .dot{width:8px;height:8px;background:var(--accent);display:inline-block}
.menubar .item{cursor:none;transition:color .2s}
.menubar .item:hover{color:var(--paper)}
.menubar .crumb{color:var(--accent-light);font-weight:500}
.menubar .right{margin-left:auto;display:flex;gap:18px;align-items:center}
.menubar .status{display:flex;align-items:center;gap:7px;cursor:none}
.menubar .status .bdot{width:7px;height:7px;background:var(--accent);animation:blink 1.1s step-end infinite}
.menubar .status.flash .bdot{animation:flash .4s steps(2) 6}
@keyframes blink{50%{opacity:0}}
@keyframes flash{50%{background:var(--moss-light)}}
.menubar .clock{color:var(--moss-light);min-width:128px;text-align:right}

/* Menu bar — button resets (items are now <button> elements) */
.menubar button.item,
.menubar button.item:focus{
  background:none;border:none;padding:0;
  font:inherit;letter-spacing:inherit;text-transform:inherit;color:inherit;
}
.menubar .item.open{color:var(--paper)}
.menubar .term-quick{opacity:.7;letter-spacing:0;font-size:var(--t-sm)}
.menubar .term-quick:hover{opacity:1;color:var(--paper)}

/* Dropdown wrapper — needs relative positioning for the panel */
.menu-wrap{position:relative;display:flex;align-items:center}

/* Dropdown panel */
.menu-dropdown{
  position:absolute;top:calc(100% + 3px);left:0;
  min-width:190px;
  background:var(--ink);
  border:1px solid var(--border-moss);
  padding:4px 0;
  z-index:800;
  box-shadow:0 10px 28px rgba(0,0,0,.3);
}
/* Items */
.menu-dropdown .mi{
  display:block;width:100%;
  text-align:left;
  padding:5px 14px 5px 30px;
  font-size:var(--t-sm);letter-spacing:var(--ls-cap);text-transform:uppercase;
  color:var(--moss-light);
  background:none;border:none;
  font-family:inherit;
  transition:background .1s,color .1s;
  cursor:none;
  position:relative;
  text-decoration:none;
}
.menu-dropdown .mi:hover{background:var(--accent);color:var(--paper)}
/* Active checkmark */
.menu-dropdown .mi.check::before{
  content:'✓';
  position:absolute;left:11px;top:50%;transform:translateY(-50%);
  font-size:8px;color:var(--accent-light);
}
.menu-dropdown .mi.check:hover::before{color:var(--paper)}
/* Section labels */
.menu-dropdown .mi-label{
  padding:7px 14px 3px;
  font-size:var(--t-xs);letter-spacing:var(--ls-cap-wide);text-transform:uppercase;
  color:var(--muted);pointer-events:none;user-select:none;
}
/* Separator */
.menu-dropdown .sep{height:1px;background:var(--border-moss);margin:4px 0}

/* Studio palette — dropdown on light background needs dark ink */
html[data-palette="studio"] .menu-dropdown{
  background:var(--paper);
  border-color:rgba(0,0,0,.12);
  box-shadow:0 10px 28px rgba(0,0,0,.15);
}
html[data-palette="studio"] .menu-dropdown .mi{color:var(--ink-2)}
html[data-palette="studio"] .menu-dropdown .mi:hover{background:var(--accent);color:var(--paper)}
html[data-palette="studio"] .menu-dropdown .sep{background:rgba(0,0,0,.1)}
html[data-palette="studio"] .menu-dropdown .mi-label{color:rgba(0,0,0,.35)}

/* ============================================================
   Desktop icons — fixed left column, above wallpaper, below windows
   ============================================================ */
.desktop-icons{
  position:fixed;top:38px;left:0;bottom:66px;
  width:88px;z-index:5;
  display:flex;flex-direction:column;align-items:center;
  gap:2px;padding:12px 4px;
  pointer-events:none;
  overflow:hidden;
}
.di{
  pointer-events:all;
  width:80px;
  display:flex;flex-direction:column;align-items:center;gap:4px;
  padding:6px 4px 5px;
  border:1px solid transparent;border-radius:5px;
  cursor:none;transition:background .15s,border-color .15s;
  user-select:none;background:none;color:var(--paper);
}
.di:hover{background:rgba(255,255,255,.13);border-color:rgba(255,255,255,.22)}
.di.open{background:rgba(255,255,255,.08)}
.di-icon{display:flex;align-items:center;justify-content:center;width:48px;height:44px}
.di-label{
  font-size:9px;letter-spacing:.05em;line-height:1.2;text-align:center;
  color:var(--paper);
  text-shadow:0 1px 4px rgba(0,0,0,.75),0 0 8px rgba(0,0,0,.4);
  max-width:76px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
  font-family:var(--font);
}
/* Studio palette has light bg — labels need dark text */
html[data-palette="studio"] .di-label{color:var(--ink-2);text-shadow:none}
html[data-palette="studio"] .di:hover{background:rgba(0,0,0,.07);border-color:rgba(0,0,0,.12)}

/* ============================================================
   Dock — horizontal bottom bar
   ============================================================ */
.dock{
  position:fixed;bottom:0;left:0;right:0;height:58px;z-index:310;
  display:flex;align-items:center;justify-content:center;
  background:rgba(0,0,0,.28);
  border-top:1px solid var(--border-moss);
  backdrop-filter:blur(6px);
}
.dock-inner{
  display:flex;align-items:center;gap:3px;
  padding:0 10px;
}
.dock-item{
  width:44px;height:44px;
  display:flex;align-items:center;justify-content:center;
  color:var(--moss-light);
  border:1px solid transparent;border-radius:8px;
  position:relative;
  transition:color .18s,background .18s,transform .12s;
  cursor:none;
}
.dock-item:hover{
  color:var(--paper);
  background:rgba(255,255,255,.09);
  transform:translateY(-3px);
}
.dock-item.open{color:var(--paper)}
.dock-item.open::after{
  content:'';position:absolute;bottom:3px;left:50%;transform:translateX(-50%);
  width:3px;height:3px;border-radius:50%;background:var(--accent);
}
.dock-sep{width:1px;height:26px;background:var(--border-moss);margin:0 5px;flex-shrink:0}
/* Studio palette dock */
html[data-palette="studio"] .dock{background:rgba(180,165,120,.35);border-top-color:rgba(0,0,0,.1)}
html[data-palette="studio"] .dock-item{color:var(--ink-2)}
html[data-palette="studio"] .dock-item:hover{color:var(--ink);background:rgba(0,0,0,.06)}

/* ============================================================
   Window (generic)
   ============================================================ */
.win{
  position:absolute;
  background:var(--paper);
  color:var(--ink);
  border:1px solid var(--ink);
  box-shadow:2px 3px 0 rgba(0,0,0,.18), 0 0 0 1px rgba(0,0,0,.05);
  display:flex;flex-direction:column;
  min-width:260px;min-height:140px;
  user-select:none;
}
.win.focused{box-shadow:3px 5px 0 rgba(0,0,0,.30), 0 0 0 1px rgba(0,0,0,.08)}
.win-titlebar{
  display:flex;align-items:center;gap:10px;
  padding:6px 10px;background:var(--paper-2);
  border-bottom:1px solid var(--ink);
  font-size:var(--t-sm);letter-spacing:var(--ls-cap);text-transform:uppercase;
  cursor:none;
}
.win.dragging .win-titlebar{cursor:none}
.win.focused .win-titlebar{background:var(--paper-3)}
.win-dots{display:flex;gap:5px}
.win-dot{width:14px;height:14px;border-radius:50%;border:1px solid rgba(0,0,0,.45);cursor:none;background:var(--paper-3);
  display:flex;align-items:center;justify-content:center;padding:0;
}
.win-dot svg{opacity:1;transition:opacity .15s}
.win-dot.close{background:var(--accent)}
.win-dot.min{background:var(--accent-light)}
.win-dot.max{background:var(--moss-light)}
.win-title{flex:1;font-weight:500;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.win-meta{font-size:var(--t-xs);letter-spacing:var(--ls-cap);color:var(--muted);display:flex;align-items:center;gap:6px}
.win-meta .pip{width:6px;height:6px;background:var(--accent);border-radius:50%}

.win-body{
  flex:1;overflow:auto;
  font-size:var(--t-base);color:var(--ink);
  scrollbar-width:thin;scrollbar-color:var(--accent) transparent;
  position:relative;
}
.win-body::-webkit-scrollbar{width:8px}
.win-body::-webkit-scrollbar-thumb{background:var(--accent);border-radius:0}

/* Editable text inside paper windows */
.win-body.editable{caret-color:var(--accent);outline:none}
.win-body.editable [contenteditable="false"]{caret-color:auto}
.win-body.editable :focus{outline:none}
.win-body.editable [contenteditable="false"]:focus,
.win-body.editable button:focus,
.win-body.editable a:focus{outline:none}
/* subtle hint on hover of editable text containers */
.win-body.editable p:hover,
.win-body.editable .lead:hover,
.win-body.editable .body-p:hover,
.win-body.editable .hi-display:hover,
.win-body.editable .hi-medium:hover,
.win-body.editable .asub:hover,
.win-body.editable .desc:hover,
.win-body.editable .title:hover,
.win-body.editable .role:hover,
.win-body.editable .place:hover,
.win-body.editable .ptitle:hover,
.win-body.editable .excerpt:hover,
.win-body.editable .h-line:hover{
  background:rgba(192,98,58,.05);
  box-shadow:inset 0 -1px 0 rgba(192,98,58,.25);
}

.win-resize{
  position:absolute;right:0;bottom:0;width:14px;height:14px;
  background:linear-gradient(135deg, transparent 50%, var(--ink) 50%, var(--ink) 60%, transparent 60%, transparent 70%, var(--ink) 70%, var(--ink) 80%, transparent 80%);
  cursor:none;
}

/* Minimised: collapse to titlebar-only strip */
.win.minimized{
  height:auto !important;
  width:auto !important;       /* let content dictate width... */
  min-width:200px;             /* ...but not too narrow */
  max-width:300px;             /* cap it — no full-width banners */
  opacity:.82;                 /* dimmed so it reads as "inactive/sleeping" */
}
.win.minimized .win-body{display:none}
.win.minimized .win-resize{display:none}
/* Slightly different titlebar bg so minimised windows feel "rolled up" */
.win.minimized .win-titlebar{
  background:var(--paper);
  border-bottom:1px dashed var(--border-paper-strong);
}

/* Maximised: hide resize handle, prevent titlebar drag affordance */
.win.maximized .win-resize{display:none}
.win.maximized .win-titlebar{cursor:default}

/* ============================================================
   Window content patterns (reusable)
   ============================================================ */
.slabel{
  font-size:var(--t-xs);letter-spacing:var(--ls-cap-x);text-transform:uppercase;
  color:var(--accent);display:flex;align-items:center;gap:14px;
}
.slabel::after{content:"";flex:1;height:1px;background:var(--border-paper-strong)}

.hi-display{
  font-size:48px;font-weight:700;line-height:.92;letter-spacing:var(--ls-display);
  text-transform:uppercase;color:var(--ink);margin:14px 0 8px;
}
.hi-display .dot{color:var(--accent)}
.hi-medium{font-size:32px;font-weight:700;line-height:.95;letter-spacing:-.02em;text-transform:uppercase;color:var(--ink)}
.hi-medium .dot{color:var(--accent)}

.lead{
  font-size:var(--t-lg);font-weight:300;line-height:1.55;color:var(--ink);
  max-width:48ch;
}
.lead em{color:var(--accent);font-style:normal}

.asub{font-size:var(--t-md);color:var(--muted);line-height:1.6;max-width:48ch}

.body-p{font-size:var(--t-base);color:var(--ink);line-height:1.6;margin-bottom:8px}
.body-p em{color:var(--accent);font-style:normal}

.tag{
  display:inline-block;font-size:var(--t-xxs);letter-spacing:var(--ls-cap-sm);text-transform:uppercase;
  color:var(--ink-2);border:1px solid var(--border-paper-strong);padding:3px 8px;
}
.tag-row{display:flex;flex-wrap:wrap;gap:6px}
.tag-link{color:var(--accent);border-color:var(--accent);cursor:none;transition:background .15s,color .15s}
.tag-link:hover{background:var(--accent);color:var(--paper)}

.metric{font-size:38px;font-weight:700;color:var(--accent);line-height:1;letter-spacing:-.02em}
.metric-label{font-size:var(--t-xs);letter-spacing:var(--ls-cap);text-transform:uppercase;color:var(--muted);margin-top:6px}

.kv{display:flex;justify-content:space-between;gap:10px;font-size:var(--t-md);padding:4px 0;border-bottom:1px solid var(--border-paper)}
.kv:last-child{border-bottom:none}
.kv .k{color:var(--muted);letter-spacing:var(--ls-cap-sm);text-transform:uppercase}

.outlink{
  display:inline-flex;align-items:center;gap:6px;
  font-size:var(--t-xs);letter-spacing:var(--ls-cap);text-transform:uppercase;
  color:var(--ink-2);transition:color .2s;cursor:none;
  border-bottom:1px solid transparent;padding-bottom:1px;
}
.outlink:hover{color:var(--accent);border-bottom-color:var(--accent)}

.divider{height:1px;background:var(--border-paper-strong);margin:14px 0}

/* file list (folder window) */
.filelist{font-size:var(--t-md)}
.filelist .row{
  display:grid;grid-template-columns:18px 1fr auto;gap:10px;align-items:center;
  padding:7px 14px;border-bottom:1px dashed var(--border-paper);cursor:none;
  transition:background .15s;
}
.filelist .row:hover{background:var(--paper-2)}
.filelist .row:last-child{border-bottom:none}
.filelist .row .ico{
  width:16px;height:12px;background:var(--accent);position:relative;
}
.filelist .row .ico::before{content:"";position:absolute;left:0;top:-3px;width:6px;height:3px;background:var(--accent)}
.filelist .row .ico.txt{background:var(--paper-3);border:1px solid var(--ink-2)}
.filelist .row .ico.txt::before{display:none}
.filelist .row .ico.img{background:var(--moss-light)}
.filelist .row .ico.img::before{display:none}
.filelist .row .name{font-weight:500;color:var(--ink)}
.filelist .row .ext{font-size:var(--t-xs);letter-spacing:var(--ls-cap);text-transform:uppercase;color:var(--muted)}

/* project card */
.project{
  padding:14px 16px;border-bottom:1px solid var(--border-paper-strong);
  display:grid;grid-template-columns:80px 1fr;gap:18px;align-items:start;
}
.project:last-child{border-bottom:none}
.project .num{font-size:var(--t-xs);letter-spacing:var(--ls-cap);color:var(--muted)}
.project .title{font-size:var(--t-lg);font-weight:500;color:var(--ink);margin-bottom:6px;line-height:1.25}
.project .desc{font-size:var(--t-md);color:var(--ink-2);line-height:1.6;margin-bottom:10px}
.project .met{font-size:24px;font-weight:700;color:var(--accent);line-height:1;margin-bottom:4px}
.project .met-l{font-size:var(--t-xs);letter-spacing:var(--ls-cap);text-transform:uppercase;color:var(--muted)}

/* timeline */
.timeline{position:relative;padding-left:24px}
.timeline::before{content:"";position:absolute;left:6px;top:6px;bottom:6px;width:1px;background:var(--ink-2)}
.timeline .ev{position:relative;padding:0 0 16px}
.timeline .ev::before{
  content:"";position:absolute;left:-21px;top:6px;width:11px;height:11px;
  background:var(--accent);border:1.5px solid var(--ink);border-radius:50%;
}
.timeline .ev .yr{font-size:var(--t-xs);letter-spacing:var(--ls-cap);text-transform:uppercase;color:var(--muted);margin-bottom:3px}
.timeline .ev .role{font-size:var(--t-md);font-weight:500;color:var(--ink);margin-bottom:3px}
.timeline .ev .place{font-size:var(--t-md);color:var(--ink-2)}
.timeline .ev .note{font-size:var(--t-xs);color:var(--muted);margin-top:4px;letter-spacing:var(--ls-cap-sm);text-transform:uppercase}

/* writing list */
.posts .post{
  padding:12px 16px;border-bottom:1px solid var(--border-paper-strong);cursor:none;transition:background .15s;
}
.posts .post:hover{background:var(--paper-2)}
.posts .post:last-child{border-bottom:none}
.posts .post .meta{font-size:var(--t-xs);letter-spacing:var(--ls-cap);text-transform:uppercase;color:var(--muted)}
.posts .post .ptitle{font-size:var(--t-md);font-weight:500;color:var(--ink);margin:4px 0 4px;line-height:1.4}
.posts .post .excerpt{font-size:var(--t-xs);color:var(--ink-2);line-height:1.6}
.posts .post .read-more{
  font-size:var(--t-xs);letter-spacing:var(--ls-cap);text-transform:uppercase;
  color:var(--accent);margin-top:6px;opacity:0;transition:opacity .15s;
}
.posts .post:hover .read-more{opacity:1}

/* post reader view (inside writing window) */
.post-reader-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:7px 14px;border-bottom:1px solid var(--border-paper-strong);
  background:var(--paper-2);flex-shrink:0;
}
.back-btn{
  font-size:var(--t-xs);letter-spacing:var(--ls-cap);text-transform:uppercase;
  color:var(--ink-2);border:1px solid var(--border-paper-strong);
  padding:3px 10px;cursor:none;transition:color .15s,background .15s,border-color .15s;
}
.back-btn:hover{color:var(--paper);background:var(--accent);border-color:var(--accent)}
.post-reader-tag{
  font-size:var(--t-xs);letter-spacing:var(--ls-cap);text-transform:uppercase;color:var(--muted);
}
.post-reader{
  padding:20px 22px 24px;overflow-y:auto;flex:1;
}
.post-reader-title{
  font-size:var(--t-lg);font-weight:500;color:var(--ink);line-height:1.35;
  margin-bottom:18px;padding-bottom:14px;border-bottom:1px solid var(--border-paper);
}
.post-reader-body p{
  font-size:var(--t-md);color:var(--ink-2);line-height:1.75;margin-bottom:14px;
}
.post-reader-body p:last-child{margin-bottom:0}
.post-reader-draft{
  font-size:var(--t-sm);letter-spacing:var(--ls-cap);text-transform:uppercase;
  color:var(--muted);text-align:center;padding:36px 0;
}

/* photo grid */
.photos{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--ink);padding:0;border-top:1px solid var(--ink)}
.photos .ph{
  position:relative;aspect-ratio:4/3;background:var(--moss-light);overflow:hidden;
  cursor:none;
}
.photos .ph::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, transparent 50%, rgba(0,0,0,.45) 100%);
}
.photos .ph .ptag{
  position:absolute;left:8px;bottom:6px;z-index:2;
  font-size:var(--t-xs);letter-spacing:var(--ls-cap);text-transform:uppercase;color:var(--paper);
}
.photos .ph .pyr{
  position:absolute;right:8px;top:6px;z-index:2;
  font-size:var(--t-xxs);letter-spacing:var(--ls-cap-sm);color:var(--paper);opacity:.8;
}
/* synthesized landscape SVG fills via classes */
.photos .ph svg{position:absolute;inset:0;width:100%;height:100%;display:block}

/* hobbies grid */
.hobbies-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;padding:14px 16px}
.hobby{
  background:var(--paper-2);border:1px solid var(--border-paper-strong);padding:14px;
  display:flex;flex-direction:column;gap:6px;cursor:none;transition:background .15s, transform .15s;
}
.hobby:hover{background:var(--paper-3);transform:translateY(-1px)}
.hobby .h-ico{width:42px;height:42px;display:flex;align-items:center;justify-content:center;margin-bottom:4px}
.hobby .h-name{font-size:var(--t-md);font-weight:500;color:var(--ink);letter-spacing:.04em}
.hobby .h-meta{font-size:var(--t-xs);letter-spacing:var(--ls-cap);text-transform:uppercase;color:var(--muted)}
.hobby .h-line{font-size:var(--t-xs);color:var(--ink-2);line-height:1.5}

/* terminal */
.terminal{
  background:#13140e;color:var(--moss-light);font-family:var(--font);
  font-size:var(--t-md);line-height:1.65;padding:14px 16px;
  height:100%;overflow:auto;
}
.terminal .ln{white-space:pre-wrap;word-break:break-word}
.terminal .pr{color:var(--accent-light);user-select:none;white-space:pre}
.terminal .arg{color:var(--paper)}
.terminal .ok{color:var(--moss-light)}
.terminal .err{color:var(--accent)}
.terminal .dim{color:var(--muted)}
.terminal .accent{color:var(--accent)}
.terminal .row{display:flex;gap:0;align-items:baseline;width:100%}
.terminal .row input,
.terminal .row textarea{
  flex:1 1 auto;
  min-width:240px;
  background:transparent;border:none;outline:none;color:var(--paper);
  font:inherit;
  caret-color:var(--accent-light);
  resize:none;
  padding:0;
  margin:0;
  height:1.6em;
  line-height:inherit;
}
.terminal .cur{
  display:inline-block;width:7px;height:13px;background:var(--moss-light);
  vertical-align:-2px;animation:blink 1s steps(2) infinite;margin-left:1px;
  flex:none;
}
.terminal pre{margin:0;color:var(--accent-light);line-height:1.05;font-size:9.5px;white-space:pre}

/* contact */
.contact{padding:18px 18px 22px}
.contact .row{
  display:grid;grid-template-columns:90px 1fr;gap:14px;padding:9px 0;
  border-bottom:1px solid var(--border-paper);align-items:center;
}
.contact .row:last-child{border-bottom:none}
.contact .row .k{font-size:var(--t-xs);letter-spacing:var(--ls-cap);text-transform:uppercase;color:var(--muted)}
.contact .row .v{font-size:var(--t-md);color:var(--ink)}
.contact .row a.v{color:var(--ink);border-bottom:1px solid transparent;transition:color .2s, border-color .2s}
.contact .row a.v:hover{color:var(--accent);border-bottom-color:var(--accent)}

/* about window grid */
.about-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:0;height:100%}
.about-grid .l{padding:22px 24px;overflow:auto}
.about-grid .r{padding:22px 20px;background:var(--paper-2);border-left:1px solid var(--border-paper-strong);overflow:auto;display:flex;flex-direction:column;gap:14px}
.about-grid .r .now{
  border:1px solid var(--ink);padding:12px;background:var(--accent);color:var(--paper);
}
.about-grid .r .now .label{font-size:var(--t-xs);letter-spacing:var(--ls-cap-x);text-transform:uppercase;opacity:.85;margin-bottom:6px}
.about-grid .r .now .line{font-size:var(--t-md);font-weight:500;line-height:1.45}
.about-grid .r .now .ddot{display:inline-block;width:7px;height:7px;background:var(--paper);border-radius:50%;margin-right:6px;animation:blink 1.1s step-end infinite}
.about-grid .r .now-sub{font-size:var(--t-xs);letter-spacing:var(--ls-cap);text-transform:uppercase;color:var(--muted);margin-top:2px}

.stack-cols{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;font-size:var(--t-xs)}
.stack-cols h5{font-size:var(--t-xs);letter-spacing:var(--ls-cap-x);text-transform:uppercase;color:var(--muted);font-weight:400;margin-bottom:6px}
.stack-cols ul{list-style:none}
.stack-cols li{display:flex;gap:8px;color:var(--ink);line-height:1.7;font-size:var(--t-md)}
.stack-cols li::before{content:"—";color:var(--accent-dim)}

/* hint at bottom */
.hint{
  position:fixed;left:50%;bottom:18px;transform:translateX(-50%);z-index:50;
  font-size:var(--t-xs);letter-spacing:var(--ls-cap-wide);text-transform:uppercase;
  color:var(--moss-light);opacity:.6;pointer-events:none;
  transition:opacity 1s;
}
.hint.hidden{opacity:0}

/* easter — donut takeover modal */
.donut-modal{
  position:fixed;inset:0;background:rgba(7,7,7,.92);z-index:9991;
  display:flex;align-items:center;justify-content:center;color:var(--accent);
  font-family:var(--font);font-size:11px;line-height:1.05;
  animation:fadeIn .3s ease;
}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.donut-modal pre{white-space:pre;color:var(--accent)}
.donut-modal .esc{
  position:absolute;bottom:30px;left:50%;transform:translateX(-50%);
  color:var(--moss-light);font-size:var(--t-xs);letter-spacing:var(--ls-cap-wide);text-transform:uppercase;
}

/* small folder labels */
.fmeta{font-size:var(--t-xs);color:var(--muted);letter-spacing:var(--ls-cap);text-transform:uppercase;padding:7px 14px;border-bottom:1px solid var(--border-paper-strong);display:flex;justify-content:space-between;align-items:center;background:var(--paper-2)}
.fmeta .count .n{color:var(--accent);font-weight:700}

/* photo lightbox */
.lightbox{
  position:fixed;inset:0;background:rgba(0,0,0,.85);z-index:8000;
  display:flex;align-items:center;justify-content:center;padding:60px;
  cursor:none;
}
.lightbox .lb-img{
  width:min(900px,80vw);aspect-ratio:4/3;background:var(--moss-light);border:1px solid var(--moss-light);
  position:relative;overflow:hidden;
}
.lightbox .lb-cap{
  position:absolute;bottom:30px;left:50%;transform:translateX(-50%);color:var(--paper);
  font-size:var(--t-xs);letter-spacing:var(--ls-cap-x);text-transform:uppercase;
}
.lightbox .lb-esc{
  position:absolute;top:30px;right:30px;color:var(--moss-light);
  font-size:var(--t-xs);letter-spacing:var(--ls-cap-wide);text-transform:uppercase;
}

/* welcome (greet) toast */
.toast{
  position:fixed;left:50%;top:60px;transform:translateX(-50%);
  background:var(--ink);color:var(--accent);
  padding:10px 14px;font-size:var(--t-xs);letter-spacing:var(--ls-cap-x);text-transform:uppercase;
  z-index:1000;border:1px solid var(--accent);
  animation:toastIn .3s ease, toastOut .4s ease 2.6s forwards;
}
@keyframes toastIn{from{opacity:0;transform:translate(-50%,-10px)}to{opacity:1;transform:translate(-50%,0)}}
@keyframes toastOut{to{opacity:0;transform:translate(-50%,-10px)}}


/* ============================================================
   TWEAKS — palette / backdrop / chrome variations
   Selected via data-attrs on <html>
   ============================================================ */

/* --- Palette: sun-baked (terracotta dominant, moss accent) --- */
html[data-palette="sun-baked"]{
  --bg:        #b35636;
  --bg-2:      #8a3f23;
  --bg-3:      #5a2a13;
  --surface:   #c66942;
  --moss-light:#f3c8a7;    /* re-used as the "secondary fg on bg" */
  --sage:      #e9a682;

  --paper:     #f4ead6;
  --paper-2:   #e6dcba;
  --paper-3:   #d8cda6;

  --accent:    #5a6a3a;    /* moss is the accent */
  --accent-deep: #34401e;
  --accent-light:#a8b582;
  --accent-dim:#1f2d10;
}

/* --- Palette: forest (deep forest bg, lime accent) --- */
html[data-palette="forest"]{
  --bg:        #1f2d10;
  --bg-2:      #15200a;
  --bg-3:      #0e1607;
  --surface:   #2a3b18;
  --moss-light:#7d8a5c;
  --sage:      #a8b582;

  --paper:     #efe6cb;
  --paper-2:   #e1d6b4;
  --paper-3:   #d2c79e;

  --accent:    #5e9c00;    /* the JJ.DEV lime */
  --accent-deep: #375704;
  --accent-light:#d8ff86;
  --accent-dim:#213a0b;
}

/* --- Palette: studio (cream bg, terra accent + sage secondaries) --- */
html[data-palette="studio"]{
  --bg:        #e6dcba;
  --bg-2:      #d8cda6;
  --bg-3:      #c8bb8a;
  --surface:   #d2c79e;
  --moss-light:#5a6a3a;    /* moss is now darker, used on the light bg */
  --sage:      #c8cfa8;

  --paper:     #fbf4dd;
  --paper-2:   #f1ead0;
  --paper-3:   #e6dcba;

  --accent:    #c0623a;
  --accent-deep: #8a3f23;
  --accent-light:#e9a682;
  --accent-dim:#39250f;
}

/* Studio menu bar needs darker contrast on cream bg */
html[data-palette="studio"] .menubar{
  background:rgba(58,69,37,.18);
  color:#3a352e;
  border-bottom-color:rgba(0,0,0,.12);
}
html[data-palette="studio"] .menubar .logo{color:var(--accent-deep)}
html[data-palette="studio"] .menubar .clock,
html[data-palette="studio"] .menubar .item{color:rgba(29,28,26,.7)}
html[data-palette="studio"] .menubar .item:hover{color:var(--ink)}
html[data-palette="studio"] body{color:var(--ink-2)}
html[data-palette="studio"] .hint{color:var(--ink-2);opacity:.55}

/* Sun-baked menu bar contrast */
html[data-palette="sun-baked"] .menubar .crumb{color:#fff7e6}
html[data-palette="sun-baked"] .menubar .clock{color:rgba(244,234,214,.8)}

/* --- Backdrop: tiles (terra/moss tile grid floor) --- */
html[data-backdrop="tiles"] body{
  background:
    repeating-linear-gradient(90deg, transparent 0, transparent 119px, rgba(0,0,0,.22) 119px, rgba(0,0,0,.22) 121px),
    repeating-linear-gradient(0deg,  transparent 0, transparent 119px, rgba(0,0,0,.22) 119px, rgba(0,0,0,.22) 121px),
    var(--bg);
  background-repeat:repeat,repeat,no-repeat;
}

/* --- Backdrop: quiet (plain flat color) --- */
html[data-backdrop="quiet"] body{background:var(--bg)}

/* --- Chrome: retro (Mac OS 9 pinstripe titlebars + chunky resize) --- */
html[data-chrome="retro"] .win{
  border:1.5px solid var(--ink);
  box-shadow:3px 4px 0 rgba(0,0,0,.32);
}
html[data-chrome="retro"] .win-titlebar{
  background-image: repeating-linear-gradient(0deg, #1d1c1a 0, #1d1c1a 1.5px, transparent 1.5px, transparent 3px);
  background-color: var(--paper-2);
  padding:5px 10px;border-bottom:1.5px solid var(--ink);
}
html[data-chrome="retro"] .win-title{
  background:var(--paper);padding:1px 10px;border:1.2px solid var(--ink);
  font-weight:500;letter-spacing:var(--ls-cap-sm);
}
html[data-chrome="retro"] .win-meta{background:var(--paper);padding:1px 7px;border:1.2px solid var(--ink)}
html[data-chrome="retro"] .win-resize{
  background:repeating-linear-gradient(135deg, #1d1c1a 0, #1d1c1a 1.5px, transparent 1.5px, transparent 4px);
  border-left:1.5px solid var(--ink);border-top:1.5px solid var(--ink);
}
html[data-chrome="retro"] .win-dot{border:1.2px solid var(--ink);box-shadow:inset 0 0 0 1px var(--paper)}

/* --- Chrome: sketchy (rough.js SVG frame, pencil hatching, hand-drawn feel) --- */

/* Remove all synthetic borders — rough.js SVG overlay draws the frame */
html[data-chrome="sketchy"] .win{
  border:none;
  box-shadow:none;
  background:var(--paper);
  overflow:visible; /* let rough paths extend slightly outside if needed */
}

/* Subtle random resting tilts (un-tilts on focus) */
html[data-chrome="sketchy"] .win:nth-of-type(odd) { transform:rotate(-0.7deg) }
html[data-chrome="sketchy"] .win:nth-of-type(even){ transform:rotate(0.5deg)  }
html[data-chrome="sketchy"] .win:nth-of-type(3n)  { transform:rotate(-0.3deg) }
html[data-chrome="sketchy"] .win.focused          { transform:rotate(0deg); transition:transform .18s ease }
html[data-chrome="sketchy"] .win.minimized        { transform:none }
html[data-chrome="sketchy"] .win.maximized        { transform:none }

/* Titlebar — pencil-hatched background instead of solid fill */
html[data-chrome="sketchy"] .win-titlebar{
  border-bottom:none; /* rough.js line replaces this */
  background-color:var(--paper-2);
  background-image:repeating-linear-gradient(
    -52deg,
    transparent,
    transparent 5px,
    rgba(0,0,0,.055) 5px,
    rgba(0,0,0,.055) 6px
  );
}

/* Window title — slightly wobbly underline to reinforce sketch feel */
html[data-chrome="sketchy"] .win-title{
  text-decoration:underline;
  text-underline-offset:3px;
  text-decoration-style:wavy;
  text-decoration-color:rgba(0,0,0,.18);
  text-decoration-thickness:1px;
}

/* Traffic-light dots — pencil circle style */
html[data-chrome="sketchy"] .win-dot{
  border:1.5px solid var(--ink);
  background:var(--paper-2);
  box-shadow:1px 1px 0 rgba(0,0,0,.15);
}
html[data-chrome="sketchy"] .win-dot.close{ border-color:var(--accent-deep) }
html[data-chrome="sketchy"] .win-dot.max  { border-color:#2a3e10 }

/* Resize handle — crosshatch corner */
html[data-chrome="sketchy"] .win-resize{
  background:none;
  border:none;
}

/* Minimized — simple sketchy strip */
html[data-chrome="sketchy"] .win.minimized{
  border:1.5px solid var(--ink) !important;
  border-style:dashed !important;
}

/* ============================================================
   GenAI 101 — lessons window
   ============================================================ */
.lessons-wrap{
  display:flex;flex-direction:column;height:100%;user-select:none;
}
.lessons-header{
  padding:10px 18px 6px;
  border-bottom:1px solid var(--border-paper);
}
.lessons-tag{
  font-size:var(--t-xs);letter-spacing:var(--ls-cap-x);text-transform:uppercase;
  color:var(--accent);font-weight:700;
}
.lessons-body{
  flex:1;overflow:auto;padding:18px 20px 10px;
  scrollbar-width:thin;scrollbar-color:var(--accent) transparent;
}
.lessons-title{
  font-size:var(--t-lg);font-weight:700;letter-spacing:-.01em;
  color:var(--ink);margin-bottom:10px;line-height:1.25;
}
.lessons-text{
  font-size:var(--t-sm);line-height:1.7;color:var(--ink-2);
  white-space:pre-line;margin-bottom:14px;
}
.lessons-example{
  background:var(--paper-2);border:1px solid var(--border-paper);
  padding:12px 14px;margin-top:4px;
}
.lessons-ex-label{
  font-size:var(--t-xs);letter-spacing:var(--ls-cap-x);text-transform:uppercase;
  color:var(--muted);margin-bottom:10px;
}
.lessons-ex-cols{
  display:grid;grid-template-columns:1fr auto 1fr;align-items:start;gap:8px;
}
.lessons-ex-sep{
  color:var(--accent);font-size:var(--t-md);padding-top:18px;
}
.lessons-ex-cell-label{
  font-size:var(--t-xs);letter-spacing:var(--ls-cap);text-transform:uppercase;
  color:var(--muted);margin-bottom:4px;
}
.lessons-ex-pre{
  font-family:var(--font);font-size:var(--t-xs);line-height:1.6;
  color:var(--ink);white-space:pre-wrap;word-break:break-word;
  background:var(--paper-3);padding:8px 10px;border:1px solid var(--border-paper);
}
.lessons-nav{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 18px;border-top:1px solid var(--border-paper);
  background:var(--paper-2);gap:12px;flex-shrink:0;
}
.lessons-btn{
  font-size:var(--t-xs);letter-spacing:var(--ls-cap);text-transform:uppercase;
  color:var(--ink-2);border:1px solid var(--border-paper-strong);
  padding:4px 12px;cursor:none;transition:color .15s,background .15s,border-color .15s;
  min-width:70px;
}
.lessons-btn:hover:not(:disabled){
  color:var(--paper);background:var(--accent);border-color:var(--accent);
}
.lessons-btn:disabled{color:var(--muted);border-color:var(--border-paper);cursor:none}
.lessons-dots{display:flex;gap:6px;align-items:center}
.lessons-dot{
  width:8px;height:8px;border-radius:50%;background:var(--paper-3);
  border:1px solid var(--border-paper-strong);cursor:none;
  transition:background .15s,border-color .15s;padding:0;
}
.lessons-dot.active{background:var(--accent);border-color:var(--accent)}
.lessons-dot:hover:not(.active){background:var(--accent-light);border-color:var(--accent-light)}

/* ============================================================
   Desktop Plant Easter Egg — fixed bottom-right, above dock
   Click 30 times → grows → blooms 🌸
   ============================================================ */
.desktop-plant{
  position:fixed;
  bottom:66px;
  right:28px;
  z-index:3;
  cursor:none;
  user-select:none;
  opacity:.82;
  transition:opacity .2s, filter .4s;
}
.desktop-plant:hover{ opacity:1; }

/* bloom glow when fully grown */
.desktop-plant.bloomed{
  opacity:1;
  filter:drop-shadow(0 0 10px #e89ab8) drop-shadow(0 0 20px rgba(232,154,184,.35));
  animation:plant-bloom-in .8s ease-out both;
}
@keyframes plant-bloom-in{
  0%  { filter:drop-shadow(0 0 32px #f5d46a) brightness(1.7); transform:scale(1.15); }
  50% { filter:drop-shadow(0 0 18px #e89ab8) brightness(1.3); transform:scale(1.05); }
  100%{ filter:drop-shadow(0 0 10px #e89ab8) brightness(1.0); transform:scale(1); }
}

/* quick shake on each click */
.desktop-plant.shake{
  animation:plant-shake .32s ease both;
}
@keyframes plant-shake{
  0%  { transform:rotate(0deg);    }
  25% { transform:rotate(-4deg);   }
  50% { transform:rotate(4deg);    }
  75% { transform:rotate(-2deg);   }
  100%{ transform:rotate(0deg);    }
}

/* progress counter that fades up */
.plant-hint{
  position:absolute;
  bottom:100%;
  right:0;
  margin-bottom:4px;
  font-family:var(--font);
  font-size:var(--t-xs);
  color:var(--muted);
  white-space:nowrap;
  pointer-events:none;
  animation:hint-rise 1.6s ease-out forwards;
}
@keyframes hint-rise{
  0%  { opacity:1;  transform:translateY(0);    }
  55% { opacity:1;  transform:translateY(-6px); }
  100%{ opacity:0;  transform:translateY(-10px);}
}

/* bloom badge — stays visible, no fade */
.plant-hint.bloom-badge{
  animation:none;
  opacity:1;
  transform:none;
  color:var(--accent-light);
  font-size:14px;
}

