/* ============================================================
   KOTODAMA 言霊 — DESIGN LANGUAGE
   "Rider-Waite-Smith" — antique-print light system
   ------------------------------------------------------------
   Parchment paper · warm black linework · flat tarot color ·
   gilded gold accents · sans-serif type.
   Drop this file in and use the classes below, or lift the
   :root tokens into your Tailwind theme (see CLAUDE.md).
   ============================================================ */

/* ----------------------------------------------------------------
   1 · DESIGN TOKENS
   ---------------------------------------------------------------- */
:root {
  /* — Paper (backgrounds), warm cream, light → deep — */
  --paper-0:#F3E8CE;      /* page / canvas */
  --paper-1:#FAF3DF;      /* card & panel faces (lifts off page) */
  --paper-2:#ECDDB8;      /* raised band: table head, sidebar, inset */
  --paper-3:#E2D0A6;      /* hover / pressed / active inset */
  --paper-edge:#D8C390;   /* deep parchment edge / gutter */

  /* — Ink (text + linework), warm near-black → faint — */
  --ink-0:#1C1813;        /* primary text · bold black linework */
  --ink-1:#473F31;        /* secondary text */
  --ink-mid:#6E6047;      /* muted text / captions */
  --ink-lo:#9A8A68;       /* faint text / placeholders */

  /* — Hairlines (ink at alpha) — */
  --line:rgba(28,24,19,.20);     /* default hairline */
  --line-2:rgba(28,24,19,.38);   /* stronger hairline */
  --line-ink:#1C1813;            /* full bold black border (cards, modals) */

  /* — Accents (flat antique tarot color) — */
  --gold:#E0AE39;         /* marigold sky — PRIMARY / active / focus */
  --gold-soft:#EAC56E;    /* lighter gold for fills & glints */
  --gold-deep:#B5871E;    /* antique gilding — borders on gold, metal */
  --vermilion:#BF3B2C;    /* scarlet robe — danger / banish / emphasis */
  --vermilion-soft:#D9694F;
  --sky:#4C89AC;          /* sky-water blue — info / links */
  --sky-soft:#7FB0CB;
  --teal:#327A64;         /* foliage green — success / cast / live */
  --teal-soft:#5FA98C;
  --slate:#3E5871;        /* night sky — secondary / quiet emphasis */

  /* — Semantic roles — */
  --ok:#327A64;           /* cast / active / live */
  --warn:#C2962B;         /* draft / pending */
  --danger:#BF3B2C;       /* banish / dispel / destructive */
  --info:#4C89AC;

  /* ============================================================
     ELEMENTAL IDENTITY — the spine of the system.
     Five elements, each a tarot suit + alchemical sigil + ramp.
     Day values here; Night lifts them in §1b.
     Theme any container with  data-element="earth|air|fire|water|aether"
     — it rebinds --accent / --accent-soft / --accent-deep / --glow / --sigil.
     The shell (no data-element) defaults to AETHER (the KamiSama violet).
     ============================================================ */
  /* 地 EARTH · Pentacles · vine, gems, gold */
  --earth:#4E8A4E;  --earth-soft:#7FB079;  --earth-deep:#33602F;  --earth-glow:rgba(78,138,78,.30);
  /* 風 AIR · Swords · clouds, steam, steel */
  --air:#6E8CA8;    --air-soft:#A6BBD0;    --air-deep:#48637E;    --air-glow:rgba(110,140,168,.30);
  /* 火 FIRE · Wands · embers, sparks, flame */
  --fire:#C0432E;   --fire-soft:#E0805A;   --fire-deep:#8C2F1F;   --fire-glow:rgba(192,67,46,.32);
  /* 水 WATER · Cups · rivers, seas, fluid */
  --water:#3E7C9A;  --water-soft:#6FAAC4;  --water-deep:#27566F;  --water-glow:rgba(62,124,154,.30);
  /* 空 AETHER · Spirit · the KamiSama quintessence */
  --aether:#7E5BB0; --aether-soft:#A988D4; --aether-deep:#593A88; --aether-glow:rgba(126,91,176,.32);

  /* alchemical sigils (rendered via Noto Sans Symbols 2) */
  --sig-earth:"\1F703"; --sig-air:"\1F701"; --sig-fire:"\1F702"; --sig-water:"\1F704"; --sig-aether:"\1F700";

  /* default accent = AETHER (shell / KamiSama) */
  --accent:var(--aether); --accent-soft:var(--aether-soft); --accent-deep:var(--aether-deep);
  --glow:var(--aether-glow); --sigil:var(--sig-aether);
  --accent-rgb:126,91,176;

  /* back-compat aliases */
  --el-earth:var(--earth); --el-air:var(--air); --el-fire:var(--fire);
  --el-water:var(--water); --el-aether:var(--aether);

  /* — Rgb channels (for alpha mixes) — */
  --gold-rgb:224,174,57;
  --ink-rgb:28,24,19;
  --vermilion-rgb:191,59,44;
  --teal-rgb:50,122,100;
  --sky-rgb:76,137,172;

  /* — Radius — */
  --r-card:4px;
  --r-control:3px;
  --r-pill:999px;

  /* — Elevation (warm, soft — paper casting on paper) — */
  --shadow-1:0 1px 0 rgba(255,255,255,.55) inset, 0 2px 6px -3px rgba(60,45,18,.35);
  --shadow-2:0 1px 0 rgba(255,255,255,.6) inset, 0 14px 30px -18px rgba(60,45,18,.50);
  --shadow-modal:0 1px 0 rgba(255,255,255,.5) inset, 0 40px 80px -30px rgba(40,28,8,.65);
  --glow-gold:0 0 0 1px rgba(var(--gold-rgb),.5), 0 6px 22px -8px rgba(var(--gold-rgb),.55);

  /* — Type families — */
  --ff-display:"Marcellus", "Cormorant Garamond", Georgia, serif;
  --ff-body:"Mulish", system-ui, -apple-system, sans-serif;
  --ff-mono:"JetBrains Mono", ui-monospace, "SFMono-Regular", monospace;
  --ff-kanji:"Zen Kaku Gothic New", "Mulish", sans-serif;
  --ff-sigil:"Noto Sans Symbols 2", "Segoe UI Symbol", "Apple Symbols", sans-serif;
  --on-gold:#1F1A12;      /* constant dark ink for text/knobs on gold (both themes) */

  /* — Spacing scale (4pt) — */
  --s-1:4px; --s-2:8px; --s-3:12px; --s-4:16px;
  --s-5:24px; --s-6:32px; --s-7:48px; --s-8:64px;
}

