/* ── Custom Cursors ── */
/* Hotspot format: url('...') hotspot-x hotspot-y, fallback */
/* hotspot is the pixel coordinate that acts as the "click point" */
 
  html                                       { --xp-cursor: url('https://unwellfargo.neocities.org/img/xp-icons/arrow_m.png') 0 0, default; cursor: var(--xp-cursor); }
  *                                          { cursor: var(--xp-cursor); }
  a, button, select, label, summary, [onclick], .interactive, .desktop-icon, .sm-item, .ctx-item, .ictx-item, .ql-icon, .taskbar-btn, .tb-btn, .tree-item, .item-icon, .item-list, .details-table tbody tr, .logoff-btn, .sm-footer-btn { --xp-cursor: url('https://unwellfargo.neocities.org/img/xp-icons/link_m.png') 0 0, pointer; }
  input, textarea                           { --xp-cursor: url('https://unwellfargo.neocities.org/img/xp-icons/beam_m.png') 16 16, text; }
 
  .resize-handle.n, .resize-handle.s       { cursor: url('https://unwellfargo.neocities.org/img/xp-icons/default_size4.png') 8 8, n-resize; }
  .resize-handle.e, .resize-handle.w       { cursor: url('https://unwellfargo.neocities.org/img/xp-icons/default_size3.png') 8 8, e-resize; }
  .resize-handle.nw, .resize-handle.se     { cursor: url('https://unwellfargo.neocities.org/img/xp-icons/default_size2.png') 8 8, nw-resize; }
  .resize-handle.ne, .resize-handle.sw     { cursor: url('https://unwellfargo.neocities.org/img/xp-icons/default_size1.png') 8 8, ne-resize; }

