/**
 * @license
 * SPDX-License-Identifier: Apache-2.0
*/:root{--primary-blue: #0050FF;--dark-blue: #00008C;--light-blue: #82DCFA;--white: #FFFFFF;--accent-green: #00DC7D;--accent-red: #F65D7C;--neutral-black: #00001E;--neutral-grey-light: #F3F3F5;--neutral-grey-dark: #e9ecef;--background-color: var(--neutral-grey-light);--text-color: var(--neutral-black);--card-background: var(--white);--border-radius: 12px;--box-shadow: 0 4px 12px rgba(0, 0, 0, .06);--box-shadow-hover: 0 6px 16px rgba(0, 0, 0, .1);--font-family: "Roboto", sans-serif;--bouncy-transition: transform .2s cubic-bezier(.175, .885, .32, 1.275)}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:var(--font-family);background-color:var(--background-color);color:var(--text-color);line-height:1.5;overflow:hidden}h1{font-size:1.75rem;font-weight:700;color:var(--primary-blue);margin:0}h2{font-size:1.25rem;font-weight:500;color:var(--dark-blue);margin:0}.app-container{display:flex;flex-direction:column;height:100vh;width:100vw}.app-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;background-color:var(--card-background);border-bottom:1px solid #e0e0e0;flex-shrink:0;box-shadow:var(--box-shadow);z-index:10}.header-actions{display:flex;gap:1rem;align-items:center}.header-btn,.new-project-btn{background-color:var(--white);color:var(--primary-blue);border:1px solid #ccc;padding:.6rem 1.2rem;font-size:.9rem;font-weight:500;border-radius:8px;cursor:pointer;transition:all .2s ease,var(--bouncy-transition)}.header-btn:hover,.new-project-btn:hover{background-color:#f8f9fa;border-color:var(--primary-blue);transform:translateY(-2px)}.new-project-btn{background-color:var(--primary-blue);color:var(--white);border-color:var(--primary-blue)}.new-project-btn:hover{background-color:var(--dark-blue);border-color:var(--dark-blue)}.logout-btn{background-color:transparent;color:var(--accent-red);border:1px solid var(--accent-red);padding:.6rem 1.2rem;font-size:.9rem;font-weight:500;border-radius:8px;cursor:pointer;transition:all .2s ease,var(--bouncy-transition)}.logout-btn:hover{background-color:var(--accent-red);color:var(--white);transform:translateY(-2px)}.profile-dropdown-container{position:relative}.profile-trigger{width:40px;height:40px;border-radius:50%;border:2px solid #e0e0e0;background-color:var(--neutral-grey-light);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;padding:0;overflow:hidden;color:#666}.profile-trigger:hover{border-color:var(--primary-blue);transform:scale(1.05);box-shadow:0 2px 8px #0050ff33}.profile-trigger-img{width:100%;height:100%;object-fit:cover}.profile-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:180px;background-color:var(--white);border:1px solid #e0e0e0;border-radius:12px;box-shadow:0 8px 24px #0000001f;z-index:100;padding:.5rem 0;animation:dropdownFadeIn .15s ease-out}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.dropdown-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;background:none;border:none;cursor:pointer;font-size:.9rem;font-weight:500;color:var(--text-color);text-align:left;transition:background-color .15s ease}.dropdown-item:hover{background-color:var(--neutral-grey-light)}.dropdown-item svg{flex-shrink:0}.dropdown-divider{height:1px;background-color:#e0e0e0;margin:.5rem 0}.dropdown-item-logout{color:var(--accent-red)}.dropdown-item-logout:hover{background-color:#f65d7c1a}.scene-control-bar{position:absolute;top:-60px;left:50%;transform:translate(-50%);display:flex;gap:.5rem;background-color:#fff;padding:.5rem;border-radius:50px;box-shadow:0 4px 12px #00000026;z-index:100;pointer-events:auto;opacity:0;animation:fadeIn .2s ease-out forwards}@keyframes fadeIn{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.scene-control-btn{width:36px;height:36px;border-radius:50%;border:1px solid #eee;background-color:#fff;color:var(--text-color);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;position:relative}.scene-control-btn:hover{background-color:var(--neutral-grey-light);color:var(--primary-blue);border-color:var(--primary-blue);transform:translateY(-2px);box-shadow:0 2px 5px #0000001a}.scene-control-btn.delete-btn:hover{color:var(--accent-red);border-color:var(--accent-red);background-color:#f65d7c1a;filter:brightness(.9)}.scene-control-btn svg{width:18px;height:18px}.content-wrapper{display:flex;flex-grow:1;overflow:hidden;min-height:0;height:100%}.sidebar{width:420px;flex-shrink:0;background-color:var(--card-background);border-right:1px solid #e0e0e0;padding:2rem;overflow-y:auto;display:flex;flex-direction:column;gap:1rem}.sidebar h2{margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #e0e0e0}.content-area{flex-grow:1;padding:2rem;overflow-y:auto;display:flex;flex-direction:column}.content-header{margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid #e0e0e0;flex-shrink:0}.content-header h2{font-size:1.5rem}.step-accordion{border:1px solid #e0e0e0;border-radius:var(--border-radius);transition:all .3s ease;animation:slideInUp .5s ease-out forwards}.step-accordion.active{border-color:var(--primary-blue);box-shadow:0 0 15px #0050ff1a}.step-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem;cursor:pointer;background-color:var(--card-background);border-radius:var(--border-radius);transition:background-color .2s ease}.step-accordion.active:not(:last-child) .step-header{border-bottom-left-radius:0;border-bottom-right-radius:0}.step-accordion:not(.active) .step-header:hover{background-color:#f8f9fa}.step-header .step-summary{font-size:.9rem;color:#555;background-color:var(--neutral-grey-light);padding:.25rem .75rem;border-radius:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:150px}.step-content{max-height:0;overflow:hidden;transition:max-height .5s ease-in-out,padding .5s ease-in-out;padding:0 1.25rem;background-color:#fafbff}.step-content.open{max-height:2000px;padding:1.25rem;border-top:1px solid #e0e0e0}.step-inner-content{margin-top:1.5rem}.step-description{font-size:.9rem;color:#555;margin-bottom:1rem;background-color:var(--neutral-grey-light);padding:.75rem;border-radius:8px;border-left:4px solid var(--light-blue)}@keyframes slideInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.image-uploader label{display:inline-block;background-color:var(--primary-blue);color:var(--white);padding:.8rem 1.5rem;border-radius:8px;cursor:pointer;font-weight:500;text-align:center;width:100%;transition:all .2s ease,var(--bouncy-transition)}.image-uploader label:hover{background-color:var(--dark-blue);transform:scale(1.02)}.image-uploader label.disabled{background-color:var(--neutral-grey-dark);color:#999;cursor:not-allowed;transform:none}.image-uploader input[type=file]{display:none}.image-preview{margin-top:1rem;width:100%;min-height:200px;position:relative;background-color:var(--neutral-grey-dark);border-radius:var(--border-radius);overflow:hidden;border:2px dashed #ccc;display:flex;align-items:center;justify-content:center}.image-preview img,.image-preview video{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:contain}.image-preview span{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#888}.ad-formats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.75rem}.ad-format-btn{background-color:#fff;border:1px solid #ddd;border-radius:8px;padding:.5rem;cursor:pointer;font-weight:500;color:var(--text-color);text-align:center;transition:all .2s ease,var(--bouncy-transition);white-space:normal;min-height:58px;display:flex;align-items:center;justify-content:center}.ad-format-btn:hover{border-color:var(--primary-blue);color:var(--primary-blue);transform:translateY(-2px);box-shadow:var(--box-shadow)}.ad-format-btn:disabled{opacity:.5;cursor:not-allowed}.ad-format-btn.selected{background-color:var(--primary-blue);color:var(--white);border-color:var(--primary-blue)}.ad-format-selector__search{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#f9fafb;border-radius:8px;margin-bottom:.75rem}.ad-format-selector__search input{flex:1;border:none;background:transparent;outline:none;font-size:.9rem}.ad-format-selector__tabs{display:flex;gap:.25rem;background:#f3f4f6;border-radius:8px;padding:.25rem;margin-bottom:1rem}.ad-format-selector__tabs button{flex:1;padding:.5rem .75rem;border:none;background:transparent;border-radius:6px;cursor:pointer;font-weight:500;color:#6b7280;transition:all .2s}.ad-format-selector__tabs button.active{background:#fff;color:var(--primary-blue);box-shadow:0 1px 3px #0000001a}.ad-format-selector__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:.75rem;max-height:250px;overflow-y:auto;padding:.5rem;background-color:var(--neutral-grey-light);border-radius:var(--border-radius);border:1px solid var(--neutral-grey-dark)}.ad-format-selector__card{display:flex;flex-direction:column;align-items:center;padding:.5rem;border:2px solid transparent;border-radius:8px;background:#fff;cursor:pointer;transition:all .2s;aspect-ratio:1 / 1}.ad-format-selector__card:hover{border-color:var(--light-blue)}.ad-format-selector__card.selected{border-color:var(--primary-blue);background:#eff6ff}.ad-format-selector__card:disabled{opacity:.5;cursor:not-allowed}.ad-format-selector__card img{width:100%;aspect-ratio:1 / 1;object-fit:cover;border-radius:6px;margin-bottom:.25rem}.ad-format-selector__card-placeholder{width:100%;aspect-ratio:1 / 1;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#e0e7ff,#c7d2fe);border-radius:6px;margin-bottom:.25rem;color:var(--primary-blue);font-weight:700;font-size:1.25rem}.ad-format-selector__card-name{font-weight:500;font-size:.75rem;color:#111827;text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:100%}.ad-format-selector__card-type{font-size:.6rem;padding:.15rem .4rem;border-radius:4px;margin-top:.15rem;font-weight:500}.ad-format-selector__card-type.indoor{background:#dbeafe;color:var(--primary-blue)}.ad-format-selector__card-type.outdoor{background:#dcfce7;color:#16a34a}.ad-format-selector__empty{grid-column:1 / -1;text-align:center;color:#6b7280;padding:2rem}.choice-container-vertical{display:flex;flex-direction:column;gap:1rem}.context-container{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.75rem}.choice-btn,.context-btn{background-color:var(--white);color:var(--primary-blue);border:1px solid var(--primary-blue);padding:.75rem 1rem;border-radius:8px;cursor:pointer;font-weight:500;text-align:center;transition:all .2s ease-in-out,var(--bouncy-transition)}.choice-btn:hover:not(:disabled),.context-btn:hover:not(:disabled){background-color:var(--primary-blue);color:var(--white);transform:scale(1.05)}.choice-btn.selected,.context-btn.selected{background-color:var(--primary-blue);color:var(--white)}.choice-btn:disabled,.context-btn:disabled{opacity:.5;cursor:not-allowed;transform:none;background-color:var(--neutral-grey-dark);border-color:#ccc;color:#999}.selection-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.5rem}.selection-card{padding:.5rem;border:1px solid #eaecf0;border-radius:12px;background-color:var(--white);cursor:pointer;transition:all .2s cubic-bezier(.2,.8,.2,1);text-align:center;font-weight:500;gap:0;min-height:72px;height:100%;color:#475467;font-size:.9rem;box-shadow:0 1px 2px #1018280d;display:flex;flex-direction:column;justify-content:center;align-items:center}.selection-card:hover{border-color:var(--primary-blue);background-color:#fff;transform:translateY(-2px);box-shadow:0 4px 6px -1px #1018281a,0 2px 4px -1px #1018280f;color:var(--primary-blue)}.selection-card.selected{border-color:var(--primary-blue);background-color:#eff8ff;color:var(--primary-blue);box-shadow:0 0 0 4px #eff8ff,0 1px 2px #1018280d}.selection-card input[type=radio]{display:none}.selection-card-icon{font-size:1.5rem;margin-bottom:.25rem}.generation-controls{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #e0e0e0}.placement-mode-selector .context-container{grid-template-columns:1fr 1fr}.placement-mode-selector .context-btn{padding:.6rem 1rem}.main-content-layout{display:flex;flex-grow:1;gap:2rem;min-height:0}.preview-area{flex-grow:1;display:flex;flex-direction:column;min-width:0;min-height:0}.thumbnail-sidebar{width:240px;flex-shrink:0;padding:1rem;border-left:1px solid #e0e0e0;background-color:var(--card-background);display:flex;flex-direction:column;gap:1rem;overflow-y:auto}.thumbnail-sidebar-item{width:100%;aspect-ratio:16 / 9;border:3px solid transparent;border-radius:8px;padding:0;cursor:pointer;overflow:hidden;background-color:#eee;transition:all .2s ease,var(--bouncy-transition);position:relative}.thumbnail-sidebar-item:hover{transform:scale(1.02);box-shadow:0 4px 12px #0000001a}.thumbnail-sidebar-item.selected{border-color:var(--primary-blue);box-shadow:0 0 10px #0050ff4d}.thumbnail-sidebar-item img{width:100%;height:100%;object-fit:cover;display:block}.thumbnail-sidebar-item.placeholder{background-color:#f3f3f3;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:default;color:#999;font-size:.8rem;border:1px dashed #ccc}.thumbnail-sidebar-item.placeholder:hover{transform:none;box-shadow:none}.spinner-mini{border:3px solid #ddd;border-top:3px solid var(--primary-blue);border-radius:50%;width:24px;height:24px;animation:spin 1s linear infinite;margin-bottom:.5rem}.result-display{display:flex;justify-content:center;align-items:center;width:100%;flex-grow:1;min-height:300px;background-color:var(--neutral-grey-dark);border-radius:var(--border-radius);position:relative;overflow:hidden}.placeholder-content{display:flex;flex-direction:column;align-items:center;gap:1rem;color:#888;text-align:center}.placeholder-content svg{stroke:#bbb}.placeholder-content span{font-size:.9rem}.result-display img{width:100%;height:100%;object-fit:contain;position:relative;z-index:1}.satisfaction-bubble{position:absolute;bottom:80px;right:20px;background-color:var(--white);padding:1rem;border-radius:var(--border-radius);box-shadow:0 4px 20px #00000026;z-index:50;max-width:250px;animation:fadeInBubble .3s ease-out forwards;border-left:4px solid var(--accent-green)}.satisfaction-bubble h4{font-size:.95rem;color:var(--dark-blue);margin-bottom:.5rem;font-weight:600}.satisfaction-bubble p{font-size:.85rem;color:#666;margin-bottom:0;line-height:1.4}.satisfaction-bubble-arrow{position:absolute;bottom:-8px;right:40px;width:0;height:0;border-left:8px solid transparent;border-right:8px solid transparent;border-top:8px solid var(--white)}.satisfaction-close{position:absolute;top:5px;right:5px;background:none;border:none;cursor:pointer;color:#999;padding:2px}.satisfaction-close:hover{color:var(--text-color)}@keyframes fadeInBubble{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.satisfaction-overlay{display:none}.loading-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background-color:#ffffffe6;display:flex;flex-direction:column;justify-content:center;align-items:center;z-index:10}.spinner{border:6px solid #f3f3f3;border-top:6px solid var(--primary-blue);border-radius:50%;width:50px;height:50px;animation:spin 1s linear infinite;margin-bottom:1rem}.loading-text{font-weight:500;color:var(--primary-blue)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.error-message{background-color:#f65d7c26;color:var(--dark-blue);border:1px solid var(--accent-red);padding:1rem;border-radius:8px}.info-message{font-size:.85rem;color:var(--dark-blue);background-color:#e6f0ff;padding:.75rem;border-radius:8px;border-left:4px solid var(--primary-blue);margin-top:1rem}.thumbnail-gallery{display:flex;flex-direction:column;gap:1rem}.thumbnail-item{width:100%;aspect-ratio:16 / 10;border:3px solid transparent;border-radius:var(--border-radius);cursor:pointer;overflow:hidden;padding:0;transition:all .2s ease,var(--bouncy-transition);background-color:var(--neutral-grey-dark)}.thumbnail-item:hover{transform:scale(1.05)}.thumbnail-item.selected{border-color:var(--primary-blue);box-shadow:0 0 10px #0050ff80;transform:scale(1.02)}.thumbnail-item img{width:100%;height:100%;object-fit:cover;display:block}.result-actions{display:flex;flex-wrap:wrap;gap:1rem;width:100%;margin-top:1rem;flex-shrink:0}.download-btn,.regenerate-btn,.add-template-btn,.add-collection-btn,.start-campaign-btn{border:none;padding:.5rem 1.25rem;font-size:.9rem;font-weight:600;border-radius:8px;cursor:pointer;transition:all .2s ease,box-shadow .2s ease;flex-grow:0;height:38px;display:inline-flex;align-items:center;justify-content:center;position:relative}.download-btn:hover,.regenerate-btn:hover,.add-template-btn:hover,.add-collection-btn:hover,.start-campaign-btn:hover{box-shadow:var(--box-shadow-hover)}.download-btn{background-color:var(--white);color:var(--primary-blue);border:1px solid #ccc}.download-btn:hover:not(:disabled){background-color:#f8f9fa;border-color:var(--primary-blue)}.regenerate-btn{background-color:var(--primary-blue);color:var(--white)}.regenerate-btn:hover:not(:disabled){background-color:var(--dark-blue)}.add-collection-btn{background-color:var(--white);color:var(--primary-blue);border:1px solid #ccc}.add-collection-btn:hover{background-color:#f8f9fa;border-color:var(--primary-blue)}.start-campaign-btn{background-color:var(--white);color:var(--primary-blue);border:1px solid #ccc}.start-campaign-btn:hover{background-color:#f8f9fa;border-color:var(--primary-blue)}.add-template-btn{background-color:var(--white);color:var(--primary-blue);border:1px solid #ccc}.add-template-btn:hover{background-color:#f0f6ff}.add-template-btn:disabled{opacity:.5;cursor:not-allowed;transform:none;background-color:var(--neutral-grey-dark);border-color:#ccc;color:#999}.result-nav-arrow{position:absolute;top:50%;transform:translateY(-50%);width:50px;height:50px;display:flex;align-items:center;justify-content:center;background:#ffffffd9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(0,0,0,.1);border-radius:50%;color:var(--neutral-black);cursor:pointer;z-index:10;transition:all .3s ease;opacity:.8;box-shadow:0 4px 15px #0000001a}.result-nav-arrow:hover{background:#fff;opacity:1;transform:translateY(-50%) scale(1.1);box-shadow:0 8px 25px #00000026;color:var(--primary-blue);border-color:var(--primary-blue)}.result-nav-arrow--prev{left:1.5rem}.result-nav-arrow--next{right:1.5rem}.result-nav-arrow svg{display:block}.ai-suggestion-panel{border-color:var(--light-blue)}.content-header{gap:.5rem!important}.content-header>div,.scene-builder-actions{display:flex!important;gap:.5rem!important;align-items:center!important}.content-header .header-btn,.content-header .regenerate-btn,.content-header .add-collection-btn,.content-header .add-template-btn,.content-header .download-btn{padding:.4rem .75rem!important;font-size:.8rem!important;font-weight:500!important;height:34px!important;display:inline-flex!important;align-items:center!important;justify-content:center!important;gap:.35rem!important;flex-grow:0!important;flex-shrink:0!important;white-space:nowrap!important;border-radius:6px!important}.content-header .header-btn,.content-header .add-collection-btn,.content-header .add-template-btn{background-color:var(--white)!important;color:var(--primary-blue)!important;border:1px solid #d0d5dd!important}.content-header .header-btn:hover,.content-header .add-collection-btn:hover,.content-header .add-template-btn:hover{background-color:#f8f9fa!important;border-color:var(--primary-blue)!important}.content-header .regenerate-btn{background-color:var(--primary-blue)!important;color:var(--white)!important;border:none!important}.content-header .regenerate-btn:hover{background-color:var(--dark-blue)!important}.content-header .header-btn svg{width:16px!important;height:16px!important;margin-right:0!important}.result-toolbar{position:absolute;top:1rem;right:1rem;display:flex;align-items:center;gap:.25rem;padding:.35rem;background:#fffffff2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:10px;box-shadow:0 4px 16px #0000001f;z-index:20;border:1px solid rgba(0,0,0,.06)}.result-toolbar-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:8px;cursor:pointer;color:var(--neutral-black);transition:all .15s ease}.result-toolbar-btn:hover:not(:disabled){background:var(--neutral-grey-light);color:var(--primary-blue)}.result-toolbar-btn:disabled{opacity:.4;cursor:not-allowed}.result-toolbar-btn svg{flex-shrink:0}.result-toolbar-divider{width:1px;height:24px;background:#e0e0e0;margin:0 .25rem}.ai-suggestion-panel .radio-label{font-size:.9rem}.ai-suggestion-panel .image-uploader label{padding:.6rem 1rem;font-size:.9rem}.ai-suggest-trigger{position:absolute;top:1rem;right:1rem;z-index:5;background-color:#0050ffe6;color:#fff;border:none;border-radius:50%;width:44px;height:44px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease,var(--bouncy-transition);box-shadow:0 4px 12px #00001e4d}.ai-suggest-trigger:hover{background-color:var(--primary-blue);transform:scale(1.1)}.ai-suggest-trigger svg{width:24px;height:24px;stroke:#fff}.satisfaction-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background-color:#00143cbf;display:flex;justify-content:center;align-items:center;z-index:20;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);animation:fadeIn .5s ease-in-out;padding:1rem}.satisfaction-content{background-color:var(--white);color:var(--text-color);padding:2.5rem;border-radius:var(--border-radius);box-shadow:0 8px 24px #0003;text-align:center;max-width:90%;transform:scale(.95);animation:popIn .5s cubic-bezier(.175,.885,.32,1.275) forwards}.satisfaction-content p{font-size:1.2rem;font-weight:500;color:var(--dark-blue);padding:0;margin:0}.satisfaction-subtext{font-size:1rem!important;font-weight:400!important;color:#555!important;margin-top:.5rem!important}.satisfaction-btn{margin-top:1.5rem;background-color:var(--primary-blue);color:var(--white);border:none;padding:.75rem 2.5rem;font-size:1rem;font-weight:500;border-radius:8px;cursor:pointer;transition:all .2s ease,var(--bouncy-transition)}.satisfaction-btn:hover{background-color:var(--dark-blue);transform:scale(1.05)}@keyframes popIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.canvas-overlay-text{position:absolute;top:0;left:0;width:100%;display:flex;justify-content:center;pointer-events:none;z-index:5;padding:1rem;text-align:center}.canvas-overlay-text.full-overlay{height:100%;align-items:center;background-color:#00000080}.canvas-overlay-text p{font-size:1.1rem;font-weight:500;color:#fff;background-color:#00001ebf;padding:.75rem 1.5rem;border-radius:8px;box-shadow:0 2px 8px #0000004d}@keyframes loginGradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}@keyframes loginCardEntrance{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes loginTitleGlow{0%,to{text-shadow:0 0 20px rgba(130,220,250,.3),0 0 40px rgba(0,80,255,.2)}50%{text-shadow:0 0 30px rgba(130,220,250,.5),0 0 60px rgba(0,80,255,.3)}}@keyframes floatingOrb{0%,to{transform:translate(0) scale(1)}33%{transform:translate(30px,-20px) scale(1.1)}66%{transform:translate(-20px,20px) scale(.95)}}.login-page-wrapper{display:flex;width:100vw;height:100vh;overflow:hidden}.login-left-panel{width:27%;min-width:340px;height:100%;display:flex;flex-direction:column;justify-content:center;align-items:center;background:var(--white);padding:3rem;position:relative;z-index:2}.login-right-panel{flex:1;height:100%;position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:center;align-items:center}.login-video-background{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;z-index:0}.login-right-panel:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#00008cb3,#0050ff80);z-index:1}.login-brand-header{text-align:center;z-index:2;animation:loginCardEntrance .8s cubic-bezier(.16,1,.3,1) forwards}.login-brand-title{font-size:4rem;font-weight:800;color:var(--white);letter-spacing:-1px;margin:0;text-shadow:0 4px 20px rgba(0,0,0,.3)}@keyframes subtitleReveal{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes subtitleGradient{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.login-brand-subtitle{font-size:1.4rem;font-weight:500;margin-top:1rem;color:#ffffffe6;animation:subtitleReveal .8s cubic-bezier(.16,1,.3,1) .3s forwards;opacity:0;letter-spacing:.5px;text-shadow:0 2px 10px rgba(0,0,0,.2)}.auth-container{display:flex;flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;max-width:400px}.auth-card{background:#ffffffd9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.9);padding:2.5rem 3rem;border-radius:24px;box-shadow:0 8px 32px #0050ff1a,0 2px 8px #00000014;width:100%;max-width:420px;animation:loginCardEntrance .8s cubic-bezier(.16,1,.3,1) .15s forwards;opacity:0}.auth-card h1{color:var(--dark-blue);font-size:1.75rem;font-weight:600;margin-bottom:1.75rem;text-align:center}.auth-form{display:flex;flex-direction:column;gap:1.25rem}.input-group{display:flex;flex-direction:column}.input-group label{font-size:.875rem;font-weight:500;margin-bottom:.5rem;color:var(--text-color)}.input-group input,.input-group select{padding:.875rem 1rem;border:1px solid #dde3ee;border-radius:12px;font-size:1rem;font-family:inherit;background:var(--white);color:var(--text-color);transition:all .3s ease}.input-group input::placeholder{color:#9ca3af}.input-group input:focus,.input-group select:focus{outline:none;border-color:var(--primary-blue);background:var(--white);box-shadow:0 0 0 4px #0050ff1a}.auth-btn{background:var(--primary-blue);color:var(--white);border:none;padding:1rem;font-size:1.1rem;font-weight:600;border-radius:12px;cursor:pointer;transition:all .3s ease;margin-top:.75rem;position:relative;overflow:hidden}.auth-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #0050ff66}.auth-btn:active:not(:disabled){transform:translateY(0)}.auth-btn:disabled{opacity:.5;cursor:not-allowed}.auth-toggle{text-align:center;margin-top:1.5rem;color:#6b7280;font-size:.9rem}.auth-toggle-link,.auth-toggle button{background:none;border:none;color:var(--primary-blue);font-weight:600;cursor:pointer;text-decoration:none;font-size:.9rem;transition:color .2s ease}.auth-toggle-link:hover,.auth-toggle button:hover{color:var(--dark-blue);text-decoration:underline}.auth-error{background-color:#f65d7c1f;color:#dc2626;border:1px solid rgba(246,93,124,.3);padding:.875rem;border-radius:12px;text-align:center;font-size:.9rem;animation:loginCardEntrance .3s ease forwards}.auth-info{background-color:#00dc7d26;color:var(--accent-green);border:1px solid rgba(0,220,125,.3);padding:.875rem;border-radius:12px;text-align:center;font-size:.9rem;margin-bottom:1rem}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00143cbf;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);animation:fadeIn .3s ease-in-out}.modal-content{background-color:var(--white);padding:2rem;border-radius:var(--border-radius);box-shadow:0 8px 24px #0003;width:100%;max-width:500px;animation:popIn .3s cubic-bezier(.175,.885,.32,1.275) forwards;position:relative}.modal-content h2{text-align:center;margin-top:0}.close-btn{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:1.5rem;cursor:pointer;color:#98a2b3;transition:color .2s ease,transform .2s ease;display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%}.close-btn:hover{color:var(--neutral-black);background-color:#f2f4f7}.profile-picture-container{width:120px;height:120px;border-radius:50%;margin:1rem auto;position:relative;overflow:hidden;border:4px solid var(--primary-blue);background-color:var(--neutral-grey-light)}.profile-picture-container img{width:100%;height:100%;object-fit:cover}.profile-picture-container .upload-overlay{position:absolute;bottom:0;left:0;width:100%;height:40%;background-color:#00001e99;color:#fff;display:flex;justify-content:center;align-items:center;font-size:.8rem;text-align:center;cursor:pointer;opacity:0;transition:opacity .3s ease}.profile-picture-container:hover .upload-overlay{opacity:1}.profile-form{margin-top:1rem}.danger-zone{margin-top:2rem;padding-top:1.5rem;border-top:2px solid var(--accent-red)}.danger-zone h3{color:var(--accent-red);margin-bottom:.5rem}.danger-zone p{font-size:.9rem;margin-bottom:1rem}.delete-btn{width:100%;background-color:var(--accent-red);color:var(--white);border:none;padding:.75rem;font-size:1rem;font-weight:700;border-radius:8px;cursor:pointer;transition:all .2s ease,var(--bouncy-transition)}.delete-btn:hover{filter:brightness(.9);transform:scale(1.02)}.history-modal{max-width:90vw;width:1200px;height:90vh;display:flex;flex-direction:column}.history-modal .modal-body{overflow-y:auto;flex-grow:1;padding-right:1rem}.history-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1.5rem}.history-item{background-color:var(--neutral-grey-light);border-radius:var(--border-radius);box-shadow:0 2px 5px #0000000d;display:flex;flex-direction:column;overflow:hidden}.history-item-preview{width:100%;aspect-ratio:16 / 10;background-color:var(--neutral-grey-dark);display:flex;align-items:center;justify-content:center}.history-item-preview img{width:100%;height:100%;object-fit:cover}.history-item-content{padding:1rem;display:flex;flex-direction:column;gap:.75rem;flex-grow:1}.history-item-content h3{font-size:1rem;font-weight:500;word-break:break-all}.ai-summary{font-size:.85rem;font-style:italic;color:#555;border-left:3px solid var(--light-blue);padding-left:.75rem;margin:.25rem 0}.notes-textarea{width:100%;min-height:80px;border:1px solid #ccc;border-radius:8px;padding:.5rem;font-family:inherit;font-size:.9rem;resize:vertical}.history-item-actions{display:flex;gap:.5rem;margin-top:auto}.history-item-actions button{flex:1 1 0;padding:.5rem;font-size:.8rem;border-radius:6px;cursor:pointer;border:1px solid transparent;transition:all .2s ease,var(--bouncy-transition)}.history-item-actions button:hover{transform:scale(1.05)}.history-action-load{background-color:var(--primary-blue);color:var(--white)}.history-action-download{background-color:var(--accent-green);color:var(--neutral-black)}.history-action-delete{background:none;border-color:var(--accent-red);color:var(--accent-red)}.history-action-delete:hover{background-color:var(--accent-red);color:var(--white);filter:brightness(.9)}.history-empty{text-align:center;padding:4rem 2rem;color:#888}.template-selector-container{display:flex;flex-direction:column;gap:1.5rem}.template-filters{display:flex;flex-direction:column;gap:.75rem}.filter-group{display:flex;align-items:center;flex-wrap:wrap;gap:.5rem}.filter-label{font-weight:500;margin-right:.5rem}.filter-group button{background:var(--neutral-grey-dark);border:1px solid #ccc;padding:.4rem .8rem;border-radius:20px;cursor:pointer;transition:all .2s ease,var(--bouncy-transition)}.filter-group button:hover{transform:scale(1.05)}.filter-group button.active{background:var(--primary-blue);color:var(--white);border-color:var(--primary-blue)}.template-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));grid-auto-rows:max-content;gap:1rem;max-height:250px;overflow-y:auto;padding:.5rem;background-color:var(--neutral-grey-light);border-radius:var(--border-radius);border:1px solid var(--neutral-grey-dark);align-items:start}.template-item{width:100%;aspect-ratio:1 / 1;border:3px solid transparent;border-radius:8px;cursor:pointer;overflow:hidden;padding:0;transition:all .2s ease,var(--bouncy-transition);background-color:#ccc;position:relative;display:block}.template-item:hover{transform:scale(1.05);border-color:var(--light-blue)}.template-item.selected{border-color:var(--primary-blue);box-shadow:0 0 10px #0050ff80;transform:scale(1.05)}.template-item img{width:100%;height:100%;object-fit:cover}.template-item-indicator{position:absolute;top:5px;left:5px;background-color:#0050ffcc;color:#fff;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;box-shadow:0 1px 3px #0000004d;pointer-events:none}.template-item-indicator.selection-checkmark{top:5px;right:5px;left:auto;background-color:var(--accent-green);width:28px;height:28px;z-index:3}.selection-count{font-weight:600;color:var(--primary-blue);background-color:#0050ff1a;padding:.5rem 1rem;border-radius:8px;text-align:center;font-size:.9rem}.template-selection-header{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:.5rem}.template-selection-header .info-message{margin:0;flex-grow:1}.expand-templates-btn{display:flex;align-items:center;gap:.4rem;padding:.5rem .75rem;background:#fff;border:1px solid var(--primary-blue);border-radius:8px;color:var(--primary-blue);font-size:.8rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.expand-templates-btn:hover{background:var(--primary-blue);color:#fff}.expand-templates-btn svg{flex-shrink:0}.template-fullscreen-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00143cd9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:9999;display:flex;align-items:center;justify-content:center;padding:24px;animation:overlayFadeIn .2s ease-out}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}.template-fullscreen-modal{width:100%;height:100%;background:#f8faff;border-radius:16px;box-shadow:0 30px 100px #001e5066;display:flex;flex-direction:column;position:relative;overflow:hidden;animation:modalPopIn .25s cubic-bezier(.34,1.56,.64,1)}@keyframes modalPopIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.template-fullscreen-modal h2{display:none}.template-fullscreen-modal .template-filters{display:flex;align-items:center;gap:1.5rem;background:#fff;padding:.75rem 1.25rem;border-bottom:1px solid #e8ecf4;flex-shrink:0}.template-fullscreen-modal .template-filters .filter-group{display:flex;align-items:center;gap:.4rem}.template-fullscreen-modal .template-filters .filter-label{font-size:.8rem;margin-right:.25rem}.template-fullscreen-modal .template-filters button{padding:.35rem .7rem;font-size:.8rem}.template-fullscreen-modal .selection-count{margin-left:auto;margin-bottom:0;padding:.4rem 1rem;font-size:.9rem;white-space:nowrap}.template-modal-close{position:absolute;top:.6rem;right:.75rem;width:40px;height:40px;border:none;background:transparent;font-size:1.5rem;color:#888;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;z-index:10;border-radius:8px}.template-modal-close:hover{background:#f65d7c1a;color:var(--accent-red)}.template-modal-body{flex:1;overflow-y:auto;padding:1rem 1.5rem!important;min-height:0}.template-grid-expanded{display:grid;grid-template-columns:repeat(auto-fill,minmax(500px,1fr))!important;gap:2rem!important;max-height:none!important;background:transparent;border:none;padding:0!important}.template-grid-expanded .template-item{aspect-ratio:16 / 9!important;border-radius:16px!important;box-shadow:0 8px 30px #00000026!important;transition:all .2s ease;overflow:hidden}.template-grid-expanded .template-item:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0050ff26}.template-grid-expanded .template-item.selected{border-color:var(--primary-blue);box-shadow:0 4px 16px #0050ff4d}.template-item-name{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent 0%,#00001ed9);color:#fff;font-size:.75rem;font-weight:500;padding:1.5rem .5rem .4rem;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.template-modal-footer{padding:.75rem 1.25rem;background:#fff;border-top:1px solid #e8ecf4;text-align:center;flex-shrink:0}.template-modal-footer .auth-btn{padding:.7rem 2.5rem;font-size:1rem;font-weight:600;border-radius:10px}.template-results-sidebar{width:140px;flex-shrink:0;background:var(--card-background);border-left:1px solid #e0e0e0;padding:1rem .75rem;display:flex;flex-direction:column;gap:.75rem;overflow-y:auto;max-height:100%}.template-results-sidebar h4{font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin:0 0 .5rem;padding:0 .25rem}.template-result-thumb{display:flex;flex-direction:column;align-items:center;gap:.4rem;padding:.5rem;background:transparent;border:2px solid transparent;border-radius:10px;cursor:pointer;transition:all .2s ease;width:100%}.template-result-thumb img{width:100%;height:70px;object-fit:cover;border-radius:6px}.template-result-thumb:hover{background:#0050ff0d;border-color:var(--light-blue)}.template-result-thumb.active{border-color:var(--primary-blue);background:#0050ff1a}.template-result-label{font-size:.7rem;font-weight:500;color:var(--dark-blue);max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:center}.template-delete-btn{position:absolute;top:5px;right:5px;width:24px;height:24px;background-color:#f65d7ce6;color:#fff;border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-weight:700;transition:transform .2s;z-index:5}.template-delete-btn:hover{transform:scale(1.1);background-color:var(--accent-red)}.category-form-group{margin-bottom:1.5rem}.category-form-group p{font-weight:500;margin-bottom:.75rem}.radio-group{display:flex;gap:1rem}.radio-label{display:flex;align-items:center;gap:.5rem;cursor:pointer}.werbemittel-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem}.werbemittel-item{width:100%;aspect-ratio:1 / 1;border:3px solid transparent;border-radius:var(--border-radius);cursor:pointer;overflow:hidden;padding:0;transition:all .2s ease,var(--bouncy-transition);background-color:#ccc;position:relative}.werbemittel-item:hover{transform:scale(1.05);border-color:var(--light-blue);box-shadow:0 4px 12px #0000001a}.werbemittel-item img,.werbemittel-item video{width:100%;height:100%;object-fit:cover}.werbemittel-item-name{position:absolute;bottom:0;left:0;width:100%;background:#00001e99;color:#fff;font-size:.8rem;padding:.5rem;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.werbemittel-item-indicator{position:absolute;top:8px;right:8px;background-color:#00001eb3;color:#fff;border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center;pointer-events:none;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:2}.werbemittel-item-indicator svg{width:16px;height:16px}.template-editor-mode{display:flex}.template-editor-sidebar{width:380px;padding-right:1.5rem}.template-editor-sidebar .template-grid{max-height:none;flex-grow:1}.template-editor-main{flex-grow:1;display:flex;flex-direction:column}.template-editor-layout{display:flex;gap:2rem;flex-grow:1;min-height:0}.template-editor-form{width:420px;flex-shrink:0;overflow-y:auto;padding-right:1rem;display:flex;flex-direction:column;gap:1rem}.template-editor-canvas-container{flex-grow:1;display:flex}.defined-areas-list{margin-top:1.5rem}.defined-areas-list h4{font-size:1rem;margin-bottom:.5rem}.defined-areas-list ul{list-style:none;padding:0;display:flex;flex-direction:column;gap:.5rem}.defined-areas-list li{background-color:var(--neutral-grey-light);padding:.5rem 1rem;border-radius:6px;display:flex;justify-content:space-between;align-items:center;font-size:.9rem}.defined-areas-list li button{background:none;border:none;color:var(--accent-red);font-size:1.2rem;cursor:pointer;line-height:1}.magnifier{position:absolute;width:150px;height:150px;border-radius:50%;border:3px solid var(--primary-blue);box-shadow:0 5px 15px #00001e4d;overflow:hidden;pointer-events:none;z-index:100;background-color:#fff}.magnifier canvas{width:100%;height:100%}.collections-mode-wrap{display:flex;flex-direction:column;flex-grow:1;overflow:hidden;min-height:0;height:100%}.collections-gallery-view{width:100%;min-height:0;overflow-y:auto;flex-grow:1}.collections-detail-layout{display:flex;flex-grow:1;overflow:hidden;min-height:0}.collections-sidebar{width:420px;flex-shrink:0;background-color:var(--card-background);border-right:1px solid #e0e0e0;padding:2rem;overflow-y:auto;display:flex;flex-direction:column;gap:1.5rem}.collections-sidebar .danger-zone{margin-top:auto;border-top:1px solid #ddd}.collection-info-box h2{font-size:1.8rem;margin-bottom:.5rem;color:var(--dark-blue)}.collection-actions{display:flex;flex-direction:column;gap:1rem;padding-top:1.5rem;border-top:1px solid #e0e0e0}.collection-actions h3{font-size:1.1rem;color:var(--text-color)}.collection-actions .header-btn,.collection-actions .download-btn{width:100%}.collections-main-content{flex-grow:1;padding:2rem;display:flex;flex-direction:column;min-height:0}.collections-mockup-preview{flex-grow:1;position:relative;display:flex;align-items:center;justify-content:center;background-color:transparent;border-radius:var(--border-radius);overflow:hidden}.collections-mockup-preview img{width:100%;height:100%;object-fit:contain}.collections-mockup-actions{position:absolute;top:1rem;right:1rem;display:flex;gap:.5rem;padding:.5rem;z-index:5}.action-icon-btn{background:transparent;border:none;cursor:pointer;padding:8px;border-radius:50%;color:#fff;transition:transform .2s ease;filter:drop-shadow(0 2px 4px rgba(0,0,0,.6));display:flex;align-items:center;justify-content:center}.action-icon-btn:hover{transform:scale(1.15)}.action-icon-btn.delete:hover{color:var(--accent-red)}.collections-thumbnail-strip{flex-shrink:0;margin-top:1.5rem;display:flex;gap:1rem;overflow-x:auto;padding:1rem;background-color:var(--card-background);border-radius:var(--border-radius)}.collections-thumbnail-strip .thumbnail-item{width:140px;height:90px;flex-shrink:0}.collections-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.collection-card{background-color:var(--white);border-radius:var(--border-radius);overflow:hidden;box-shadow:var(--box-shadow);transition:all .2s ease,var(--bouncy-transition);cursor:pointer;border:2px solid transparent}.collection-card:hover{transform:translateY(-5px);box-shadow:var(--box-shadow-hover);border-color:var(--primary-blue)}.collection-card-preview{width:100%;aspect-ratio:16 / 10;background-color:var(--neutral-grey-dark);display:flex;align-items:center;justify-content:center;position:relative}.collection-card-preview img{width:100%;height:100%;object-fit:cover}.collection-card-overlay{position:absolute;bottom:0;left:0;width:100%;background:linear-gradient(to top,#00001eb3,#00001e00);color:#fff;padding:2rem 1rem 1rem;font-size:.9rem}.collection-card-info{padding:1rem}.collection-card-info h3{font-size:1.1rem;font-weight:700;color:var(--dark-blue);margin-bottom:.25rem}.collection-card-info p{font-size:.85rem;color:#555}.modal-tabs{display:flex;border-bottom:1px solid #e0e0e0;margin-bottom:1.5rem}.modal-tab-btn{flex:1;padding:.75rem;background:none;border:none;cursor:pointer;font-size:1rem;font-weight:500;color:#888;border-bottom:3px solid transparent;transition:all .2s ease}.modal-tab-btn.active{color:var(--primary-blue);border-bottom-color:var(--primary-blue)}.existing-collections-list{max-height:200px;overflow-y:auto;border:1px solid #e0e0e0;border-radius:8px}.existing-collection-item{padding:.75rem 1rem;cursor:pointer;border-bottom:1px solid #e0e0e0}.existing-collection-item:last-child{border-bottom:none}.existing-collection-item:hover{background-color:#f0f6ff}.existing-collection-item.selected{background-color:var(--primary-blue);color:#fff}.gallery-layout-full{display:flex;width:100%;height:100%;overflow:hidden}.gallery-layout-modal{display:flex;width:100%;height:70vh;min-height:600px}.gallery-modal-content{max-width:1200px;width:90vw;height:auto;padding:0;overflow:hidden}.gallery-modal-content .close-btn{z-index:100;right:1.5rem;top:1.5rem}.gallery-sidebar{width:260px;background-color:var(--neutral-grey-light);border-right:1px solid #e0e0e0;padding:1.5rem;display:flex;flex-direction:column;flex-shrink:0}.gallery-sidebar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.gallery-sidebar-header h3{margin:0;font-size:1.1rem;color:var(--dark-blue)}.icon-btn{background:none;border:none;font-size:1.2rem;cursor:pointer;color:var(--primary-blue);width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center}.icon-btn:hover{background-color:#0050ff1a}.folder-create-input{display:flex;gap:.5rem;margin-bottom:1rem}.folder-create-input input{width:100%;padding:.4rem;border:1px solid #ccc;border-radius:4px;font-size:.9rem}.folder-create-input button{padding:.2rem .5rem;font-size:.8rem;cursor:pointer}.folder-list{display:flex;flex-direction:column;gap:.5rem;overflow-y:auto;flex-grow:1}.folder-item,.folder-item-wrapper{display:flex;align-items:center;padding:.6rem .8rem;border-radius:8px;cursor:pointer;font-size:.95rem;color:var(--text-color);text-decoration:none;transition:background-color .2s;background:none;border:none;width:100%;text-align:left}.folder-item-wrapper{padding:0;position:relative}.folder-item:hover,.folder-btn:hover{background-color:#e9ecef}.folder-item.active,.folder-item-wrapper.active .folder-btn{background-color:#0050ff1a;color:var(--primary-blue);font-weight:500}.folder-icon{margin-right:.75rem;font-size:1.1rem}.folder-btn{flex-grow:1;padding:.6rem .8rem;background:none;border:none;text-align:left;cursor:pointer;font-size:.95rem;font-family:inherit;display:flex;align-items:center}.folder-rename-input{flex-grow:1;margin:.3rem;padding:.3rem;border:1px solid var(--primary-blue);border-radius:4px}.folder-actions{display:none;padding-right:.5rem}.folder-item-wrapper:hover .folder-actions{display:flex}.folder-actions button{background:none;border:none;cursor:pointer;font-size:.9rem;margin-left:.3rem;opacity:.6}.folder-actions button:hover{opacity:1}.folder-actions button.delete{color:var(--accent-red)}.gallery-content{flex:1 1 0;display:flex;flex-direction:column;background-color:#fff;min-width:0;min-height:0;overflow:hidden}.gallery-header{padding:1.5rem 2rem;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.gallery-modal-content .gallery-header{padding-right:4rem}.gallery-header h2{margin:0;font-size:1.4rem}.gallery-header-actions{display:flex;gap:1rem}.upload-btn-label{background-color:var(--primary-blue);color:#fff;padding:.6rem 1.2rem;border-radius:8px;cursor:pointer;font-weight:500;font-size:.9rem;transition:background-color .2s}.upload-btn-label:hover{background-color:var(--dark-blue)}.gallery-grid{padding:2rem;overflow-y:auto;display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1.5rem;align-content:start;flex-grow:1;flex-basis:0;min-height:0;width:100%;padding-bottom:120px}.gallery-layout-modal .gallery-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));padding:1.5rem;padding-bottom:120px;overflow-y:auto}.gallery-card{background-color:#fff;border:1px solid #eee;border-radius:12px;box-shadow:0 2px 8px #0000000d;transition:all .2s;position:relative;display:flex;flex-direction:column;justify-content:space-between;height:auto}.gallery-card:hover{box-shadow:0 8px 16px #0000001a;transform:translateY(-2px)}.gallery-card.selectable:hover{border-color:var(--primary-blue);background-color:#f8faff}.gallery-card.selectable{cursor:pointer}.gallery-card-preview{aspect-ratio:1 / 1;background-color:#f3f3f3;display:flex;align-items:center;justify-content:center;position:relative}.gallery-card-preview img,.gallery-card-preview video{width:100%;height:100%;object-fit:contain}.type-badge{position:absolute;top:8px;right:8px;background-color:#000000b3;color:#fff;font-size:.7rem;padding:.25rem .5rem;border-radius:4px;font-weight:600;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.gallery-card-info{padding:1rem;flex-shrink:0}.gallery-card-info h4{margin:0 0 .5rem;font-size:1rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text-color);font-weight:500}.metadata-row{display:flex;gap:.6rem;align-items:center;font-size:.75rem;color:#666}.metadata-tag{background-color:#f0f0f0;padding:.15rem .4rem;border-radius:4px}.gallery-card-actions{padding:.8rem;border-top:1px solid #f0f0f0;display:flex;justify-content:space-between;align-items:center;gap:.5rem;background-color:#fafafa;flex-shrink:0}.action-icon-group{display:flex;gap:.5rem}.action-icon{background:#fff;border:1px solid #e0e0e0;cursor:pointer;width:32px;height:32px;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .2s;color:#555}.action-icon:hover{background-color:var(--primary-blue);color:#fff;border-color:var(--primary-blue)}.action-icon.delete:hover{background-color:var(--accent-red);color:#fff;border-color:var(--accent-red)}.action-icon svg{width:16px;height:16px;stroke-width:2}.use-btn{background-color:var(--primary-blue);color:#fff;border:none;padding:.5rem .8rem;font-size:.85rem;font-weight:500;border-radius:6px;cursor:pointer;transition:background-color .2s}.use-btn:hover{background-color:var(--dark-blue)}.move-dropdown-container{position:relative}.move-menu{position:absolute;bottom:100%;right:0;background:#fff;border:1px solid #ddd;border-radius:8px;box-shadow:0 4px 12px #00000026;padding:.5rem;min-width:160px;z-index:20;max-height:200px;overflow-y:auto}.move-menu button{display:block;width:100%;text-align:left;padding:.6rem .8rem;background:none;border:none;cursor:pointer;font-size:.9rem;color:var(--text-color);border-radius:4px}.move-menu button:hover{background-color:#f5f5f5}.gallery-empty-state{grid-column:1 / -1;text-align:center;padding:3rem;color:#888}.scene-builder-layout{display:flex;flex-grow:1;overflow:hidden}.scene-controls-overlay{position:absolute;top:1rem;right:1rem;display:flex;gap:.5rem;z-index:10}.control-btn{background-color:#fff;border:1px solid #ccc;border-radius:6px;padding:.4rem .8rem;font-size:.85rem;cursor:pointer;box-shadow:0 2px 5px #0000001a;transition:all .2s;display:flex;align-items:center;gap:.4rem}.control-btn:hover{background-color:#f8f9fa;transform:translateY(-1px);box-shadow:0 4px 8px #00000026}.control-btn.danger{color:var(--accent-red);border-color:var(--accent-red)}.control-btn.danger:hover{background-color:var(--accent-red);color:#fff}@media(max-width:1200px){.template-editor-form{width:360px}}@media(max-width:1024px){.sidebar,.collections-sidebar{width:340px}.thumbnail-sidebar{width:140px}.template-editor-mode{flex-direction:column;overflow-y:auto}.template-editor-sidebar{width:100%;border-right:none;border-bottom:1px solid #e0e0e0;height:auto;padding:1rem}.template-editor-layout{flex-direction:column}.template-editor-form{width:100%;overflow-y:visible}}@media(max-width:768px){.content-wrapper{flex-direction:column;overflow-y:auto}.main-content-layout,.collections-detail-layout,.gallery-layout-full{flex-direction:column}.sidebar,.collections-sidebar,.gallery-sidebar{width:100%;height:auto;max-height:50vh;border-right:none;border-bottom:1px solid #e0e0e0}.content-area,.gallery-content{height:auto;overflow-y:visible;padding:1rem}.sidebar,.collections-sidebar{padding:1rem}.thumbnail-sidebar{width:100%;overflow-y:visible}.thumbnail-gallery{flex-direction:row;overflow-x:auto}.thumbnail-item{flex-shrink:0;width:120px}.app-header{flex-direction:column;gap:1rem;padding:1rem}.gallery-layout-modal{flex-direction:column;height:auto;max-height:80vh;overflow-y:auto}}.warning-title{color:var(--accent-red);font-size:1.3rem;font-weight:700;margin-bottom:1rem}.warning-text{margin-bottom:2rem;color:#333}.modal-actions{display:flex;justify-content:space-between;gap:1rem;align-items:center}.pro-sidebar{background:var(--card-background);color:var(--text-color);display:flex;flex-direction:column;height:100%;border-right:1px solid #e0e0e0;font-family:var(--font-family)}.pro-sidebar-header{padding:1rem;border-bottom:1px solid #e0e0e0;background:var(--neutral-grey-light)}.pro-sidebar-header h3{margin:0;font-size:.9rem;font-weight:700;letter-spacing:1px;color:var(--dark-blue)}.spinner-small{width:20px;height:20px;border:2px solid #ccc;border-top-color:var(--primary-blue);border-radius:50%;animation:spin 1s linear infinite}.pro-scroll-container{flex-grow:1;overflow-y:auto;padding:1rem}.pro-section{margin-bottom:2rem}.pro-section-header{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;color:var(--primary-blue);font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.pro-control-group{margin-bottom:1.2rem}.pro-control-group label{display:block;font-size:.75rem;color:#666;margin-bottom:.5rem;font-weight:500}.pro-select{width:100%;background:#fff;border:1px solid #ccc;color:#333;padding:.5rem;border-radius:4px;font-size:.9rem;outline:none;transition:border-color .2s}.pro-select:focus{border-color:var(--primary-blue);box-shadow:0 0 0 2px #007bff1a}.pro-toggle-group{display:flex;background:#f0f0f0;border-radius:4px;padding:2px;border:1px solid #e0e0e0}.pro-toggle-btn{flex:1;background:transparent;border:none;color:#666;padding:.4rem;font-size:.8rem;cursor:pointer;border-radius:3px;transition:all .2s}.pro-toggle-btn.active{background:#fff;color:var(--primary-blue);font-weight:600;box-shadow:0 1px 3px #0000001a}.pro-toggle-group.small .pro-toggle-btn{padding:.2rem;font-size:.7rem}.pro-range{width:100%;height:4px;background:#e0e0e0;border-radius:2px;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.pro-range::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;background:#fff;border-radius:50%;cursor:pointer;border:2px solid var(--primary-blue);box-shadow:0 1px 3px #0003}.range-ticks{display:flex;justify-content:space-between;font-size:.7rem;color:#888;margin-top:.3rem}.pro-label-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.value-text{font-size:.7rem;color:var(--primary-blue);font-weight:600}.camera-angle-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem}.tech-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:.6rem;background:#fff;border:1px solid #ddd;border-radius:4px;color:#666;cursor:pointer;transition:all .2s}.tech-btn:hover{background:#f8f9fa;color:#333;border-color:#ccc}.tech-btn.active{background:#007bff0d;border-color:var(--primary-blue);color:var(--primary-blue);box-shadow:0 0 0 1px var(--primary-blue) inset}.tech-btn span{font-size:.6rem;margin-top:.3rem}.hud-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:#e0e0e0;padding:2px;border:1px solid #ccc;border-radius:4px;width:100%;aspect-ratio:16/9}.hud-cell{background:#fff;border:none;cursor:pointer;position:relative;display:flex;align-items:center;justify-content:center}.hud-cell:hover{background:#f8f9fa}.hud-cell.active{background:#007bff1a}.hud-cell.active .reticle{width:12px;height:12px;border:2px solid var(--primary-blue);border-radius:50%;position:relative}.hud-cell.active .reticle:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:2px;height:2px;background:var(--primary-blue)}.hud-cell.empty{background:#f0f0f0;cursor:default}.pro-checkbox-row{display:flex;align-items:center;margin-bottom:.5rem}.pro-checkbox-label{display:flex;align-items:center;cursor:pointer;font-size:.85rem;color:#333;position:relative;padding-left:24px}.pro-checkbox-label input{position:absolute;opacity:0;cursor:pointer}.checkmark{position:absolute;top:0;left:0;height:16px;width:16px;background-color:#fff;border:1px solid #ccc;border-radius:3px}.pro-checkbox-label:hover input~.checkmark{background-color:#f8f9fa;border-color:#bbb}.pro-checkbox-label input:checked~.checkmark{background-color:var(--primary-blue);border-color:var(--primary-blue)}.checkmark:after{content:"";position:absolute;display:none}.pro-checkbox-label input:checked~.checkmark:after{display:block}.pro-checkbox-label .checkmark:after{left:5px;top:1px;width:4px;height:9px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}.pro-footer{padding:1rem;border-top:1px solid #e0e0e0;background:#f8f9fa}.pro-sub-controls{margin-top:.8rem;padding-left:1rem;border-left:2px solid #e0e0e0}.pro-slider-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.pro-slider-row span{font-size:.75rem;color:#666}.value-badge{background:#e0e0e0;padding:2px 4px;border-radius:3px;color:#333!important;font-size:.7rem!important;font-weight:600}.camera-angle-selector{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem}.angle-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:.5rem;background:#f5f5f5;border:1px solid #ddd;border-radius:6px;cursor:pointer;transition:all .2s}.angle-btn:hover{background:#e9ecef}.angle-btn.active{background:var(--primary-blue);color:#fff;border-color:var(--primary-blue)}.focus-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:4px;width:100%;aspect-ratio:16/9;background:#eee;padding:4px;border-radius:4px;border:1px solid #ddd}.focus-cell{background:#fff;border:1px solid #ddd;border-radius:2px;cursor:pointer;position:relative;transition:all .2s;display:flex;align-items:center;justify-content:center}.focus-cell:hover{background:#f8f9fa;border-color:#bbb}.focus-cell.active{background:#007bff1a;border-color:var(--primary-blue)}.focus-cell.empty{background:#f5f5f5;cursor:default;border:none}.focus-indicator{width:8px;height:8px;background:var(--primary-blue);border-radius:50%;box-shadow:0 0 0 2px #007bff4d}.pos-template-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;max-height:180px;overflow-y:auto;padding:4px}.pos-template-item{position:relative;height:60px;border-radius:4px;overflow:hidden;cursor:pointer;border:2px solid transparent;background:#f0f0f0;transition:border-color .2s,transform .2s}.pos-template-item:hover{border-color:var(--light-blue);transform:scale(1.02)}.pos-template-item.selected{border-color:var(--primary-blue)}.pos-template-item img{width:100%;height:100%;object-fit:cover;display:block}.pos-template-label{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,#000000b3);color:#fff;font-size:.55rem;padding:8px 4px 3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pos-template-empty{grid-column:1 / -1;padding:1rem;text-align:center;color:#888;font-size:.8rem}.glass-shimmer-container{position:absolute;top:0;left:0;right:0;bottom:0;background:#ffffff26;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:100;display:flex;flex-direction:column;align-items:center;justify-content:center;overflow:hidden}.shimmer-bar{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(110deg,#fff0 30%,#fff6,#fff0 70%);background-size:200% 100%;animation:glimmer 2.5s infinite linear;pointer-events:none}@keyframes glimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.glass-loader-text{position:relative;z-index:101;font-family:Inter,sans-serif;font-size:.95rem;font-weight:500;color:#333;background:#ffffffb3;padding:.5rem 1.2rem;border-radius:20px;box-shadow:0 4px 15px #0000000d;display:flex;align-items:center;gap:.6rem;letter-spacing:.02em}.glass-loader-icon{width:16px;height:16px;border:2px solid #333;border-top-color:transparent;border-radius:50%;animation:spin 1s linear infinite;opacity:.7}@keyframes spin-subtle{to{transform:rotate(360deg)}}.glass-shimmer-generic-bg{background:linear-gradient(135deg,#f5f7fa,#c3cfe2)}.template-selected-thumbnails{display:flex;gap:.75rem;padding:1rem 1.25rem;background:#f0f4ff;border-top:1px solid #e8ecf4;overflow-x:auto;align-items:center;flex-shrink:0;min-height:80px}.selected-thumbnail-item{position:relative;width:60px;height:60px;border-radius:8px;overflow:visible;flex-shrink:0;cursor:pointer;border:2px solid var(--primary-blue);transition:transform .2s}.selected-thumbnail-item img{width:100%;height:100%;object-fit:cover;border-radius:6px;display:block}.selected-thumbnail-item:hover{transform:scale(1.05)}.remove-selection-btn{position:absolute;top:-8px;right:-8px;width:20px;height:20px;background:var(--accent-red);color:#fff;border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;line-height:1;cursor:pointer;z-index:2;box-shadow:0 2px 4px #0003}.remove-selection-btn:hover{background:#d6304b;transform:scale(1.1)}.template-modal-body{padding-bottom:0!important}.editor-layout{display:flex;height:100%;width:100%;background-color:var(--background-color)}.editor-sidebar{width:320px;flex-shrink:0;background-color:var(--card-background);border-right:1px solid #e0e0e0;display:flex;flex-direction:column}.editor-sidebar-header{padding:1.5rem;border-bottom:1px solid #e0e0e0;background-color:var(--card-background)}.editor-list{flex-grow:1;overflow-y:auto}.editor-list-item{padding:1rem 1.5rem;border-bottom:1px solid #f0f0f0;cursor:pointer;transition:background-color .2s ease;border-left:4px solid transparent}.editor-list-item:hover{background-color:var(--neutral-grey-light)}.editor-list-item.selected{background-color:#f0f7ff;border-left-color:var(--primary-blue)}.editor-list-item-title{font-weight:600;margin-bottom:.25rem;color:var(--text-color)}.editor-list-item-meta{font-size:.85rem;color:#888}.editor-main{flex-grow:1;padding:2rem;overflow-y:auto;background-color:var(--neutral-grey-light)}.editor-card{background-color:var(--white);border-radius:var(--border-radius);box-shadow:var(--box-shadow);padding:2rem;max-width:800px;margin:0 auto}.editor-form-group{margin-bottom:1.5rem}.editor-form-label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-color)}.editor-input{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:8px;font-size:1rem;transition:border-color .2s;font-family:inherit}.editor-input:focus{border-color:var(--primary-blue);outline:none}.editor-radio-group{display:flex;gap:2rem}.editor-radio-label{display:flex;align-items:center;gap:.5rem;cursor:pointer}.editor-image-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:1rem}.editor-ref-image{position:relative;aspect-ratio:1;border-radius:8px;overflow:hidden;border:1px solid #eee}.editor-ref-image img{width:100%;height:100%;object-fit:cover}.editor-delete-btn{position:absolute;top:5px;right:5px;background:#ffffffe6;color:var(--accent-red);border:none;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 2px 5px #0003}.editor-add-image{aspect-ratio:1;border:2px dashed #ddd;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#999;font-size:2rem;transition:all .2s}.editor-add-image:hover{border-color:var(--primary-blue);color:var(--primary-blue);background-color:#f0f7ff}.editor-ref-image img{cursor:pointer;transition:opacity .2s}.editor-ref-image img:hover{opacity:.85}.editor-checkbox-label{display:flex;align-items:flex-start;gap:.75rem;cursor:pointer;font-size:.95rem;line-height:1.4;color:var(--text-color)}.editor-checkbox-label input[type=checkbox]{width:18px;height:18px;margin-top:2px;flex-shrink:0;accent-color:var(--primary-blue);cursor:pointer}.lightbox-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000e6;z-index:9999;display:flex;align-items:center;justify-content:center}.lightbox-close{position:absolute;top:20px;right:20px;background:transparent;border:none;color:#fff;font-size:2.5rem;cursor:pointer;width:50px;height:50px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .2s;z-index:10001}.lightbox-close:hover{background:#ffffff1a}.lightbox-content{max-width:90vw;max-height:85vh;display:flex;align-items:center;justify-content:center}.lightbox-image{max-width:100%;max-height:85vh;object-fit:contain;border-radius:8px;box-shadow:0 10px 50px #00000080}.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);background:#ffffff1a;border:none;color:#fff;font-size:3rem;cursor:pointer;width:60px;height:80px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:background .2s;z-index:10000}.lightbox-nav:hover{background:#fff3}.lightbox-nav-prev{left:20px}.lightbox-nav-next{right:20px}.lightbox-counter{position:absolute;bottom:30px;left:50%;transform:translate(-50%);background:#0009;color:#fff;padding:.5rem 1rem;border-radius:20px;font-size:.9rem;font-weight:500;letter-spacing:.5px}.placement-area-search{position:relative;width:100%}.placement-area-search__input-wrapper{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#fff;border:1px solid #e0e0e0;border-radius:10px;min-height:42px;transition:border-color .2s,box-shadow .2s}.placement-area-search__input-wrapper:focus-within{border-color:var(--primary-blue);box-shadow:0 0 0 3px #0050ff1a}.placement-area-search__icon{color:#94a3b8;flex-shrink:0}.placement-area-search__input{flex:1;min-width:100px;border:none;outline:none;font-size:.9rem;font-family:var(--font-family);background:transparent}.placement-area-search__input::placeholder{color:#94a3b8}.placement-area-search__tag{display:flex;align-items:center;gap:.35rem;padding:.3rem .5rem;background:var(--primary-blue);color:#fff;border-radius:6px;font-size:.8rem;font-weight:600;white-space:nowrap}.placement-area-search__tag-remove{display:flex;align-items:center;justify-content:center;background:none!important;border:none!important;color:var(--accent-red);cursor:pointer;padding:0;transition:transform .15s}.placement-area-search__tag-remove:hover{transform:scale(1.2)}.placement-area-search__suggestions{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#fff;border:1px solid #e0e0e0;border-radius:10px;box-shadow:0 8px 24px #0000001f;list-style:none;padding:.5rem 0;margin:0;z-index:100;max-height:200px;overflow-y:auto}.placement-area-search__suggestion{padding:.6rem 1rem;cursor:pointer;font-size:.9rem;color:#475467;transition:background-color .15s}.placement-area-search__suggestion:hover,.placement-area-search__suggestion.highlighted{background:var(--neutral-grey-light);color:var(--primary-blue)}.scene-builder-layout{display:flex;height:100%;width:100%;overflow:hidden;background-color:var(--background-color)}.armi-launcher{position:fixed;bottom:8px;right:8px;z-index:999;display:flex;flex-direction:column;align-items:flex-end;gap:.4rem}.armi-launcher--hidden{display:none}.armi-restore-btn{position:fixed;bottom:8px;right:8px;z-index:999;width:24px;height:24px;border-radius:50%;background:var(--primary-blue);border:none;cursor:pointer;opacity:.5;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.armi-restore-btn:hover{opacity:1;transform:scale(1.2)}.armi-restore-btn svg{width:14px;height:14px;color:#fff}.armi-launcher__hide{position:absolute;top:-8px;left:-8px;width:24px;height:24px;border-radius:50%;background:#00000080;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s,background .2s;color:#fff;font-size:16px;line-height:1;z-index:10}.armi-launcher:hover .armi-launcher__hide{opacity:1}.armi-launcher__hide:hover{background:var(--accent-red)}.armi-speech-bubble{position:relative;background:#fff;border-radius:12px;padding:.5rem 1.5rem .5rem .75rem;box-shadow:0 2px 12px #0000001f;max-width:180px;font-size:.75rem;animation:armi-bubble-pop .3s cubic-bezier(.175,.885,.32,1.275)}.armi-speech-bubble__text{font-size:.7rem;font-weight:500;color:var(--text-color);line-height:1.3}.armi-speech-bubble__close{position:absolute;top:2px;right:4px;background:none;border:none;font-size:1rem;color:#aaa;cursor:pointer;padding:0;line-height:1;transition:color .2s}.armi-speech-bubble__close:hover{color:var(--accent-red)}.armi-speech-bubble__tail{position:absolute;bottom:-6px;right:20px;width:0;height:0;border-left:7px solid transparent;border-right:7px solid transparent;border-top:7px solid white}@keyframes armi-bubble-pop{0%{opacity:0;transform:scale(.8) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.armi-launcher__button{display:flex;align-items:center;justify-content:center;padding:0;background:transparent;border:none;cursor:pointer;transition:transform .3s cubic-bezier(.175,.885,.32,1.275);filter:drop-shadow(0 2px 8px rgba(0,0,0,.15))}.armi-launcher__button:hover,.armi-launcher__button--hover{transform:translateY(-3px) scale(1.1);filter:drop-shadow(0 4px 12px rgba(0,80,255,.25))}.armi-launcher__button:active{transform:translateY(-1px) scale(1.05)}.armi-avatar .armi-body-group{animation:armi-bob 4s ease-in-out infinite}@keyframes armi-bob{0%,to{transform:translateY(0)}50%{transform:translateY(-2px)}}.armi-avatar .armi-waving-arm{transform-origin:68px 70px;transition:transform .3s ease}.armi-avatar--hover .armi-waving-arm{animation:armi-wave .6s ease-in-out infinite}@keyframes armi-wave{0%,to{transform:rotate(0)}25%{transform:rotate(-25deg)}75%{transform:rotate(20deg)}}.armi-avatar .armi-blink-left,.armi-avatar .armi-blink-right{animation:armi-blink 4s ease-in-out infinite}@keyframes armi-blink{0%,90%,to{ry:0;opacity:0}95%{ry:6px;opacity:1}}.armi-avatar .armi-antenna{animation:armi-glow 2s ease-in-out infinite}@keyframes armi-glow{0%,to{filter:brightness(1) drop-shadow(0 0 2px rgba(111,181,224,.5))}50%{filter:brightness(1.3) drop-shadow(0 0 8px rgba(111,181,224,.8))}}.armi-avatar--hover .armi-antenna{animation-duration:.5s}.object-library{display:flex;flex-direction:column;gap:.5rem;padding:1.5rem!important;height:100%;overflow:hidden}.object-library h2{flex-shrink:0;margin-bottom:.75rem;padding-bottom:.75rem;padding-left:3rem;border-bottom:1px solid #e0e0e0;font-size:1.2rem}.scene-builder-layout .sidebar:not(.object-library) .sidebar-header{padding-right:3rem}.object-library__remove-btn{flex-shrink:0;display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:transparent;border:1px solid var(--accent-red);border-radius:10px;color:var(--accent-red);font-weight:600;font-size:.9rem;cursor:pointer;margin-bottom:.75rem;transition:all .2s ease}.object-library__remove-btn:hover{background:#f65d7c1a;transform:translateY(-2px)}.object-library__search{flex-shrink:0;display:flex;align-items:center;gap:.5rem;padding:.6rem .75rem;background:#f8fafc;border:1px solid #E2E8F0;border-radius:10px;margin-bottom:.75rem}.object-library__search svg{color:#94a3b8;flex-shrink:0;width:16px;height:16px}.object-library__search input{flex:1;border:none;background:transparent;font-size:.9rem;color:var(--neutral-black);outline:none}.object-library__search input::placeholder{color:#94a3b8}.object-library__info-row{flex-shrink:0;display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.object-library__info-message{flex:1;font-size:.8rem;color:#475467;background:#eff8ff;padding:.5rem .75rem;border-radius:8px;border-left:3px solid var(--primary-blue)}.object-library__expand-btn{display:flex;align-items:center;gap:.4rem;padding:.5rem .75rem;background:var(--white);border:1px solid var(--primary-blue);border-radius:8px;color:var(--primary-blue);font-weight:600;font-size:.8rem;cursor:pointer;transition:all .2s ease;white-space:nowrap}.object-library__expand-btn:hover{background:#0050ff0d;transform:translateY(-2px)}.object-library__tabs{flex-shrink:0;display:flex;gap:0;background:var(--neutral-grey-light);padding:.25rem;border-radius:10px;margin-bottom:.75rem}.object-library__tabs button{flex:1;padding:.5rem .75rem;border:none;background:transparent;border-radius:8px;cursor:pointer;font-size:.85rem;font-weight:600;color:#64748b;transition:all .2s ease}.object-library__tabs button:hover{color:var(--primary-blue)}.object-library__tabs button.active{background:var(--white);color:var(--primary-blue);box-shadow:0 1px 4px #0000000f}.object-library__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem;overflow-y:auto;overflow-x:hidden;padding:.75rem;background:var(--neutral-grey-light);border-radius:12px;border:1px solid #E2E8F0;max-height:400px}.object-library__grid--expanded{max-height:400px;grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.object-library__loading{grid-column:1 / -1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;padding:1.5rem;color:#94a3b8;font-size:.85rem}.object-library__empty{grid-column:1 / -1;text-align:center;padding:1.5rem 1rem;color:#94a3b8;font-size:.85rem}.object-library__card{display:flex;flex-direction:column;align-items:center;padding:.5rem;background:var(--white);border:1px solid #E2E8F0;border-radius:10px;cursor:pointer;transition:all .2s cubic-bezier(.2,.8,.2,1)}.object-library__card:hover{border-color:var(--primary-blue);transform:translateY(-3px);box-shadow:0 6px 12px #0050ff1a}.object-library__card img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:6px;margin-bottom:.4rem;background:#f1f5f9}.object-library__card--compact{padding:.4rem}.object-library__card--compact img{aspect-ratio:4/3;border-radius:5px;margin-bottom:.3rem}.object-library__card--compact .object-library__card-name{font-size:.7rem;-webkit-line-clamp:1;margin-bottom:.15rem}.object-library__card--compact .object-library__card-type{font-size:.55rem;padding:.1rem .35rem}.object-library__card-placeholder{width:100%;aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#e0e7ff,#c7d2fe);border-radius:6px;margin-bottom:.4rem;font-size:1.5rem;font-weight:700;color:var(--primary-blue)}.object-library__card-name{font-size:.75rem;font-weight:600;color:var(--neutral-black);text-align:center;margin-bottom:.2rem;line-height:1.2;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;width:100%}.object-library__card-type{font-size:.6rem;font-weight:700;padding:.15rem .4rem;border-radius:4px;text-transform:uppercase;letter-spacing:.03em}.object-library__card-type.indoor{background:#dbeafe;color:#2563eb}.object-library__card-type.outdoor{background:#d1fae5;color:#059669}.object-library__add-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1rem;background:var(--white);border:1px dashed var(--primary-blue);border-radius:10px;color:var(--primary-blue);font-weight:600;font-size:.9rem;cursor:pointer;margin-top:1rem;transition:all .2s ease}.object-library__add-btn:hover{background:#0050ff0d;border-style:solid;transform:translateY(-2px)}.object-library__selected{margin-top:.75rem;padding-top:.75rem;border-top:1px solid #ddd}.object-library__selected h3{font-size:.85rem;font-weight:600;margin-bottom:.4rem;color:var(--neutral-black)}.object-library__selected p{font-size:.8rem;color:#555;max-height:50px;overflow:hidden;margin-bottom:.5rem}.object-library-modal{max-width:700px;width:90vw;max-height:85vh;display:flex;flex-direction:column}.object-library-modal h2{margin:0 0 1.25rem;font-size:1.4rem;font-weight:700;color:var(--neutral-black);border:none;padding:0}.object-library-modal .object-library__search,.object-library-modal .object-library__tabs{margin-bottom:1rem}.object-library-modal .object-library__grid{max-height:none;flex:1;overflow-y:auto}.scene-builder-layout{display:flex;height:100%;position:relative}.scene-builder-layout .sidebar{transition:width .3s ease,min-width .3s ease,padding .3s ease,opacity .3s ease;position:relative}.scene-builder-layout .sidebar.collapsed{width:60px!important;min-width:60px!important;padding:0!important;overflow:hidden}.scene-builder-layout .sidebar.collapsed>*:not(.sidebar-toggle-btn){opacity:0;pointer-events:none;visibility:hidden}.sidebar-toggle-btn{position:absolute;top:1rem;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--white);border:1px solid #e0e0e0;border-radius:8px;cursor:pointer;z-index:10;transition:all .2s ease;color:#666}.sidebar-toggle-btn:hover{background:var(--neutral-grey-light);color:var(--primary-blue);border-color:var(--primary-blue)}.sidebar-toggle-btn--left{right:1rem}.sidebar-toggle-btn--right{left:1rem}.sidebar.collapsed .sidebar-toggle-btn{top:1rem;left:50%!important;right:auto!important;transform:translate(-50%);opacity:1!important;pointer-events:auto!important;visibility:visible!important}.ad-builder-layout{display:flex;height:100%;min-height:500px;width:100%;background-color:var(--background-color);overflow:hidden;position:relative;font-family:var(--font-family)}.ab-sidebar{width:320px;background-color:var(--card-background);border-right:1px solid #e0e0e0;display:flex;flex-direction:column;z-index:10;flex-shrink:0;height:100%}.ab-sidebar.right{border-right:none;border-left:1px solid #e0e0e0}.ab-header{padding:1rem;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;align-items:center;background-color:#fafbfc}.ab-header h2{font-size:1rem;font-weight:600;color:var(--neutral-black);display:flex;align-items:center;gap:.5rem}.ab-header-accent{width:4px;height:16px;background-color:var(--primary-blue);border-radius:2px;display:inline-block}.ab-content{flex:1;overflow-y:auto;padding:0}.ab-footer{padding:1rem;border-top:1px solid #e0e0e0;background-color:#fafbfc;margin-top:auto}.ab-canvas-area{flex:1;min-height:400px;background-color:#f0f2f5;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;box-shadow:inset 0 0 20px #00000005}.ab-canvas-container{position:relative;width:100%;height:100%}.pos-mode-toggle{background-color:#fffffff2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:.3rem;border-radius:50px;box-shadow:0 4px 12px #00000014;display:flex;gap:.25rem;border:1px solid rgba(0,0,0,.05)}.pos-mode-btn{padding:.5rem 1.25rem;border-radius:50px;border:none;background:none;font-size:.9rem;font-weight:500;color:#666;cursor:pointer;transition:all .2s cubic-bezier(.2,.8,.2,1);white-space:nowrap}.pos-mode-btn:hover{color:var(--neutral-black);background-color:#00000008}.pos-mode-btn.active{background-color:var(--primary-blue);color:var(--white);box-shadow:0 2px 8px #0050ff33}.beta-tag{font-size:.65rem;background-color:#0050ff1a;color:var(--primary-blue);padding:.1rem .3rem;border-radius:4px;margin-left:.4rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;vertical-align:middle}.pos-mode-btn.active .beta-tag{background-color:#fff3;color:#fff}.ab-btn-primary{width:100%;padding:.75rem 1rem;background-color:var(--primary-blue);color:var(--white);border:none;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:.5rem}.ab-btn-primary:hover:not(:disabled){background-color:var(--dark-blue);transform:translateY(-1px);box-shadow:0 4px 12px #0050ff33}.ab-btn-primary:disabled{background-color:#ccc;cursor:not-allowed;opacity:.7}.ab-btn-secondary{width:100%;padding:.6rem 1rem;background-color:var(--white);border:1px solid #ddd;color:var(--text-color);border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s ease}.ab-btn-secondary:hover{border-color:var(--primary-blue);color:var(--primary-blue);background-color:#f8faff}.ab-upload-card{background-color:var(--white);padding:2.5rem;border-radius:16px;box-shadow:0 10px 30px #0000000d;text-align:center;max-width:400px;border:1px solid rgba(0,0,0,.03)}.ab-icon-circle{width:64px;height:64px;background-color:#f0f7ff;color:var(--primary-blue);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;margin:0 auto 1.5rem}.ab-list-header{padding:.75rem 1rem;font-size:.75rem;font-weight:600;text-transform:uppercase;color:#888;background-color:#f8f9fa;border-bottom:1px solid #eee;letter-spacing:.5px;position:sticky;top:0}.ab-list-item{padding:.75rem 1rem;display:flex;align-items:center;gap:.75rem;cursor:pointer;border-bottom:1px solid #f5f5f5;transition:background-color .1s ease}.ab-list-item:hover{background-color:#f8faff}.ab-list-item.selected{background-color:#f0f7ff;border-left:3px solid var(--primary-blue)}.ab-item-icon{width:32px;height:32px;border-radius:6px;background-color:var(--white);border:1px solid #eee;display:flex;align-items:center;justify-content:center;font-size:.8rem;color:#666;flex-shrink:0}.ab-list-item.selected .ab-item-icon{border-color:var(--light-blue);color:var(--primary-blue)}.ab-item-info{flex:1;min-width:0}.ab-item-title{font-size:.9rem;font-weight:500;color:var(--text-color);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ab-list-item.selected .ab-item-title{color:var(--primary-blue)}.ab-item-subtitle{font-size:.75rem;color:#999}.glass-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background-color:#ffffffb3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:50;display:flex;align-items:center;justify-content:center;flex-direction:column}.glass-box{background:#fffc;border:1px solid rgba(255,255,255,.3);padding:1.5rem 3rem;border-radius:12px;box-shadow:0 8px 32px #0000001a}.ab-hidden{display:none!important}.ab-variants-gallery{width:100%;height:100%;padding:2rem;display:flex;flex-direction:column;gap:1.5rem;overflow:hidden}.ab-variants-header{display:flex;justify-content:space-between;align-items:center;gap:1.5rem}.ab-variants-title{display:flex;flex-direction:column;gap:.35rem}.ab-variants-header h2{font-size:1.5rem;font-weight:700;color:var(--primary-blue);margin:0}.ab-variants-subtitle{font-size:.85rem;color:#6b7280}.ab-variants-actions{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap}.ab-variants-regenerate{display:flex;align-items:center;gap:.5rem;color:#fff;border:none;padding:8px 16px;border-radius:8px;background-color:var(--primary-blue);cursor:pointer;font-size:.9rem;font-weight:500;box-shadow:0 2px 4px #0050ff33;transition:all .2s ease}.ab-variants-regenerate:hover{background-color:var(--dark-blue);transform:translateY(-1px)}.ab-variants-stage{flex:1;min-height:420px;padding:1.5rem;border-radius:16px;border:1px solid rgba(0,0,0,.06);background:radial-gradient(120% 140% at 20% 0%,#0050ff14,#fff9 55%),linear-gradient(135deg,#fff,#f3f6fb);box-shadow:0 12px 24px #0000000f;display:flex}.ab-variants-viewport{position:relative;width:100%;height:100%;border-radius:12px;overflow:hidden;border:1px solid rgba(0,0,0,.08);background:#f8fafc;box-shadow:inset 0 0 0 1px #fff9;touch-action:none}.ab-variants-viewport.zoomed{cursor:grab}.ab-variants-viewport.zoomed:active{cursor:grabbing}.ab-variants-canvas-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(0,0,0,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(0,0,0,.04) 1px,transparent 1px);background-size:36px 36px;opacity:.2;pointer-events:none}.ab-variants-image-center{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%)}.ab-variants-image-frame{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.ab-variants-image-transform{width:100%;height:100%;transform-origin:center;will-change:transform}.ab-variants-image{width:100%;height:100%;object-fit:contain;-webkit-user-select:none;user-select:none;pointer-events:none}.ab-variants-select{position:absolute;bottom:16px;right:16px;width:auto;padding:.6rem 1.1rem;z-index:2;box-shadow:0 8px 16px #0050ff33}.ab-variants-thumbs{display:flex;gap:.75rem;overflow-x:auto;padding-bottom:.25rem}.ab-variants-thumb{width:96px;height:96px;border-radius:12px;border:1px solid transparent;background:#fff;box-shadow:0 6px 12px #00000014;cursor:pointer;padding:.35rem;flex:0 0 auto;transition:border-color .2s ease,box-shadow .2s ease}.ab-variants-thumb.selected{border-color:var(--primary-blue);box-shadow:0 0 0 2px #0050ff26}.ab-variants-thumb img{width:100%;height:100%;object-fit:contain;border-radius:8px;background:#fff}._overlay_1xn16_3{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000}._modal_1xn16_14{background:#fff;border-radius:20px;padding:2rem;width:100%;max-width:440px;position:relative;box-shadow:0 20px 60px #0003}._closeBtn_1xn16_24{position:absolute;top:1rem;right:1rem;background:none;border:none;color:#64748b;cursor:pointer;padding:.5rem;border-radius:8px;transition:all .2s}._closeBtn_1xn16_24:hover{background:#f1f5f9;color:#0f172a}._header_1xn16_42{text-align:center;margin-bottom:1.5rem}._iconWrapper_1xn16_47{width:56px;height:56px;background:linear-gradient(135deg,#0050ff,#0040cc);border-radius:16px;display:flex;align-items:center;justify-content:center;color:#fff;margin:0 auto 1rem}._header_1xn16_42 h2{margin:0 0 .5rem;font-size:1.5rem;font-weight:700;color:#0f172a}._subtitle_1xn16_66{margin:0;font-size:.9rem;color:#64748b}._form_1xn16_73{display:flex;flex-direction:column;gap:1.25rem}._field_1xn16_79{display:flex;flex-direction:column;gap:.5rem}._field_1xn16_79>label{display:flex;align-items:center;gap:.5rem;font-size:.85rem;font-weight:600;color:#475569}._expiryOptions_1xn16_94{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem}._expiryBtn_1xn16_100{padding:.6rem .75rem;border:1px solid #E2E8F0;border-radius:10px;background:#fff;color:#475569;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s}._expiryBtn_1xn16_100:hover{border-color:#0050ff;color:#0050ff}._expiryBtn_1xn16_100._active_1xn16_117{background:#0050ff;border-color:#0050ff;color:#fff}._dateInput_1xn16_123{padding:.65rem .75rem;border:1px solid #E2E8F0;border-radius:10px;font-size:.9rem;margin-top:.5rem;width:100%;font-family:inherit}._dateInput_1xn16_123:focus{outline:none;border-color:#0050ff;box-shadow:0 0 0 3px #0050ff1a}._checkboxLabel_1xn16_139{display:flex;align-items:center;gap:.5rem;cursor:pointer}._checkboxLabel_1xn16_139 input[type=checkbox]{width:18px;height:18px;accent-color:#0050FF}._passwordInput_1xn16_152{padding:.65rem .75rem;border:1px solid #E2E8F0;border-radius:10px;font-size:.9rem;width:100%;font-family:inherit;margin-top:.25rem}._passwordInput_1xn16_152:focus{outline:none;border-color:#0050ff;box-shadow:0 0 0 3px #0050ff1a}._error_1xn16_168{color:#dc2626;font-size:.85rem;padding:.5rem .75rem;background:#fef2f2;border-radius:8px}._generateBtn_1xn16_176{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.85rem 1.5rem;background:linear-gradient(135deg,#0050ff,#0040cc);border:none;border-radius:12px;color:#fff;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s;margin-top:.5rem}._generateBtn_1xn16_176:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #0050ff4d}._generateBtn_1xn16_176:disabled{opacity:.6;cursor:not-allowed}._spinner_1xn16_203{animation:_spin_1xn16_203 1s linear infinite}@keyframes _spin_1xn16_203{to{transform:rotate(360deg)}}._result_1xn16_214{text-align:center}._successIcon_1xn16_218{width:64px;height:64px;background:linear-gradient(135deg,#10b981,#059669);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;margin:0 auto 1rem}._successText_1xn16_230{font-size:1.1rem;font-weight:600;color:#0f172a;margin:0 0 1.25rem}._urlBox_1xn16_237{display:flex;gap:.5rem;margin-bottom:1rem}._urlInput_1xn16_243{flex:1;padding:.65rem .75rem;border:1px solid #E2E8F0;border-radius:10px;font-size:.85rem;background:#f8fafc;color:#475569;font-family:monospace;overflow:hidden;text-overflow:ellipsis}._copyBtn_1xn16_256{display:flex;align-items:center;gap:.4rem;padding:.65rem 1rem;background:#0050ff;border:none;border-radius:10px;color:#fff;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}._copyBtn_1xn16_256:hover{background:#0040cc}._passwordNote_1xn16_276{display:flex;align-items:center;justify-content:center;gap:.5rem;font-size:.8rem;color:#64748b;margin:0 0 1rem;padding:.5rem .75rem;background:#fef3c7;border-radius:8px}._doneBtn_1xn16_289{padding:.75rem 2rem;background:#f1f5f9;border:none;border-radius:10px;color:#475569;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s}._doneBtn_1xn16_289:hover{background:#e2e8f0}._dashboard_m8npp_7{--primary: #0050FF;--primary-light: rgba(0, 80, 255, .08);--accent: #F65D7C;--bg: #F5F7FA;--card-bg: #FFFFFF;--text: #0F172A;--text-muted: #64748B;--border: rgba(0, 0, 0, .06);--shadow: 0 2px 8px rgba(0, 0, 0, .04), 0 1px 2px rgba(0, 0, 0, .06);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .08);--radius: 16px;--radius-sm: 10px;width:100%;height:100%;background:var(--bg);display:flex;flex-direction:column;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;overflow:hidden}._header_m8npp_31{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 2rem;background:var(--card-bg);border-bottom:1px solid var(--border)}._headerLeft_m8npp_40{display:flex;flex-direction:column;gap:2px}._planName_m8npp_46{font-size:1.5rem;font-weight:700;color:var(--text);margin:0}._breadcrumb_m8npp_53{font-size:.8rem;color:var(--text-muted)}._tabs_m8npp_58{display:flex;background:var(--bg);padding:4px;border-radius:var(--radius-sm);gap:4px}._tab_m8npp_58{padding:.5rem 1.25rem;border:none;background:transparent;font-size:.85rem;font-weight:600;color:var(--text-muted);cursor:pointer;border-radius:8px;transition:all .2s}._tab_m8npp_58:hover{color:var(--text)}._tabActive_m8npp_82{background:var(--card-bg);color:var(--primary);box-shadow:0 1px 3px #00000014}._headerActions_m8npp_88{display:flex;gap:.75rem}._btnOutline_m8npp_93{display:flex;align-items:center;gap:.4rem;padding:.5rem 1rem;background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.85rem;font-weight:600;color:var(--text);cursor:pointer;transition:all .15s}._btnOutline_m8npp_93:hover{border-color:var(--primary);color:var(--primary)}._btnPrimary_m8npp_113{display:flex;align-items:center;gap:.4rem;padding:.5rem 1rem;background:var(--primary);border:none;border-radius:var(--radius-sm);font-size:.85rem;font-weight:600;color:#fff;cursor:pointer;transition:all .15s}._btnPrimary_m8npp_113:hover{background:#0040cc}._mainGrid_m8npp_133{display:grid;grid-template-columns:1fr 2fr;gap:1.5rem;padding:1.5rem 2rem;flex:1;min-height:0;overflow-y:auto}._leftCol_m8npp_144{display:flex;flex-direction:column;gap:1rem;min-height:0}._rightCol_m8npp_151{display:flex;flex-direction:column;gap:1rem;min-height:0;overflow:hidden}._card_m8npp_160{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.25rem}._cardHeader_m8npp_167{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;font-size:.95rem;font-weight:600;color:var(--text)}._cardHeader_m8npp_167 svg{margin-right:.4rem;opacity:.7}._viewCount_m8npp_182{font-size:.75rem;font-weight:500;color:var(--text-muted);background:var(--bg);padding:.2rem .6rem;border-radius:20px}._badge_m8npp_191{font-size:.65rem;font-weight:700;text-transform:uppercase;background:var(--primary-light);color:var(--primary);padding:.25rem .6rem;border-radius:20px}._mockupCard_m8npp_202{flex:2.5;display:flex;flex-direction:column;min-height:0;overflow:hidden}._mockupContainer_m8npp_211{flex:1;position:relative;display:flex;align-items:center;justify-content:center;background:var(--bg);border-radius:var(--radius-sm);overflow:hidden;min-height:200px}._mockupCanvasWrapper_m8npp_223{width:100%;height:100%;display:flex;align-items:center;justify-content:center}._mockupCanvasWrapper_m8npp_223 .planning-canvas{width:100%;height:100%}._mockupCanvasWrapper_m8npp_223 .planning-canvas canvas{max-width:100%;max-height:100%;object-fit:contain}._mockupImage_m8npp_243{max-width:100%;max-height:100%;object-fit:contain;border-radius:8px}._mockupEmpty_m8npp_250{color:var(--text-muted);font-size:.9rem}._mockupNav_m8npp_255{position:absolute;bottom:.75rem;right:.75rem;display:flex;align-items:center;gap:.5rem;background:var(--card-bg);padding:.3rem .6rem;border-radius:20px;box-shadow:var(--shadow-lg);font-size:.75rem;font-weight:600}._mockupNav_m8npp_255 button{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border:none;background:transparent;cursor:pointer;border-radius:50%;color:var(--text)}._mockupNav_m8npp_255 button:hover{background:var(--primary-light);color:var(--primary)}._mockupStats_m8npp_289{display:flex;align-items:center;gap:.5rem;font-size:.8rem;font-weight:500;color:var(--text-muted)}._mockupStat_m8npp_289{display:flex;align-items:center;gap:.25rem}._mockupStat_m8npp_289 strong{font-weight:700;color:var(--text)}._mockupStatDivider_m8npp_309{color:var(--border);font-size:.6rem}._mockupStatAccent_m8npp_314,._mockupStatAccent_m8npp_314 strong{color:var(--accent)}._statsRow_m8npp_322{display:flex;flex-direction:column;gap:.4rem;width:30%}._statCard_m8npp_329{background:var(--card-bg);border-radius:var(--radius-sm);box-shadow:var(--shadow);padding:.4rem .5rem;text-align:center;border:1px solid var(--border)}._statCardAccent_m8npp_338{background:linear-gradient(135deg,#1a1a2e,#16213e)}._statCardAccent_m8npp_338 ._statValue_m8npp_342,._statCardAccent_m8npp_338 ._statLabel_m8npp_343{color:#fff}._statValue_m8npp_342{display:block;font-size:1.1rem;font-weight:800;color:var(--text);line-height:1.1}._statLabel_m8npp_343{font-size:.55rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-weight:600}._infoSection_m8npp_364{display:flex;gap:.75rem;align-items:stretch;flex-shrink:0}._timingsCard_m8npp_373{flex:1;padding:.75rem 1rem!important}._timingsGrid_m8npp_378{display:flex;flex-direction:column;gap:.35rem}._timingItem_m8npp_384{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:.25rem;background:var(--bg);border-radius:6px;position:relative}._timingET_m8npp_396{flex:none;width:100%;padding:0;background:linear-gradient(135deg,var(--primary) 0%,#0040CC 100%);overflow:hidden;border-radius:6px}._timingETMain_m8npp_405{display:flex;align-items:center;gap:.4rem;padding:.3rem .6rem;width:100%}._timingETIcon_m8npp_413{display:flex;align-items:center;justify-content:center;width:20px;height:20px;background:#fff3;border-radius:4px;color:#fff}._timingETInfo_m8npp_424{flex:1;display:flex;flex-direction:column;gap:0}._timingETInfo_m8npp_424 ._timingLabel_m8npp_431{color:#fffc;font-size:.5rem}._timingETInfo_m8npp_424 ._timingDate_m8npp_436{color:#fff;font-size:.8rem;font-weight:700}._timingsRow_m8npp_443{display:grid;grid-template-columns:repeat(4,1fr);gap:.3rem}._timingsRow_m8npp_443 ._timingItem_m8npp_384{padding:.2rem .15rem}._timingBadge_m8npp_453{font-size:.42rem;font-weight:800;text-transform:uppercase;background:var(--primary-light);color:var(--primary);padding:.05rem .15rem;border-radius:3px;margin-top:.1rem}._timingDate_m8npp_436{display:block;font-size:.85rem;font-weight:700;color:var(--text)}._timingLabel_m8npp_431{font-size:.6rem;color:var(--text-muted);text-transform:uppercase;font-weight:600}._etBanner_m8npp_479{background:linear-gradient(135deg,var(--primary) 0%,#0040CC 100%);padding:1.25rem 1.5rem}._etBannerContent_m8npp_484{display:flex;align-items:center;gap:1rem}._etBannerIcon_m8npp_490{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:#fff3;border-radius:12px;color:#fff}._etBannerText_m8npp_501{flex:1;display:flex;flex-direction:column;gap:2px}._etBannerLabel_m8npp_508{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#fffc}._etBannerDate_m8npp_516{font-size:1.25rem;font-weight:800;color:#fff}._badgeFinal_m8npp_522{background:#00dc7d33!important;color:#00dc7d!important}._carrierHeaderTitle_m8npp_528{display:flex;align-items:baseline;gap:.75rem}._globalCommentNotice_m8npp_534{font-size:.75rem;font-weight:400;font-style:italic;color:var(--text-muted)}._carriersCard_m8npp_542{flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden}._carriersGrid_m8npp_550{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem;overflow-y:auto;flex:1;padding-right:.25rem}._carrierItem_m8npp_559{background:var(--card-bg);border-radius:var(--radius);padding:1rem;display:flex;flex-direction:column;gap:.75rem;border:1px solid var(--border);transition:box-shadow .2s,transform .2s}._carrierItem_m8npp_559:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}._carrierHeader_m8npp_528{display:flex;flex-direction:column;gap:.25rem}._carrierName_m8npp_581{font-size:1rem;font-weight:700;color:var(--text)}._carrierChannels_m8npp_587{font-size:.7rem;color:var(--text-muted);letter-spacing:.02em}._carrierComment_m8npp_593{display:flex;align-items:flex-start;gap:.4rem;padding:.5rem .75rem;background:var(--primary-light);border-radius:8px;font-size:.75rem;color:var(--text);line-height:1.4}._carrierComment_m8npp_593 svg{flex-shrink:0;color:var(--primary);margin-top:.1rem}._carrierThumbnails_m8npp_611{display:flex;gap:10px;flex-wrap:wrap;align-items:flex-start}._thumbnailWrapper_m8npp_618{display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer}._thumbnailWrapper_m8npp_618:hover ._thumbnail_m8npp_618{transform:scale(1.05);box-shadow:0 6px 16px #0000002e}._thumbnail_m8npp_618{position:relative;width:clamp(80px,10vw,100px);height:clamp(80px,10vw,100px);border-radius:12px;overflow:hidden;background:linear-gradient(135deg,#e2e8f0,#cbd5e1);transition:transform .2s,box-shadow .2s;border:2px solid transparent;box-shadow:0 2px 8px #0000001a}._thumbnail_m8npp_618 img{width:100%;height:100%;object-fit:cover}._slotName_m8npp_654{font-size:.7rem;font-weight:700;color:var(--text);text-align:center;max-width:clamp(80px,10vw,100px);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.2}._campaignName_m8npp_666{font-size:.6rem;font-weight:600;color:var(--primary-blue);text-align:center;max-width:clamp(80px,10vw,100px);font-style:italic;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.2;margin-top:-2px}._thumbnailPlaceholder_m8npp_681{display:flex;align-items:center;justify-content:center;width:100%;height:100%;font-size:.7rem;font-weight:700;color:var(--text-muted)}._thumbnailMore_m8npp_692{display:flex;align-items:center;justify-content:center;width:clamp(80px,10vw,100px);height:clamp(80px,10vw,100px);border-radius:12px;background:#0050ff1a;color:var(--primary);font-size:1rem;font-weight:700}._newBadge_m8npp_705{position:absolute;top:6px;right:6px;background:var(--accent);color:#fff;font-size:.6rem;font-weight:800;padding:2px 6px;border-radius:6px;text-transform:uppercase;box-shadow:0 2px 4px #00000026}._statusBadge_m8npp_720{position:absolute;top:6px;left:6px;font-size:.6rem;font-weight:800;padding:2px 6px;border-radius:6px;text-transform:uppercase;letter-spacing:.02em;box-shadow:0 2px 4px #00000026}._statusFinal_m8npp_733{background:#00dc7de6;color:#fff;box-shadow:0 1px 3px #00dc7d4d}._statusTbd_m8npp_739{background:#f59e0be6;color:#fff;box-shadow:0 1px 3px #f59e0b4d}._lightbox_m8npp_746{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:9999;padding:2rem}._lightboxClose_m8npp_757{position:absolute;top:1.5rem;right:1.5rem;width:48px;height:48px;border-radius:50%;background:#ffffff1a;border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}._lightboxClose_m8npp_757:hover{background:#fff3}._lightboxImage_m8npp_778{max-width:90%;max-height:90%;object-fit:contain;border-radius:12px;box-shadow:0 20px 60px #00000080}._container_ddjhg_3{height:100vh;background:linear-gradient(180deg,#f8fafc,#eef2ff);display:flex;flex-direction:column;overflow:hidden}._header_ddjhg_11{display:flex;align-items:center;justify-content:space-between;padding:1rem 2rem;background:#fff;border-bottom:1px solid #E2E8F0}._logo_ddjhg_20{display:flex;align-items:center;gap:.75rem}._logoText_ddjhg_26{font-size:1.5rem;font-weight:800;color:#0050ff;letter-spacing:-.02em}._shareBadge_ddjhg_33{padding:.4rem .75rem;background:#eef2ff;border:1px solid #C7D2FE;border-radius:20px;font-size:.8rem;font-weight:600;color:#4f46e5}._center_ddjhg_43{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem}._spinner_ddjhg_52{animation:_spin_ddjhg_52 1s linear infinite;color:#0050ff}@keyframes _spin_ddjhg_52{to{transform:rotate(360deg)}}._passwordCard_ddjhg_64{background:#fff;border-radius:20px;padding:2.5rem;width:100%;max-width:400px;text-align:center;box-shadow:0 20px 60px #0000001a}._iconWrapper_ddjhg_74{width:64px;height:64px;background:linear-gradient(135deg,#0050ff,#0040cc);border-radius:18px;display:flex;align-items:center;justify-content:center;color:#fff;margin:0 auto 1.25rem}._passwordCard_ddjhg_64 h2{margin:0 0 .5rem;font-size:1.5rem;font-weight:700;color:#0f172a}._passwordCard_ddjhg_64 p{margin:0 0 1.5rem;color:#64748b}._passwordCard_ddjhg_64 form{display:flex;flex-direction:column;gap:1rem}._passwordInput_ddjhg_104{padding:.85rem 1rem;border:1px solid #E2E8F0;border-radius:12px;font-size:1rem;width:100%;text-align:center;font-family:inherit}._passwordInput_ddjhg_104:focus{outline:none;border-color:#0050ff;box-shadow:0 0 0 3px #0050ff1a}._errorMessage_ddjhg_120{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.65rem 1rem;background:#fef2f2;border-radius:10px;color:#dc2626;font-size:.9rem;font-weight:500}._submitBtn_ddjhg_133{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.85rem 1.5rem;background:linear-gradient(135deg,#0050ff,#0040cc);border:none;border-radius:12px;color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}._submitBtn_ddjhg_133:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #0050ff4d}._submitBtn_ddjhg_133:disabled{opacity:.6;cursor:not-allowed}._errorCard_ddjhg_160{background:#fff;border-radius:20px;padding:2.5rem;width:100%;max-width:440px;text-align:center;box-shadow:0 20px 60px #0000001a}._errorIconWrapper_ddjhg_170{width:64px;height:64px;background:linear-gradient(135deg,#ef4444,#dc2626);border-radius:18px;display:flex;align-items:center;justify-content:center;color:#fff;margin:0 auto 1.25rem}._errorCard_ddjhg_160 h2{margin:0 0 .5rem;font-size:1.5rem;font-weight:700;color:#0f172a}._errorCard_ddjhg_160 p{margin:0 0 1.5rem;color:#64748b}._backBtn_ddjhg_194{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:#f1f5f9;border:none;border-radius:10px;color:#475569;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s}._backBtn_ddjhg_194:hover{background:#e2e8f0}._dashboardWrapper_ddjhg_214{flex:1;padding:1.5rem;overflow:auto}._dashboardWrapper_ddjhg_214 .pos-planning-dashboard__export-btn,._dashboardWrapper_ddjhg_214 .planning-dashboard__edit-btn{display:none!important}.pos-planning-home{display:flex;flex-direction:column;height:100%;background:var(--background-color)}.pos-planning-home__header{display:flex;align-items:center;justify-content:space-between;padding:1rem 2rem;border-bottom:1px solid #e0e0e0;background:var(--card-background);box-shadow:var(--box-shadow);gap:2rem;min-height:60px}.pos-planning-home__header h1{margin:0;font-size:1.5rem;font-weight:700;color:var(--primary-blue);flex:1;text-align:center}.pos-planning-home__back{display:flex;align-items:center;gap:.5rem;background:transparent;border:none;color:#64748b;cursor:pointer;font-size:.9rem;font-weight:500;transition:color .2s ease;flex-shrink:0;white-space:nowrap}.pos-planning-home__back:hover{color:var(--primary-blue)}.pos-planning-home__new-btn{display:flex;align-items:center;gap:.5rem;padding:.6rem 1.2rem;background:var(--primary-blue);color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:500;transition:all .2s ease,var(--bouncy-transition);flex-shrink:0;white-space:nowrap}.pos-planning-home__new-btn:hover{background:var(--dark-blue);transform:translateY(-2px)}.pos-planning-home__content{flex:1;overflow-y:auto;padding:2rem}.pos-planning-home__loading,.pos-planning-home__empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:#64748b;gap:1rem}.pos-planning-home__empty button{display:flex;align-items:center;gap:.5rem;padding:.6rem 1.2rem;background:var(--primary-blue);color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:500}.pos-planning-home__list{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.pos-planning-home__item{display:flex;align-items:center;gap:1.25rem;padding:1.25rem;background:var(--card-background);border:1px solid #e0e0e0;border-radius:12px;cursor:pointer;transition:all .2s ease,var(--bouncy-transition);box-shadow:var(--box-shadow)}.pos-planning-home__item:hover{border-color:var(--primary-blue);transform:translateY(-4px);box-shadow:var(--box-shadow-hover)}.pos-planning-home__item-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:var(--neutral-grey-light);border-radius:10px;color:var(--primary-blue)}.pos-planning-home__item-info{display:flex;flex-direction:column;gap:.25rem}.pos-planning-home__item-name{font-weight:600;font-size:1.1rem;color:var(--neutral-black)}.pos-planning-home__item-meta{font-size:.85rem;color:#64748b}.pos-planning-create-modal{max-width:600px}.pos-planning-create-modal__label{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.5rem;font-size:.9rem;font-weight:500;color:var(--neutral-black)}.pos-planning-create-modal__label input{padding:.75rem;border:1px solid #ccc;border-radius:8px;font-size:1rem;transition:border-color .2s}.pos-planning-create-modal__label input:focus{outline:none;border-color:var(--primary-blue);box-shadow:0 0 0 3px #0050ff1a}.pos-planning-create-modal__templates{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:1rem;max-height:350px;overflow-y:auto;margin-bottom:1.5rem;padding:.25rem}.pos-planning-create-modal__template-card{display:flex;flex-direction:column;align-items:center;padding:.5rem;border:1px solid #eaecf0;border-radius:12px;cursor:pointer;transition:all .2s cubic-bezier(.2,.8,.2,1);background:var(--card-background)}.pos-planning-create-modal__template-card:hover{border-color:var(--primary-blue);transform:translateY(-2px);box-shadow:0 4px 6px -1px #1018281a}.pos-planning-create-modal__template-card.selected{border-color:var(--primary-blue);background-color:#eff8ff;box-shadow:0 0 0 4px #eff8ff,0 1px 2px #1018280d}.pos-planning-create-modal__template-card img{width:100%;aspect-ratio:16/9;object-fit:cover;border-radius:8px;margin-bottom:.5rem}.pos-planning-create-modal__template-card span{font-size:.8rem;font-weight:500;text-align:center;color:#475467}.pos-planning-create-modal__template-card.selected span{color:var(--primary-blue)}.view-type-badge{font-size:.65rem;padding:.15rem .4rem;background:var(--neutral-grey-light);border-radius:4px;margin-top:.25rem;color:#64748b;font-weight:600}.pos-planning-editor{display:flex;height:100%;background:var(--background-color)}.pos-planning-editor__export-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#fffffff2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:9999}.pos-planning-editor__export-modal{background:#fff;padding:2.5rem 3rem;border-radius:16px;box-shadow:0 20px 60px #00000026;text-align:center;max-width:400px}.pos-planning-editor__export-modal h3{margin:0 0 .5rem;font-size:1.25rem;font-weight:700;color:var(--neutral-black)}.pos-planning-editor__export-modal p{margin:0 0 1.5rem;font-size:.9rem;color:var(--primary-blue);font-weight:500}.pos-planning-editor__export-spinner{width:48px;height:48px;margin:0 auto 1.5rem;border:4px solid #E2E8F0;border-top-color:var(--primary-blue);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.pos-planning-editor__export-progress-container{width:100%;height:8px;background:#e2e8f0;border-radius:4px;overflow:hidden;margin-bottom:.75rem}.pos-planning-editor__export-progress-fill{height:100%;background:var(--primary-blue);border-radius:4px;transition:width .3s ease}.pos-planning-editor__export-percent{font-size:.85rem;font-weight:600;color:#64748b}.pos-planning-editor__main{flex:1;display:flex;flex-direction:column;overflow:hidden;position:relative}.pos-planning-editor__header{display:flex;align-items:center;gap:1.5rem;padding:1rem 1.5rem;background:var(--card-background);border-bottom:1px solid #e0e0e0;box-shadow:var(--box-shadow);z-index:5}.pos-planning-editor__header h2{margin:0;font-size:1.25rem;font-weight:600;color:var(--neutral-black)}.pos-planning-editor__back{display:flex;align-items:center;gap:.4rem;background:transparent;border:none;color:#64748b;cursor:pointer;font-size:.9rem;font-weight:500;transition:color .2s}.pos-planning-editor__back:hover{color:var(--primary-blue)}.planning-sidebar{width:500px;height:100%;background:var(--card-background);border-right:1px solid #e0e0e0;display:flex;flex-direction:column;overflow-y:auto;position:relative;box-shadow:2px 0 10px #00000005}.planning-sidebar--collapsed{width:60px}.planning-sidebar__toggle{position:absolute;top:1rem;right:1rem;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--white);border:1px solid #e0e0e0;border-radius:8px;cursor:pointer;z-index:10;transition:all .2s}.planning-sidebar__toggle:hover{background:var(--neutral-grey-light);border-color:var(--primary-blue);color:var(--primary-blue)}.planning-sidebar__section{padding:1.5rem;border-bottom:1px solid #f0f0f0}.planning-sidebar__section:last-child{border-bottom:none}.planning-sidebar__section-title{font-size:.75rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:#94a3b8;margin:0 0 1rem}.planning-sidebar__timing-row{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem;font-size:.9rem}.planning-sidebar__timing-row label{width:90px;flex-shrink:0;font-weight:500;color:#475467}.planning-sidebar__timing-row input[type=date]{flex:1;padding:.5rem;border:1px solid #e0e0e0;border-radius:8px;font-size:.85rem;font-family:var(--font-family)}.planning-sidebar__timing-row input[type=date]:focus{outline:none;border-color:var(--primary-blue)}.planning-sidebar__timing-row--highlight{background:#0050ff0f;padding:.75rem;margin:-.25rem -.5rem .75rem;border-radius:10px;border:1px solid rgba(0,80,255,.15)}.planning-sidebar__timing-row--highlight label{font-size:1.1rem;font-weight:800;color:var(--primary-blue);width:50px}.planning-sidebar__timing-row--highlight input[type=date]{font-size:1rem;padding:.6rem;font-weight:600}.planning-sidebar__status-toggle{padding:.35rem .75rem;font-size:.7rem;font-weight:700;border:none;border-radius:6px;cursor:pointer;text-transform:uppercase;letter-spacing:.02em;transition:opacity .2s}.planning-sidebar__status-toggle:hover{opacity:.9}.planning-sidebar__status-toggle.final{background:#00dc7d;color:#fff}.planning-sidebar__status-toggle.tbd{background:#f59e0b;color:#fff}.planning-sidebar__comments-input{width:100%;padding:.75rem;border:1px solid #e0e0e0;border-radius:10px;font-size:.85rem;font-family:var(--font-family);resize:vertical;min-height:80px;background:#fafafa;transition:all .2s}.planning-sidebar__comments-input:focus{outline:none;border-color:var(--primary-blue);background:#fff;box-shadow:0 0 0 3px #0050ff1a}.planning-sidebar__comments-input::placeholder{color:#94a3b8;font-style:italic}.planning-sidebar__filter{display:flex;gap:.5rem;background:var(--neutral-grey-light);padding:.25rem;border-radius:10px;margin-bottom:1rem}.planning-sidebar__filter button{flex:1;padding:.5rem;border:none;background:transparent;border-radius:8px;cursor:pointer;font-size:.85rem;font-weight:600;color:#64748b;transition:all .2s}.planning-sidebar__filter button.active{background:var(--white);color:var(--primary-blue);box-shadow:0 2px 6px #0000000d}.planning-sidebar__section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.planning-sidebar__add-carrier{position:relative}.planning-sidebar__add-carrier>button{display:flex;align-items:center;gap:.3rem;padding:.4rem .8rem;font-size:.8rem;font-weight:600;background:var(--white);border:1px solid var(--primary-blue);color:var(--primary-blue);border-radius:8px;cursor:pointer;transition:all .2s}.planning-sidebar__add-carrier>button:hover{background:var(--primary-blue);color:#fff}.planning-sidebar__dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:200px;background:var(--white);border:1px solid #e0e0e0;border-radius:12px;box-shadow:0 10px 25px #0000001a;list-style:none;padding:.5rem 0;margin:0;z-index:100;overflow:hidden}.planning-sidebar__dropdown li{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;cursor:pointer;font-size:.9rem;font-weight:500;color:var(--neutral-black);transition:background-color .15s}.planning-sidebar__dropdown li:hover{background:var(--neutral-grey-light);color:var(--primary-blue)}.planning-sidebar__dropdown .badge{font-size:.7rem;padding:.15rem .4rem;background:#f1f5f9;border-radius:4px;color:#64748b}.planning-sidebar__empty-msg{font-size:.9rem;color:#94a3b8;text-align:center;padding:2rem 0;font-style:italic}.planning-sidebar__carrier-card{background:#f8fafc;border:1px solid #E2E8F0;border-radius:12px;padding:1rem 1rem 2rem;margin-bottom:1rem;transition:all .2s}.planning-sidebar__carrier-card:hover{border-color:var(--primary-blue);background:#fff;box-shadow:0 4px 12px #0000000d}.planning-sidebar__carrier-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.planning-sidebar__carrier-name{font-weight:700;font-size:.95rem;color:var(--neutral-black);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.planning-sidebar__carrier-action{background:transparent;border:1px solid transparent;color:#94a3b8;cursor:pointer;padding:.4rem;border-radius:6px;transition:all .2s;display:flex;align-items:center;justify-content:center;outline:none}.planning-sidebar__carrier-action:hover{background:#f1f5f9;color:var(--primary-blue)}.planning-sidebar__carrier-action.active{background:#0050ff14;color:var(--primary-blue);border-color:#0050ff33}.planning-sidebar__carrier-remove{background:transparent;border:none;color:#94a3b8;cursor:pointer;padding:.4rem;border-radius:6px;transition:all .2s;display:flex;align-items:center;justify-content:center}.planning-sidebar__carrier-remove:hover{background:#f65d7c1a;color:var(--accent-red)}.planning-sidebar__channels{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.planning-sidebar__channel-chip{display:flex;align-items:center;gap:.35rem;font-size:.75rem;padding:.35rem .65rem;background:#fff;border:1px solid #E2E8F0;border-radius:6px;cursor:pointer;font-weight:600;color:#64748b;transition:all .2s}.planning-sidebar__channel-chip:hover{border-color:var(--primary-blue)}.planning-sidebar__channel-chip.active{background:#eff6ff;border-color:var(--primary-blue);color:var(--primary-blue)}.planning-sidebar__slots-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:.75rem;row-gap:2rem}.planning-sidebar__slot-tile{position:relative;aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#fff;border:2px solid #E2E8F0;border-radius:10px;cursor:pointer;transition:all .2s cubic-bezier(.175,.885,.32,1.275)}.planning-sidebar__slot-tile:hover{transform:scale(1.05);border-color:var(--primary-blue);box-shadow:0 4px 12px #0050ff1a}.planning-sidebar__slot-tile.active{border-color:var(--primary-blue);box-shadow:0 0 0 4px #0050ff1a}.planning-sidebar__slot-tile img{width:100%;height:100%;object-fit:cover}.planning-sidebar__slot-tbd{display:flex;align-items:center;justify-content:center;width:100%;height:100%;background:linear-gradient(135deg,#94a3b8,#64748b);color:#fff;font-weight:800;font-size:.8rem;text-shadow:0 1px 2px rgba(0,0,0,.2)}.planning-sidebar__slot-name{position:absolute;bottom:0;left:0;right:0;background:#000000b3;color:#fff;font-size:.65rem;font-weight:600;padding:.25rem;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.planning-sidebar__slot-campaign{position:absolute;bottom:-22px;left:-4px;right:-4px;font-size:.55rem;font-weight:600;color:var(--primary-blue);text-align:center;white-space:normal;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;line-height:1.3;font-style:italic}.planning-sidebar__slot-status{position:absolute;top:.3rem;left:.3rem;font-size:.55rem;padding:.15rem .4rem;border-radius:4px;font-weight:800;text-transform:uppercase;box-shadow:0 1px 2px #0000001a}.planning-sidebar__slot-status.final{background:#00dc7d;color:#fff}.planning-sidebar__slot-status.tbd{background:#f59e0b;color:#fff}.planning-sidebar__slot-neu-badge{position:absolute;top:.3rem;right:.3rem;font-size:.55rem;padding:.15rem .4rem;background:var(--accent-red);color:#fff;border-radius:4px;font-weight:800;text-transform:uppercase;box-shadow:0 1px 2px #00000026;letter-spacing:.02em}.planning-sidebar__slot-menu-btn{position:absolute;bottom:1.5rem;right:.3rem;width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:#fff;color:var(--neutral-black);border:1px solid #E2E8F0;border-radius:6px;cursor:pointer;opacity:0;transition:all .2s;box-shadow:0 2px 4px #0000001a}.planning-sidebar__slot-tile:hover .planning-sidebar__slot-menu-btn{opacity:1}.planning-sidebar__slot-menu{position:absolute;bottom:calc(100% + 4px);right:0;min-width:150px;background:var(--white);border:1px solid #e0e0e0;border-radius:10px;box-shadow:0 8px 24px #00000026;list-style:none;padding:.5rem 0;margin:0;z-index:100}.planning-sidebar__slot-menu li{display:flex;align-items:center;gap:.6rem;padding:.6rem 1rem;cursor:pointer;font-size:.8rem;font-weight:500;color:#475467}.planning-sidebar__slot-menu li:hover{background:#f8fafc;color:var(--primary-blue)}.planning-sidebar__slot-menu li.danger{color:var(--accent-red)}.planning-sidebar__slot-menu li.danger:hover{background:#f65d7c0d;color:var(--accent-red)}.planning-sidebar__slot-add{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#fff;border:2px dashed #E2E8F0;border-radius:10px;cursor:pointer;color:#94a3b8;transition:all .2s}.planning-sidebar__slot-add:hover{border-color:var(--primary-blue);color:var(--primary-blue);background:#eff6ff}.planning-sidebar__add-slot-inline{display:flex;gap:.5rem;margin-top:1rem}.planning-sidebar__add-slot-inline input{flex:1;padding:.5rem;border:1px solid #E2E8F0;border-radius:8px;font-size:.85rem;font-family:inherit}.planning-sidebar__add-slot-inline button{padding:.5rem .8rem;font-size:.8rem;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .2s}.planning-sidebar__add-slot-inline button:first-of-type{background:var(--primary-blue);color:#fff}.planning-sidebar__add-slot-inline button:last-of-type{background:#f1f5f9;color:#64748b}.planning-sidebar__modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.planning-sidebar__modal{background:#fff;border-radius:16px;padding:1.75rem;width:100%;max-width:400px;box-shadow:0 20px 40px #00000026;animation:slideUp .25s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.planning-sidebar__modal-title{font-size:1.25rem;font-weight:700;color:var(--neutral-black);margin:0 0 1.5rem}.planning-sidebar__modal-field{margin-bottom:1.25rem}.planning-sidebar__modal-field label{display:block;font-size:.8rem;font-weight:600;color:#64748b;margin-bottom:.5rem}.planning-sidebar__modal-field input{width:100%;padding:.75rem 1rem;border:1px solid #E2E8F0;border-radius:10px;font-size:.95rem;font-family:inherit;transition:all .2s;background:#fafafa}.planning-sidebar__modal-field input:focus{outline:none;border-color:var(--primary-blue);background:#fff;box-shadow:0 0 0 3px #0050ff1a}.planning-sidebar__modal-field input::placeholder{color:#94a3b8}.planning-sidebar__modal-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.5rem}.planning-sidebar__modal-cancel{padding:.65rem 1.25rem;font-size:.9rem;font-weight:600;background:transparent;border:1px solid #E2E8F0;border-radius:10px;color:#64748b;cursor:pointer;transition:all .2s}.planning-sidebar__modal-cancel:hover{background:#f8fafc;border-color:#cbd5e1}.planning-sidebar__modal-save{padding:.65rem 1.5rem;font-size:.9rem;font-weight:600;background:var(--primary-blue);border:none;border-radius:10px;color:#fff;cursor:pointer;transition:all .2s}.planning-sidebar__modal-save:hover{background:var(--dark-blue);transform:translateY(-1px);box-shadow:0 4px 12px #0050ff40}.planning-sidebar__modal-save:disabled{background:#cbd5e1;cursor:not-allowed;transform:none;box-shadow:none}.planning-sidebar__actions{padding:1.5rem;margin-top:auto;border-top:1px solid #e0e0e0;display:flex;flex-direction:column;gap:.75rem;background:var(--card-background)}.planning-sidebar__actions-row{display:flex;gap:.5rem}.planning-sidebar__actions-row .planning-sidebar__save-btn{flex:1}.planning-sidebar__refresh-btn{display:flex;align-items:center;justify-content:center;padding:.8rem;border:1px solid #E2E8F0;border-radius:10px;background:var(--white);color:#475467;cursor:pointer;transition:all .2s}.planning-sidebar__refresh-btn:hover{border-color:var(--primary-blue);color:var(--primary-blue);transform:translateY(-2px)}.planning-sidebar__save-btn,.planning-sidebar__export-btn{display:flex;align-items:center;justify-content:center;gap:.6rem;padding:.8rem;border:none;border-radius:10px;cursor:pointer;font-weight:600;font-size:.95rem;transition:all .2s,var(--bouncy-transition)}.planning-sidebar__save-btn{background:var(--white);border:1px solid #E2E8F0;color:#475467}.planning-sidebar__save-btn:hover{border-color:var(--primary-blue);color:var(--primary-blue);transform:translateY(-2px)}.planning-sidebar__export-btn{background:var(--primary-blue);color:#fff}.planning-sidebar__export-btn:hover{background:var(--dark-blue);transform:translateY(-2px);box-shadow:0 4px 15px #0050ff33}.planning-sidebar__export-btn:disabled{cursor:default;transform:none}.planning-sidebar__export-progress{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center;overflow:hidden;border-radius:inherit}.planning-sidebar__export-progress-bar{position:absolute;left:0;top:0;bottom:0;background:#fff3;transition:width .3s ease;border-radius:inherit}.planning-sidebar__export-progress span{position:relative;z-index:1;font-size:.8rem;font-weight:500}.planning-canvas{flex:1;position:relative;background:var(--neutral-grey-light);display:flex;align-items:center;justify-content:center;overflow:hidden}.planning-canvas canvas{max-width:95%;max-height:95%;box-shadow:0 10px 40px #0000001a;border-radius:4px}.planning-canvas--empty{display:flex;flex-direction:column;align-items:center;gap:1rem;color:#94a3b8}.planning-canvas__loading{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#fffc;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:20;gap:1rem;color:var(--primary-blue);font-weight:500}.planning-canvas__nav{position:absolute;top:50%;transform:translateY(-50%);width:60px;height:60px;display:flex;align-items:center;justify-content:center;background:#fff6;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.5);border-radius:50%;color:var(--neutral-black);cursor:pointer;z-index:10;transition:all .4s cubic-bezier(.2,.8,.2,1);opacity:.7;box-shadow:0 4px 15px #0000000d}.planning-canvas__nav:hover{background:#fff;opacity:1;transform:translateY(-50%) scale(1.1);box-shadow:0 10px 30px #00000026;color:var(--primary-blue);border-color:var(--primary-blue)}.planning-canvas__nav--prev{left:2rem}.planning-canvas__nav--next{right:2rem}.planning-canvas__nav svg{display:block}.planning-bottom-bar{padding:1rem 1.5rem;background:var(--card-background);border-top:1px solid #e0e0e0;box-shadow:0 -4px 15px #00000008;z-index:5}.planning-bottom-bar__views{display:flex;gap:1rem;overflow-x:auto;padding:.5rem 0;scrollbar-width:thin}.planning-bottom-bar__thumb{flex-shrink:0;width:140px;aspect-ratio:16 / 9;border-radius:8px;border:3px solid transparent;cursor:pointer;background:#f1f5f9;transition:all .2s,var(--bouncy-transition);position:relative;box-shadow:0 2px 6px #0000000d}.planning-bottom-bar__thumb:hover{transform:translateY(-4px);box-shadow:0 8px 16px #0000001a}.planning-bottom-bar__thumb.active{border-color:var(--primary-blue);transform:translateY(-4px)}.planning-bottom-bar__thumb-img{width:100%;height:100%;object-fit:cover;border-radius:5px}.planning-bottom-bar__thumb-name{position:absolute;bottom:0;left:0;right:0;background:#0009;color:#fff;font-size:.65rem;font-weight:600;padding:.25rem .5rem;text-align:center}.planning-bottom-bar__add{flex-shrink:0;width:48px;height:48px;border-radius:50%;border:1px solid #E2E8F0;background:var(--white);color:var(--primary-blue);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s,var(--bouncy-transition);align-self:center;box-shadow:0 4px 10px #0000000d}.planning-bottom-bar__add:hover{background:var(--primary-blue);color:var(--white);transform:scale(1.1);box-shadow:0 6px 15px #0050ff33}.ad-format-selector-modal{max-width:700px;width:90vw;max-height:80vh;display:flex;flex-direction:column}.ad-format-selector-modal h2{margin:0 0 1.5rem;font-size:1.5rem;font-weight:700;color:var(--neutral-black)}.ad-format-selector-modal__search{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:#f8fafc;border:1px solid #E2E8F0;border-radius:10px;margin-bottom:1rem}.ad-format-selector-modal__search svg{color:#94a3b8;flex-shrink:0}.ad-format-selector-modal__search input{flex:1;border:none;background:transparent;font-size:1rem;color:var(--neutral-black);outline:none}.ad-format-selector-modal__search input::placeholder{color:#94a3b8}.ad-format-selector-modal__tabs{display:flex;gap:.5rem;background:var(--neutral-grey-light);padding:.25rem;border-radius:10px;margin-bottom:1.25rem}.ad-format-selector-modal__tabs button{flex:1;padding:.6rem 1rem;border:none;background:transparent;border-radius:8px;cursor:pointer;font-size:.9rem;font-weight:600;color:#64748b;transition:all .2s ease}.ad-format-selector-modal__tabs button:hover{color:var(--primary-blue)}.ad-format-selector-modal__tabs button.active{background:var(--white);color:var(--primary-blue);box-shadow:0 2px 6px #0000000f}.ad-format-selector-modal__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:1rem;overflow-y:auto;max-height:400px;padding:.25rem}.ad-format-selector-modal__empty{grid-column:1 / -1;text-align:center;padding:3rem 1rem;color:#94a3b8;font-size:.95rem}.ad-format-selector-modal__card{display:flex;flex-direction:column;align-items:center;padding:.75rem;background:var(--card-background);border:1px solid #E2E8F0;border-radius:12px;cursor:pointer;transition:all .2s cubic-bezier(.2,.8,.2,1)}.ad-format-selector-modal__card:hover{border-color:var(--primary-blue);transform:translateY(-4px);box-shadow:0 8px 16px #0050ff1a}.ad-format-selector-modal__card img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:8px;margin-bottom:.5rem;background:#f1f5f9}.ad-format-selector-modal__card-placeholder{width:100%;aspect-ratio:1;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#e0e7ff,#c7d2fe);border-radius:8px;margin-bottom:.5rem;font-size:2rem;font-weight:700;color:var(--primary-blue)}.ad-format-selector-modal__card-name{font-size:.85rem;font-weight:600;color:var(--neutral-black);text-align:center;margin-bottom:.25rem;line-height:1.3}.ad-format-selector-modal__card-type{font-size:.7rem;font-weight:700;padding:.2rem .5rem;border-radius:4px;text-transform:uppercase;letter-spacing:.03em}.ad-format-selector-modal__card-type.indoor{background:#dbeafe;color:#2563eb}.ad-format-selector-modal__card-type.outdoor{background:#d1fae5;color:#059669}.ad-format-selector-modal__add-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.8rem 1rem;background:var(--white);border:1px dashed var(--primary-blue);border-radius:10px;color:var(--primary-blue);font-weight:600;font-size:.9rem;cursor:pointer;margin-top:1rem;transition:all .2s ease}.ad-format-selector-modal__add-btn:hover{background:#0050ff0d;border-style:solid;transform:translateY(-2px)}.pos-plan-delete-btn{position:absolute;top:.5rem;right:.5rem;width:32px;height:32px;display:flex;align-items:center;justify-content:center;gap:.25rem;background:#ffffffe6;border:1px solid #E2E8F0;border-radius:8px;cursor:pointer;color:#94a3b8;transition:all .2s;opacity:0;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.collection-card:hover .pos-plan-delete-btn{opacity:1}.pos-plan-delete-btn:hover{background:#f65d7c1a;border-color:var(--accent-red);color:var(--accent-red)}.pos-plan-delete-btn.confirm{width:auto;padding:.4rem .75rem;background:var(--accent-red);border-color:var(--accent-red);color:#fff;opacity:1}.pos-plan-delete-btn.confirm:hover{filter:brightness(.9)}.pos-plan-delete-btn span{font-size:.75rem;font-weight:600}.planning-bottom-bar__thumb-remove{position:absolute;top:-8px;right:-8px;width:22px;height:22px;display:flex;padding:0;margin:0;align-items:center;justify-content:center;background:var(--accent-red);border:2px solid white;border-radius:50%;cursor:pointer;color:#fff;opacity:0;z-index:10;transition:all .2s;box-shadow:0 2px 8px #0003}.planning-bottom-bar__thumb:hover .planning-bottom-bar__thumb-remove{opacity:1}.planning-bottom-bar__thumb-remove:hover{filter:brightness(.9);transform:scale(1.15)}.planning-sidebar__slot-tile{max-width:100%}.planning-sidebar__slot-name{max-width:100%;text-overflow:ellipsis}.pos-planning-toast{position:fixed;top:2rem;left:50%;transform:translate(-50%) translateY(-20px);background:#00dc7de6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;padding:.75rem 1.5rem;border-radius:12px;font-weight:600;font-size:.95rem;box-shadow:0 10px 25px #00dc7d33;z-index:1000;pointer-events:none;opacity:0;transition:all .3s cubic-bezier(.175,.885,.32,1.275);display:flex;align-items:center;gap:.75rem}.pos-planning-toast.show{opacity:1;transform:translate(-50%) translateY(0)}.pos-planning-toast svg{flex-shrink:0}.pos-planning-dashboard{display:flex;flex-direction:column;height:100%;background:linear-gradient(135deg,#f8fafc,#e2e8f0);overflow:hidden}.pos-planning-dashboard__header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 2rem;background:var(--card-background);border-bottom:1px solid #e0e0e0;box-shadow:var(--box-shadow);z-index:10}.pos-planning-dashboard__title{display:flex;align-items:baseline;gap:1rem}.pos-planning-dashboard__title h1{margin:0;font-size:1.5rem;font-weight:700;color:var(--primary-blue)}.pos-planning-dashboard__subtitle{font-size:.9rem;color:#64748b;font-weight:500}.pos-planning-dashboard__actions{display:flex;gap:.75rem}.pos-planning-dashboard__btn{display:flex;align-items:center;gap:.5rem;padding:.65rem 1.25rem;border-radius:10px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease,var(--bouncy-transition);border:none}.pos-planning-dashboard__btn--primary{background:var(--primary-blue);color:#fff}.pos-planning-dashboard__btn--primary:hover{background:var(--dark-blue);transform:translateY(-2px)}.pos-planning-dashboard__btn--secondary{background:#fff;color:var(--primary-blue);border:1px solid var(--primary-blue)}.pos-planning-dashboard__btn--secondary:hover{background:#eff6ff;transform:translateY(-2px)}.pos-planning-dashboard__btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.pos-planning-dashboard__content{flex:1;overflow-y:auto;padding:2rem}.pos-planning-dashboard__empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:#64748b;gap:1rem}.pos-planning-dashboard__empty button{padding:.6rem 1.2rem;background:var(--primary-blue);color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:500}.dashboard-section{background:#ffffffb3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;padding:2rem;margin-bottom:2rem;box-shadow:0 8px 32px #0000000f;border:1px solid rgba(255,255,255,.8)}.dashboard-section__title{font-size:1.75rem;font-weight:700;color:var(--primary-blue);margin:0 0 1.5rem;letter-spacing:-.02em}.dashboard-section__content{display:grid;grid-template-columns:220px 1fr;gap:2rem;margin-bottom:2rem}.dashboard-timings-card{background:var(--dark-blue);color:#fff;border-radius:16px;padding:1.5rem;box-shadow:0 8px 24px #00205c40}.dashboard-timings-card__row{display:flex;justify-content:space-between;align-items:center;padding:.6rem 0;border-bottom:1px solid rgba(255,255,255,.1);font-size:.85rem}.dashboard-timings-card__row:last-child{border-bottom:none}.dashboard-timings-card__row--highlight{background:#ffffff1a;padding:.75rem;margin:-.5rem -.75rem .5rem;border-radius:10px;border-bottom:none}.dashboard-timings-card__row--highlight .dashboard-timings-card__label{font-size:1.25rem;font-weight:800}.dashboard-timings-card__row--highlight .dashboard-timings-card__value{font-size:1.1rem;font-weight:700}.dashboard-timings-card__label{font-weight:600;opacity:.9}.dashboard-timings-card__value{font-weight:500;display:flex;align-items:center;gap:.5rem}.dashboard-timings-card__status{font-size:.65rem;padding:.15rem .4rem;border-radius:4px;font-weight:700;text-transform:uppercase}.dashboard-timings-card__status--tbd{background:#f59e0b}.dashboard-timings-card__status--final{background:#00dc7d}.dashboard-section__hero{position:relative;display:flex;flex-direction:column;align-items:center}.dashboard-hero-viewer{width:100%;max-height:450px;border-radius:16px;overflow:hidden;background:#e2e8f0;box-shadow:0 12px 40px #0000001a}.dashboard-hero-viewer__image{width:100%;height:100%;object-fit:contain}.dashboard-hero-viewer--empty{display:flex;align-items:center;justify-content:center;min-height:300px;color:#64748b;font-size:.95rem}.dashboard-hero-viewer__nav{display:flex;align-items:center;gap:1rem;margin-top:1rem}.dashboard-hero-viewer__btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#fff;border:1px solid #e0e0e0;border-radius:50%;cursor:pointer;transition:all .2s ease;color:var(--neutral-black)}.dashboard-hero-viewer__btn:hover{background:var(--primary-blue);color:#fff;border-color:var(--primary-blue);transform:scale(1.1)}.dashboard-hero-viewer__index{font-size:.9rem;font-weight:600;color:#64748b;min-width:50px;text-align:center}.dashboard-section__cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1.25rem}.dashboard-ad-card{background:#fff;border-radius:14px;padding:1rem;box-shadow:0 4px 12px #0000000d;border:1px solid #e2e8f0;transition:all .25s cubic-bezier(.175,.885,.32,1.275);display:flex;flex-direction:column;gap:.5rem}.dashboard-ad-card:hover{transform:scale(1.02);box-shadow:0 8px 24px #0000001a;border-color:var(--primary-blue)}.dashboard-ad-card__header{display:flex;justify-content:space-between;align-items:center}.dashboard-ad-card__name{font-weight:700;font-size:.9rem;color:var(--neutral-black);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dashboard-ad-card__neu-badge{font-size:.6rem;padding:.2rem .5rem;background:var(--accent-red);color:#fff;border-radius:4px;font-weight:800;text-transform:uppercase;letter-spacing:.02em;flex-shrink:0}.dashboard-ad-card__tags{font-size:.7rem;color:#64748b;font-weight:500}.dashboard-ad-card__image{width:100%;aspect-ratio:4/3;border-radius:10px;overflow:hidden;background:#f1f5f9;margin:.25rem 0}.dashboard-ad-card__image img{width:100%;height:100%;object-fit:cover}.dashboard-ad-card__placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#94a3b8,#64748b);color:#fff;font-weight:700;font-size:.9rem}.dashboard-ad-card__slot-name{font-size:.75rem;font-weight:600;color:#475467;text-align:center}.dashboard-v2{display:flex;flex-direction:column;height:100%;background:#f8fafc;overflow:hidden}.dashboard-v2__header{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;background:#fff;border-bottom:1px solid #e2e8f0;box-shadow:0 1px 3px #0000000a}.dashboard-v2__title{display:flex;align-items:baseline;gap:.75rem}.dashboard-v2__title h1{margin:0;font-size:1.4rem;font-weight:700;color:var(--primary-blue)}.dashboard-v2__title span{font-size:.85rem;color:#94a3b8;font-weight:500}.dashboard-v2__actions{display:flex;gap:.5rem}.dashboard-v2__btn{display:flex;align-items:center;gap:.4rem;padding:.5rem 1rem;border-radius:10px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s ease;border:none}.dashboard-v2__btn--primary{background:var(--primary-blue);color:#fff}.dashboard-v2__btn--primary:hover{background:var(--dark-blue)}.dashboard-v2__btn--secondary{background:#fff;color:var(--primary-blue);border:1px solid #e2e8f0}.dashboard-v2__btn--secondary:hover{background:#f8fafc;border-color:var(--primary-blue)}.dashboard-v2__btn:disabled{opacity:.5;cursor:not-allowed}.dashboard-v2__tabs{display:flex;gap:.5rem;padding:.75rem 2rem;background:#fff;border-bottom:1px solid #e2e8f0}.dashboard-v2__tab{display:flex;align-items:center;gap:.5rem;padding:.6rem 1.25rem;border:none;background:#f1f5f9;border-radius:10px;font-size:.9rem;font-weight:600;color:#64748b;cursor:pointer;transition:all .2s ease}.dashboard-v2__tab:hover{background:#e2e8f0}.dashboard-v2__tab.active{background:var(--primary-blue);color:#fff}.dashboard-v2__tab-count{font-size:.7rem;padding:.15rem .5rem;background:#fff3;border-radius:6px}.dashboard-v2__tab.active .dashboard-v2__tab-count{background:#ffffff4d}.dashboard-v2__content{flex:1;display:flex;justify-content:center;align-items:flex-start;padding:1.5rem;overflow-y:auto}.dashboard-v2__slide{width:100%;max-width:1280px;aspect-ratio:16 / 9;background:#fffc;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:24px;border:1px solid rgba(255,255,255,.9);box-shadow:0 8px 32px #0000000f;padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem;overflow:hidden}.dashboard-v2__row-top{display:grid;grid-template-columns:200px 1fr;gap:1.25rem;flex:1;min-height:0}.dashboard-v2__timings{background:var(--dark-blue);color:#fff;border-radius:16px;padding:1.25rem;display:flex;flex-direction:column;gap:.5rem}.dashboard-v2__timings-header{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;opacity:.7;margin-bottom:.5rem}.dashboard-v2__timing-row{display:flex;justify-content:space-between;align-items:center;font-size:.8rem;padding:.4rem 0;border-bottom:1px solid rgba(255,255,255,.1)}.dashboard-v2__timing-row:last-child{border-bottom:none}.dashboard-v2__timing-row--highlight{background:#ffffff1a;padding:.6rem;margin:0 -.5rem .25rem;border-radius:8px;border-bottom:none}.dashboard-v2__timing-row--highlight .dashboard-v2__timing-label{font-size:1rem;font-weight:800}.dashboard-v2__timing-row--highlight .dashboard-v2__timing-value{font-size:.95rem;font-weight:700}.dashboard-v2__timing-label{font-weight:600;opacity:.9}.dashboard-v2__timing-value{display:flex;align-items:center;gap:.4rem;font-weight:500}.dashboard-v2__timing-status{font-size:.55rem;padding:.1rem .35rem;border-radius:4px;font-weight:700;text-transform:uppercase}.dashboard-v2__timing-status--tbd{background:#f59e0b}.dashboard-v2__timing-status--final{background:#00dc7d}.dashboard-v2__hero{position:relative;flex:1;min-height:0;background:#f1f5f9;border-radius:16px;overflow:hidden;display:flex;align-items:center;justify-content:center}.dashboard-v2__hero-img{max-width:100%;max-height:100%;object-fit:contain;border-radius:12px}.dashboard-v2__hero-empty{color:#94a3b8;font-size:.9rem}.dashboard-v2__hero-nav{position:absolute;bottom:.75rem;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:.5rem;background:#ffffffe6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:.35rem .5rem;border-radius:20px;box-shadow:0 2px 8px #0000001a}.dashboard-v2__hero-nav button{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#fff;border:1px solid #e2e8f0;border-radius:50%;cursor:pointer;transition:all .15s ease;color:#475467}.dashboard-v2__hero-nav button:hover{background:var(--primary-blue);color:#fff;border-color:var(--primary-blue)}.dashboard-v2__hero-nav span{font-size:.75rem;font-weight:600;color:#64748b;min-width:40px;text-align:center}.dashboard-v2__gallery{flex-shrink:0}.dashboard-v2__gallery-title{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#94a3b8;margin:0 0 .75rem}.dashboard-v2__gallery-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.75rem}.dashboard-v2__card{background:#fff;border-radius:14px;padding:.75rem;box-shadow:0 2px 8px #0000000a;border:1px solid #e2e8f0}.dashboard-v2__card-header{margin-bottom:.5rem}.dashboard-v2__card-name{font-weight:700;font-size:.85rem;color:var(--neutral-black);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dashboard-v2__card-gallery{display:flex;gap:.4rem;overflow-x:auto;padding-bottom:.25rem}.dashboard-v2__card-gallery::-webkit-scrollbar{height:4px}.dashboard-v2__card-gallery::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:2px}.dashboard-v2__card-slot{position:relative;flex-shrink:0;width:60px;display:flex;flex-direction:column;align-items:center}.dashboard-v2__card-slot img{width:60px;height:45px;object-fit:cover;border-radius:6px;background:#f1f5f9}.dashboard-v2__card-slot-placeholder{width:60px;height:45px;display:flex;align-items:center;justify-content:center;background:#94a3b8;color:#fff;font-size:.6rem;font-weight:700;border-radius:6px}.dashboard-v2__card-slot-name{font-size:.55rem;color:#64748b;margin-top:.2rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:60px;text-align:center}.pos-planning-loading-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#fff;z-index:9999;display:flex;align-items:center;justify-content:center;flex-direction:column}.pos-planning-loading-content{display:flex;flex-direction:column;align-items:center;gap:1rem}.pos-planning-loading-content h3{font-size:1.25rem;font-weight:600;color:var(--neutral-black);margin:0}.pos-planning-loading-content p{color:#64748b;margin:0}.pos-planning-loading-content .spinner{width:48px;height:48px;border:4px solid rgba(0,80,255,.1);border-top-color:var(--primary-blue);border-radius:50%;animation:spin 1s linear infinite}.dashboard-v2__card-neu-badge{position:absolute;top:2px;right:2px;font-size:.45rem;padding:.1rem .25rem;background:var(--accent-red);color:#fff;border-radius:3px;font-weight:800;text-transform:uppercase}.dashboard-v2__card-empty{font-size:.75rem;color:#94a3b8;padding:.5rem}.dashboard-v2__card-footer{font-size:.65rem;color:#64748b;margin-top:.5rem;padding-top:.5rem;border-top:1px solid #f1f5f9}
