.custom-page{padding:2rem 0}.custom-page-title{font-size:1.5rem;font-weight:700;margin-bottom:1.5rem;color:var(--gray-900)}.custom-page-content{display:grid;grid-template-columns:300px 1fr;gap:2rem}@media (max-width:768px){.custom-page-content{grid-template-columns:1fr}}.custom-page-sidebar{display:flex;flex-direction:column;gap:1.5rem}.sidebar-section{background-color:var(--background-color);border:1px solid var(--border-color);border-radius:.5rem;padding:1rem}.sidebar-section-title{font-size:1rem;font-weight:600;margin-bottom:1rem;color:var(--gray-800)}.element-actions,.element-buttons,.layout-actions{display:flex;flex-direction:column;gap:.5rem}.canvas-container{position:relative;background-color:var(--gray-100);border:1px solid var(--border-color);border-radius:.5rem;overflow:hidden;margin-bottom:2rem}.canvas-element{position:absolute;cursor:move;user-select:none}.text-element{background-color:rgba(255,255,255,.8);padding:.5rem}.image-element,.text-element{display:flex;align-items:center;justify-content:center;border:1px dashed var(--gray-400);border-radius:.25rem}.image-element{background-color:rgba(200,200,255,.3);flex-direction:column}.canvas-element.selected{border:2px solid var(--primary-color);box-shadow:0 0 0 2px rgba(99,102,241,.3)}.resize-handle{position:absolute;width:10px;height:10px;background-color:var(--primary-color);border:1px solid white;border-radius:50%;z-index:10}.resize-handle-ne{top:-5px;right:-5px;cursor:ne-resize}.resize-handle-se{bottom:-5px;right:-5px;cursor:se-resize}.resize-handle-sw{bottom:-5px;left:-5px;cursor:sw-resize}.resize-handle-nw{top:-5px;left:-5px;cursor:nw-resize}.text-content{overflow:hidden}.image-placeholder,.text-content{width:100%;height:100%;display:flex;align-items:center;justify-content:center;text-align:center}.image-placeholder{flex-direction:column}.image-category{font-size:.75rem;font-weight:600;color:var(--gray-600);margin-bottom:.25rem}.image-description{font-size:.875rem;color:var(--gray-800)}.prompt-container{margin-top:1rem}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background-color:var(--background-color);border-radius:.5rem;padding:1.5rem;width:90%;max-width:500px;box-shadow:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -2px rgba(0,0,0,.05)}.modal-title{font-size:1.25rem;font-weight:600;color:var(--gray-900)}.modal-content,.modal-title{margin-bottom:1.5rem}.modal-actions{display:flex;justify-content:flex-end;gap:.75rem}.color-input-container{margin-bottom:1rem}.color-input-label{display:block;font-size:.875rem;font-weight:500;margin-bottom:.25rem;color:var(--gray-700)}.color-input{width:100%;height:2.5rem;padding:0;cursor:pointer}.color-input,.layout-list{border:1px solid var(--border-color);border-radius:.375rem}.layout-list{max-height:300px;overflow-y:auto}.layout-item{padding:.75rem 1rem;border-bottom:1px solid var(--border-color);cursor:pointer;transition:background-color .2s ease}.layout-item:last-child{border-bottom:none}.layout-item:hover{background-color:var(--gray-100)}.layout-item.selected{background-color:var(--primary-color);color:white}.layout-name{font-weight:500;margin-bottom:.25rem}.layout-date{font-size:.75rem;color:var(--gray-500)}.layout-item.selected .layout-date{color:rgba(255,255,255,.8)}.no-layouts-message{text-align:center;padding:1rem;color:var(--gray-500)}.text-parts-tabs{display:flex;gap:.25rem;margin-bottom:1rem;overflow-x:auto;padding-bottom:.5rem}.text-part-tab{padding:.5rem .75rem;border:1px solid var(--border-color);border-radius:.25rem;background-color:var(--background-color);font-size:.875rem;cursor:pointer;white-space:nowrap}.text-part-tab.active{background-color:var(--primary-color);color:white;border-color:var(--primary-color)}.text-part-tab.add-tab{background-color:var(--gray-100);font-weight:700}.text-part-tab.add-tab:hover{background-color:var(--gray-200)}