*{box-sizing:border-box}body{margin:0;min-height:100vh;background:#f7f5f2}#root{min-height:100vh}button,input,textarea{font-family:inherit}:root{color-scheme:light;font-family:IBM Plex Sans,Segoe UI,sans-serif}.app{display:flex;flex-direction:column;height:100vh;background:linear-gradient(135deg,#f7f5f2,#eef1f6);color:#141414}.auth-screen{align-items:center}.profile-screen{align-items:stretch}.auth-card{margin:80px auto;width:min(420px,92vw);background:#fff;border-radius:16px;padding:24px;box-shadow:0 20px 40px #0000001f;display:flex;flex-direction:column;gap:12px}.auth-field{display:flex;flex-direction:column;gap:6px;font-size:12px;font-weight:600}.auth-field input{border:1px solid #d2d6de;border-radius:10px;padding:10px 12px;font-size:14px}.auth-actions{display:flex;gap:10px;justify-content:flex-end}.auth-link{border:none;background:transparent;color:#325c9b;text-align:left;padding:0;font-size:13px;cursor:pointer}.auth-link:disabled{opacity:.6;cursor:default}.support-fab{position:fixed;right:20px;bottom:20px;z-index:60;border:none;border-radius:999px;background:#111;color:#fff;font-weight:700;letter-spacing:.04em;padding:12px 18px;cursor:pointer;box-shadow:0 10px 24px #00000047}.support-overlay{position:fixed;inset:0;z-index:70;background:#0006;display:flex;align-items:flex-end;justify-content:flex-end;padding:20px}.support-modal{width:min(540px,96vw);background:#fff;border-radius:16px;padding:16px;box-shadow:0 26px 48px #0000004d;display:flex;flex-direction:column;gap:12px}.support-header{display:flex;align-items:center;justify-content:space-between;gap:10px}.support-header h3{margin:0}.support-field{display:flex;flex-direction:column;gap:6px;font-weight:600;font-size:12px}.support-field textarea{border:1px solid #d2d6de;border-radius:10px;padding:10px 12px;font-size:14px;resize:vertical}.support-upload-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.support-upload-button{display:inline-flex}.support-upload-count{color:#4d5663;font-size:12px;font-weight:600}.support-files{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.support-file{border:1px solid #dfe4eb;border-radius:12px;padding:8px;display:flex;flex-direction:column;gap:6px}.support-file img{width:100%;height:90px;object-fit:cover;border-radius:8px}.support-file-meta{font-size:12px;line-height:1.3;color:#2b3544;word-break:break-word}.support-remove{align-self:flex-start;border:none;background:transparent;color:#7d0c0c;cursor:pointer;font-size:12px;padding:0}.auth-error{background:#ffe8e8;color:#7d0c0c;border:1px solid #f3bcbc;border-radius:10px;padding:8px 10px;font-size:12px}.auth-success{background:#e7f6ee;color:#1e5a3e;border:1px solid #bfe4ce;border-radius:10px;padding:8px 10px;font-size:12px}.app-header{display:flex;justify-content:space-between;align-items:center;padding:12px 20px;background:#fff;border-bottom:1px solid #e5e5e5}.left-actions{display:flex;gap:10px;align-items:center}.back-button{font-weight:600}.header-right{display:flex;align-items:center;gap:10px}.lang-switch{display:inline-flex;align-items:center;gap:4px;padding:4px;background:#f4f4f4;border-radius:999px}.lang-button{border:none;background:transparent;padding:4px 8px;border-radius:999px;cursor:pointer;font-size:16px;line-height:1}.lang-button.active{background:#fff;box-shadow:0 4px 10px #0000001f}.tab-bar{display:flex;gap:6px;background:#f4f4f4;padding:6px;border-radius:999px}.tab-button{border:none;background:transparent;padding:6px 14px;border-radius:999px;font-weight:600;cursor:pointer;color:#333}.tab-button.active{background:#fff;box-shadow:0 4px 10px #0000001f}.status{font-weight:600;padding:6px 12px;border-radius:999px;background:#ecf5ec;color:#155724}.status-error{background:#fdeaea;color:#7d0c0c}.app-body{flex:1;display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:12px;overflow:hidden}.profile-body{width:100%;display:flex;justify-content:center;padding:24px}.profile-card{width:min(760px,92vw);background:#fff;border-radius:16px;padding:20px;box-shadow:0 20px 40px #0000001a;display:flex;flex-direction:column;gap:16px}.profile-greeting{font-size:22px;font-weight:700;text-align:center}.profile-header{display:flex;justify-content:space-between;align-items:center;gap:12px}.profile-header h3{margin:0}.profile-header p{margin:4px 0 0;color:#5a616b}.profile-header-actions{display:inline-flex;gap:8px;align-items:center}.profile-list{display:flex;flex-direction:column;gap:8px}.profile-trash-footer{display:flex;justify-content:flex-end}.profile-search{border:1px solid #d2d6de;border-radius:10px;padding:10px 12px;font-size:14px}.profile-item{border:1px solid #e1e5ee;border-radius:12px;padding:12px 14px;display:flex;justify-content:space-between;align-items:center;background:#f9fafc;cursor:pointer;text-align:left;position:relative;transition:opacity .2s ease,transform .25s ease,max-height .25s ease,margin .25s ease,padding .25s ease;max-height:80px}.profile-item:hover{background:#eef2f7}.trash-item{cursor:default}.profile-item.deleting{opacity:0;transform:translateY(24px) scale(.98);max-height:0;margin-top:0;margin-bottom:0;padding-top:0;padding-bottom:0;pointer-events:none}.profile-item-title{font-weight:600}.profile-item-artist{font-weight:400;color:#6a717c}.profile-item-meta{font-size:12px;color:#6a717c}.profile-delete{border:none;background:transparent;color:#b11b1b;font-size:0;opacity:0;transition:opacity .15s ease;display:inline-flex;align-items:center;justify-content:center;padding:6px;border-radius:8px;cursor:pointer}.profile-item-actions{display:inline-flex;align-items:center;gap:6px}.profile-restore{border:none;background:transparent;font-size:0;opacity:0;transition:opacity .15s ease;display:inline-flex;align-items:center;justify-content:center;padding:6px;border-radius:8px;cursor:pointer}.profile-restore-icon{width:16px;height:16px;display:block;filter:brightness(.35)}.profile-delete:disabled{opacity:.35;cursor:not-allowed}.profile-item:hover .profile-delete,.profile-item:hover .profile-restore{opacity:1}.profile-delete:hover{background:#b11b1b14}.profile-restore:hover{background:#283c5a14}.profile-delete-icon{width:16px;height:16px;display:block}.profile-empty{padding:16px;border:1px dashed #d2d6de;border-radius:12px;color:#6a717c;text-align:center}.trash-button{padding:8px 14px;background:#fff;color:#b11b1b;gap:8px;display:inline-flex;align-items:center;border:1px solid #b11b1b}.trash-button:hover{background:#b11b1b;color:#fff}.trash-button-icon{width:16px;height:16px;display:block;filter:none}.trash-button:hover .trash-button-icon{filter:brightness(0) invert(1)}.trash-note{margin:0;color:#6a717c;font-size:13px}.trash-header{justify-content:flex-start;gap:12px}.pane{background:#fff;border-radius:12px;border:1px solid #dedede;box-shadow:0 8px 18px #0000000f;overflow:hidden;display:flex;flex-direction:column}.left-pane{padding:0}.editor-pane{display:flex;flex-direction:column;height:100%}.editor-code{position:relative;flex:1;background:#0f1115}.editor-toolbar{display:flex;gap:8px;padding:10px 12px;background:#0f1115;border-bottom:1px solid rgba(255,255,255,.08);position:relative}.editor-toolbar .ghost-button{background:#1b1f26;color:#f2f4f8;border:1px solid rgba(255,255,255,.08)}.editor-menu{position:relative}.editor-icon-button{display:inline-flex;align-items:center;justify-content:center;padding:6px 8px}.editor-icon{width:16px;height:16px;display:block}.editor-menu-popover{position:absolute;top:40px;right:0;background:#1b1f26;border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:10px 12px;color:#f2f4f8;min-width:180px;z-index:5;box-shadow:0 10px 24px #0006}.editor-menu-popover label{display:flex;flex-direction:column;gap:6px;font-size:12px}.editor-menu-popover input{background:#0f1115;border:1px solid rgba(255,255,255,.15);border-radius:6px;padding:6px 8px;color:#f2f4f8}.editor-menu-hint{margin-top:8px;font-size:11px;color:#9aa3af}.editor-textarea{flex:1;width:100%;height:100%;border:none;resize:none;padding:16px;font-family:IBM Plex Mono,SFMono-Regular,monospace;font-size:14px;background:transparent;color:transparent;line-height:1.5;caret-color:#f2f4f8;position:relative;z-index:1;white-space:pre-wrap;word-break:break-word;overflow-wrap:anywhere;box-sizing:border-box}.editor-textarea:focus{outline:2px solid #4c7fff;outline-offset:-2px}.editor-highlight{position:absolute;inset:0;padding:16px;margin:0;font-family:IBM Plex Mono,SFMono-Regular,monospace;font-size:14px;line-height:1.5;white-space:pre-wrap;word-break:break-word;overflow-wrap:anywhere;box-sizing:border-box;color:#dfe6f0;pointer-events:none;overflow:auto}.editor-textarea.has-hover{cursor:grab}.editor-textarea.dragging{cursor:grabbing;caret-color:transparent}.editor-drag-ghost{position:fixed;z-index:5;background:#1b1f26eb;color:#f2f4f8;border:1px solid rgba(255,255,255,.2);border-radius:8px;padding:6px 10px;font-family:IBM Plex Mono,SFMono-Regular,monospace;font-size:13px;pointer-events:none;box-shadow:0 12px 24px #00000059;white-space:pre}.token-drop{display:inline-block;width:2px;height:1.2em;background:#4c7fff;border-radius:2px;vertical-align:-.2em;margin:0 1px}.token-brace-colon{color:#8fd3a6}.token-brace-plain{color:#c7a7f2}.token-chord{color:#f1a1a8}.token-hover{background:#ffffff14;border-radius:4px;box-shadow:0 0 0 1px #ffffff40}.preview-pane{background:#f9fafc;position:relative}.preview-scroll{overflow:auto;padding:16px;height:100%}.preview-status,.preview-empty{padding:10px;text-align:center;color:#6b6b6b}.preview-status.floating{position:absolute;top:16px;right:16px;background:#ffffffe6;color:#1a1a1a;border:1px solid #e1e1e1;border-radius:999px;padding:8px 14px;box-shadow:0 8px 18px #00000026;z-index:2}.preview-warning.floating{position:absolute;top:16px;left:16px;background:#fff5e6f2;color:#7a3d00;border:1px solid #f0d7b0;border-radius:999px;padding:8px 14px;box-shadow:0 8px 18px #00000026;z-index:2}.preview-page{width:100%;margin-bottom:16px;box-shadow:0 12px 24px #0000001a;border-radius:6px}.error-panel{background:#fff;padding:10px 20px;border-top:1px solid #e5e5e5;max-height:160px;overflow:auto}.error-panel ul{list-style:none;padding:0;margin:6px 0 0}.error-panel li{margin-bottom:6px}.diag-error button{color:#7d0c0c}.import-modal{width:min(720px,92vw)}.import-body{display:flex;flex-direction:column;gap:18px}.import-section h3{margin:0 0 6px}.import-section p{margin:0 0 12px;color:#5a616b}.import-dropzone{border:2px dashed #c9d3e0;border-radius:16px;padding:18px;display:flex;align-items:center;justify-content:space-between;gap:12px;background:#f7f8fb}.import-dropzone.disabled{opacity:.6;pointer-events:none}.import-dropzone-text{font-weight:600;color:#3b4250}.import-file-list{margin-top:12px;background:#f4f6fb;border-radius:12px;padding:10px 12px}.import-file-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px;font-weight:600}.import-file-list ul{list-style:none;padding:0;margin:0;display:grid;gap:4px;color:#4a515c}.import-textarea{width:100%;min-height:140px;border-radius:12px;border:1px solid #d4dbe7;padding:12px;font-family:IBM Plex Mono,SFMono-Regular,monospace;font-size:13px;resize:vertical}.import-textarea:disabled{background:#f4f4f4;color:#8c96a6}.import-text-actions{margin-top:6px}.import-footer{display:flex;flex-direction:column;gap:12px;align-items:stretch}.import-warning{background:#fff3e6;border:1px solid #f0d7b0;color:#7a3d00;border-radius:12px;padding:12px;display:flex;align-items:center;justify-content:space-between;gap:12px}.import-error{background:#ffe8e8;color:#7d0c0c;border:1px solid #f3bcbc;border-radius:12px;padding:10px 12px;display:flex;justify-content:space-between;align-items:center;gap:12px}.import-error-close{border:none;background:transparent;font-size:18px;cursor:pointer;color:inherit}.import-summary{background:#eef4ff;border:1px solid #cddaf6;border-radius:12px;padding:10px 12px;color:#2d3e5a}.import-summary ul{margin:8px 0 0 18px;padding:0}.diag-warning button{color:#8a6d3b}.empty-state{color:#7a7a7a}.ghost-button,.primary-button,.link-button{border:none;cursor:pointer;font-weight:600;border-radius:6px;padding:8px 14px}.ghost-button{background:#f1f1f1}.primary-button{background:#4c7fff;color:#fff}.primary-button:disabled{opacity:.5;cursor:not-allowed}.link-button{background:transparent;padding:0;font-weight:500;text-align:left}.panel-backdrop,.modal-backdrop{position:fixed;inset:0;background:#0f111566;display:flex;align-items:center;justify-content:center;z-index:10}.options-panel{background:#fff;padding:20px;width:100%;max-height:none;overflow:auto}.options-header{display:flex;justify-content:space-between;align-items:center}.options-section{margin-top:16px}.options-subsection{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:#666;margin:6px 0 8px}.options-grid{display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}.elements-grid{display:grid;gap:14px}.settings-card{border:1px solid #e0e0e0;border-radius:10px;padding:16px 18px;background:#fff;box-shadow:0 18px 30px #00000014;display:grid;gap:12px}.page-setup-card{border:1px solid #e0e0e0;border-radius:10px;padding:16px 18px;background:#fff;box-shadow:0 18px 30px #00000014}.page-setup-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr);gap:8px;min-height:280px;align-items:center;justify-items:center}.page-setup-cell{display:flex;flex-direction:column;align-items:center;gap:6px}.page-setup-label{font-size:12px;font-weight:600;color:#4b5563;text-transform:uppercase;letter-spacing:.06em}.page-setup-cell.top{grid-column:2 / 3;grid-row:1 / 2}.page-setup-cell.right{grid-column:3 / 4;grid-row:2 / 3}.page-setup-cell.bottom{grid-column:2 / 3;grid-row:3 / 4}.page-setup-cell.left{grid-column:1 / 2;grid-row:2 / 3}.page-setup-center{grid-column:2 / 3;grid-row:2 / 3;width:120px;height:160px;display:flex;align-items:center;justify-content:center}.page-setup-center img{max-width:100%;max-height:100%;border-radius:6px;box-shadow:0 8px 16px #0000001f}.element-card{border:1px solid #e0e0e0;border-radius:10px;padding:16px 18px;background:#fff;box-shadow:0 18px 30px #00000014}.element-title{font-weight:700;font-size:20px;margin-bottom:8px;color:#1b1e23}.element-divider{height:1px;background:#e3e6eb;margin:8px 0 12px}.style-editor{display:flex;flex-direction:column;gap:12px}.style-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:12px 16px;align-items:center;width:100%}.style-cell{display:flex;align-items:center;gap:12px;min-width:0}.style-label{font-size:16px;color:#2a2f35;line-height:1;min-width:160px}.stepper{display:inline-flex;align-items:center;border-radius:10px;border:1px solid #d2d6de;overflow:hidden;background:#f1f3f6;height:42px;width:144px;justify-self:start}.stepper-btn{border:none;background:#e0e3e8;width:40px;padding:8px 0;font-size:16px;font-weight:700;cursor:pointer;color:#2a2f35;display:flex;align-items:center;justify-content:center;height:100%}.stepper-input{width:64px;border:none;text-align:center;background:#fff;font-weight:600;padding:0;line-height:1;height:100%;margin:0;outline:none;text-indent:0;appearance:textfield}.stepper-input::-webkit-outer-spin-button,.stepper-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.toggle-pill{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:12px;border:1px solid #d2d6de;background:#fff;font-weight:600;color:#30363d;cursor:pointer;min-height:42px;width:100%;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.toggle-pill input{width:16px;height:16px}.toggle-pill.active{background:#eef2ff;border-color:#c7d2fe}.color-pill{display:inline-flex;align-items:center;gap:10px;padding:8px 16px;border-radius:12px;border:1px solid #b9a2e6;background:#7d59c8;color:#fff;font-weight:600;cursor:pointer;justify-content:center;min-height:42px;width:100%;min-width:0}.color-pill input[type=color]{width:22px;height:22px;border:none;padding:0;background:transparent}.color-pill input[type=color]::-webkit-color-swatch{border:none;border-radius:50%}@media(max-width:900px){.style-grid{grid-template-columns:1fr}.style-cell{justify-content:flex-start}}.checkbox-row{display:flex;align-items:center;gap:8px}.modal{background:#fff;width:min(720px,90vw);border-radius:14px;padding:20px;box-shadow:0 30px 50px #0000004d}.modal-header,.modal-footer{display:flex;justify-content:space-between;align-items:center}.modal-body{margin:16px 0;max-height:60vh;overflow:auto}.key-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:8px}.pane-content{padding:16px;overflow:auto;height:100%}.meta-bar{display:grid;grid-template-columns:repeat(3,minmax(180px,1fr));gap:12px;margin-bottom:12px}.meta-field{display:flex;flex-direction:column;gap:6px;font-size:12px}.meta-field label{display:flex;flex-direction:column;gap:6px;font-weight:600;color:#2a2f35}.meta-field input,.meta-field textarea{border:1px solid #d2d6de;border-radius:8px;padding:8px 10px;font-size:13px;font-family:inherit}.meta-field textarea{resize:vertical}.meta-field.disabled input,.meta-field.disabled textarea{background:#f2f2f2;color:#8c8c8c}.meta-hint{font-size:11px;color:#a33}.page-setup{display:flex;flex-direction:column;gap:12px}.page-setup-editor{display:flex;flex-direction:column;gap:12px;height:100%}.page-setup-toolbar{display:flex;gap:12px;align-items:center}.page-setup-toolbar input{margin-left:8px;width:80px}.page-mockup{position:relative;width:100%;max-width:none;height:100%;aspect-ratio:210 / 297;border:1px solid #d7d7d7;background:repeating-linear-gradient(0deg,rgba(0,0,0,.03),rgba(0,0,0,.03) 1px,transparent 1px,transparent 16px),repeating-linear-gradient(90deg,rgba(0,0,0,.03),rgba(0,0,0,.03) 1px,transparent 1px,transparent 16px),#fff;border-radius:12px;margin:0 auto}.mockup-item{position:absolute;transform:translateY(-50%);background:#111;color:#fff;font-size:12px;padding:4px 8px;border-radius:999px;cursor:grab;-webkit-user-select:none;user-select:none}.mockup-item:active{cursor:grabbing}.export-panel{display:flex;flex-direction:column;gap:12px}.export-header{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}.export-presets{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.preset-select{border:1px solid #d2d6de;border-radius:8px;padding:6px 10px;font-size:13px;background:#fff}.export-section{display:flex;flex-direction:column;gap:8px}.export-section h3{margin:0}.export-filename input{width:100%;border:1px solid #d2d6de;border-radius:10px;padding:10px 12px;font-size:13px;font-family:IBM Plex Mono,SFMono-Regular,monospace}.export-token-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.export-preview{margin-top:10px;border:1px solid #d2d6de;border-radius:10px;padding:10px 12px;display:flex;flex-direction:column;gap:4px;background:#f8fafc}.export-preview-label{font-size:11px;font-weight:600;color:#6a717c;text-transform:uppercase;letter-spacing:.06em}.export-preview-text{font-family:IBM Plex Mono,SFMono-Regular,monospace;font-size:13px;color:#1f2732}.token-pill{border:1px solid #d8dde6;background:#f5f7fb;color:#2f3640;border-radius:999px;padding:4px 10px;font-size:12px;cursor:grab}.token-pill:active{cursor:grabbing}.key-grid-rows{display:flex;flex-direction:column;gap:6px}.key-row{display:grid;grid-template-columns:repeat(3,minmax(80px,1fr));gap:8px}.panel-actions{margin-top:12px}@media(max-width:900px){.app-body{grid-template-columns:1fr;grid-template-rows:1fr 1fr}}