/* ----------------------------------------------------------------
   1a · ELEMENTAL SCOPING — rebind the accent to an element.
   Put data-element on any container (a vessel card, a detail page,
   the <body>, a modal). Everything inside inherits the element's
   accent, glow and sigil. Nest freely.
   ---------------------------------------------------------------- */
[data-element="earth"] {--accent:var(--earth); --accent-soft:var(--earth-soft); --accent-deep:var(--earth-deep); --glow:var(--earth-glow); --sigil:var(--sig-earth);}
[data-element="air"]   {--accent:var(--air);   --accent-soft:var(--air-soft);   --accent-deep:var(--air-deep);   --glow:var(--air-glow);   --sigil:var(--sig-air);}
[data-element="fire"]  {--accent:var(--fire);  --accent-soft:var(--fire-soft);  --accent-deep:var(--fire-deep);  --glow:var(--fire-glow);  --sigil:var(--sig-fire);}
[data-element="water"] {--accent:var(--water); --accent-soft:var(--water-soft); --accent-deep:var(--water-deep); --glow:var(--water-glow); --sigil:var(--sig-water);}
[data-element="aether"]{--accent:var(--aether);--accent-soft:var(--aether-soft);--accent-deep:var(--aether-deep);--glow:var(--aether-glow);--sigil:var(--sig-aether);}

/* ----------------------------------------------------------------
   1b · NIGHT — Rider-Waite "Moon / Star / Tower" dark palette
   Apply  data-palette="night"  on <html>.
   Deep indigo night sky · bone text · steel linework ·
   the gold moon & vermilion still burn.
   ---------------------------------------------------------------- */
