@import "https://fonts.googleapis.com/css2?family=Cinzel:wght@400;600;700;900&family=Crimson+Text:ital,wght@0,400;0,600;0,700;1,400&family=MedievalSharp&display=swap";:root{--bg-dark:#0d0b0e;--bg-card:#16131a;--bg-card-hover:#1e1a24;--bg-input:#1a1620;--border:#2a2433;--border-glow:#6b3fa0;--accent:#c084fc;--accent-bright:#e0b0ff;--accent-dim:#7c3aed;--gold:#f59e0b;--gold-bright:#fbbf24;--text-primary:#e8e0f0;--text-secondary:#9a8fad;--text-muted:#6b5f7e;--danger:#ef4444;--success:#22c55e;--parchment:#2a2235;--parchment-light:#342c42;--gen-names:#c084fc;--gen-quests:#34d399;--gen-taverns:#f59e0b;--gen-encounters:#ef4444;--gen-npcs:#38bdf8;--gen-dice:#c084fc;--gen-loot:#fbbf24;--gen-towns:#a78bfa;--gen-dungeons:#f97316;--gen-wildmagic:#e879f9;--gen-shops:#6ee7b7;--gen-weather:#67e8f9;--gen-traps:#fca5a5;--gen-plothooks:#c4b5fd;--gen-graphpaper:#94a3b8;--gen-dungeonmap:#a0b0d0}*{box-sizing:border-box;margin:0;padding:0}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}:focus:not(:focus-visible){outline:none}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}body{background:var(--bg-dark);color:var(--text-primary);min-height:100vh;font-family:Crimson Text,Georgia,serif;overflow-x:hidden}.app-bg{z-index:0;pointer-events:none;background:radial-gradient(at 15% 0,#6b3fa047 0%,#0000 50%),radial-gradient(at 85% 5%,#7c3aed1f 0%,#0000 40%),radial-gradient(at 80% 100%,#7c3aed38 0%,#0000 45%),radial-gradient(at 50% 60%,#5a288c0f 0%,#0000 60%),radial-gradient(#0d0b0e 0% 100%);position:fixed;inset:0}.app-bg:after{content:"";opacity:1;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");background-size:256px 256px;position:absolute;inset:0}.app-bg:before{content:"";z-index:1;background:radial-gradient(#0000 40%,#0006 100%);position:absolute;inset:0}.app-container{z-index:1;max-width:1100px;margin:0 auto;padding:20px 20px 60px;position:relative}.header{text-align:center;padding:48px 0 24px;position:relative}.header:before{content:"";z-index:-1;background:radial-gradient(at 50% 80%,#6b3fa014 0%,#0000 70%);position:absolute;inset:0}.header:after{content:"";background:linear-gradient(90deg, transparent, var(--accent), transparent);width:240px;height:1px;margin:24px auto 0;display:block}.logo-icon{filter:drop-shadow(0 0 24px #c084fc80);mix-blend-mode:lighten;border-radius:8px;width:148px;height:auto;margin-bottom:8px;animation:6s ease-in-out infinite logoFloat}@keyframes logoFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.logo-title{background:linear-gradient(135deg, var(--accent-bright), var(--gold-bright), var(--accent));-webkit-text-fill-color:transparent;letter-spacing:6px;text-transform:uppercase;text-shadow:none;filter:drop-shadow(0 2px 8px #c084fc33);-webkit-background-clip:text;font-family:Cinzel,serif;font-size:42px;font-weight:900}.logo-sub{letter-spacing:8px;color:var(--text-secondary);text-transform:uppercase;margin-top:4px;font-family:Cinzel,serif;font-size:13px}.tab-bar{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;flex-wrap:wrap;justify-content:center;gap:4px;margin-bottom:28px;padding:6px;display:flex}.tab-btn{color:var(--text-secondary);cursor:pointer;letter-spacing:.5px;white-space:nowrap;background:0 0;border:none;border-radius:8px;align-items:center;gap:6px;padding:8px 14px;font-family:Cinzel,serif;font-size:12px;font-weight:600;text-decoration:none;transition:all .25s;display:flex}.tab-btn:hover{color:var(--text-primary);background:var(--bg-card-hover)}.tab-btn.active{color:var(--accent-bright);background:#7c3aed33;box-shadow:0 0 20px #7c3aed26}.tab-icon{font-size:16px}.tab-label{display:inline}@media (width<=600px){.tab-bar{gap:2px;padding:4px}.tab-btn{padding:10px 12px;font-size:11px;position:relative}.tab-label{display:none}.tab-icon{font-size:20px}.tab-btn.active .tab-label{font-size:10px;display:inline}}.gen-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:32px;animation:.35s panelIn;position:relative;box-shadow:0 4px 40px #0000004d,inset 0 1px #c084fc0a}@keyframes panelIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.gen-panel:before{content:"";background:linear-gradient(90deg, transparent, var(--accent), transparent);height:1px;position:absolute;top:0;left:0;right:0}.gen-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:8px;display:flex}.gen-title{color:var(--text-primary);letter-spacing:2px;text-shadow:0 0 30px #c084fc1f;font-family:Cinzel,serif;font-size:28px;font-weight:400}.gen-desc{color:var(--text-secondary);margin-bottom:24px;font-size:17px;line-height:1.7}.controls{flex-wrap:wrap;align-items:flex-end;gap:12px;margin-bottom:24px;display:flex}.control-group{flex-direction:column;gap:6px;display:flex}.control-label{letter-spacing:2px;color:var(--text-muted);text-transform:uppercase;font-family:Cinzel,serif;font-size:11px}.control-select,.control-input{background:var(--bg-input);border:1px solid var(--border);color:var(--text-primary);border-radius:8px;min-width:160px;padding:10px 14px;font-family:Crimson Text,serif;font-size:15px;transition:border-color .2s}.control-select:focus,.control-input:focus{border-color:var(--accent)}.control-select:focus-visible,.control-input:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.control-select option{background:var(--bg-dark)}.generate-btn{cursor:pointer;letter-spacing:2px;text-transform:uppercase;background:linear-gradient(135deg, var(--accent-dim), var(--border-glow));color:#fff;border:none;border-radius:10px;padding:12px 28px;font-family:Cinzel,serif;font-size:14px;font-weight:700;transition:all .3s;position:relative;overflow:hidden}.generate-btn:after{content:"";background:linear-gradient(90deg,#0000,#ffffff26,#0000);transition:transform;position:absolute;inset:0;transform:translate(-100%)}.generate-btn:hover{transform:translateY(-2px);box-shadow:0 6px 24px #7c3aed66}.generate-btn:active{transform:translateY(0)}.generate-btn.generate-btn--flash:after{transition:transform .5s;transform:translate(100%)}.results-area{flex-direction:column;gap:16px;display:flex}.results-area--names{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px;display:grid}.results-area--names .result-card{padding:16px 20px}.results-area--names .result-main-name{margin-bottom:4px;font-size:19px}.result-card{background:var(--parchment);border:1px solid var(--border);border-radius:12px;padding:24px;transition:border-color .3s,box-shadow .3s;animation:.4s both cardIn;position:relative;overflow:hidden}.result-card:hover{border-color:color-mix(in srgb, var(--card-accent,var(--accent)) 60%, transparent);box-shadow:0 0 20px color-mix(in srgb, var(--card-accent,var(--accent)) 10%, transparent)}@keyframes cardIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.result-card:before{content:"";background:linear-gradient(180deg, var(--card-accent,var(--accent)), color-mix(in srgb, var(--card-accent,var(--accent)) 40%, transparent));width:3px;position:absolute;top:0;bottom:0;left:0}.result-card[data-gen=names]{--card-accent:var(--gen-names)}.result-card[data-gen=quests]{--card-accent:var(--gen-quests)}.result-card[data-gen=taverns]{--card-accent:var(--gen-taverns)}.result-card[data-gen=encounters]{--card-accent:var(--gen-encounters)}.result-card[data-gen=npcs]{--card-accent:var(--gen-npcs)}.result-card[data-gen=loot]{--card-accent:var(--gen-loot)}.result-card[data-gen=towns]{--card-accent:var(--gen-towns)}.result-card[data-gen=dungeons]{--card-accent:var(--gen-dungeons)}.result-card[data-gen=wildmagic]{--card-accent:var(--gen-wildmagic)}.result-card[data-gen=shops]{--card-accent:var(--gen-shops)}.result-card[data-gen=weather]{--card-accent:var(--gen-weather)}.result-card[data-gen=traps]{--card-accent:var(--gen-traps)}.result-card[data-gen=plothooks]{--card-accent:var(--gen-plothooks)}.result-card-watermark{opacity:.06;pointer-events:none;-webkit-user-select:none;user-select:none;font-size:32px;position:absolute;top:10px;right:12px}.result-number{color:var(--text-muted);letter-spacing:2px;font-family:Cinzel,serif;font-size:11px;position:absolute;top:12px;right:16px}.result-main-name{color:var(--accent-bright);text-shadow:0 0 24px #c084fc40,0 0 60px #c084fc14;letter-spacing:.5px;margin-bottom:8px;font-family:Cinzel,serif;font-size:24px;font-weight:700}.result-tag{letter-spacing:1px;text-transform:uppercase;border:1px solid var(--border);color:var(--text-secondary);border-radius:4px;margin-bottom:8px;margin-right:6px;padding:3px 10px;font-family:Cinzel,serif;font-size:12px;display:inline-block}.result-tag.gold{color:var(--gold);border-color:#f59e0b66}.result-tag.danger{color:var(--danger);border-color:#ef44444d}.result-tag.success{color:var(--success);border-color:#22c55e4d}.result-field{margin-top:12px}.result-field-label{color:var(--card-accent,var(--accent));letter-spacing:2.5px;text-transform:uppercase;border-bottom:1px solid color-mix(in srgb, var(--card-accent,var(--accent)) 25%, transparent);opacity:.7;margin-bottom:5px;padding-bottom:3px;font-family:Cinzel,serif;font-size:11px;font-weight:700;display:inline-block}.result-field-value{color:var(--text-primary);font-size:16px;line-height:1.7}.result-flavor{color:var(--text-secondary);margin-top:4px;font-size:15px;font-style:italic;line-height:1.6}.rerollable-field .result-field-label{align-items:center;gap:6px;display:flex}.reroll-btn{cursor:pointer;opacity:0;background:0 0;border:none;padding:0 2px;font-size:12px;line-height:1;transition:opacity .2s,transform .4s}.rerollable-field:hover .reroll-btn{opacity:.6}.reroll-btn:hover{transform:scale(1.2);opacity:1!important}.reroll-btn--spin{animation:.4s rerollSpin;opacity:1!important}@keyframes rerollSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.result-copy-btn{cursor:pointer;color:var(--text-muted);opacity:0;z-index:2;background:0 0;border:1px solid #0000;border-radius:6px;padding:4px 8px;font-size:15px;transition:all .2s;position:absolute;top:10px;right:14px}.result-card:hover .result-copy-btn{opacity:1}.result-copy-btn:hover{color:var(--accent-bright);border-color:var(--border);background:#7c3aed1a}.result-copy-btn--copied{color:var(--success)!important;opacity:1!important}.empty-state{text-align:center;padding:56px 24px;position:relative}.empty-state-icon{opacity:.12;margin-bottom:16px;font-size:56px;animation:4s ease-in-out infinite emptyPulse}@keyframes emptyPulse{0%,to{opacity:.12;transform:scale(1)}50%{opacity:.2;transform:scale(1.05)}}.empty-state-text{letter-spacing:2px;color:var(--text-muted);font-family:Cinzel,serif;font-size:14px}.empty-state-sub{color:var(--text-muted);opacity:.6;margin-top:8px;font-family:Crimson Text,serif;font-size:14px;font-style:italic}.history-bar{border-top:1px solid var(--border);justify-content:space-between;align-items:center;margin-top:24px;padding-top:16px;display:flex}.history-count{color:var(--text-muted);letter-spacing:1px;font-family:Cinzel,serif;font-size:13px}.clear-btn{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:6px;padding:6px 14px;font-family:Crimson Text,serif;font-size:13px;transition:all .2s}.clear-btn:hover{border-color:var(--danger);color:var(--danger)}.history-actions{align-items:center;gap:8px;display:flex}.export-btn{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:6px;padding:6px 12px;font-family:Crimson Text,serif;font-size:13px;transition:all .2s}.export-btn:hover{border-color:var(--accent);color:var(--accent)}.ad-slot{display:none}.app-footer{text-align:center;border-top:1px solid var(--border);margin-top:48px;padding-top:24px}.footer-text{color:var(--text-muted);font-size:13px}.footer-links{justify-content:center;gap:20px;margin-top:8px;display:flex}.footer-link{color:var(--text-secondary);cursor:pointer;font-size:13px;text-decoration:none}.footer-link:hover{color:var(--accent)}.dice-quick-row{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.dice-quick-btn{border:1px solid var(--border);background:var(--bg-input);color:var(--text-secondary);cursor:pointer;letter-spacing:1px;border-radius:8px;padding:10px 16px;font-family:Cinzel,serif;font-size:14px;font-weight:600;transition:all .2s}.dice-quick-btn:hover{border-color:var(--accent);color:var(--accent-bright);background:#7c3aed1a}.dice-input-row{gap:12px;margin-bottom:20px;display:flex}.dice-input{background:var(--bg-input);border:1px solid var(--border);color:var(--text-primary);border-radius:10px;flex:1;padding:12px 16px;font-family:Crimson Text,serif;font-size:18px;transition:border-color .2s}.dice-input:focus{border-color:var(--accent)}.dice-input:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.dice-input::placeholder{color:var(--text-muted)}.dice-input-sm{flex:unset;min-width:120px;padding:8px 12px;font-size:14px}.dice-error{color:var(--danger);background:#ef44441a;border:1px solid #ef44444d;border-radius:8px;margin-bottom:16px;padding:10px 16px;font-size:14px}.dice-help-toggle{color:var(--accent);cursor:pointer;background:0 0;border:none;padding:0;font-family:Crimson Text,serif;font-size:16px;text-decoration:underline}.dice-help-toggle:hover{color:var(--accent-bright)}.dice-help{background:var(--parchment);border:1px solid var(--border);border-radius:10px;margin-bottom:20px;padding:16px 20px}.dice-help-table{border-collapse:collapse;width:100%}.dice-help-table td{border-bottom:1px solid var(--border);padding:5px 12px;font-size:14px}.dice-help-table td:first-child{white-space:nowrap;width:140px}.dice-help-table code{color:var(--accent-bright);background:#7c3aed26;border-radius:4px;padding:2px 6px;font-family:Fira Code,Consolas,monospace;font-size:13px}.dice-result-card{background:var(--parchment);border:1px solid var(--border);border-radius:12px;margin-bottom:8px;padding:20px 24px;animation:.3s cardIn;position:relative;overflow:hidden}.dice-result-card:before{content:"";background:linear-gradient(180deg, var(--accent), var(--accent-dim));width:3px;position:absolute;top:0;bottom:0;left:0}.dice-result-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.dice-result-notation{color:var(--text-muted);letter-spacing:1px;font-family:Fira Code,Consolas,monospace;font-size:14px}.dice-preset-label{color:var(--accent-bright);font-family:Cinzel,serif;font-weight:600}.dice-copy-btn{cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px 8px;font-size:16px;transition:background .2s}.dice-copy-btn:hover{background:#7c3aed26}.dice-result-roll{border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:12px;padding:8px 0;display:flex}.dice-result-roll:last-child{border-bottom:none}.dice-result-roll-num{color:var(--text-muted);letter-spacing:1px;min-width:54px;font-family:Cinzel,serif;font-size:12px}.dice-result-dice-row{flex-wrap:wrap;flex:1;align-items:center;gap:4px;display:flex}.dice-term-group{flex-wrap:wrap;align-items:center;gap:4px;display:inline-flex}.dice-term-plus{color:var(--text-muted);margin:0 2px;font-size:14px}.dice-die{min-width:32px;height:32px;color:var(--accent-bright);background:#c084fc1f;border:1px solid #c084fc4d;border-radius:6px;justify-content:center;align-items:center;padding:0 6px;font-family:Cinzel,serif;font-size:14px;font-weight:700;display:inline-flex}.dice-die.dice-dropped{color:var(--danger);opacity:.6;background:#ef44441a;border-color:#ef444440;text-decoration:line-through}.dice-die.dice-rerolled{color:var(--gold);background:#f59e0b1a;border-color:#f59e0b4d;font-size:12px}.dice-die.dice-exploded{color:var(--success);background:#22c55e1a;border-color:#22c55e4d}.dice-die.dice-max{color:var(--success);background:#22c55e26;border-color:#22c55e66}.dice-die.dice-min{color:var(--danger);background:#ef44441f;border-color:#ef44444d}.dice-modifier{color:var(--text-secondary);padding:0 2px;font-family:Cinzel,serif;font-size:14px}.dice-result-total{color:var(--text-primary);text-align:right;min-width:60px;font-family:Cinzel,serif;font-size:28px;font-weight:900}.dice-result-total.dice-nat20{color:var(--success);text-shadow:0 0 12px #22c55e80}.dice-result-total.dice-nat1{color:var(--danger);text-shadow:0 0 12px #ef444480}.dice-presets-section{margin-top:24px}.dice-presets-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.dice-section-title{color:var(--text-primary);letter-spacing:2px;font-family:Cinzel,serif;font-size:16px;font-weight:700}.dice-presets-actions{gap:8px;display:flex}.dice-small-btn{border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;letter-spacing:.5px;background:0 0;border-radius:6px;padding:6px 12px;font-family:Cinzel,serif;font-size:13px;transition:all .2s}.dice-small-btn:hover{border-color:var(--accent);color:var(--accent-bright)}.dice-small-btn-muted{color:var(--text-muted)}.dice-small-btn-muted:hover{border-color:var(--text-secondary);color:var(--text-secondary)}.dice-preset-form{background:var(--parchment);border:1px solid var(--border);border-radius:8px;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:12px;padding:12px;display:flex}.dice-pin-label{color:var(--text-secondary);cursor:pointer;white-space:nowrap;align-items:center;gap:4px;font-family:Cinzel,serif;font-size:13px;display:flex}.dice-preset-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:8px;margin-bottom:12px;display:grid}.dice-preset-item{border:1px solid var(--border);border-radius:8px;transition:border-color .2s;display:flex;position:relative}.dice-preset-item:hover{border-color:var(--accent)}.dice-preset-btn{background:var(--bg-input);color:var(--text-primary);cursor:pointer;text-align:left;border:none;flex-direction:column;flex:1;gap:2px;padding:10px 14px;transition:background .2s;display:flex}.dice-preset-btn:hover{background:#7c3aed1a}.dice-preset-name{color:var(--text-primary);letter-spacing:.5px;font-family:Cinzel,serif;font-size:13px;font-weight:600}.dice-preset-notation{color:var(--text-muted);font-family:Fira Code,Consolas,monospace;font-size:12px}.dice-preset-menu-wrap{position:relative}.dice-preset-dots{background:var(--bg-input);border:none;border-left:1px solid var(--border);color:var(--text-muted);cursor:pointer;height:100%;padding:10px 8px;font-size:16px;transition:color .2s}.dice-preset-dots:hover{color:var(--text-primary)}.dice-preset-menu{z-index:50;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;min-width:100px;position:absolute;bottom:100%;right:0;overflow:hidden;box-shadow:0 8px 24px #0006}.dice-preset-menu button{width:100%;color:var(--text-secondary);cursor:pointer;text-align:left;background:0 0;border:none;padding:8px 14px;font-family:Crimson Text,serif;font-size:13px;display:block}.dice-preset-menu button:hover{color:var(--text-primary);background:#7c3aed1a}.dice-toggle-all{color:var(--text-muted);letter-spacing:1px;cursor:pointer;background:0 0;border:none;margin-bottom:8px;padding:4px 0;font-family:Cinzel,serif;font-size:13px}.dice-toggle-all:hover{color:var(--text-secondary)}.dice-history-section{margin-top:24px}.dice-history-list{flex-direction:column;gap:4px;max-height:300px;display:flex;overflow-y:auto}.dice-history-entry{background:var(--parchment);border:1px solid var(--border);border-radius:6px;padding:8px 12px;transition:border-color .2s}.dice-history-entry:hover{border-color:var(--accent)}.dice-history-top{align-items:center;gap:12px;display:flex}.dice-history-notation{color:var(--text-muted);min-width:100px;font-family:Fira Code,Consolas,monospace;font-size:13px}.dice-history-totals{flex-wrap:wrap;flex:1;gap:8px;display:flex}.dice-history-total{color:var(--text-primary);font-family:Cinzel,serif;font-size:16px;font-weight:700}.dice-history-total.dice-nat20{color:var(--success)}.dice-history-total.dice-nat1{color:var(--danger)}.dice-history-actions{gap:4px;display:flex}.dice-tiny-btn{cursor:pointer;background:0 0;border:none;border-radius:4px;padding:2px 6px;font-size:14px;transition:background .2s}.dice-tiny-btn:hover{background:#7c3aed26}.result-fav-btn{cursor:pointer;color:var(--text-muted);opacity:0;z-index:2;background:0 0;border:1px solid #0000;border-radius:6px;padding:4px 8px;font-size:16px;line-height:1;transition:all .2s;position:absolute;top:10px;right:44px}.result-card:hover .result-fav-btn{opacity:1}.result-fav-btn:hover{color:var(--gold);border-color:var(--border);background:#f59e0b1a}.result-fav-btn--active{color:var(--gold)!important;opacity:1!important}.result-fav-btn--active:hover{color:var(--gold-bright)!important}.tab-divider{background:var(--border);flex-shrink:0;align-self:center;width:1px;height:24px;margin:0 4px}.tab-btn--favorites.active{color:var(--gold-bright);background:#f59e0b26;box-shadow:0 0 20px #f59e0b1a}.favorites-group{margin-bottom:32px}.favorites-group-header{color:var(--text-primary);letter-spacing:1.5px;border-bottom:1px solid var(--border);align-items:center;gap:10px;margin-bottom:16px;padding-bottom:8px;font-family:Cinzel,serif;font-size:18px;font-weight:600;display:flex}.favorites-group-icon{font-size:22px}.favorites-group-label{flex:1}.favorites-group-count{color:var(--text-muted);background:var(--bg-input);border:1px solid var(--border);letter-spacing:1px;border-radius:12px;padding:2px 10px;font-family:Cinzel,serif;font-size:13px}.seo-content{border-top:1px solid var(--border);color:var(--text-muted);margin-top:32px;padding-top:20px;font-size:14px;line-height:1.7}.gp-controls{flex-wrap:wrap;align-items:flex-end;gap:12px;margin-bottom:28px;display:flex}.gp-preview-area{flex-wrap:wrap;align-items:flex-start;gap:32px;display:flex}.gp-preview-card{background:var(--parchment);border:1px solid var(--border);border-radius:12px;flex-direction:column;align-items:center;gap:12px;padding:20px;display:flex}.gp-preview-label{letter-spacing:2px;color:var(--text-muted);text-transform:uppercase;font-family:Cinzel,serif;font-size:11px}.gp-preview-canvas{border:1px solid var(--border);border-radius:4px;box-shadow:0 2px 12px #0000004d}.gp-download-section{flex-direction:column;gap:20px;display:flex}.gp-download-btn{padding:14px 32px;font-size:15px}.gp-info{flex-direction:column;gap:8px;display:flex}.gp-info-row{color:var(--text-secondary);gap:8px;font-size:15px;display:flex}.gp-info-label{letter-spacing:1px;color:var(--text-muted);text-transform:uppercase;min-width:80px;font-family:Cinzel,serif;font-size:11px}.dungeon-map-page{padding:24px}.dm-layout{border:1px solid var(--border);background:var(--bg-dark);border-radius:12px;gap:0;margin-bottom:24px;display:flex;overflow:hidden}.dm-toolbar{background:var(--bg-card);border-right:1px solid var(--border);flex-direction:column;gap:16px;width:180px;min-width:180px;max-height:600px;padding:12px;display:flex;overflow-y:auto}.dm-toolbar-section{flex-direction:column;gap:4px;display:flex}.dm-toolbar-label{letter-spacing:2px;color:var(--text-muted);text-transform:uppercase;margin-bottom:4px;font-family:Cinzel,serif;font-size:10px}.dm-tool-btn{color:var(--text-secondary);cursor:pointer;text-align:left;background:0 0;border:1px solid #0000;border-radius:6px;align-items:center;gap:8px;width:100%;padding:7px 10px;font-family:Crimson Text,serif;font-size:14px;transition:all .2s;display:flex}.dm-tool-btn:hover{background:var(--bg-card-hover);color:var(--text-primary)}.dm-tool-btn--active{border-color:var(--accent-dim);color:var(--accent-bright);background:#7c3aed33}.dm-tool-icon{text-align:center;flex-shrink:0;width:22px;font-size:16px}.dm-tool-name{white-space:nowrap}.dm-action-btn{border:1px solid var(--border);color:var(--text-secondary);letter-spacing:.5px;cursor:pointer;white-space:nowrap;background:0 0;border-radius:6px;padding:6px 10px;font-family:Cinzel,serif;font-size:11px;transition:all .2s}.dm-action-btn:hover{border-color:var(--accent);color:var(--accent-bright)}.dm-action-btn:disabled{opacity:.4;cursor:default}.dm-action-btn--danger:hover{border-color:var(--danger);color:var(--danger)}.dm-checkbox{color:var(--text-secondary);cursor:pointer;align-items:center;gap:6px;font-family:Crimson Text,serif;font-size:13px;display:flex}.dm-checkbox input{accent-color:var(--accent)}.dm-size-controls{gap:8px;display:flex}.dm-size-label{color:var(--text-muted);align-items:center;gap:4px;font-family:Cinzel,serif;font-size:11px;display:flex}.dm-size-input{background:var(--bg-input);border:1px solid var(--border);width:48px;color:var(--text-primary);text-align:center;border-radius:4px;outline:none;padding:4px 6px;font-family:Crimson Text,serif;font-size:13px}.dm-size-input:focus{border-color:var(--accent)}.dm-canvas-wrap{background:#1a2744;flex:1;min-height:500px;position:relative;overflow:hidden}.dm-canvas{width:100%;height:100%;display:block}.dm-canvas-hint{letter-spacing:1px;color:#a0b0d080;pointer-events:none;white-space:nowrap;font-family:Cinzel,serif;font-size:10px;position:absolute;bottom:8px;left:50%;transform:translate(-50%)}.dm-legend{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:20px}.dm-legend-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.dm-legend-title{color:var(--text-primary);letter-spacing:2px;font-family:Cinzel,serif;font-size:18px;font-weight:600}.dm-legend-empty{color:var(--text-muted);text-align:center;padding:16px 0;font-size:14px;font-style:italic}.dm-legend-list{flex-direction:column;gap:10px;display:flex}.dm-legend-entry{background:var(--parchment);border:1px solid var(--border);border-radius:8px;padding:12px}.dm-legend-entry-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.dm-legend-num{background:var(--accent-dim);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-family:Cinzel,serif;font-size:13px;font-weight:700;display:inline-flex}.dm-legend-delete{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:2px 6px;font-size:14px;transition:all .2s}.dm-legend-delete:hover{color:var(--danger);background:#ef44441a}.dm-legend-text{background:var(--bg-input);border:1px solid var(--border);width:100%;color:var(--text-primary);resize:vertical;border-radius:6px;outline:none;padding:8px 10px;font-family:Crimson Text,serif;font-size:14px;line-height:1.6;transition:border-color .2s}.dm-legend-text:focus{border-color:var(--accent)}.dm-legend-text::placeholder{color:var(--text-muted)}.info-page{max-width:720px}.info-page .gen-title{margin-bottom:8px}.info-updated{color:var(--text-muted);margin-bottom:20px;font-family:Crimson Text,serif;font-size:13px;font-style:italic}.info-section{margin-bottom:24px}.info-section p{color:var(--text-secondary);margin:0 0 12px;font-family:Crimson Text,serif;font-size:16px;line-height:1.7}.info-section p:last-child{margin-bottom:0}.info-heading{color:var(--text-primary);letter-spacing:1px;margin:0 0 10px;font-family:Cinzel,serif;font-size:16px;font-weight:600}.info-link{color:var(--accent);text-decoration:none;transition:color .2s}.info-link:hover{color:var(--accent-bright);text-decoration:underline}.info-email{margin-top:8px;font-size:18px}@media (width<=700px){.logo-title{letter-spacing:3px;font-size:28px}.tab-btn{gap:6px;padding:8px 12px;font-size:12px}.gen-panel{padding:20px}.result-main-name{font-size:18px}.results-area--names{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}}@media (width<=480px){.tab-btn{padding:8px 10px;font-size:11px}.tab-label{display:none}.tab-icon{font-size:20px}.results-area--names{grid-template-columns:1fr}}@media (width<=600px){.gp-preview-area{flex-direction:column;align-items:stretch}.gp-preview-card{align-items:center}.gp-download-section{align-items:stretch}}@media (width<=800px){.dm-layout{flex-direction:column}.dm-toolbar{border-right:none;border-bottom:1px solid var(--border);flex-flow:wrap;gap:10px;width:100%;min-width:100%;max-height:none;padding:10px}.dm-toolbar-section{flex-flow:wrap;align-items:center;gap:4px}.dm-toolbar-label{margin-bottom:0;margin-right:4px}.dm-canvas-wrap{min-height:400px}}
