/* ===================================================================
   FoxyCorp — Cuddly Compliance UI (Stitch palette)
   bg #fbf9f3 · primary #944930 · peach #ff9e80/#ffb59e · teal #a2cfcb
   v9 — TOP NAV layout (no sidebar)
   =================================================================== */
:root{
  --bg:#fbf9f3; --surface:#ffffff; --surface-2:#f5f3ee; --surface-3:#f0eee8;
  --line:#e8e4db; --line-2:#ded8cc;
  --primary:#944930; --primary-soft:#ff9e80; --primary-tint:#ffdbd0;
  --peach:#ffb59e; --peach-bg:#ffe9e0;
  --teal:#a2cfcb; --teal-bg:#e3f1ef;
  --ink:#2f1a12; --ink-2:#7a6a60; --ink-3:#a99c92;
  --good:#5fa888; --warn:#e0a23c; --bad:#d2603f;
  --r:22px; --r-sm:14px;
  --shadow:0 10px 30px -12px rgba(120,50,28,.18);
  --shadow-sm:0 4px 14px -8px rgba(120,50,28,.25);
  --topnav-h: 56px;
  --lore-h: 50px;  /* lore row height on desktop */
  --header-total: calc(var(--topnav-h) + var(--lore-h));
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{
  font-family:"Nunito Sans",system-ui,sans-serif;
  background:
    radial-gradient(1200px 600px at 80% -10%, #fff3ec 0%, transparent 60%),
    var(--bg);
  color:var(--ink); -webkit-font-smoothing:antialiased;
}
.material-symbols-rounded{font-size:20px;line-height:1;vertical-align:middle}
h1,h2,h3{font-family:"Quicksand",sans-serif;margin:0}

/* ===================================================================
   APP SHELL — top nav + scrollable main below
   =================================================================== */
.app{
  display:flex;
  flex-direction:column;
  height:100vh;
  overflow:hidden;
}

/* ===================================================================
   TOP NAVIGATION HEADER
   =================================================================== */
.topnav{
  background:var(--surface);
  border-bottom:1px solid var(--line);
  box-shadow:var(--shadow-sm);
  position:sticky;top:0;z-index:40;
  flex:none;
}

/* ── Row 1: brand + floor nav + controls ── */
.topnav-row1{
  display:flex;
  align-items:center;
  gap:12px;
  padding:0 16px;
  height:var(--topnav-h);
  min-width:0;
}

/* Brand */
.brand{display:flex;align-items:center;gap:10px;flex:none}
.brand-logo{width:36px;height:36px;border-radius:11px;object-fit:cover;box-shadow:var(--shadow-sm)}
.brand-text h1{font-size:18px;color:var(--primary);font-weight:700;line-height:1.1}
.brand-text .tagline{font-size:10px;color:var(--ink-3);font-weight:700;white-space:nowrap}

/* Floor nav — scrollable, takes remaining space */
.nav{
  display:flex;
  flex-direction:row;
  gap:4px;
  flex:1 1 0;
  min-width:0;
  overflow-x:auto;
  scrollbar-width:none;
  -webkit-overflow-scrolling:touch;
  align-items:center;
  padding:4px 0;
}
.nav::-webkit-scrollbar{display:none}
.nav-item{
  display:flex;align-items:center;gap:8px;
  padding:7px 12px;border:0;
  background:transparent;border-radius:11px;cursor:pointer;
  font:inherit;font-size:12.5px;font-weight:700;color:var(--ink-2);
  white-space:nowrap;flex:none;transition:.15s;
}
.nav-item:hover:not(:disabled){background:var(--surface-2);color:var(--ink)}
.nav-item.active{background:var(--peach-bg);color:var(--primary)}
.nav-item.active .material-symbols-rounded{color:var(--primary-soft)}
.nav-item:disabled{opacity:.45;cursor:default}

/* Right controls cluster */
.topnav-controls{
  display:flex;
  align-items:center;
  gap:10px;
  flex:none;
  margin-left:auto;
}


/* Cuddle button */
.cuddle-btn{
  display:flex;align-items:center;justify-content:center;gap:8px;
  padding:9px 15px;border:0;border-radius:14px;cursor:pointer;
  font:inherit;font-weight:800;font-size:13px;
  color:#fff;background:linear-gradient(135deg,var(--primary),#b6603f);
  box-shadow:var(--shadow-sm);transition:.15s;white-space:nowrap;flex:none;
}
.cuddle-btn:hover{transform:translateY(-1px);filter:brightness(1.05)}
.cuddle-btn:active{transform:translateY(0)}
.cuddle-btn .material-symbols-rounded{font-size:18px}

/* Lang switcher */
.lang{display:flex;gap:3px;background:var(--surface-2);padding:3px;border-radius:10px;flex:none}
.lang button{
  border:0;background:transparent;font:inherit;font-weight:800;font-size:11px;
  color:var(--ink-3);padding:5px 8px;border-radius:8px;cursor:pointer;
}
.lang button.active{background:#fff;color:var(--primary);box-shadow:var(--shadow-sm)}

/* Connection badge */
.conn{font-size:11px;font-weight:800;color:var(--ink-3);flex:none}
.conn.live{color:var(--good)}

/* Lore toggle (mobile only) */
.lore-toggle{
  display:none;
  border:1px solid var(--line);background:var(--surface-2);
  border-radius:10px;width:36px;height:36px;
  align-items:center;justify-content:center;
  cursor:pointer;color:var(--ink-2);transition:.15s;
}
.lore-toggle:hover{background:var(--peach-bg);color:var(--primary)}
.lore-toggle[aria-expanded="true"]{background:var(--peach-bg);color:var(--primary)}
.lore-toggle .material-symbols-rounded{font-size:20px}

/* ── Lore row (desktop: inline, mobile: collapsible) ── */
.topnav-lore{
  border-top:1px solid var(--line);
  padding:8px 16px;
  background:var(--surface-2);
}
.lore-card{display:flex;align-items:flex-start;gap:14px}
.lore-head{
  display:flex;align-items:center;gap:5px;color:var(--primary);font-weight:800;
  font-size:10px;text-transform:uppercase;letter-spacing:.4px;flex:none;
}
.lore-list{
  list-style:none;margin:0;padding:0;
  display:flex;flex-direction:row;flex-wrap:wrap;gap:6px 16px;
}
.lore-list li{display:flex;gap:5px;font-size:11px;line-height:1.3;color:var(--ink-2)}
.lore-ic{flex:0 0 auto}

/* ===================================================================
   MAIN CONTENT AREA
   =================================================================== */
.main{
  padding:18px 22px;
  display:flex;flex-direction:column;gap:16px;
  flex:1;min-height:0;
  overflow-y:auto;
  min-width:0;
  height:calc(100vh - var(--topnav-h) - var(--lore-h));
}

.topbar{display:flex;align-items:center;gap:12px}
.clock{display:flex;align-items:center;gap:7px;background:var(--surface);
  border:1px solid var(--line);border-radius:14px;padding:8px 13px;box-shadow:var(--shadow-sm)}
.clock b{font-family:"Quicksand";font-size:16px}
.clock .phase{font-size:11px;font-weight:800;color:var(--primary-soft);text-transform:uppercase;letter-spacing:.5px}
.clock .material-symbols-rounded{color:var(--ink-3)}
.topbar .online{margin-left:auto}
/* Legacy stat chips - hidden but kept for JS safety */
.stat-chips{display:none}
.chip{display:none}

/* ===================================================================
   STAGE (office view)
   =================================================================== */
.stage{display:grid;grid-template-columns:1fr 300px;gap:16px;flex:1;min-height:0}

.floor-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);
  padding:18px;box-shadow:var(--shadow);display:flex;flex-direction:column;min-width:0;min-height:0}
.floor-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px}
.floor-head h2{font-size:19px;color:var(--primary)}
.floor-head .loc small{display:block;font-size:11px;font-weight:800;color:var(--ink-3);
  text-transform:uppercase;letter-spacing:.6px}