[data-palette="night"]{
  /* paper → deep night indigo */
  --paper-0:#121521;      /* deepest night sky */
  --paper-1:#1A1E2E;      /* card & panel faces */
  --paper-2:#232839;      /* raised band */
  --paper-3:#2C3247;      /* hover / inset */
  --paper-edge:#3A415A;

  /* ink → bone / parchment text on night */
  --ink-0:#ECE3CE;        /* primary text · bone */
  --ink-1:#C6BEA9;        /* secondary */
  --ink-mid:#8C8674;      /* muted */
  --ink-lo:#615E50;       /* faint */

  /* hairlines → bone at alpha; bold edge → steel (still reads as a framed plate) */
  --line:rgba(236,227,206,.12);
  --line-2:rgba(236,227,206,.24);
  --line-ink:#5A6178;     /* steel-indigo bold border */

  /* accents → same hues, lifted for dark ground */
  --gold:#E6B948;
  --gold-soft:#F2D27E;
  --gold-deep:#C49A2E;
  --vermilion:#D9543F;
  --vermilion-soft:#E8765C;
  --sky:#6FA8C9;
  --sky-soft:#93C0DA;
  --teal:#4FA083;
  --teal-soft:#74BBA0;
  --slate:#6B86A6;

  --ok:#4FA083;
  --warn:#D6A93C;
  --danger:#D9543F;
  --info:#6FA8C9;

  /* elemental ramps — lifted for the dark ground (data-element rebinds auto-follow) */
  --earth:#6FAE5C;  --earth-soft:#9ED086;  --earth-deep:#4C8444;
  --air:#93AEC8;    --air-soft:#BFD2E4;    --air-deep:#6A88A4;
  --fire:#DD5B3F;   --fire-soft:#EE8A66;   --fire-deep:#B5412C;
  --water:#5BA0C4;  --water-soft:#88C2DD;  --water-deep:#3C7593;
  --aether:#A079D6; --aether-soft:#C2A8E8; --aether-deep:#7C57AE;
  --earth-glow:rgba(111,174,92,.34); --air-glow:rgba(147,174,200,.32);
  --fire-glow:rgba(221,91,63,.36);   --water-glow:rgba(91,160,196,.34);
  --aether-glow:rgba(160,121,214,.36);
  --accent-rgb:160,121,214;

  /* rgb channels */
  --gold-rgb:230,185,72;
  --ink-rgb:236,227,206;
  --vermilion-rgb:217,84,63;
  --teal-rgb:79,160,131;
  --sky-rgb:111,168,201;

  /* elevation → deeper, cooler */
  --shadow-1:0 1px 0 rgba(255,255,255,.04) inset, 0 2px 8px -3px rgba(0,0,0,.6);
  --shadow-2:0 1px 0 rgba(255,255,255,.05) inset, 0 18px 40px -20px rgba(0,0,0,.8);
  --shadow-modal:0 1px 0 rgba(255,255,255,.05) inset, 0 50px 90px -30px rgba(0,0,0,.85);
}
/* night ground: swap letterpress grain for a faint starfield */
[data-palette="night"] body{background:var(--paper-0)}
[data-palette="night"] body::before{
  background-image:
    radial-gradient(1.3px 1.3px at 18% 28%, rgba(236,227,206,.55), transparent),
    radial-gradient(1px 1px at 68% 62%, rgba(230,185,72,.55), transparent),
    radial-gradient(1px 1px at 42% 82%, rgba(236,227,206,.35), transparent),
    radial-gradient(1.4px 1.4px at 84% 22%, rgba(236,227,206,.45), transparent),
    radial-gradient(1px 1px at 12% 70%, rgba(111,168,201,.45), transparent),
    radial-gradient(1.1px 1.1px at 55% 14%, rgba(236,227,206,.3), transparent);
  background-repeat:repeat;background-size:330px 330px;
  opacity:.5;mix-blend-mode:normal;
}
/* night fixups for the few literal colors */
[data-palette="night"] .badge.draft{color:#EAC56E}
[data-palette="night"] .toast.warn .t-ic{color:#EAC56E}
[data-palette="night"] .field input:focus,
[data-palette="night"] .field select:focus,
[data-palette="night"] .field textarea:focus{background:var(--paper-3)}

/* ----------------------------------------------------------------
   2 · BASE
   ---------------------------------------------------------------- */
*{box-sizing:border-box}
html,body{margin:0}
body{
  background:var(--paper-0);
  color:var(--ink-0);
  font-family:var(--ff-body);
  font-size:15px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
/* faint letterpress grain on the paper */
body::before{
  content:"";position:fixed;inset:0;z-index:0;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E");
  opacity:.05;mix-blend-mode:multiply;
}
::selection{background:rgba(var(--gold-rgb),.4);color:var(--ink-0)}
a{color:var(--sky);text-decoration-thickness:1px;text-underline-offset:3px}
button{font-family:inherit;color:inherit;cursor:pointer;background:none;border:none;padding:0}
input,select,textarea{font-family:inherit}
::-webkit-scrollbar{width:11px;height:11px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--paper-edge);border:3px solid transparent;background-clip:content-box;border-radius:8px}
::-webkit-scrollbar-thumb:hover{background:var(--ink-lo);background-clip:content-box}

/* ----------------------------------------------------------------
   3 · TYPE
   ---------------------------------------------------------------- */
.display{font-family:var(--ff-display);font-weight:400;letter-spacing:.01em;line-height:1.08}
h1,h2,h3,h4{font-family:var(--ff-display);font-weight:400;letter-spacing:.01em;margin:0;color:var(--ink-0)}
.t-hero{font-size:clamp(40px,6vw,68px);font-weight:400;letter-spacing:.005em;line-height:1.02}
.t-h1{font-size:34px;line-height:1.1}
.t-h2{font-size:24px;line-height:1.15}
.t-h3{font-size:18px;line-height:1.25}
.mono{font-family:var(--ff-mono)}
.kanji{font-family:var(--ff-kanji);font-weight:500}
.eyebrow{
  font-family:var(--ff-mono);font-size:10.5px;font-weight:500;
  letter-spacing:.30em;text-transform:uppercase;color:var(--ink-mid);
}
.label{
  font-family:var(--ff-mono);font-size:10px;font-weight:500;
  letter-spacing:.22em;text-transform:uppercase;color:var(--ink-lo);
}
.caption{font-size:13px;color:var(--ink-mid);line-height:1.5}
.muted{color:var(--ink-mid)}
.faint{color:var(--ink-lo)}

/* gilded text sweep — a touch of shimmer on key accents */
.gild{
  background:linear-gradient(100deg,var(--gold-deep) 0%,var(--gold) 30%,var(--gold-soft) 48%,var(--gold) 66%,var(--gold-deep) 100%);
  background-size:220% 100%;
  -webkit-background-clip:text;background-clip:text;color:transparent;
  animation:gildShift 7s linear infinite;
}
@keyframes gildShift{to{background-position:-220% 0}}

/* ----------------------------------------------------------------
   4 · LINEWORK · BOXES · PANELS
   ---------------------------------------------------------------- */
/* default soft panel — hairline, subtle lift */
.panel{
  background:var(--paper-1);
  border:1px solid var(--line-2);
  border-radius:var(--r-card);
  box-shadow:var(--shadow-1);
}
.panel-pad{padding:var(--s-5)}

/* INKED box — the signature bold-black-outline plate (cards, dialogs, key surfaces) */
.inked{
  position:relative;
  background:var(--paper-1);
  border:1.5px solid var(--line-ink);
  border-radius:var(--r-card);
  box-shadow:var(--shadow-2);
}
/* inner keyline frame, like a tarot card border */
.inked.framed::after{
  content:"";position:absolute;inset:5px;border:1px solid var(--line-2);
  border-radius:2px;pointer-events:none;
}

/* hairline divider, optional center node (rotated lozenge) */
.rule{height:1px;background:var(--line);border:0;position:relative}
.rule.node::after{
  content:"";position:absolute;left:50%;top:50%;width:6px;height:6px;
  transform:translate(-50%,-50%) rotate(45deg);
  background:var(--paper-0);border:1px solid var(--line-ink);
}
.rule.ink{background:var(--line-2)}

/* corner lozenges — drop into any .inked for the card-corner detail */
.corner{position:absolute;width:7px;height:7px;border:1.5px solid var(--line-ink);
  transform:rotate(45deg);background:var(--paper-1);z-index:2}
.corner.tl{top:-4px;left:-4px}.corner.tr{top:-4px;right:-4px}
.corner.bl{bottom:-4px;left:-4px}.corner.br{bottom:-4px;right:-4px}

/* ----------------------------------------------------------------
   5 · CARDS (tarot)
   ---------------------------------------------------------------- */
.tcard{
  position:relative;
  background:var(--paper-1);
  border:1.5px solid var(--line-ink);
  border-radius:var(--r-card);
  box-shadow:var(--shadow-2);
  transition:transform .45s cubic-bezier(.2,.7,.2,1), box-shadow .45s, border-color .45s;
}
.tcard .frame{position:absolute;inset:6px;border:1px solid var(--line-2);border-radius:2px;pointer-events:none}
.tcard-body{position:relative;padding:var(--s-5);z-index:1}

/* card title plate — the bottom roman-label band of an RWS card */
.tcard-name{
  border-top:1.5px solid var(--line-ink);
  padding:11px var(--s-5);text-align:center;
  font-family:var(--ff-mono);font-size:11px;font-weight:600;
  letter-spacing:.26em;text-transform:uppercase;color:var(--ink-0);
  display:flex;align-items:center;justify-content:center;gap:10px;
}
.tcard-num{font-family:var(--ff-mono);color:var(--gold-deep);font-size:11px;letter-spacing:.1em}

.tcard.interactive{cursor:pointer}
.tcard.interactive:hover{
  transform:translateY(-5px);
  box-shadow:0 1px 0 rgba(255,255,255,.6) inset, 0 26px 50px -22px rgba(40,28,8,.6);
  border-color:var(--ink-0);
}
.tcard.interactive:hover .frame{border-color:rgba(var(--gold-rgb),.65)}

/* draw / deal animation */
@keyframes drawCard{0%{opacity:0;transform:translateY(22px) scale(.97)}100%{opacity:1;transform:none}}
.draw{animation:drawCard .55s cubic-bezier(.2,.7,.2,1) both}
.draw-stagger>*{animation:drawCard .55s cubic-bezier(.2,.7,.2,1) both}

/* ----------------------------------------------------------------
   6 · BUTTONS & CHIPS
   ---------------------------------------------------------------- */
.btn{
  font-family:var(--ff-mono);font-size:11px;font-weight:500;
  letter-spacing:.16em;text-transform:uppercase;
  padding:10px 18px;border:1px solid var(--line-ink);border-radius:var(--r-control);
  color:var(--ink-0);background:var(--paper-1);
  display:inline-flex;align-items:center;gap:9px;
  transition:transform .12s, background .2s, box-shadow .2s, border-color .2s;
}
.btn:hover{background:var(--paper-2)}
.btn:active{transform:translateY(1px)}
.btn:focus-visible{outline:none;box-shadow:0 0 0 3px rgba(var(--gold-rgb),.45)}
.btn-sm{padding:7px 13px;font-size:10px}

/* PRIMARY — gilded gold plate with black ink edge + shimmer */
.btn-primary{
  position:relative;overflow:hidden;color:var(--on-gold);
  background:linear-gradient(180deg,var(--gold-soft),var(--gold));
  border-color:var(--gold-deep);
  box-shadow:0 1px 0 rgba(255,255,255,.45) inset, 0 6px 16px -8px rgba(var(--gold-rgb),.7);
}
.btn-primary:hover{background:linear-gradient(180deg,var(--gold-soft),var(--gold-soft))}
.btn-primary::after{
  content:"";position:absolute;top:0;left:-130%;width:55%;height:100%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.6),transparent);
  transform:skewX(-18deg);
}
.btn-primary:hover::after{animation:sweep 1s ease}
@keyframes sweep{from{left:-130%}to{left:150%}}

