:root{
  --bg:#10131e; --deep:#060711; --panel:#1d2233; --panel2:#2b3148; --ink:#fff6de; --muted:#c7bfae;
  --gold:#ffd66e; --green:#72ffc3; --blue:#87d8ff; --red:#ff7777; --purple:#c7a5ff; --line:rgba(255,255,255,.13);
  --safeTop:env(safe-area-inset-top,0px); --safeBottom:env(safe-area-inset-bottom,0px);
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;min-height:100%;background:var(--deep);color:var(--ink);font-family:ui-rounded,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif}
body{overflow-x:hidden}.app{min-height:100svh;background:radial-gradient(circle at 20% -10%,rgba(255,214,110,.22),transparent 34%),radial-gradient(circle at 90% 8%,rgba(135,216,255,.16),transparent 36%),linear-gradient(180deg,#151828,#060711 70%);padding:calc(12px + var(--safeTop)) 12px calc(28px + var(--safeBottom))}.topbar{max-width:980px;margin:0 auto 10px;display:grid;grid-template-columns:1fr auto;gap:12px;align-items:center}.eyebrow{display:block;font-size:10px;font-weight:1000;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,246,222,.58)}h1{margin:3px 0 0;font-size:clamp(28px,8vw,54px);line-height:.9;letter-spacing:-.075em}.smallBtn,.tab,.actionBtn{border:1px solid var(--line);background:rgba(255,255,255,.075);color:var(--ink);border-radius:16px;font-weight:1000;letter-spacing:.04em;min-height:46px;padding:0 14px;box-shadow:0 12px 32px rgba(0,0,0,.22)}.primary{background:linear-gradient(180deg,#ffe5a1,#b87328);color:#251204;border-color:rgba(255,230,160,.5)}.tabs{max-width:980px;margin:0 auto 12px;display:grid;grid-template-columns:repeat(4,1fr);gap:8px;position:sticky;top:0;z-index:10;padding:8px 0;background:linear-gradient(180deg,rgba(6,7,17,.96),rgba(6,7,17,.78),rgba(6,7,17,0));backdrop-filter:blur(10px)}.tab{font-size:12px;min-height:44px}.tab.active{background:linear-gradient(180deg,#83ffd0,#2c8a69);color:#04140d;border-color:rgba(114,255,195,.55)}main{max-width:980px;margin:0 auto}.view{display:none}.view.active{display:block}.hero{position:relative;overflow:hidden;border:1px solid var(--line);border-radius:28px;background:var(--panel);box-shadow:0 30px 90px rgba(0,0,0,.36)}.heroBg{position:absolute;inset:0;background-image:var(--bgimg);background-size:cover;background-position:center;opacity:.22;filter:saturate(1.15)}.heroShade{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.05),rgba(0,0,0,.82))}.heroInner{position:relative;display:grid;grid-template-columns:112px 1fr;gap:14px;padding:18px}.portrait{width:112px;height:112px;border-radius:26px;background:rgba(0,0,0,.28);border:1px solid rgba(255,255,255,.18);display:grid;place-items:center;box-shadow:inset 0 1px rgba(255,255,255,.06)}.portrait img{width:92px;height:92px;object-fit:contain}.titleLine{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.saveBadge{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:6px 9px;background:rgba(255,214,110,.15);border:1px solid rgba(255,214,110,.33);color:#ffe6a6;font-size:11px;font-weight:1000;letter-spacing:.08em;text-transform:uppercase}.hero h2{margin:0;font-size:clamp(36px,11vw,72px);letter-spacing:-.085em;line-height:.86}.meta{margin-top:8px;color:rgba(255,246,222,.76);font-weight:900}.chips{display:flex;gap:7px;flex-wrap:wrap;margin-top:12px}.chip{border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.075);border-radius:999px;padding:7px 9px;font-size:12px;font-weight:950}.grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:12px}.card{border:1px solid var(--line);background:rgba(29,34,51,.88);border-radius:24px;padding:14px;box-shadow:0 18px 55px rgba(0,0,0,.25)}.card h3{margin:0 0 10px;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,246,222,.58)}.bigNext{font-size:22px;line-height:1.05;font-weight:1000;letter-spacing:-.04em}.soft{color:var(--muted);font-weight:750;line-height:1.35}.statGrid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.stat{border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.055);border-radius:18px;padding:10px;text-align:center}.stat img{width:34px;height:34px;object-fit:contain}.stat b{display:block;margin-top:4px;font-size:20px}.stat span{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,246,222,.56);font-weight:1000}.lootList,.skillList{display:grid;gap:8px}.lootRow,.skillRow{display:grid;grid-template-columns:48px 1fr;gap:10px;align-items:center;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.045);border-radius:18px;padding:8px}.lootRow img,.skillRow img{width:48px;height:48px;object-fit:contain;background:rgba(0,0,0,.18);border-radius:12px;padding:3px}.lootRow b,.skillRow b{display:block}.lootRow p,.skillRow p{margin:3px 0 0;color:var(--muted);font-size:12px;line-height:1.25;font-weight:750}.petBox{display:grid;grid-template-columns:70px 1fr;gap:12px;align-items:center}.petBox img{width:70px;height:70px;object-fit:contain;border:1px solid rgba(255,255,255,.14);border-radius:18px;background:rgba(0,0,0,.2);padding:4px}.timelineShell{border:1px solid var(--line);background:rgba(29,34,51,.82);border-radius:26px;padding:14px}.timelineHead{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px}.timelineHead h2{margin:0;font-size:28px;letter-spacing:-.06em}.rail{display:flex;gap:10px;overflow-x:auto;padding:6px 2px 16px;scroll-snap-type:x mandatory}.rail::-webkit-scrollbar{height:8px}.rail::-webkit-scrollbar-thumb{background:rgba(255,255,255,.17);border-radius:99px}.railItem{min-width:190px;scroll-snap-align:start;border:1px solid rgba(255,255,255,.14);border-radius:22px;background:linear-gradient(180deg,rgba(255,255,255,.085),rgba(255,255,255,.035));padding:12px;position:relative}.railItem:after{content:"→";position:absolute;right:-16px;top:45%;font-weight:1000;color:#ffe6a0}.railItem:last-child:after{content:""}.railItem.save{border-color:rgba(114,255,195,.26)}.railItem.skit{border-color:rgba(199,165,255,.26)}.railItem small{display:block;font-size:10px;font-weight:1000;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,246,222,.55)}.railItem b{display:block;font-size:19px;margin-top:4px}.railItem p{margin:7px 0 0;color:var(--muted);font-size:12px;line-height:1.25;font-weight:760}.storyControls{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}.storyBlock{border:1px solid var(--line);background:rgba(29,34,51,.82);border-radius:26px;padding:14px;margin-bottom:12px}.storyBlock h2{margin:0 0 4px;font-size:24px;letter-spacing:-.05em}.storyMeta{color:var(--muted);font-size:12px;font-weight:900;margin-bottom:10px}.skitLine{display:grid;grid-template-columns:54px 1fr;gap:10px;align-items:start;margin:10px 0}.skitLine.pet{grid-template-columns:1fr 54px}.skitLine.pet .bubble{grid-column:1;grid-row:1;text-align:right}.skitLine.pet .face{grid-column:2}.face{width:54px;height:54px;border-radius:16px;border:1px solid rgba(255,255,255,.14);background:rgba(0,0,0,.22);display:grid;place-items:center;overflow:hidden}.face img{width:48px;height:48px;object-fit:contain}.bubble{border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.065);border-radius:18px;padding:10px}.bubble b{display:block;color:#ffe6a0;font-size:11px;letter-spacing:.08em;text-transform:uppercase;margin-bottom:3px}.bubble p{margin:0;font-family:Georgia,serif;font-size:15px;line-height:1.32}.refs{display:flex;gap:5px;flex-wrap:wrap;margin-top:7px}.ref{display:inline-flex;align-items:center;gap:5px;border:1px solid rgba(255,255,255,.12);background:rgba(0,0,0,.18);border-radius:999px;padding:4px 6px;font-size:10px;color:rgba(255,246,222,.75);font-weight:900}.ref img{width:18px;height:18px;object-fit:contain;border-radius:4px}.gptFlow{display:grid;gap:12px}.step{display:grid;grid-template-columns:52px 1fr auto;gap:12px;align-items:center;border:1px solid var(--line);background:rgba(29,34,51,.82);border-radius:24px;padding:12px}.num{width:52px;height:52px;border-radius:18px;background:linear-gradient(180deg,#ffe5a1,#b87328);display:grid;place-items:center;color:#241104;font-weight:1000;font-size:24px}.step h3{margin:0;font-size:18px}.step p{margin:3px 0 0;color:var(--muted);font-weight:760;line-height:1.3}.textarea{width:100%;min-height:180px;border:1px solid var(--line);border-radius:18px;background:rgba(0,0,0,.22);color:var(--ink);padding:12px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px}.toast{position:fixed;left:50%;bottom:calc(18px + var(--safeBottom));transform:translateX(-50%) translateY(20px);opacity:0;background:rgba(0,0,0,.82);border:1px solid rgba(255,255,255,.15);border-radius:999px;color:#fff;padding:10px 14px;font-size:13px;font-weight:900;z-index:50;transition:.18s}.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}.empty{border:1px dashed rgba(255,255,255,.2);border-radius:24px;padding:24px;text-align:center;color:var(--muted);font-weight:800}.hidden{display:none!important}@media(max-width:760px){.app{padding-left:10px;padding-right:10px}.topbar{grid-template-columns:1fr}.smallBtn{width:100%}.tabs{gap:6px}.tab{font-size:11px;padding:0 6px}.heroInner{grid-template-columns:82px 1fr;padding:13px}.portrait{width:82px;height:82px;border-radius:20px}.portrait img{width:70px;height:70px}.grid{grid-template-columns:1fr}.statGrid{grid-template-columns:repeat(2,1fr)}.step{grid-template-columns:42px 1fr}.step .actionBtn{grid-column:1/3;width:100%}.num{width:42px;height:42px;border-radius:14px;font-size:20px}.railItem{min-width:168px}.hero h2{font-size:42px}}


/* Account / backend layer */
.headerActions{display:flex;gap:8px;align-items:center;flex-wrap:wrap;justify-content:flex-end}.headerActions .smallBtn{width:auto}.modal{position:fixed;inset:0;background:rgba(0,0,0,.62);z-index:100;display:grid;place-items:center;padding:16px}.modalCard{width:min(560px,100%);border:1px solid var(--line);background:linear-gradient(180deg,#252b40,#10131e);border-radius:28px;padding:18px;box-shadow:0 35px 120px rgba(0,0,0,.55);position:relative}.modalCard h2{margin:0 0 6px;font-size:34px;letter-spacing:-.07em}.modalClose{position:absolute;right:14px;top:12px;width:42px;height:42px;border-radius:14px;border:1px solid var(--line);background:rgba(255,255,255,.075);color:var(--ink);font-size:26px;font-weight:900}.accountStatus{border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.055);border-radius:16px;padding:10px;margin:10px 0;color:var(--muted);font-weight:850}.formGrid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.input{min-height:48px;border-radius:16px;border:1px solid var(--line);background:rgba(0,0,0,.22);color:var(--ink);padding:0 12px;font:inherit;font-weight:800}.modalActions{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}.softLine{border:0;border-top:1px solid var(--line);margin:14px 0}.accountSaves{display:grid;gap:8px;margin-top:12px;max-height:260px;overflow:auto}.accountSaveRow{display:grid;grid-template-columns:1fr auto auto;gap:8px;align-items:center;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.055);border-radius:16px;padding:10px}.accountSaveRow b{display:block}.accountSaveRow small{display:block;color:var(--muted);font-weight:800;margin-top:2px}.tinyBtn{min-height:36px;border-radius:12px;border:1px solid var(--line);background:rgba(255,255,255,.075);color:var(--ink);font-weight:950;padding:0 10px}.danger{border-color:rgba(255,119,119,.35);color:#ffd0d0}@media(max-width:760px){.topbar{grid-template-columns:1fr}.headerActions{justify-content:stretch}.headerActions .smallBtn{flex:1 1 44%;min-width:0}.formGrid{grid-template-columns:1fr}.accountSaveRow{grid-template-columns:1fr}.tinyBtn{width:100%}}


.timelineBtns{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.syncStatus{margin:8px 0;color:rgba(255,248,232,.65);font-weight:850;font-size:12px}
@media(max-width:700px){
  .timelineHead{display:block}
  .timelineBtns{justify-content:stretch;margin-top:10px}
  .timelineBtns .smallBtn{flex:1;min-width:120px}
}


/* v8 explicit Session Timeline */
.sessionChain{display:grid;gap:14px;margin-top:18px}
.chainRow{display:grid;grid-template-columns:1fr 34px 1fr;gap:10px;align-items:stretch}
.chainArrow{display:grid;place-items:center;color:#ffe4a1;font-size:28px;font-weight:1000}
.chainCard{
  min-height:118px;border-radius:24px;border:1px solid rgba(255,255,255,.16);
  background:linear-gradient(180deg,rgba(255,255,255,.075),rgba(255,255,255,.035));
  color:#fff8e8;text-align:center;padding:14px 12px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:7px;
  box-shadow:inset 0 1px rgba(255,255,255,.05);
}
.chainCard span{font-size:11px;font-weight:1000;letter-spacing:.22em;color:rgba(255,248,232,.55)}
.chainCard b{font-size:clamp(22px,6vw,34px);line-height:1.02;color:#0a95ff}
.chainCard em{font-style:normal;color:rgba(255,248,232,.72);font-weight:900;font-size:13px}
.saveCard{border-color:rgba(122,255,199,.24)}
.skitCard{border-color:rgba(185,147,255,.26)}
@media(max-width:680px){
  .chainRow{grid-template-columns:1fr;gap:8px}
  .chainArrow{transform:rotate(90deg);height:20px}
  .chainCard{min-height:104px}
}



/* v10 vertical mobile-first timeline */
.verticalHead h2{
  font-size:clamp(42px,11vw,68px);
  line-height:.94;
  margin:0 0 12px;
}
.verticalChain{
  display:grid;
  gap:18px;
  margin-top:18px;
}
.verticalPair{
  display:grid;
  gap:10px;
}
.verticalCard{
  width:100%;
  min-height:112px;
  border-radius:26px;
  border:1px solid rgba(255,255,255,.16);
  background:linear-gradient(180deg,rgba(255,255,255,.075),rgba(255,255,255,.035));
  color:#fff8e8;
  text-align:center;
  padding:16px 14px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:7px;
  box-shadow:inset 0 1px rgba(255,255,255,.05);
}
.verticalCard span{
  font-size:11px;
  font-weight:1000;
  letter-spacing:.22em;
  color:rgba(255,248,232,.55);
}
.verticalCard b{
  font-size:clamp(24px,7vw,38px);
  line-height:1.02;
  color:#0a95ff;
}
.verticalCard em{
  font-style:normal;
  color:rgba(255,248,232,.72);
  font-weight:900;
  font-size:13px;
}
.sessionCard{
  border-color:rgba(122,255,199,.26);
}
.storyCard{
  border-color:rgba(185,147,255,.30);
}
.verticalArrow{
  display:grid;
  place-items:center;
  min-height:26px;
  color:#ffe4a1;
  font-size:30px;
  font-weight:1000;
  line-height:1;
}
.timelineBtns{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
.timelineBtns .smallBtn{
  flex:1;
  min-width:130px;
}
.syncStatus{
  margin:10px 0 4px;
  color:rgba(255,248,232,.65);
  font-weight:850;
  font-size:12px;
}
.rail{
  display:block!important;
  overflow:visible!important;
}
@media(min-width:760px){
  .verticalPair{
    max-width:620px;
    margin:0 auto;
  }
}



/* v11 compact readable vertical timeline */
.compactTimeline .verticalHead h2{
  font-size:clamp(34px,8.5vw,54px)!important;
  line-height:.96;
  margin:0 0 10px;
}
.compactTimeline .timelineBtns{
  display:grid!important;
  grid-template-columns:1fr 1fr;
  gap:8px;
}
.compactTimeline .timelineBtns .smallBtn{
  min-width:0!important;
  min-height:46px!important;
  border-radius:18px!important;
  font-size:11px!important;
}
.compactTimeline .timelineBtns .smallBtn:last-child{
  grid-column:1 / -1;
}
.compactTimeline .syncStatus{
  margin:12px 0 10px;
  font-size:12px;
}
.compactTimeline .verticalChain{
  display:grid;
  gap:12px;
  margin-top:10px;
}
.compactTimeline .verticalPair{
  display:grid;
  gap:6px;
}
.compactTimeline .verticalCard{
  min-height:82px!important;
  border-radius:20px!important;
  padding:10px 12px!important;
  gap:4px!important;
}
.compactTimeline .verticalCard span{
  font-size:9px!important;
  letter-spacing:.18em!important;
}
.compactTimeline .verticalCard b{
  font-size:clamp(20px,5.5vw,30px)!important;
}
.compactTimeline .verticalCard em{
  font-size:12px!important;
}
.compactTimeline .verticalArrow{
  min-height:18px!important;
  font-size:22px!important;
}
@media(max-width:680px){
  .compactTimeline .timelineHead{display:block!important}
}



/* v12 production compact touch fix */
.compactTimeline .verticalCard{
  pointer-events:auto!important;
  position:relative;
  z-index:2;
}
.compactTimeline .verticalCard *{
  pointer-events:none;
}
.compactTimeline .timelineBtns .smallBtn{
  font-size:10px!important;
}



/* v13 exact timeline click targets */
.verticalCard[data-v13-load],
.verticalCard[data-v13-skit]{
  cursor:pointer;
  touch-action:manipulation;
}
.verticalCard[data-v13-load] *,
.verticalCard[data-v13-skit] *{
  pointer-events:none;
}



/* v14 guard against invisible session screen */
#saveView:not(.hidden),
#sessionView:not(.hidden){
  min-height:60vh;
}



/* v16 clean vertical timeline */
.compactTimeline .verticalHead h2{
  font-size:clamp(34px,8.5vw,54px)!important;
  line-height:.96;
  margin:0 0 10px;
}
.compactTimeline .timelineBtns{
  display:grid!important;
  grid-template-columns:1fr 1fr;
  gap:8px;
}
.compactTimeline .timelineBtns .smallBtn{
  min-width:0!important;
  min-height:46px!important;
  border-radius:18px!important;
  font-size:11px!important;
}
.compactTimeline .timelineBtns .smallBtn:last-child{
  grid-column:1 / -1;
}
.compactTimeline .syncStatus{
  margin:12px 0 10px;
  font-size:12px;
}
.compactTimeline .verticalChain{
  display:grid;
  gap:12px;
  margin-top:10px;
}
.compactTimeline .verticalPair{
  display:grid;
  gap:6px;
}
.compactTimeline .verticalCard{
  width:100%;
  min-height:82px!important;
  border-radius:20px!important;
  border:1px solid rgba(255,255,255,.16);
  background:linear-gradient(180deg,rgba(255,255,255,.075),rgba(255,255,255,.035));
  color:#fff8e8;
  text-align:center;
  padding:10px 12px!important;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:4px!important;
  touch-action:manipulation;
}
.compactTimeline .verticalCard *{pointer-events:none}
.compactTimeline .verticalCard span{
  font-size:9px!important;
  font-weight:1000;
  letter-spacing:.18em!important;
  color:rgba(255,248,232,.55);
}
.compactTimeline .verticalCard b{
  font-size:clamp(20px,5.5vw,30px)!important;
  line-height:1.02;
  color:#0a95ff;
}
.compactTimeline .verticalCard em{
  font-size:12px!important;
  font-style:normal;
  color:rgba(255,248,232,.72);
  font-weight:900;
}
.compactTimeline .sessionCard{border-color:rgba(122,255,199,.26)}
.compactTimeline .storyCard{border-color:rgba(185,147,255,.30)}
.compactTimeline .verticalArrow{
  display:grid;
  place-items:center;
  min-height:18px!important;
  color:#ffe4a1;
  font-size:22px!important;
  font-weight:1000;
  line-height:1;
}
.view.active{display:block!important}