.floor-head .loc h2{font-size:20px;color:var(--primary)}
.online{flex:none;font-size:11px;font-weight:800;color:var(--ink-3);
  background:var(--surface-2);padding:6px 11px;border-radius:10px;white-space:nowrap}
.online.live{color:var(--good);background:var(--teal-bg)}

/* AmFoxy pill link */
.amfoxy-pill{
  display:flex;align-items:center;gap:7px;
  padding:7px 13px;border-radius:999px;
  background:linear-gradient(120deg,#fff4ef,#ffddd0);
  border:1px solid var(--primary-tint);
  color:var(--primary);font-family:"Quicksand",sans-serif;
  font-weight:800;font-size:12px;white-space:nowrap;
  text-decoration:none;transition:.2s;box-shadow:var(--shadow-sm);
  margin-left:8px;flex-shrink:0;
}
.amfoxy-pill:hover{
  background:linear-gradient(120deg,#ffe8dd,#ffc5b0);
  transform:translateY(-1px);box-shadow:var(--shadow);
  border-color:var(--primary-soft);
}
.amfoxy-pill .material-symbols-rounded{font-size:16px;color:var(--primary-soft)}
@media(max-width:520px){
  .amfoxy-pill span:last-child{display:none}
  .amfoxy-pill{padding:7px 10px}
}

.meeting-flag{margin-left:auto;display:none;align-items:center;gap:5px;font-size:12px;font-weight:800;
  color:#fff;background:linear-gradient(135deg,var(--primary),#b6603f);padding:7px 12px;border-radius:11px;
  animation:beep 1s ease-in-out infinite}
.meeting-flag.on{display:inline-flex}

.scene-wrap{position:relative;flex:1;min-height:0;border-radius:18px;overflow:hidden;
  border:1px solid var(--primary-tint);
  background:radial-gradient(120% 90% at 50% 0%, #fffaf7 0%, #ffefe8 60%, #ffe3d9 100%)}
#scene{width:100%;height:100%;display:block;touch-action:none}
.hint-pill{position:absolute;left:50%;bottom:12px;transform:translateX(-50%);
  background:#ffffffcc;backdrop-filter:blur(4px);border:1px solid var(--line);
  font-size:11px;font-weight:700;color:var(--ink-2);padding:6px 12px;border-radius:11px;pointer-events:none}

/* DOM labels projected over the 3D foxes */
.fox-labels{position:absolute;inset:0;overflow:hidden;pointer-events:none}
.fox-label{position:absolute;transform:translate(-50%,-100%);text-align:center;pointer-events:auto;cursor:pointer}
.fl-name{display:inline-block;font-family:"Quicksand";font-weight:700;font-size:12px;color:var(--ink);
  background:#fffffff0;border:1px solid var(--line);border-radius:11px;padding:2px 8px;box-shadow:var(--shadow-sm);white-space:nowrap}
.fl-name span{font-size:11px}
.fox-label.attention .fl-name{box-shadow:0 0 0 2px var(--primary-soft),var(--shadow-sm);animation:beep 1s infinite}
.fox-label.creative-block .fl-name{box-shadow:0 0 0 2px #e8c8f0,var(--shadow-sm)}
.fox-label.creative-block .fl-name::after{content:" 😵";font-size:10px}
.fl-bubble{position:absolute;bottom:100%;left:50%;transform:translate(-50%,4px);margin-bottom:6px;
  background:#fff;border:1px solid var(--line);border-radius:13px;padding:7px 10px;font-family:"Nunito Sans";
  font-size:12px;line-height:1.35;width:max-content;max-width:180px;box-shadow:var(--shadow);
  opacity:0;transition:.25s;white-space:normal}
.fl-bubble::after{content:"";position:absolute;top:100%;left:50%;transform:translateX(-50%);
  border:6px solid transparent;border-top-color:#fff}
.fl-bubble.show{opacity:1;transform:translate(-50%,0)}

/* Mood Bar — fox dot strip under the 3D scene */
.mood-bar{
  display:flex;gap:10px;justify-content:center;padding:10px 0 4px;
  flex-wrap:wrap;
}
.mood-dot{
  display:flex;flex-direction:column;align-items:center;gap:4px;
  cursor:pointer;position:relative;
}
.mood-dot-circle{
  width:36px;height:36px;border-radius:50%;
  border:2.5px solid #fff;
  box-shadow:0 2px 8px -3px rgba(120,50,28,.25);
  transition:.25s;position:relative;
  display:flex;align-items:center;justify-content:center;
  font-size:11px;
}
.mood-dot:hover .mood-dot-circle{transform:scale(1.15)}
.mood-dot.creative-block .mood-dot-circle::after{
  content:"😵";position:absolute;top:-6px;right:-6px;font-size:12px;
}
.mood-dot-name{
  font-size:9px;font-weight:800;color:var(--ink-3);letter-spacing:.3px;
  white-space:nowrap;text-transform:uppercase;
}
.mood-dot-tooltip{
  position:absolute;bottom:calc(100% + 6px);left:50%;transform:translateX(-50%);
  background:#2f1a12;color:#fff;border-radius:9px;padding:6px 10px;
  font-size:11px;font-weight:700;white-space:nowrap;
  opacity:0;pointer-events:none;transition:.15s;z-index:99;
}
.mood-dot:hover .mood-dot-tooltip{opacity:1}

/* ── Right rail ── */
.rail{display:flex;flex-direction:column;gap:14px;min-height:0;overflow-y:auto;padding-right:4px}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);
  padding:15px;box-shadow:var(--shadow)}
.card-head{display:flex;align-items:center;gap:8px;margin-bottom:11px}
.card-head h3{font-size:15px;color:var(--primary)}
.who-pill{margin-left:auto;font-size:12px;font-weight:800;color:var(--primary);
  background:var(--peach-bg);padding:5px 10px;border-radius:10px}
.card-head .dot{margin-left:auto;width:9px;height:9px;border-radius:50%;background:var(--good);
  box-shadow:0 0 0 4px var(--teal-bg)}

/* care card simplified */
.care-simple{display:flex;flex-direction:column;gap:10px}

/* Bigger cuddle button in the care panel */
.cuddle-big{
  width:100%;padding:13px;font-size:14px;
  border-radius:var(--r-sm);
  box-shadow:var(--shadow);
}

/* Café drinks */
.cafe-drinks{display:flex;flex-direction:column;gap:7px}
.drink-btn{
  display:flex;align-items:center;gap:10px;padding:10px 12px;
  border:1px solid var(--line);background:var(--surface-2);
  border-radius:13px;cursor:pointer;font:inherit;font-weight:700;
  font-size:12px;color:var(--ink);text-align:left;transition:.15s;
  position:relative;overflow:hidden;width:100%;
}
.drink-btn:hover:not(:disabled){background:#fff;border-color:var(--primary-tint);transform:translateY(-1px)}
.drink-btn:disabled{opacity:.55;cursor:default}
.drink-btn span{font-size:18px;flex:none}
.drink-btn b{display:block;font-size:12px;font-weight:800}
.drink-btn small{display:block;font-size:10px;font-weight:700;color:var(--ink-3)}
.drink-btn .cool{position:absolute;left:0;bottom:0;height:3px;background:var(--primary-soft);width:0;transition:width linear}

/* Fox mini card (selected fox in care panel) */
.fox-mini{
  display:flex;align-items:center;gap:10px;
  padding:10px 12px;border-radius:14px;
  background:var(--peach-bg);border:1px solid var(--primary-tint);
}
.fox-mini img{width:40px;height:40px;border-radius:12px;object-fit:contain}
.fox-mini-info{flex:1;min-width:0}
.fox-mini-info strong{display:block;font-family:"Quicksand";font-size:14px;font-weight:800;color:var(--primary)}
.fox-mini-info small{font-size:11px;color:var(--ink-2)}
.mini-needs{display:flex;gap:5px;margin-top:5px;flex-wrap:wrap}
.mini-need-pip{
  display:flex;align-items:center;gap:3px;font-size:11px;
  background:rgba(255,255,255,.7);padding:2px 6px;border-radius:8px;
  font-weight:700;color:var(--ink-2);
}

/* Legacy care classes — keep for any remaining JS refs */
.needs{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}
.need-row{display:flex;align-items:center;gap:8px}
.need-row .ic{font-size:14px;width:16px;text-align:center}
.need-row .lab{font-size:12px;font-weight:700;color:var(--ink-2);width:60px}
.need-row .track{flex:1;height:9px;border-radius:8px;background:var(--surface-3);overflow:hidden}
.need-row .track i{display:block;height:100%;border-radius:8px;transition:width .4s}
.need-row .val{font-size:11px;font-weight:800;color:var(--ink-3);width:28px;text-align:right}
.fox-picker{display:flex;gap:6px;margin-bottom:12px;flex-wrap:wrap}
.fox-chip{display:flex;align-items:center;gap:5px;border:1px solid var(--line);
  background:var(--surface-2);border-radius:11px;padding:4px 8px 4px 4px;cursor:pointer;font:inherit;
  font-weight:700;font-size:11px;color:var(--ink-2);transition:.15s;position:relative}
.fox-chip img{width:24px;height:24px;object-fit:contain}
.fox-chip.active{background:var(--peach-bg);border-color:var(--primary-tint);color:var(--primary)}
.fox-chip.beep::after{content:"";position:absolute;top:-3px;right:-3px;width:8px;height:8px;
  border-radius:50%;background:var(--primary-soft);box-shadow:0 0 0 3px #fff;animation:beep 1s infinite}
.care-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.care-btn{display:flex;align-items:center;gap:8px;padding:10px 11px;border:1px solid var(--line);
  background:var(--surface-2);border-radius:13px;cursor:pointer;font:inherit;font-weight:800;
  font-size:12px;color:var(--ink);text-align:left;transition:.15s;position:relative;overflow:hidden}
.care-btn:hover:not(:disabled){background:#fff;border-color:var(--primary-tint);transform:translateY(-1px)}
.care-btn:disabled{opacity:.55;cursor:default}
.care-btn .emo{font-size:17px}
.care-btn small{display:block;font-size:10px;font-weight:700;color:var(--ink-3)}
.care-btn .cool{position:absolute;left:0;bottom:0;height:3px;background:var(--primary-soft);width:0}

/* communal chat */
.slack{flex:1;display:flex;flex-direction:column;min-height:260px}
.log{display:flex;flex-direction:column;gap:8px;overflow-y:auto;flex:1;padding-right:4px}
.log-row{display:flex;gap:8px;align-items:flex-start}
.log-row img{width:28px;height:28px;object-fit:contain;flex:none;margin-top:2px}
.log-row .b{background:var(--surface-2);border-radius:12px;border-top-left-radius:4px;
  padding:7px 10px;font-size:12px;line-height:1.4;color:var(--ink)}
.log-row .who{display:block;font-family:"Quicksand";font-weight:700;font-size:11px;color:var(--primary);margin-bottom:1px}
.log-row.burnout .b{background:#fdeae3} .log-row.recover .b{background:var(--teal-bg)}

/* floor switcher items */
.floor-item{justify-content:flex-start}
.floor-item .fl-ix{display:grid;place-items:center;width:20px;height:20px;border-radius:6px;
  background:var(--surface-2);color:var(--ink-3);font-size:10px;font-weight:800;flex:none}
.floor-item.active .fl-ix{background:var(--primary-soft);color:#fff}
.floor-item .fl-count{margin-left:auto;min-width:18px;height:18px;padding:0 5px;border-radius:9px;
  display:grid;place-items:center;font-size:11px;font-weight:800;color:transparent}
.floor-item .fl-count.on{background:var(--teal-bg);color:var(--good)}
.floor-item[data-id="rooftop"] .fl-ix{background:#c8f0c8;color:#2d6e2d}
.floor-item[data-id="creative"] .fl-ix{background:#e8d0f8;color:#6030a0}

/* ===================================================================
   VIEW TABS
   =================================================================== */
.view-tabs{display:flex;gap:8px;flex-wrap:wrap}
.view-tab{display:flex;align-items:center;gap:7px;padding:8px 14px;border-radius:999px;
  border:1px solid var(--line);background:var(--surface);color:var(--ink-2);
  font-family:"Quicksand",sans-serif;font-weight:700;font-size:13px;cursor:pointer;
  transition:.15s}
.view-tab:hover{border-color:var(--peach)}
.view-tab.active{background:var(--primary);color:#fff;border-color:var(--primary)}
.view-tab .material-symbols-rounded{font-size:18px}

/* View switching */
.view:not(.active){display:none!important}
.view-pad{flex:1;overflow:auto;padding-right:4px}
.view-pad.active{display:flex;flex-direction:column;gap:16px}
.view-head h2{font-size:21px;color:var(--primary)}
.view-head p{margin:4px 0 0;color:var(--ink-3);font-size:13px}
.view-head{position:relative}
.empty{padding:36px;text-align:center;color:var(--ink-3);font-size:14px;
  background:var(--surface-2);border-radius:var(--r);border:1px dashed var(--line-2)}
.empty.sm{padding:16px;font-size:12px}

.ghost-btn{display:inline-flex;align-items:center;gap:6px;padding:7px 13px;border-radius:999px;
  border:1px solid var(--line-2);background:var(--surface);color:var(--primary);cursor:pointer;
  font-family:"Quicksand",sans-serif;font-weight:700;font-size:12px;transition:.15s}
.ghost-btn:hover{background:var(--primary-tint)}
.ghost-btn .material-symbols-rounded{font-size:17px}
#exportMemoirs{position:absolute;top:0;right:0}

/* Interview button */
.interview-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;
  margin-top:10px;padding:11px;border-radius:var(--r-sm);border:none;cursor:pointer;
  background:linear-gradient(120deg,var(--teal),#8fc3be);color:#1f4b47;
  font-family:"Quicksand",sans-serif;font-weight:800;font-size:14px;box-shadow:var(--shadow-sm)}
.interview-btn:hover{filter:brightness(1.04)}
.interview-btn .emo{font-size:17px}

/* ===================================================================
   SAGA / MEMOIRS
   =================================================================== */

.saga-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px}
.saga-card{position:relative;background:linear-gradient(140deg,#fff5ef,#f3ecfb);
  border:1px solid var(--line);border-radius:var(--r);padding:17px;box-shadow:var(--shadow-sm)}
.saga-badge{display:inline-block;background:var(--primary);color:#fff;font-weight:800;
  font-size:11px;padding:3px 10px;border-radius:999px;margin-bottom:9px;font-family:"Quicksand",sans-serif}
.saga-card h3{font-size:17px;color:var(--primary);margin-bottom:7px}
.saga-card p{margin:0 0 12px;color:var(--ink-2);font-size:13px;line-height:1.5}

.memoir-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:14px;align-items:start}
.memoir-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);
  padding:15px;box-shadow:var(--shadow-sm)}
.memoir-top{display:flex;align-items:center;gap:9px;margin-bottom:11px}
.memoir-top img{width:34px;height:34px;border-radius:10px;object-fit:cover}
.memoir-top strong{flex:1;font-family:"Quicksand",sans-serif;font-size:15px}
.mc-list{display:flex;flex-direction:column;gap:13px}
.mc h4{font-family:"Quicksand",sans-serif;font-size:13px;color:var(--primary);margin-bottom:3px}
.mc p{margin:0;font-size:13px;line-height:1.5;color:var(--ink-2);font-family:Georgia,serif}

/* ===================================================================
   TOASTS
   =================================================================== */
.toasts{position:fixed;right:16px;bottom:16px;display:flex;flex-direction:column;gap:8px;z-index:50}
.toast{background:var(--ink);color:#fff;padding:11px 15px;border-radius:13px;font-weight:700;
  font-size:13px;box-shadow:var(--shadow);display:flex;align-items:center;gap:8px;
  animation:slidein .3s ease;max-width:290px}
.toast.level{background:linear-gradient(135deg,var(--primary),#b6603f)}
.toast.burn{background:var(--bad)}
@keyframes slidein{from{transform:translateX(40px);opacity:0}}

/* ===================================================================
   SPECIAL COMPONENTS
   =================================================================== */
/* log-row kinds */
.log-row.ticker  { background:linear-gradient(90deg,#fff9e0,transparent); border-left:3px solid var(--warn); }
.log-row.night   { background:linear-gradient(90deg,#f0eaf8,transparent); border-left:3px solid #9b6dd0; opacity:.9; }
.log-row.situation{ background:linear-gradient(90deg,#eaf8f0,transparent); border-left:3px solid var(--teal); }
.log-row.burnout { background:linear-gradient(90deg,#fde8e0,transparent); border-left:3px solid var(--bad); }
.log-row.recover { background:linear-gradient(90deg,#e8f8ec,transparent); border-left:3px solid var(--good); }
.ticker-msg { font-size:12px; font-style:italic; color:var(--ink-2); padding:3px 0; }

/* Inquiry toast */
.inquiry-toast{
  background:var(--surface);border:1.5px solid var(--primary-tint);border-radius:18px;
  box-shadow:0 12px 36px -8px rgba(148,73,48,.28);
  padding:13px 15px;min-width:250px;max-width:310px;
  display:flex;flex-direction:column;gap:9px;
}
.iq-head{ display:flex;align-items:flex-start;gap:11px; }
.iq-avatar{ width:48px;height:48px;border-radius:11px;object-fit:contain;flex:none; }
.iq-text{ font-size:13px;color:var(--ink);line-height:1.4;margin-top:3px; }
.iq-opts{ display:flex;flex-wrap:wrap;gap:6px; }
.iq-opt{
  padding:7px 13px;border:0;border-radius:20px;cursor:pointer;font:inherit;font-size:12px;
  background:var(--peach-bg);color:var(--primary);font-weight:700;transition:.15s;
}
.iq-opt:hover{ background:var(--primary-soft);color:#fff; }
.iq-skip{
  align-self:flex-end;padding:3px 9px;border:0;border-radius:9px;cursor:pointer;
  background:transparent;color:var(--ink-3);font:inherit;font-size:11px;text-decoration:underline;
}
.iq-bar{ height:3px;border-radius:3px;background:var(--line);overflow:hidden;margin-top:2px; }
.iq-bar-fill{
  height:100%;background:var(--primary-soft);border-radius:3px;
  animation:iq-shrink linear forwards;width:100%;
}
@keyframes iq-shrink{ from{width:100%} to{width:0%} }

/* Day Arc banner */
.day-arc-banner{
  background:linear-gradient(135deg,#fff8e8,#f0f8ff);
  border:1.5px solid #e8d8a0;border-radius:14px;
  padding:9px 15px;font-size:13px;color:var(--ink-2);
  box-shadow:var(--shadow-sm);max-width:310px;line-height:1.4;
  animation:slide-in .3s ease;
}
.day-arc-banner em{ color:var(--ink);font-style:normal;font-weight:700; }

/* Interview chat modal */
.chat-overlay{position:fixed;inset:0;background:rgba(47,26,18,.34);backdrop-filter:blur(4px);
  display:flex;align-items:center;justify-content:center;z-index:60;padding:20px}
.chat-overlay[hidden]{display:none}
.chat-box{width:min(440px,100%);height:min(560px,90vh);background:var(--surface);
  border-radius:var(--r);box-shadow:var(--shadow);display:flex;flex-direction:column;overflow:hidden}
.chat-head{display:flex;align-items:center;gap:10px;padding:13px 15px;border-bottom:1px solid var(--line)}
.chat-head img{width:38px;height:38px;border-radius:11px;object-fit:cover}
.chat-head strong{display:block;font-family:"Quicksand",sans-serif}
.chat-head small{color:var(--ink-3);font-size:11px}
.chat-close{margin-left:auto;border:none;background:var(--surface-2);width:30px;height:30px;
  border-radius:9px;cursor:pointer;color:var(--ink-2);font-size:14px}
.chat-log{flex:1;overflow:auto;padding:15px;display:flex;flex-direction:column;gap:10px}
.cb{max-width:80%;padding:9px 12px;border-radius:14px;font-size:14px;line-height:1.45;white-space:pre-wrap}
.cb-me{align-self:flex-end;background:var(--primary);color:#fff;border-bottom-right-radius:5px}
.cb-fox{align-self:flex-start;background:var(--surface-2);color:var(--ink);border-bottom-left-radius:5px}
.cb.typing{opacity:.6;font-style:italic}
.chat-form{display:flex;gap:8px;padding:12px;border-top:1px solid var(--line)}
.chat-form input{flex:1;border:1px solid var(--line-2);border-radius:999px;padding:9px 14px;
  font-family:inherit;font-size:14px;outline:none}
.chat-form input:focus{border-color:var(--peach)}
.chat-form button{border:none;background:var(--primary);color:#fff;width:40px;border-radius:50%;
  cursor:pointer;display:flex;align-items:center;justify-content:center}

/* ===================================================================
   ANIMATIONS
   =================================================================== */
@keyframes beep{50%{transform:translateX(-50%) translateY(-2px)}}
@keyframes bob{50%{transform:translateY(-4px)}}
@keyframes slide-in{from{transform:translateY(-8px);opacity:0}}

/* ===================================================================
   RESPONSIVE — Tablet
   =================================================================== */
@media(max-width:1100px){
  .stage{grid-template-columns:1fr}
  .rail{flex-direction:row;flex-wrap:wrap}
  .card{flex:1;min-width:250px}
  .level-chip .level-hint-mini{display:none}
  .level-bar-mini{display:none}
}

@media(max-width:900px){
  /* Hide lore row entirely on tablet — save vertical space */
  .topnav-lore{display:none}
  .lore-toggle{display:flex}

  /* Topnav lore row shows when toggled on mobile */
  .topnav-lore.open{display:block}

  /* Recalculate main height without lore row */
  .main{height:calc(100vh - var(--topnav-h))}

  /* Compact cuddle label */
  .cuddle-btn .cuddle-label{display:none}
  .cuddle-btn{padding:9px 11px}

  /* Level chip — compact */
  .level-chip-info small{display:none}
}

/* ===================================================================
   RESPONSIVE — Mobile (≤ 680px)
   =================================================================== */
@media(max-width:680px){
  :root{ --topnav-h: 52px; }

  /* Let page scroll naturally */
  html,body{height:auto}
  .app{height:auto;min-height:100vh;overflow:visible}

  /* ── Top nav ── */
  .topnav-row1{
    padding:0 12px;
    gap:8px;
  }

  /* Hide tagline on small screens */
  .brand-text .tagline{display:none}
  .brand-text h1{font-size:16px}
  .brand-logo{width:30px;height:30px;border-radius:9px}

  /* Level chip minimal */
  .level-chip{padding:5px 8px;gap:5px}
  .level-chip .material-symbols-rounded{font-size:18px}
  .level-chip-info b{font-size:15px}
  .level-chip-info small{display:none}
  .level-bar-mini{display:none}
  .level-hint-mini{display:none}

  /* Conn text: hide label, keep dot */
  .conn{font-size:0;width:10px;height:10px;border-radius:50%;
    background:var(--ink-3);position:relative}
  .conn.live{background:var(--good)}

  /* Lang buttons: compact */
  .lang button{padding:4px 6px;font-size:10px}

  /* Topnav controls compact gap */
  .topnav-controls{gap:6px}

  /* Lore: shown as overlay panel under header when toggled */
  .topnav-lore{
    display:none;
    position:absolute;
    top:var(--topnav-h);
    left:0;right:0;
    z-index:39;
    box-shadow:var(--shadow);
    border-bottom:1px solid var(--line);
  }
  .topnav-lore.open{display:block}
  .lore-card{flex-direction:column;gap:6px}
  .lore-list{flex-direction:column;gap:5px}

  /* Main: full width, scrollable */
  .main{
    padding:12px 12px;
    flex:none;
    height:auto;
    overflow:visible;
    min-height:calc(100vh - var(--topnav-h));
  }

  /* Topbar chips: scrollable row */
  .topbar{flex-wrap:nowrap;overflow-x:auto;gap:8px;-webkit-overflow-scrolling:touch}
  .topbar::-webkit-scrollbar{display:none}
  .clock{flex:0 0 auto;padding:7px 11px}
  .stat-chips{margin-left:0;gap:7px;flex:0 0 auto;flex-wrap:nowrap}
  .stat-chips .chip{flex:0 0 auto;padding:7px 10px;min-width:0}
  .stat-chips .chip b{font-size:14px}

  /* View tabs: scrollable */
  .view-tabs{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;gap:6px}
  .view-tabs::-webkit-scrollbar{display:none}
  .view-tab{flex:0 0 auto;padding:7px 12px;font-size:12px}

  /* Stage: single column, natural height */
  .stage{grid-template-columns:1fr;flex:none;min-height:auto}
  .floor-card{padding:13px}
  .floor-head .loc h2,#floorTitle{font-size:17px}

  /* Scene: tall enough to be playable */
  .scene-wrap{min-height:60vh}
  #view-office.active{display:flex;flex-direction:column}

  /* Rail: stacked */
  .rail{flex-direction:column}
  .card{min-width:0;flex:none}

  /* View-pad: natural height */
  .view-pad{flex:none;overflow:visible}

  .lore-toggle{display:flex}
}

/* ===================================================================
   PROJECTS / MANUSCRIPT BOARD
   =================================================================== */
.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}

.project-card{
  background:var(--surface);border:1px solid var(--line);
  border-radius:var(--r);padding:18px;box-shadow:var(--shadow-sm);
  display:flex;flex-direction:column;gap:12px;
  position:relative;overflow:hidden;
}
.project-card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:4px;
  background:linear-gradient(90deg,var(--primary-soft),var(--peach));
}
.project-card.published::before{
  background:linear-gradient(90deg,#5fa888,#a2cfcb);
}
.project-cover{font-size:36px;line-height:1;text-align:center;margin-bottom:2px}
.project-title{font-family:"Quicksand",sans-serif;font-size:17px;font-weight:800;color:var(--primary);text-align:center}
.project-phase{
  display:inline-flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;
  padding:4px 10px;border-radius:999px;
}
.phase-writing{background:#fff3e0;color:#c47a00}
.phase-editing{background:#e8f0fe;color:#1a73e8}
.phase-layout{background:#f3e5f5;color:#7b1fa2}
.phase-published{background:var(--teal-bg);color:#1b6b60}

.project-progress-wrap{
  background:var(--surface-3);border-radius:8px;height:10px;overflow:hidden;
}
.project-progress-bar{
  height:100%;border-radius:8px;
  background:linear-gradient(90deg,var(--primary-soft),var(--peach));
  transition:width .8s ease;
}
.project-card.published .project-progress-bar{
  background:linear-gradient(90deg,#5fa888,#a2cfcb);
}
.project-progress-pct{
  font-family:"Quicksand";font-size:13px;font-weight:800;
  color:var(--ink-2);text-align:right;
}
.project-meta{display:flex;justify-content:space-between;align-items:center;font-size:12px}
.project-assigned{display:flex;gap:4px;align-items:center}
.project-assigned img{width:22px;height:22px;border-radius:7px;object-fit:contain;border:2px solid #fff;box-shadow:var(--shadow-sm);margin-left:-6px}
.project-assigned img:first-child{margin-left:0}
.project-deadline{
  font-weight:800;font-size:11px;color:var(--ink-3);
  background:var(--surface-2);padding:3px 8px;border-radius:8px;
}
.project-deadline.urgent{color:var(--bad);background:#fdeae3}

/* Book launch celebration overlay */
@keyframes book-launch{
  0%{transform:scale(.5) translateY(20px);opacity:0}
  60%{transform:scale(1.12) translateY(-6px);opacity:1}
  100%{transform:scale(1) translateY(0);opacity:1}
}
.book-launch-toast{
  position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);
  background:linear-gradient(135deg,var(--primary),#b6603f);
  color:#fff;border-radius:24px;padding:28px 36px;text-align:center;
  box-shadow:0 24px 60px -12px rgba(120,50,28,.45);z-index:200;
  animation:book-launch .6s cubic-bezier(.34,1.56,.64,1) forwards;
}
.book-launch-toast .bl-cover{font-size:52px;display:block;margin-bottom:8px;filter:drop-shadow(0 4px 12px rgba(0,0,0,.25))}
.book-launch-toast h3{font-family:"Quicksand";font-size:20px;font-weight:800;margin:0 0 4px}
.book-launch-toast p{margin:0;font-size:13px;opacity:.85}

/* New log row kinds */
.log-row.creative .b{background:#f3e5f5;border-left:3px solid #ce93d8}
.log-row.phase .b{background:#e8f0fe;border-left:3px solid #90aef8}
.log-row.launch .b{background:linear-gradient(90deg,#fff9e0,#ffe0cc);border-left:3px solid var(--primary-soft)}
.log-row.relationship .b{background:#fff0f5;border-left:3px solid #ff69b4}

/* Floating emojis for relationship updates */
.floating-emo {
  position: absolute;
  transform: translate(-50%, -50%);
  font-size: 24px;
  pointer-events: none;
  z-index: 100;
  text-shadow: 0 2px 4px rgba(0,0,0,0.2);
}