.btn-ghost{background:transparent;border-color:var(--line-2)}
.btn-ghost:hover{background:rgba(var(--ink-rgb),.05);border-color:var(--line-ink)}
.btn-danger{color:var(--vermilion);border-color:rgba(var(--vermilion-rgb),.5);background:transparent}
.btn-danger:hover{background:rgba(var(--vermilion-rgb),.1);border-color:var(--vermilion)}
.btn[disabled]{opacity:.45;cursor:not-allowed}

/* chips — small inline tags */
.chip{
  font-family:var(--ff-mono);font-size:10px;font-weight:500;
  letter-spacing:.14em;text-transform:uppercase;
  padding:5px 10px;border:1px solid var(--line-2);border-radius:var(--r-control);
  color:var(--ink-1);background:var(--paper-1);
  display:inline-flex;align-items:center;gap:7px;white-space:nowrap;
}
.chip.on{border-color:var(--gold-deep);color:var(--ink-0);background:rgba(var(--gold-rgb),.16)}

/* ----------------------------------------------------------------
   7 · FORMS & INPUTS
   ---------------------------------------------------------------- */
.field{margin-bottom:var(--s-4)}
.field>label{
  display:block;font-family:var(--ff-mono);font-size:10px;font-weight:500;
  letter-spacing:.20em;text-transform:uppercase;color:var(--ink-mid);margin-bottom:7px;
}
.field input,.field select,.field textarea{
  width:100%;background:var(--paper-1);
  border:1.5px solid var(--line-2);border-radius:var(--r-control);
  color:var(--ink-0);padding:11px 13px;
  font-family:var(--ff-body);font-size:14px;
  transition:border-color .2s, box-shadow .2s, background .2s;
}
.field input::placeholder,.field textarea::placeholder{color:var(--ink-lo)}
.field input:hover,.field select:hover,.field textarea:hover{border-color:var(--line-ink)}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--gold-deep);background:#fff;
  box-shadow:0 0 0 3px rgba(var(--gold-rgb),.28);
}
.field .hint{font-size:12px;color:var(--ink-lo);margin-top:6px}
.field.err input{border-color:var(--vermilion)}
.field.err .hint{color:var(--vermilion)}
/* mono input — for runes / IDs / passphrase */
.field.rune input{font-family:var(--ff-mono);letter-spacing:.06em}

