.interactive-banner{position:relative;overflow:hidden;user-select:none}.interactive-banner-image{transition:transform .2s ease-out;will-change:transform}.interactive-banner-image.dragging{transition:none;cursor:grabbing!important}.interactive-banner-overlay{position:absolute;inset:0;background:rgba(0,0,0,.2);border:2px dashed #60a5fa;pointer-events:none;opacity:0;transition:opacity .3s ease}.interactive-banner-overlay.visible{opacity:1}.interactive-banner-hint{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:rgba(0,0,0,.8);color:white;padding:.75rem 1.5rem;border-radius:9999px;font-size:.875rem;font-weight:500;backdrop-filter:blur(4px);pointer-events:none;opacity:0;transition:opacity .3s ease}.interactive-banner-hint.visible{opacity:1}.interactive-banner-controls{position:absolute;bottom:1rem;left:50%;transform:translateX(-50%);z-index:20;opacity:0;transition:opacity .3s ease}.interactive-banner-controls.visible{opacity:1}.interactive-banner-controls-panel{background:rgba(0,0,0,.9);backdrop-filter:blur(8px);border-radius:.75rem;padding:1rem;display:flex;align-items:center;gap:1rem;border:1px solid rgba(255,255,255,.1);box-shadow:0 10px 25px rgba(0,0,0,.5)}.interactive-banner-position{color:white;font-size:.875rem;font-weight:500;min-width:3rem;text-align:center}.interactive-banner-arrows{display:flex;gap:.5rem}.interactive-banner-arrow{padding:.5rem;background:rgba(75,85,99,.8);color:white;border:none;border-radius:.375rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.interactive-banner-arrow:hover{background:rgba(107,114,128,.9);transform:translateY(-1px)}.interactive-banner-arrow:active{transform:translateY(0)}.interactive-banner-actions{display:flex;gap:.5rem}.interactive-banner-save{padding:.5rem 1rem;background:#059669;color:white;border:none;border-radius:.375rem;cursor:pointer;font-size:.875rem;font-weight:500;transition:all .2s ease;display:flex;align-items:center;gap:.5rem}.interactive-banner-save:hover{background:#047857;transform:translateY(-1px)}.interactive-banner-save:disabled{opacity:.5;cursor:not-allowed;transform:none}.interactive-banner-cancel{padding:.5rem 1rem;background:rgba(75,85,99,.8);color:white;border:none;border-radius:.375rem;cursor:pointer;font-size:.875rem;font-weight:500;transition:all .2s ease;display:flex;align-items:center;gap:.5rem}.interactive-banner-cancel:hover{background:rgba(107,114,128,.9);transform:translateY(-1px)}.interactive-banner-cancel:disabled{opacity:.5;cursor:not-allowed;transform:none}@media (max-width:768px){.interactive-banner-controls-panel{padding:.75rem;gap:.75rem;margin:0 1rem}.interactive-banner-position{font-size:.75rem;min-width:2.5rem}.interactive-banner-arrow{padding:.375rem}.interactive-banner-cancel,.interactive-banner-save{padding:.375rem .75rem;font-size:.75rem}.interactive-banner-hint{font-size:.75rem;padding:.5rem 1rem}}@media (hover:none) and (pointer:coarse){.interactive-banner-arrow,.interactive-banner-cancel,.interactive-banner-save{min-height:44px;min-width:44px}.interactive-banner-controls-panel{gap:1rem}}@media (prefers-contrast:high){.interactive-banner-overlay{border-color:#ffffff;background:rgba(0,0,0,.5)}.interactive-banner-controls-panel{background:#000000;border-color:#ffffff}.interactive-banner-hint{background:#000000;border:1px solid #ffffff}}@media (prefers-reduced-motion:reduce){.interactive-banner-arrow,.interactive-banner-cancel,.interactive-banner-controls,.interactive-banner-hint,.interactive-banner-image,.interactive-banner-overlay,.interactive-banner-save{transition:none}}.interactive-banner-arrow:focus,.interactive-banner-cancel:focus,.interactive-banner-save:focus{outline:2px solid #60a5fa;outline-offset:2px}.interactive-banner-loading{position:absolute;inset:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;color:white;font-size:.875rem;backdrop-filter:blur(2px)}.interactive-banner-loading:after{content:"";width:1rem;height:1rem;border:2px solid transparent;border-top-color:currentcolor;border-radius:50%;animation:spin 1s linear infinite;margin-left:.5rem}@keyframes spin{to{transform:rotate(1turn)}}.ProseMirror{outline:none;min-height:300px;padding:1rem;background:#1e1e1e;color:white;border-radius:.5rem;border:2px solid #374151;transition:border-color .2s ease}.ProseMirror:focus{box-shadow:0 0 0 4px rgba(139,92,246,.1)}.ProseMirror.ProseMirror-focused,.ProseMirror:focus{border-color:#8b5cf6}.ProseMirror h1{font-size:2rem}.ProseMirror h1,.ProseMirror h2{font-weight:700;margin:1rem 0 .5rem;color:#f3f4f6}.ProseMirror h2{font-size:1.5rem}.ProseMirror h3{font-size:1.25rem;font-weight:700;margin:1rem 0 .5rem;color:#f3f4f6}.ProseMirror p{margin:.5rem 0;line-height:1.6}.ProseMirror strong{font-weight:700;color:#f9fafb}.ProseMirror em{font-style:italic;color:#e5e7eb}.ProseMirror u{text-decoration:underline}.ProseMirror s{text-decoration:line-through}.ProseMirror ul{list-style-type:disc}.ProseMirror ol,.ProseMirror ul{margin:.5rem 0;padding-left:1.5rem}.ProseMirror ol{list-style-type:decimal}.ProseMirror li{margin:.25rem 0;line-height:1.5}.ProseMirror li p{margin:0}.ProseMirror a{color:#60a5fa;text-decoration:underline;transition:color .2s ease}.ProseMirror a:hover{color:#93c5fd}.ProseMirror img{max-width:100%;height:auto;border-radius:.5rem;margin:.5rem 0;box-shadow:0 4px 6px -1px rgba(0,0,0,.1)}.ProseMirror .text-left{text-align:left}.ProseMirror .text-center{text-align:center}.ProseMirror .text-right{text-align:right}.ProseMirror .text-justify{text-align:justify}.ProseMirror blockquote{border-left:4px solid #8b5cf6;padding-left:1rem;margin:1rem 0;font-style:italic;color:#d1d5db;background:rgba(139,92,246,.1);border-radius:0 .5rem .5rem 0}.ProseMirror code{background:#374151;color:#f9fafb;padding:.125rem .25rem;border-radius:.25rem;font-family:Courier New,monospace;font-size:.875rem}.ProseMirror pre{background:#1f2937;color:#f9fafb;padding:1rem;border-radius:.5rem;overflow-x:auto;margin:1rem 0;border:1px solid #374151}.ProseMirror pre code{background:transparent;padding:0;border-radius:0}.ProseMirror table{border-collapse:collapse;margin:1rem 0;width:100%;background:#1f2937;border-radius:.5rem;overflow:hidden}.ProseMirror td,.ProseMirror th{border:1px solid #374151;padding:.5rem;text-align:left}.ProseMirror th{background:#374151;font-weight:700;color:#f9fafb}.ProseMirror td{color:#e5e7eb}.ProseMirror p.is-editor-empty:first-child:before{content:attr(data-placeholder);float:left;color:#6b7280;pointer-events:none;height:0}.ProseMirror ::selection{background:rgba(139,92,246,.3)}.ProseMirror ::-moz-selection{background:rgba(139,92,246,.3)}.rich-text-toolbar{background:linear-gradient(135deg,#374151,#1f2937);border:2px solid #4b5563;border-bottom:none;border-radius:.75rem .75rem 0 0;padding:.75rem;display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.rich-text-toolbar button{background:#4b5563;color:#e5e7eb;border:1px solid #6b7280;border-radius:.375rem;padding:.5rem;min-width:2.5rem;height:2.5rem;display:flex;align-items:center;justify-content:center;transition:all .2s ease;cursor:pointer}.rich-text-toolbar button:hover{background:#6b7280;border-color:#8b5cf6;transform:translateY(-1px)}.rich-text-toolbar button.is-active{background:#8b5cf6;border-color:#a855f7;color:white;box-shadow:0 2px 4px rgba(139,92,246,.3)}.rich-text-toolbar button:disabled{opacity:.5;cursor:not-allowed;transform:none}.rich-text-toolbar button:disabled:hover{background:#4b5563;border-color:#6b7280;transform:none}.rich-text-toolbar .toolbar-separator{width:1px;height:1.5rem;background:#6b7280;margin:0 .25rem}.color-picker-button{position:relative}.color-picker-dropdown{position:absolute;top:100%;left:0;background:#1f2937;border:2px solid #4b5563;border-radius:.5rem;padding:.5rem;display:grid;grid-template-columns:repeat(6,1fr);gap:.25rem;z-index:50;box-shadow:0 10px 25px rgba(0,0,0,.3)}.color-picker-dropdown button{width:1.5rem;height:1.5rem;border-radius:.25rem;border:1px solid #6b7280;cursor:pointer;transition:transform .1s ease}.color-picker-dropdown button:hover{transform:scale(1.1);border-color:white}@media (max-width:768px){.rich-text-toolbar{padding:.5rem;gap:.25rem}.rich-text-toolbar button{min-width:2rem;height:2rem;padding:.25rem}.ProseMirror{min-height:200px;padding:.75rem}}.rich-text-editor-container{animation:fadeIn .3s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.rich-text-editor-error .ProseMirror,.rich-text-editor-error .rich-text-toolbar{border-color:#ef4444}.rich-text-editor-loading{opacity:.7;pointer-events:none}.rich-text-editor-loading .rich-text-toolbar{background:#374151}.rich-text-editor-loading .ProseMirror{background:#1f2937}