@import"https://fonts.googleapis.com/css2?family=Cinzel:wght@400;500;600;700&family=Inter:wght@400;500;600;700&display=swap";:root{--bg-deep: #0c1612;--bg-panel: #18241e;--bg-elevated: #25382c;--border-subtle: #3a5a48;--border-accent: #c8a857;--leaf-glow: #e8c970;--text-primary: #f4ecd6;--text-muted: #8a9a85;--text-accent: #c8a857;--state-hope: #4a8a5a;--state-fear: #9a5a6a;--state-success: #5a9a5a;--state-danger: #b85a4a;--state-disabled: #3a4a3a;--font-display: "Cinzel", "Georgia", serif;--font-body: "Inter", "Segoe UI", sans-serif;--fs-h1: 28px;--fs-h2: 20px;--fs-h3: 16px;--fs-body: 14px;--fs-small: 12px;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--shadow-panel: 0 8px 24px rgba(0, 0, 0, .6);--shadow-glow-accent: 0 0 16px rgba(200, 160, 74, .4);--shadow-glow-leaf: 0 0 24px rgba(127, 185, 80, .55);--z-overlay: 1000;--z-modal: 1100}.dom-overlay,.dom-overlay *,.dom-overlay *:before,.dom-overlay *:after{box-sizing:border-box;margin:0;padding:0}.dom-overlay{font-family:var(--font-body);color:var(--text-primary);font-size:var(--fs-body);line-height:1.5}.dom-overlay h1,.dom-overlay h2,.dom-overlay h3{font-family:var(--font-display);color:var(--text-accent);line-height:1.2}.dom-overlay h1{font-size:var(--fs-h1);font-weight:700}.dom-overlay h2{font-size:var(--fs-h2);font-weight:700}.dom-overlay h3{font-size:var(--fs-h3);font-weight:600}.dom-overlay p{color:var(--text-primary)}.dom-overlay button{cursor:pointer;font-family:inherit;font-size:inherit;border:none;background:none;color:inherit}.dom-overlay button:focus-visible{outline:2px solid var(--border-accent);outline-offset:2px}.dom-overlay button:disabled{cursor:not-allowed;color:var(--state-disabled)}.dom-overlay{position:absolute;top:0;left:0;width:100%;height:100%;z-index:var(--z-overlay);display:flex;align-items:center;justify-content:center;padding:var(--space-md);background:#000000b3;font-family:var(--font-body);color:var(--text-primary);animation:dom-overlay-fade .25s ease-out}.dom-overlay,.dom-overlay *,.dom-overlay *:before,.dom-overlay *:after{box-sizing:border-box}@keyframes dom-overlay-fade{0%{opacity:0}to{opacity:1}}.dom-fullscreen{position:absolute;top:0;left:0;width:100%;height:100%;z-index:var(--z-overlay);display:flex;flex-direction:column;background:radial-gradient(ellipse at 50% 0%,rgba(200,160,74,.08) 0%,transparent 60%),var(--bg-deep);font-family:var(--font-body);color:var(--text-primary);animation:dom-overlay-fade .4s ease-out}.dom-fullscreen,.dom-fullscreen *,.dom-fullscreen *:before,.dom-fullscreen *:after{box-sizing:border-box}.dom-panel{position:relative;background:linear-gradient(180deg,var(--bg-elevated) 0%,var(--bg-panel) 100%);border:1px solid var(--border-accent);border-radius:var(--radius-lg);box-shadow:inset 0 1px #ffffff0a,0 16px 40px #000000b3;padding:var(--space-lg);max-width:90vw;max-height:90vh;display:flex;flex-direction:column;gap:var(--space-md);animation:dom-panel-in .3s ease-out}@keyframes dom-panel-in{0%{transform:translateY(10px);opacity:0}to{transform:translateY(0);opacity:1}}.dom-body-overlay .dom-panel{transform:scale(var(--ui-scale, 1));transform-origin:center center;animation:dom-overlay-fade .25s ease-out}.dom-panel__header{text-align:center;padding-bottom:var(--space-sm);border-bottom:1px solid var(--border-subtle);position:relative}.dom-panel__title{font-family:var(--font-display);font-size:22px;font-weight:700;color:var(--text-accent);letter-spacing:4px;text-transform:uppercase;text-shadow:0 0 16px rgba(200,160,74,.3),0 2px 6px rgba(0,0,0,.8)}.dom-panel__subtitle{margin-top:4px;font-size:var(--fs-small);color:var(--text-muted);font-style:italic;letter-spacing:1px}.dom-panel__close{position:absolute;top:0;right:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-muted);font-size:18px;cursor:pointer;transition:border-color .15s ease,color .15s ease}.dom-panel__close:hover{border-color:var(--border-accent);color:var(--text-accent)}.dom-panel__body{display:flex;flex-direction:column;gap:var(--space-md);overflow-y:auto;scrollbar-width:none}.dom-panel__body::-webkit-scrollbar{display:none}.dom-section__title{font-family:var(--font-display);font-size:14px;font-weight:700;color:var(--text-accent);letter-spacing:2px;text-transform:uppercase;padding-bottom:6px;border-bottom:1px solid color-mix(in srgb,var(--border-accent) 45%,transparent)}.dom-section__desc{margin-top:4px;font-size:var(--fs-small);color:var(--text-muted);line-height:1.4;font-style:italic}.dom-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;background:#0000004d;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font-display);font-size:13px;font-weight:600;letter-spacing:1px;text-transform:uppercase;cursor:pointer;transition:border-color .15s ease,background .15s ease,transform .1s ease}.dom-btn:hover:not([data-disabled=true]){border-color:var(--border-accent);background:#00000080}.dom-btn:active:not([data-disabled=true]){transform:translateY(1px)}.dom-btn[data-disabled=true]{opacity:.4;cursor:not-allowed}.dom-btn--primary{background:linear-gradient(180deg,#d8b260 0%,var(--border-accent) 50%,#a08038 100%);border-color:#8a6a2a;color:var(--bg-deep);box-shadow:inset 0 1px #fff6,0 4px 12px #00000080}.dom-btn--primary:hover:not([data-disabled=true]){border-color:#8a6a2a;box-shadow:inset 0 1px #fff6,0 6px 18px #0000008c,0 0 24px #c8a04a66}.dom-btn--success{border-color:#6abf6a66;color:var(--state-success)}.dom-btn--success:hover:not([data-disabled=true]){border-color:var(--state-success);background:#6abf6a1f}.dom-resource-row{display:flex;flex-wrap:wrap;justify-content:center;gap:4px 18px;font-size:11px;color:var(--text-muted);letter-spacing:.8px;text-transform:uppercase}.dom-resource-row strong{color:var(--text-accent);font-weight:700}.dom-tag{display:inline-block;padding:1px 6px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;border-radius:3px;background:#ffffff0f;border:1px solid var(--border-subtle);color:var(--text-muted)}.dom-tag--common{color:var(--text-muted);border-color:#9a958366}.dom-tag--uncommon{color:var(--state-success);border-color:#6abf6a66}.dom-tag--rare{color:var(--text-accent);border-color:#c8a04a80}.dom-tag--epic{color:#c694e8;border-color:#a855f780}.dom-leadership{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:var(--space-md);background:#080c14b8;backdrop-filter:blur(2px);font-family:var(--font-body);color:var(--text-primary);animation:dom-overlay-fade .25s ease-out}.dom-leadership__card{max-width:30rem;display:flex;flex-direction:column;gap:var(--space-md);text-align:center;padding:var(--space-lg);background:linear-gradient(180deg,var(--bg-elevated) 0%,var(--bg-panel) 100%);border:1px solid var(--border-accent);border-radius:var(--radius-lg);box-shadow:inset 0 1px #ffffff0a,0 16px 40px #000000b3}.dom-leadership__title{font-family:var(--font-display);font-size:20px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--text-accent);text-shadow:0 0 16px rgba(200,160,74,.3)}.dom-leadership__text{font-size:var(--fs-small);color:var(--text-muted);line-height:1.5}.dom-leadership__btn{align-self:center;padding:10px 22px;background:linear-gradient(180deg,#d8b260 0%,var(--border-accent) 50%,#a08038 100%);border:1px solid #8a6a2a;border-radius:var(--radius-sm);color:var(--bg-deep);font-family:var(--font-display);font-size:14px;font-weight:700;letter-spacing:1px;text-transform:uppercase;cursor:pointer;box-shadow:inset 0 1px #fff6,0 4px 12px #00000080;transition:box-shadow .15s ease,transform .1s ease}.dom-leadership__btn:hover{box-shadow:inset 0 1px #fff6,0 6px 18px #0000008c,0 0 24px #c8a04a66}.dom-leadership__btn:active{transform:translateY(1px)}.cc,.cc *,.cc *:before,.cc *:after{box-sizing:border-box}.cc{position:absolute;top:0;left:0;width:100%;height:100%;z-index:var(--z-overlay);display:flex;flex-direction:column;gap:var(--space-md);padding:var(--space-md) var(--space-lg);background:radial-gradient(ellipse at 50% 0%,rgba(200,160,74,.08) 0%,transparent 60%),radial-gradient(ellipse at 50% 100%,rgba(74,144,200,.05) 0%,transparent 50%),var(--bg-deep);font-family:var(--font-body);color:var(--text-primary);animation:cc-fade-in .6s ease-out}@keyframes cc-fade-in{0%{opacity:0}to{opacity:1}}.cc__header{text-align:center;position:relative;padding:var(--space-xs) var(--space-2xl);flex-shrink:0}.cc__header:before,.cc__header:after{content:"";position:absolute;top:50%;width:80px;height:1px;background:linear-gradient(to right,transparent,var(--border-accent) 40%,var(--border-accent) 60%,transparent);opacity:.6}.cc__header:before{left:calc(50% - 200px)}.cc__header:after{left:calc(50% + 120px)}.cc__title{font-family:var(--font-display);font-size:24px;font-weight:700;color:var(--text-accent);text-transform:uppercase;letter-spacing:4px;text-shadow:0 0 20px rgba(200,160,74,.4),0 2px 8px rgba(0,0,0,.8)}.cc__subtitle{margin-top:2px;color:var(--text-muted);font-size:var(--fs-small);font-style:italic;letter-spacing:1px}.cc__body,.cc__cards{flex:1;display:flex;gap:var(--space-lg);align-items:stretch;min-height:0}.cc__card{flex:1 1 0;min-width:0;display:flex;flex-direction:column;gap:var(--space-sm);padding:var(--space-md);cursor:pointer;position:relative;background:linear-gradient(180deg,var(--bg-elevated) 0%,var(--bg-panel) 100%);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);box-shadow:inset 0 1px #ffffff0a,0 8px 24px #00000080;transition:border-color .2s ease,box-shadow .3s ease;animation:cc-card-in .5s ease-out backwards}.cc__card:nth-child(1){animation-delay:.05s}.cc__card:nth-child(2){animation-delay:.15s}.cc__card:nth-child(3){animation-delay:.25s}@keyframes cc-card-in{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.cc__card:before,.cc__card:after{content:"";position:absolute;width:18px;height:18px;border:1px solid var(--border-accent);opacity:0;transition:opacity .25s ease;pointer-events:none}.cc__card:before{top:-1px;left:-1px;border-right:none;border-bottom:none;border-top-left-radius:var(--radius-lg)}.cc__card:after{bottom:-1px;right:-1px;border-left:none;border-top:none;border-bottom-right-radius:var(--radius-lg)}.cc__card:hover{border-color:#c8a04a66}.cc__card:hover:before,.cc__card:hover:after{opacity:.5}.cc__card.is-selected{border-color:var(--border-accent);box-shadow:inset 0 1px #c8a04a26,0 0 0 1px #c8a04a66,0 0 24px #c8a04a40,0 16px 40px #000000b3}.cc__card.is-selected:before,.cc__card.is-selected:after{opacity:1}.cc__card-head{text-align:center;padding-bottom:var(--space-sm);border-bottom:1px solid var(--border-subtle)}.cc__class-name{font-family:var(--font-display);font-size:20px;font-weight:700;color:var(--text-accent);letter-spacing:2px;text-transform:uppercase;text-shadow:0 2px 6px rgba(0,0,0,.6)}.cc__card.is-selected .cc__class-name{text-shadow:0 0 16px rgba(200,160,74,.5),0 2px 6px rgba(0,0,0,.8)}.cc__class-desc{margin-top:2px;color:var(--text-muted);font-size:11px;line-height:1.35;font-style:italic}.cc__stats{margin-top:var(--space-sm);display:flex;flex-wrap:wrap;justify-content:center;gap:4px 10px;font-size:11px;color:var(--text-muted);letter-spacing:.8px;text-transform:uppercase}.cc__stat.is-key{color:var(--text-accent);font-weight:700}.cc__domains{display:flex;flex-direction:column;gap:6px;flex:1;min-height:0;overflow-y:auto;scrollbar-width:none}.cc__domains::-webkit-scrollbar{display:none}.cc__domain{display:block;background:var(--bg-deep);border:1px solid var(--border-subtle);border-radius:var(--radius-md);cursor:pointer;position:relative;overflow:hidden;transition:background .2s ease,border-color .2s ease;flex-shrink:0}.cc__domain:before{content:"";position:absolute;top:0;bottom:0;left:0;width:3px;background:var(--border-accent);transform:scaleY(0);transition:transform .25s ease;transform-origin:center}.cc__domain:hover{border-color:#c8a04a80;background:var(--bg-panel)}.cc__domain:hover:before{transform:scaleY(1)}.cc__domain.is-selected{background:linear-gradient(180deg,rgba(200,160,74,.12) 0%,var(--bg-deep) 100%);border-color:var(--border-accent);box-shadow:inset 0 0 12px #c8a04a1a,0 0 16px #c8a04a26}.cc__domain.is-selected:before{transform:scaleY(1);width:4px}.cc__domain-head{display:flex;flex-direction:column;gap:2px;padding:var(--space-sm) var(--space-md)}.cc__domain-name{font-family:var(--font-display);font-weight:600;font-size:var(--fs-body);letter-spacing:1.5px;color:var(--text-primary)}.cc__domain.is-selected .cc__domain-name{color:var(--text-accent)}.cc__domain-tagline{font-size:11px;color:var(--text-muted);line-height:1.3}.cc__domain-stat{font-size:10px;color:var(--text-accent);letter-spacing:.8px;text-transform:uppercase}.cc__domain-deck{display:flex;flex-direction:column;gap:3px;padding:0 var(--space-sm);max-height:0;opacity:0;transition:max-height .35s ease,opacity .25s ease,padding .35s ease}.cc__domain.is-selected .cc__domain-deck{max-height:700px;opacity:1;padding:0 var(--space-sm) var(--space-sm)}.cc__chip{display:flex;flex-direction:column;gap:2px;padding:5px 8px;background:#00000059;border:1px solid var(--border-subtle);border-radius:var(--radius-sm)}.cc__chip-name-row{display:flex;align-items:baseline;gap:6px}.cc__chip-name{flex:1;font-family:var(--font-display);font-weight:600;font-size:12px;color:var(--text-primary);letter-spacing:.3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cc__chip-count{font-family:var(--font-display);font-weight:700;font-size:11px;color:var(--text-accent);flex-shrink:0}.cc__chip-meta{display:flex;flex-wrap:wrap;align-items:center;gap:2px 8px;font-size:10px;color:var(--text-muted)}.cc__chip-kind{text-transform:uppercase;letter-spacing:.8px}.cc__chip-cost{letter-spacing:.3px}.cc__chip-formula{display:inline;color:var(--text-primary);letter-spacing:.3px}.cc__formula-label{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;margin-right:2px}.cc__num,.cc__dice{font-family:var(--font-display);font-weight:700;font-size:12px;color:var(--text-primary)}.cc__dice-range{font-family:var(--font-body);font-size:9px;color:var(--text-muted);margin-left:2px;letter-spacing:0}.cc__stat-ref{font-family:var(--font-display);font-weight:700;font-size:11px;color:var(--text-accent);letter-spacing:.5px}.cc__sep{color:var(--text-muted);opacity:.4;margin:0 4px}.cc__cta{flex:0 0 240px;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:var(--space-md)}.cc__confirm{position:relative;padding:var(--space-md) var(--space-lg);width:100%;font-family:var(--font-display);font-size:16px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--bg-deep);background:linear-gradient(180deg,#d8b260 0%,var(--border-accent) 50%,#a08038 100%);border:1px solid #8a6a2a;border-radius:var(--radius-md);box-shadow:inset 0 1px #fff6,inset 0 -2px 4px #0003,0 4px 12px #00000080;cursor:pointer;opacity:.5;filter:saturate(.4);transition:opacity .3s ease,filter .3s ease,transform .1s ease,box-shadow .25s ease}.cc:has(.cc__card.is-selected):has(.cc__domain.is-selected) .cc__confirm{opacity:1;filter:saturate(1);box-shadow:inset 0 1px #fff6,inset 0 -2px 4px #0003,0 4px 12px #00000080,0 0 24px #c8a04a66;animation:cc-confirm-pulse 2.4s ease-in-out infinite}.cc:has(.cc__card.is-selected):has(.cc__domain.is-selected) .cc__confirm:hover{transform:translateY(-2px);box-shadow:inset 0 1px #fff6,inset 0 -2px 4px #0003,0 8px 20px #0009,0 0 36px #c8a04a8c}.cc:has(.cc__card.is-selected):has(.cc__domain.is-selected) .cc__confirm:active{transform:translateY(0)}@keyframes cc-confirm-pulse{0%,to{box-shadow:inset 0 1px #fff6,inset 0 -2px 4px #0003,0 4px 12px #00000080,0 0 24px #c8a04a66}50%{box-shadow:inset 0 1px #fff6,inset 0 -2px 4px #0003,0 4px 12px #00000080,0 0 32px #c8a04a99}}.cc__hint{color:var(--text-muted);font-size:var(--fs-small);font-style:italic;letter-spacing:1px;text-align:center;opacity:.7}.dom-panel:has(.forge__placeholder){min-width:480px;max-width:600px}.forge__placeholder{font-size:var(--fs-small);color:var(--text-muted);line-height:1.5;text-align:center;font-style:italic}.forge__prices{display:flex;flex-direction:column;gap:4px;list-style:none}.forge__price-row{display:grid;grid-template-columns:120px 50px 1fr;align-items:center;gap:8px;padding:4px 8px;background:#00000040;border:1px solid var(--border-subtle);border-radius:var(--radius-sm)}.forge__price-value{font-family:var(--font-body);font-weight:700;font-size:14px;color:var(--text-accent);text-align:right}.forge__price-unit{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px}.forge__examples{font-size:var(--fs-small);color:var(--text-muted);text-align:center}.forge__examples em{color:var(--text-primary);font-style:italic}.forge__actions{display:flex;justify-content:center;margin-top:var(--space-sm)}.forge__card{display:flex;flex-direction:row;align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-md);background:#0000004d;border:1px solid var(--border-subtle);border-radius:var(--radius-md);box-shadow:0 2px 6px #0000004d;transition:border-color .15s ease,box-shadow .2s ease}.forge__card:hover{border-color:#c8a04a66;box-shadow:0 4px 12px #00000080,0 0 12px #c8a04a1f}.forge__card .dom-btn{flex:0 0 auto}.forge__card-info{display:flex;align-items:center;gap:var(--space-sm);flex:1;min-width:0}.forge__card-name{font-family:var(--font-display);font-weight:600;font-size:14px;color:var(--text-primary);letter-spacing:.5px}.forge__card-meta{font-size:11px;color:var(--text-muted);letter-spacing:.3px}.dom-panel:has(.temple__section){min-width:560px;max-width:720px}.temple__section{display:flex;flex-direction:column;gap:var(--space-sm)}.temple__action-row{display:flex;justify-content:flex-start}.temple__cost{color:var(--text-muted);font-weight:600;font-size:10px;letter-spacing:.5px}.temple__stats{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}.temple__stat-btn{flex-direction:column;padding:8px 6px;gap:4px;letter-spacing:.5px}.temple__stat-label{font-size:11px;text-transform:uppercase;color:var(--text-muted)}.temple__stat-progress{font-family:var(--font-display);font-size:13px;letter-spacing:.3px;color:var(--text-primary)}.temple__stat-progress strong{font-weight:700;color:var(--text-primary)}.temple__stat-progress em{font-style:normal;font-weight:700;color:var(--text-accent)}.dom-panel:has(.guild__grid){min-width:700px;max-width:880px}.guild__grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-sm)}.guild__card{display:flex;flex-direction:column;gap:6px;padding:var(--space-md);background:#0000004d;border:1px solid var(--border-subtle);border-radius:var(--radius-md);box-shadow:0 2px 6px #0000004d;transition:border-color .15s ease,box-shadow .2s ease}.guild__card:hover{border-color:#c8a04a66}.guild__card-head{display:flex;align-items:baseline;justify-content:space-between;gap:8px}.guild__card-name{font-family:var(--font-display);font-size:14px;font-weight:700;color:var(--text-primary);letter-spacing:1px;text-transform:uppercase}.guild__card-level{font-family:var(--font-display);font-size:12px;color:var(--text-accent);letter-spacing:1px}.guild__card-desc{font-size:11px;color:var(--text-muted);line-height:1.4;flex:1}.guild__card-action{margin-top:4px}.dom-panel:has(.tavern__grid){min-width:760px;max-width:1000px}.tavern__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:var(--space-md)}.tavern__empty{font-size:var(--fs-small);color:var(--text-muted);text-align:center;font-style:italic}.tavern__card{display:flex;flex-direction:column;gap:6px;padding:var(--space-sm);background:#0000004d;border:1px solid var(--border-subtle);border-radius:var(--radius-md);box-shadow:0 2px 6px #0000004d;transition:transform .15s ease,border-color .15s ease,box-shadow .2s ease}.tavern__card:hover{transform:translateY(-2px);border-color:#c8a04a66;box-shadow:0 4px 12px #00000080,0 0 12px #c8a04a26}.tavern__card-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.tavern__card-name{font-family:var(--font-display);font-size:14px;font-weight:700;color:var(--text-primary);letter-spacing:1px;text-transform:uppercase}.tavern__card-costs{display:flex;gap:12px;font-size:10px;color:var(--text-muted);letter-spacing:.5px;text-transform:uppercase}.tavern__card-costs strong{font-family:var(--font-display);color:var(--text-accent);font-weight:700;font-size:13px}.tavern__variant{font-size:11px;line-height:1.4;color:var(--text-primary)}.tavern__variant span{display:inline-block;margin-right:4px;font-family:var(--font-display);font-weight:700;letter-spacing:.8px;text-transform:uppercase}.tavern__variant--hope span{color:var(--state-success)}.tavern__variant--fear span{color:var(--state-fear)}.tavern__buy{margin-top:4px}.dom-panel:has(.deck-modal__grid){min-width:760px;max-width:1100px}.dom-panel:has(.deck-modal__grid) .dom-panel__body{max-height:70vh;overflow-y:auto}.deck-modal__hint{font-size:var(--fs-small);color:var(--text-muted);font-style:italic;margin-bottom:var(--space-sm)}.deck-modal__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--space-sm)}.deck-card{display:flex;flex-direction:column;gap:6px;padding:var(--space-sm);background:#0000004d;border:1px solid var(--border-subtle);border-radius:var(--radius-md)}.deck-card__head{display:flex;align-items:center;justify-content:space-between;gap:8px}.deck-card__name{font-family:var(--font-display);font-size:14px;font-weight:700;color:var(--text-primary);letter-spacing:1px;text-transform:uppercase}.deck-card__count{display:inline-block;margin-left:6px;padding:1px 6px;border-radius:8px;background:#c8a04a2e;color:var(--text-accent);font-size:11px}.deck-card__costs{display:flex;gap:12px;font-size:10px;color:var(--text-muted);letter-spacing:.5px;text-transform:uppercase}.deck-card__costs strong{font-family:var(--font-display);color:var(--text-accent);font-weight:700;font-size:13px}.deck-card__variant{font-size:11px;line-height:1.4;color:var(--text-primary)}.deck-card__variant span{display:inline-block;margin-right:4px;font-family:var(--font-display);font-weight:700;letter-spacing:.8px;text-transform:uppercase}.deck-card__variant--hope span{color:var(--state-success)}.deck-card__variant--fear span{color:var(--state-fear)}.dom-panel:has(.deck-mgr){min-width:720px;max-width:1000px;width:88vw}.deck-mgr__counter{font-family:var(--font-display);font-size:16px;font-weight:700;letter-spacing:1px;text-transform:uppercase;margin-bottom:var(--space-sm)}.deck-mgr__counter.is-full{color:var(--state-success)}.deck-mgr__counter.is-warn{color:var(--text-accent)}.deck-mgr__hint{font-size:var(--fs-small);color:var(--text-muted);font-style:italic;margin-bottom:var(--space-sm)}.deck-mgr__cols{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md);height:60vh}.deck-mgr__col{display:flex;flex-direction:column;min-height:0;border:1px solid var(--border-subtle);border-radius:var(--radius-md);background:#00000040}.deck-mgr__col-title,.deck-mgr__tabs{padding:var(--space-sm);border-bottom:1px solid var(--border-subtle)}.deck-mgr__col-title{font-family:var(--font-display);font-size:13px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--text-accent)}.deck-mgr__tabs{display:flex;gap:6px}.deck-tab{flex:1;padding:6px 8px;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);background:transparent;color:var(--text-muted);font-family:var(--font-display);font-size:12px;letter-spacing:.5px;text-transform:uppercase;cursor:pointer}.deck-tab.is-active{background:#c8a04a2e;color:var(--text-accent);border-color:var(--border-accent)}.deck-mgr__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(148px,168px));justify-content:center;gap:var(--space-md);padding:var(--space-md);align-content:start;overflow-y:auto;min-height:0;flex:1}.deck-pick{cursor:pointer;transition:transform .1s,opacity .1s}.deck-pick:hover{transform:translateY(-3px)}.deck-pick.is-disabled{opacity:.4;pointer-events:none}.deck-mgr__empty{color:var(--text-muted);font-style:italic;padding:var(--space-md)}.game-card{position:relative;display:flex;flex-direction:column;gap:7px;width:100%;color:var(--text-primary);--domain-accent: var(--border-subtle)}.game-card--d-steel{--domain-accent: #8fa3b8}.game-card--d-blood{--domain-accent: #c1556a}.game-card--d-light{--domain-accent: #e0c266}.game-card--d-darkness{--domain-accent: #9a7fcf}.game-card--d-nature{--domain-accent: #74b35e}.game-card--d-fire{--domain-accent: #db7b42}.game-card--d-ice{--domain-accent: #5ab8d0}.game-card--d-shadow{--domain-accent: #8475a8}.game-card--d-class{--domain-accent: #c8a857}.game-card--d-common{--domain-accent: #7d8c79}.game-card__frame{position:relative;width:100%;aspect-ratio:5 / 7;display:flex;flex-direction:column;overflow:hidden;border-radius:10px;border:1.5px solid color-mix(in srgb,var(--domain-accent) 72%,#000);background:linear-gradient(180deg,var(--bg-elevated) 0%,var(--bg-panel) 100%);box-shadow:inset 0 1px #ffffff0d,0 4px 14px #00000073;transition:box-shadow .16s ease,border-color .16s ease}.game-card__frame:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--domain-accent);opacity:.9}.deck-pick:hover .game-card__frame,.game-card__frame:hover{border-color:var(--domain-accent);box-shadow:inset 0 1px #ffffff12,0 8px 20px #0000008c,0 0 16px color-mix(in srgb,var(--domain-accent) 45%,transparent)}.game-card__head{display:flex;flex-direction:column;gap:4px;padding:9px 10px 8px;background:#00000038;border-bottom:1px solid color-mix(in srgb,var(--domain-accent) 35%,transparent)}.game-card__meta{display:flex;align-items:center;gap:6px;padding-right:18px}.game-card__domain{flex:0 0 auto;font-family:var(--font-display);font-size:9px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;padding:1px 8px;border-radius:999px;color:var(--bg-deep);background:var(--domain-accent);white-space:nowrap}.game-card__rarity{margin-left:auto;flex:0 1 auto;font-family:var(--font-display);font-size:8px;font-weight:700;letter-spacing:.2px;text-transform:uppercase;color:var(--text-muted);white-space:nowrap}.game-card--r-uncommon .game-card__rarity{color:var(--state-success)}.game-card--r-rare .game-card__rarity{color:var(--text-accent)}.game-card--r-epic .game-card__rarity{color:#c694e8}.game-card__name{font-family:var(--font-display);font-size:13.5px;font-weight:700;line-height:1.14;color:var(--text-primary);text-shadow:0 1px 2px rgba(0,0,0,.6);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.game-card__body{flex:1;display:flex;flex-direction:column;min-height:0}.game-card__section{flex:1;display:flex;flex-direction:column;justify-content:center;gap:2px;padding:6px 10px;min-height:0}.game-card__section--hope{background:#4a8a5a1a}.game-card__section--fear{background:#9a5a6a1a;border-top:1px dashed color-mix(in srgb,var(--border-accent) 30%,transparent)}.game-card__section-label{font-family:var(--font-display);font-size:8.5px;font-weight:700;letter-spacing:1.4px;text-transform:uppercase}.game-card__section--hope .game-card__section-label{color:#a8c896}.game-card__section--fear .game-card__section-label{color:#c9889a}.game-card__formula{font-family:var(--font-body);font-size:11px;line-height:1.3;font-weight:500;color:var(--text-primary);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.game-card__footer{display:flex;align-items:center;justify-content:center;gap:6px;padding:6px 8px;background:#00000057;border-top:1px solid var(--border-subtle)}.game-card__cost-label{font-family:var(--font-display);font-size:9px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:var(--text-muted)}.game-card__cost-value{font-family:var(--font-display);font-size:14px;font-weight:700;color:var(--text-accent)}.game-card__count{position:absolute;top:-7px;right:-7px;z-index:4;min-width:22px;height:22px;padding:0 6px;display:flex;align-items:center;justify-content:center;border-radius:11px;background:var(--border-accent);border:2px solid var(--bg-deep);color:var(--bg-deep);font-family:var(--font-display);font-weight:700;font-size:11px;box-shadow:0 2px 6px #0000008c}.dom-panel:has(.equipment__cols){min-width:800px;max-width:1050px}.equipment__cols{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-lg)}.equipment__col{display:flex;flex-direction:column;gap:var(--space-sm)}.equipment__slots,.equipment__items{display:flex;flex-direction:column;gap:6px}.equipment__slot,.equipment__item{display:flex;align-items:center;gap:var(--space-sm);padding:8px 12px;background:#0000004d;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);box-shadow:0 2px 6px #0000004d}.equipment__slot--filled{border-color:#6abf6a66}.equipment__slot-info,.equipment__item-info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.equipment__slot-label{font-size:10px;color:var(--text-muted);letter-spacing:1px;text-transform:uppercase}.equipment__slot-name,.equipment__item-name{font-family:var(--font-display);font-weight:600;font-size:13px;color:var(--text-primary);letter-spacing:.5px}.equipment__slot-empty{font-size:11px;color:var(--text-muted);font-style:italic}.equipment__slot-bonus,.equipment__item-meta{font-size:10px;color:var(--text-muted);letter-spacing:.5px}.equipment__empty{font-size:var(--fs-small);color:var(--text-muted);text-align:center;font-style:italic;padding:var(--space-md)}.equipment__stats{display:flex;flex-wrap:wrap;justify-content:center;gap:4px 16px;padding:var(--space-sm);background:#0000004d;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px}.equipment__stats strong{font-family:var(--font-body);font-weight:700;color:var(--text-accent);font-size:12px}.equipment__stats .stat--buff,.equipment__stats .stat--buff strong{color:#7fd47f}.equipment__stats .stat--debuff,.equipment__stats .stat--debuff strong{color:#d96a6a}.equipment__tag{display:inline-block;margin-left:8px;padding:2px 8px;border-radius:10px;font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;vertical-align:middle}.equipment__tag--light{background:#a0d2a02e;color:#b8d8b8;border:1px solid rgba(160,210,160,.4)}.equipment__tag--medium{background:#c8aa5a2e;color:#d8c08a;border:1px solid rgba(200,170,90,.4)}.equipment__tag--heavy{background:#b478502e;color:#d09a78;border:1px solid rgba(180,120,80,.4)}.dom-panel:has(.levelup__options){min-width:720px;max-width:980px}.levelup__options{display:flex;flex-wrap:wrap;justify-content:center;align-items:stretch;gap:var(--space-lg);perspective:1600px;padding:var(--space-sm) 0 var(--space-md)}.levelup__pick{-webkit-appearance:none;-moz-appearance:none;appearance:none;margin:0;padding:0;border:none;background:none;font:inherit;color:inherit;cursor:pointer;transition:transform .18s ease,filter .18s ease}.levelup__pick:focus-visible{outline:2px solid var(--border-accent);outline-offset:4px;border-radius:var(--radius-md)}.levelup__pick--card{width:210px;perspective:1400px}.levelup__pick--card:hover{transform:translateY(-10px)}.levelup__card-flip{display:block;position:relative;transform-style:preserve-3d;transform:rotateY(180deg);transition:transform .9s cubic-bezier(.16,.68,.24,1)}.levelup__pick--card.is-revealed .levelup__card-flip{transform:rotateY(0)}.levelup__card-flip:before{content:"";position:absolute;inset:0;backface-visibility:hidden;transform:rotateY(180deg);border-radius:10px;border:2px solid var(--border-accent);background:radial-gradient(circle at 50% 38%,rgba(232,201,112,.28),transparent 46%),repeating-linear-gradient(45deg,rgba(200,160,74,.06) 0 9px,transparent 9px 18px),repeating-linear-gradient(-45deg,rgba(200,160,74,.05) 0 9px,transparent 9px 18px),linear-gradient(160deg,#1c2c22,#0c1612);box-shadow:inset 0 0 0 1px #e8c9702e,inset 0 0 32px #000000a6,0 6px 18px #0000008c}.levelup__card-flip:after{content:"";position:absolute;top:50%;left:50%;width:54px;height:54px;transform:translate(-50%,-50%) rotateY(180deg) rotate(45deg);backface-visibility:hidden;border:2px solid var(--leaf-glow);box-shadow:0 0 18px #e8c97080;opacity:.9}.levelup__card-face{display:block;position:relative;backface-visibility:hidden;border-radius:10px;overflow:hidden}.levelup__card-face:after{content:"";position:absolute;inset:0;pointer-events:none;mix-blend-mode:screen;background:linear-gradient(105deg,transparent 32%,rgba(244,236,214,.6) 50%,transparent 68%);background-size:250% 100%;background-position:160% 0;opacity:0}.levelup__pick--card.is-revealed .levelup__card-face:after{animation:lu-beam 1s ease-out .62s forwards}.levelup__pick--card.is-revealed .game-card__frame{animation:lu-glow 1.3s ease-out .5s both}.levelup__pick--card.is-revealed .game-card--r-rare .game-card__frame,.levelup__pick--card.is-revealed .game-card--r-epic .game-card__frame{animation-name:lu-glow-strong;animation-duration:1.5s}.levelup__pick--stat{display:flex;align-items:center;justify-content:center;min-width:220px;padding:var(--space-lg) var(--space-md);background:linear-gradient(180deg,var(--bg-elevated) 0%,var(--bg-panel) 100%);border:1px solid var(--border-subtle);border-radius:var(--radius-md);animation:lu-rise .38s ease-out var(--reveal-delay, 0ms) both;transition:transform .16s ease,border-color .16s ease,box-shadow .2s ease}.levelup__pick--stat:hover{transform:translateY(-3px);border-color:var(--border-accent);box-shadow:0 8px 22px #00000080,var(--shadow-glow-accent)}.levelup__pick-stat{font-family:var(--font-display);font-size:19px;font-weight:700;letter-spacing:1px;color:var(--text-accent)}@keyframes lu-beam{0%{opacity:0;background-position:160% 0}18%{opacity:1}to{opacity:0;background-position:-160% 0}}@keyframes lu-glow{0%{box-shadow:0 4px 14px #00000073}42%{box-shadow:0 0 30px color-mix(in srgb,var(--domain-accent) 65%,transparent),0 8px 24px #00000080}to{box-shadow:0 4px 14px #00000073}}@keyframes lu-glow-strong{0%{box-shadow:0 4px 14px #00000073;transform:scale(1)}34%{box-shadow:0 0 48px color-mix(in srgb,var(--domain-accent) 90%,transparent),0 0 90px color-mix(in srgb,var(--leaf-glow) 38%,transparent);transform:scale(1.06)}to{box-shadow:0 4px 14px #00000073;transform:scale(1)}}@keyframes lu-rise{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@media (prefers-reduced-motion: reduce){.levelup__card-flip{transition:none}.levelup__card-face:after,.levelup__pick--card.is-revealed .game-card__frame,.levelup__pick--stat{animation:none}}.dom-panel:has(.voting__question){min-width:420px;max-width:560px}.voting__question{text-align:center;font-size:15px;color:var(--text-primary);line-height:1.5;font-style:italic}.voting__options{display:flex;flex-direction:column;gap:6px}.voting__option-row{display:flex;align-items:center;width:100%;padding:10px 14px;background:#0003;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);box-shadow:0 2px 6px #00000040;cursor:pointer;transition:border-color .15s ease,background .15s ease,box-shadow .2s ease}.voting__option-row:hover{border-color:var(--border-accent);background:#0000004d;box-shadow:0 4px 12px #0006}.voting__option-row input[type=radio]{margin-right:8px;accent-color:var(--border-accent);cursor:pointer}.voting__option-row span{flex:1;font-family:var(--font-body);font-size:13px;color:var(--text-primary);letter-spacing:.3px;text-transform:none}.voting__result{text-align:center;font-size:var(--fs-body);color:var(--text-muted);padding:var(--space-md);font-style:italic}.voting__result strong{color:var(--text-accent);font-weight:700;font-style:normal}.dom-panel:has(.event__text){min-width:460px;max-width:580px}.event__image-frame{width:100%;height:220px;overflow:hidden;border:1px solid var(--border-accent);border-radius:var(--radius-md);box-shadow:inset 0 0 24px #0009}.event__image{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.event__text{font-size:var(--fs-body);color:var(--text-primary);line-height:1.55;text-align:center;font-style:italic}.event__reward{display:flex;flex-direction:column;align-items:center;gap:4px;padding:var(--space-sm) var(--space-md);background:#6abf6a14;border:1px solid rgba(106,191,106,.4);border-radius:var(--radius-md)}.event__reward-label{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:1.5px}.event__reward-name{font-family:var(--font-display);font-size:16px;font-weight:700;color:var(--text-accent);letter-spacing:1px}.event__actions{display:flex;justify-content:center;margin-top:4px}.event__reward-list{list-style:none;padding:0;margin:0}.event__reward-list li{margin:4px 0;font-size:13px;color:var(--text-primary);line-height:1.4}.event__reward-desc{color:var(--text-muted);font-size:12px;font-style:normal}.cutscene{position:absolute;top:0;left:0;width:100%;height:100%;z-index:var(--z-overlay);background:linear-gradient(180deg,#0003,#0009);display:flex;flex-direction:column;justify-content:flex-end;cursor:pointer;animation:dom-overlay-fade .4s ease-out}.cutscene,.cutscene *,.cutscene *:before,.cutscene *:after{box-sizing:border-box}.cutscene__skip{position:absolute;top:var(--space-md);right:var(--space-md);padding:6px 14px;background:#0009;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-muted);font-family:var(--font-body);font-size:12px;letter-spacing:.5px;cursor:pointer;transition:color .15s ease,border-color .15s ease}.cutscene__skip:hover{color:var(--text-accent);border-color:var(--border-accent)}.cutscene__panel{margin:0 var(--space-lg) var(--space-lg);padding:var(--space-md) var(--space-lg);background:linear-gradient(180deg,#1a1825f2,#0c0a14fa);border:1px solid var(--border-accent);border-radius:var(--radius-md);box-shadow:0 -8px 24px #00000080;animation:cutscene-slide-up .4s ease-out}@keyframes cutscene-slide-up{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.cutscene__speaker{display:block;font-family:var(--font-display);font-size:14px;font-weight:700;color:var(--text-accent);letter-spacing:2px;text-transform:uppercase;margin-bottom:var(--space-xs)}.cutscene__speaker:empty{display:none}.cutscene__text{font-size:15px;color:var(--text-primary);line-height:1.55;min-height:3em}.hud{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:var(--z-overlay);font-family:var(--font-body);color:var(--text-primary)}.hud,.hud *,.hud *:before,.hud *:after{box-sizing:border-box}.hud__top{position:absolute;top:var(--space-md);left:50%;transform:translate(-50%);display:flex;align-items:stretch;gap:6px;padding:6px;background:linear-gradient(180deg,#1a1825eb,#0c0a14f2);border:1px solid var(--border-accent);border-radius:var(--radius-md);box-shadow:0 4px 16px #0009,inset 0 1px #ffffff0a;pointer-events:auto}.hud__resources,.hud__meta{display:flex;gap:6px}.hud__resource,.hud__chip{display:flex;align-items:center;gap:8px;padding:6px 12px;background:#00000059;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);min-height:38px;transition:opacity .2s ease,border-color .15s ease}.hud__resource[data-empty=true]{opacity:.4}.hud__resource:hover,.hud__chip:hover{border-color:#c8a04a80}.hud__resource-icon{width:22px;height:22px;-o-object-fit:contain;object-fit:contain;image-rendering:pixelated;flex-shrink:0}.hud__resource-value{font-family:var(--font-body);font-weight:700;font-size:15px;color:var(--text-accent);letter-spacing:.3px;min-width:36px;text-align:right}.hud__chip-label{font-family:var(--font-body);font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:1.2px}.hud__chip-value{font-family:var(--font-body);font-weight:700;font-size:15px;color:var(--text-primary);letter-spacing:.3px;min-width:28px;text-align:right;margin-left:auto}.hud__chip-aux{font-family:var(--font-body);font-size:10px;color:var(--text-muted);letter-spacing:.3px}.hud__chip--energy .hud__chip-value{color:var(--state-hope)}.hud__chip--level .hud__chip-value{color:var(--text-accent)}.hud__legend{position:absolute;bottom:var(--space-md);left:var(--space-md);pointer-events:auto;display:flex;align-items:center;gap:var(--space-md);padding:8px 14px;background:linear-gradient(180deg,#1a1825eb,#0c0a14f2);border:1px solid var(--border-subtle);border-radius:var(--radius-md);box-shadow:0 4px 16px #00000080}.hud__legend-title{font-family:var(--font-body);font-size:10px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:1.5px;padding-right:var(--space-sm);border-right:1px solid var(--border-subtle)}.hud__legend-list{list-style:none;display:flex;gap:var(--space-md)}.hud__legend-list li{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text-primary);letter-spacing:.5px}.hud__dot{display:inline-block;width:8px;height:8px;border-radius:50%;box-shadow:0 0 6px currentColor;flex-shrink:0}.hud__dot--troop{background:var(--state-success);color:var(--state-success)}.hud__dot--event{background:var(--state-fear);color:var(--state-fear)}.hud__dot--battle{background:#a855f7;color:#a855f7}.hud__nav{position:absolute;bottom:var(--space-md);left:50%;transform:translate(-50%);display:flex;gap:var(--space-sm);pointer-events:auto}.hud__nav--triangle{left:var(--space-lg);bottom:var(--space-lg);transform:none;display:grid;grid-template-columns:1fr 1fr;grid-template-rows:auto auto;gap:8px 24px;width:260px}.hud__nav--triangle .hud__nav-btn--top{grid-column:1 / span 2;justify-self:center}.hud__nav--triangle .hud__nav-btn--left{grid-column:1;grid-row:2}.hud__nav--triangle .hud__nav-btn--right{grid-column:2;grid-row:2}.hud__nav-btn{display:flex;flex-direction:column;align-items:center;gap:2px;min-width:96px;padding:8px 12px;background:linear-gradient(180deg,var(--bg-elevated) 0%,var(--bg-panel) 100%);border:2px solid var(--border-accent);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-body);cursor:pointer;transition:border-color .15s ease,transform .1s ease,box-shadow .2s ease;box-shadow:inset 0 0 0 1px #3a354899,0 4px 14px #0000008c,0 0 #c8a04a00}.hud__nav-btn:hover{border-color:var(--border-accent);transform:translateY(-2px);box-shadow:0 6px 16px #0009,0 0 16px #c8a04a40}.hud__nav-btn:active{transform:translateY(0)}.hud__nav-icon{font-size:22px;line-height:1}.hud__nav-label{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:1.2px}.hud__nav-btn:hover .hud__nav-label{color:var(--text-accent)}.town{position:fixed;inset:0;width:100vw;height:100vh;z-index:var(--z-overlay);display:flex;flex-direction:column;font-family:var(--font-body);color:var(--text-primary);overflow:hidden;animation:dom-overlay-fade .4s ease-out}.town,.town *,.town *:before,.town *:after{box-sizing:border-box}.town__bg{position:absolute;inset:0;background:url(/castle.png) center / cover no-repeat,var(--bg-deep);z-index:0}.town__shade{position:absolute;inset:0;z-index:1;background:radial-gradient(ellipse at 50% 0%,rgba(200,160,74,.1) 0%,transparent 50%),linear-gradient(180deg,#0c0a148c,#0c0a14d9)}.town__header,.town__grid,.town__resources{position:relative;z-index:2}.town__header{position:relative;padding:var(--space-lg) var(--space-xl)}.town__title-wrap{text-align:center}.town__back{position:absolute;top:var(--space-lg);right:var(--space-xl)}.town__grid{flex:1;display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-md);padding:0 var(--space-xl);max-width:1200px;width:100%;margin:0 auto;align-content:center}.town__card{display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);padding:var(--space-lg) var(--space-md);background:linear-gradient(180deg,#25223aeb,#1a1825f2);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);box-shadow:inset 0 1px #ffffff0d,0 8px 24px #0009;cursor:pointer;font-family:var(--font-body);color:var(--text-primary);transition:transform .2s ease,border-color .2s ease,box-shadow .25s ease;animation:cc-card-in .5s ease-out backwards}.town__card:nth-child(1){animation-delay:.05s}.town__card:nth-child(2){animation-delay:.12s}.town__card:nth-child(3){animation-delay:.19s}.town__card:nth-child(4){animation-delay:.26s}.town__card:hover:not(.town__card--disabled){transform:translateY(-4px);border-color:var(--border-accent);box-shadow:inset 0 1px #c8a04a26,0 12px 32px #000000b3,0 0 24px #c8a04a40}.town__card--disabled{filter:blur(2px) grayscale(.5);opacity:.5;cursor:not-allowed;pointer-events:none}.town__card--disabled .town__card-cta{color:var(--text-muted)}.town__card-icon{font-size:56px;line-height:1}.town__card-name{font-family:var(--font-display);font-size:20px;font-weight:700;color:var(--text-accent);letter-spacing:3px;text-transform:uppercase;text-shadow:0 2px 6px rgba(0,0,0,.7)}.town__card-desc{flex:1;font-size:var(--fs-small);color:var(--text-muted);line-height:1.45;text-align:center;font-style:italic}.town__card-cta{margin-top:var(--space-sm);padding:6px 16px;background:linear-gradient(180deg,#d8b260 0%,var(--border-accent) 50%,#a08038 100%);border:1px solid #8a6a2a;border-radius:var(--radius-sm);color:var(--bg-deep);font-family:var(--font-display);font-size:12px;font-weight:700;letter-spacing:2px;text-transform:uppercase;box-shadow:inset 0 1px #fff6,0 2px 6px #0006;transition:box-shadow .2s ease}.town__card:hover .town__card-cta{box-shadow:inset 0 1px #fff6,0 4px 12px #00000080,0 0 16px #c8a04a80}.town__resources{display:flex;justify-content:center;flex-wrap:wrap;gap:4px 32px;padding:var(--space-md) var(--space-xl) var(--space-lg);font-size:12px;color:var(--text-muted);text-transform:uppercase;letter-spacing:1.2px}.town__resources strong{font-family:var(--font-display);color:var(--text-accent);font-weight:700;font-size:14px;margin-left:4px}.icon-gold{display:inline-block;width:18px;height:18px;background:url(/map/icons/icon_gold.png) center / contain no-repeat;vertical-align:-4px}.icon-gold--sm{width:14px;height:14px;vertical-align:-2px}.admin-launch{position:fixed;top:var(--space-md);right:var(--space-md);z-index:1050;display:inline-flex;align-items:center;gap:var(--space-xs);padding:8px 14px;background:linear-gradient(180deg,var(--bg-elevated) 0%,var(--bg-panel) 100%);border:2px solid var(--border-accent);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-body);font-weight:600;font-size:var(--fs-body);letter-spacing:.3px;cursor:pointer;box-shadow:inset 0 0 0 1px #3a354899,0 4px 14px #0000008c;transition:border-color .15s ease,transform .1s ease,box-shadow .2s ease}.admin-launch:hover{transform:translateY(-2px);box-shadow:0 6px 16px #0009,0 0 16px #c8a04a40;color:var(--text-accent)}.admin-launch:active{transform:translateY(0)}