/* ----------------------------------------------------------------
   8 · TABLES / DATA LISTS
   ---------------------------------------------------------------- */
.table-wrap{border:1.5px solid var(--line-ink);border-radius:var(--r-card);overflow:hidden;background:var(--paper-1)}
table.kt{width:100%;border-collapse:collapse;font-size:14px}
table.kt thead th{
  background:var(--paper-2);text-align:left;
  font-family:var(--ff-mono);font-size:10px;font-weight:600;
  letter-spacing:.16em;text-transform:uppercase;color:var(--ink-mid);
  padding:11px 16px;border-bottom:1.5px solid var(--line-ink);
}
table.kt tbody td{padding:13px 16px;border-bottom:1px solid var(--line);color:var(--ink-1);vertical-align:middle}
table.kt tbody tr:last-child td{border-bottom:0}
table.kt tbody tr{transition:background .15s}
table.kt tbody tr:hover{background:rgba(var(--gold-rgb),.10)}
table.kt td .lead{color:var(--ink-0);font-weight:600}
table.kt .num{font-family:var(--ff-mono);font-variant-numeric:tabular-nums;text-align:right}

/* ----------------------------------------------------------------
   9 · TOGGLE — cast / dispel (a flame lit or snuffed)
   ---------------------------------------------------------------- */
.cast{
  display:flex;align-items:center;gap:13px;padding:13px 15px;
  border:1.5px solid var(--line-2);border-radius:var(--r-control);
  background:var(--paper-1);transition:all .25s;cursor:pointer;
}
.cast:hover{border-color:var(--line-ink);background:var(--paper-2)}
.cast .flame{
  width:32px;height:32px;flex:none;display:grid;place-items:center;
  border:1.5px solid var(--line-2);border-radius:50%;
  color:var(--ink-lo);background:var(--paper-0);transition:all .3s;
}
.cast .flame svg{transition:transform .3s}
.cast.on{border-color:var(--gold-deep);background:rgba(var(--gold-rgb),.10)}
.cast.on .flame{
  color:var(--vermilion);border-color:var(--gold-deep);
  background:radial-gradient(circle at 50% 65%, rgba(var(--gold-rgb),.5), var(--paper-1));
  box-shadow:0 0 16px -3px rgba(var(--gold-rgb),.7);
}
.cast.on .flame svg{transform:translateY(-1px) scale(1.08)}
.cast .cast-meta{display:flex;flex-direction:column;gap:1px}
.cast .cast-title{font-weight:600;color:var(--ink-0);font-size:14px}
.cast .cast-state{font-family:var(--ff-mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-lo)}
.cast.on .cast-state{color:var(--teal)}
.cast.locked{opacity:.6;cursor:not-allowed}

/* compact switch variant */
.switch{position:relative;width:46px;height:26px;border-radius:var(--r-pill);
  border:1.5px solid var(--line-ink);background:var(--paper-2);transition:.25s;flex:none}
.switch::after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;
  background:var(--ink-0);transition:.25s}
.switch.on{background:var(--gold);border-color:var(--gold-deep)}
.switch.on::after{left:23px;background:var(--on-gold)}

/* ----------------------------------------------------------------
   10 · BADGES & STATUS DOTS
   ---------------------------------------------------------------- */
