:root{--bg-primary: #0a0a0f;--bg-secondary: #111118;--bg-tertiary: #1a1a22;--accent-cyan: #00ffff;--accent-magenta: #ff00ff;--accent-purple: #9d4edd;--text-primary: #e0e0e8;--text-secondary: #a0a0b0;--text-muted: #606070;--border-color: #2a2a33;--glow-cyan: 0 0 10px rgba(0, 255, 255, .5);--glow-magenta: 0 0 10px rgba(255, 0, 255, .5);--glow-purple: 0 0 10px rgba(157, 78, 221, .5)}*{box-sizing:border-box}.grimoire-playground{min-height:100vh;background:var(--bg-primary);color:var(--text-primary);font-family:Courier New,Monaco,monospace;display:flex;flex-direction:column}.top-bar{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);box-shadow:var(--glow-cyan);flex-wrap:wrap;gap:.5rem}.app-title{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.app-title .rune{width:1.25rem;height:1.25rem;filter:drop-shadow(0 0 3px var(--accent-cyan))}.app-title h1{margin:0;font-size:1.25rem;color:var(--text-primary);font-weight:400;white-space:nowrap}.top-controls{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap;flex:1;justify-content:flex-end}.ritual-select,.top-controls button{padding:.5rem .75rem;background:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-primary);font-family:inherit;cursor:pointer;transition:all .2s;font-size:.875rem;white-space:nowrap}.ritual-select:hover,.top-controls button:hover{border-color:var(--accent-cyan);box-shadow:var(--glow-cyan)}@media(max-width:768px){.top-bar{padding:.5rem .75rem}.app-title .rune{width:1rem;height:1rem}.app-title h1{font-size:1rem}.ritual-select,.top-controls button{padding:.4rem .6rem;font-size:.8rem}.ritual-select{min-width:120px;max-width:150px}}@media(max-width:768px){.spell-header{gap:.75rem}.spell-actions{flex-wrap:wrap}}@media(max-width:480px){.top-bar{flex-direction:column;align-items:stretch}.app-title{justify-content:center;margin-bottom:.25rem}.top-controls{justify-content:center;width:100%}.ritual-select{flex:1;min-width:0;max-width:none}.spell-header{gap:.5rem}.spell-info{flex-basis:100%;order:2}.spell-actions{order:3;width:100%;justify-content:flex-end;margin-top:.5rem}.spell-number{order:1}.spell-card{padding:.75rem}}.playground-content{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1rem;padding:1rem;flex:1;overflow:hidden}@media(max-width:1200px){.playground-content{grid-template-columns:1fr;grid-template-rows:auto auto auto}}.panel{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:4px;display:flex;flex-direction:column;overflow:hidden}.panel-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:var(--bg-tertiary);border-bottom:1px solid var(--border-color)}.panel-header h2{margin:0;font-size:1rem;font-weight:400;color:var(--accent-cyan)}.source-panel{min-height:400px}.editor-container{flex:1;overflow:hidden}.code-editor{height:100%;min-height:400px}.sample-select{padding:.25rem .5rem;background:var(--bg-primary);border:1px solid var(--border-color);color:var(--text-primary);font-family:inherit;font-size:.875rem}.ritual-panel{min-height:400px;display:flex;flex-direction:column}.spell-list{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:1rem}.spell-card{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:4px;padding:1rem;transition:all .2s}.spell-card:hover{border-color:var(--accent-purple);box-shadow:var(--glow-purple)}.spell-header{display:flex;align-items:flex-start;gap:1rem;flex-wrap:wrap}.spell-number{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;background:var(--accent-purple);color:var(--bg-primary);border-radius:50%;font-weight:700;flex-shrink:0}.spell-info{flex:1;min-width:0}.spell-info h3{margin:0 0 .25rem;font-size:1rem;color:var(--text-primary)}.spell-description{margin:0;font-size:.875rem;color:var(--text-secondary)}.spell-actions{display:flex;gap:.5rem;flex-wrap:wrap;flex-shrink:0}.spell-actions button{background:transparent;border:1px solid var(--border-color);color:var(--text-primary);width:2rem;height:2rem;cursor:pointer;font-family:inherit;transition:all .2s}.spell-actions button:hover:not(:disabled){border-color:var(--accent-cyan);color:var(--accent-cyan)}.spell-actions button:disabled{opacity:.3;cursor:not-allowed}.config-drawer{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color)}.config-field{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.config-field label{font-size:.875rem;color:var(--text-secondary)}.config-field input,.config-field select{padding:.25rem .5rem;background:var(--bg-primary);border:1px solid var(--border-color);color:var(--text-primary);font-family:inherit;font-size:.875rem}.add-spell-btn,.cast-ritual-btn{margin:1rem;padding:.75rem 1.5rem;background:var(--accent-purple);border:none;color:var(--bg-primary);font-family:inherit;font-size:1rem;font-weight:700;cursor:pointer;transition:all .2s;box-shadow:var(--glow-purple)}.add-spell-btn:hover,.cast-ritual-btn:hover:not(:disabled){background:var(--accent-magenta);box-shadow:var(--glow-magenta);transform:scale(1.02)}.cast-ritual-btn:disabled{opacity:.5;cursor:not-allowed}.output-panel{min-height:400px;display:flex;flex-direction:column}.tabs{display:flex;gap:.5rem}.tabs button{padding:.5rem 1rem;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text-secondary);font-family:inherit;cursor:pointer;transition:all .2s}.tabs button:hover{color:var(--text-primary)}.tabs button.active{color:var(--accent-cyan);border-bottom-color:var(--accent-cyan)}.tab-content{flex:1;overflow-y:auto;padding:1rem}.code-output{margin:0;padding:1rem;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:4px;font-family:Courier New,monospace;font-size:.875rem;white-space:pre-wrap;word-wrap:break-word;color:var(--text-primary)}.diff-viewer{height:100%}.diff-split{display:grid;grid-template-columns:1fr 1fr;gap:1rem;height:100%}.diff-side{display:flex;flex-direction:column}.diff-header{padding:.5rem;background:var(--bg-tertiary);border-bottom:1px solid var(--border-color);font-size:.875rem;font-weight:700}.diff-content{flex:1;overflow-y:auto;font-family:Courier New,monospace;font-size:.75rem}.diff-line{padding:.25rem .5rem;white-space:pre}.diff-line.original{background:#ff00001a}.diff-line.changed{background:#00ff001a}.steps-list{display:flex;flex-direction:column;gap:1rem}.step-item{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:4px;padding:1rem}.step-header{display:flex;align-items:center;gap:1rem;margin-bottom:.5rem}.step-number{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;background:var(--accent-cyan);color:var(--bg-primary);border-radius:50%;font-weight:700}.step-header h4{margin:0;flex:1;color:var(--text-primary)}.size-change{font-size:.875rem;color:var(--text-secondary)}.step-messages{margin:.5rem 0}.message{font-size:.875rem;color:var(--accent-cyan);margin:.25rem 0}.step-warnings{margin:.5rem 0}.warning{font-size:.875rem;color:var(--accent-magenta);margin:.25rem 0}.step-details{margin-top:.5rem}.step-details summary{cursor:pointer;color:var(--accent-purple);font-size:.875rem}.step-output{margin-top:.5rem;padding:.5rem;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:4px;font-family:Courier New,monospace;font-size:.75rem;white-space:pre-wrap;max-height:200px;overflow-y:auto}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.metric-card{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:4px;padding:1rem;text-align:center}.metric-label{font-size:.875rem;color:var(--text-secondary);margin-bottom:.5rem}.metric-value{font-size:1.5rem;font-weight:700;color:var(--accent-cyan)}.ritual-log{border-top:1px solid var(--border-color);padding:1rem;background:var(--bg-tertiary)}.ritual-log h3{margin:0 0 .5rem;font-size:.875rem;color:var(--text-secondary);text-transform:uppercase}.log-content{max-height:150px;overflow-y:auto;font-family:Courier New,monospace;font-size:.75rem}.log-empty{color:var(--text-muted);font-style:italic}.log-entry{color:var(--text-secondary);margin:.25rem 0;padding-left:.5rem;border-left:2px solid var(--accent-purple)}.modal-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:4px;max-width:600px;max-height:80vh;width:90%;display:flex;flex-direction:column;box-shadow:var(--glow-cyan)}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-bottom:1px solid var(--border-color)}.modal-header h2{margin:0;color:var(--accent-cyan)}.close-btn{background:transparent;border:none;color:var(--text-primary);font-size:1.5rem;cursor:pointer;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center}.close-btn:hover{color:var(--accent-magenta)}.spell-palette{padding:1rem;overflow-y:auto;max-height:60vh}.spell-category{margin-bottom:1.5rem}.spell-category h3{margin:0 0 .5rem;color:var(--accent-purple);font-size:.875rem;text-transform:uppercase}.palette-spell{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:4px;padding:.75rem;margin-bottom:.5rem;cursor:pointer;transition:all .2s}.palette-spell:hover{border-color:var(--accent-cyan);box-shadow:var(--glow-cyan);transform:translate(4px)}.palette-spell h4{margin:0 0 .25rem;color:var(--text-primary);font-size:1rem}.palette-spell p{margin:0;font-size:.875rem;color:var(--text-secondary)}
