@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--color-red-400:oklch(70.4% .191 22.216);--color-green-400:oklch(79.2% .209 151.711);--spacing:.25rem;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.visible{visibility:visible}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.hidden{display:none}.text-green-400{color:var(--color-green-400)}.text-red-400{color:var(--color-red-400)}.ring{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}}:root{--bg-primary:#0a0a14;--bg-secondary:#12101e;--bg-card:#1a1528;--bg-surface:#1e1a2d;--text-primary:#e8dcc4;--text-secondary:#b8a88a;--text-muted:#7a6f5e;--text-gold:#d4a017;--text-silver:#a8b4c0;--hills:#d4a017;--mountains:#6b8db5;--forests:#2d9d5b;--shadows:#8b5fbf;--rings:gold;--threat:#c33;--gold:#d4a017;--gold-light:#e8c040;--gold-dark:#8b6914;--silver:#a8b4c0;--bronze:#cd7f32;--danger:#c33;--success:#2d9d5b;--border-ornate:#3d3250;--border-gold:#d4a0174d;--font-display:"Cinzel Decorative", "Cinzel", serif;--font-heading:"Cinzel", serif;--font-body:"Cormorant Garamond", "Georgia", serif;--font-ui:"Cinzel", serif}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;overflow:hidden}body{font-family:var(--font-body);color:var(--text-primary);background:var(--bg-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;font-size:16px;line-height:1.5}#root{height:100%}.app{height:100%;position:relative;overflow:hidden auto}.app::-webkit-scrollbar{width:6px}.app::-webkit-scrollbar-track{background:var(--bg-primary)}.app::-webkit-scrollbar-thumb{background:var(--border-ornate);border-radius:3px}.screen{min-height:100vh;padding:1rem;position:relative}.screen-header{border-bottom:1px solid var(--border-ornate);align-items:center;gap:1rem;margin-bottom:1.5rem;padding-bottom:.75rem;display:flex}.screen-title{font-family:var(--font-heading);color:var(--text-gold);font-size:1.25rem;font-weight:600}.main-menu{text-align:center;background:radial-gradient(at 50% 30%,#d4a01714,#0000 60%),radial-gradient(at 50% 80%,#8b5fbf0f,#0000 50%),linear-gradient(#0a0a14,#12101e,#0a0a14);flex-direction:column;justify-content:center;align-items:center;display:flex}.menu-content{flex-direction:column;align-items:center;gap:1.5rem;max-width:480px;padding:2rem 1rem;display:flex}.menu-ring-container{width:80px;height:80px;margin-bottom:.5rem;position:relative}.menu-ring{border:3px solid var(--rings);border-radius:50%;width:80px;height:80px;animation:3s ease-in-out infinite ringGlow;position:relative;box-shadow:0 0 20px #ffd7004d,0 0 40px #ffd70026,inset 0 0 20px #ffd7001a}.menu-ring-inner{border:2px solid #ffd70066;border-radius:50%;position:absolute;inset:6px}@keyframes ringGlow{0%,to{box-shadow:0 0 20px #ffd7004d,0 0 40px #ffd70026,inset 0 0 20px #ffd7001a}50%{box-shadow:0 0 30px #ffd70080,0 0 60px #ffd70040,inset 0 0 30px #ffd70033}}.menu-title{flex-direction:column;gap:.25rem;display:flex}.menu-title-the{font-family:var(--font-display);color:var(--text-gold);letter-spacing:.1em;text-shadow:0 0 20px #d4a0174d;font-size:1.5rem}.menu-title-sub{font-family:var(--font-heading);color:var(--text-primary);font-size:1.1rem;font-weight:500}.menu-title-game{font-family:var(--font-body);color:var(--text-secondary);margin-top:.25rem;font-size:.9rem;font-style:italic}.menu-inscription{font-family:var(--font-body);color:var(--text-muted);max-width:300px;font-size:.8rem;font-style:italic}.menu-buttons{flex-direction:column;gap:.75rem;width:100%;max-width:320px;display:flex}.menu-footer{font-family:var(--font-body);color:var(--text-muted);margin-top:1rem;font-size:.8rem}.btn{font-family:var(--font-ui);border:1px solid var(--border-ornate);cursor:pointer;text-transform:uppercase;letter-spacing:.05em;background:var(--bg-card);color:var(--text-primary);border-radius:4px;padding:.6rem 1.2rem;font-size:.85rem;font-weight:600;transition:all .2s;position:relative;overflow:hidden}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-gold{background:linear-gradient(135deg,var(--gold-dark) 0%,var(--gold) 50%,var(--gold-light) 100%);color:#1a0f07;border-color:var(--gold);text-shadow:0 1px #ffd7004d;box-shadow:0 2px 8px #d4a0174d}.btn-gold:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 16px #d4a01780}.btn-silver{background:linear-gradient(135deg,#6b7b8d 0%,var(--silver) 50%,#c8d4e0 100%);color:#1a1a2e;border-color:var(--silver)}.btn-silver:hover:not(:disabled){box-shadow:0 4px 16px #a8b4c066}.btn-bronze{background:linear-gradient(135deg,#8b5e2a 0%,var(--bronze) 50%,#e0a050 100%);color:#1a0f07;border-color:var(--bronze)}.btn-outline{border-color:var(--border-ornate);color:var(--text-secondary);background:0 0}.btn-outline:hover:not(:disabled){border-color:var(--text-gold);color:var(--text-gold)}.btn-danger{color:#faa;background:linear-gradient(135deg,#5c1a1a,#8b2020);border-color:#8b2020}.btn-lg{padding:.8rem 1.5rem;font-size:.95rem}.btn-sm{padding:.35rem .75rem;font-size:.75rem}.btn-xs{padding:.2rem .5rem;font-size:.65rem}.btn-full{width:100%}.form-section{margin-bottom:1.5rem}.form-label{font-family:var(--font-heading);color:var(--text-gold);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem;font-size:.85rem;display:block}.form-input{background:var(--bg-card);border:1px solid var(--border-ornate);width:100%;color:var(--text-primary);font-family:var(--font-body);border-radius:4px;outline:none;padding:.6rem .8rem;font-size:1rem;transition:border-color .2s}.form-input:focus{border-color:var(--gold);box-shadow:0 0 8px #d4a01733}.form-hint{color:var(--text-muted);margin-top:.5rem;font-size:.8rem;font-style:italic}.player-count-selector{grid-template-columns:repeat(4,1fr);gap:.5rem;display:grid}.player-names{flex-direction:column;gap:.5rem;display:flex}.card{cursor:pointer;border:2px solid var(--card-border,var(--border-ornate));background:linear-gradient(135deg,var(--card-bg,#1a1528e6) 0%,#0a0a14f2 100%);border-radius:6px;flex-shrink:0;width:72px;height:104px;transition:all .2s;position:relative;box-shadow:0 2px 8px #0006,inset 0 1px #ffffff0d}.card-sm{width:56px;height:80px}.card-sm .card-inner{padding:3px}.card-sm .card-rank{font-size:.65rem}.card-sm .card-suit-icon{font-size:.55rem}.card-sm .card-emblem{font-size:1.2rem}.card-sm .card-name{font-size:.4rem}.card-playable{border-color:var(--card-glow,var(--gold));box-shadow:0 0 12px var(--card-glow,#d4a01766),0 2px 8px #0006;animation:1.5s ease-in-out infinite cardPulse}@keyframes cardPulse{0%,to{box-shadow:0 0 12px var(--card-glow,#d4a01766)}50%{box-shadow:0 0 20px var(--card-glow,#d4a01799)}}.card-playable:hover{box-shadow:0 0 24px var(--card-glow,#d4a01799);transform:translateY(-8px)scale(1.05)}.card-selected{border-color:var(--rings);transform:translateY(-12px);box-shadow:0 0 20px #ffd70080}.card-disabled{opacity:.5;cursor:not-allowed}.card-disabled:hover{transform:none}.card-ring{box-shadow:0 0 16px #ffd70066,0 0 32px #ffd70026,inset 0 0 12px #ffd7001a;border-color:var(--rings)!important}.card-inner{flex-direction:column;justify-content:space-between;align-items:center;height:100%;padding:4px;display:flex;position:relative}.card-corner{flex-direction:column;align-items:center;line-height:1;display:flex}.card-corner-top{align-self:flex-start}.card-corner-bottom{align-self:flex-end;transform:rotate(180deg)}.card-rank{font-family:var(--font-heading);color:var(--card-color,var(--text-primary));font-size:.8rem;font-weight:700}.card-suit-icon{font-size:.65rem}.card-center{justify-content:center;align-items:center;display:flex;position:relative}.card-emblem{filter:drop-shadow(0 0 4px var(--card-glow,#fff3));font-size:1.5rem}.card-ring-glow{pointer-events:none;background:radial-gradient(circle,#ffd70033,#0000 70%);border-radius:50%;animation:3s ease-in-out infinite ringGlow;position:absolute;inset:-8px}.card-name{font-family:var(--font-body);color:var(--text-secondary);text-align:center;text-overflow:ellipsis;white-space:nowrap;max-width:100%;font-size:.5rem;line-height:1.1;overflow:hidden}.card-back{border-color:var(--border-ornate);background:repeating-linear-gradient(45deg,#3d32504d 0 2px,#0000 2px 8px),linear-gradient(135deg,#1a1528,#0d0a18)}.card-back-design{flex-direction:column;justify-content:center;align-items:center;gap:.5rem;height:100%;display:flex}.card-back-ring{border:2px solid var(--gold);border-radius:50%;width:28px;height:28px;box-shadow:0 0 8px #d4a0174d}.card-back-text{font-family:var(--font-display);color:var(--text-gold);letter-spacing:.2em;font-size:.5rem}.card-mini{font-family:var(--font-heading);font-size:.8rem;font-weight:600}.hand-container{padding:.75rem 0}.hand-label{font-family:var(--font-heading);color:var(--text-gold);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem;font-size:.75rem}.hand-cards{-webkit-overflow-scrolling:touch;scrollbar-width:thin;gap:4px;padding:.5rem 0;display:flex;overflow-x:auto}.hand-cards::-webkit-scrollbar{height:4px}.hand-cards::-webkit-scrollbar-thumb{background:var(--border-ornate);border-radius:2px}.hand-hint{color:var(--text-muted);margin-top:.25rem;font-size:.75rem;font-style:italic}.trick-area{border:1px solid var(--border-ornate);background:linear-gradient(135deg,#1a152899,#12101ecc);border-radius:8px;margin:.75rem 0;padding:1rem}.trick-header{text-align:center;margin-bottom:.75rem}.trick-label{font-family:var(--font-heading);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.1em;font-size:.8rem}.trick-cards{flex-wrap:wrap;justify-content:center;gap:.75rem;display:flex}.trick-slot{flex-direction:column;align-items:center;gap:.25rem;display:flex}.trick-slot-label{font-family:var(--font-heading);color:var(--text-muted);text-transform:uppercase;font-size:.6rem}.trick-slot-empty{justify-content:center;align-items:center;width:56px;height:80px;display:flex}.trick-slot-placeholder{border:2px dashed var(--border-ornate);opacity:.3;border-radius:4px;width:48px;height:72px}.pass-screen{z-index:100;cursor:pointer;background:radial-gradient(at 50% 40%,#1a1528fa,#0a0a14fc);justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.pass-screen-content{text-align:center;flex-direction:column;align-items:center;gap:1.25rem;padding:2rem;display:flex}.pass-ring-icon{margin-bottom:.5rem}.pass-ring{border:3px solid var(--gold);border-radius:50%;width:60px;height:60px;animation:3s ease-in-out infinite ringGlow;box-shadow:0 0 30px #ffd7004d}.pass-title{font-family:var(--font-heading);color:var(--text-gold);text-transform:uppercase;letter-spacing:.1em;font-size:1.5rem}.pass-player-name{font-family:var(--font-display);color:var(--text-primary);font-size:2rem}.pass-characters{flex-direction:column;gap:.25rem;display:flex}.pass-character{font-family:var(--font-body);color:var(--text-secondary);font-size:.9rem;font-style:italic}.pass-ready-btn{margin-top:1rem}.pass-hint{color:var(--text-muted);font-size:.75rem}.pass-undo-btn{margin-top:.75rem}.undo-bar{justify-content:center;padding:.35rem 0;display:flex}.btn-undo{opacity:.85;font-size:.8rem;transition:opacity .15s}.btn-undo:hover{opacity:1}.goal-display{background:var(--bg-card);border:1px solid var(--border-ornate);border-radius:6px;margin-bottom:.5rem;padding:.75rem}.goal-met{border-color:var(--success);background:#2d9d5b1a}.goal-failed{border-color:var(--danger);background:#cc33331a}.goal-character-name{font-family:var(--font-heading);color:var(--text-primary);font-size:.85rem;font-weight:600}.goal-character-title{font-family:var(--font-body);color:var(--text-muted);font-size:.75rem;font-style:italic}.goal-description{color:var(--text-secondary);margin-top:.25rem;font-size:.8rem}.goal-progress{color:var(--text-gold);margin-top:.25rem;font-size:.75rem}.goal-result{font-family:var(--font-heading);text-transform:uppercase;margin-top:.5rem;font-size:.85rem;font-weight:700}.goal-summary{flex-wrap:wrap;justify-content:center;gap:.75rem;padding:.5rem 0;display:flex;overflow-x:auto}.goal-summary-item{background:var(--bg-card);border:1px solid var(--border-ornate);border-radius:4px;flex-direction:column;align-items:center;min-width:60px;padding:.35rem .5rem;display:flex}.goal-summary-name{font-family:var(--font-heading);color:var(--text-secondary);text-transform:uppercase;font-size:.6rem}.goal-summary-tricks{color:var(--text-gold);font-size:.75rem;font-weight:600}.chapter-intro-content{text-align:center;flex-direction:column;align-items:center;gap:1rem;max-width:600px;margin:0 auto;padding:2rem 1rem;display:flex}.chapter-intro-number{font-family:var(--font-heading);color:var(--text-muted);text-transform:uppercase;letter-spacing:.2em;font-size:.85rem}.chapter-intro-title{font-family:var(--font-display);color:var(--text-gold);text-shadow:0 0 20px #d4a01733;font-size:1.75rem;line-height:1.2}.chapter-intro-divider{background:linear-gradient(90deg,transparent,var(--gold),transparent);width:120px;height:2px}.chapter-intro-story{font-family:var(--font-body);color:var(--text-secondary);font-size:1.05rem;font-style:italic;line-height:1.7}.chapter-intro-event{background:var(--bg-card);border:1px solid var(--border-ornate);border-radius:8px;width:100%;padding:1rem}.event-name{font-family:var(--font-heading);color:var(--text-gold);margin-bottom:.5rem;font-size:.9rem}.event-description{color:var(--text-secondary);font-size:.85rem}.event-flavor{color:var(--text-muted);margin-top:.5rem;font-size:.8rem;font-style:italic}.chapter-intro-meta{color:var(--text-muted);gap:.5rem;font-size:.8rem;display:flex}.campaign-progress-bar{background:var(--bg-card);border:1px solid var(--border-ornate);border-radius:4px;height:28px;margin-bottom:1rem;position:relative;overflow:hidden}.campaign-progress-fill{background:linear-gradient(90deg,var(--gold-dark),var(--gold));border-radius:3px;height:100%;transition:width .5s}.campaign-progress-text{font-family:var(--font-heading);color:var(--text-primary);text-transform:uppercase;letter-spacing:.1em;justify-content:center;align-items:center;font-size:.7rem;display:flex;position:absolute;inset:0}.campaign-complete-banner{text-align:center;background:linear-gradient(135deg,#2d9d5b26,#2d9d5b0d);border:1px solid #2d9d5b4d;border-radius:8px;margin-bottom:1rem;padding:1rem}.campaign-complete-banner h3{font-family:var(--font-heading);color:var(--success);font-size:1rem}.campaign-complete-banner p{color:var(--text-secondary);font-size:.85rem}.chapter-list{flex-direction:column;gap:.5rem;padding-bottom:2rem;display:flex}.chapter-card{background:var(--bg-card);border:1px solid var(--border-ornate);cursor:pointer;border-radius:6px;align-items:center;gap:.75rem;padding:.75rem;transition:all .2s;display:flex}.chapter-card:hover:not(.chapter-locked){border-color:var(--gold);box-shadow:0 0 12px #d4a01733}.chapter-completed{background:#2d9d5b0d;border-color:#2d9d5b4d}.chapter-current{border-color:var(--gold);box-shadow:0 0 8px #d4a01733}.chapter-locked{opacity:.4;cursor:not-allowed}.chapter-number{font-family:var(--font-heading);color:var(--text-gold);text-align:center;min-width:32px;font-size:1.1rem;font-weight:700}.chapter-info{flex:1}.chapter-name{font-family:var(--font-heading);color:var(--text-primary);font-size:.85rem}.chapter-meta{color:var(--text-muted);font-size:.7rem}.chapter-threat{color:var(--threat)}.chapter-attempts{color:var(--danger);font-size:.65rem}.chapter-current-badge{font-family:var(--font-heading);color:var(--gold);text-transform:uppercase;letter-spacing:.1em;border:1px solid var(--gold);border-radius:3px;padding:.15rem .4rem;font-size:.6rem}.chapter-lock{font-size:1rem}.setup-info{font-family:var(--font-heading);color:var(--text-secondary);text-align:center;margin-bottom:1rem;font-size:.85rem}.character-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:.75rem;margin-bottom:1.5rem;display:grid}.character-card{background:var(--bg-card);border:2px solid var(--border-ornate);cursor:pointer;border-radius:8px;padding:.75rem;transition:all .2s;position:relative}.character-card:hover{border-color:var(--text-gold)}.character-selected{border-color:var(--gold);background:#d4a0170d;box-shadow:0 0 12px #d4a0174d}.character-required{border-color:#2d9d5b80}.character-race-badge{font-family:var(--font-heading);text-transform:uppercase;letter-spacing:.1em;border-radius:3px;margin-bottom:.25rem;padding:.1rem .4rem;font-size:.55rem;display:inline-block}.race-hobbit{color:var(--hills);background:#8b691433}.race-wizard{color:var(--silver);background:#a8b4c033}.race-elf{color:var(--forests);background:#2d9d5b33}.race-man{color:var(--mountains);background:#6b8db533}.race-dwarf{color:var(--bronze);background:#cd7f3233}.race-other{color:var(--shadows);background:#8b5fbf33}.character-card-name{font-family:var(--font-heading);color:var(--text-primary);font-size:.85rem;font-weight:600}.character-card-title{font-family:var(--font-body);color:var(--text-muted);font-size:.75rem;font-style:italic}.character-card-goal{color:var(--text-secondary);border-top:1px solid var(--border-ornate);margin-top:.5rem;padding-top:.5rem;font-size:.75rem}.character-required-badge{font-family:var(--font-heading);color:var(--success);text-transform:uppercase;border:1px solid var(--success);border-radius:2px;padding:.1rem .3rem;font-size:.5rem;position:absolute;top:.5rem;right:.5rem}.character-assignment{flex-wrap:wrap;gap:.25rem;margin-top:.5rem;display:flex}.setup-content{max-width:600px;margin:0 auto}.setup-characters{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.5rem;margin-bottom:1rem;display:grid}.setup-char-card{background:var(--bg-card);border:1px solid var(--border-ornate);border-radius:6px;padding:.6rem}.setup-char-name{font-family:var(--font-heading);color:var(--text-primary);font-size:.8rem}.setup-char-title{color:var(--text-muted);font-size:.7rem;font-style:italic}.setup-char-goal{color:var(--text-secondary);margin-top:.25rem;font-size:.7rem}.setup-char-cards{color:var(--text-gold);margin-top:.25rem;font-size:.7rem}.setup-message{font-family:var(--font-body);color:var(--text-gold);text-align:center;background:var(--bg-card);border:1px solid var(--border-gold);border-radius:6px;margin-bottom:1rem;padding:1rem;font-size:1rem;font-style:italic}.setup-revealed{margin-bottom:1rem}.setup-revealed h3{font-family:var(--font-heading);color:var(--text-secondary);margin-bottom:.5rem;font-size:.85rem}.setup-revealed-cards{flex-wrap:wrap;gap:.5rem;display:flex}.setup-char-active{border-color:var(--text-gold);box-shadow:0 0 8px #d4a01759}.setup-char-done{opacity:.5}.setup-char-ability{color:var(--text-secondary);margin-top:.25rem;font-size:.65rem}.setup-interactive{background:var(--bg-surface);border:1px solid var(--border-ornate);border-radius:6px;margin-bottom:1rem;padding:.75rem}.setup-hand-label{font-family:var(--font-heading);color:var(--text-primary);margin-bottom:.5rem;font-size:.8rem}.setup-hand-cards{flex-wrap:wrap;gap:.4rem;margin-bottom:.5rem;display:flex}.setup-view-picker{flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem;display:flex}.setup-all-hands{flex-direction:column;gap:.75rem;display:flex}.setup-target-hand{border-top:1px solid var(--border-ornate);padding-top:.5rem}.suit-picker{flex-wrap:wrap;justify-content:center;gap:.5rem;display:flex}.btn-suit{font-family:var(--font-heading);cursor:pointer;border:2px solid;border-radius:6px;padding:.6rem 1.2rem;font-size:.9rem;font-weight:600;transition:transform .15s,box-shadow .15s}.btn-suit:hover{transform:scale(1.06)}.suit-hills{border-color:var(--hills);color:var(--hills);background:#d4a01726}.suit-mountains{border-color:var(--mountains);color:var(--mountains);background:#6b8db526}.suit-forests{border-color:var(--forests);color:var(--forests);background:#2d9d5b26}.suit-shadows{border-color:var(--shadows);color:var(--shadows);background:#8b5fbf26}.gameplay{flex-direction:column;padding:.5rem;display:flex}.gameplay-header{background:var(--bg-card);border:1px solid var(--border-ornate);border-radius:6px;justify-content:space-between;align-items:center;margin-bottom:.5rem;padding:.5rem;display:flex}.gameplay-chapter{font-family:var(--font-heading);color:var(--text-gold);font-size:.75rem}.gameplay-trick-info{font-family:var(--font-heading);color:var(--text-secondary);font-size:.75rem}.gameplay-trump{color:var(--forests);font-size:.7rem}.gameplay-ring-warning{color:var(--threat);font-size:.65rem}.gameplay-event-bar{color:var(--text-muted);text-align:center;padding:.25rem;font-size:.7rem;font-style:italic}.current-player-indicator{text-align:center;border:1px solid var(--border-gold);background:linear-gradient(135deg,#d4a0171a,#d4a01705);border-radius:6px;margin:.5rem 0;padding:.5rem}.current-player-name{font-family:var(--font-heading);color:var(--text-gold);font-size:1rem}.current-player-owner{color:var(--text-muted);margin-left:.5rem;font-size:.8rem}.current-player-goal{color:var(--text-secondary);font-size:.75rem;font-style:italic}.solo-hands{flex-direction:column;gap:.25rem;display:flex}.trick-result-overlay{background:radial-gradient(at 50% 40%,#1a1528fa,#0a0a14fc);justify-content:center;align-items:center;display:flex}.trick-result-content{text-align:center;flex-direction:column;align-items:center;gap:1rem;max-width:500px;padding:1.5rem;display:flex}.trick-result-title{font-family:var(--font-heading);color:var(--text-gold);font-size:1.2rem}.trick-result-cards{flex-wrap:wrap;justify-content:center;gap:.75rem;display:flex}.trick-result-card{flex-direction:column;align-items:center;gap:.25rem;display:flex}.trick-result-winner{position:relative}.trick-result-winner:after{content:"u2B50";font-size:1rem;position:absolute;top:-8px;right:-8px}.trick-result-player{font-family:var(--font-heading);color:var(--text-muted);text-transform:uppercase;font-size:.6rem}.trick-winner-announcement{align-items:center;gap:.5rem;display:flex}.trick-winner-label{font-family:var(--font-heading);color:var(--text-secondary);text-transform:uppercase;font-size:.8rem}.trick-winner-name{font-family:var(--font-heading);color:var(--text-gold);font-size:1.1rem;font-weight:700}.chapter-result{flex-direction:column;gap:1rem;max-width:600px;margin:0 auto;padding:1.5rem 1rem;display:flex}.result-banner{text-align:center;border-radius:8px;padding:1.5rem}.result-victory{background:linear-gradient(135deg,#2d9d5b26,#d4a0171a);border:1px solid #2d9d5b4d}.result-defeat{background:linear-gradient(135deg,#cc333326,#8b5fbf1a);border:1px solid #cc33334d}.result-icon{margin-bottom:.5rem;font-size:2.5rem}.result-title{font-family:var(--font-display);color:var(--text-gold);font-size:1.5rem}.result-subtitle{font-family:var(--font-body);color:var(--text-secondary);margin-top:.5rem;font-size:.9rem}.result-chapter-info{text-align:center}.result-chapter-number{font-family:var(--font-heading);color:var(--text-muted);text-transform:uppercase;font-size:.75rem;display:block}.result-chapter-name{font-family:var(--font-heading);color:var(--text-primary);font-size:1rem}.result-stats{justify-content:center;gap:2rem;display:flex}.result-stat{text-align:center}.stat-label{color:var(--text-muted);text-transform:uppercase;font-size:.7rem;display:block}.stat-value{font-family:var(--font-heading);color:var(--text-gold);font-size:1.5rem}.result-goals-title{font-family:var(--font-heading);color:var(--text-secondary);margin-bottom:.5rem;font-size:.9rem}.result-actions{flex-direction:column;gap:.5rem;margin-top:1rem;display:flex}.save-slots{flex-direction:column;gap:.75rem;display:flex}.save-slot{background:var(--bg-card);border:1px solid var(--border-ornate);cursor:pointer;border-radius:6px;align-items:center;gap:.75rem;padding:.75rem;transition:all .2s;display:flex}.save-slot:hover{border-color:var(--gold)}.save-slot-info{flex:1}.save-slot-name{font-family:var(--font-heading);color:var(--text-primary);font-size:.9rem}.save-slot-details{color:var(--text-secondary);font-size:.75rem}.save-slot-sep{margin:0 .25rem}.save-slot-progress{color:var(--text-gold);font-size:.7rem}.save-slot-date{color:var(--text-muted);font-size:.65rem}.empty-state{text-align:center;color:var(--text-muted);padding:3rem 1rem}.empty-state p{margin-bottom:1rem;font-style:italic}.rules-content{max-width:640px;margin:0 auto;padding-bottom:2rem}.rules-section{margin-bottom:1.5rem}.rules-section h3{font-family:var(--font-heading);color:var(--text-gold);border-bottom:1px solid var(--border-ornate);margin-bottom:.5rem;padding-bottom:.25rem;font-size:1rem}.rules-section p,.rules-section li{font-family:var(--font-body);color:var(--text-secondary);font-size:.95rem;line-height:1.7}.rules-section ul,.rules-section ol{margin-top:.5rem;padding-left:1.5rem}.rules-section li{margin-bottom:.25rem}.rules-suit{padding:0 .25rem;font-weight:600}.rules-suit.hills{color:var(--hills)}.rules-suit.mountains{color:var(--mountains)}.rules-suit.forests{color:var(--forests)}.rules-suit.shadows{color:var(--shadows)}.rules-suit.rings{color:var(--rings)}.text-green-400{color:#4ade80}.text-red-400{color:#f87171}@media(min-width:768px){.screen{padding:1.5rem 2rem}.menu-title-the{font-size:2rem}.menu-title-sub{font-size:1.3rem}.menu-ring-container,.menu-ring{width:100px;height:100px}.card{width:88px;height:128px}.card-sm{width:68px;height:96px}.card-rank{font-size:1rem}.card-emblem{font-size:2rem}.card-name{font-size:.6rem}.chapter-intro-title{font-size:2.25rem}.chapter-intro-story{font-size:1.1rem}.character-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}}@media(min-width:1024px){.card{width:100px;height:144px}.card-rank{font-size:1.1rem}.card-emblem{font-size:2.2rem}.card-name{font-size:.65rem}.hand-cards{gap:6px}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.screen{animation:.3s ease-out fadeIn}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.chapter-card,.character-card,.save-slot{animation:.3s ease-out backwards slideUp}.chapter-card:first-child{animation-delay:50ms}.chapter-card:nth-child(2){animation-delay:.1s}.chapter-card:nth-child(3){animation-delay:.15s}.chapter-card:nth-child(4){animation-delay:.2s}.chapter-card:nth-child(5){animation-delay:.25s}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}