.badge{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--ff-mono);font-size:10px;font-weight:600;
  letter-spacing:.14em;text-transform:uppercase;
  padding:4px 9px;border-radius:var(--r-control);border:1px solid;
}
.badge.live{color:var(--teal);border-color:rgba(var(--teal-rgb),.45);background:rgba(var(--teal-rgb),.12)}
.badge.draft{color:#9a7415;border-color:rgba(var(--gold-rgb),.5);background:rgba(var(--gold-rgb),.16)}
.badge.banished{color:var(--vermilion);border-color:rgba(var(--vermilion-rgb),.45);background:rgba(var(--vermilion-rgb),.1)}
.badge.dormant{color:var(--ink-mid);border-color:var(--line-2);background:var(--paper-2)}
.badge.kami{color:var(--el-aether);border-color:rgba(110,90,142,.5);background:rgba(110,90,142,.12)}

.dot{width:7px;height:7px;border-radius:50%;display:inline-block;flex:none}
.dot.live{background:var(--teal);box-shadow:0 0 0 3px rgba(var(--teal-rgb),.18)}
.dot.draft{background:var(--warn);box-shadow:0 0 0 3px rgba(var(--gold-rgb),.2)}
.dot.banished{background:var(--vermilion);box-shadow:0 0 0 3px rgba(var(--vermilion-rgb),.18)}
.dot.dormant{background:var(--ink-lo)}

/* ----------------------------------------------------------------
   11 · MODALS / DIALOGS
   ---------------------------------------------------------------- */
.scrim{
  position:fixed;inset:0;z-index:50;display:grid;place-items:center;padding:24px;
  background:rgba(28,20,8,.5);backdrop-filter:blur(2px);
  animation:fadeIn .25s ease both;
}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.dialog{
  position:relative;width:min(480px,100%);background:var(--paper-1);
  border:2px solid var(--line-ink);border-radius:var(--r-card);
  box-shadow:var(--shadow-modal);
  animation:dialogIn .35s cubic-bezier(.2,.7,.2,1) both;
}
@keyframes dialogIn{from{opacity:0;transform:translateY(14px) scale(.98)}to{opacity:1;transform:none}}
.dialog::after{content:"";position:absolute;inset:5px;border:1px solid var(--line-2);border-radius:2px;pointer-events:none}
.dialog-head{
  padding:18px 22px 14px;border-bottom:1.5px solid var(--line-ink);
  display:flex;align-items:flex-start;justify-content:space-between;gap:16px;
}
.dialog-title{font-family:var(--ff-display);font-size:21px;font-weight:400;letter-spacing:.01em;color:var(--ink-0)}
.dialog-body{padding:20px 22px;color:var(--ink-1)}
.dialog-foot{padding:14px 22px 18px;display:flex;gap:10px;justify-content:flex-end}
.dialog-x{width:30px;height:30px;display:grid;place-items:center;border:1px solid var(--line-2);
  border-radius:var(--r-control);color:var(--ink-mid);flex:none}
.dialog-x:hover{border-color:var(--line-ink);color:var(--ink-0);background:var(--paper-2)}

/* ----------------------------------------------------------------
   12 · TOASTS / ALERTS
   ---------------------------------------------------------------- */
.toast{
  display:flex;align-items:flex-start;gap:12px;padding:13px 15px;
  background:var(--paper-1);border:1.5px solid var(--line-ink);
  border-left-width:4px;border-radius:var(--r-control);
  box-shadow:var(--shadow-2);max-width:420px;
}
.toast .t-ic{width:22px;height:22px;flex:none;display:grid;place-items:center;margin-top:1px}
.toast .t-title{font-weight:600;color:var(--ink-0);font-size:14px;line-height:1.3}
.toast .t-msg{font-size:13px;color:var(--ink-mid);margin-top:2px}
.toast.info{border-left-color:var(--sky)} .toast.info .t-ic{color:var(--sky)}
.toast.success{border-left-color:var(--teal)} .toast.success .t-ic{color:var(--teal)}
.toast.warn{border-left-color:var(--warn)} .toast.warn .t-ic{color:#9a7415}
.toast.danger{border-left-color:var(--vermilion)} .toast.danger .t-ic{color:var(--vermilion)}

/* ----------------------------------------------------------------
   13 · NAV / SIDEBAR
   ---------------------------------------------------------------- */
.sidebar{
  background:var(--paper-2);border-right:1.5px solid var(--line-ink);
  display:flex;flex-direction:column;
}
.nav-group{padding:14px 12px}
.nav-group+.nav-group{border-top:1px solid var(--line)}
.nav-head{font-family:var(--ff-mono);font-size:9.5px;font-weight:600;letter-spacing:.22em;
  text-transform:uppercase;color:var(--ink-lo);padding:0 10px 8px}
.nav-item{
  display:flex;align-items:center;gap:11px;padding:9px 11px;border-radius:var(--r-control);
  color:var(--ink-1);font-size:14px;font-weight:500;transition:background .15s,color .15s;
  position:relative;border:1px solid transparent;
}
.nav-item .ji{font-family:var(--ff-kanji);color:var(--ink-lo);width:16px;text-align:center;font-size:13px}
.nav-item:hover{background:rgba(var(--ink-rgb),.05);color:var(--ink-0)}
.nav-item.active{background:var(--paper-1);border-color:var(--line-ink);color:var(--ink-0);font-weight:600}
.nav-item.active::before{content:"";position:absolute;left:-12px;top:50%;transform:translateY(-50%);
  width:3px;height:18px;background:var(--gold);border-radius:2px}
.nav-item.active .ji{color:var(--gold-deep)}

/* ----------------------------------------------------------------
   14 · SEAL / MARK
   ---------------------------------------------------------------- */
.seal{position:relative;display:grid;place-items:center;border-radius:50%;
  border:1.5px solid var(--line-ink);background:var(--paper-1);box-shadow:var(--shadow-1)}
.seal::before{content:"";position:absolute;inset:5px;border:1px solid var(--line-2);border-radius:50%}
.seal .seal-char{font-family:var(--ff-kanji);font-weight:700;line-height:1;color:var(--ink-0);position:relative;z-index:2}
.seal.gilded{border-color:var(--gold-deep)}
.seal.gilded .seal-char{color:var(--gold-deep)}

/* engraved watermark kanji — drop behind content */
.watermark{position:absolute;font-family:var(--ff-kanji);color:var(--ink-0);
  opacity:.04;pointer-events:none;user-select:none;line-height:.8;z-index:0}

/* ----------------------------------------------------------------
   15 · HELPERS
   ---------------------------------------------------------------- */
.row{display:flex;align-items:center;gap:var(--s-3)}
.col{display:flex;flex-direction:column}
.wrap{display:flex;flex-wrap:wrap;gap:var(--s-3)}
.grow{flex:1}
.center{display:grid;place-items:center}
@keyframes riseIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.rise{animation:riseIn .5s ease both}
.scroll{overflow-y:auto;scrollbar-gutter:stable}

/* ================================================================
   16 · ELEMENTAL LAYER
   Sigils · sigil-buttons · accent-wired components · tarot deck.
   Everything here reads --accent / --glow / --sigil, so it
   recolors instantly inside any [data-element] scope.
   ================================================================ */

/* — Sigil glyph. <i class="sigil"></i> draws the current element's
     alchemical mark; add .suit to swap to the tarot suit name nearby. — */
.sigil{font-family:var(--ff-sigil);font-style:normal;line-height:1;display:inline-block;color:var(--accent)}
.sigil::before{content:var(--sigil)}
.sigil.lg::before{font-size:1.4em}
.sigil.ink{color:var(--ink-0)}

/* — SIGIL BUTTON — the default ritual button language.
     A glyph + mono command, framed in accent ink, that glows and
     traces a faint conjuring ring on hover. — */
.btn.sigil-btn{
  position:relative;gap:11px;color:var(--accent-deep);
  border-color:color-mix(in srgb, var(--accent) 55%, transparent);
  background:color-mix(in srgb, var(--accent) 8%, var(--paper-1));
}
.btn.sigil-btn::before{
  content:var(--sigil);font-family:var(--ff-sigil);font-size:15px;
  color:var(--accent);line-height:1;transition:transform .3s;
}
.btn.sigil-btn:hover{
  background:color-mix(in srgb, var(--accent) 16%, var(--paper-1));
  border-color:var(--accent);color:var(--accent-deep);
  box-shadow:0 0 0 1px color-mix(in srgb,var(--accent) 40%,transparent), 0 8px 26px -10px var(--glow);
}
.btn.sigil-btn:hover::before{transform:rotate(40deg) scale(1.12)}
[data-palette="night"] .btn.sigil-btn{color:var(--accent-soft)}
[data-palette="night"] .btn.sigil-btn:hover{color:var(--accent-soft)}

/* — SEAL BUTTON — a circular sigil seal for icon-only ritual triggers.
     The dashed ring rotates on hover, like a summoning circle. — */
.seal-btn{
  position:relative;width:46px;height:46px;flex:none;border-radius:50%;
  display:grid;place-items:center;color:var(--accent);
  border:1.5px solid color-mix(in srgb,var(--accent) 55%,transparent);
  background:color-mix(in srgb,var(--accent) 9%,var(--paper-1));transition:all .3s;
}
.seal-btn::before{content:var(--sigil);font-family:var(--ff-sigil);font-size:19px;line-height:1;z-index:2}
.seal-btn::after{
  content:"";position:absolute;inset:3px;border-radius:50%;
  border:1px dashed color-mix(in srgb,var(--accent) 50%,transparent);
  transition:transform .6s ease, opacity .3s;opacity:.5;
}
.seal-btn:hover{box-shadow:0 0 22px -4px var(--glow);border-color:var(--accent)}
.seal-btn:hover::after{transform:rotate(120deg);opacity:1}
.seal-btn.lg{width:62px;height:62px}.seal-btn.lg::before{font-size:26px}

/* — Element-filled CTA (when you want the accent itself as the action) — */
.btn-el{
  color:#fff;border-color:var(--accent-deep);
  background:linear-gradient(180deg,var(--accent-soft),var(--accent));
  box-shadow:0 1px 0 rgba(255,255,255,.25) inset, 0 6px 16px -8px var(--glow);
}
.btn-el:hover{background:var(--accent);box-shadow:0 0 22px -6px var(--glow)}

/* — Elemental badge / chip — */
.badge.el,.chip.el{
  color:var(--accent-deep);
  border-color:color-mix(in srgb,var(--accent) 45%,transparent);
  background:color-mix(in srgb,var(--accent) 14%,transparent);
}
[data-palette="night"] .badge.el,[data-palette="night"] .chip.el{color:var(--accent-soft)}
.badge.el .sigil,.chip.el .sigil{color:var(--accent)}

/* — Faint accent-tinted ground + a giant sigil watermark for elemental cards — */
.el-ground{
  background:
    radial-gradient(120% 90% at 100% 0%, color-mix(in srgb,var(--accent) 12%,transparent), transparent 60%),
    var(--paper-1);
}
.el-watermark{
  position:absolute;right:10px;bottom:-6px;font-family:var(--ff-sigil);
  font-size:104px;line-height:1;color:var(--accent);opacity:.10;
  pointer-events:none;user-select:none;z-index:0;
}
.el-watermark::before{content:var(--sigil)}

/* — Elemental motif textures (CSS only — no illustration).
     Subtle, accent-tinted, evoke each element's matter. — */
.el-texture{position:relative}
.el-texture::after{content:"";position:absolute;inset:0;pointer-events:none;opacity:.5;z-index:0;border-radius:inherit}
[data-element="earth"] .el-texture::after{          /* gem lattice */
  background-image:radial-gradient(color-mix(in srgb,var(--accent) 22%,transparent) 1px, transparent 1.4px);
  background-size:14px 14px;}
[data-element="air"] .el-texture::after{            /* cloud streaks */
  background-image:repeating-linear-gradient(8deg, color-mix(in srgb,var(--accent) 12%,transparent) 0 2px, transparent 2px 16px);}
[data-element="fire"] .el-texture::after{           /* embers */
  background-image:radial-gradient(color-mix(in srgb,var(--accent) 26%,transparent) 1px, transparent 1.6px);
  background-size:20px 20px;background-position:0 0,10px 10px;}
[data-element="water"] .el-texture::after{          /* ripples */
  background-image:repeating-radial-gradient(circle at 30% 120%, transparent 0 11px, color-mix(in srgb,var(--accent) 13%,transparent) 11px 12px);}

/* — Accent-wired component overrides (kick in inside any [data-element]) — */
.tcard.elemental{border-color:color-mix(in srgb,var(--accent) 55%,var(--line-ink))}
.tcard.elemental .frame{border-color:color-mix(in srgb,var(--accent) 40%,transparent)}
.tcard.elemental.interactive:hover{
  border-color:var(--accent);
  box-shadow:0 1px 0 rgba(255,255,255,.5) inset, 0 26px 50px -22px var(--glow), 0 0 0 1px color-mix(in srgb,var(--accent) 35%,transparent);
}
.tcard.elemental .tcard-name{border-top-color:color-mix(in srgb,var(--accent) 50%,var(--line-ink))}
.tcard.elemental .tcard-num{color:var(--accent)}
.nav-item.active.elemental,.nav-item.active[data-element]{border-color:color-mix(in srgb,var(--accent) 50%,var(--line-ink))}
.nav-item.active.elemental::before{background:var(--accent)}

/* — Stat card (dashboard) — accent figure, faint corner sigil — */
.stat{position:relative;overflow:hidden;background:var(--paper-1);
  border:1.5px solid var(--line-ink);border-radius:var(--r-card);padding:18px 20px;box-shadow:var(--shadow-1)}
.stat .stat-eyebrow{font-family:var(--ff-mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-mid);display:flex;align-items:center;gap:8px}
.stat .stat-num{font-family:var(--ff-display);font-size:40px;font-weight:400;line-height:1;margin-top:12px;color:var(--accent)}
.stat .stat-sig{position:absolute;right:-6px;bottom:-14px;font-family:var(--ff-sigil);font-size:74px;color:var(--accent);opacity:.10}
.stat .stat-sig::before{content:var(--sigil)}

/* ================================================================
   17 · TAROT DECK & DRAW
   A face-down stack you deal from. Pair with the JS in the
   styleguide (or your own) to flip + place drawn cards.
   ================================================================ */
.card-back{
  position:relative;background:
    repeating-linear-gradient(45deg, color-mix(in srgb,var(--accent) 16%,var(--paper-2)) 0 6px, color-mix(in srgb,var(--accent) 7%,var(--paper-2)) 6px 12px);
  border:1.5px solid var(--accent-deep);border-radius:var(--r-card);
  display:grid;place-items:center;box-shadow:var(--shadow-2);overflow:hidden;
}
.card-back::after{content:"";position:absolute;inset:6px;border:1px solid color-mix(in srgb,var(--accent) 45%,transparent);border-radius:2px}
.card-back .back-sigil{font-family:var(--ff-sigil);font-size:34px;color:var(--accent);
  opacity:.9;z-index:1;text-shadow:0 0 18px var(--glow)}
.card-back .back-sigil::before{content:var(--sigil)}

/* the deck = stacked backs with a slight fan */
.deck{position:relative;width:132px;height:200px}
.deck .card-back{position:absolute;inset:0;transition:transform .4s}
.deck .card-back:nth-child(1){transform:translate(6px,6px) rotate(3deg)}
.deck .card-back:nth-child(2){transform:translate(3px,3px) rotate(1.5deg)}
.deck:hover .card-back:nth-child(1){transform:translate(9px,8px) rotate(4.5deg)}

/* deal motion — applied to a card as it leaves the deck */
@keyframes dealOut{
  0%{opacity:0;transform:translate(0,0) rotate(-6deg) scale(.96)}
  55%{opacity:1}
  100%{opacity:1;transform:translate(var(--deal-x,0),var(--deal-y,0)) rotate(0) scale(1)}
}
.dealt{animation:dealOut .6s cubic-bezier(.2,.7,.2,1) both}

/* flip-to-reveal (face-down → face-up) */
.flip-wrap{perspective:1400px}
.flip{position:relative;transition:transform .7s cubic-bezier(.4,.1,.2,1);transform-style:preserve-3d}
.flip.down{transform:rotateY(180deg)}
.flip>.face{position:absolute;inset:0;backface-visibility:hidden}
.flip>.face.back{transform:rotateY(180deg)}

