/*
 * Foxfire styles - a sunlit glass conservatory of sigils.
 * The UI sits inside an airy greenhouse at golden hour. Surfaces are panes of
 * frosted glass (translucent, softly blurred, lit along the rim). Hand-drawn
 * vines and blossoms grow around the edges, never across the middle, and sigils
 * stay as dark luminous gems set into the bright glass.
 * Type: Fraunces (display) over Hanken Grotesk (data).
 */
:root{
  /* daylight garden ground */
  --bg-top:#fdf8f4; --bg-mid:#f3edf1; --bg-bot:#ecf1ea;
  --sun:#ffe9c9;
  --ink:#3b3442; --ink-dim:#6e6675; --ink-faint:#a39aa8;
  --moon:#322b3a;                       /* (legacy name) heading ink */
  /* botanic life */
  --leaf:#abd2b1; --leaf-edge:#6fa67e; --sage:#8dbb98; --sage-deep:#5e9170;
  --rose:#e58fab; --rose-deep:#cd6c8e; --bloom:#fbe2eb;
  /* warm, gentle glow - never neon */
  --gold:#e7b577; --glow-warm:#f1c98c; --glow-cool:#8ec8ad;
  --firefly:#e6a866; --arcane:#9c8ae0;
  /* rarity as soft pigments that read on light glass */
  --r-common:#93a39a; --r-uncommon:#5fae87; --r-rare:#5f93c4; --r-epic:#9a78c8; --r-legendary:#d6a24e; --r-mythic:#d579a0;
  /* ---- frosted glass design tokens ---- */
  --glass:rgba(255,255,255,.40);
  --glass-2:rgba(255,255,255,.58);
  --glass-3:rgba(255,255,255,.78);
  --glass-edge:rgba(255,255,255,.8);
  --glass-line:rgba(120,96,120,.16);
  --glass-blur:20px;
  --glass-shadow:0 22px 48px -22px rgba(86,64,90,.34),0 6px 16px -10px rgba(86,64,90,.18);
  --glass-hi:rgba(255,255,255,.55);
  --lattice:repeating-linear-gradient(45deg,transparent 0 22px,rgba(255,255,255,.5) 22px 22.7px),
            repeating-linear-gradient(-45deg,transparent 0 22px,rgba(255,255,255,.5) 22px 22.7px);
  /* dark sigil-gem disc */
  --disc:radial-gradient(circle at 38% 30%,#2c3b31,#0f1813 82%);
  --display:"Fraunces",Georgia,"Times New Roman",serif;
  --ui:"Hanken Grotesk",system-ui,-apple-system,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{font-family:var(--ui);color:var(--ink);background:var(--bg-bot);overflow:hidden;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;cursor:default}
button{font-family:inherit;color:inherit}
::selection{background:rgba(229,143,171,.24)}
:focus-visible{outline:1.5px solid var(--sage-deep);outline-offset:3px}

/* ---- shared flora-part styling (vines & blossoms, bright) ---- */
.leaf{fill:var(--leaf);stroke:var(--leaf-edge);stroke-width:1;stroke-opacity:.7}
.vein{fill:none;stroke:var(--leaf-edge);stroke-width:.8;stroke-opacity:.5}
.stem{fill:none;stroke:var(--sage);stroke-width:3.4;stroke-linecap:round}
.stem--thin{stroke-width:2}
.petal,.bl path,.bl{fill:rgba(245,201,216,.6);stroke:var(--rose);stroke-width:1;stroke-opacity:.7}
.core{fill:var(--gold);filter:drop-shadow(0 0 5px rgba(231,181,119,.55))}
.bud{fill:var(--rose);filter:drop-shadow(0 0 4px rgba(229,143,171,.5))}
.bell path{fill:rgba(245,201,216,.55);stroke:var(--rose-deep);stroke-width:1;stroke-opacity:.7}
.cap{fill:var(--leaf);stroke:var(--leaf-edge);stroke-width:1;stroke-opacity:.6}
.stalk{fill:#cfe4cf}
.spot{fill:var(--rose);filter:drop-shadow(0 0 3px rgba(229,143,171,.5))}
.blade{fill:none;stroke:var(--sage);stroke-width:3;stroke-linecap:round}
.sprite{position:absolute}

/* the conservatory scene (behind the workspace, never interactive) */
.scene{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.sky{position:absolute;inset:0;background:
  radial-gradient(75% 55% at 76% -4%, rgba(255,231,198,.95), transparent 58%),
  radial-gradient(60% 50% at 8% 6%, rgba(226,240,231,.75), transparent 60%),
  linear-gradient(168deg, var(--bg-top), var(--bg-mid) 54%, var(--bg-bot))}
.sky::after{content:"";position:absolute;inset:0;opacity:.5;background:
  radial-gradient(2px 2px at 20% 26%, rgba(255,224,188,.7), transparent 60%),
  radial-gradient(2px 2px at 72% 16%, rgba(245,205,220,.6), transparent 60%),
  radial-gradient(1.5px 1.5px at 46% 32%, rgba(255,224,188,.5), transparent 60%),
  radial-gradient(1.5px 1.5px at 86% 40%, rgba(245,205,220,.45), transparent 60%)}
/* a soft golden-hour sun, drifting */
.moon{position:absolute;top:5%;left:72%;width:150px;height:150px;border-radius:50%;
  background:radial-gradient(circle at 50% 50%, rgba(255,240,212,.95), rgba(255,226,184,.45) 52%, transparent 72%);
  box-shadow:0 0 120px 50px rgba(255,226,184,.4);opacity:.85;
  animation:moonDrift 90s ease-in-out infinite alternate}
@keyframes moonDrift{to{transform:translate(-18px,12px)}}
#fireflies{position:absolute;inset:0;z-index:2;mix-blend-mode:multiply;opacity:.5}
.skyline{position:absolute;left:0;right:0;bottom:0;width:100%;height:230px;z-index:1}
.skyline__far{fill:#dce9da;opacity:.85}
.skyline__near{fill:#cadfca}

/* foreground vines - placed asymmetrically at the edges, gently swaying */
.flora{position:absolute;z-index:3;overflow:visible;opacity:.92}
.flora--bl{left:-14px;bottom:-10px;width:300px;height:300px;transform-origin:left bottom;animation:sway1 9s ease-in-out infinite alternate}
.flora--blooms{left:96px;bottom:6px;width:140px;height:184px;transform-origin:center bottom;animation:sway2 7s ease-in-out infinite alternate}
.flora--bells{left:226px;bottom:0;width:112px;height:196px;transform-origin:center bottom;animation:sway1 8s .6s ease-in-out infinite alternate}
.flora--grass-l{left:18px;bottom:-6px;width:250px;height:116px;transform-origin:center bottom;animation:sway2 6s ease-in-out infinite alternate}
.flora--br{right:30px;bottom:-6px;width:190px;height:122px;transform-origin:center bottom;animation:sway2 8s .4s ease-in-out infinite alternate}
.flora--grass-r{right:0;bottom:-6px;width:230px;height:116px;transform-origin:center bottom;animation:sway1 7s .3s ease-in-out infinite alternate}
.flora--tr{right:-20px;top:-26px;width:300px;height:300px;transform:scale(-1,-1);transform-origin:right top;animation:swayTop 10s ease-in-out infinite alternate}
.flora--tl{left:-10px;top:-14px;width:170px;height:170px;transform:scale(-1,1);transform-origin:left top;animation:swayTopL 9s .5s ease-in-out infinite alternate}
@keyframes sway1{from{transform:rotate(-1.4deg)}to{transform:rotate(1.6deg)}}
@keyframes sway2{from{transform:rotate(1.4deg)}to{transform:rotate(-1.4deg)}}
@keyframes swayTop{from{transform:scale(-1,-1) rotate(-1.2deg)}to{transform:scale(-1,-1) rotate(1.4deg)}}
@keyframes swayTopL{from{transform:scale(-1,1) rotate(-1.4deg)}to{transform:scale(-1,1) rotate(1.2deg)}}

/* a whisper of paper grain over the scene - the handmade texture */
.grain{position:fixed;inset:0;z-index:70;pointer-events:none;opacity:.28;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='matrix' values='0 0 0 0 0.55 0 0 0 0 0.5 0 0 0 0 0.55 0 0 0 0.5 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* the workspace: the clearing */
#stage{position:fixed;inset:0;z-index:5;overflow:hidden;touch-action:none}
.clearing{position:absolute;left:0;right:300px;top:0;bottom:0;pointer-events:none;
  background:radial-gradient(48% 42% at 44% 46%, rgba(255,255,255,.4), transparent 70%)}
#tokens{position:absolute;inset:0}
.stage-hint{position:absolute;top:46%;left:44%;transform:translate(-50%,-50%);text-align:center;
  color:var(--ink-dim);max-width:30rem;pointer-events:none;transition:opacity .4s ease}
.stage-hint.gone{opacity:0}
.stage-hint__mark{font-size:1.7rem;color:var(--gold);display:block;margin-bottom:.7rem;
  filter:drop-shadow(0 0 10px rgba(231,181,119,.45));animation:breathe 5s ease-in-out infinite}
.stage-hint p{font-family:var(--display);font-size:1.18rem;line-height:1.7;font-weight:400;color:var(--ink)}
.stage-hint b{font-weight:600;font-style:italic;color:var(--rose-deep)}
.stage-hint__sub{display:block;margin-top:1rem;font-size:.86rem;color:var(--ink-faint);font-style:italic;font-family:var(--display)}
@keyframes breathe{0%,100%{opacity:.7}50%{opacity:1}}

.dissolve{position:absolute;left:44%;bottom:20px;transform:translateX(-50%);width:50px;height:50px;border:0;
  background:none;cursor:default;opacity:0;transition:opacity .25s,transform .2s;pointer-events:none;
  color:var(--rose-deep);display:grid;place-items:center}
.dissolve.show{opacity:.55;pointer-events:auto}
.dissolve.hot{opacity:1;transform:translateX(-50%) scale(1.18)}
.dissolve__glyph{font-size:1.4rem;filter:drop-shadow(0 0 8px rgba(205,108,142,.55))}

/* ---- a sigil token: a dark gem set into the bright clearing ---- */
.token{position:absolute;top:0;left:0;width:100px;will-change:transform;cursor:grab;
  touch-action:none;user-select:none;-webkit-user-select:none;
  display:flex;flex-direction:column;align-items:center;gap:.4rem;animation:tokFade .22s ease both}
.token.dragging{cursor:grabbing;z-index:30}
@keyframes tokFade{from{opacity:0}}
.token__disc{position:relative;width:84px;height:84px;display:grid;place-items:center;--rc:var(--r-common);--glow:transparent;
  border-radius:49% 51% 47% 53% / 53% 49% 51% 47%;          /* an organic pebble, not a circle */
  background:var(--disc);
  border:1px solid color-mix(in srgb,var(--rc) 60%, #2a3a30);
  box-shadow:0 8px 18px -6px rgba(80,66,84,.45), inset 0 1px 0 rgba(255,255,255,.14), inset 0 -6px 12px rgba(0,0,0,.4);
  transition:transform .15s ease, box-shadow .2s ease;
  animation:discIn .3s cubic-bezier(.2,.9,.3,1.2) both}
@keyframes discIn{from{opacity:0;transform:scale(.4)}}
.token__disc::after{content:"";position:absolute;left:50%;bottom:-9px;width:56px;height:12px;transform:translateX(-50%);
  background:radial-gradient(closest-side, rgba(86,66,86,.28), transparent);pointer-events:none}  /* grounding shadow */
.token__disc svg{width:84%;height:84%;position:relative}
.token.rare-glow .token__disc{box-shadow:0 8px 18px -6px rgba(80,66,84,.45), inset 0 1px 0 rgba(255,255,255,.14), inset 0 -6px 12px rgba(0,0,0,.4), 0 0 18px -3px var(--glow)}
.token:hover .token__disc{transform:translateY(-3px)}
.token.drop-target .token__disc{transform:scale(1.08);border-color:var(--rc);box-shadow:0 10px 20px -5px rgba(80,66,84,.5),0 0 22px -4px var(--glow),inset 0 1px 0 rgba(255,255,255,.16)}
.token__name{font-family:var(--display);font-style:italic;font-size:.8rem;color:var(--ink);text-align:center;line-height:1.05;
  max-width:104px;padding:.12rem .55rem;background:var(--glass-3);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
  border:1px solid var(--glass-line);border-radius:999px;box-shadow:0 4px 10px -4px rgba(86,66,86,.3);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.token.rare-glow .token__name{color:var(--rose-deep);font-weight:500}

/* the binding bloom - a soft pulse of warm light */
.bloom{position:absolute;width:8px;height:8px;border-radius:50%;pointer-events:none;z-index:25;transform:translate(-50%,-50%);
  background:radial-gradient(circle,var(--bc,#f1c98c),transparent 70%);animation:bloom .6s ease-out forwards}
@keyframes bloom{0%{opacity:0;transform:translate(-50%,-50%) scale(.5)}25%{opacity:.85}100%{opacity:0;transform:translate(-50%,-50%) scale(13)}}

/* title + glassy markers */
#hud{position:fixed;top:0;left:0;right:0;z-index:8;display:flex;align-items:flex-start;justify-content:space-between;
  padding:18px 22px;pointer-events:none}
#hud>*{pointer-events:auto}
.brand{display:flex;flex-direction:column;line-height:1.05}
.brand__name{font-family:var(--display);font-weight:600;font-size:1.7rem;letter-spacing:.01em;
  color:var(--moon);text-shadow:0 1px 10px rgba(255,255,255,.7)}
.brand__sub{font-family:var(--display);font-style:italic;font-size:.84rem;color:var(--rose-deep);margin-top:.05rem}
.brand__stat{font-size:.76rem;color:var(--ink-faint);margin-top:.5rem;letter-spacing:.02em}
.brand__stat b{color:var(--sage-deep);font-weight:600}
.hud__actions{display:flex;align-items:center;gap:.7rem}
/* a marker - a little pane of frosted glass */
.marker{display:inline-flex;align-items:center;gap:.4rem;cursor:pointer;padding:.42rem .85rem;
  color:var(--ink);background:var(--glass-2);border:1px solid var(--glass-edge);border-radius:11px;
  -webkit-backdrop-filter:blur(14px) saturate(1.2);backdrop-filter:blur(14px) saturate(1.2);
  box-shadow:0 8px 18px -10px rgba(86,66,86,.4),inset 0 1px 0 var(--glass-hi);
  font-family:var(--display);font-size:.94rem;transition:.18s}
.marker__g{color:var(--rose-deep)}
.marker:hover{border-color:var(--rose);box-shadow:0 10px 24px -10px rgba(205,108,142,.45),0 0 0 1px rgba(229,143,171,.25),inset 0 1px 0 var(--glass-hi);transform:translateY(-1px)}
.marker--mp .marker__g{color:var(--arcane)}
.marker--mp:hover{border-color:var(--arcane);box-shadow:0 10px 24px -10px rgba(156,138,224,.45),0 0 0 1px rgba(156,138,224,.25),inset 0 1px 0 var(--glass-hi)}
/* rune icons - glyph + faint hover halo */
.rune{width:36px;height:36px;border:1px solid transparent;background:none;cursor:pointer;color:var(--ink-dim);font-size:1.05rem;
  display:grid;place-items:center;border-radius:50%;transition:.16s}
.rune:hover{color:var(--moon);background:var(--glass-2);border-color:var(--glass-edge);
  -webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);text-shadow:0 0 10px rgba(231,181,119,.4)}
.rune.off{color:var(--ink-faint)}

/* collection: a frosted-glass alchemy journal */
.shelf{position:fixed;top:0;right:0;bottom:0;z-index:9;width:300px;display:flex;
  transform:translateX(100%);transition:transform .4s cubic-bezier(.4,0,.18,1)}
.shelf.open{transform:none}
.shelf__tab{position:absolute;left:-36px;top:50%;transform:translateY(-50%);width:36px;height:144px;cursor:pointer;
  border:1px solid var(--glass-edge);border-right:0;border-radius:12px 0 0 12px;
  background:var(--glass-2);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);
  box-shadow:-8px 0 22px -10px rgba(86,66,86,.35),inset 0 1px 0 var(--glass-hi)}
.shelf__tab span{writing-mode:vertical-rl;transform:rotate(180deg);font-family:var(--display);font-style:italic;
  font-size:.92rem;color:var(--ink-dim);letter-spacing:.04em}
.shelf__tab:hover span{color:var(--rose-deep)}
.shelf__vine{position:absolute;left:-26px;top:0;bottom:0;width:60px;height:100%;z-index:2;pointer-events:none;overflow:visible;opacity:.9}
.shelf__inner{position:relative;flex:1;display:flex;flex-direction:column;min-width:0;border-radius:16px 0 0 16px;overflow:hidden;
  background:var(--glass);-webkit-backdrop-filter:blur(var(--glass-blur)) saturate(1.15) brightness(1.04);
  backdrop-filter:blur(var(--glass-blur)) saturate(1.15) brightness(1.04);
  border:1px solid var(--glass-edge);border-right:0;box-shadow:var(--glass-shadow),inset 0 1px 0 var(--glass-hi)}
.shelf__inner::before{content:"";position:absolute;inset:0;pointer-events:none;z-index:0;
  background:var(--lattice),radial-gradient(120% 60% at 50% -8%,var(--glass-hi),transparent 58%);opacity:.6}
.shelf__inner>*{position:relative;z-index:1}
.shelf__head{padding:18px 18px 12px;border-bottom:1px solid var(--glass-line);background:linear-gradient(var(--glass-2),transparent)}
.shelf__title{font-family:var(--display);font-size:1.16rem;color:var(--moon)}
.shelf__count{font-family:var(--ui);font-size:.78rem;color:var(--ink-faint);margin-left:.3rem}
.search{width:100%;margin-top:.6rem;border:0;border-bottom:1px solid var(--glass-line);background:transparent;color:var(--ink);
  padding:.4rem .2rem;font-size:.9rem;font-family:var(--display);font-style:italic}
.search::placeholder{color:var(--ink-faint)}
.search:focus{outline:none;border-bottom-color:var(--sage-deep)}
.sorts{display:flex;gap:1rem;margin-top:.7rem}
.sort{border:0;background:none;cursor:pointer;color:var(--ink-faint);font-family:var(--display);font-style:italic;
  font-size:.84rem;padding:0 0 .15rem;position:relative;transition:color .15s}
.sort:hover{color:var(--ink-dim)}
.sort.on{color:var(--rose-deep)}
.sort.on::after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:1.5px;background:currentColor;opacity:.7;border-radius:2px}
.shelf__scroll{position:relative;z-index:1;flex:1;overflow-y:auto;overscroll-behavior:contain;padding:14px 12px}
.shelf__list{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.shelf__empty{grid-column:1/-1;color:var(--ink-faint);text-align:center;padding:2rem 1rem;font-family:var(--display);font-style:italic;line-height:1.5}
.shelf__foot{position:relative;z-index:1;padding:10px 16px;border-top:1px solid var(--glass-line);
  color:var(--ink-faint);font-size:.74rem;text-align:center;font-style:italic;font-family:var(--display)}

.scell{position:relative;border:0;background:none;cursor:grab;touch-action:none;user-select:none;
  display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.45rem .2rem;transition:background .15s;border-radius:10px}
.scell:hover{background:rgba(255,255,255,.45)}
.scell.dragging{cursor:grabbing;opacity:.4}
.scell.chosen{background:rgba(229,143,171,.18);box-shadow:inset 0 0 0 1px rgba(229,143,171,.4)}
.scell__disc{width:54px;height:54px;display:grid;place-items:center;--rc:var(--r-common);--glow:transparent;
  border-radius:48% 52% 50% 50% / 52% 50% 50% 48%;background:var(--disc);
  border:1px solid color-mix(in srgb,var(--rc) 55%, #2a3a30);box-shadow:0 4px 10px -4px rgba(80,66,84,.4),inset 0 -4px 8px rgba(0,0,0,.35)}
.scell__disc svg{width:82%;height:82%}
.scell__name{font-family:var(--display);font-style:italic;font-size:.72rem;line-height:1.05;text-align:center;color:var(--ink-dim);
  max-width:86px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.scell.new::after{content:"";position:absolute;top:.35rem;right:.55rem;width:6px;height:6px;border-radius:50%;
  background:var(--gold);box-shadow:0 0 7px var(--gold)}

/* inspector: a pressed specimen on a frosted pane */
.inspector{position:fixed;inset:0;z-index:40;display:flex;align-items:center;justify-content:center;padding:24px;
  opacity:0;visibility:hidden;pointer-events:none;transition:opacity .22s,visibility .22s}
.inspector.show{opacity:1;visibility:visible;pointer-events:auto}
.insp{position:relative;width:min(560px,94vw);max-height:88vh;overflow-y:auto;overscroll-behavior:contain;color:var(--ink);
  padding:28px 30px;--ic:var(--sage-deep);border-radius:18px;
  background:var(--glass-2);-webkit-backdrop-filter:blur(26px) saturate(1.2);backdrop-filter:blur(26px) saturate(1.2);
  border:1px solid var(--glass-edge);box-shadow:var(--glass-shadow),inset 0 1px 0 var(--glass-hi);
  transform:translateY(10px) scale(.985);transition:transform .24s cubic-bezier(.2,.9,.3,1.1)}
.inspector.show .insp{transform:none}
.insp::before{content:"";position:absolute;inset:9px;border:1px solid var(--glass-line);border-radius:12px;pointer-events:none}
.insp::after{content:"";position:absolute;inset:0;border-radius:18px;pointer-events:none;opacity:.5;
  background:var(--lattice)}
.insp>*{position:relative;z-index:1}
.frame-flora{position:absolute;z-index:2;pointer-events:none;overflow:visible}
.insp .vines--tl,.insp .vines--br{position:absolute;width:120px;height:120px;pointer-events:none;overflow:visible;z-index:2}
.insp .vines--tl{top:-24px;left:-20px;transform:scale(-1,1)}
.insp .vines--br{right:-28px;bottom:-28px;width:150px;height:150px}
.x{position:absolute;top:12px;right:12px;z-index:3;border:0;background:var(--glass-2);cursor:pointer;width:30px;height:30px;border-radius:50%;
  color:var(--ink-dim);font-size:1rem;display:grid;place-items:center;transition:.15s;border:1px solid var(--glass-line)}
.x:hover{color:var(--rose-deep);border-color:var(--rose)}
.insp__head{display:flex;gap:1.3rem;align-items:center}
.insp__mark{width:124px;height:124px;flex:0 0 auto;display:grid;place-items:center;
  border-radius:48% 52% 50% 50% / 52% 50% 50% 48%;background:var(--disc);
  border:1px solid color-mix(in srgb,var(--ic) 55%,#2a3a30);box-shadow:inset 0 -8px 16px rgba(0,0,0,.45),0 8px 22px -8px rgba(80,66,84,.4),0 0 22px -8px var(--ic)}
.insp__mark svg{width:84%;height:84%}
.insp__name{font-family:var(--display);font-weight:600;font-size:1.85rem;line-height:1.04;color:var(--moon)}
.insp__rar{display:inline-flex;align-items:center;gap:.4rem;font-family:var(--ui);font-size:.78rem;letter-spacing:.1em;
  text-transform:uppercase;margin-top:.4rem;color:var(--ic)}
.insp__rar::before{content:"";width:7px;height:7px;border-radius:50%;background:currentColor}
.insp__line{font-family:var(--display);font-style:italic;color:var(--ink-dim);font-size:.98rem;margin-top:.3rem}
.insp__chips{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.6rem}
.mini{font-size:.74rem;color:var(--ink-dim);border:1px solid var(--glass-line);background:var(--glass-2);border-radius:999px;padding:.12rem .55rem}
.insp__cols{display:grid;grid-template-columns:1fr 1.05fr;gap:1.5rem;margin-top:1.4rem}
.eyebrow{font-family:var(--display);font-style:italic;font-size:.86rem;color:var(--sage-deep);margin-bottom:.5rem}
.stat{display:grid;grid-template-columns:5rem 1fr 1.6rem;align-items:center;gap:.5rem;margin:.34rem 0}
.stat__k{font-size:.8rem;color:var(--ink-dim)}
.stat__bar{height:6px;background:rgba(120,96,120,.16);box-shadow:inset 0 1px 2px rgba(120,96,120,.2);overflow:hidden;border-radius:3px}
.stat__bar i{display:block;height:100%;background:linear-gradient(90deg,var(--sage),var(--glow-cool))}
.stat__v{text-align:right;font-size:.82rem;font-variant-numeric:tabular-nums;color:var(--ink)}
.insp__cast{margin-top:.7rem;font-size:.78rem;color:var(--ink-faint);font-style:italic;font-family:var(--display)}
.fx,.qk{list-style:none}
.fx li{position:relative;padding:.18rem 0 .18rem 1.1rem;font-size:.92rem;line-height:1.4}
.fx li::before{content:"❧";position:absolute;left:0;color:var(--sage-deep);font-size:.78rem;top:.28rem}
.qk{margin-top:.3rem}
.qk li{padding:.2rem 0;font-size:.88rem;line-height:1.35}
.qk .q-nm{color:var(--rose-deep);font-style:italic;font-family:var(--display)}
.qk .q-bl{color:var(--ink-dim)}
.tags{display:flex;flex-wrap:wrap;gap:.4rem}
.tag{font-size:.74rem;color:var(--r-epic);border:1px solid color-mix(in srgb,var(--r-epic) 40%,transparent);background:color-mix(in srgb,var(--r-epic) 8%,transparent);border-radius:999px;padding:.12rem .55rem}
.insp__disc{margin-top:1.3rem;padding-top:1rem;border-top:1px solid var(--glass-line);display:grid;grid-template-columns:1fr 1fr;gap:.7rem 1.3rem}
.disc-row .k{display:block;font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-faint)}
.disc-row .v{font-family:var(--display);color:var(--ink)}
.insp__act{margin-top:1.3rem;display:flex;justify-content:flex-end}

/* trials: the arena, under glass */
.trials{position:fixed;inset:0;z-index:38;display:flex;align-items:center;justify-content:center;padding:24px;
  opacity:0;visibility:hidden;pointer-events:none;transition:opacity .25s,visibility .25s;
  background:rgba(60,52,66,.18);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}
.trials.show{opacity:1;visibility:visible;pointer-events:auto}
.trials__panel{position:relative;width:min(980px,96vw);height:min(640px,92vh);display:flex;flex-direction:column;border-radius:20px;overflow:hidden;
  background:var(--glass-2);-webkit-backdrop-filter:blur(26px) saturate(1.18);backdrop-filter:blur(26px) saturate(1.18);
  border:1px solid var(--glass-edge);box-shadow:var(--glass-shadow),inset 0 1px 0 var(--glass-hi)}
.trials__panel::before{content:"";position:absolute;inset:0;pointer-events:none;z-index:0;
  background:var(--lattice),radial-gradient(120% 50% at 50% -6%,var(--glass-hi),transparent 56%);opacity:.55}
.trials__panel>*{position:relative;z-index:1}
.trials__panel>.frame-flora{position:absolute;overflow:visible;pointer-events:none;z-index:2;opacity:.92}
.frame-flora--tl{top:-30px;left:-26px;width:150px;height:150px;transform:scale(-1,1)}
.frame-flora--br{right:-30px;bottom:-28px;width:200px;height:200px}
.trials__head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--glass-line)}
.trials__tabs{display:flex;gap:1.2rem}
.ttab{border:0;background:none;cursor:pointer;color:var(--ink-faint);font-family:var(--display);font-style:italic;font-size:1.02rem;padding-bottom:.2rem;position:relative}
.ttab:hover{color:var(--ink-dim)}
.ttab.on{color:var(--rose-deep)}
.ttab.on::after{content:"";position:absolute;left:0;right:0;bottom:0;height:1.5px;background:currentColor;opacity:.75;border-radius:2px}
.trials__body{flex:1;position:relative;overflow:hidden}
.trial{position:absolute;inset:0;opacity:0;pointer-events:none;transition:opacity .25s;overflow:auto}
.trial.is-active{opacity:1;pointer-events:auto}
.arena{position:relative;height:100%;display:flex;flex-direction:column;align-items:center;gap:.4rem;padding:16px 22px}
.arena__turn{font-family:var(--display);font-size:1.05rem;color:var(--ink-dim);min-height:1.4rem;text-align:center}
.arena__turn b{color:var(--moon);font-style:italic;font-weight:500}
.being{display:flex;flex-direction:column;align-items:center;text-align:center;width:100%;max-width:440px}
.being.self{margin-top:auto}
.being__sig{width:148px;height:148px;cursor:pointer;filter:drop-shadow(0 6px 18px rgba(205,108,142,.28))}
.being__sig svg{width:100%;height:100%}
.being__name{font-family:var(--display);font-size:1.16rem;color:var(--moon)}
.intent{min-height:1.3rem;font-family:var(--display);font-style:italic;font-size:.94rem;color:var(--rose-deep);margin:.05rem 0 .3rem}
.intent__eye{font-style:normal;font-family:var(--ui);font-size:.68rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-faint);margin-right:.25rem}
.intent__word{color:var(--ink-faint);font-size:.82rem}
.hpbar{position:relative;width:min(360px,86%);height:15px;background:rgba(120,96,120,.16);box-shadow:inset 0 1px 2px rgba(120,96,120,.22);
  overflow:hidden;border-radius:999px;border:1px solid var(--glass-edge)}
.hpbar i{display:block;height:100%;width:calc(var(--hp,1)*100%);background:linear-gradient(90deg,var(--glow-cool),var(--sage-deep));transition:width .45s ease;border-radius:999px}
.hpbar.foe i{background:linear-gradient(90deg,var(--rose),var(--rose-deep))}
.hpnum{position:absolute;right:8px;top:50%;transform:translateY(-50%);font-size:.66rem;color:#fff;font-variant-numeric:tabular-nums;
  text-shadow:0 1px 2px rgba(60,52,66,.7);pointer-events:none}
.self__foot{display:flex;align-items:center;gap:.8rem;margin-top:.4rem}
.focus{display:flex;gap:4px}
.focus i{width:11px;height:11px;border-radius:50%;border:1px solid var(--gold);opacity:.4}
.focus i.lit{background:var(--gold);box-shadow:0 0 6px var(--gold);opacity:1}
.tracks{display:flex;flex-wrap:wrap;gap:.3rem;justify-content:center;min-height:1.4rem;margin:.3rem 0}
.chip{display:inline-flex;align-items:center;gap:.18rem;font-size:.82rem;color:var(--ink);background:var(--glass-2);
  border:1px solid var(--glass-edge);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border-radius:999px;padding:.06rem .5rem}
.chip b{font-weight:600;font-size:.74rem;color:var(--ink)}
.chip i{font-style:normal;font-size:.6rem;color:var(--rose-deep);margin-left:3px;opacity:.9}
.scars{position:absolute;inset:0;pointer-events:none;z-index:4}
.splat{position:absolute;width:96px;height:96px;transform:translate(-50%,-50%) scale(.4);opacity:0;pointer-events:none}
.splat.go{animation:splat .7s ease forwards}
@keyframes splat{0%{opacity:0;transform:translate(-50%,-50%) scale(.3)}30%{opacity:.8}100%{opacity:.4;transform:translate(-50%,-50%) scale(1)}}
.numeral{position:absolute;font-family:var(--display);font-weight:600;font-size:1.5rem;color:var(--rose-deep);text-shadow:0 2px 6px rgba(255,255,255,.6);pointer-events:none;opacity:0}
.numeral.go{animation:rise 1.1s ease forwards}
@keyframes rise{0%{opacity:0;transform:translateY(8px)}20%{opacity:1}100%{opacity:0;transform:translateY(-32px)}}
/* the action bar - your sigils to cast this turn */
.actionbar{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;width:100%;max-width:700px;min-height:88px}
.cast{width:86px;border:1px solid var(--glass-edge);border-radius:13px;background:var(--glass);cursor:pointer;
  -webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:inset 0 1px 0 var(--glass-hi);
  display:flex;flex-direction:column;align-items:center;gap:.18rem;padding:.4rem .25rem .35rem;color:var(--ink);transition:transform .14s,border-color .15s,box-shadow .18s}
.cast__sig{width:50px;height:50px;display:grid;place-items:center;--rc:var(--r-common);border-radius:48% 52% 50% 50%/52% 50% 50% 48%;
  background:var(--disc);border:1px solid color-mix(in srgb,var(--rc) 55%,#2a3a30)}
.cast__sig svg{width:84%;height:84%}
.cast__name{font-family:var(--display);font-style:italic;font-size:.7rem;line-height:1.05;max-width:82px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--ink-dim)}
.cast__meta{display:flex;align-items:center;gap:.3rem;font-size:.64rem;color:var(--ink-faint)}
.cast__cost{color:var(--gold);font-weight:600}
.cast__ch{display:inline-flex;gap:2px}
.cast__ch i{width:5px;height:5px;border-radius:50%;background:rgba(120,96,120,.25)}
.cast__ch i.on{background:var(--sage-deep);box-shadow:0 0 4px var(--glow-cool)}
.cast__cd{font-size:.6rem;color:var(--ink-faint)}
.cast.is-ready{border-color:rgba(143,200,173,.6)}
.cast.is-ready:hover{transform:translateY(-4px);border-color:var(--glow-cool);box-shadow:0 8px 20px -8px rgba(110,166,126,.5),inset 0 1px 0 var(--glass-hi)}
.cast.is-locked{opacity:.45;cursor:default}
.cast--focus{justify-content:center;color:var(--ink-dim)}
.cast--focus .cast__focusglyph{font-size:1.5rem;color:var(--gold);height:50px;display:grid;place-items:center}
.cast--focus.is-ready:hover{transform:translateY(-4px);border-color:var(--gold);box-shadow:0 8px 20px -8px rgba(231,181,119,.5),inset 0 1px 0 var(--glass-hi)}
.duelctl{text-align:center;min-height:5.4rem;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.55rem}
.difficulty{display:flex;gap:1.3rem}
.diff{border:0;background:none;cursor:pointer;color:var(--ink-faint);font-family:var(--display);font-style:italic;font-size:.94rem;padding-bottom:.15rem;position:relative}
.diff:hover{color:var(--ink-dim)}
.diff.on{color:var(--gold)}
.diff.on::after{content:"";position:absolute;left:0;right:0;bottom:0;height:1.5px;background:currentColor;opacity:.8;border-radius:2px}
.duel-note{margin-top:.2rem;max-width:30rem;font-family:var(--display);font-style:italic;font-size:.82rem;line-height:1.5;color:var(--ink-faint);text-align:center}
.duel-note b{color:var(--sage-deep);font-weight:600}
.begin{cursor:pointer;color:var(--moon);font-family:var(--display);font-size:1rem;padding:.55rem 1.6rem;border-radius:11px;
  background:linear-gradient(var(--glass-3),var(--glass-2));border:1px solid var(--glass-edge);
  -webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 8px 18px -10px rgba(86,66,86,.4),inset 0 1px 0 var(--glass-hi);transition:.18s}
.begin:hover{border-color:var(--sage);box-shadow:0 10px 24px -10px rgba(110,166,126,.5),0 0 0 1px rgba(143,187,152,.3),inset 0 1px 0 var(--glass-hi);transform:translateY(-1px)}
.text-link{border:0;background:none;color:var(--ink-faint);cursor:pointer;font-style:italic;font-family:var(--display);font-size:.86rem}
.text-link:hover{color:var(--sage-deep)}
.result{font-family:var(--display);font-size:1.14rem;color:var(--ink)}
.rubric{color:var(--sage-deep)}.gilt{color:var(--gold)}

/* Multiplayer popover - frosted, with its arcane accent */
.mp-pop{position:fixed;top:72px;right:22px;z-index:52;width:min(330px,86vw);padding:22px 22px 18px;border-radius:16px;text-align:center;
  background:var(--glass-2);-webkit-backdrop-filter:blur(24px) saturate(1.2);backdrop-filter:blur(24px) saturate(1.2);
  border:1px solid var(--glass-edge);box-shadow:var(--glass-shadow),inset 0 1px 0 var(--glass-hi);
  opacity:0;visibility:hidden;transform:translateY(-8px);transition:opacity .2s,transform .2s,visibility .2s}
.mp-pop.show{opacity:1;visibility:visible;transform:none}
.mp-pop>*{position:relative;z-index:1}
.mp-pop .frame-flora{position:absolute;top:-26px;left:-22px;width:120px;height:120px;transform:scale(-1,1);pointer-events:none;z-index:0;overflow:visible;opacity:.9}
.mp-pop__glyph{font-size:1.9rem;color:var(--arcane);filter:drop-shadow(0 0 12px rgba(156,138,224,.5))}
.mp-pop__title{font-family:var(--display);font-size:1.34rem;color:var(--moon);margin:.15rem 0 .45rem}
.mp-pop__body{font-size:.9rem;color:var(--ink-dim);line-height:1.55;margin-bottom:1.1rem}
.mp-pop__body em{color:var(--sage-deep);font-style:italic}

/* Expedition */
.exp{position:relative;height:100%;padding:22px;display:flex;flex-direction:column}
.exp__map{position:relative;flex:1;min-height:0}
.exp-edges{position:absolute;inset:0;width:100%;height:100%;overflow:visible}
.exp-edges line{stroke:rgba(120,96,120,.4);stroke-width:.5;stroke-dasharray:2 2;vector-effect:non-scaling-stroke}
.exp-node{position:absolute;transform:translate(-50%,-50%);width:46px;height:46px;cursor:default;
  border:1px solid var(--glass-edge);border-radius:48% 52% 50% 50% / 52% 50% 50% 48%;
  background:var(--glass-2);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
  display:grid;place-items:center;padding:0;color:var(--ink-dim);transition:transform .15s,box-shadow .2s}
.exp-node .g{font-size:1.05rem}
.exp-node.cleared{opacity:.4}
.exp-node.current{border-color:var(--sage);box-shadow:0 0 16px -3px var(--glow-cool);cursor:pointer;color:var(--ink)}
.exp-node.choosable{border-color:var(--gold);cursor:pointer;color:var(--ink);animation:beckon 2.4s ease-in-out infinite}
.exp-node.choosable:hover,.exp-node.current:hover{transform:translate(-50%,-50%) scale(1.14)}
@keyframes beckon{0%,100%{box-shadow:0 0 0 0 rgba(231,181,119,0)}50%{box-shadow:0 0 14px 1px rgba(231,181,119,.45)}}
.exp-node.boss{width:58px;height:58px}.exp-node.boss .g{font-size:1.3rem;color:var(--rose-deep)}
.exp-node.elite .g{color:var(--gold)}
.exp__info{min-height:6rem;text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem}
.exp__info .body{color:var(--ink-dim);font-family:var(--display);font-style:italic}

/* toast + scrim */
.toast{position:fixed;left:44%;top:78px;transform:translateX(-50%) translateY(-14px);z-index:60;display:flex;align-items:center;gap:.7rem;
  padding:.7rem 1.1rem;border-radius:12px;pointer-events:none;background:var(--glass-3);
  -webkit-backdrop-filter:blur(18px) saturate(1.2);backdrop-filter:blur(18px) saturate(1.2);
  border:1px solid var(--tc,var(--glass-edge));box-shadow:var(--glass-shadow),inset 0 1px 0 var(--glass-hi);opacity:0;transition:opacity .3s,transform .3s cubic-bezier(.2,.9,.3,1.2)}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast__mark{width:40px;height:40px;flex:0 0 auto;border-radius:46%;background:var(--disc);display:grid;place-items:center}
.toast__mark svg{width:84%;height:84%}
.toast__txt b{font-family:var(--display);font-size:1.04rem;color:var(--tc,var(--sage-deep));display:block}
.toast__eyebrow{font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint)}
.scrim{position:fixed;inset:0;z-index:35;background:rgba(60,52,66,.22);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);
  opacity:0;pointer-events:none;transition:opacity .22s}
.scrim.show{opacity:1;pointer-events:auto}

/* responsive */
@media (max-width:760px){
  .shelf{width:min(86vw,300px)} .clearing{right:0}
  .insp__cols{grid-template-columns:1fr;gap:1rem} .insp__head{flex-direction:column;text-align:center}
  .trials__panel{height:94vh}
  .brand__sub{display:none}
}

/* motion floor */
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.08s!important}
  .flora,.moon{animation:none}
}
