*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;line-height:1.6;color:#333;overflow-x:hidden}button{cursor:pointer}.generator-container{min-height:100vh;padding:2rem;transition:background-color .3s ease}@media(max-width:768px){.generator-container{padding:1rem}}.generator-title{text-align:center;margin-bottom:2rem;font-size:2.5rem}@media(max-width:768px){.generator-title{font-size:2rem;margin-bottom:1.5rem}}.generator-layout{display:flex;gap:2rem;max-width:1400px;margin:0 auto}@media(max-width:1024px){.generator-layout{flex-direction:column}}.controls-section{flex:1;display:flex;flex-direction:column;gap:2rem;max-width:100%}.control-group{background-color:hsla(0,0%,100%,.9);border-radius:12px;padding:1.5rem;box-shadow:0 4px 6px rgba(0,0,0,.1);overflow:hidden}.control-group h2{margin-bottom:1.5rem;padding-bottom:.5rem;border-bottom:1px solid #eee}.control-item{margin-bottom:1.2rem}.control-item:last-child{margin-bottom:0}.control-item label{display:block;margin-bottom:.5rem;font-weight:500;color:#444}.control-item input[type=text],.control-item select{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:6px;font-size:1rem}.control-item input[type=text]:focus,.control-item select:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 2px rgba(99,102,241,.2)}.control-item input[type=range]{width:100%;height:8px;-webkit-appearance:none;appearance:none;background:#e5e7eb;border-radius:8px}.control-item input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;background-color:#6366f1;border-radius:50%;cursor:pointer}.control-item input[type=range]::-moz-range-thumb{width:18px;height:18px;background-color:#6366f1;border:none;border-radius:50%;cursor:pointer}.control-item input[type=range]:focus{outline:none}.control-item input[type=range]:disabled{opacity:.5;cursor:not-allowed}.control-item input[type=range]:disabled::-webkit-slider-thumb{background-color:#aaa}.control-item input[type=range]:disabled::-moz-range-thumb{background-color:#aaa}.control-item input[type=color]{-webkit-appearance:none;width:100%;height:40px;border:1px solid #ddd;border-radius:6px;padding:0;cursor:pointer}.control-item input[type=color]::-webkit-color-swatch-wrapper{padding:0}.control-item input[type=color]::-webkit-color-swatch{border:none;border-radius:4px}.control-item input[type=color]:disabled{opacity:.5;cursor:not-allowed}.shadows-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:.5rem;border-bottom:1px solid #eee}.shadow-controls{background-color:#f9fafb;padding:1rem;border-radius:8px;margin-bottom:1rem}.shadow-controls:last-child{margin-bottom:0}.shadow-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.shadow-header h3{font-size:1.1rem;font-weight:600}.shadow-actions{display:flex;align-items:center;gap:.5rem}.toggle{position:relative;display:inline-block;width:40px;height:24px}.toggle input{opacity:0;width:0;height:0}.toggle input:checked+.slider{background-color:#6366f1}.toggle input:focus+.slider{box-shadow:0 0 1px #6366f1}.toggle input:checked+.slider:before{transform:translateX(16px)}.toggle .slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#ccc;transition:.4s;border-radius:34px}.toggle .slider:before{position:absolute;content:"";height:16px;width:16px;left:4px;bottom:4px;background-color:#fff;transition:.4s;border-radius:50%}.add-shadow-btn,.copy-btn,.remove-shadow-btn,.reset-position-btn{padding:.5rem 1rem;border:none;border-radius:6px;font-weight:500;cursor:pointer;transition:background-color .2s ease}.add-shadow-btn:focus,.copy-btn:focus,.remove-shadow-btn:focus,.reset-position-btn:focus{outline:none}.add-shadow-btn:disabled,.copy-btn:disabled,.remove-shadow-btn:disabled,.reset-position-btn:disabled{opacity:.5;cursor:not-allowed}.add-shadow-btn{background-color:#6366f1;color:#fff}.add-shadow-btn:hover{background-color:#4f46e5}.remove-shadow-btn{background-color:#ef4444;color:#fff;font-size:.875rem}.remove-shadow-btn:hover{background-color:#dc2626}.reset-position-btn{background-color:#3b82f6;color:#fff;font-size:.8rem;padding:.25rem .5rem}.reset-position-btn:hover{background-color:#2563eb}.preview-section{flex:1;display:flex;flex-direction:column;gap:1.5rem;overflow-x:hidden}.preview-container{position:relative;transition:transform .1s ease;will-change:transform}.preview-header{background-color:hsla(0,0%,100%,.9);border-radius:12px 12px 0 0;box-shadow:0 4px 6px rgba(0,0,0,.1);overflow:hidden}.preview-drag-handle{padding:1rem 1.5rem;display:flex;justify-content:space-between;align-items:center;background-color:#f1f5f9;cursor:grab;user-select:none}.preview-drag-handle:active{cursor:grabbing}.preview-drag-handle span{font-weight:600}.preview-area{background-color:hsla(0,0%,100%,.9);padding:3rem;min-height:200px;display:flex;justify-content:center;align-items:center;box-shadow:0 4px 6px rgba(0,0,0,.1)}@media(max-width:768px){.preview-area{padding:2rem}}.preview-text{text-align:center;word-break:break-word;transition:all .3s ease;max-width:100%}.css-output{background-color:hsla(0,0%,100%,.9);border-radius:0 0 12px 12px;overflow:hidden;box-shadow:0 4px 6px rgba(0,0,0,.1)}.css-output .css-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background-color:#f9fafb;border-bottom:1px solid #eee}.css-output .css-header h3{font-size:1.1rem;font-weight:600}.css-output pre{padding:1.5rem;background-color:#f8fafc;overflow-x:auto;font-family:Source Code Pro,monospace;font-size:.9rem;line-height:1.5;color:#334155}.copy-btn{background-color:#f3f4f6;color:#4b5563}.copy-btn:hover{background-color:#e5e7eb}.copy-notification{position:fixed;bottom:20px;right:20px;background-color:#10b981;color:#fff;padding:.75rem 1.5rem;border-radius:8px;box-shadow:0 4px 6px rgba(0,0,0,.1);opacity:0;animation:fadeInOut 2s ease forwards}@keyframes fadeInOut{0%{opacity:0;transform:translateY(20px)}20%{opacity:1;transform:translateY(0)}80%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-20px)}}@media(max-width:768px){.shadow-header{flex-direction:column;align-items:flex-start;gap:.5rem}.shadow-actions{width:100%;justify-content:space-between}.preview-drag-handle{flex-direction:column;gap:.5rem;align-items:flex-start}.preview-drag-handle .reset-position-btn{width:100%}}.error-notification{background-color:#ef4444;color:#fff;padding:1rem;border-radius:8px;margin-bottom:1rem;display:flex;align-items:center;justify-content:space-between}.error-notification button{background:none;border:none;color:#fff;font-weight:700;font-size:1.2rem;cursor:pointer}