/* ── Reset & Base (from reset.css) ── */
  *, *::before, *::after {
    box-sizing: border-box; margin: 0; padding: 0;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    user-select: none !important;
    -webkit-user-select: none !important;
  }
  html { font-size: 100%; height: 100%; overflow: hidden; }
  body {
    font-family: Tahoma, Arial, sans-serif;
    font-size: 11px;
    height: 100%;
    line-height: 1.5;
    overflow: hidden;
    width: 100%;
    background: #000;
    filter: brightness(1.01) contrast(1.015) saturate(1.02);
  }
  button, input, select, textarea {
    font-size: 11px;
    user-select: text !important;
    -webkit-user-select: text !important;
    font-family: Tahoma, Arial, sans-serif;
  }
  a { color: inherit; text-decoration: none; }
  img, svg { height: auto; max-width: 100%; vertical-align: middle; }
  :root {
    --z-base: 1;
    --z-window: 100;
    --z-taskbar: 500;
    --z-tooltip: 1000;
    --z-startmenu: 1500;
    --taskbar-height: 30px;
    --taskbar-item-height: 26px;
    --icon-size-small: 15px;
    --tray-spacing: 6px;
    --taskbar-text-shadow: 1px 1px 1px rgba(0,0,0,.6);
    --xp-bg-main: #ece9d8;
    --xp-bg-accent: #0f61cb;
    --xp-border-main: #aca899;
    --icon-hover-bg: rgba(49,106,197,.22);
    --icon-selected-bg: rgba(49,106,197,.5);
    --desktop-icon-cell-size: 83px;
    --desktop-icon-img-size: 45px;
    --desktop-icon-font-size: 11px;
    --desktop-icon-line-height: 18px;
    --desktop-icon-padding: 6px;
    --desktop-icon-grid-gap: 8px;
    --desktop-icons-padding: 20px 0 0 18px;
    --icon-border-radius: 3px;
    color-scheme: light only;
  }
  /* cursor utilities */
  .interactive { --xp-cursor: url('https://unwellfargo.neocities.org/img/xp-icons/link_m.png') 0 0, pointer; }
  .non-interactive { --xp-cursor: url('https://unwellfargo.neocities.org/img/xp-icons/arrow_m.png') 0 0, default; }

  /* ── Boot Screen ── */
  #boot-screen {
    position: fixed; inset: 0; z-index: 9999;
    background: #000;
    display: flex; flex-direction: column;
    align-items: center; justify-content: center;
    transition: opacity 0.8s ease;
  }
  #boot-screen.fade-out { opacity: 0; pointer-events: none; }

  .boot-logo {
    font-size: 48px;
    color: #fff;
    font-weight: 300;
    letter-spacing: -1px;
    margin-bottom: 8px;
  }
  .boot-logo span { color: #3a6bc4; }

  .boot-tagline {
    color: #aaa;
    font-size: 11px;
    font-family: Tahoma, sans-serif;
    margin-bottom: 40px;
    letter-spacing: 0.5px;
  }

  .boot-bar-track {
    border: 2px solid #b2b2b2;
    border-radius: 7px;
    height: 22px;
    width: 180px;
    overflow: hidden;
    padding: 2px 1px;
    font-size: 0;
  }

  .boot-bar-segment {
    animation: loader 2s infinite linear;
    background: linear-gradient(180deg, #2838c7 0, #5979ef 17%, #869ef3 32%, #869ef3 45%, #5979ef 59%, #2838c7);
    display: inline-block;
    height: 100%;
    margin-right: 2px;
    width: 9px;
  }

  @keyframes loader {
    0%   { transform: translate(-30px); }
    100% { transform: translate(180px); }
  }

  .boot-bottom {
    position: absolute;
    bottom: 20px;
    right: 24px;
    color: #555;
    font-size: 10px;
    text-align: right;
  }
  .boot-claude-credit {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 4px;
    text-decoration: none;
    color: #aaa;
    font-family: Tahoma, Arial, sans-serif;
    font-size: 17.5px;
    opacity: 1;
    transition: opacity 0.2s;
  }
  .boot-claude-credit:hover { opacity: 1; }
  .boot-claude-logo {
    height: 26px;
    width: auto;
    object-fit: contain;
    filter: none;
  }

  /* ── Login Screen ── */
  #login-screen {
    position: fixed; inset: 0; z-index: 9998;
    display: none;
    background-color: #002d99;
    transition: opacity 0.5s ease;
    overflow: hidden;
  }
  #login-screen.visible { display: block; }
  #login-screen.fade-out { opacity: 0 !important; pointer-events: none; }

  .login-screen-inner {
    background-color: #587cdb;
    position: absolute;
    inset: 100px 0;
    transition: opacity 0.4s ease;
  }
  .login-screen-inner::before {
    background: linear-gradient(90deg, transparent, #bad7f8, transparent, transparent);
    content: ""; height: 3px;
    left: 0; position: absolute; right: 0; top: 0; width: 100%;
  }
  .login-screen-inner::after {
    background: linear-gradient(90deg, transparent, #f8953d, transparent, transparent);
    bottom: 0; content: ""; height: 3px;
    left: 0; position: absolute; right: 0; width: 100%;
  }
  .login-screen-inner.fade-out { opacity: 0; pointer-events: none; }

  /* Content inside the band — fades out independently */
  .login-screen-content {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    position: relative;
    transition: opacity 0.7s ease;
  }

  /* Left side — logo + instruction */
  .login-left {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    padding-right: 72px;
    gap: 16px;
  }
  .login-xp-logo {
    display: block;
    height: 170px;
    width: auto;
  }
  .login-instruction {
    color: #fff;
    font-size: 19px;
    font-weight: 400;
    letter-spacing: .25px;
    text-align: right;
  }
  .login-instruction-name {
    font-weight: 700;
  }

  /* Vertical divider */
  .login-divider {
    width: 2px;
    top: 20%; bottom: 20%;
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    background: linear-gradient(180deg, rgba(186,215,248,0) 0, #bad7f8 40%, #bad7f8 60%, rgba(186,215,248,0));
    opacity: 0.35;
    pointer-events: none;
  }

  /* Right side — user card */
  .login-right {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    padding-left: 72px;
  }

  .login-card {
    background: transparent;
    border-radius: 5px;
    padding: 12px 18px;
    --xp-cursor: url('https://unwellfargo.neocities.org/img/xp-icons/link_m.png') 0 0, pointer; cursor: var(--xp-cursor);
    display: flex;
    align-items: center;
    gap: 20px;
    min-width: 260px;
    position: relative;
    z-index: 0;
    transition: none;
  }
  .login-card::before {
    background: linear-gradient(90deg, #113fa6, #113fa6, #587cdb);
    border-radius: inherit;
    content: "";
    height: 100%; left: 0;
    opacity: 0;
    position: absolute; top: 0;
    transition: opacity 0.3s ease;
    width: 100%; z-index: -1;
  }
  .login-card:hover::before { opacity: 1; }
  .login-card:hover .login-avatar { border-color: #fdbd32; }
  .login-card:hover .login-title { color: #fdbd32; }

  .login-avatar {
    width: 70px; height: 70px;
    object-fit: cover;
    border-radius: 5px;
    border: 3px solid #fff;
    flex-shrink: 0;
    transition: border-color 0.3s;
  }
  .login-text-wrap { }
  .login-name {
    color: #fff;
    font-size: 26px;
    font-weight: 500;
    letter-spacing: .25px;
    margin-bottom: 2px;
  }
  .login-title {
    color: navy;
    font-size: 13px;
    font-weight: 700;
    line-height: 1.2;
    transition: color 0.3s;
  }

  /* Bottom-left restart button */
  .login-turn-off {
    position: absolute;
    bottom: 35px;
    left: 50px;
    display: flex;
    align-items: center;
    gap: 8px;
    --xp-cursor: url('https://unwellfargo.neocities.org/img/xp-icons/link_m.png') 0 0, pointer; cursor: var(--xp-cursor);
    z-index: 10;
  }
  .login-turn-off img {
    height: 32px; width: 32px;
    opacity: 0.8;
    transition: opacity 0.2s ease;
  }
  .login-turn-off:hover img { opacity: 1; }
  .login-turn-off span {
    color: #eff1ed;
    font-size: 16px;
    font-weight: 500;
  }

  /* Bottom-right hint */
  .login-bottom-hint {
    position: absolute;
    bottom: 30px; right: 50px;
    color: rgba(255,255,255,0.8);
    font-size: 14px;
  }

  /* ── Desktop (from desktop.css) ── */
  #desktop {
    background-image: url('https://unwellfargo.neocities.org/img/bliss.jpg');
    background-position: center;
    background-size: cover;
    height: 100%;
    inset: 0 !important;
    overflow: hidden !important;
    position: fixed !important;
    user-select: none;
    width: 100%;
    display: none;
  }
  #desktop.visible { display: block; }
  @media (max-width: 768px) {
    #desktop { background-image: url('https://unwellfargo.neocities.org/img/bliss.jpg'); }
  }

  /* ── Desktop Icons (from desktop.css) ── */
  #desktop-icons {
    display: grid;
    grid-template-rows: repeat(auto-fill, var(--desktop-icon-cell-size));
    grid-auto-columns: var(--desktop-icon-cell-size);
    grid-auto-flow: column;
    grid-gap: var(--desktop-icon-grid-gap);
    padding: var(--desktop-icons-padding);
    height: calc(100% - 30px);
    place-content: start start;
    z-index: 5;
    overflow: hidden;
  }

  .desktop-icon {
    align-items: center;
    border: 1px solid transparent;
    border-radius: var(--icon-border-radius);
    --xp-cursor: url('https://unwellfargo.neocities.org/img/xp-icons/link_m.png') 0 0, pointer; cursor: var(--xp-cursor);
    display: flex;
    flex-direction: column;
    height: var(--desktop-icon-cell-size);
    justify-content: center;
    padding: var(--desktop-icon-padding);
    position: relative;
    width: var(--desktop-icon-cell-size);
    z-index: 5;
  }
  .desktop-icon:hover { background-color: var(--icon-hover-bg); }
  .desktop-icon.selected {
    background-color: var(--icon-selected-bg);
    border: 1px dotted hsla(0,0%,100%,.5);
  }

  #rubber-band {
    position: fixed;
    display: none;
    border: 1px solid #316ac5;
    background: rgba(49,106,197,0.15);
    pointer-events: none;
    z-index: 9;
  }
  .desktop-icon img {
    height: var(--desktop-icon-img-size) !important;
    width: var(--desktop-icon-img-size) !important;
    max-width: none !important;
    margin-bottom: 5px;
    transform: translateY(2px);
    flex-shrink: 0;
  }
  .desktop-icon .icon-img {
    font-size: 34px;
    line-height: 1;
    margin-bottom: 5px;
    transform: translateY(2px);
    filter: drop-shadow(0 2px 3px rgba(0,0,0,0.5));
  }
  .desktop-icon span {
    color: #fff;
    display: block;
    font-size: var(--desktop-icon-font-size);
    font-weight: 400;
    letter-spacing: .3px;
    line-height: var(--desktop-icon-line-height);
    max-width: 100%;
    overflow: visible;
    text-align: center;
    text-shadow: 1px 1px 1px rgba(0,0,0,.9), 0 0 3px rgba(0,0,0,.8);
    transform: translateY(2px);
    white-space: normal;
  }

  /* ── Taskbar (from taskbar.css) ── */
  #taskbar {
    align-items: center;
    background-image: url('https://mitchivin.com/assets/gui/taskbar/taskbar-bg.webp');
    background-repeat: repeat-x;
    background-size: auto 100%;
    bottom: 0; left: 0;
    display: flex;
    height: var(--taskbar-height);
    overflow: hidden;
    position: fixed;
    width: 100%;
    z-index: var(--z-taskbar);
  }

  /* Start button */
  #start-btn {
    background: transparent;
    border: none !important;
    box-shadow: none !important;
    height: var(--taskbar-height);
    margin: 0; padding: 0;
    position: relative;
    transition: filter .1s ease;
    width: auto;
    flex-shrink: 0;
    --xp-cursor: url('https://unwellfargo.neocities.org/img/xp-icons/link_m.png') 0 0, pointer; cursor: var(--xp-cursor);
  }
  #start-btn:hover { filter: brightness(1.15); }
  #start-btn:active { filter: brightness(.9); }
  #start-btn img { border: none; display: block; height: var(--taskbar-height); }
  .start-flag { display: none; }

  /* Taskbar programs area */
  #taskbar-programs {
    align-items: center;
    display: flex;
    flex-grow: 1;
    height: 100%;
    margin: 0 4px;
    min-width: 0;
    overflow: hidden;
    padding: 0;
    gap: 2px;
  }

  .taskbar-btn {
    align-items: center;
    background: linear-gradient(0deg,#1a5a99 0,#2176c7);
    border: 1px solid #174a7c;
    border-radius: 4px;
    box-shadow: inset 1px 1px 1px rgba(0,0,0,.4), inset -1px -1px 0 hsla(0,0%,100%,.05);
    color: #fff;
    --xp-cursor: url('https://unwellfargo.neocities.org/img/xp-icons/link_m.png') 0 0, pointer; cursor: var(--xp-cursor);
    display: flex;
    flex-shrink: 1;
    font-family: Tahoma, Arial, sans-serif;
    font-size: 11px;
    height: var(--taskbar-item-height);
    justify-content: flex-start;
    max-width: 160px;
    min-width: 60px;
    overflow: hidden;
    padding: 0 6px;
    text-overflow: ellipsis;
    text-shadow: 1px 1px 1px rgba(0,0,0,.3);
    white-space: nowrap;
    gap: 4px;
  }
  .taskbar-btn:hover:not(.active) {
    background: linear-gradient(180deg,#56b6fc 0,#52aeff 50%,#0e81ec);
    border: 1px solid #2176c7;
    box-shadow: inset 0 1px 1px hsla(0,0%,100%,.45), 0 1px 2px rgba(0,0,0,.18);
  }
  .taskbar-btn.active {
    background: linear-gradient(180deg,#3ba0e7 0,#3295eb 50%,#3389d4) !important;
    border: 1px solid #0e63ad !important;
    box-shadow: inset 0 1px 1px hsla(0,0%,100%,.2) !important;
    color: #fff !important;
    text-shadow: 1px 1px 1px rgba(0,0,0,.3) !important;
  }
  .taskbar-btn img { display: block; flex-shrink: 0; height: var(--icon-size-small); width: var(--icon-size-small); }
  .taskbar-btn .tb-icon { font-size: 13px; flex-shrink: 0; }

  /* ── Quick Launch ── */
  #quick-launch {
    display: flex;
    align-items: center;
    height: 100%;
    padding: 0 4px;
    gap: 2px;
    border: none;
    flex-shrink: 0;
  }
  .ql-icon {
    height: 18px !important;
    width: 18px !important;
    max-width: none !important;
    object-fit: contain;
    --xp-cursor: url('https://unwellfargo.neocities.org/img/xp-icons/link_m.png') 0 0, pointer; cursor: var(--xp-cursor);
    opacity: 0.9;
    border-radius: 2px;
    padding: 1px;
    transition: opacity 0.1s, background 0.1s;
    flex-shrink: 0;
  }
  .ql-icon:hover { opacity: 1; background: rgba(255,255,255,0.2); }
  .ql-icon:active { background: rgba(0,0,0,0.2); }

  /* System tray */
  #system-tray {
    align-items: center;
    display: flex;
    flex-grow: 0;
    flex-shrink: 0;
    height: 100%;
    margin-left: auto;
    min-width: 0;
    padding-right: 0;
    position: relative;
    width: auto;
  }
  .system-tray-bg {
    height: var(--taskbar-height);
    left: 0; top: 0;
    pointer-events: none;
    position: absolute;
    width: 100%;
    z-index: 1;
  }
  .tray-content {
    align-items: center;
    box-sizing: border-box;
    display: flex;
    height: 100%;
    justify-content: center;
    padding: 0 12px;
    position: relative;
    width: 100%;
    z-index: 2;
  }
  .tray-icons {
    align-items: center;
    display: flex;
    gap: var(--tray-spacing);
    height: 100%;
    margin-right: 8px;
  }
  .tray-crt-toggle, .tray-fullscreen-icon, .tray-welcome-icon {
    align-items: center;
    --xp-cursor: url('https://unwellfargo.neocities.org/img/xp-icons/link_m.png') 0 0, pointer; cursor: var(--xp-cursor);
    display: flex;
    height: 16px;
    object-fit: contain;
    width: 16px;
  }
  #clock {
    color: #fff;
    font-size: 11px;
    text-shadow: var(--taskbar-text-shadow);
    white-space: nowrap;
    z-index: 2;
  }

  /* ── Start Menu (from startMenu.css) ── */
  #start-menu {
    background-color: var(--xp-bg-accent);
    border: 1px solid rgba(0,0,0,.3);
    border-radius: 5px 5px 0 0;
    bottom: calc(var(--taskbar-height) + .5px);
    box-shadow: 0 -2px 8px rgba(0,0,0,.4), 2px 4px 10px rgba(0,0,0,.4), inset 0 0 55px hsla(0,0%,100%,.08);
    display: none;
    flex-direction: column;
    height: 455px;
    left: 0;
    overflow: hidden;
    position: absolute;
    width: 335px;
    z-index: var(--z-startmenu);
  }
  #start-menu.visible { display: flex; }

  .sm-header {
    align-items: center;
    background: linear-gradient(180deg,#1868ce 0,#0e60cb 12%,#0e60cb 20%,#1164cf 32%,#1667cf 33%,#1b6cd3 47%,#1e70d9 54%,#2476dc 60%,#297ae0 65%,#3482e3 77%,#3786e5 79%,#428ee9 90%,#4791eb);
    border-radius: 5px 5px 0 0;
    box-shadow: inset 0 -2px 3px rgba(10,36,106,.4);
    display: flex;
    flex: 0 0 51px;
    height: 51px;
    position: relative;
    width: 100%;
    padding: 0 8px;
    gap: 8px;
  }
  .sm-header::after {
    background: linear-gradient(90deg,rgba(255,140,0,.1) 0,rgba(255,165,0,.9) 30%,rgba(255,165,0,.9) 70%,rgba(255,140,0,.1));
    bottom: 0; content: ""; height: 2px;
    left: 0; position: absolute; right: 0;
  }
  .sm-avatar {
    border: 2px solid hsla(0,0%,100%,.7);
    border-radius: 3px;
    box-shadow: 0 0 0 1px rgba(0,95,184,.6), inset 0 0 2px 1px hsla(0,0%,100%,.35);
    height: 40px; width: 40px;
    object-fit: cover;
    flex-shrink: 0;
  }
  .sm-username { color: #fff; font-size: 13.5px; font-weight: 700; letter-spacing: .5px; text-shadow: 1px 1px 2px rgba(0,0,0,.6); }
  .sm-subtitle { color: #adc8f5; font-size: 10px; }

  .sm-body {
    box-shadow: inset 0 6px 10px -6px rgba(0,0,0,.3);
    display: flex;
    flex: 1;
    overflow: hidden;
    width: 100%;
  }
  .sm-left {
    background-color: #fff;
    box-shadow: inset -2px 0 3px -1px rgba(0,0,0,.15), inset 0 3px 4px -3px rgba(0,0,0,.2);
    display: flex;
    flex-direction: column;
    width: 52%;
  }
  .sm-right {
    background-color: #d2e5fa;
    border-left: 1px solid #a6bbd6;
    box-shadow: inset 2px 0 3px -1px hsla(0,0%,100%,.7), inset 0 3px 4px -3px rgba(0,0,0,.15);
    display: flex;
    flex-direction: column;
    width: 48%;
  }

  .sm-item {
    align-items: center;
    box-sizing: border-box;
    --xp-cursor: url('https://unwellfargo.neocities.org/img/xp-icons/link_m.png') 0 0, pointer; cursor: var(--xp-cursor);
    display: flex;
    padding: 4px 8px;
    transition: background-color .05s ease;
    width: 100%;
    gap: 7px;
    font-size: 12px;
    color: #000;
    flex: 1;
  }
  .sm-right .sm-item { flex: none; height: 35px; max-height: 35px; min-height: 35px; padding: 8px 7.5px 8px 9px; font-size: 11.5px; }
  .sm-item:hover { background-color: #2f71cd; color: #fff !important; box-shadow: inset 0 0 5px rgba(0,0,0,.2); }
  .sm-item:hover img { filter: none; }
  .sm-item img { flex-shrink: 0; }
  .sm-left .sm-item img { height: 30px; width: 30px; filter: drop-shadow(1px 1px 1px rgba(0,0,0,.3)); }
  .sm-left .sm-item img.sm-allprog-chevron { height: 30px; width: 30px; filter: none; }
  .sm-right .sm-item img { height: 25px; width: 25px; }
  .sm-item .sm-icon { font-size: 20px; width: 24px; text-align: center; flex-shrink: 0; }
  .sm-item-label { font-weight: 600; }

  .sm-separator { height: 1px; background: linear-gradient(90deg,transparent,#d2d2d2 50%,transparent); margin: 0; flex: 0 0 auto; }

  .sm-footer {
    align-items: center;
    background-color: #0f61cb;
    border-top: 1px solid rgba(0,0,0,.3);
    box-shadow: inset 0 1px 4px rgba(0,0,0,.2);
    display: flex;
    flex: 0 0 46px;
    height: 46px;
    justify-content: flex-end;
    position: relative;
    width: 100%;
  }
  .sm-footer::before {
    background: linear-gradient(180deg,#428ee9 0,#3786e5 10%,#3482e3 21%,#297ae0 35%,#2476dc 40%,#1e70d9 46%,#1b6cd3 53%,#1667cf 67%,#1164cf 68%,#0e60cb 80%,#0e60cb 88%,#1868ce);
    content: ""; inset: 0; position: absolute; z-index: 0;
  }
  .sm-footer-btns { align-items: center; display: flex; height: 100%; padding-right: 2px; position: relative; z-index: 1; }
  .sm-footer-btn {
    align-items: center;
    color: #fff;
    --xp-cursor: url('https://unwellfargo.neocities.org/img/xp-icons/link_m.png') 0 0, pointer; cursor: var(--xp-cursor);
    display: inline-flex;
    font-family: Tahoma, Arial, sans-serif;
    font-size: 12.5px;
    height: 30px;
    margin: 0 5px;
    padding: 0;
    text-shadow: 1px 1px 1px rgba(0,0,0,.4);
    background: transparent;
    border: none;
    gap: 0;
  }
  .sm-footer-btn span { padding: 0 6px; }
  .sm-footer-btn img { border-radius: 3px; height: 24px; width: 24px; transition: filter .1s ease; }
  .sm-footer-btn:hover img { filter: brightness(1.2); }

  /* ── All Programs Flyout ── */
  #sm-allprograms-btn {
    flex-shrink: 0;
  }
  .sm-allprog-chevron {
    margin-left: auto;
    flex-shrink: 0;
    object-fit: contain;
    padding-right: 4px;
  }

  #sm-programs-flyout {
    background: #fff;
    border: 1px solid rgba(0,0,0,.35);
    border-radius: 5px 5px 5px 0;
    box-shadow: 0 -4px 12px rgba(0,0,0,.35);
    display: none;
    max-height: calc(455px * 1.15);
    overflow-y: auto;
    position: fixed;
    z-index: calc(var(--z-startmenu) + 1);
    padding: 3px 0;
  }
  #sm-programs-flyout.visible { display: block; }

  .sm-prog-item {
    align-items: center;
    display: flex;
    font-family: Tahoma, Arial, sans-serif;
    font-size: 11.5px;
    gap: 8px;
    padding: 5px 10px 5px 8px;
    --xp-cursor: url('https://unwellfargo.neocities.org/img/xp-icons/link_m.png') 0 0, pointer; cursor: var(--xp-cursor);
  }
  .sm-prog-item:hover {
    background: #2f71cd;
    color: #fff;
  }
  .sm-prog-item img {
    flex-shrink: 0;
    height: 20px;
    object-fit: contain;
    width: 20px;
  }

  /* ── Windows (from window.css + windowBars.css) ── */
  #windows-container { position: absolute; z-index: var(--z-window); width: 100%; height: 100%; pointer-events: none; }

  .xp-window {
    border: 2px solid #284ffd;
    border-radius: 8px 8px 0 0;
    border-top-width: 1.5px;
    display: none;
    filter: drop-shadow(1px 1px 4px rgba(0,0,0,.5));
    flex-direction: column;
    max-height: calc(100vh - 30px);
    max-width: 100vw;
    min-height: 200px;
    min-width: 300px;
    overflow: hidden;
    position: absolute;
    pointer-events: auto;
  }
  .xp-window.visible { display: flex; }

  /* ── Resize handles ── */
  .resize-handle {
    position: absolute;
    z-index: 10;
  }
  .resize-handle.n  { top:-4px;    left:8px;    right:8px;   height:8px;  cursor:n-resize;  }
  .resize-handle.s  { bottom:-4px; left:8px;    right:8px;   height:8px;  cursor:s-resize;  }
  .resize-handle.e  { right:-4px;  top:8px;     bottom:8px;  width:8px;   cursor:e-resize;  }
  .resize-handle.w  { left:-4px;   top:8px;     bottom:8px;  width:8px;   cursor:w-resize;  }
  .resize-handle.nw { top:-4px;    left:-4px;   width:12px;  height:12px; cursor:nw-resize; }
  .resize-handle.ne { top:-4px;    right:-4px;  width:12px;  height:12px; cursor:ne-resize; }
  .resize-handle.sw { bottom:-4px; left:-4px;   width:12px;  height:12px; cursor:sw-resize; }
  .resize-handle.se { bottom:-4px; right:-4px;  width:12px;  height:12px; cursor:se-resize; }
  .xp-window:not(.focused) { border-color: #3d7bff; }

  .xp-window .title-bar {
    border-radius: 6px 6px 0 0;
    cursor: move;
    display: flex;
    justify-content: space-between;
    margin: 0 -1px;
    min-height: 30px;
    overflow: hidden;
    padding-bottom: 1px;
    position: relative;
    user-select: none;
    width: calc(100% + 2px);
  }
  .xp-window .title-bar-text {
    color: #fff;
    flex-grow: 1;
    font-weight: 700;
    overflow: hidden;
    padding: 3px 5px;
    text-overflow: ellipsis;
    white-space: nowrap;
    align-self: center;
  }
  .xp-window .title-bar-controls { align-items: center; display: flex; }

  .xp-window .window-body {
    background-color: var(--xp-bg-main);
    border: none !important;
    display: flex;
    flex: 1;
    flex-direction: column;
    margin: 0;
    min-height: 0;
    overflow: auto;
    padding: 0;
    position: relative;
  }

  /* window open/close/minimize animations */
  @keyframes windowOpenFadeSlide {
    0%   { opacity: 0; transform: translate(-24px,-24px); }
    100% { opacity: 1; transform: none; }
  }
  .window-opening { animation: windowOpenFadeSlide .2s ease-out; }

  @keyframes windowMinimizeZoom {
    0%   { opacity: 1; transform: none; }
    100% { opacity: .5; transform: scale(.55); }
  }
  .window-minimizing { animation: windowMinimizeZoom .15s ease-in forwards; transform-origin: bottom center; }

  @keyframes windowRestoreZoom {
    0%   { opacity: .5; transform: scale(.55); }
    100% { opacity: 1; transform: none; }
  }
  .window-restoring { animation: windowRestoreZoom .15s ease-out; transform-origin: bottom center; }

  .xp-window .title-bar {
    cursor: move;
    user-select: none;
  }

  .xp-window .window-body {
    padding: 12px;
    background: #fff;
    overflow-y: auto;
    height: calc(100% - 30px);
  }

  /* ── Window Content Styles ── */
  .win-section { margin-bottom: 14px; }
  .win-section h3 {
    font-size: 12px;
    font-weight: bold;
    color: #0a246a;
    border-bottom: 1px solid #c8d4e8;
    padding-bottom: 3px;
    margin-bottom: 6px;
  }
  .win-section p { line-height: 1.6; color: #333; margin-bottom: 6px; }

  .info-row { display: flex; gap: 6px; margin-bottom: 5px; align-items: center; }
  .info-label { font-weight: bold; color: #555; min-width: 70px; font-size: 11px; }
  .info-value { color: #222; font-size: 11px; }

  .skill-bar-wrap { margin-bottom: 6px; }
  .skill-name { font-size: 11px; margin-bottom: 2px; color: #333; }
  .skill-bar { height: 12px; background: #dde; border: 1px solid #999; border-radius: 1px; overflow: hidden; }
  .skill-fill {
    height: 100%;
    background: linear-gradient(90deg, #3169c7, #5a90e8);
    transition: width 1s ease;
    width: 0%;
  }

  .project-card {
    border: 1px solid #c0d0e8;
    border-radius: 2px;
    padding: 10px;
    margin-bottom: 8px;
    --xp-cursor: url('https://unwellfargo.neocities.org/img/xp-icons/link_m.png') 0 0, pointer; cursor: var(--xp-cursor);
    transition: background 0.15s;
  }
  .project-card:hover { background: #eef2fb; }
  .project-card h4 { color: #0a246a; font-size: 12px; margin-bottom: 4px; }
  .project-card p { color: #555; font-size: 11px; line-height: 1.5; }
  .project-tags { display: flex; gap: 4px; flex-wrap: wrap; margin-top: 6px; }
  .tag {
    background: #3169c7;
    color: #fff;
    font-size: 10px;
    padding: 1px 6px;
    border-radius: 2px;
  }

  .contact-link {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px;
    border: 1px solid #c0d0e8;
    border-radius: 2px;
    margin-bottom: 6px;
    --xp-cursor: url('https://unwellfargo.neocities.org/img/xp-icons/link_m.png') 0 0, pointer; cursor: var(--xp-cursor);
    text-decoration: none;
    color: #000;
  }
  .contact-link:hover { background: #eef2fb; }
  .contact-icon { font-size: 20px; }
  .contact-label { font-size: 11px; }
  .contact-sub { font-size: 10px; color: #666; }

  .resume-row { display: flex; margin-bottom: 8px; gap: 12px; }
  .resume-date { min-width: 90px; color: #888; font-size: 10px; padding-top: 1px; }
  .resume-content h4 { font-size: 11px; font-weight: bold; color: #0a246a; }
  .resume-content p { font-size: 11px; color: #555; line-height: 1.4; }
  .resume-section-title {
    font-size: 12px;
    font-weight: bold;
    color: #0a246a;
    background: #dde8f5;
    padding: 3px 8px;
    margin: 10px 0 6px;
    border-left: 3px solid #3169c7;
  }

  /* ── Notepad Window ── */
  #notepad-body { padding: 0; height: calc(100% - 30px); display: flex; flex-direction: column; }
  #notepad-textarea {
    flex: 1;
    border: none;
    padding: 8px;
    font-family: 'Courier New', monospace;
    font-size: 12px;
    resize: none;
    outline: none;
    line-height: 1.5;
    color: #000;
  }

  /* ── My Computer ── */
  .drive-grid { display: flex; flex-wrap: wrap; gap: 12px; padding: 8px; }
  .drive-item {
    display: flex; flex-direction: column;
    align-items: center; gap: 4px;
    width: 72px; padding: 8px 4px;
    border: 1px solid transparent;
    border-radius: 2px;
    --xp-cursor: url('https://unwellfargo.neocities.org/img/xp-icons/link_m.png') 0 0, pointer; cursor: var(--xp-cursor);
  }
  .drive-item:hover { background: #eef2fb; border-color: #3169c7; }
  .drive-item .d-icon { font-size: 32px; }
  .drive-item span { font-size: 11px; text-align: center; line-height: 1.3; }

  /* ── Error / Alert dialog ── */
  .xp-dialog {
    position: fixed;
    z-index: 5000;
    display: none;
  }
  .xp-dialog.visible { display: block; }

  /* scrollbar */
  ::-webkit-scrollbar { width: 16px; }
  ::-webkit-scrollbar-track { background: #f0f0f0; }
  ::-webkit-scrollbar-thumb {
    background: linear-gradient(90deg, #c8c8c8, #e0e0e0, #c8c8c8);
    border: 1px solid #999;
  }
  ::-webkit-scrollbar-button { background: #d4d0c8; height: 16px; border: 1px solid #888; }

  /* ── Wallpaper sky ── */
  .sky-layer {
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 55%;
    background: linear-gradient(180deg, #87ceeb 0%, #aaddff 60%, #c8eeff 100%);
    z-index: 0;
    pointer-events: none;
  }
  .cloud {
    position: absolute;
    background: rgba(255,255,255,0.85);
    border-radius: 50px;
    pointer-events: none;
  }

  /* tooltip */
  [data-tip] { position: relative; }
  [data-tip]:hover::after {
    content: attr(data-tip);
    position: absolute;
    bottom: 110%;
    left: 50%;
    transform: translateX(-50%);
    background: #ffffe0;
    border: 1px solid #000;
    padding: 2px 6px;
    font-size: 11px;
    white-space: nowrap;
    z-index: 9999;
    pointer-events: none;
    color: #000;
  }

  /* ── Welcome balloon ── */
  #welcome-balloon {
    position: fixed;
    bottom: 36px;
    right: 90px;
    background: #ffffe0;
    border: 1px solid #aaa;
    border-radius: 4px;
    padding: 8px 12px;
    font-size: 11px;
    z-index: 3000;
    max-width: 220px;
    box-shadow: 2px 2px 6px rgba(0,0,0,0.2);
    display: none;
    animation: fadeIn 0.3s ease;
  }
  #welcome-balloon.visible { display: block; }
  #welcome-balloon::after {
    content: '';
    position: absolute;
    bottom: -6px; right: 16px;
    width: 10px; height: 6px;
    background: #ffffe0;
    border-bottom: 1px solid #aaa;
    border-right: 1px solid #aaa;
    clip-path: polygon(0 0, 100% 0, 50% 100%);
  }
  #welcome-balloon .balloon-close {
    position: absolute; top: 2px; right: 4px;
    --xp-cursor: url('https://unwellfargo.neocities.org/img/xp-icons/link_m.png') 0 0, pointer; cursor: var(--xp-cursor); font-size: 10px; color: #666;
  }
  #welcome-balloon .balloon-close:hover { color: #000; }

  @keyframes fadeIn { from { opacity:0; transform: translateY(4px); } to { opacity:1; transform:none; } }

  /* Right-click context menu */
  #ctx-menu {
    position: fixed;
    display: none;
    z-index: 4000;
    background: #fff;
    border: 1px solid #999;
    box-shadow: 2px 2px 6px rgba(0,0,0,0.3);
    min-width: 160px;
    font-family: Tahoma, sans-serif;
  }
  #ctx-menu.visible { display: block; }
  .ctx-item {
    padding: 4px 20px 4px 4px;
    font-size: 11px;
    --xp-cursor: url('https://unwellfargo.neocities.org/img/xp-icons/link_m.png') 0 0, pointer; cursor: var(--xp-cursor);
    color: #000;
    display: flex;
    align-items: center;
    gap: 6px;
  }
  .ctx-item img {
    width: 16px;
    height: 16px;
    object-fit: contain;
    flex-shrink: 0;
  }
  .ctx-item:hover { background: #3169c7; color: #fff; }
  .ctx-separator { height: 1px; background: #ccc; margin: 3px 0; }

  /* Progress bar for about dialog */
  .fieldset-group { margin-bottom: 8px; }

  /* ── Fake cursor (CRT mode) ── */
  #fake-cursor {
    display: none;
    position: fixed;
    top: 0; left: 0;
    width: 32px; height: 32px;
    pointer-events: none;
    z-index: 99999;
    background: url('https://unwellfargo.neocities.org/img/xp-icons/arrow_m.png') no-repeat top left / contain;
    will-change: transform;
  }
  body.crt-on #fake-cursor { display: block; opacity: 0; }
  body.crt-on #fake-cursor.moved { opacity: 1; }
  body.crt-on,
  body.crt-on * { cursor: none !important; }

  /* ── BSOD ── */
  @keyframes bsod-blink { 0%, 100% { opacity: 1; } 50% { opacity: 0; } }

  /* ── IE6 Compatibility Mode ── */
  #ie6-compat-bar {
    display: none;
    position: fixed;
    top: 0; left: 0; right: 0;
    background: #ffffe1;
    border-bottom: 2px solid #e6c300;
    padding: 3px 10px;
    font-family: Tahoma, Arial, sans-serif;
    font-size: 11px;
    color: #000;
    z-index: 999998;
    gap: 4px;
    align-items: center;
  }
  #ie6-under-construction {
    display: none;
    position: fixed;
    bottom: 32px; left: 0; right: 0;
    text-align: center;
    font-family: "Comic Sans MS", cursive;
    font-size: 11px;
    color: #ff0;
    background: repeating-linear-gradient(45deg, #000 0px, #000 10px, #ff0 10px, #ff0 20px);
    padding: 3px 0;
    z-index: 999997;
    pointer-events: none;
    text-shadow: 1px 1px 0 #000;
    letter-spacing: 1px;
  }
  body.compat-mode #ie6-compat-bar         { display: flex; }
  body.compat-mode #ie6-under-construction { display: block; }

  /* Shift everything down to make room for the compat bar */
  body.compat-mode #desktop  { top: 22px !important; }
  body.compat-mode #taskbar  { bottom: 0 !important; }

  /* Desktop: Win98 teal */
  body.compat-mode #desktop {
    background: #008080 !important;
    background-image: none !important;
  }

  /* Comic Sans everywhere on desktop */
  body.compat-mode,
  body.compat-mode * {
    font-family: "Comic Sans MS", cursive, sans-serif !important;
  }

  /* Win98-style title bars: flat navy, no gradient, no border-radius */
  body.compat-mode .title-bar {
    background: #000080 !important;
    background-image: none !important;
    border-radius: 0 !important;
  }
  body.compat-mode .xp-window {
    border-radius: 0 !important;
    border: 2px solid #000080 !important;
  }
  body.compat-mode .win-menubar {
    background: #c0c0c0 !important;
    border-bottom: 1px solid #808080 !important;
  }
  body.compat-mode .wmb-item { color: #000 !important; }

  /* Taskbar: flat Win98 gray */
  body.compat-mode #taskbar {
    background: #c0c0c0 !important;
    background-image: none !important;
    box-shadow: none !important;
    border-top: 2px solid #fff !important;
  }
  body.compat-mode #start-btn {
    background: #c0c0c0 !important;
    background-image: none !important;
    border: 2px outset #fff !important;
    border-radius: 0 !important;
    color: #000 !important;
    font-family: "Comic Sans MS", cursive !important;
    box-shadow: none !important;
  }
  body.compat-mode .taskbar-btn {
    background: #c0c0c0 !important;
    border: 2px outset #fff !important;
    border-radius: 0 !important;
    color: #000 !important;
    box-shadow: none !important;
  }
  body.compat-mode .taskbar-btn.active {
    border: 2px inset #fff !important;
    background: #b0b0b0 !important;
  }
  body.compat-mode #clock {
    color: #000 !important;
    background: #c0c0c0 !important;
    text-shadow: none !important;
  }

  /* Start menu: ugly */
  body.compat-mode #start-menu {
    background: #c0c0c0 !important;
    border-radius: 0 !important;
    border: 2px outset #fff !important;
  }
  body.compat-mode .sm-header {
    background: #000080 !important;
  }
  body.compat-mode .sm-left  { background: #c0c0c0 !important; }
  body.compat-mode .sm-right { background: #c0c0c0 !important; }
  body.compat-mode .sm-footer { background: #c0c0c0 !important; }
  body.compat-mode .sm-footer::before { display: none !important; }
  body.compat-mode .sm-item:hover { background: #000080 !important; }

  /* Desktop icons: garish selection color */
  body.compat-mode .desktop-icon.selected { background: #000080 !important; }

  /* Subtle degraded filter over whole page */
  body.compat-mode #desktop,
  body.compat-mode #taskbar,
  body.compat-mode #windows-container {
    filter: contrast(0.88) saturate(0.65) sepia(0.15) !important;
  }

  /* ── You Died Glitch ── */
  @keyframes xp-glitch-skew {
    0%   { transform: skewX(0deg)  skewY(0deg); }
    10%  { transform: skewX(-4deg) skewY(1deg)  scaleX(1.02); }
    20%  { transform: skewX(3deg)  skewY(-0.5deg); }
    30%  { transform: skewX(0deg)  skewY(2deg); }
    45%  { transform: skewX(-6deg) skewY(-1deg) scaleX(0.98) scaleY(1.02); }
    55%  { transform: skewX(2deg)  skewY(1.5deg); }
    70%  { transform: skewX(-2deg) skewY(0deg); }
    80%  { transform: skewX(5deg)  skewY(-2deg) scaleX(1.03) scaleY(0.98); }
    90%  { transform: skewX(-1deg) skewY(1deg); }
    100% { transform: skewX(0deg)  skewY(0deg); }
  }
  /* melt = displacement filter always on, color effects layered on top */
  @keyframes xp-glitch-colors {
    0%   { filter: url(#xp-melt-filter); }
    15%  { filter: url(#xp-melt-filter) hue-rotate(90deg)  saturate(3)  brightness(1.4); }
    16%  { filter: url(#xp-melt-filter) invert(1); }
    17%  { filter: url(#xp-melt-filter); }
    40%  { filter: url(#xp-melt-filter) hue-rotate(180deg) contrast(3); }
    41%  { filter: url(#xp-melt-filter) invert(1) brightness(2); }
    42%  { filter: url(#xp-melt-filter); }
    65%  { filter: url(#xp-melt-filter) hue-rotate(270deg) saturate(5)  brightness(0.6); }
    66%  { filter: url(#xp-melt-filter) invert(1); }
    67%  { filter: url(#xp-melt-filter); }
    85%  { filter: url(#xp-melt-filter) brightness(3) saturate(0); }
    86%  { filter: url(#xp-melt-filter); }
    100% { filter: url(#xp-melt-filter); }
  }
  /* cursor only gets color flicker — no displacement or skew so it stays usable */
  @keyframes xp-glitch-cursor {
    0%   { filter: none; }
    15%  { filter: hue-rotate(90deg)  saturate(3)  brightness(1.4); }
    16%  { filter: invert(1); }
    17%  { filter: none; }
    40%  { filter: hue-rotate(180deg) contrast(3); }
    41%  { filter: invert(1) brightness(2); }
    42%  { filter: none; }
    65%  { filter: hue-rotate(270deg) saturate(5)  brightness(0.6); }
    66%  { filter: invert(1); }
    67%  { filter: none; }
    85%  { filter: brightness(3) saturate(0); }
    86%  { filter: none; }
    100% { filter: none; }
  }
  body.xp-glitching #desktop,
  body.xp-glitching #taskbar,
  body.xp-glitching #windows-container {
    animation: xp-glitch-skew 0.18s steps(1) infinite, xp-glitch-colors 0.22s steps(1) infinite;
    overflow: visible;
    pointer-events: none;
  }
  body.xp-glitching #taskbar {
    animation-delay: 0.05s, 0.03s;
  }
  body.xp-glitching #windows-container {
    animation-delay: 0.09s, 0.07s;
  }
  body.xp-glitching #fake-cursor {
    animation: xp-glitch-cursor 0.09s steps(1) infinite;
  }

  /* ── CRT Effect (ported from crtEffect.css) ── */
  :root {
    --crt-scanline-opacity: 0.15;
    --crt-scanline-width: 1px;
    --crt-scanline-gap: 1px;
    --crt-moving-scanline-color: hsla(0,0%,100%,0.15);
    --crt-flicker-opacity: 0.01;
    --crt-vignette-opacity: 0.15;
    --crt-aberration-offset: 1.2px;
    --crt-aberration-opacity: 0.05;
    --crt-moving-scanline-height: 0.6px;
    --crt-curvature: 0px;
  }

  /* All CRT layers hidden by default, shown when body has .crt-on */
  .crt-effect, .crt-scanline, .crt-vignette,
  .crt-noise, .crt-flicker, .crt-aberration, .crt-persistence {
    display: none;
    pointer-events: none;
  }
  body.crt-on .crt-effect,
  body.crt-on .crt-scanline,
  body.crt-on .crt-vignette,
  body.crt-on .crt-noise,
  body.crt-on .crt-flicker,
  body.crt-on .crt-aberration,
  body.crt-on .crt-persistence { display: block; }

  @keyframes flicker {
    0%   { opacity: 0; }
    5%   { opacity: var(--crt-flicker-opacity); }
    10%  { opacity: 0; }
    15%  { opacity: var(--crt-flicker-opacity); }
    20%  { opacity: 0; }
    70%  { opacity: var(--crt-flicker-opacity); }
    80%  { opacity: 0; }
    90%  { opacity: var(--crt-flicker-opacity); }
    100% { opacity: 0; }
  }
  @keyframes crt-flicker {
    0%   { opacity: 1; }
    1%   { opacity: 0.985; }
    2%   { opacity: 0.995; }
    3%   { opacity: 0.99; }
    4%   { opacity: 1; }
    31%  { opacity: 0.985; }
    32%  { opacity: 0.99; }
    33%  { opacity: 1; }
    81%  { opacity: 0.99; }
    82%  { opacity: 0.98; }
    83%  { opacity: 1; }
    100% { opacity: 1; }
  }
  @keyframes chromatic-shift {
    0%   { transform: translate(var(--crt-aberration-offset)); }
    25%  { transform: translate(calc(var(--crt-aberration-offset) * 0.9), calc(var(--crt-aberration-offset) * 0.1)); }
    50%  { transform: translate(var(--crt-aberration-offset)); }
    75%  { transform: translate(calc(var(--crt-aberration-offset) * 1.1), calc(var(--crt-aberration-offset) * -0.1)); }
    100% { transform: translate(var(--crt-aberration-offset)); }
  }
  @keyframes noise {
    0%,100% { background-position: 0 0; }
    20%     { background-position: 20% 20%; }
    40%     { background-position: -20% -30%; }
    60%     { background-position: 30% 10%; }
    80%     { background-position: -30% 30%; }
  }

  .crt-effect {
    border-radius: var(--crt-curvature);
    box-shadow: 0 0 0 30px #000;
    height: 100%; inset: 0;
    overflow: hidden;
    position: fixed; width: 100%;
    z-index: 100000;
  }
  .crt-effect::before {
    background: repeating-linear-gradient(
      0deg,
      rgba(0,0,0,var(--crt-scanline-opacity)),
      rgba(0,0,0,var(--crt-scanline-opacity)) var(--crt-scanline-width),
      transparent var(--crt-scanline-width),
      transparent calc(var(--crt-scanline-width) + var(--crt-scanline-gap))
    );
    content: ""; display: block;
    height: 100%; inset: 0;
    mix-blend-mode: multiply;
    opacity: 0.7; position: absolute; width: 100%;
    z-index: 100000;
  }
  .crt-effect::after {
    background: repeating-linear-gradient(
      90deg,
      rgba(0,0,0,calc(var(--crt-scanline-opacity) * 0.7)),
      rgba(0,0,0,calc(var(--crt-scanline-opacity) * 0.7)) var(--crt-scanline-width),
      transparent var(--crt-scanline-width),
      transparent calc(var(--crt-scanline-width) + var(--crt-scanline-gap))
    );
    content: ""; display: block;
    height: 100%; inset: 0;
    mix-blend-mode: multiply;
    opacity: 0.7; position: absolute; width: 100%;
    z-index: 100000;
  }

  .crt-scanline {
    background: linear-gradient(180deg, hsla(0,0%,100%,0.01), hsla(0,0%,100%,0.2) 50%, hsla(0,0%,100%,0.01));
    box-shadow: 0 0 2px hsla(0,0%,100%,0.15);
    height: var(--crt-moving-scanline-height);
    left: 0; mix-blend-mode: screen;
    opacity: 0.3; position: fixed;
    top: -20px; width: 100%;
    z-index: 100001;
  }

  .crt-flicker {
    animation: crt-flicker 10s infinite;
    background-color: transparent;
    height: 100%; left: 0;
    mix-blend-mode: overlay;
    position: fixed; top: 0; width: 100%;
    z-index: 100003;
  }
  .crt-flicker::after {
    animation: flicker 15s infinite;
    background: rgba(255,255,255,var(--crt-flicker-opacity));
    content: ""; height: 100%; left: 0;
    mix-blend-mode: normal; opacity: 0;
    position: absolute; top: 0; width: 100%;
  }

  .crt-vignette {
    background: radial-gradient(ellipse at center, transparent 70%, rgba(0,0,0,0.08) 100%);
    height: 100%; left: 0;
    mix-blend-mode: multiply;
    position: fixed; top: 0; width: 100%;
    z-index: 100005;
  }

  .crt-noise {
    background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADIAAAAyCAYAAAAeP4ixAAAABmJLR0QA/wD/AP+gvaeTAAAACXBIWXMAAAsTAAALEwEAmpwYAAAAB3RJTUUH4AYSFCkEKYR5NwAAAB1pVFh0Q29tbWVudAAAAAAAQ3JlYXRlZCB3aXRoIEdJTVBkLmUHAAAFMklEQVRo3u2aTYgbVRTHf+flJQUndtLYmcxkPpJMptA2yUx2XRT8QBFajFSUQhciCo1F62Zdl9UuXLhwIbgSRF1YLNSFVApaqrW2Cwr9oO20adPOJJN8TjNJJpnk3S7mZQpCmfH1FcwPDrx3Lzfv/s9999xz7oWfZDT+JLBOnAL0vDT93AcXI8DBCvUupOmcAQ4BDgGmLaXbAD4CMICzY7j61/iUMZWPmYsZbSMhFQZg2sK+oXcW3NkUfQ/4CjiKQ8DJxBKjKmLdJjV9uVYTKnUhkhLysSahAI9HiU7OC/GE0EoJkbSQjQmRuGRTwjomFOJCNS4kk0I2IeRiQiEqTEUk0pXFwffjwEZTEO0Knu5A/8/w7ReQW4TlzXB4HIoVuLgEk3MQb8OeLpgegsXrML4Ikj6Y0BYV6Ai87MJLj0FkFob7Ye80zL0Hh0bh+2tQexLefRa+OQXHx+GLl+DkfiicgxtFmChB4jroZekZhAe2wcNRoAMDCsQ2QukqJKYhfQFOPw6n9sFYAZbfgL2d8MmLkF2ApRT0/Qjb/wQdyP5rG/VtMsRBbxTM7fDVFFydg/k6JFNwKQBTXjicgYFu6M7A5DXIzoEuVLHoiYB0CqsZILIJUg3IRSCoQG8HZLpgOgNXzsCFUXhgN3QJYAlUDPoioHcAfmDVUjJQGQmA/jXw6tABEIZnHoWPz0O9BNF7YUc35AswM4dpSlJSmkCdJeKQqcHGLMR7oNcAVYFXAnA5D2tnwF+Eb4IwNQVJBdQIfg1MkoCvDukq1JwQ0MG0QK2CkYbSw5AchONfQ3YCDh2ETzNQbEA6CgcPYIZNgnqVdFFKFMCnQxDYW4GaA6a/7m7eJAS7oVwCFT4Pw8VzsH8U5qdg72MwfAaG34LMT1CehFgTMHDQqFHVaigFhVAO/ChYDexqE4orUKpD7Dp0bIL0TsjkYWEBigvQGIChBtzog8UEZA0wI1i0V4yp1DQm5yktY0KVtBQYXQDrQsi1PiLzsGcOTs7DlXlYuwuGYjAQg5k4TK2D9xZUi9i0t0EZhbwUMFDGJzVpEjYr6Kt3nBVgJQ25ALQaEAhDow7JCNgikIqCfxHu3ogx3Yfa4aIppdYW0W0ZEj5oiDCl++hRhHhKqKwK9SpCyYS5Fuy4fIcAUyZYAnNegZUitv9W8BWQU2DSgzQsAj5hdAHeq2FrNfjZhYFRSBSAxRL0Z2GpF3wFcuZdRKROa9HBUhWUILQrUFN4rQ3RUTjRCefrYJyFkztgvAwlwCcCyjC++t+I6A62ZR+2NQciQtgCzYAuHVp3QTUGHVVYa0GkCisZcKwK1gpYdcCt/38Hf9V5GQPLs1i6hoMiLRHKFliNwPtCVBHMuPBqCcoetPJCwcS0LUwFgmq9nUYCLEyhTQ1a3jJKpEmHFRCM2pDwwb4MnMtBYx52JSH1AGTdEEcHPwjtuaG1vc7LcnAoS2ihRsVrE1WFliNUCkK1FyIZGPPA1vGb35tFdkWEtfVQe3yFuRvkWwPkXYtCy89UExZdJ2HNyX1+A6PXYdmC+9zCeBkYLtJe1Lj6R29jXYHrJcgXABseFWFNF0ouODYHhQ6MiLDR8feSbzeiqeCZH9DbBt5k+cZDCc01Ia44iYiw7IO1Eo77q7/dPZpZWNsDaQO78CPN1XlSOZfDaZs9KUG78Zt+14JQWoBEHDIWhtZm3W5P87D9Bqm0QT3t5mTagCrWbypOgdZuDdOW32zfV4xpRXHz5eLWDaHa5L8CXv2J9pP8Ij8ALHQWw2ReQZEAAAAASUVORK5CYII=");
    background-repeat: repeat;
    height: calc(100% + 1000px); left: -500px;
    opacity: 0.05; position: fixed;
    top: -500px; width: calc(100% + 1000px);
    z-index: 100006;
    animation: noise 8s steps(1) infinite;
  }

  .crt-aberration {
    height: 100%; left: 0;
    mix-blend-mode: screen;
    opacity: var(--crt-aberration-opacity);
    position: fixed; top: 0; width: 100%;
    z-index: 100007;
  }
  .crt-aberration::before {
    background: rgba(255,0,0,0.08);
    content: ""; display: block;
    height: 100%; left: 0; position: absolute; top: 0; width: 100%;
    mix-blend-mode: screen;
    transform: translate(calc(-1 * var(--crt-aberration-offset)), 0);
  }
  .crt-aberration::after {
    animation: chromatic-shift 3s ease-in-out infinite;
    background: rgba(0,0,255,0.08);
    content: ""; display: block;
    height: 100%; left: 0; position: absolute; top: 0; width: 100%;
    mix-blend-mode: screen;
    transform: translate(var(--crt-aberration-offset));
  }

  .crt-persistence {
    background: rgba(150,255,150,0.01);
    height: 100%; left: 0;
    mix-blend-mode: screen;
    position: fixed; top: 0; width: 100%;
    z-index: 100008;
  }

  body { filter: brightness(1.01) contrast(1.015) saturate(1.02); }
  body.crt-on { filter: brightness(1.06) contrast(1.08) saturate(1.06); }

  @keyframes crt-glitch {
    0%,100% { filter: brightness(1.06) contrast(1.08) saturate(1.12); }
    20%     { filter: brightness(1.12) contrast(1.12) saturate(0.95); }
    40%     { filter: brightness(1.04) contrast(1.18) saturate(1.15); }
    60%     { filter: brightness(1.10) contrast(1.04) saturate(1.08); }
  }
  body.crt-turning-on  { animation: crt-glitch 0.3s ease-out forwards; }
  body.crt-turning-off { animation: crt-glitch 0.25s ease-in forwards; }

  /* ── Login → Welcome transition ── */
  .welcome-message {
    align-items: center;
    background-color: transparent;
    color: #fff;
    display: none;
    font-family: Tahoma, Arial, sans-serif;
    height: 100%;
    justify-content: center;
    left: 0;
    opacity: 0;
    pointer-events: none;
    position: absolute;
    top: 0;
    width: 100%;
    transition: opacity .7s ease;
    z-index: 10;
  }
  .welcome-message.visible {
    display: flex;
  }
  .welcome-image-fallback {
    border-radius: 8px;
    color: #fff;
    display: block;
    font-size: 3rem;
    font-style: italic;
    font-weight: 700;
    letter-spacing: .3px;
    margin: 0 auto;
    padding: 32px 0;
    text-align: center;
    text-shadow: 1px 1px 3px rgba(0,0,0,.67), 0 1px 0 #36c;
  }
  .logoff-btn {
    display: flex; flex-direction: column;
    align-items: center; gap: 6px;
    padding: 10px 16px;
    border: 2px solid transparent;
    border-radius: 4px;
    --xp-cursor: url('https://unwellfargo.neocities.org/img/xp-icons/link_m.png') 0 0, pointer; cursor: var(--xp-cursor);
    font-size: 11px;
    font-family: Tahoma, sans-serif;
    color: #000;
    background: transparent;
    transition: background 0.15s, border-color 0.15s;
  }
  .logoff-btn:hover {
    background: rgba(49,105,199,0.15);
    border-color: #3169c7;
  }

  /* ── Window Menu Bar ── */
  .win-menubar {
    background: #e9e9e9;
    border-bottom: 2px solid #d7d4ca;
    display: flex;
    align-items: center;
    height: 22px;
    padding: 0 2px;
    position: relative;
    z-index: 50;
    flex-shrink: 0;
    user-select: none;
  }
  .wmb-item {
    padding: 2px 8px;
    font-size: 11px;
    font-family: Tahoma, Arial, sans-serif;
    --xp-cursor: url('https://unwellfargo.neocities.org/img/xp-icons/link_m.png') 0 0, pointer; cursor: var(--xp-cursor);
    border-radius: 2px;
    position: relative;
    white-space: nowrap;
  }
  .wmb-item:hover,
  .wmb-item.active { background: #0a6fc2; color: #fff; }

  .wmb-dropdown {
    display: none;
    position: absolute;
    top: 22px;
    left: 0;
    background: #f2f2f2;
    border: 1px solid #d0d0d0;
    box-shadow: 2px 2px 5px rgba(0,0,0,0.18);
    min-width: 160px;
    z-index: 9999;
    padding: 2px 0;
    font-family: Tahoma, Arial, sans-serif;
    font-size: 11px;
  }
  .wmb-dropdown.open { display: block; }

  .wmb-opt {
    padding: 3px 20px 3px 24px;
    --xp-cursor: url('https://unwellfargo.neocities.org/img/xp-icons/link_m.png') 0 0, pointer; cursor: var(--xp-cursor);
    white-space: nowrap;
    color: #000;
  }
  .wmb-opt:hover:not(.disabled) { background: #0a6fc2; color: #fff; }
  .wmb-opt.disabled { color: #aaa; cursor: default; }

  .wmb-sep {
    height: 1px;
    background: #e0e0e0;
    margin: 3px 0;
  }