.messenger-container{display:flex;flex-direction:column;height:100vh;background:var(--color-background)}.messenger-header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;background:var(--color-card);border-bottom:1px solid var(--color-border);box-shadow:var(--shadow-sm)}.messenger-header h1{font-size:20px;font-weight:700;color:var(--color-text-primary);margin:0}.messenger-header .btn-back-home{padding:8px 16px;background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;font-size:14px;color:var(--color-text-secondary);transition:all .2s}.messenger-header .btn-back-home:hover{background:var(--color-background);border-color:var(--color-primary);color:var(--color-primary)}.messenger-header .header-info{font-size:14px;color:var(--color-text-secondary)}.messenger-messages{flex:1;overflow-y:auto;padding:24px;display:flex;flex-direction:column;gap:16px}.messenger-messages::-webkit-scrollbar{width:8px}.messenger-messages::-webkit-scrollbar-track{background:transparent}.messenger-messages::-webkit-scrollbar-thumb{background:#ddd;border-radius:4px}.messenger-messages::-webkit-scrollbar-thumb:hover{background:#ccc}.loading,.empty-state{text-align:center;padding:40px;color:var(--color-text-tertiary)}.message{display:flex;gap:12px;max-width:70%;animation:fadeIn .2s ease-in-out}.message-mine{align-self:flex-end;flex-direction:row-reverse}.message-other{align-self:flex-start}.message-avatar{width:40px;height:40px;border-radius:50%;overflow:hidden;flex-shrink:0}.message-avatar img{width:100%;height:100%;object-fit:cover}.avatar-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--color-primary);color:#fff;font-weight:700;font-size:16px}.message-content-wrapper{display:flex;flex-direction:column;gap:4px}.message-sender{font-size:12px;font-weight:600;color:var(--color-text-secondary);padding:0 12px}.message-bubble{position:relative;padding:12px 16px;border-radius:var(--radius-md);background:var(--color-card);box-shadow:var(--shadow-sm);word-wrap:break-word}.message-mine .message-bubble{background:var(--color-primary);color:#fff}.message-bubble p{margin:0;line-height:1.5;white-space:pre-wrap}.message-time{font-size:11px;color:#0006;margin-top:4px;text-align:right}.message-mine .message-time{color:#ffffffb3}.message-link a{color:var(--color-primary);text-decoration:underline;word-break:break-all}.message-mine .message-link a{color:#fff}.message-image{max-width:400px}.message-image img{width:100%;border-radius:var(--radius-md);cursor:pointer;transition:transform .2s}.message-image img:hover{transform:scale(1.02)}.message-image p{margin-top:8px}.message-file{display:flex;align-items:center;gap:12px;padding:8px;background:#0000000d;border-radius:var(--radius-sm)}.message-mine .message-file{background:#fff3}.file-icon{font-size:24px}.file-info{display:flex;flex-direction:column;gap:4px}.file-info a{color:var(--color-primary);text-decoration:none;font-weight:600}.message-mine .file-info a{color:#fff}.file-info small{font-size:11px;color:var(--color-text-tertiary)}.message-mine .file-info small{color:#ffffffb3}.messenger-input-wrapper{background:var(--color-card);border-top:1px solid var(--color-border);padding:16px 24px}.file-preview{position:relative;margin-bottom:12px;padding:12px;background:var(--color-background);border-radius:var(--radius-md);display:flex;align-items:center;gap:12px}.file-preview img{max-width:100px;max-height:100px;border-radius:var(--radius-sm);object-fit:cover}.file-preview-info{display:flex;flex-direction:column;gap:4px}.file-preview-info span{font-weight:600;color:var(--color-text-primary)}.file-preview-info small{font-size:12px;color:var(--color-text-tertiary)}.btn-cancel-file{position:absolute;top:8px;right:8px;width:24px;height:24px;border-radius:50%;background:var(--color-error);color:#fff;border:none;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:all .2s}.btn-cancel-file:hover{transform:scale(1.1)}.messenger-input{display:flex;gap:12px;align-items:center}.messenger-input input[type=text]{flex:1;padding:12px 16px;border:2px solid var(--color-border);border-radius:var(--radius-md);font-size:14px;outline:none;transition:all .2s}.messenger-input input[type=text]:focus{border-color:var(--color-primary);box-shadow:0 0 0 4px #0064ff1a}.btn-attach,.btn-send{padding:12px 20px;border:none;border-radius:var(--radius-md);cursor:pointer;font-weight:600;font-size:14px;transition:all .2s}.btn-attach{background:var(--color-background);color:var(--color-text-secondary);font-size:20px;padding:12px 16px}.btn-attach:hover{background:var(--color-border)}.btn-send{background:var(--color-primary);color:#fff}.btn-send:hover:not(:disabled){background:var(--color-primary-hover);transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-send:disabled{background:var(--color-border);color:var(--color-text-tertiary);cursor:not-allowed}.input-help{margin-top:8px;font-size:12px;color:var(--color-text-tertiary);text-align:center}@media (max-width: 768px){.messenger-messages{padding:16px}.message{max-width:85%}.messenger-input-wrapper{padding:12px 16px}.message-image{max-width:300px}}.ai-tools-wrapper{font-family:Noto Sans KR,sans-serif;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);min-height:100vh;color:#fff}.ai-tools-wrapper .container{max-width:1000px;margin:0 auto;padding:20px}.ai-tools-wrapper header{text-align:center;padding:30px 0 20px}.ai-tools-wrapper header h1{font-size:2.2rem;font-weight:700;background:linear-gradient(135deg,gold,#ffb347);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:10px}.ai-tools-wrapper .subtitle{font-size:1rem;color:#888;font-weight:300}.ai-tools-wrapper .sidebar-header{padding:16px 20px;background:#ffffff0d;border-bottom:1px solid rgba(255,255,255,.1)}.ai-tools-wrapper .sidebar-header h2{font-size:18px;font-weight:600;color:#fff;margin-top:12px;background:linear-gradient(135deg,gold,#ffb347);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.ai-tools-wrapper .btn-back-home{padding:10px 20px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;border-radius:8px;cursor:pointer;transition:all .3s ease;font-size:.9rem;width:100%;text-align:left}.ai-tools-wrapper .btn-back-home:hover{background:#ffd70033;border-color:gold}.ai-tools-wrapper .mode-tabs{display:flex;gap:10px;margin-bottom:20px;justify-content:center;flex-wrap:wrap}.ai-tools-wrapper .mode-tab{padding:12px 30px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:10px;color:#888;font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s ease;font-family:Noto Sans KR,sans-serif}.ai-tools-wrapper .mode-tab:hover{background:#ffd7001a;border-color:#ffd7004d;color:gold}.ai-tools-wrapper .mode-tab.active{background:linear-gradient(135deg,gold,#ffb347);border-color:transparent;color:#1a1a2e;font-weight:600}.ai-tools-wrapper main{background:#ffffff0d;border-radius:20px;padding:30px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1)}.ai-tools-wrapper .step-indicator{display:flex;align-items:center;justify-content:center;margin-bottom:30px;gap:10px}.ai-tools-wrapper .step{width:80px;height:80px;border-radius:50%;background:#ffffff1a;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:.9rem;font-weight:500;color:#666;transition:all .3s ease}.ai-tools-wrapper .step small{font-size:.7rem;font-weight:300}.ai-tools-wrapper .step.active{background:linear-gradient(135deg,gold,#ffb347);color:#1a1a2e}.ai-tools-wrapper .step.completed{background:#4caf50;color:#fff}.ai-tools-wrapper .step-line{width:50px;height:3px;background:#fff3}.ai-tools-wrapper .step-section{margin-bottom:20px}.ai-tools-wrapper .step-section h2{font-size:1.3rem;font-weight:500;margin-bottom:8px;color:gold}.ai-tools-wrapper .section-desc{font-size:.9rem;color:#888;margin-bottom:20px}.ai-tools-wrapper .upload-area{border:2px dashed rgba(255,255,255,.3);border-radius:15px;padding:40px 20px;text-align:center;cursor:pointer;transition:all .3s ease;min-height:200px;display:flex;align-items:center;justify-content:center;margin-bottom:20px;position:relative}.ai-tools-wrapper .upload-area:hover{border-color:gold;background:#ffd7000d}.ai-tools-wrapper .upload-area.dragover{border-color:gold;background:#ffd7001a}.ai-tools-wrapper .upload-placeholder{display:flex;flex-direction:column;align-items:center;gap:15px;color:#888}.ai-tools-wrapper .upload-icon{font-size:4rem}.ai-tools-wrapper .upload-preview{position:relative;display:inline-block}.ai-tools-wrapper .upload-preview img{max-width:100%;max-height:400px;border-radius:10px;object-fit:contain}.ai-tools-wrapper .remove-btn{position:absolute;top:-12px;right:-12px;width:32px;height:32px;border-radius:50%;background:#ff4757;border:none;color:#fff;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;box-shadow:0 2px 10px #0000004d}.ai-tools-wrapper .remove-btn:hover{background:#ff6b7a;transform:scale(1.1)}.ai-tools-wrapper .analysis-controls{max-height:500px;overflow-y:auto;padding:10px;background:#0003;border-radius:12px;margin-bottom:20px}.ai-tools-wrapper .analysis-item{background:#ffffff0d;border-radius:10px;padding:15px;margin-bottom:10px;border:1px solid rgba(255,255,255,.1)}.ai-tools-wrapper .analysis-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.ai-tools-wrapper .analysis-item-actions{display:flex;align-items:center;gap:10px}.ai-tools-wrapper .edit-btn{background:none;border:none;cursor:pointer;font-size:1rem;padding:4px 8px;border-radius:5px;transition:background .2s}.ai-tools-wrapper .edit-btn:hover{background:#ffd70033}.ai-tools-wrapper .analysis-item-title{font-weight:500;color:gold;font-size:.95rem;display:flex;align-items:center;gap:8px}.ai-tools-wrapper .modified-badge{font-size:.7rem;background:linear-gradient(135deg,#4caf50,#45a049);color:#fff;padding:2px 8px;border-radius:10px;font-weight:600}.ai-tools-wrapper .analysis-item.modified{border-color:#4caf5080}.ai-tools-wrapper .toggle-switch{position:relative;width:50px;height:26px}.ai-tools-wrapper .toggle-switch input{opacity:0;width:0;height:0}.ai-tools-wrapper .toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#444;transition:.3s;border-radius:26px}.ai-tools-wrapper .toggle-slider:before{position:absolute;content:"";height:20px;width:20px;left:3px;bottom:3px;background-color:#fff;transition:.3s;border-radius:50%}.ai-tools-wrapper input:checked+.toggle-slider{background:linear-gradient(135deg,gold,#ffb347)}.ai-tools-wrapper input:checked+.toggle-slider:before{transform:translate(24px)}.ai-tools-wrapper .analysis-item-content{font-size:.85rem;color:#aaa;line-height:1.5;white-space:pre-wrap;max-height:100px;overflow-y:auto}.ai-tools-wrapper .analysis-item.disabled .analysis-item-content{opacity:.4;text-decoration:line-through}.ai-tools-wrapper .analysis-item-edit{margin-top:10px}.ai-tools-wrapper .edit-textarea{width:100%;min-height:100px;padding:10px;background:#0000004d;border:1px solid rgba(255,215,0,.3);border-radius:8px;color:#fff;font-family:Noto Sans KR,sans-serif;font-size:.85rem;line-height:1.5;resize:vertical}.ai-tools-wrapper .edit-textarea:focus{outline:none;border-color:gold}.ai-tools-wrapper .edit-actions{display:flex;gap:10px;margin-top:10px;justify-content:flex-end}.ai-tools-wrapper .save-edit-btn,.ai-tools-wrapper .cancel-edit-btn{padding:8px 16px;border:none;border-radius:6px;cursor:pointer;font-size:.85rem;font-family:Noto Sans KR,sans-serif;transition:all .2s}.ai-tools-wrapper .save-edit-btn{background:linear-gradient(135deg,gold,#ffb347);color:#1a1a2e;font-weight:600}.ai-tools-wrapper .save-edit-btn:hover{box-shadow:0 3px 10px #ffd7004d}.ai-tools-wrapper .cancel-edit-btn{background:#ffffff1a;color:#aaa;border:1px solid rgba(255,255,255,.2)}.ai-tools-wrapper .cancel-edit-btn:hover{background:#fff3;color:#fff}.ai-tools-wrapper .generate-btn{width:100%;padding:18px;background:linear-gradient(135deg,gold,#ffb347);border:none;border-radius:15px;color:#1a1a2e;font-size:1.1rem;font-weight:700;cursor:pointer;transition:all .3s ease;font-family:Noto Sans KR,sans-serif}.ai-tools-wrapper .generate-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 30px #ffd7004d}.ai-tools-wrapper .generate-btn:disabled{opacity:.5;cursor:not-allowed;background:#555;color:#999}.ai-tools-wrapper .btn-loading{display:flex;align-items:center;justify-content:center;gap:10px}.ai-tools-wrapper .spinner{width:20px;height:20px;border:3px solid rgba(26,26,46,.3);border-top-color:#1a1a2e;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.ai-tools-wrapper .step-actions{display:flex;gap:15px;justify-content:center;flex-wrap:wrap}.ai-tools-wrapper .action-btn{padding:12px 25px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;border-radius:10px;cursor:pointer;transition:all .3s ease;font-size:.9rem;font-family:Noto Sans KR,sans-serif}.ai-tools-wrapper .action-btn:hover{background:#ffd70033;border-color:gold}.ai-tools-wrapper .action-btn.primary-action{background:linear-gradient(135deg,gold,#ffb347);color:#1a1a2e;font-weight:600;border:none}.ai-tools-wrapper .action-btn.primary-action:hover{box-shadow:0 5px 20px #ffd7004d;transform:translateY(-2px)}.ai-tools-wrapper .action-btn:disabled{opacity:.5;cursor:not-allowed}.ai-tools-wrapper .generation-status{display:flex;align-items:center;justify-content:center;gap:15px;padding:40px;font-size:1.1rem;color:gold}.ai-tools-wrapper .generation-status .spinner{width:30px;height:30px;border:3px solid rgba(255,215,0,.3);border-top-color:gold}.ai-tools-wrapper .original-reference{background:#0000004d;border-radius:12px;padding:15px;text-align:center;margin-bottom:20px;max-width:300px;margin-left:auto;margin-right:auto}.ai-tools-wrapper .original-reference h4{font-size:.85rem;color:gold;margin-bottom:10px;font-weight:500}.ai-tools-wrapper .original-reference img{max-width:100%;max-height:200px;border-radius:8px;object-fit:contain;cursor:pointer;transition:transform .2s}.ai-tools-wrapper .original-reference img:hover{transform:scale(1.02)}.ai-tools-wrapper .grid-title{font-size:1rem;color:gold;margin-bottom:15px;font-weight:500;text-align:center}.ai-tools-wrapper .generated-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:15px;margin-bottom:25px}.ai-tools-wrapper .generated-grid-item{background:#0000004d;border-radius:12px;padding:10px;text-align:center;cursor:pointer;transition:all .3s ease;border:2px solid transparent;position:relative}.ai-tools-wrapper .generated-grid-item:hover{background:#ffd7001a;border-color:#ffd7004d}.ai-tools-wrapper .generated-grid-item.selected{border-color:gold;background:#ffd70026;box-shadow:0 0 20px #ffd7004d}.ai-tools-wrapper .generated-grid-item img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:8px;transition:transform .2s}.ai-tools-wrapper .generated-grid-item:hover img{transform:scale(1.02)}.ai-tools-wrapper .generated-grid-item .item-number{position:absolute;top:15px;left:15px;background:#000000b3;color:gold;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:600}.ai-tools-wrapper .generated-grid-item.selected .item-number{background:gold;color:#1a1a2e}.ai-tools-wrapper .generated-grid-item .select-indicator{position:absolute;top:15px;right:15px;color:gold;font-size:1.5rem;opacity:0;transition:opacity .2s}.ai-tools-wrapper .generated-grid-item.selected .select-indicator{opacity:1}.ai-tools-wrapper .selected-image-section{background:#ffd7001a;border:1px solid rgba(255,215,0,.3);border-radius:15px;padding:20px;margin-bottom:20px;text-align:center}.ai-tools-wrapper .selected-image-section h4{color:gold;margin-bottom:15px;font-weight:500}.ai-tools-wrapper .selected-image-container{margin-bottom:15px}.ai-tools-wrapper .selected-image-container img{max-width:100%;max-height:500px;border-radius:10px;box-shadow:0 5px 25px #ffd70033;cursor:pointer}.ai-tools-wrapper .save-notice{text-align:center;color:#4caf50;font-size:.9rem;margin-bottom:20px;padding:10px;background:#4caf501a;border-radius:8px}.ai-tools-wrapper .color-match-hint{text-align:center;color:#888;font-size:.9rem;margin-top:20px;padding:10px;background:#ffd7001a;border-radius:8px}.ai-tools-wrapper .error-message{padding:15px;background:#ff475733;border:1px solid rgba(255,71,87,.5);border-radius:10px;color:#ff6b7a;text-align:center;margin-top:20px}.ai-tools-wrapper .pc-face-upload-section{margin-top:25px;padding-top:25px;border-top:1px solid rgba(255,255,255,.1)}.ai-tools-wrapper .pc-face-upload-section h3{font-size:1.1rem;color:gold;margin-bottom:8px;font-weight:500}.ai-tools-wrapper .pc-face-upload-area{min-height:180px;max-width:400px;margin:0 auto}.ai-tools-wrapper .pc-reference-images{display:flex;justify-content:center;gap:20px;margin-bottom:25px;flex-wrap:wrap}.ai-tools-wrapper .pc-reference-images .original-reference{max-width:250px;margin:0}.ai-tools-wrapper .cm-side-by-side{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}.ai-tools-wrapper .cm-reference-preview{background:#0000004d;border-radius:12px;padding:15px;text-align:center}.ai-tools-wrapper .cm-reference-preview h4{font-size:.85rem;color:gold;margin-bottom:10px;font-weight:500}.ai-tools-wrapper .cm-reference-preview img{max-width:100%;max-height:300px;border-radius:8px;object-fit:contain}.ai-tools-wrapper .cm-processing-status{display:flex;align-items:center;justify-content:center;gap:15px;padding:30px;font-size:1rem;color:gold}.ai-tools-wrapper .cm-processing-status .spinner{width:25px;height:25px;border:3px solid rgba(255,215,0,.3);border-top-color:gold}.ai-tools-wrapper .cm-result-container{display:flex;flex-direction:column;gap:20px}.ai-tools-wrapper .cm-main-comparison{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}.ai-tools-wrapper .cm-main-comparison .image-box{background:#0000004d;border-radius:12px;padding:15px;text-align:center}.ai-tools-wrapper .cm-main-comparison .image-box h4{font-size:.85rem;color:#888;margin-bottom:10px;font-weight:400}.ai-tools-wrapper .cm-main-comparison .image-box img{max-width:100%;max-height:500px;border-radius:8px;box-shadow:0 5px 20px #0000004d;cursor:pointer;transition:transform .2s,box-shadow .2s}.ai-tools-wrapper .cm-main-comparison .image-box img:hover{transform:scale(1.02);box-shadow:0 8px 30px #ffd7004d}.ai-tools-wrapper .cm-reference-small{display:flex;align-items:center;justify-content:center;gap:15px;padding:15px;background:#0003;border-radius:10px;margin-bottom:20px}.ai-tools-wrapper .cm-reference-small h4{font-size:.85rem;color:gold;margin:0;white-space:nowrap}.ai-tools-wrapper .cm-reference-small img{max-width:120px;max-height:120px;border-radius:8px;object-fit:contain;cursor:pointer}.ai-tools-wrapper .cm-controls-panel{background:#0000004d;border-radius:12px;padding:20px;border:1px solid rgba(255,215,0,.2)}.ai-tools-wrapper .cm-controls-panel h4{color:gold;font-size:1rem;font-weight:500;margin-bottom:20px;text-align:center}.ai-tools-wrapper .cm-control-group{margin-bottom:18px}.ai-tools-wrapper .cm-control-group label{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.ai-tools-wrapper .control-label{font-size:.9rem;color:#ccc}.ai-tools-wrapper .control-value{font-size:.85rem;color:gold;font-weight:500;min-width:50px;text-align:right}.ai-tools-wrapper .cm-slider{width:100%;height:8px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#ffffff1a;border-radius:4px;outline:none;cursor:pointer}.ai-tools-wrapper .cm-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;background:linear-gradient(135deg,gold,#ffb347);border-radius:50%;cursor:pointer;box-shadow:0 2px 8px #ffd70066;transition:transform .2s,box-shadow .2s}.ai-tools-wrapper .cm-slider::-webkit-slider-thumb:hover{transform:scale(1.1);box-shadow:0 3px 12px #ffd70099}.ai-tools-wrapper .cm-slider::-moz-range-thumb{width:20px;height:20px;background:linear-gradient(135deg,gold,#ffb347);border-radius:50%;cursor:pointer;border:none;box-shadow:0 2px 8px #ffd70066}.ai-tools-wrapper .cm-adjusting-status{display:flex;align-items:center;justify-content:center;gap:15px;padding:20px;font-size:1rem;color:gold}.ai-tools-wrapper .cm-adjusting-status .spinner{width:25px;height:25px;border:3px solid rgba(255,215,0,.3);border-top-color:gold}.ai-tools-wrapper .image-modal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:#000000f2;z-index:10000;justify-content:center;align-items:center;cursor:zoom-out}.ai-tools-wrapper .image-modal.active{display:flex}.ai-tools-wrapper .image-modal img{max-width:95vw;max-height:95vh;object-fit:contain;border-radius:8px;box-shadow:0 10px 50px #00000080}.ai-tools-wrapper .image-modal-close{position:absolute;top:20px;right:30px;font-size:40px;color:#fff;cursor:pointer;opacity:.8;transition:opacity .2s;background:none;border:none}.ai-tools-wrapper .image-modal-close:hover{opacity:1}.ai-tools-wrapper .image-modal-label{position:absolute;bottom:30px;left:50%;transform:translate(-50%);color:#fff;font-size:1.1rem;background:#000000b3;padding:10px 25px;border-radius:25px}.ai-tools-wrapper .video-card{background:#ffffff1a;border-radius:24px;padding:40px;margin-bottom:30px}.ai-tools-wrapper .video-upload-area{border:3px dashed rgba(255,255,255,.3);border-radius:16px;padding:60px 40px;text-align:center;cursor:pointer;transition:all .3s ease;background:#ffffff0d;position:relative}.ai-tools-wrapper .video-upload-area:hover{border-color:gold;background:#ffd7000d}.ai-tools-wrapper .video-upload-area.dragover{border-color:gold;background:#ffd7001a}.ai-tools-wrapper .video-upload-area i{font-size:4rem;color:gold;margin-bottom:20px}.ai-tools-wrapper .video-upload-area h3{font-size:1.3rem;color:#fff;margin-bottom:10px}.ai-tools-wrapper .video-upload-area p{color:#888;font-size:.9rem}.ai-tools-wrapper .video-preview-image{width:100%;max-height:400px;object-fit:contain;border-radius:12px;margin-bottom:20px}.ai-tools-wrapper .harmony-message{display:flex;align-items:center;justify-content:center;gap:10px;padding:16px 24px;background:#ffd7001a;border-radius:12px;margin-bottom:20px;color:gold;font-weight:500}.ai-tools-wrapper .action-section{margin:20px 0}.ai-tools-wrapper .action-section label{display:block;font-weight:600;color:gold;margin-bottom:12px}.ai-tools-wrapper .action-buttons{display:flex;flex-wrap:wrap;gap:10px}.ai-tools-wrapper .video-action-btn{padding:10px 16px;border:2px solid rgba(255,255,255,.2);border-radius:20px;background:#ffffff1a;color:#ccc;font-size:.9rem;cursor:pointer;transition:all .2s ease}.ai-tools-wrapper .video-action-btn:hover{border-color:gold;color:gold}.ai-tools-wrapper .video-action-btn.selected{border-color:gold;background:linear-gradient(135deg,gold,#ffb347);color:#1a1a2e}.ai-tools-wrapper .prompt-section{margin:20px 0}.ai-tools-wrapper .prompt-toggle{display:flex;align-items:center;gap:8px;cursor:pointer;color:gold;font-size:.9rem;margin-bottom:10px}.ai-tools-wrapper .prompt-toggle:hover{text-decoration:underline}.ai-tools-wrapper .prompt-textarea{width:100%;min-height:80px;padding:12px;border:2px solid rgba(255,255,255,.2);border-radius:10px;background:#0000004d;color:#fff;font-family:inherit;font-size:.95rem;resize:vertical;transition:border-color .3s}.ai-tools-wrapper .prompt-textarea:focus{outline:none;border-color:gold}.ai-tools-wrapper .prompt-hint{font-size:.8rem;color:#888;margin-top:6px}.ai-tools-wrapper .status-container{text-align:center;padding:40px}.ai-tools-wrapper .video-spinner{width:60px;height:60px;border:4px solid rgba(255,215,0,.3);border-top-color:gold;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 20px}.ai-tools-wrapper .status-text{font-size:1.1rem;color:gold;margin-bottom:10px}.ai-tools-wrapper .progress-bar{width:100%;height:8px;background:#ffffff1a;border-radius:4px;overflow:hidden;margin-top:20px}.ai-tools-wrapper .progress-fill{height:100%;background:linear-gradient(135deg,gold,#ffb347);border-radius:4px;transition:width .3s ease}.ai-tools-wrapper .result-video{width:100%;border-radius:12px;margin-bottom:20px}.ai-tools-wrapper .download-btn{display:inline-flex;align-items:center;gap:10px;padding:16px 32px;font-size:1.1rem;font-weight:600;color:#1a1a2e;background:linear-gradient(135deg,#11998e,#38ef7d);border:none;border-radius:12px;cursor:pointer;text-decoration:none;transition:all .3s ease}.ai-tools-wrapper .download-btn:hover{transform:translateY(-2px);box-shadow:0 10px 30px #11998e66}.ai-tools-wrapper footer{text-align:center;padding:30px 0;color:#555;font-size:.8rem}@media (max-width: 768px){.ai-tools-wrapper .cm-side-by-side,.ai-tools-wrapper .cm-main-comparison{grid-template-columns:1fr}.ai-tools-wrapper .cm-main-comparison .image-box img{max-height:350px}.ai-tools-wrapper .cm-reference-small{flex-direction:column;gap:10px}.ai-tools-wrapper .cm-reference-small img{max-width:150px;max-height:150px}.ai-tools-wrapper .step{width:60px;height:60px;font-size:.8rem}.ai-tools-wrapper .step-line{width:30px}.ai-tools-wrapper .generated-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 600px){.ai-tools-wrapper header h1{font-size:1.6rem}.ai-tools-wrapper .container{padding:15px}.ai-tools-wrapper main{padding:20px}.ai-tools-wrapper .step-actions{flex-direction:column}.ai-tools-wrapper .action-btn{width:100%}.ai-tools-wrapper .generated-grid{grid-template-columns:repeat(2,1fr);gap:10px}.ai-tools-wrapper .generated-grid-item{padding:8px}.ai-tools-wrapper .generated-grid-item .item-number{width:24px;height:24px;font-size:.75rem;top:12px;left:12px}.ai-tools-wrapper .selected-image-container img{max-height:350px}}.vendors-page{display:flex;min-height:calc(100vh - 60px)}.vendors-page .sidebar{width:220px;background:#f8f9fa;border-right:1px solid #dee2e6;padding:20px 0;flex-shrink:0}.vendors-page .sidebar h3{padding:0 20px;margin-bottom:20px;font-size:16px;color:#495057}.vendors-page .sidebar-menu{list-style:none;padding:0;margin:0}.vendors-page .sidebar-menu li a{display:flex;align-items:center;padding:12px 20px;color:#495057;text-decoration:none;transition:all .2s}.vendors-page .sidebar-menu li a:hover{background:#e9ecef}.vendors-page .sidebar-menu li a.active{background:#e7f1ff;color:#0d6efd;border-right:3px solid #0d6efd}.vendors-page .menu-icon{margin-right:10px}.vendors-page .main-content{flex:1;padding:20px;background:#fff;overflow-y:auto}.stats-header{margin-bottom:20px}.stats-header h3{margin:0;color:#495057}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:30px}.stat-card{background:#fff;border:1px solid #dee2e6;border-radius:8px;padding:20px;text-align:center}.stat-card.wedding{border-left:4px solid #ff6b9d}.stat-card.doljanchi{border-left:4px solid #4ecdc4}.stat-label{font-size:14px;color:#6c757d;margin-bottom:8px}.stat-value{font-size:24px;font-weight:700;color:#212529}.stat-sub{font-size:12px;color:#6c757d;margin-top:4px}.chart-section{background:#fff;border:1px solid #dee2e6;border-radius:8px;padding:20px;margin-bottom:30px}.chart-section h4{margin:0 0 15px;color:#495057}.bar-chart{margin-top:10px}.stacked-bar{display:flex;height:40px;border-radius:4px;overflow:hidden;background:#e9ecef}.bar-segment{display:flex;align-items:center;justify-content:center;color:#fff;font-size:12px;font-weight:700;transition:width .3s}.bar-segment.wedding{background:#ff6b9d}.bar-segment.doljanchi{background:#4ecdc4}.chart-legend{display:flex;gap:20px;margin-top:10px;justify-content:center}.legend-item{display:flex;align-items:center;gap:6px;font-size:13px;color:#6c757d}.dot{width:12px;height:12px;border-radius:50%}.dot.wedding{background:#ff6b9d}.dot.doljanchi{background:#4ecdc4}.vendor-sales-section{background:#fff;border:1px solid #dee2e6;border-radius:8px;padding:20px}.vendor-sales-section h4{margin:0 0 15px;color:#495057}.vendor-form{max-width:800px}.form-section{background:#f8f9fa;border-radius:8px;padding:20px;margin-bottom:20px}.form-section h3{margin:0 0 15px;font-size:16px;color:#495057;border-bottom:1px solid #dee2e6;padding-bottom:10px}.section-desc{font-size:13px;color:#6c757d;margin-bottom:15px}.form-group{margin-bottom:15px}.form-group label{display:block;margin-bottom:6px;font-weight:500;color:#495057}.form-input{width:100%;padding:10px 12px;border:1px solid #ced4da;border-radius:4px;font-size:14px}.form-input:focus{outline:none;border-color:#86b7fe;box-shadow:0 0 0 3px #0d6efd40}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:15px}.radio-group{display:flex;gap:20px}.radio-label{display:flex;align-items:center;gap:6px;cursor:pointer}.current-file{margin-top:8px;font-size:13px;color:#6c757d}.current-file a{color:#0d6efd}.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:15px}.product-item{background:#fff;border:1px solid #dee2e6;border-radius:8px;padding:15px;transition:all .2s}.product-item.enabled{border-color:#0d6efd;background:#f0f7ff}.product-checkbox{display:flex;align-items:center;gap:8px;cursor:pointer;font-weight:500}.product-checkbox input{width:18px;height:18px}.price-input{display:flex;align-items:center;gap:8px;margin-top:10px}.price-input input{flex:1;padding:8px 10px;border:1px solid #ced4da;border-radius:4px}.price-input span{color:#6c757d}.form-actions{display:flex;gap:10px;padding-top:20px}.list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.list-header h2{margin:0}.vendors-table-wrapper{overflow-x:auto;background:#fff;border:1px solid #dee2e6;border-radius:8px}.vendors-table{width:100%;border-collapse:collapse;min-width:900px}.vendors-table th,.vendors-table td{padding:12px 16px;text-align:left;border-bottom:1px solid #dee2e6;vertical-align:middle}.vendors-table th{background:#f8f9fa;font-weight:600;color:#495057;font-size:13px;white-space:nowrap}.vendors-table tbody tr:hover{background:#f8f9fa}.vendors-table tbody tr.inactive{opacity:.6;background:#fafafa}.vendors-table .vendor-name{font-weight:600;color:#212529;white-space:nowrap}.vendors-table .products-cell{max-width:350px}.products-list-inline{display:flex;flex-wrap:wrap;gap:6px}.product-tag-inline{background:#e9ecef;padding:3px 8px;border-radius:4px;font-size:12px;color:#495057;white-space:nowrap}.vendors-table .actions-cell{white-space:nowrap}.vendors-table .actions-cell .btn{margin-right:4px}.vendors-table .actions-cell .btn:last-child{margin-right:0}.vendors-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px}.vendor-card{background:#fff;border:1px solid #dee2e6;border-radius:8px;padding:20px;transition:all .2s}.vendor-card:hover{box-shadow:0 4px 12px #0000001a}.vendor-card.inactive{opacity:.6;background:#f8f9fa}.vendor-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;padding-bottom:10px;border-bottom:1px solid #dee2e6}.vendor-header h3{margin:0;font-size:18px}.type-badge{padding:4px 10px;border-radius:12px;font-size:12px;font-weight:500}.type-badge.돌잔치{background:#d4edda;color:#155724}.type-badge.결혼식{background:#f8d7da;color:#721c24}.type-badge.둘다{background:#e2e3e5;color:#383d41}.vendor-info{margin-bottom:15px}.info-row{display:flex;gap:10px;margin-bottom:5px;font-size:14px}.info-row .label{color:#6c757d;min-width:70px}.vendor-products{margin-bottom:15px}.vendor-products h4{margin:0 0 10px;font-size:14px;color:#6c757d}.products-list{display:flex;flex-wrap:wrap;gap:8px}.product-tag{background:#e9ecef;padding:4px 10px;border-radius:4px;font-size:12px;color:#495057}.vendor-actions{display:flex;gap:8px;padding-top:10px;border-top:1px solid #dee2e6}.btn{padding:10px 20px;border:none;border-radius:4px;cursor:pointer;font-size:14px;transition:all .2s}.btn-primary{background:#0d6efd;color:#fff}.btn-primary:hover{background:#0b5ed7}.btn-primary:disabled{background:#6c757d;cursor:not-allowed}.btn-danger{background:#dc3545;color:#fff}.btn-danger:hover{background:#bb2d3b}.btn-small{padding:6px 12px;font-size:12px}.loading{text-align:center;padding:40px;color:#6c757d}.no-data{text-align:center;padding:40px;color:#6c757d;background:#f8f9fa;border-radius:8px}.data-table{width:100%;border-collapse:collapse}.data-table th,.data-table td{padding:12px;text-align:left;border-bottom:1px solid #dee2e6}.data-table th{background:#f8f9fa;font-weight:600;color:#495057}.data-table tr:hover{background:#f8f9fa}@media (max-width: 768px){.vendors-page{flex-direction:column}.vendors-page .sidebar{width:100%;border-right:none;border-bottom:1px solid #dee2e6}.vendors-page .sidebar-menu{display:flex;overflow-x:auto}.vendors-page .sidebar-menu li a{padding:10px 15px;white-space:nowrap}.vendors-page .sidebar-menu li a.active{border-right:none;border-bottom:3px solid #0d6efd}.form-row,.vendors-list{grid-template-columns:1fr}}:root{--color-primary: #0064FF;--color-primary-hover: #0055DD;--color-primary-light: #E8F3FF;--color-background: #F9FAFB;--color-card: #FFFFFF;--color-border: #E5E8EB;--color-text-primary: #191F28;--color-text-secondary: #4E5968;--color-text-tertiary: #8B95A1;--color-success: #00C73C;--color-success-light: #E8FFF3;--color-warning: #FF9500;--color-warning-light: #FFF5E6;--color-error: #FF3B30;--color-error-light: #FFE8E6;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-2xl: 48px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .04);--shadow-md: 0 2px 8px rgba(0, 0, 0, .06);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .08);--shadow-hover: 0 8px 24px rgba(0, 0, 0, .12)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Apple SD Gothic Neo,Pretendard,Segoe UI,Malgun Gothic,sans-serif;background-color:var(--color-background);color:var(--color-text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.screen,.section{display:none}.screen.active{display:block;animation:fadeIn .3s ease-in-out;height:100vh;overflow-y:auto}.section.active{display:flex;animation:fadeIn .3s ease-in-out;min-height:100vh}.container{max-width:1600px;margin:0 auto;padding:var(--spacing-xl);width:100%}.container-full{max-width:100%;padding:var(--spacing-xl) var(--spacing-lg);width:100%;box-sizing:border-box}.card{background-color:var(--color-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:var(--spacing-xl);margin-bottom:var(--spacing-lg);border:1px solid var(--color-border);position:relative;box-sizing:border-box}.container-full .card{max-width:100%;overflow:hidden}.card h2{font-size:20px;font-weight:700;margin-bottom:var(--spacing-lg);color:var(--color-text-primary);letter-spacing:-.3px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.stat-card{background-color:var(--color-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:var(--spacing-xl);border:1px solid var(--color-border);transition:box-shadow .3s ease,transform .3s ease;position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:linear-gradient(to bottom,var(--color-primary),var(--color-primary-hover));opacity:0;transition:opacity .3s ease;pointer-events:none}.stat-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}.stat-card:hover:before{opacity:1}.stat-card.warning:before{background:linear-gradient(to bottom,var(--color-warning),#FF8500);opacity:1}.stat-card h3{font-size:14px;color:var(--color-text-secondary);margin-bottom:var(--spacing-md);font-weight:600;letter-spacing:-.2px;pointer-events:none}.stat-value{font-size:36px;font-weight:700;color:var(--color-text-primary);margin-bottom:var(--spacing-md);letter-spacing:-1px;pointer-events:none}.btn{padding:14px 24px;border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-card);color:var(--color-text-primary);font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);white-space:nowrap;letter-spacing:-.3px}.btn:hover{background-color:var(--color-background);border-color:var(--color-text-tertiary);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.btn:active{transform:translateY(0);box-shadow:none}.btn-primary{background-color:var(--color-primary);color:#fff;border:none;box-shadow:var(--shadow-sm)}.btn-primary:hover{background-color:var(--color-primary-hover);transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-primary:active{transform:translateY(0);box-shadow:var(--shadow-sm)}.btn-danger{background-color:var(--color-error);color:#fff;border:none;box-shadow:var(--shadow-sm)}.btn-danger:hover{background-color:#e63329;transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-danger:active{transform:translateY(0)}.btn-sm{padding:8px 16px;font-size:13px;border-radius:var(--radius-sm)}.btn-large{padding:18px 32px;font-size:17px;font-weight:700;border-radius:var(--radius-md)}.button-group{display:flex;gap:var(--spacing-md);flex-wrap:wrap}.category-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.category-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg);background-color:var(--color-background);border-radius:var(--radius-md);border:1px solid var(--color-border);transition:all .2s ease}.category-item:hover{background-color:var(--color-card);box-shadow:var(--shadow-sm);transform:translate(4px)}.category-info{flex:1}.category-name{font-weight:600;margin-bottom:var(--spacing-xs);color:var(--color-text-primary);font-size:16px;letter-spacing:-.3px}.category-amount{color:var(--color-text-secondary);font-size:14px;font-weight:500}.quick-actions{margin-top:var(--spacing-xl)}.quick-actions h2{font-size:20px;font-weight:700;margin-bottom:var(--spacing-lg);color:var(--color-text-primary);letter-spacing:-.3px}.upload-area{border:2px dashed var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-2xl) var(--spacing-lg);text-align:center;margin-bottom:var(--spacing-xl);background-color:var(--color-background);transition:all .3s ease}.upload-area:hover{border-color:var(--color-primary);background-color:var(--color-primary-light)}.info-box{background-color:var(--color-primary-light);border-left:4px solid var(--color-primary);padding:var(--spacing-lg);border-radius:var(--radius-md)}.info-box h3{font-size:15px;font-weight:700;margin-bottom:var(--spacing-md);color:var(--color-text-primary)}.info-box ul{margin-left:20px;margin-bottom:var(--spacing-md)}.info-box li{margin-bottom:var(--spacing-sm);font-size:14px;color:var(--color-text-secondary);line-height:1.6}.warning-box{background-color:var(--color-warning-light);border-left:4px solid var(--color-warning);padding:var(--spacing-lg);border-radius:var(--radius-md);margin-top:var(--spacing-lg)}.warning-box p{margin-bottom:var(--spacing-sm);font-size:14px;color:var(--color-text-primary)}.warning-box p:first-child{font-weight:700;font-size:15px}.product-list{max-height:500px;overflow-y:auto;border-radius:var(--radius-md)}.product-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg);border-bottom:1px solid var(--color-border);cursor:pointer;transition:all .2s ease}.product-item:last-child{border-bottom:none}.product-item:hover{background-color:var(--color-background)}.product-item.selected{background-color:var(--color-primary-light);border-left:4px solid var(--color-primary);padding-left:calc(var(--spacing-lg) - 4px)}.product-name{font-weight:600;color:var(--color-text-primary);font-size:15px;letter-spacing:-.2px}.product-count{color:var(--color-text-secondary);font-size:14px;font-weight:500}.form-group{margin-bottom:var(--spacing-lg);isolation:isolate}.form-group label{display:block;margin-bottom:var(--spacing-sm);font-weight:600;font-size:14px;color:var(--color-text-primary);letter-spacing:-.2px;cursor:pointer;-webkit-user-select:none;user-select:none}.form-group input,.form-group select{width:100%;padding:14px 16px;border:2px solid var(--color-border);border-radius:var(--radius-md);font-size:15px;color:var(--color-text-primary);background-color:var(--color-card);transition:all .15s ease;font-family:inherit;cursor:text;-webkit-appearance:none;-moz-appearance:none;appearance:none;box-sizing:border-box;user-select:auto;-webkit-user-select:auto;-moz-user-select:auto;-ms-user-select:auto}.form-group select{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%234E5968' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;padding-right:40px}.form-group input:hover:not(:focus),.form-group select:hover:not(:focus){border-color:var(--color-text-tertiary)}.form-group input:focus,.form-group select:focus{outline:none!important;border-color:var(--color-primary)!important;box-shadow:0 0 0 4px var(--color-primary-light)!important;background-color:#fff!important}.form-group input:disabled,.form-group select:disabled{background-color:var(--color-background);cursor:not-allowed;opacity:.6}.form-group input::placeholder{color:var(--color-text-tertiary)}.search-bar{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);isolation:isolate}.search-bar input{flex:1;padding:14px 16px;border:2px solid var(--color-border);border-radius:var(--radius-md);font-size:15px;color:var(--color-text-primary);background-color:var(--color-card);transition:all .15s ease;cursor:text;font-family:inherit;box-sizing:border-box}.search-bar input:hover:not(:focus){border-color:var(--color-text-tertiary)}.search-bar input:focus{outline:none!important;border-color:var(--color-primary)!important;box-shadow:0 0 0 4px var(--color-primary-light)!important;background-color:#fff!important}.search-bar input::placeholder{color:var(--color-text-tertiary)}.filter-bar{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.table-container{overflow-x:auto;overflow-y:auto;border-radius:var(--radius-md);border:1px solid var(--color-border);width:100%;max-width:100%;box-sizing:border-box}.container-full .table-container{max-width:calc(100vw - 48px)}table{width:100%;border-collapse:collapse}thead{background-color:var(--color-background)}th{padding:var(--spacing-lg);text-align:left;font-weight:700;font-size:13px;color:var(--color-text-secondary);border-bottom:2px solid var(--color-border);text-transform:uppercase;letter-spacing:.5px}td{padding:var(--spacing-lg);border-bottom:1px solid var(--color-border);font-size:14px;color:var(--color-text-primary)}tbody tr{transition:background-color .2s ease}tbody tr:hover{background-color:var(--color-background)}tbody tr:last-child td{border-bottom:none}tbody tr[draggable=true]{transition:background-color .2s ease,opacity .2s ease}tbody tr[draggable=true]:active{opacity:.5;background-color:var(--color-primary-light)}tbody tr[draggable=true]:hover{background-color:var(--color-background);cursor:move}.table-footer{margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--color-border);text-align:right;font-size:14px;color:var(--color-text-secondary);font-weight:500}.action-buttons{display:flex;gap:var(--spacing-sm)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;width:100%;height:100%;background-color:#191f28b3;display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .2s ease}.modal{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#191f28b3;display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .2s ease}.modal-content{background-color:var(--color-card);border-radius:var(--radius-lg);width:90%;max-width:540px;box-shadow:var(--shadow-hover);animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{padding:var(--spacing-xl);border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;align-items:center}.modal-header h2{font-size:20px;font-weight:700;color:var(--color-text-primary);letter-spacing:-.3px}.btn-close,.modal-close{background:none;border:none;font-size:24px;cursor:pointer;color:var(--color-text-tertiary);padding:var(--spacing-sm);width:36px;height:36px;border-radius:var(--radius-sm);transition:all .2s ease;display:flex;align-items:center;justify-content:center}.btn-close:hover,.modal-close:hover{background-color:var(--color-background);color:var(--color-text-primary)}.modal-body{padding:var(--spacing-xl)}.modal-footer{padding:var(--spacing-xl);border-top:1px solid var(--color-border);display:flex;justify-content:flex-end;gap:var(--spacing-md);background-color:var(--color-background);border-radius:0 0 var(--radius-lg) var(--radius-lg)}.chart-area{padding:var(--spacing-lg) 0;min-height:300px}#monthly-chart{width:100%;height:280px}.result-message{padding:var(--spacing-lg);border-radius:var(--radius-md);margin-bottom:var(--spacing-md);font-weight:500;display:flex;justify-content:space-between;align-items:center}.result-message.success{background-color:var(--color-success-light);color:#006b1f;border-left:4px solid var(--color-success)}.result-message.error{background-color:var(--color-error-light);color:#d32f2f;border-left:4px solid var(--color-error)}.result-message button{background:none;border:none;font-size:20px;color:inherit;cursor:pointer;padding:4px 8px;border-radius:var(--radius-sm);transition:all .2s ease;display:flex;align-items:center;justify-content:center;width:28px;height:28px;flex-shrink:0}.result-message button:hover{background-color:#0000001a}.result-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.result-stat{padding:var(--spacing-lg);background-color:var(--color-background);border-radius:var(--radius-md);text-align:center;border:1px solid var(--color-border)}.result-stat-label{font-size:13px;color:var(--color-text-secondary);margin-bottom:var(--spacing-xs);font-weight:600}.result-stat-value{font-size:28px;font-weight:700;color:var(--color-text-primary);letter-spacing:-.5px}.error-list{background-color:var(--color-warning-light);border-left:4px solid var(--color-warning);padding:var(--spacing-lg);border-radius:var(--radius-md);max-height:240px;overflow-y:auto}.error-item{font-size:14px;margin-bottom:var(--spacing-sm);color:var(--color-text-primary)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--color-background);border-radius:var(--radius-sm)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-sm);border:2px solid var(--color-background)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-tertiary)}@media (max-width: 1024px){.sidebar{position:fixed;left:-260px;top:0;height:100vh;z-index:1000;transition:left .3s ease;box-shadow:var(--shadow-lg)}.sidebar.mobile-open{left:0}.main-content{width:100%}.sidebar-overlay{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:#191f2880;z-index:999}.sidebar-overlay.active{display:block}.home-header h1{font-size:36px}.home-modules{grid-template-columns:1fr}}@media (max-width: 768px){.container{padding:var(--spacing-lg)}.stats-grid{grid-template-columns:1fr}.card{padding:var(--spacing-lg)}.button-group{flex-direction:column}.button-group .btn{width:100%}.filter-bar{grid-template-columns:1fr}.modal-content{width:95%}.home-header h1{font-size:28px}.home-header p{font-size:16px}.home-container{padding:var(--spacing-lg)}}.coupon-select-item{display:flex;align-items:center;gap:12px;padding:14px 16px;border:2px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;background:var(--color-card);transition:all .2s ease;-webkit-user-select:none;user-select:none}.coupon-select-item:hover{border-color:var(--color-primary);background:var(--color-primary-light);transform:translateY(-1px);box-shadow:var(--shadow-md)}.coupon-select-item:active{transform:translateY(0)}.coupon-select-item input[type=checkbox]{width:20px;height:20px;min-width:20px;cursor:pointer;margin:0;accent-color:var(--color-primary)}.coupon-select-item input[type=checkbox]:checked+.coupon-info{color:var(--color-primary)}.coupon-select-item:has(input:checked){border-color:var(--color-primary);background:var(--color-primary-light);box-shadow:0 0 0 3px #0064ff1a}.coupon-info{flex:1;pointer-events:none}.coupon-name{font-weight:600;font-size:15px;color:var(--color-text-primary);margin-bottom:4px;line-height:1.4}.coupon-meta{font-size:13px;color:var(--color-text-tertiary);line-height:1.4}.home-container{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2xl);background:linear-gradient(135deg,#667eea,#764ba2)}.home-header{text-align:center;margin-bottom:var(--spacing-2xl);color:#fff}.home-header h1{font-size:48px;font-weight:800;margin-bottom:var(--spacing-md);text-shadow:0 2px 20px rgba(0,0,0,.2)}.home-header p{font-size:18px;opacity:.9}.home-modules{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:var(--spacing-lg);max-width:1000px;width:100%}.home-module-card{background:#fff;border-radius:var(--radius-lg);padding:var(--spacing-2xl);cursor:pointer;transition:all .3s ease;box-shadow:0 8px 24px #00000026;position:relative}.home-module-card:hover{transform:translateY(-8px);box-shadow:0 12px 32px #0003}.home-module-card.disabled{cursor:not-allowed;opacity:.6}.home-module-card.disabled:hover{transform:none}.module-icon{font-size:48px;margin-bottom:var(--spacing-md)}.home-module-card h2{font-size:24px;font-weight:700;margin-bottom:var(--spacing-sm);color:var(--color-text-primary)}.home-module-card p{color:var(--color-text-secondary);font-size:15px;line-height:1.6}.module-arrow{position:absolute;right:var(--spacing-lg);bottom:var(--spacing-lg);font-size:24px;color:var(--color-primary);font-weight:700}.module-badge{position:absolute;top:var(--spacing-md);right:var(--spacing-md);background:var(--color-warning);color:#fff;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600}.sidebar{width:260px;background:var(--color-card);border-right:1px solid var(--color-border);display:flex;flex-direction:column;height:100vh;position:sticky;top:0;flex-shrink:0;overflow:hidden}.sidebar-header{padding:var(--spacing-lg);border-bottom:1px solid var(--color-border)}.sidebar-header h2{font-size:20px;font-weight:700;color:var(--color-text-primary);margin-top:var(--spacing-md)}.btn-back-home{background:var(--color-background);border:1px solid var(--color-border);padding:8px 16px;border-radius:var(--radius-sm);font-size:14px;font-weight:500;color:var(--color-text-secondary);cursor:pointer;transition:all .2s;width:100%;text-align:left}.btn-back-home:hover{background:var(--color-primary-light);color:var(--color-primary);border-color:var(--color-primary)}.sidebar-menu{list-style:none;padding:var(--spacing-sm);overflow-y:auto;flex:1}.sidebar-menu li{margin-bottom:2px}.sidebar-menu a{display:flex;align-items:center;padding:12px 16px;color:var(--color-text-secondary);text-decoration:none;border-radius:var(--radius-sm);transition:all .2s;font-weight:500;font-size:15px}.sidebar-menu a:hover{background:var(--color-background);color:var(--color-text-primary)}.sidebar-menu a.active{background:var(--color-primary-light);color:var(--color-primary);font-weight:600}.menu-icon{margin-right:12px;font-size:18px}.menu-separator{padding:16px 16px 8px;font-size:12px;font-weight:700;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.5px}.main-content{flex:1;overflow-y:auto;background:var(--color-background)}.main-content .screen{min-height:100%}.main-content .screen:not(:has(.container)){padding:var(--spacing-xl)}.supplies-container{height:100%;background:var(--color-background);display:flex;flex-direction:column;overflow:hidden}.supplies-header{background:var(--color-card);border-bottom:1px solid var(--color-border);padding:var(--spacing-xl);flex-shrink:0;box-shadow:var(--shadow-sm)}.supplies-header h1{font-size:28px;font-weight:700;color:var(--color-text-primary);margin-top:var(--spacing-md);letter-spacing:-.5px}.supplies-container>.container{flex:1;overflow-y:auto}.header-with-button{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-lg);border-bottom:2px solid var(--color-border)}.header-with-button h2{font-size:24px;font-weight:700;color:var(--color-text-primary);margin:0;letter-spacing:-.4px}.filter-container{display:flex;gap:var(--spacing-md);align-items:center;flex-wrap:wrap;padding:var(--spacing-lg);background:var(--color-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--color-border)}#settlements-list .table-container{overflow-x:auto;margin-top:var(--spacing-lg)}#settlements-list table{min-width:800px;font-size:14px}#settlements-list th{white-space:nowrap;padding:var(--spacing-md) var(--spacing-sm);font-size:13px}#settlements-list td{white-space:nowrap;padding:var(--spacing-md) var(--spacing-sm);font-size:14px}#settlements-list td:first-child{font-weight:600}.expense-layout{display:flex;gap:0;flex:1;overflow:hidden}.expense-tabs{width:200px;flex-shrink:0;background:var(--color-card);border-right:1px solid var(--color-border);padding:var(--spacing-md) 0}.expense-tab{width:100%;padding:var(--spacing-md) var(--spacing-lg);border:none;background:transparent;display:flex;align-items:center;gap:var(--spacing-md);cursor:pointer;transition:all .2s ease;border-left:3px solid transparent;text-align:left;font-size:14px}.expense-tab:hover{background:var(--color-background)}.expense-tab.active{background:var(--color-primary-light);border-left-color:var(--color-primary);color:var(--color-primary);font-weight:600}.expense-tab .tab-icon{font-size:20px}.expense-tab .tab-label{flex:1}.text-center{text-align:center}.text-right{text-align:right}.text-muted{color:#666}.text-muted-light{color:#999}.text-primary-bright{color:#e0e0e0}.text-secondary-bright{color:#a0a0a0}.text-success{color:#4caf50}.text-warning{color:#ff9800}.text-danger{color:#ff4757}.text-info{color:#00d9ff}.text-fixed-expense{color:#667eea}.badge{padding:2px 8px;border-radius:4px;font-size:12px;color:#fff;display:inline-block}.badge-bcoupon{background:#4caf50}.badge-wcoupon{background:#2196f3}.badge-other{background:#9e9e9e}.input-sm{padding:4px;border:1px solid var(--color-border);border-radius:4px}.input-success{border:2px solid #4CAF50}.input-w60{width:60px}.input-w80{width:80px}.input-w100{width:100px}.input-w120{width:120px}.input-w150{width:150px}.input-full{width:100%}.btn-success{background-color:#4caf50!important;color:#fff!important}.flex{display:flex}.flex-between{display:flex;justify-content:space-between}.flex-center{display:flex;align-items:center}.font-12{font-size:12px}.font-13{font-size:13px}.font-14{font-size:14px}.font-15{font-size:15px}.font-16{font-size:16px}.font-20{font-size:20px}.font-medium{font-weight:500}.font-semibold{font-weight:600}.mt-4{margin-top:4px}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mb-8{margin-bottom:8px}.ml-6{margin-left:6px}.ml-8{margin-left:8px}.p-12{padding:12px}.p-40{padding:40px}.empty-message{color:#666;text-align:center;padding:var(--spacing-lg)}.empty-state{text-align:center;color:var(--color-text-tertiary);padding:var(--spacing-xl)}.category-profit-item{display:flex;justify-content:space-between;padding:var(--spacing-md);border-bottom:1px solid var(--color-border)}.result-success{color:var(--color-success);font-weight:600}.result-error{color:var(--color-error);font-weight:600}.result-info{color:var(--color-text-secondary);font-size:14px;margin-top:8px}.result-warning-box{margin-top:12px;padding:12px;background:var(--color-warning-light);border-radius:var(--radius-sm)}.result-warning-title{color:var(--color-warning);font-weight:600;margin-bottom:8px}.result-warning-list{margin:0;padding-left:20px;color:var(--color-text-secondary);font-size:13px}.status-success{color:#00f2fe}.status-danger{color:#f5576c}.cell-null{color:#999}.sortable-header{cursor:pointer;-webkit-user-select:none;user-select:none}.expense-content{flex:1;padding:var(--spacing-xl);overflow-y:auto;background:var(--color-background)}.expense-tab-content{display:none}.expense-tab-content.active{display:block}.category-section{background:var(--color-card);border-radius:var(--radius-lg);padding:var(--spacing-xl);margin-bottom:var(--spacing-xl);box-shadow:var(--shadow-md);border:1px solid var(--color-border)}.category-section h3{font-size:20px;font-weight:700;color:var(--color-primary);margin-bottom:var(--spacing-lg);letter-spacing:-.3px;padding-bottom:var(--spacing-md);border-bottom:2px solid var(--color-primary-light)}.category-section h4{font-size:16px;font-weight:600;color:var(--color-text-secondary);margin-bottom:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-background);border-radius:var(--radius-sm);border-left:3px solid var(--color-primary)}.form-input{padding:14px 16px;border:2px solid var(--color-border);border-radius:var(--radius-md);font-size:15px;color:var(--color-text-primary);background-color:var(--color-card);transition:all .15s ease;font-family:inherit}.form-input:hover:not(:focus){border-color:var(--color-text-tertiary)}.form-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 4px var(--color-primary-light);background-color:#fff}.form-input::placeholder{color:var(--color-text-tertiary)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-lg)}textarea.form-input{resize:vertical;min-height:80px;line-height:1.6;user-select:auto;-webkit-user-select:auto;-moz-user-select:auto;-ms-user-select:auto}.btn-secondary{background-color:var(--color-background);color:var(--color-text-secondary);border:1px solid var(--color-border)}.btn-secondary:hover{background-color:var(--color-card);color:var(--color-text-primary);border-color:var(--color-text-tertiary)}.supplies-container table{width:100%;border-collapse:separate;border-spacing:0}.supplies-container thead th{background:var(--color-background);position:sticky;top:0;z-index:10}.supplies-container tbody tr:hover{background:var(--color-primary-light);transform:scale(1.002);box-shadow:var(--shadow-sm)}.supplies-container td a{color:var(--color-primary);text-decoration:none;font-weight:600;transition:all .2s ease}.supplies-container td a:hover{color:var(--color-primary-hover);text-decoration:underline}.empty-state{text-align:center;padding:var(--spacing-2xl);color:var(--color-text-tertiary);font-size:16px}.empty-state-icon{font-size:64px;margin-bottom:var(--spacing-lg);opacity:.5}@media (max-width: 768px){.form-row{grid-template-columns:1fr}.header-with-button{flex-direction:column;align-items:flex-start;gap:var(--spacing-md)}.header-with-button .btn{width:100%}.filter-container{flex-direction:column;align-items:stretch}.filter-container input,.filter-container select{max-width:100%!important;width:100%}}.stat-number{font-size:32px;font-weight:700;color:var(--color-primary);margin:var(--spacing-md) 0;letter-spacing:-.5px}.db-filter-panel{display:none;margin:var(--spacing-lg) 0;padding:var(--spacing-xl);background:var(--color-background);border-radius:var(--radius-lg);border:1px solid var(--color-border)}.db-filter-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-lg)}.badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:13px;font-weight:600;letter-spacing:.3px;text-transform:uppercase}.badge-wcoupon{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.badge-bcoupon{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff}.calculator-group{margin-bottom:var(--spacing-2xl)}.calculator-group h3{font-size:18px;font-weight:600;color:var(--color-text-primary);margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:2px solid var(--color-primary)}.labor-item,.material-item{display:grid;grid-template-columns:1.5fr 2fr 1.5fr 1.5fr auto;gap:var(--spacing-md);align-items:center;margin-bottom:var(--spacing-md);padding:var(--spacing-md);background:var(--color-background);border-radius:var(--radius-md);transition:all .2s ease}.labor-item:hover,.material-item:hover{background:#f0f4f8;box-shadow:var(--shadow-sm)}.calc-input{padding:12px 16px;border:2px solid var(--color-border);border-radius:var(--radius-sm);font-size:15px;font-weight:500;transition:all .2s ease;background:#fff}.calc-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #0064ff1a}.calc-input.full-width{width:100%;max-width:400px}.labor-cost,.material-cost{font-size:16px;font-weight:700;color:var(--color-primary);text-align:right;padding-right:var(--spacing-sm)}.btn-add-labor,.btn-add-material{padding:10px 20px;background:var(--color-primary-light);color:var(--color-primary);border:2px solid var(--color-primary);border-radius:var(--radius-md);font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;margin-top:var(--spacing-sm)}.btn-add-labor:hover,.btn-add-material:hover{background:var(--color-primary);color:#fff;transform:translateY(-1px);box-shadow:var(--shadow-sm)}.btn-remove{width:32px;height:32px;background:var(--color-error-light);color:var(--color-error);border:none;border-radius:50%;font-size:20px;font-weight:700;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.btn-remove:hover{background:var(--color-error);color:#fff;transform:scale(1.1)}.calculator-results{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:var(--radius-lg);padding:var(--spacing-xl);margin:var(--spacing-2xl) 0;color:#fff}.result-row{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md) 0;font-size:16px;border-bottom:1px solid rgba(255,255,255,.2)}.result-row:last-child{border-bottom:none}.result-row span:first-child{font-weight:500;opacity:.95}.result-row span:last-child{font-weight:700;font-size:18px}.result-row.total{font-size:20px;font-weight:700;padding:var(--spacing-lg) 0;margin:var(--spacing-sm) 0;border-top:2px solid rgba(255,255,255,.4);border-bottom:2px solid rgba(255,255,255,.4)}.result-row.total span:last-child{font-size:24px}.result-row.profit,.result-row.profit-rate{font-size:18px;font-weight:600}.result-row.profit span:last-child,.result-row.profit-rate span:last-child{font-size:22px;font-weight:800}.calculate-btn{width:100%;padding:var(--spacing-lg);font-size:18px;font-weight:700;margin-bottom:var(--spacing-md)}.reset-btn{width:100%;padding:var(--spacing-md);font-size:16px;background:var(--color-background);color:var(--color-text-secondary);border:2px solid var(--color-border)}.reset-btn:hover{background:#fff;border-color:var(--color-text-secondary);color:var(--color-text-primary)}@media (max-width: 768px){.labor-item,.material-item{grid-template-columns:1fr;gap:var(--spacing-sm)}.calc-input.full-width{max-width:100%}.calculator-results{padding:var(--spacing-lg)}.result-row{font-size:14px}.result-row span:last-child{font-size:16px}.result-row.total{font-size:16px}.result-row.total span:last-child{font-size:20px}}
