.toast-container{position:fixed;top:1rem;right:1rem;z-index:9999;display:flex;flex-direction:column;gap:var(--gap-3);pointer-events:none;max-width:420px}.toast{display:flex;align-items:center;gap:var(--gap-3);padding:var(--gap-4);background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-lg);border:1.5px solid var(--border);pointer-events:all;animation:toastSlideIn .3s ease-out;cursor:pointer;transition:transform .2s ease,opacity .2s ease}.toast:hover{transform:translateY(-2px);box-shadow:0 16px 40px #00000026}.toast-icon{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.875rem;flex-shrink:0}.toast-message{flex:1;font-size:.875rem;font-weight:500;color:var(--text);line-height:1.4}.toast-close{width:24px;height:24px;border:none;background:transparent;color:var(--muted);font-size:1.25rem;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .15s ease;flex-shrink:0;line-height:1}.toast-close:hover{background:var(--bg);color:var(--text)}.toast--success{border-color:#10b9814d;background:#10b9810d}.toast--success .toast-icon{background:var(--success-500);color:#fff}.toast--error{border-color:#ef44444d;background:#ef44440d}.toast--error .toast-icon{background:var(--danger-500);color:#fff}.toast--warning{border-color:#f59e0b4d;background:#f59e0b0d}.toast--warning .toast-icon{background:var(--warning-500);color:#fff}.toast--info{border-color:#2563eb4d;background:#2563eb0d}.toast--info .toast-icon{background:var(--primary-600);color:#fff}@keyframes toastSlideIn{0%{transform:translate(120%);opacity:0}to{transform:translate(0);opacity:1}}.login-page{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;padding:2rem}.login-container{display:grid;grid-template-columns:1fr 1fr;gap:3rem;max-width:1200px;width:100%}.login-card{background:#fff;border-radius:16px;padding:3rem;box-shadow:0 20px 60px #0000004d}.login-header{text-align:center;margin-bottom:2rem}.login-header h1{font-size:3rem;font-weight:800;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin:0 0 .5rem}.login-header p{color:#64748b;font-size:1rem;margin:0}.login-body{margin-bottom:2rem}.login-body h2{font-size:1.75rem;margin:0 0 .5rem;color:#0f172a}.login-subtitle{color:#64748b;margin:0 0 2rem}.login-error{background:#fee2e2;color:#dc2626;padding:1rem;border-radius:8px;margin-bottom:1rem;font-size:.875rem}.btn-google-signin{width:100%;display:flex;align-items:center;justify-content:center;gap:.75rem;background:#fff;border:2px solid #e2e8f0;padding:.875rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;color:#0f172a}.btn-google-signin:hover:not(:disabled){background:#f8fafc;border-color:#cbd5e1;transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.btn-google-signin:disabled{opacity:.6;cursor:not-allowed}.login-divider{display:flex;align-items:center;margin:1.5rem 0;color:#94a3b8;font-size:.875rem}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:#e2e8f0}.login-divider span{padding:0 1rem}.login-info{text-align:center;color:#64748b;font-size:.875rem;line-height:1.6}.login-info strong{color:#667eea}.login-footer{display:flex;justify-content:center;gap:1rem;padding-top:2rem;border-top:1px solid #e2e8f0;font-size:.875rem}.login-footer a{color:#667eea;text-decoration:none}.login-footer a:hover{text-decoration:underline}.login-footer span{color:#cbd5e1}.login-features{background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;padding:2rem;color:#fff}.login-features h3{font-size:1.5rem;margin:0 0 1.5rem}.login-features ul{list-style:none;padding:0;margin:0}.login-features li{padding:.75rem 0;font-size:1rem;line-height:1.6;opacity:.95}@media (max-width: 968px){.login-container{grid-template-columns:1fr}.login-features{order:-1}}@media (max-width: 640px){.login-page{padding:1rem}.login-card{padding:2rem 1.5rem}.login-header h1{font-size:2rem}}.pricing-page{max-width:1400px;margin:0 auto;padding:60px 20px;position:relative}.pricing-header{text-align:center;margin-bottom:60px;padding-top:20px;position:relative}.pricing-back-button{position:absolute;top:20px;left:20px;background:#fff;border:2px solid #e2e8f0;border-radius:8px;padding:10px 20px;font-size:.95rem;font-weight:500;color:#475569;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .2s ease}.pricing-back-button:hover{border-color:#667eea;color:#667eea;transform:translate(-4px)}.pricing-back-button .back-arrow{font-size:1.2rem;transition:transform .2s ease}.pricing-back-button:hover .back-arrow{transform:translate(-2px)}.pricing-header h1{font-size:3rem;font-weight:700;color:#1a1a2e;margin-bottom:16px}.pricing-header p{font-size:1.25rem;color:#64748b}.pricing-error{max-width:600px;margin:0 auto 30px;padding:16px 24px;background:#fee;border:1px solid #fcc;border-radius:8px;color:#c33;text-align:center}.pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:30px;margin-bottom:80px}.pricing-card{background:#fff;border:2px solid #e2e8f0;border-radius:16px;padding:40px 32px;position:relative;transition:all .3s ease}.pricing-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px #0000001a}.pricing-card.highlighted{border-color:#667eea;box-shadow:0 8px 16px #667eea26}.pricing-card.current{border-color:#10b981;background:#f0fdf4}.badge{position:absolute;top:-12px;left:50%;transform:translate(-50%);background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:6px 20px;border-radius:20px;font-size:.875rem;font-weight:600}.badge.current-badge{background:linear-gradient(135deg,#10b981,#059669)}.plan-header{text-align:center;margin-bottom:32px;padding-bottom:24px;border-bottom:1px solid #e2e8f0}.plan-icon{font-size:3rem;margin-bottom:12px;line-height:1}.plan-header h3{font-size:1.5rem;font-weight:700;color:#1a1a2e;margin-bottom:16px}.price{display:flex;align-items:baseline;justify-content:center;gap:4px}.price .amount{font-size:3.5rem;font-weight:800;color:#667eea}.pricing-card.current .price .amount{color:#10b981}.price .period{font-size:1.125rem;color:#64748b}.projects-count{margin-top:12px;font-size:1rem;color:#64748b;font-weight:500}.features-list{list-style:none;padding:0;margin:0 0 32px}.features-list li{display:flex;align-items:center;gap:12px;padding:12px 0;color:#475569;font-size:.9375rem}.features-list svg{color:#10b981;flex-shrink:0}.limitations-section{margin:24px 0 32px;padding-top:24px;border-top:1px solid #e2e8f0}.limitations-title{font-size:.875rem;font-weight:600;color:#64748b;margin-bottom:12px;text-transform:uppercase;letter-spacing:.5px}.limitations-list{list-style:none;padding:0;margin:0}.limitations-list li{display:flex;align-items:center;gap:10px;padding:8px 0;color:#94a3b8;font-size:.875rem;opacity:.8}.limitations-list svg{color:#ef4444;flex-shrink:0}.plan-button{width:100%;padding:16px 32px;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.plan-button.primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.plan-button.primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 16px #667eea4d}.plan-button.secondary{background:#fff;border:2px solid #667eea;color:#667eea}.plan-button.secondary:hover:not(:disabled){background:#f8f9ff}.plan-button:disabled{opacity:.6;cursor:not-allowed}.pricing-card.current .plan-button{background:#10b981;color:#fff;cursor:default}.pricing-faq{max-width:1000px;margin:0 auto;padding-top:60px;border-top:1px solid #e2e8f0}.pricing-faq h2{font-size:2rem;font-weight:700;text-align:center;margin-bottom:40px;color:#1a1a2e}.comparison-table{overflow-x:auto;margin-bottom:60px;border-radius:12px;border:1px solid #e2e8f0;background:#fff}.comparison-table table{width:100%;border-collapse:collapse;font-size:.9375rem}.comparison-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.comparison-table th{padding:20px 16px;text-align:left;font-weight:600}.comparison-table th:first-child{border-radius:12px 0 0}.comparison-table th:last-child{border-radius:0 12px 0 0}.comparison-table tbody tr{border-bottom:1px solid #e2e8f0;transition:background .2s ease}.comparison-table tbody tr:hover{background:#f8f9ff}.comparison-table tbody tr:last-child{border-bottom:none}.comparison-table td{padding:16px;color:#475569}.comparison-table td:first-child{font-weight:500;color:#1a1a2e}.comparison-table td:not(:first-child){text-align:center}.faq-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:30px}.faq-item h4{font-size:1.125rem;font-weight:600;color:#1a1a2e;margin-bottom:12px}.faq-item p{font-size:.9375rem;color:#64748b;line-height:1.6}@media (max-width: 768px){.pricing-header h1{font-size:2rem}.pricing-header p{font-size:1rem}.pricing-grid{grid-template-columns:1fr}.price .amount{font-size:2.5rem}.faq-grid{grid-template-columns:1fr}}.upgrade-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000;padding:1rem}.upgrade-modal-content{background:#fff;border-radius:16px;max-width:500px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d;position:relative}.upgrade-modal-close{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:1.5rem;cursor:pointer;color:#64748b;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .2s}.upgrade-modal-close:hover{background:#f1f5f9;color:#1e293b}.upgrade-modal-header{text-align:center;padding:2rem 2rem 1rem}.upgrade-modal-icon{font-size:3rem;margin-bottom:1rem}.upgrade-modal-header h2{margin:0;font-size:1.5rem;color:#1e293b}.upgrade-modal-body{padding:0 2rem 2rem}.upgrade-usage-info{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-bottom:1.5rem;padding:1rem;background:#f8fafc;border-radius:12px;font-size:1.25rem}.usage-current{font-size:2rem;font-weight:700;color:#ef4444}.usage-separator{font-weight:300;color:#94a3b8}.usage-limit{font-size:2rem;font-weight:700;color:#64748b}.usage-label{margin-left:.5rem;color:#64748b;font-size:.875rem}.upgrade-message{text-align:center;color:#475569;margin-bottom:1.5rem;line-height:1.6}.upgrade-plan-card{background:linear-gradient(135deg,#667eea,#764ba2);padding:1.5rem;border-radius:12px;color:#fff}.upgrade-plan-card.enterprise{background:linear-gradient(135deg,#fbbf24,#f59e0b)}.upgrade-plan-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.upgrade-plan-icon{font-size:1.5rem}.upgrade-plan-name{font-size:1.25rem;font-weight:600}.upgrade-plan-price{font-size:2rem;font-weight:700;margin-bottom:1.5rem}.upgrade-plan-features{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.75rem}.upgrade-plan-features li{display:flex;align-items:center;gap:.5rem;font-size:.9375rem;opacity:.95}.upgrade-modal-footer{display:flex;gap:1rem;padding:1.5rem 2rem;border-top:1px solid #e2e8f0}.upgrade-modal-footer button{flex:1;padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;border:none}.btn-secondary:hover{background:#e2e8f0;color:#475569}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.app-layout{min-height:100vh;height:100vh;display:flex;flex-direction:column;background:var(--bg);color:var(--text);overflow:hidden}.app-toolbar{background:var(--surface);color:var(--text);box-shadow:0 1px 3px #00000014;position:relative;z-index:5;flex-shrink:0;border-bottom:1.5px solid var(--border)}.app-toolbar .toolbar{padding:1rem 0;display:flex;align-items:center;justify-content:space-between;gap:1rem}.app-nav{background:var(--surface);border-bottom:1.5px solid var(--border);position:relative;z-index:10000;box-shadow:0 1px 2px #0000000a;flex-shrink:0}.app-nav .nav-wrap{display:flex;align-items:stretch;gap:0}.app-content{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}.app-footer{background:var(--surface);border-top:1.5px solid var(--border);padding:1rem 0;flex-shrink:0}.subscription-banner{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:16px 24px;border-radius:12px;margin-bottom:24px;display:flex;align-items:center;justify-content:space-between;gap:20px;box-shadow:0 4px 12px #667eea33}.subscription-banner.free{background:linear-gradient(135deg,#64748b,#475569)}.subscription-banner.pro{background:linear-gradient(135deg,#667eea,#764ba2)}.subscription-banner.enterprise{background:linear-gradient(135deg,#fbbf24,#f59e0b)}.subscription-info{display:flex;align-items:center;gap:24px;flex:1}.plan-badge{display:flex;align-items:center;gap:8px;background:#fff3;padding:8px 16px;border-radius:20px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.plan-icon{font-size:1.25rem}.plan-name{font-weight:600;font-size:.9375rem}.projects-counter{display:flex;flex-direction:column;gap:6px;flex:1;max-width:300px}.counter-text{font-size:.875rem;font-weight:500;opacity:.95}.progress-bar{width:100%;height:6px;background:#ffffff40;border-radius:3px;overflow:hidden}.progress-fill{height:100%;border-radius:3px;transition:all .3s ease}.upgrade-prompt{display:flex;align-items:center;gap:12px;background:#ffffff26;padding:10px 16px;border-radius:8px}.upgrade-prompt span{font-size:.875rem;font-weight:500}.upgrade-button{background:#fff;color:#667eea;border:none;padding:8px 20px;border-radius:6px;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .2s ease}.subscription-banner.free .upgrade-button{color:#64748b}.subscription-banner.enterprise .upgrade-button{color:#f59e0b}.upgrade-button:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.subtle-upgrade-button{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);padding:8px 20px;border-radius:6px;font-weight:500;font-size:.875rem;cursor:pointer;transition:all .2s ease}.subtle-upgrade-button:hover{background:#ffffff4d;transform:translateY(-1px)}@media (max-width: 768px){.subscription-banner{flex-direction:column;align-items:stretch}.subscription-info{flex-direction:column;align-items:stretch;gap:12px}.projects-counter{max-width:100%}.upgrade-prompt{flex-direction:column;gap:8px}.upgrade-button,.subtle-upgrade-button{width:100%}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background:#fff;border-radius:16px;width:90%;max-width:500px;box-shadow:0 20px 60px #0000004d;animation:modalSlideIn .2s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px 24px 16px;border-bottom:1px solid #e2e8f0}.modal-header h2{font-size:1.5rem;font-weight:700;color:#1a1a2e;margin:0}.modal-close{background:none;border:none;font-size:2rem;color:#64748b;cursor:pointer;line-height:1;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .2s}.modal-close:hover{background:#f1f5f9;color:#1a1a2e}.modal-body{padding:24px}.form-group{margin-bottom:24px}.form-group label{display:block;font-size:.875rem;font-weight:600;color:#334155;margin-bottom:8px}.form-group input{width:100%;padding:12px 16px;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;transition:all .2s}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input:disabled{background:#f8fafc;cursor:not-allowed}.error-message{padding:12px 16px;background:#fee;border:1px solid #fcc;border-radius:8px;color:#c33;font-size:.875rem;margin-bottom:16px}.modal-actions{display:flex;gap:12px;justify-content:flex-end}.modal-actions button{min-width:120px}.admin-header{display:flex;justify-content:space-between;align-items:center;padding:0;width:100%}.header-left{flex:1}.header-right{display:flex;align-items:center;gap:var(--gap-3)}.user-info{display:flex;align-items:center;gap:var(--gap-3);padding:8px 16px;background:var(--surface);border-radius:12px;border:1px solid var(--border)}.user-avatar{width:32px;height:32px;border-radius:50%;object-fit:cover}.user-name{font-size:.875rem;font-weight:500;color:var(--text);max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-header h1{font-size:2rem;font-weight:800;color:var(--text);margin:0;letter-spacing:-.5px}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:var(--gap-4)}.loading-state p{color:var(--muted);font-size:.875rem}.dashboard-content{max-width:1400px;margin:0 auto;padding:2rem}.dashboard-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;margin-bottom:3rem}@media (max-width: 1024px){.dashboard-stats{grid-template-columns:repeat(2,1fr)}}@media (max-width: 640px){.dashboard-stats{grid-template-columns:1fr;gap:1.25rem}}.stat-card{display:flex;align-items:center;gap:1.25rem;padding:1.75rem!important;cursor:default;transition:all .3s ease;background:linear-gradient(135deg,var(--surface) 0%,white 100%);border:1.5px solid var(--border)}.stat-card:hover{transform:translateY(-3px);box-shadow:0 8px 20px #0000001a!important;border-color:var(--primary-200)}.stat-icon{font-size:2.5rem;width:70px;height:70px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary-50) 0%,var(--primary-100) 100%);border-radius:16px;border:2px solid var(--primary-200);flex-shrink:0}.stat-info{flex:1;min-width:0}.stat-value{font-size:2.25rem;font-weight:800;color:var(--text);margin-bottom:.375rem;line-height:1}.projects-section{margin-top:2rem}.section-header h2{font-size:1.625rem;font-weight:800;color:var(--text);margin:0;letter-spacing:-.5px;display:flex;align-items:center;gap:.75rem}.section-actions{display:flex;align-items:center;gap:var(--gap-3)}.projects-count{font-size:.875rem;color:var(--muted);font-weight:600;background:var(--surface-2);padding:var(--gap-2) var(--gap-3);border-radius:var(--radius)}.projects-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem}@media (min-width: 1600px){.projects-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width: 1200px){.projects-grid{grid-template-columns:1fr;gap:1.5rem}}.project-card{cursor:pointer;transition:all .3s ease;display:flex;flex-direction:column;border-radius:16px;background:#fff;border:1.5px solid var(--border);position:relative;padding:2rem!important}.project-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f!important;border-color:var(--primary)}.project-card-header{margin-bottom:1.5rem;padding-bottom:1.25rem;border-bottom:2px solid var(--border)}.project-title-section{display:flex;flex-direction:column;gap:1rem}.project-card-header h3{font-size:1.375rem;font-weight:800;color:var(--text);margin:0;letter-spacing:-.5px;line-height:1.3}.project-badges{display:flex;flex-wrap:wrap;gap:.625rem;align-items:center}.project-card-body{flex:1;margin-bottom:var(--gap-4)}.project-info-list{display:flex;flex-direction:column;gap:1rem;width:100%}.info-row{display:flex;align-items:flex-start;gap:1rem;padding:1rem;background:var(--surface-2);border-radius:12px;transition:all .2s ease;border:1px solid var(--border)}.info-row:hover{background:var(--surface);border-color:var(--primary-200)}.info-icon{font-size:1.75rem;flex-shrink:0;line-height:1;opacity:.9;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary-50) 0%,var(--primary-100) 100%);border-radius:10px;border:1.5px solid var(--primary-200)}.info-details{display:flex;flex-direction:column;gap:.375rem;flex:1;min-width:0}.info-label{font-size:.75rem;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.05em;line-height:1.2}.info-value{font-size:1rem;color:var(--text);font-weight:700;line-height:1.4;word-break:break-word}.project-card-footer{padding-top:1.5rem;margin-top:1rem;border-top:2px solid var(--border);display:flex;justify-content:space-between;align-items:center;gap:1rem}.project-card-footer .btn-delete{padding:.75rem 1rem;min-width:48px;background:transparent;color:var(--color-danger, #ef4444);border:1.5px solid var(--color-danger, #ef4444);font-size:1.25rem;transition:all .2s ease}.project-card-footer .btn-delete:hover:not(:disabled){background:var(--color-danger, #ef4444);color:#fff;transform:scale(1.05)}.project-card-footer .btn-delete:disabled{opacity:.5;cursor:not-allowed}.project-card-footer .btn-manage{flex:1;padding:.875rem 1.5rem;font-weight:700;font-size:1rem;background:linear-gradient(135deg,var(--primary-600) 0%,var(--primary-700) 100%);border:none;box-shadow:0 2px 8px #0000001a;transition:all .2s ease}.project-card-footer .btn-manage:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.project-header h3{font-size:1.25rem;font-weight:600;color:var(--text);margin:0}.project-meta{display:flex;flex-direction:column;gap:var(--gap-2);margin-bottom:var(--gap-3)}.meta-item{font-size:.875rem;color:var(--muted)}.project-actions{margin-top:var(--gap-4);padding-top:var(--gap-3);border-top:1px solid var(--border)}.no-projects{grid-column:1 / -1;text-align:center;color:var(--text-muted);font-size:1.125rem;font-weight:500;padding:4rem 2rem;background:var(--surface);border-radius:16px;border:1.5px dashed var(--border)}.admin-loading{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.admin-loading p{font-size:1.25rem;margin-top:1rem}@media (max-width: 768px){.dashboard-content{padding:1.25rem}.admin-header h1{font-size:1.75rem}.projects-grid{grid-template-columns:1fr;gap:1.25rem}.section-header{flex-direction:column;align-items:flex-start;gap:1rem}.section-header h2{font-size:1.375rem}}@media (max-width: 480px){.dashboard-content{padding:1rem}.admin-header h1{font-size:1.5rem}.stat-card{padding:1.25rem!important}.stat-icon{width:56px;height:56px;font-size:2rem}.stat-value{font-size:1.875rem}.project-card-header h3{font-size:1.125rem}}.polygon-drawer{width:100%;height:100%;overflow:visible;padding:0;margin:0;background:transparent;position:relative;display:block}.polygon-drawer canvas{box-shadow:0 4px 6px #0000004d;background:transparent;display:block;margin:0}.image-stage{position:relative;display:inline-block;line-height:0;image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges;margin:auto}.image-stage img{display:block;-webkit-user-select:none;user-select:none;-webkit-user-drag:none;image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges}.image-stage canvas{position:absolute;inset:0 auto auto 0;image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges}.no-image{color:var(--text-light);font-size:1.125rem;text-align:center}.virtual-tour-uploader{margin:20px 0;padding:20px;background:#f8f9fa;border-radius:8px;border:2px dashed #dee2e6}.virtual-tour-uploader h4{margin:0 0 15px;color:#495057;font-size:16px}.virtual-tour-uploader .info{margin:10px 0;color:#6c757d;font-size:14px}.virtual-tour-uploader .info strong{color:#495057}.mode-selector{display:flex;gap:10px;margin:15px 0;padding:4px;background:#e9ecef;border-radius:8px}.mode-btn{flex:1;padding:10px 16px;background:#fff;border:2px solid transparent;border-radius:6px;color:#6c757d;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.mode-btn:hover{color:#495057;border-color:#dee2e6}.mode-btn.active{background:#007bff;color:#fff;border-color:#007bff;box-shadow:0 2px 6px #007bff4d}.url-input-group{display:flex;gap:10px;margin:15px 0}.url-input{flex:1;padding:12px 16px;border:2px solid #dee2e6;border-radius:6px;font-size:14px;transition:all .2s}.url-input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.url-submit-btn{padding:12px 24px;background:#28a745;color:#fff;border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.url-submit-btn:hover:not(:disabled){background:#218838;transform:translateY(-2px);box-shadow:0 4px 8px #28a7454d}.url-submit-btn:disabled{background:#6c757d;cursor:not-allowed;opacity:.6}.folder-input-label{display:block;margin:15px 0}.upload-btn{display:inline-block;padding:12px 24px;background:#007bff;color:#fff;border-radius:6px;cursor:pointer;font-weight:500;transition:all .3s ease}.upload-btn:hover{background:#0056b3;transform:translateY(-2px);box-shadow:0 4px 8px #007bff4d}.upload-btn:active{transform:translateY(0)}.progress-bar{width:100%;height:6px;background:#e9ecef;border-radius:3px;margin-top:15px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#007bff,#0056b3);transition:width .3s ease;border-radius:3px}.current-tour{display:flex;align-items:center;gap:15px;padding:15px;background:#fff;border-radius:6px}.current-tour p{margin:0;color:#28a745;font-weight:500;flex:1}.preview-link{padding:8px 16px;background:#17a2b8;color:#fff;text-decoration:none;border-radius:4px;font-size:14px;transition:background .2s}.preview-link:hover{background:#138496}.delete-btn{padding:8px 16px;background:#dc3545;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:14px;transition:background .2s}.delete-btn:hover{background:#c82333}.project-editor{min-height:100vh;height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;flex-direction:column;overflow:hidden}.editor-header{background:#fffffffa;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 4px 20px #0000001a;flex-shrink:0}.editor-header h1{font-size:1.75rem;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:800;margin:0}.btn-back{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.75rem 1.75rem;border-radius:10px;font-weight:700;cursor:pointer;transition:all .3s;box-shadow:0 4px 15px #667eea66}.btn-back:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea80}.editor-container{display:flex;flex:1;min-height:0;margin:0;border-radius:0;overflow:hidden;background:#fff;box-shadow:none}.sidebar{width:280px;flex-shrink:0;display:flex;flex-direction:column;background:#f8f9fc;border-right:2px solid #e8ebf5}.sidebar-top{padding:2rem 1.5rem;background:#fff;border-bottom:2px solid #e8ebf5;display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.sidebar-top h2{font-size:1.15rem;font-weight:800;color:#1e293b;margin:0}.btn-add-building{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.65rem 1.25rem;border-radius:10px;font-size:.85rem;font-weight:700;cursor:pointer;transition:all .3s;box-shadow:0 3px 10px #667eea4d}.btn-add-building:hover{transform:translateY(-2px);box-shadow:0 5px 15px #667eea66}.buildings-container{flex:1;overflow-y:auto;padding:1.5rem}.building-item{margin-bottom:1.5rem}.building-card{background:#fff;border:2px solid #e8ebf5;border-radius:12px;padding:1.25rem 1.5rem;display:flex;justify-content:space-between;align-items:center;cursor:pointer;transition:all .3s;box-shadow:0 2px 8px #0000000a}.building-card:hover{border-color:#667eea;box-shadow:0 4px 16px #667eea26;transform:translate(4px)}.building-card.selected{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;box-shadow:0 6px 20px #667eea4d}.building-info{display:flex;flex-direction:column;gap:.35rem}.building-title{font-size:1.05rem;font-weight:800;color:#1e293b}.building-card.selected .building-title{color:#fff}.building-count{font-size:.8rem;font-weight:600;color:#64748b}.building-card.selected .building-count{color:#ffffffd9}.btn-delete{background:#fee;color:#ef4444;border:2px solid #fecaca;width:32px;height:32px;border-radius:8px;font-size:1.5rem;font-weight:700;cursor:pointer;transition:all .3s;display:flex;align-items:center;justify-content:center;line-height:1;padding:0}.btn-delete:hover{background:#ef4444;color:#fff;border-color:#ef4444;transform:scale(1.1)}.building-card.selected .btn-delete{background:#fff3;border-color:#fff6;color:#fff}.building-card.selected .btn-delete:hover{background:#ef4444;border-color:#ef4444}.floors-container{margin-top:1rem;padding:1rem;background:#fff;border:2px solid #e8ebf5;border-radius:12px}.floors-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:2px solid #e8ebf5}.floors-label{font-size:.85rem;font-weight:800;color:#667eea;text-transform:uppercase;letter-spacing:.5px}.btn-add-floor{background:#f0f2ff;color:#667eea;border:2px solid #d9deff;padding:.5rem 1rem;border-radius:8px;font-size:.75rem;font-weight:700;cursor:pointer;transition:all .3s}.btn-add-floor:hover{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:#667eea}.floors-list{display:flex;flex-direction:column;gap:.75rem;margin-top:.75rem}.floors-header{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;margin-bottom:.5rem}.floors-header span{font-size:.75rem;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.floor-item{background:#f8f9fc;border:2px solid #e8ebf5;border-radius:8px;padding:.75rem 1rem;display:flex;justify-content:space-between;align-items:center;cursor:pointer;transition:all .3s;gap:.5rem}.floor-item:hover{background:#f0f2ff;border-color:#667eea;transform:translate(2px)}.floor-item.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;box-shadow:0 2px 8px #667eea4d}.floor-item-content{display:flex;align-items:center;gap:.75rem;flex:1}.floor-item span{font-size:.9rem;font-weight:600;color:#1e293b}.floor-item.active span{color:#fff}.floor-card{background:#f8f9fc;border:2px solid #e8ebf5;border-radius:10px;padding:1rem 1.25rem;display:flex;justify-content:space-between;align-items:center;cursor:grab;transition:all .3s}.floor-card:hover{background:#f0f2ff;border-color:#667eea;transform:translate(4px)}.floor-card.selected{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;box-shadow:0 4px 16px #667eea4d}.floor-card.dragging{opacity:.5;cursor:grabbing}.floor-label{font-size:.95rem;font-weight:700;color:#1e293b}.floor-card.selected .floor-label{color:#fff}.floor-badge{background:#fff;color:#667eea;padding:.35rem .75rem;border-radius:6px;font-size:.8rem;font-weight:800;box-shadow:0 2px 6px #00000014}.floor-card.selected .floor-badge{background:#fffffff2;color:#667eea}.editor-main{flex:1;display:flex;flex-direction:column;overflow:hidden;background:#fafbff;min-width:0}.editor-toolbar{padding:.5rem 1rem;background:linear-gradient(135deg,#667eea14,#764ba214);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:2px solid rgba(102,126,234,.1);display:flex;justify-content:space-between;align-items:center;flex-shrink:0;gap:1rem}.editor-toolbar h3{font-size:1.25rem;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:800;margin:0;display:flex;align-items:center;gap:.5rem}.lots-count{font-size:.85rem;font-weight:600;color:#64748b}.toolbar-actions{display:flex;gap:1rem}.btn-draw,.btn-close-polygon,.btn-cancel,.btn-export{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.5rem 1rem;border-radius:8px;font-weight:700;cursor:pointer;transition:all .3s;box-shadow:0 4px 12px #667eea4d;font-size:.85rem}.btn-draw:hover,.btn-close-polygon:hover,.btn-export:hover{transform:translateY(-2px);box-shadow:0 6px 16px #667eea66}.btn-cancel{background:#f1f5f9;color:#64748b;box-shadow:0 2px 8px #0000000d}.btn-cancel:hover{background:#e2e8f0;color:#1e293b}.btn-close-polygon:disabled{opacity:.5;cursor:not-allowed}.canvas-container{flex:1;overflow:auto;padding:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea08,#764ba208);min-width:0;min-height:0}.canvas-container canvas{box-shadow:0 10px 40px #0000001a;border-radius:12px;cursor:crosshair}.no-floor-selected{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:#64748b;font-size:1.25rem;font-weight:600;gap:1rem}.no-floor-selected:before{content:"📋";font-size:4rem}.edit-toolbar{position:absolute;bottom:2rem;left:50%;transform:translate(-50%);display:flex;gap:1rem;background:#fffffffa;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:1.25rem 2rem;border-radius:16px;box-shadow:0 10px 40px #0003;border:2px solid rgba(102,126,234,.3);z-index:100}.edit-toolbar:before{content:"🖊️ Mode édition : Glissez les sommets • Double-clic pour ajouter • Alt+Clic pour supprimer";position:absolute;top:-2.5rem;left:50%;transform:translate(-50%);background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:.5rem 1.25rem;border-radius:8px;font-size:.85rem;font-weight:600;white-space:nowrap;box-shadow:0 4px 12px #667eea66}.lot-form-panel{position:fixed;right:0;top:0;bottom:0;width:420px;background:#fff;box-shadow:-4px 0 20px #00000026;overflow-y:auto;z-index:1000;animation:slideInRight .3s ease-out}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}.lot-form-header{padding:2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.lot-form-header h3{font-size:1.5rem;font-weight:800;margin:0}.lot-form-content{padding:2rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.5rem}.form-group label{display:block;font-weight:700;color:#1e293b;margin-bottom:.5rem;font-size:.9rem}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.75rem;border:2px solid #e8ebf5;border-radius:8px;font-size:.95rem;transition:all .3s;font-family:inherit}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group textarea{min-height:100px;resize:vertical}.tour-preview iframe{width:100%;height:300px;border:2px solid #e8ebf5;border-radius:8px;margin:.5rem 0}.tour-actions{display:flex;gap:.75rem;margin-top:.75rem}.btn-danger{background:#fee;color:#ef4444;border:2px solid #fecaca;padding:.65rem 1.25rem;border-radius:8px;font-weight:700;cursor:pointer;transition:all .3s;font-size:.85rem}.btn-danger:hover{background:#ef4444;color:#fff;border-color:#ef4444}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .2s}.modal{background:#fff;border-radius:16px;padding:2.5rem;max-width:500px;width:90%;box-shadow:0 20px 60px #0000004d;animation:scaleIn .3s}@keyframes scaleIn{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.modal h2{font-size:1.5rem;font-weight:800;color:#1e293b;margin:0 0 2rem}.modal-actions{display:flex;gap:1rem;margin-top:2rem}.btn-primary,.btn-secondary{flex:1;padding:.875rem;border-radius:10px;font-weight:700;cursor:pointer;transition:all .3s;border:none;font-size:.95rem}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 12px #667eea4d}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 16px #667eea66}.btn-secondary{background:#f1f5f9;color:#64748b}.btn-secondary:hover{background:#e2e8f0;color:#1e293b}.status-badge{display:inline-block;padding:.35rem .75rem;border-radius:20px;font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.status-badge.status-disponible{background:#10b98120;color:#047857}.status-badge.status-option{background:#f59e0b20;color:#d97706}.status-badge.status-vendu{background:#ef444420;color:#dc2626}.virtual-tour-viewer{position:fixed;top:0;left:0;right:0;bottom:0;background:#000;z-index:10000;display:flex;flex-direction:column;animation:fadeIn .3s ease}.viewer-header{display:flex;justify-content:space-between;align-items:center;padding:15px 25px;background:#000000e6;border-bottom:1px solid rgba(255,255,255,.1)}.viewer-header h3{margin:0;color:#fff;font-size:18px;font-weight:500}.close-btn{width:40px;height:40px;background:#ffffff1a;border:none;border-radius:50%;color:#fff;font-size:24px;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;line-height:1}.close-btn:hover{background:#fff3;transform:rotate(90deg)}.viewer-content{flex:1;position:relative;overflow:hidden}.viewer-content iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:none}.client-viewer{display:flex;height:100%;min-height:0;overflow:hidden;background:var(--bg);position:relative}.client-viewer.embedded{height:100%;flex-direction:column}.client-viewer.embedded .canvas-viewer{position:absolute;top:0;left:0;right:0;bottom:0;z-index:1;padding:0;margin:0}.client-viewer.embedded .canvas-viewer canvas{border-radius:0;box-shadow:none;animation:none;width:100%;height:100%;object-fit:cover}.viewer-sidebar{overflow-y:auto}.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;padding:var(--gap-6);background:var(--bg);color:var(--text);gap:var(--gap-4)}.loading-spinner{width:60px;height:60px;border:5px solid var(--border);border-top-color:var(--primary-600);border-radius:50%;animation:spin .8s linear infinite}.loading p{font-size:1.1rem;color:var(--text);font-weight:600}.viewer-sidebar{width:280px;background:var(--surface);color:var(--text);display:flex;flex-direction:column;border-right:2px solid var(--border);box-shadow:var(--shadow);border-radius:0 var(--radius) var(--radius) 0;margin:0;flex-shrink:0}.client-viewer.embedded:after{content:"";position:absolute;top:0;left:0;bottom:0;width:60px;z-index:98;pointer-events:all}.client-viewer.embedded:before{content:"";position:absolute;bottom:0;left:0;right:0;height:60px;z-index:98;pointer-events:all}.client-viewer.embedded .viewer-sidebar{position:absolute;left:0;top:50%;transform:translateY(-50%);width:240px;max-height:85vh;z-index:100;background:#fffffff5;-webkit-backdrop-filter:blur(25px) saturate(180%);backdrop-filter:blur(25px) saturate(180%);border-radius:0 24px 24px 0;border:1px solid rgba(229,231,235,.8);border-left:none;box-shadow:15px 0 50px #00000026,0 0 1px #0000001a;overflow:hidden;transition:all .3s ease;opacity:1;pointer-events:all}.client-viewer.embedded .viewer-sidebar.sidebar-visible,.client-viewer.embedded .viewer-sidebar:hover,.client-viewer.embedded .viewer-sidebar.sidebar-pinned{left:0;opacity:1;pointer-events:all;transform:translateY(-50%) scale(1)}.sidebar-toggle{position:absolute;left:0;top:50%;transform:translateY(-50%);width:48px;height:100px;background:linear-gradient(135deg,#3b82f6eb,#6366f1eb);-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border:1px solid rgba(255,255,255,.5);border-left:none;border-radius:0 20px 20px 0;z-index:99;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;font-size:1.5rem;color:#fff;transition:all .4s cubic-bezier(.34,1.56,.64,1);box-shadow:6px 0 25px #3b82f659,0 0 1px #ffffff80 inset;opacity:.85;animation:gentlePulseToggle 3.5s ease-in-out infinite}.sidebar-toggle:after{content:"Menu";font-size:.65rem;font-weight:700;letter-spacing:.5px;opacity:.9}@keyframes gentlePulseToggle{0%,to{box-shadow:6px 0 25px #3b82f659,0 0 1px #ffffff80 inset;transform:translateY(-50%) scale(1)}50%{box-shadow:6px 0 35px #3b82f680,0 0 2px #ffffffb3 inset;transform:translateY(-50%) scale(1.03)}}.sidebar-toggle:hover{width:56px;opacity:1;transform:translateY(-50%) translate(3px);box-shadow:12px 0 40px #3b82f699}.client-viewer.embedded:hover .sidebar-toggle{opacity:.9}.sidebar-toggle.sidebar-pinned{opacity:1;animation:none}@keyframes pulseToggle{0%,to{box-shadow:8px 0 30px #3b82f666}50%{box-shadow:12px 0 40px #3b82f6b3}}@keyframes slideInFromLeft{0%{opacity:0;transform:translate(-100px)}to{opacity:1;transform:translate(0)}}.project-title{padding:2rem 1.5rem;border-bottom:2px solid rgba(30,58,138,.1);background:linear-gradient(135deg,#1e3a8a0d,#3b82f60d);border-radius:0 20px 0 0}.project-title h2{font-size:1.4rem;margin:0;background:linear-gradient(135deg,#1e3a8a,#3b82f6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:800;letter-spacing:-.5px}.floors-nav{padding:1.5rem;overflow-y:auto;flex:1}.floors-nav h3{font-size:.9rem;text-transform:uppercase;background:linear-gradient(135deg,#1e3a8a,#3b82f6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:1rem;font-weight:800;letter-spacing:1px}.floor-btn{width:100%;padding:1rem 1.25rem;background:#fff;color:#1e3a8a!important;border:3px solid #3b82f6;border-radius:12px;text-align:left;font-size:1rem;margin-bottom:.75rem;transition:all .3s cubic-bezier(.4,0,.2,1);font-weight:700;cursor:pointer;position:relative;overflow:hidden;box-shadow:0 3px 12px #3b82f640;-webkit-text-fill-color:#1e3a8a!important}.floor-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(30,58,138,.08),transparent);transition:left .5s}.floor-btn:hover:before{left:100%}.floor-btn:hover{background:linear-gradient(135deg,#1e3a8a0d,#3b82f60d);color:#3b82f6!important;transform:translate(6px);border-color:#3b82f6;box-shadow:0 4px 12px #3b82f626;-webkit-text-fill-color:#3b82f6!important}.floor-btn.active{background:linear-gradient(135deg,#1e3a8a,#3b82f6);border-color:#3b82f6;color:#fff;box-shadow:0 0 20px #3b82f666,0 4px 12px #00000026;transform:translate(6px) scale(1.02)}.floor-btn.active:hover{box-shadow:0 0 25px #3b82f680,0 6px 16px #0003;transform:translate(8px) scale(1.03)}.viewer-main{flex:1;display:flex;flex-direction:column;overflow:hidden;position:relative;min-width:0;min-height:0;background:#fff}.canvas-viewer{width:100%;height:100%;display:flex;align-items:center;justify-content:center;overflow:hidden;padding:0;margin:0;position:relative;background:#fff}.canvas-viewer canvas{width:100%!important;height:100%!important;object-fit:contain;position:absolute;top:0;left:0}@keyframes pulse-select{0%{transform:scale(1);box-shadow:0 2px 8px #0000001a}50%{transform:scale(1.02);box-shadow:0 8px 24px #3b82f64d}to{transform:scale(1);box-shadow:0 4px 16px #3b82f633}}.lot-list-card.selected-animate{animation:pulse-select .4s cubic-bezier(.34,1.56,.64,1);border:2px solid #3b82f6!important;background:linear-gradient(135deg,#3b82f614,#6366f114)}.lot-list-card:hover{border-color:#93c5fd;box-shadow:0 4px 12px #3b82f626;transition:all .2s ease}.favorite-btn.active{animation:favorite-pop .3s cubic-bezier(.34,1.56,.64,1)}@keyframes favorite-pop{0%{transform:scale(1)}50%{transform:scale(1.3) rotate(10deg)}to{transform:scale(1) rotate(0)}}.btn-export-pdf:active,.btn-share:active,.btn-contact:active{transform:scale(.95);transition:transform .1s ease}.btn-control:active:after,.nav-item:active:after{content:"";position:absolute;top:50%;left:50%;width:100%;height:100%;background:#3b82f64d;border-radius:50%;transform:translate(-50%,-50%) scale(0);animation:ripple .6s ease-out}@keyframes ripple{to{transform:translate(-50%,-50%) scale(2);opacity:0}}.canvas-loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:1rem;z-index:10}.canvas-loading p{color:#1e3a8a;font-size:1rem;font-weight:600}.status-legend,.legend-item,.legend-item .dot,.lot-status.disponible,.lot-status.option,.lot-status.vendu{display:none}.client-viewer:not(.embedded) .canvas-viewer canvas{box-shadow:0 10px 40px #00000026;border-radius:12px;animation:fadeIn .3s ease-out}.client-viewer.embedded .canvas-viewer canvas{border-radius:0;box-shadow:none;object-fit:cover}@keyframes fadeIn{0%{opacity:0;transform:scale(.98)}to{opacity:1;transform:scale(1)}}@media (max-width: 1024px){.client-viewer:not(.embedded) .sidebar{width:280px}.floor-item{padding:.75rem}.lot-card{padding:.875rem}}@media (max-width: 768px){.client-viewer:not(.embedded){flex-direction:column-reverse}.client-viewer:not(.embedded) .sidebar{width:100%;height:35vh;max-height:350px;border-right:none;border-top:1px solid var(--border);border-bottom:none;overflow-y:auto;box-shadow:0 -4px 12px #00000014}.viewer-main{height:65vh;border-bottom:1px solid var(--border)}.floor-item{padding:.625rem;font-size:.9rem}.lot-card{padding:.75rem}.lot-details{font-size:.875rem}.hover-card{min-width:220px;font-size:.875rem}.controls-bar{padding:.5rem;gap:.5rem}.btn-control{width:36px;height:36px;font-size:1rem}}@media (max-width: 480px){.client-viewer:not(.embedded) .sidebar{height:30vh;max-height:280px;box-shadow:0 -2px 8px #00000014}.viewer-main{height:70vh}.sidebar-header h2{font-size:1.1rem}.floor-item{padding:.5rem;font-size:.85rem}.lot-card{padding:.625rem;font-size:.85rem}.lot-details{font-size:.8rem}.hover-card{min-width:180px;font-size:.8rem}.hover-card-header h3{font-size:1rem}.hover-card-body p{font-size:.75rem}.controls-bar{padding:.375rem;gap:.375rem}.btn-control{width:32px;height:32px;font-size:.9rem}.welcome-overlay{padding:1.5rem}.welcome-overlay h2{font-size:1.25rem}.welcome-overlay p{font-size:.9rem}}@media (max-width: 320px){.hover-card{min-width:160px;font-size:.75rem}.sidebar-header h2{font-size:1rem}.floor-item,.lot-card{font-size:.75rem}}@media (max-height: 500px) and (orientation: landscape){.client-viewer:not(.embedded){flex-direction:row}.client-viewer:not(.embedded) .sidebar{width:35vw;max-width:320px;height:100vh;border-right:1px solid var(--border);border-top:none;box-shadow:4px 0 12px #00000014}.viewer-main{height:100vh;border-bottom:none}.welcome-overlay{padding:1rem}.welcome-overlay h2{font-size:1.1rem}}@media (hover: none) and (pointer: coarse){.floor-item{min-height:48px}.lot-card{min-height:60px}.btn-control{min-width:44px;min-height:44px}.floor-item:hover,.lot-card:hover{background:inherit;transform:none}.floor-item:active{background:var(--primary-100)}.lot-card:active{background:var(--surface-2)}}.no-floor{color:#1e3a8a;font-size:1.25rem;font-weight:600}.tooltip{display:none}.hover-popup{position:absolute;top:0;left:0;transform:translate(-50%,calc(-100% - 36px));z-index:1100;pointer-events:none;animation:fadeIn .1s ease-out}.hover-card{background:#fffffffa;-webkit-backdrop-filter:blur(20px) saturate(180%);backdrop-filter:blur(20px) saturate(180%);border:2px solid #3b82f6;border-radius:16px;min-width:260px;box-shadow:0 12px 40px #3b82f659,0 0 1px #ffffff80 inset}@keyframes fadeInScale{0%{opacity:0;transform:translate(-50%,calc(-100% - 36px)) scale(.85)}to{opacity:1;transform:translate(-50%,calc(-100% - 36px)) scale(1)}}.hover-card-header{display:flex;justify-content:space-between;align-items:center;padding:14px 16px 8px;gap:.5rem;background:linear-gradient(180deg,rgba(59,130,246,.08) 0%,transparent 100%);border-radius:16px 16px 0 0}.hover-code{font-weight:800;font-size:20px;color:#1e40af;flex:1;display:flex;align-items:center;gap:.5rem;text-shadow:0 1px 2px rgba(0,0,0,.1)}.icon-360{display:inline-flex;align-items:center;gap:.25rem;font-size:.75rem;font-weight:700;color:#3b82f6;background:#3b82f61a;padding:.25rem .5rem;border-radius:6px;border:1.5px solid #3b82f6;animation:pulse-360 2s ease-in-out infinite}@keyframes pulse-360{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.9}}.hover-status-badge{padding:.25rem .625rem;border-radius:12px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;box-shadow:0 2px 8px #00000026}.hover-status-badge.disponible{background:linear-gradient(135deg,#10b981,#059669);color:#fff;box-shadow:0 2px 8px #10b98166}.hover-status-badge.option{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;box-shadow:0 2px 8px #f59e0b66}.hover-status-badge.vendu{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;box-shadow:0 2px 8px #ef444466}.hover-card-body{padding:10px 16px 14px}.hover-card-body .row{display:flex;justify-content:space-between;font-size:14px;color:#475569;padding:4px 0}.hover-card-body .row strong{color:#1e40af;font-weight:700}.hover-card-footer{padding:12px 16px;border-top:1px solid rgba(226,232,240,.8);background:linear-gradient(180deg,#f8fafc80,#f1f5f980)}.hover-call-btn{width:100%;background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;border:none;padding:10px 16px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px #8b5cf64d;display:flex;align-items:center;justify-content:center;gap:8px}.hover-call-btn:hover{background:linear-gradient(135deg,#7c3aed,#6d28d9);transform:translateY(-2px);box-shadow:0 4px 12px #8b5cf666}.hover-pin{position:absolute;left:50%;top:calc(100% + 8px);transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:6px}.hover-pin-line{width:2px;height:20px;background:linear-gradient(180deg,#3b82f6,#60a5fa);box-shadow:0 0 4px #3b82f680}.hover-pin-node{width:16px;height:16px;background:#fff;border:3px solid #3b82f6;border-radius:50%;box-shadow:0 2px 8px #3b82f666,0 0 1px #fffc inset}.lot-details{position:fixed;right:0;top:0;bottom:0;width:400px;background:linear-gradient(180deg,#fffffffa,#f8fafcfa);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-left:2px solid rgba(30,58,138,.1);overflow-y:auto;z-index:1000;animation:slideIn .2s cubic-bezier(.34,1.56,.64,1);box-shadow:-4px 0 20px #0000001a}.client-viewer.embedded .lot-details{right:0;top:50%;bottom:auto;transform:translateY(-50%);width:420px;max-height:90vh;border-radius:20px 0 0 20px;border:2px solid rgba(255,255,255,.3);border-right:none;box-shadow:-15px 0 60px #0000004d;background:#fffffffa;-webkit-backdrop-filter:blur(20px) saturate(180%);backdrop-filter:blur(20px) saturate(180%);animation:slideInFromRight .2s cubic-bezier(.34,1.56,.64,1);transition:transform .15s ease,opacity .15s ease}@keyframes slideInFromRight{0%{opacity:0;transform:translateY(-50%) translate(50px)}to{opacity:1;transform:translateY(-50%) translate(0)}}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.btn-back-home{background:linear-gradient(135deg,#1e3a8a0d,#3b82f60d);color:#1e3a8a;border:2px solid rgba(30,58,138,.15);padding:.625rem 1.25rem;border-radius:10px;cursor:pointer;font-size:.9rem;font-weight:700;display:flex;align-items:center;gap:.5rem;transition:all .3s ease;margin-bottom:.75rem;box-shadow:0 2px 8px #0000000d}.btn-back-home:hover{background:linear-gradient(135deg,#1e3a8a,#3b82f6);color:#fff;transform:translate(-5px);border-color:#3b82f6;box-shadow:0 4px 12px #3b82f640}.project-title{display:flex;flex-direction:column}.project-title h2{margin:0}.close-btn{position:absolute;top:1rem;right:1rem;background:linear-gradient(135deg,#ef44441a,#dc26261a);border:2px solid rgba(239,68,68,.3);width:36px;height:36px;border-radius:50%;font-size:1.25rem;color:#ef4444;transition:all .3s;z-index:10;cursor:pointer;font-weight:700;box-shadow:0 2px 8px #0000000d}.close-btn:hover{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border-color:#ef4444;transform:rotate(90deg) scale(1.1);box-shadow:0 4px 12px #ef44444d}.lot-details-content{padding:2rem}.lot-details-content h2{color:#1e3a8a;font-size:1.75rem;margin-bottom:.5rem;font-weight:800}.lot-subtitle{color:#64748b;font-size:1.125rem;margin-bottom:2rem;font-weight:500}.plan-section{margin-bottom:2rem}.plan-section h3{color:#1e3a8a;font-size:1rem;margin-bottom:1rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.plan-section img{width:100%;border-radius:12px;box-shadow:0 4px 12px #0000001a;border:2px solid rgba(30,58,138,.1)}.lot-info-section{background:linear-gradient(135deg,#1e3a8a08,#3b82f608);padding:1.5rem;border-radius:12px;margin-top:2rem;border:2px solid rgba(30,58,138,.1);box-shadow:0 2px 8px #0000000d}.lot-info-section h3{color:#1e3a8a;font-size:1rem;margin-bottom:1rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.info-grid{display:grid;gap:1rem}.info-item{display:flex;justify-content:space-between;align-items:center;padding-bottom:.75rem;border-bottom:2px solid rgba(30,58,138,.1)}.info-item:last-child{border-bottom:none}.info-label{color:#64748b;font-size:.875rem;font-weight:600}.info-value{color:#1e3a8a;font-weight:700;font-size:.95rem}.info-value.price{color:#3b82f6;font-size:1.25rem;font-weight:800}.loading{display:flex;align-items:center;justify-content:center;height:100%;padding:2rem;background:linear-gradient(135deg,#1e3a8a,#3b82f6);color:#fff;font-size:1.25rem}.filters-section{padding:1rem 1.5rem;border-bottom:2px solid rgba(30,58,138,.1);background:linear-gradient(135deg,#1e3a8a08,#3b82f608)}.btn-toggle-filters{width:100%;padding:1rem;background:linear-gradient(135deg,#1e3a8a,#3b82f6);color:#fff;border:2px solid #3b82f6;border-radius:10px;font-weight:700;font-size:.9rem;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;box-shadow:0 4px 12px #3b82f64d}.btn-toggle-filters:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.btn-toggle-filters:hover:before{left:100%}.btn-toggle-filters:hover{background:linear-gradient(135deg,#1e40af,#2563eb);box-shadow:0 6px 20px #3b82f666;transform:translateY(-2px)}.btn-toggle-filters:active{transform:translateY(0)}.filters-panel{margin-top:1rem;display:flex;flex-direction:column;gap:.75rem;animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.filter-group{display:flex;flex-direction:column;gap:.25rem}.filter-group label{font-size:.75rem;color:#64748b;text-transform:uppercase;font-weight:700;letter-spacing:.5px}.filter-group input,.filter-group select{padding:.75rem;border:2px solid rgba(30,58,138,.15);border-radius:8px;background:#fff;color:#1e3a8a;font-size:.875rem;transition:all .3s;outline:none;font-weight:600}.filter-group input:focus,.filter-group select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;background:#3b82f605}.filter-group select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;background:#3b82f605}.filter-group input:hover,.filter-group select:hover{border-color:#3b82f6;background:#3b82f605}.btn-reset-filters{padding:.75rem;background:linear-gradient(135deg,#ef44441a,#dc26261a);color:#ef4444;border:2px solid rgba(239,68,68,.3);border-radius:8px;font-size:.875rem;font-weight:700;cursor:pointer;transition:all .3s}.btn-reset-filters:hover{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border-color:#ef4444;transform:translateY(-2px);box-shadow:0 4px 12px #ef44444d}.floor-filtered-count{font-size:.75rem;opacity:.7;font-weight:600}.view-toggle-bar{display:flex;justify-content:center;align-items:center;gap:1rem;padding:.75rem 1rem;background:#fff;border-bottom:1px solid var(--border);min-height:auto}.client-viewer.embedded:before{content:"";position:absolute;top:0;left:0;right:0;height:60px;z-index:99;pointer-events:all}.client-viewer.embedded .view-toggle-bar{position:absolute;bottom:-100px;left:50%;transform:translate(-50%);z-index:100;background:#fffffffa;-webkit-backdrop-filter:blur(20px) saturate(180%);backdrop-filter:blur(20px) saturate(180%);border-radius:20px 20px 0 0;border:2px solid rgba(255,255,255,.3);border-bottom:none;box-shadow:0 -10px 40px #0003;padding:1rem 1.5rem;min-height:unset;transition:bottom .5s cubic-bezier(.34,1.56,.64,1),opacity .4s ease;opacity:0;pointer-events:none}.client-viewer.embedded .view-toggle-bar.view-bar-visible,.client-viewer.embedded .view-toggle-bar:hover{bottom:0;opacity:1;pointer-events:all}@keyframes slideInFromTop{0%{opacity:0;transform:translate(-50%) translateY(-50px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.view-actions{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.view-toggle-btn{padding:.75rem 1rem;background:#fff;color:#1e3a8a;border:2px solid rgba(30,58,138,.15);border-radius:10px;font-weight:700;font-size:.85rem;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;gap:.5rem;white-space:nowrap;box-shadow:0 2px 8px #0000000d}.view-toggle-btn svg{flex-shrink:0;transition:transform .3s ease}.view-toggle-btn:hover svg{transform:scale(1.1)}.view-toggle-btn.active svg{stroke:#fff}.view-toggle-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(30,58,138,.08),transparent);transition:left .5s}.view-toggle-btn:hover:before{left:100%}.view-toggle-btn:hover{background:linear-gradient(135deg,#1e3a8a0d,#3b82f60d);color:#1e3a8a;transform:translateY(-2px);border-color:#3b82f6;box-shadow:0 4px 12px #3b82f626}.view-toggle-btn.active{background:linear-gradient(135deg,#1e3a8a,#3b82f6);border-color:#3b82f6;color:#fff;box-shadow:0 0 20px #3b82f666,0 4px 12px #00000026;transform:translateY(-2px) scale(1.02)}.view-toggle-btn.active:hover{box-shadow:0 0 25px #3b82f680,0 6px 16px #0003;transform:translateY(-3px) scale(1.03)}.lots-counter{display:flex;align-items:center;justify-content:center;padding:.75rem 1rem;background:linear-gradient(135deg,#3b82f626,#1e3a8a0d);border:2px solid rgba(59,130,246,.4);border-radius:10px;color:#3b82f6;font-weight:800;font-size:.8rem;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 2px 8px #3b82f633;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{box-shadow:0 2px 8px #3b82f633}50%{box-shadow:0 4px 16px #3b82f666}}.list-viewer{flex:1;overflow-y:auto;background:transparent;padding:1rem}.lots-list-view{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem;max-width:1400px;margin:0 auto}.lot-list-card{background:#fff;border:2px solid rgba(30,58,138,.15);border-radius:12px;padding:1.5rem;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);animation:fadeInUp .4s ease-out backwards;box-shadow:0 2px 8px #0000000d}.lot-list-card:nth-child(1){animation-delay:.05s}.lot-list-card:nth-child(2){animation-delay:.1s}.lot-list-card:nth-child(3){animation-delay:.15s}.lot-list-card:nth-child(4){animation-delay:.2s}.lot-list-card:nth-child(5){animation-delay:.25s}.lot-list-card:nth-child(n+6){animation-delay:.3s}.lot-list-card:hover{border-color:#3b82f6;transform:translateY(-4px);box-shadow:0 8px 24px #3b82f640}.lot-list-card.selected{border-color:#3b82f6;background:linear-gradient(135deg,#1e3a8a0d,#3b82f60d);box-shadow:0 0 20px #3b82f64d}.lot-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:2px solid rgba(30,58,138,.1)}.lot-list-header h3{color:#1e3a8a;font-size:1.25rem;margin:0;font-weight:800}.lot-status-badge{padding:.375rem .875rem;border-radius:20px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 2px 6px #0003;transition:all .3s}.lot-status-badge.disponible{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.lot-status-badge.option{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.lot-status-badge.vendu{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.lot-list-body{display:flex;flex-direction:column;gap:.5rem}.lot-list-body p{color:#64748b;font-size:.875rem;margin:0;font-weight:500}.lot-list-body p strong{color:#1e3a8a;font-weight:700;display:inline-block;min-width:80px}.lot-header-actions{display:flex;justify-content:flex-start;align-items:flex-start;margin-bottom:1.25rem;position:relative}.btn-export-pdf{background:linear-gradient(135deg,#1e3a8a,#3b82f6);color:#fff;border:2px solid #3b82f6;padding:.625rem 1.25rem;border-radius:10px;font-size:.875rem;font-weight:700;cursor:pointer;transition:all .3s;white-space:nowrap;box-shadow:0 2px 8px #3b82f64d}.btn-export-pdf:hover{background:linear-gradient(135deg,#1e40af,#2563eb);transform:translateY(-2px);box-shadow:0 4px 12px #3b82f666}.lot-action-buttons{display:flex;gap:.75rem;align-items:center;margin-top:1.25rem;flex-wrap:wrap}.lot-header-actions{margin-bottom:0}.lot-header-actions h2{margin:0;font-size:1.75rem;line-height:1.2;color:#1e293b;font-weight:800}.lot-subtitle{margin:.15rem 0 0;font-size:.95rem;color:#475569;font-weight:600}.btn-share{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;padding:.625rem 1.25rem;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s ease;white-space:nowrap;box-shadow:0 2px 8px #10b9814d;display:flex;align-items:center;gap:.5rem}.btn-share:hover{background:linear-gradient(135deg,#059669,#047857);transform:translateY(-2px);box-shadow:0 4px 12px #10b98166}.btn-export-pdf{background:linear-gradient(135deg,#2563eb,#3b82f6);color:#fff;border:none;padding:.625rem 1.25rem;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s ease;white-space:nowrap;box-shadow:0 2px 8px #3b82f64d;display:flex;align-items:center;gap:.5rem}.btn-virtual-tour{background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .3s ease;white-space:nowrap;box-shadow:0 2px 8px #2563eb66;animation:pulse-btn 2s ease-in-out infinite}.btn-virtual-tour:hover{background:linear-gradient(135deg,#1d4ed8,#1e40af);transform:translateY(-2px) scale(1.05);box-shadow:0 6px 16px #2563eb80;animation:none}.btn-call{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;border:none;padding:.625rem 1.25rem;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s ease;white-space:nowrap;box-shadow:0 2px 8px #8b5cf64d;display:flex;align-items:center;gap:.5rem}.btn-call:hover{background:linear-gradient(135deg,#7c3aed,#6d28d9);transform:translateY(-2px);box-shadow:0 4px 12px #8b5cf666}@keyframes pulse-btn{0%,to{box-shadow:0 2px 8px #2563eb66}50%{box-shadow:0 2px 16px #2563eb99}}.btn-share-small{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;padding:.4rem .8rem;border-radius:6px;font-size:.75rem;font-weight:500;cursor:pointer;transition:all .3s ease;margin-top:.5rem;width:100%;box-shadow:0 2px 8px #10b9814d}.btn-share-small:hover{background:linear-gradient(135deg,#059669,#047857);transform:translateY(-2px);box-shadow:0 4px 12px #10b98166}.zoom-controls{position:absolute;bottom:2rem;right:2rem;display:flex;flex-direction:column;gap:.5rem;z-index:100}.zoom-btn{width:48px;height:48px;background:#2563ebe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid rgba(255,255,255,.2);border-radius:50%;color:#fff;font-size:1.25rem;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);display:flex;align-items:center;justify-content:center}.zoom-btn:hover{background:#1d4ed8f2;transform:scale(1.15);box-shadow:0 4px 20px #2563eb66}.zoom-btn:active{transform:scale(.9)}@media (max-width: 768px){.client-viewer{flex-direction:column}.viewer-sidebar{width:100%;max-height:40vh;overflow-y:auto}.floors-nav{display:flex;flex-wrap:wrap;gap:.5rem}.floor-btn{flex:1;min-width:calc(50% - .25rem);margin-bottom:0}.lot-details{width:100%;position:fixed;top:0;right:0;height:100vh;z-index:1000}.lots-list-view{grid-template-columns:1fr}.view-toggle-bar{flex-wrap:wrap}.hover-popup{display:none!important}}.lightbox-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000fa;display:flex;align-items:center;justify-content:center;z-index:99999;cursor:pointer;animation:fadeIn .4s cubic-bezier(.16,1,.3,1);overflow:hidden}@keyframes fadeIn{0%{opacity:0;-webkit-backdrop-filter:blur(0px);backdrop-filter:blur(0px)}to{opacity:1;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}}.lightbox-toolbar{position:fixed;top:0;left:0;right:0;display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;background:linear-gradient(180deg,rgba(0,0,0,.8) 0%,transparent 100%);z-index:100000;animation:slideDown .5s ease-out}@keyframes slideDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}.lightbox-left-actions{display:flex;gap:1rem;align-items:center}.lightbox-counter{color:#fff;font-size:1.125rem;font-weight:700;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:.625rem 1.25rem;border-radius:50px;border:2px solid rgba(255,255,255,.2);box-shadow:0 4px 20px #0000004d}.lightbox-actions{display:flex;gap:.75rem;align-items:center}.lightbox-tool-btn{background:#ffffff26;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid rgba(255,255,255,.25);width:48px;height:48px;border-radius:50%;font-size:1.25rem;color:#fff;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px #0000004d}.lightbox-tool-btn:hover{background:#ffffff40;border-color:#fff6;transform:scale(1.15);box-shadow:0 6px 25px #0006}.lightbox-tool-btn:active{transform:scale(.95)}.lightbox-close{background:linear-gradient(135deg,#ef4444e6,#dc2626e6);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid rgba(255,255,255,.3);width:48px;height:48px;border-radius:50%;font-size:1.5rem;color:#fff;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);z-index:10001;display:flex;align-items:center;justify-content:center;font-weight:700;box-shadow:0 4px 20px #ef444466}.lightbox-close:hover{background:linear-gradient(135deg,#ef4444,#dc2626);border-color:#ffffff80;transform:rotate(90deg) scale(1.2);box-shadow:0 6px 30px #ef444499}.lightbox-image-container{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center;overflow:hidden;user-select:none;-webkit-user-select:none;touch-action:none}.lightbox-image{max-width:95vw;max-height:90vh;width:auto;height:auto;object-fit:contain;cursor:default;box-shadow:0 25px 80px #000c;border-radius:12px;animation:zoomIn .5s cubic-bezier(.16,1,.3,1);pointer-events:none;transition:transform .3s ease-out}@keyframes zoomIn{0%{transform:scale(.85);opacity:0}to{transform:scale(1);opacity:1}}.lightbox-nav{position:fixed;top:50%;transform:translateY(-50%);width:64px;height:64px;background:#ffffff26;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid rgba(255,255,255,.25);border-radius:50%;color:#fff;font-size:3rem;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);z-index:10000;display:flex;align-items:center;justify-content:center;font-weight:300;line-height:1;box-shadow:0 4px 20px #0000004d}.lightbox-nav-prev{left:2rem}.lightbox-nav-next{right:2rem}.lightbox-nav:hover{background:#ffffff4d;border-color:#ffffff80;transform:translateY(-50%) scale(1.15);box-shadow:0 6px 30px #00000080}.lightbox-nav:active{transform:translateY(-50%) scale(.95)}.lightbox-thumbnails{position:fixed;bottom:2rem;left:50%;transform:translate(-50%);display:flex;gap:.75rem;padding:1rem 1.5rem;background:#000000b3;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:16px;border:2px solid rgba(255,255,255,.1);max-width:90vw;overflow-x:auto;z-index:10000;box-shadow:0 10px 40px #00000080;animation:slideUp .5s cubic-bezier(.16,1,.3,1)}@keyframes slideUp{0%{transform:translate(-50%) translateY(100%);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}.lightbox-thumbnails::-webkit-scrollbar{height:6px}.lightbox-thumbnails::-webkit-scrollbar-track{background:#ffffff0d;border-radius:3px}.lightbox-thumbnails::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.lightbox-thumbnails::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.lightbox-thumb{width:80px;height:60px;background-size:cover;background-position:center;background-repeat:no-repeat;border-radius:8px;cursor:pointer;transition:all .3s ease;border:3px solid transparent;opacity:.6;flex-shrink:0;box-shadow:0 2px 8px #0000004d}.lightbox-thumb:hover{opacity:1;transform:scale(1.1);border-color:#ffffff4d;box-shadow:0 4px 16px #0006}.lightbox-thumb.active{opacity:1;border-color:#3b82f6;box-shadow:0 0 20px #3b82f699;transform:scale(1.05)}.lightbox-zoom-indicator{position:fixed;bottom:2rem;right:2rem;background:#000c;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;padding:.75rem 1.25rem;border-radius:50px;font-size:1rem;font-weight:700;border:2px solid rgba(255,255,255,.2);z-index:10000;box-shadow:0 4px 20px #0000004d;animation:fadeIn .3s ease}.immersive-hint{position:absolute;pointer-events:none;z-index:90;opacity:.65;transition:opacity .6s ease,transform .4s cubic-bezier(.34,1.56,.64,1);display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.5rem;text-shadow:0 2px 8px rgba(0,0,0,.5)}.client-viewer.embedded:hover .immersive-hint{opacity:0;transform:scale(.9)}.hint-top{bottom:20px;left:50%;transform:translate(-50%);animation:pulseUp 2.5s ease-in-out infinite}.hint-top:before{content:"▲";display:block;font-size:2rem;color:#60a5fa;filter:drop-shadow(0 0 8px rgba(96,165,250,.6))}.hint-top:after{content:"Vues";position:absolute;bottom:100%;margin-bottom:.5rem;font-size:.875rem;font-weight:700;color:#3b82f6;background:#ffffffeb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:.3rem .85rem;border-radius:12px;white-space:nowrap;box-shadow:0 4px 12px #00000026;border:1px solid rgba(59,130,246,.2)}.hint-left{left:20px;top:50%;transform:translateY(-50%);animation:pulseRight 2s ease-in-out infinite}.hint-left:before{content:"▶";display:block;font-size:2rem;color:#60a5fa;filter:drop-shadow(0 0 8px rgba(96,165,250,.6))}.hint-left:after{content:"Étages";position:absolute;left:100%;margin-left:.5rem;font-size:.875rem;font-weight:700;color:#3b82f6;background:#ffffffeb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:.3rem .85rem;border-radius:12px;white-space:nowrap;box-shadow:0 4px 12px #00000026;border:1px solid rgba(59,130,246,.2)}.hint-bottom-right{bottom:20px;right:20px;animation:pulseDiagonal 2s ease-in-out infinite}.hint-bottom-right:before{content:"◢";display:block;font-size:2rem;color:#60a5fa;filter:drop-shadow(0 0 8px rgba(96,165,250,.6))}.hint-bottom-right:after{content:"Zoom";position:absolute;bottom:100%;right:0;margin-bottom:.5rem;font-size:.875rem;font-weight:700;color:#3b82f6;background:#ffffffeb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:.3rem .85rem;border-radius:12px;white-space:nowrap;box-shadow:0 4px 12px #00000026;border:1px solid rgba(59,130,246,.2)}@keyframes pulseDown{0%,to{transform:translate(-50%) translateY(0);opacity:.65}50%{transform:translate(-50%) translateY(5px);opacity:.85}}@keyframes pulseUp{0%,to{transform:translate(-50%) translateY(0);opacity:.65}50%{transform:translate(-50%) translateY(-5px);opacity:.85}}@keyframes pulseRight{0%,to{transform:translateY(-50%) translate(0);opacity:.65}50%{transform:translateY(-50%) translate(5px);opacity:.85}}@keyframes pulseDiagonal{0%,to{transform:translate(0);opacity:.65}50%{transform:translate(3px,3px);opacity:.85}}.immersive-welcome{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:linear-gradient(135deg,#111827f5,#1e293bf5);-webkit-backdrop-filter:blur(30px) saturate(150%);backdrop-filter:blur(30px) saturate(150%);color:#fff;padding:2.5rem 3.5rem;border-radius:32px;text-align:center;z-index:200;animation:fadeInOut 4s cubic-bezier(.4,0,.2,1) forwards;pointer-events:none;border:1px solid rgba(99,102,241,.4);box-shadow:0 25px 80px #00000080,0 0 60px #3b82f626,0 0 1px #fff3 inset;max-width:600px}.immersive-welcome h3{margin:0 0 1.5rem;font-size:2rem;font-weight:800;display:flex;align-items:center;justify-content:center;gap:.75rem}.immersive-welcome p{margin:1rem 0;font-size:1.125rem;opacity:.95;line-height:1.6}.immersive-welcome .controls-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:2rem}.immersive-welcome .control-item{background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:1rem;border-radius:12px;border:1px solid rgba(255,255,255,.2)}.immersive-welcome .control-icon{font-size:2rem;display:block;margin-bottom:.5rem}.immersive-welcome .control-label{font-size:.875rem;font-weight:600;opacity:.9}@keyframes fadeInOut{0%{opacity:0;transform:translate(-50%,-50%) scale(.9)}15%{opacity:1;transform:translate(-50%,-50%) scale(1)}85%{opacity:1;transform:translate(-50%,-50%) scale(1)}to{opacity:0;transform:translate(-50%,-50%) scale(.9);pointer-events:none}}@media (max-width: 768px){.lightbox-toolbar{padding:1rem}.lightbox-counter{font-size:.875rem;padding:.5rem 1rem}.lightbox-tool-btn,.lightbox-close{width:40px;height:40px;font-size:1rem}.lightbox-nav{width:48px;height:48px;font-size:2rem}.lightbox-nav-prev{left:1rem}.lightbox-nav-next{right:1rem}.lightbox-thumbnails{bottom:1rem;padding:.75rem 1rem;gap:.5rem}.lightbox-thumb{width:60px;height:45px}.lightbox-zoom-indicator{bottom:1rem;right:1rem;padding:.5rem 1rem;font-size:.875rem}.lightbox-image{max-width:100vw;max-height:85vh}}.help-btn{position:absolute;bottom:2rem;left:50%;transform:translate(-50%);width:48px;height:48px;background:#2563ebe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid rgba(255,255,255,.2);border-radius:50%;color:#fff;font-size:1.25rem;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);display:flex;align-items:center;justify-content:center;z-index:100}.help-btn:hover{background:#1d4ed8f2;transform:translate(-50%) scale(1.15);box-shadow:0 4px 20px #2563eb66}.help-btn:active{transform:translate(-50%) scale(.9)}.help-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:3000;animation:fadeIn .2s ease-out}.help-modal{background:#1e293b;border:2px solid #334155;border-radius:16px;padding:2rem;max-width:600px;width:90%;max-height:80vh;overflow-y:auto;position:relative;animation:zoomIn .3s ease-out}.help-close{position:absolute;top:1rem;right:1rem;background:#334155;border:none;width:32px;height:32px;border-radius:50%;font-size:1.25rem;color:#fff;cursor:pointer;transition:all .2s}.help-close:hover{background:#475569;transform:scale(1.1)}.help-modal h2{color:#fff;margin:0 0 1.5rem;font-size:1.5rem}.help-content{display:flex;flex-direction:column;gap:1.5rem}.help-section h3{color:#cbd5e1;font-size:1rem;margin:0 0 .75rem;font-weight:600}.help-item{display:flex;align-items:center;gap:1rem;padding:.5rem 0;color:#e2e8f0}.help-item kbd{background:#334155;color:#fff;padding:.25rem .5rem;border-radius:4px;font-family:monospace;font-size:.875rem;border:1px solid #475569;min-width:32px;text-align:center;box-shadow:0 2px 4px #0003}.help-item span:last-child{flex:1;font-size:.9rem}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.5rem}.gallery-thumbnail{width:100%;height:120px;object-fit:cover;border-radius:8px;border:2px solid var(--border-color);transition:all .2s}.gallery-thumbnail:hover{border-color:var(--primary-color);transform:scale(1.05)}.favorite-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#94a3b8;transition:all .3s ease;padding:.25rem;line-height:1}.favorite-btn:hover{color:#fbbf24;transform:scale(1.2)}.favorite-btn.active{color:#fbbf24;text-shadow:0 0 10px rgba(251,191,36,.5)}.lot-list-title{display:flex;align-items:center;gap:.5rem}.view-toggle-btn.compare-action{background:linear-gradient(135deg,#10b981,#059669);color:#fff;font-weight:600;animation:pulse-glow 2s ease-in-out infinite}@keyframes pulse-glow{0%,to{box-shadow:0 0 10px #10b98180}50%{box-shadow:0 0 20px #10b981cc}}.lot-list-card.selected-for-compare,.selected-for-compare{border:3px solid #10b981!important;background:linear-gradient(135deg,#10b9811a,#0596690d)!important;box-shadow:0 0 20px #10b9814d!important}.compare-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:1100;padding:2rem;animation:fadeIn .3s ease}.compare-modal{background:linear-gradient(180deg,#1e293b,#0f172a);border-radius:16px;max-width:1400px;width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 25px 50px #00000080;border:2px solid #334155;animation:slideUp .4s cubic-bezier(.16,1,.3,1)}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.compare-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:2px solid #334155;background:linear-gradient(90deg,#1e293b,#334155)}.compare-modal-header h2{margin:0;color:#fff;font-size:1.5rem;display:flex;align-items:center;gap:.5rem}.compare-close{background:#ef4444;color:#fff;border:none;width:32px;height:32px;border-radius:50%;cursor:pointer;font-size:1.25rem;display:flex;align-items:center;justify-content:center;transition:all .3s ease;box-shadow:0 2px 8px #ef44444d}.compare-close:hover{background:#dc2626;transform:rotate(90deg) scale(1.1);box-shadow:0 4px 12px #ef444480}.compare-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;padding:2rem;overflow-y:auto;flex:1}.compare-card{background:linear-gradient(135deg,#1e293b,#0f172a);border:2px solid #334155;border-radius:12px;overflow:hidden;transition:all .3s ease;box-shadow:0 4px 12px #0000004d}.compare-card:hover{transform:translateY(-4px);box-shadow:0 8px 20px #0006;border-color:#3b82f6}.compare-card-header{background:linear-gradient(135deg,#334155,#1e293b);padding:1rem;display:flex;justify-content:space-between;align-items:center;border-bottom:2px solid #475569}.compare-card-header h3{margin:0;color:#fff;font-size:1.125rem;font-weight:600}.remove-compare-btn{background:#ef4444;color:#fff;border:none;width:24px;height:24px;border-radius:50%;cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.remove-compare-btn:hover{background:#dc2626;transform:scale(1.15)}.compare-card-body{padding:1rem}.compare-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem;border-bottom:1px solid #334155}.compare-row:last-child{border-bottom:none}.compare-label{color:#94a3b8;font-size:.875rem;font-weight:500}.compare-value{color:#fff;font-weight:600;text-align:right}.compare-actions{display:flex;gap:1rem;justify-content:center;padding:1.5rem 2rem;border-top:2px solid #334155;background:#1e293b}.btn-secondary{background:linear-gradient(135deg,#64748b,#475569);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:600;transition:all .3s ease;box-shadow:0 4px 12px #0003}.btn-secondary:hover{transform:translateY(-2px);box-shadow:0 6px 16px #0000004d;background:linear-gradient(135deg,#475569,#334155)}.btn-primary{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:600;transition:all .3s ease;box-shadow:0 4px 12px #3b82f64d}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 16px #3b82f680;background:linear-gradient(135deg,#2563eb,#1d4ed8)}.promoter-access-btn-discrete{position:fixed;bottom:20px;left:20px;width:40px;height:40px;border-radius:8px;background:#3b82f61a;border:1px solid rgba(59,130,246,.2);color:#3b82f6;font-size:1.25rem;cursor:pointer;transition:all .3s ease;z-index:1000;display:flex;align-items:center;justify-content:center}.promoter-access-btn-discrete:hover{background:#3b82f633;border-color:#3b82f666;transform:scale(1.05)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .2s ease-out}.modal-content{background:var(--surface, #ffffff);border-radius:16px;padding:2rem;width:90%;max-width:400px;box-shadow:0 8px 32px #0003;animation:slideInUp .3s ease-out}.modal-content h2{margin:0 0 1.5rem;font-size:1.5rem;color:var(--text, #1e293b)}.modal-content input{width:100%;padding:.75rem 1rem;border:2px solid rgba(0,0,0,.1);border-radius:8px;font-size:1rem;margin-bottom:1.5rem;background:var(--surface, #ffffff);color:var(--text, #1e293b)}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end}.modal-actions button{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.modal-actions button:first-child{background:#0000000d;color:var(--text, #1e293b)}.modal-actions button:first-child:hover{background:#0000001a}.modal-actions button:last-child{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.modal-actions button:last-child:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);transform:translateY(-2px);box-shadow:0 4px 12px #3b82f666}@media (max-width: 768px){.compare-grid{grid-template-columns:1fr;padding:1rem}.compare-overlay,.compare-modal-header{padding:1rem}.compare-modal-header h2{font-size:1.125rem}.promoter-access-btn-discrete{bottom:80px}}.promoter-edit-toolbar{position:fixed;bottom:20px;left:50%;transform:translate(-50%);background:var(--surface, #ffffff);border:2px solid #3b82f6;border-radius:12px;box-shadow:0 8px 32px #3b82f666;z-index:999;min-width:600px;animation:slideUp .3s ease-out}[data-theme=dark] .promoter-edit-toolbar{background:var(--surface, #1e293b);border-color:#60a5fa}.toolbar-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid rgba(59,130,246,.2);background:linear-gradient(135deg,#3b82f61a,#2563eb1a)}.toolbar-header h3{margin:0;font-size:1rem;font-weight:600;color:var(--text, #1e293b)}.unsaved-indicator{font-size:.875rem;color:#f59e0b;font-weight:500;animation:pulse 2s ease-in-out infinite}.toolbar-actions{display:flex;gap:.75rem;padding:1rem 1.5rem;align-items:center}.toolbar-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border:1px solid rgba(0,0,0,.1);border-radius:8px;background:var(--surface, #ffffff);color:var(--text, #1e293b);cursor:pointer;transition:all .2s;font-size:.9rem;font-weight:500;white-space:nowrap}[data-theme=dark] .toolbar-btn{background:var(--bg, #0f172a);border-color:#ffffff1a}.toolbar-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #00000026;border-color:#3b82f6}.toolbar-btn.active{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border-color:transparent}.toolbar-btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.toolbar-btn .btn-icon{font-size:1.2rem;line-height:1}.toolbar-btn .btn-label{font-size:.9rem}.toolbar-divider{width:1px;height:32px;background:#0000001a;margin:0 .5rem}[data-theme=dark] .toolbar-divider{background:#ffffff1a}.save-btn:not(:disabled){background:linear-gradient(135deg,#10b981,#059669);color:#fff;border-color:transparent}.save-btn:hover:not(:disabled){box-shadow:0 4px 12px #10b98166}.cancel-btn:not(:disabled){background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border-color:transparent}.cancel-btn:hover:not(:disabled){box-shadow:0 4px 12px #ef444466}.toolbar-instructions{padding:.75rem 1.5rem;background:#3b82f60d;border-top:1px solid rgba(59,130,246,.2)}.toolbar-instructions p{margin:0;font-size:.875rem;color:var(--text-secondary, #64748b);font-weight:500}.toolbar-selected-lot{padding:.75rem 1.5rem;background:#3b82f60d;border-top:1px solid rgba(59,130,246,.2)}.toolbar-selected-lot p{margin:0;font-size:.875rem;color:var(--text-secondary, #64748b)}.toolbar-selected-lot strong{color:var(--text, #1e293b);font-weight:600}@keyframes slideUp{0%{opacity:0;transform:translate(-50%,20px)}to{opacity:1;transform:translate(-50%)}}@keyframes slideDown{0%{opacity:0;transform:translate(-50%,-20px)}to{opacity:1;transform:translate(-50%)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@media (max-width: 768px){.promoter-edit-toolbar{bottom:70px;left:1rem;right:1rem;transform:none;min-width:auto;width:calc(100% - 2rem)}.toolbar-actions{flex-wrap:wrap;gap:.5rem}.toolbar-btn{flex:1;min-width:calc(50% - .25rem);justify-content:center}.toolbar-btn .btn-label{display:none}.toolbar-btn .btn-icon{font-size:1.5rem}.toolbar-divider{display:none}}@media (max-width: 480px){.toolbar-btn{min-width:100%}}.lot-edit-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10001;animation:fadeIn .2s ease-out;overflow-y:auto;padding:2rem 1rem}.lot-edit-modal{background:var(--surface, #ffffff);border-radius:16px;width:90%;max-width:800px;max-height:90vh;box-shadow:0 8px 32px #0003;animation:slideInUp .3s ease-out;overflow-y:auto;margin:auto}[data-theme=dark] .lot-edit-modal{background:var(--surface, #1e293b)}.lot-edit-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid rgba(0,0,0,.1);position:sticky;top:0;background:var(--surface, #ffffff);z-index:1}[data-theme=dark] .lot-edit-header{background:var(--surface, #1e293b);border-bottom-color:#ffffff1a}.lot-edit-header h2{margin:0;font-size:1.5rem;font-weight:600;color:var(--text, #1e293b)}.lot-edit-form{padding:1.5rem}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:1.5rem}.form-group{display:flex;flex-direction:column}.form-group.full-width{grid-column:1 / -1}.form-group label{margin-bottom:.5rem;font-weight:500;color:var(--text, #1e293b);font-size:.9rem}.form-group input,.form-group select,.form-group textarea{padding:.75rem 1rem;border:2px solid rgba(0,0,0,.1);border-radius:8px;font-size:1rem;transition:border-color .2s;background:var(--surface, #ffffff);color:var(--text, #1e293b)}[data-theme=dark] .form-group input,[data-theme=dark] .form-group select,[data-theme=dark] .form-group textarea{background:var(--bg, #0f172a);border-color:#ffffff1a}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#3b82f6}.form-group textarea{resize:vertical;min-height:100px;font-family:inherit}.features-input{display:flex;gap:.5rem;margin-bottom:1rem}.features-input input{flex:1}.add-feature-btn{padding:.75rem 1.5rem;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.add-feature-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #3b82f666}.features-list{display:flex;flex-wrap:wrap;gap:.5rem}.feature-tag{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#3b82f61a;border:1px solid rgba(59,130,246,.2);border-radius:6px;font-size:.875rem;color:var(--text, #1e293b)}.feature-tag span{font-weight:500}.remove-feature-btn{background:none;border:none;color:#ef4444;cursor:pointer;padding:0;font-size:1rem;line-height:1;transition:transform .2s}.remove-feature-btn:hover{transform:scale(1.2)}.lot-edit-actions{display:flex;gap:1rem;justify-content:flex-end;padding-top:1.5rem;border-top:1px solid rgba(0,0,0,.1)}[data-theme=dark] .lot-edit-actions{border-top-color:#ffffff1a}.btn-secondary:hover{background:#0000001a}[data-theme=dark] .btn-secondary:hover{background:#ffffff1a}.btn-primary{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 12px #10b98166}@media (max-width: 768px){.lot-edit-modal{width:95%;max-height:95vh}.form-grid{grid-template-columns:1fr}.lot-edit-actions{flex-direction:column-reverse}.btn-secondary,.btn-primary{width:100%}.features-input{flex-direction:column}.add-feature-btn{width:100%}}.color-picker-group{display:flex;align-items:center;gap:1rem}.color-input{width:80px;height:50px;padding:4px;border:2px solid rgba(0,0,0,.1);border-radius:8px;cursor:pointer;background:var(--surface, #ffffff)}[data-theme=dark] .color-input{background:var(--bg, #0f172a);border-color:#ffffff1a}.color-input::-webkit-color-swatch-wrapper{padding:0}.color-input::-webkit-color-swatch{border:none;border-radius:6px}.color-preview{width:40px;height:40px;border-radius:8px;border:2px solid rgba(0,0,0,.1);box-shadow:0 2px 4px #0000001a}[data-theme=dark] .color-preview{border-color:#ffffff1a}.random-color-btn{padding:.5rem 1rem;background:linear-gradient(135deg,#8b5cf6,#ec4899);color:#fff;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.random-color-btn:hover{background:linear-gradient(135deg,#7c3aed,#db2777);transform:translateY(-2px);box-shadow:0 4px 12px #8b5cf666}.reset-color-btn{padding:.5rem 1rem;background:#ef4444;color:#fff;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.reset-color-btn:hover{background:#dc2626;transform:translateY(-2px)}.upload-section{display:flex;flex-direction:column;gap:.75rem}.upload-btn{padding:.75rem 1.5rem;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s;font-size:.95rem;align-self:flex-start}.upload-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #3b82f666}.upload-btn:disabled{opacity:.6;cursor:not-allowed}.remove-image-btn{padding:.5rem 1rem;background:#ef4444;color:#fff;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;align-self:flex-start}.remove-image-btn:hover{background:#dc2626;transform:translateY(-2px)}.plan-preview{width:100%;max-width:100%;border-radius:8px;border:2px solid #e8ebf5;margin-top:.5rem}[data-theme=dark] .plan-preview{border-color:#ffffff26}.image-preview{margin-top:.75rem;border-radius:8px;overflow:hidden;border:2px solid rgba(0,0,0,.1);max-width:100%}[data-theme=dark] .image-preview{border-color:#ffffff1a}.image-preview img{width:100%;height:auto;max-height:200px;object-fit:contain;display:block;background:var(--bg, #f3f4f6)}[data-theme=dark] .image-preview img{background:var(--bg, #0f172a)}.project-home{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem;display:flex;flex-direction:column;align-items:center}.project-home-header{text-align:center;color:#fff;margin-bottom:3rem;animation:fadeInDown .6s ease}.project-home-header h1{font-size:3rem;margin:0 0 .5rem;font-weight:700;text-shadow:0 2px 10px rgba(0,0,0,.2)}.project-subtitle{font-size:1.25rem;opacity:.95;font-weight:300}.project-home-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:2rem;max-width:1400px;width:100%;margin-bottom:2rem}.option-card{background:#fff;border-radius:16px;padding:2.5rem;cursor:pointer;transition:all .4s cubic-bezier(.175,.885,.32,1.275);box-shadow:0 10px 30px #0003;animation:fadeInUp .6s ease;animation-fill-mode:both;display:flex;flex-direction:column;align-items:center;text-align:center}.option-card:nth-child(1){animation-delay:.1s}.option-card:nth-child(3){animation-delay:.3s}.option-card:nth-child(4){animation-delay:.4s}.option-card:hover{transform:translateY(-10px) scale(1.02);box-shadow:0 20px 40px #0000004d}.option-card-disabled{opacity:.6;cursor:not-allowed}.option-card-disabled:hover{transform:none;box-shadow:0 10px 30px #0003}.option-icon{font-size:5rem;margin-bottom:1.5rem;animation:bounce 2s infinite}.option-card:hover .option-icon{animation:bounce .6s ease}.option-card h2{font-size:1.75rem;margin:0 0 1rem;color:#2d3748;font-weight:600}.option-card p{font-size:1rem;color:#718096;line-height:1.6;margin-bottom:1.5rem}.option-features{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center;margin-bottom:2rem}.option-features span{background:#f7fafc;padding:.5rem 1rem;border-radius:20px;font-size:.875rem;color:#4a5568;font-weight:500;border:1px solid #e2e8f0}.btn-option{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:1rem 2.5rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #667eea66;width:100%;max-width:300px}.btn-option:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea80}.btn-option:disabled{background:#cbd5e0;cursor:not-allowed;box-shadow:none}.project-home-footer{background:#fffffff2;padding:1.5rem 2rem;border-radius:12px;max-width:800px;text-align:center;box-shadow:0 4px 15px #0000001a;animation:fadeIn .6s ease .4s;animation-fill-mode:both}.project-home-footer p{margin:0;color:#4a5568;font-size:1rem}.project-home-footer strong{color:#667eea}.project-home-loading,.project-home-error{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.project-home-loading p,.project-home-error p{font-size:1.25rem;margin-top:1rem}.project-home-error h1{font-size:2.5rem;margin-bottom:1rem}.loader{border:4px solid rgba(255,255,255,.3);border-top:4px solid white;border-radius:50%;width:60px;height:60px;animation:spin 1s linear infinite}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}@media (max-width: 768px){.project-home{padding:1rem}.project-home-header h1{font-size:2rem}.project-subtitle{font-size:1rem}.project-home-content{grid-template-columns:1fr;gap:1.5rem}.option-card{padding:2rem}.option-icon{font-size:4rem}.option-card h2{font-size:1.5rem}}.plan-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:20px;color:#fff;font-weight:600;box-shadow:0 2px 8px #0000001a;transition:all .2s}.plan-badge:hover{transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.plan-badge-small{padding:.25rem .75rem;font-size:.75rem;border-radius:12px}.plan-badge-small .plan-badge-icon{font-size:.875rem}.plan-badge-medium{padding:.5rem 1rem;font-size:.875rem}.plan-badge-medium .plan-badge-icon{font-size:1rem}.plan-badge-large{padding:.75rem 1.5rem;font-size:1rem}.plan-badge-large .plan-badge-icon{font-size:1.25rem}.plan-badge-free{background:#64748b}.plan-badge-pro{background:linear-gradient(135deg,#667eea,#764ba2)}.plan-badge-enterprise{background:linear-gradient(135deg,#fbbf24,#f59e0b)}.plan-badge-icon{display:flex;align-items:center;justify-content:center}.plan-badge-label{white-space:nowrap}.settings-header{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:0;gap:2rem;margin-bottom:2.5rem}.header-left{display:flex;justify-content:flex-start}.header-center{display:flex;align-items:center;gap:1rem;justify-content:center}.settings-header h1{font-size:2rem;font-weight:800;color:var(--text);margin:0;white-space:nowrap;letter-spacing:-.5px}.header-actions{display:flex;gap:.75rem;align-items:center;justify-content:flex-end}.settings-content{width:100%;max-width:1400px;margin:0 auto;padding:2rem;display:flex;flex-direction:column;gap:2rem;overflow-y:auto}.section-header-enhanced{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;gap:1.5rem;flex-wrap:wrap}.config-tabs{display:flex;gap:.5rem;background:var(--surface-2);padding:.375rem;border-radius:12px;border:1.5px solid var(--border)}.config-tab{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:transparent;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;font-size:.9375rem;font-weight:500;color:var(--text-muted);white-space:nowrap}.config-tab:hover{background:var(--surface);color:var(--text)}.config-tab.active{background:var(--primary);color:#fff;box-shadow:0 2px 8px #3b82f64d}.tab-icon{font-size:1.25rem;line-height:1}.tab-label{font-weight:500}.project-info-section{padding:2rem}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1.25rem;border-bottom:2px solid var(--border)}.section-header h2{font-size:1.375rem;font-weight:700;color:var(--text);margin:0}.section-header p{color:var(--text-muted);font-size:.9375rem;margin:.375rem 0 0}.edit-actions{display:flex;gap:.875rem}.project-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-top:1.5rem}.info-item{display:flex;flex-direction:column;gap:.75rem;padding:1.25rem;background:var(--surface);border-radius:12px;border:1.5px solid var(--border);transition:all .2s ease}.info-item:hover{border-color:var(--primary-200);box-shadow:0 2px 8px #0000000d;transform:translateY(-1px)}.info-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:.25rem}.info-value{font-size:1.0625rem;font-weight:500;color:var(--text);line-height:1.5}.info-value code{background:var(--surface-2);padding:.375rem .625rem;border-radius:6px;font-size:.875rem;font-family:Courier New,monospace;border:1px solid var(--border);color:var(--primary);font-weight:600}.project-edit-form{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;margin-top:1.5rem;padding:1rem;background:var(--surface);border-radius:12px}.form-group{display:flex;flex-direction:column;gap:.625rem}.form-group label{font-size:.875rem;font-weight:600;color:var(--text);display:flex;align-items:center;gap:.25rem}.form-group input,.form-group textarea,.form-group select{padding:.875rem 1rem;border:1.5px solid var(--border);border-radius:10px;font-size:.9375rem;background:#fff;color:var(--text);transition:all .2s ease;font-family:inherit}.form-group textarea{resize:vertical;min-height:100px;line-height:1.6}.form-group select{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236b7280' d='M10.293 3.293L6 7.586 1.707 3.293A1 1 0 00.293 4.707l5 5a1 1 0 001.414 0l5-5a1 1 0 10-1.414-1.414z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px #3b82f61a;background:#fff}.form-group input:hover,.form-group textarea:hover,.form-group select:hover{border-color:var(--primary-300)}.form-group small{font-size:.8125rem;color:var(--text-muted);margin-top:-.25rem;font-style:italic}.form-section-title{margin-top:2.5rem;margin-bottom:1.25rem;padding-top:2rem;border-top:2px solid var(--border);grid-column:1 / -1}.form-section-title h4{font-size:1.25rem;font-weight:700;color:var(--text);margin:0 0 .5rem;display:flex;align-items:center;gap:.5rem}.form-section-title p{font-size:.9375rem;color:var(--text-muted);margin:0;line-height:1.5}.form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;grid-column:1 / -1}.logo-preview,.logo-container{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--surface);border-radius:10px;border:1.5px dashed var(--border)}.client-logo{width:100px;height:100px;object-fit:contain;border:2px solid var(--border);border-radius:12px;padding:.75rem;background:#fff;box-shadow:0 2px 8px #00000014}.logo-upload{display:flex;flex-direction:column;gap:.75rem;align-items:flex-start}.logo-hint{font-size:.8125rem;color:var(--text-muted);font-style:italic}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:2rem;margin-top:1rem}.stat-card{display:flex;align-items:center;gap:1.25rem;padding:1.75rem!important;cursor:default!important;transition:all .3s ease;background:linear-gradient(135deg,var(--surface) 0%,white 100%);border:1.5px solid var(--border)}.stat-card:hover{transform:translateY(-3px);box-shadow:0 8px 20px #0000001a;border-color:var(--primary-200)}.stat-icon{font-size:2.25rem;width:70px;height:70px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary-50) 0%,var(--primary-100) 100%);border-radius:16px;border:2px solid var(--primary-200);flex-shrink:0}.stat-content{flex:1;min-width:0}.stat-value{font-size:2.25rem;font-weight:800;color:var(--text);line-height:1;margin-bottom:.375rem}.stat-label{font-size:.9375rem;color:var(--text-muted);font-weight:500;line-height:1.3}.settings-section{margin-top:2rem}.settings-section>h2{font-size:1.625rem;font-weight:700;color:var(--text);margin:0 0 2rem;display:flex;align-items:center;gap:.75rem}.settings-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:2rem}.settings-card{cursor:pointer;transition:all .3s ease;border:2px solid var(--border);border-radius:16px;position:relative;overflow:visible;background:#fff;height:100%;display:flex;flex-direction:column}.settings-card:hover{transform:translateY(-6px);box-shadow:0 12px 32px #00000026;border-color:var(--primary)}.settings-card-content{display:flex;flex-direction:column;gap:1.25rem;padding:2rem;flex:1}.settings-icon{font-size:3rem;width:80px;height:80px;display:flex;align-items:center;justify-content:center;border-radius:16px;background:linear-gradient(135deg,var(--primary-50) 0%,var(--primary-100) 100%);border:2px solid var(--primary-200);flex-shrink:0;margin-bottom:.5rem}.settings-card-content h3{font-size:1.25rem;font-weight:700;color:var(--text);margin:0;line-height:1.3}.settings-card-content p{font-size:.9375rem;color:var(--text-muted);margin:0;line-height:1.6;flex:1}.settings-stats{display:flex;align-items:center;gap:.75rem;margin-top:auto;padding-top:1rem;border-top:1px solid var(--border);font-size:.875rem;font-weight:600;color:var(--primary)}.danger-zone{border:2px solid #fee2e2!important;background:linear-gradient(135deg,#fef2f2,#fff)!important}.danger-zone .section-header{border-bottom-color:#fecaca}.danger-zone h2{color:#dc2626}.danger-zone .section-header p{color:#991b1b}.danger-actions{display:flex;flex-direction:column;gap:1rem}.danger-action-item{display:flex;justify-content:space-between;align-items:center;gap:2rem;padding:1.5rem;background:#fff;border-radius:8px;border:1px solid #fecaca}.danger-action-item h3{font-size:1rem;font-weight:600;color:var(--text);margin:0 0 .25rem}.danger-action-item p{font-size:.875rem;color:var(--text-muted);margin:0}.loading-state,.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;min-height:400px;text-align:center}.loading-state p{color:var(--text-muted);font-size:1rem}.empty-state h2{font-size:1.5rem;font-weight:600;color:var(--text);margin:0}@media (max-width: 768px){.settings-content{padding:1.25rem}.settings-header{grid-template-columns:1fr;gap:1.25rem;margin-bottom:2rem}.settings-header h1{font-size:1.625rem}.header-left,.header-center,.header-actions{justify-content:flex-start}.header-center{flex-direction:column;align-items:flex-start}.config-tabs{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}.config-tab{flex-shrink:0;min-width:auto}.section-header-enhanced{flex-direction:column;align-items:stretch}.project-info-section{padding:1.5rem}.project-info-grid,.project-edit-form,.form-row{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1.25rem}.settings-grid{grid-template-columns:1fr;gap:1.5rem}.settings-section>h2{font-size:1.375rem}.settings-card-content{padding:1.5rem}.danger-action-item{flex-direction:column;align-items:flex-start}.stat-icon{width:60px;height:60px;font-size:2rem}.stat-value{font-size:1.875rem}}@media (max-width: 480px){.settings-content{padding:1rem}.settings-header h1{font-size:1.5rem}.config-tab{padding:.625rem 1rem;font-size:.875rem}.tab-icon{font-size:1.125rem}.stats-grid{grid-template-columns:1fr;gap:1rem}.stat-card{padding:1.25rem!important}.settings-grid{gap:1.25rem}.settings-icon{width:70px;height:70px;font-size:2.5rem}.client-logo{width:80px;height:80px}}.config-header{display:flex;justify-content:space-between;align-items:start;padding:0}.config-header h1{font-size:1.75rem;font-weight:800;color:var(--text);margin:var(--gap-2) 0 var(--gap-1) 0;letter-spacing:-.02em}.config-subtitle{color:var(--muted);font-size:.9rem;font-weight:500}.config-content{max-width:1200px;margin:0 auto;padding:0 var(--gap-6) var(--gap-6);height:calc(100vh - 140px);overflow-y:auto}.config-tabs{display:flex;gap:.5rem;margin-bottom:var(--gap-6);border-bottom:2px solid var(--border);position:sticky;top:0;background:var(--bg);z-index:10;padding:var(--gap-6) 0 0}.config-tab{padding:.75rem 1.5rem;border:none;background:transparent;color:var(--muted);font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;border-bottom:3px solid transparent;margin-bottom:-2px}.config-tab:hover{color:var(--text);background:#3b82f60d}.config-tab.active{color:var(--primary);border-bottom-color:var(--primary);background:#3b82f614}.config-content::-webkit-scrollbar{width:8px}.config-content::-webkit-scrollbar-track{background:var(--bg);border-radius:4px}.config-content::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.config-content::-webkit-scrollbar-thumb:hover{background:var(--muted)}.config-form{display:flex;flex-direction:column;gap:var(--gap-6)}.form-section h2{font-size:1.25rem;font-weight:600;color:var(--text);margin-bottom:var(--gap-4)}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--gap-4)}@media (max-width: 900px){.form-grid{grid-template-columns:1fr}}.form-field-full{margin-bottom:var(--gap-4)}.form-field-full label{display:block;margin-bottom:var(--gap-2);font-weight:500;color:var(--text)}.form-field-full textarea{width:100%;padding:var(--gap-3);border:1px solid var(--border);border-radius:var(--radius);font-family:inherit;resize:vertical}.logo-preview,.plan-preview{margin-top:var(--gap-4);padding:var(--gap-4);border:2px dashed var(--border);border-radius:var(--radius);background:var(--bg);display:flex;justify-content:center;align-items:center}.logo-preview img{max-width:250px;max-height:150px;object-fit:contain}.plan-preview img{width:100%;max-height:400px;object-fit:contain;border-radius:var(--radius-sm)}.info-box{background:var(--bg);padding:var(--gap-3);border-radius:var(--radius);margin-bottom:var(--gap-3)}.info-box label{display:block;margin-bottom:var(--gap-2);font-weight:600;color:var(--text)}.link-display{display:flex;gap:var(--gap-2)}.link-input{flex:1;background:var(--surface)}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--gap-3)}.info-item{display:flex;flex-direction:column;gap:var(--gap-1)}.info-label{font-size:.75rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}.form-actions-sticky{position:sticky;bottom:0;z-index:10;background:var(--bg);padding:var(--gap-4) 0;margin:var(--gap-4) calc(-1 * var(--gap-6)) 0;padding-left:var(--gap-6);padding-right:var(--gap-6)}.actions-card{background:var(--surface);box-shadow:var(--shadow-lg)!important}.form-actions{display:flex;justify-content:flex-end;gap:var(--gap-3);align-items:center}@media (max-width: 768px){.form-actions{flex-direction:column-reverse;width:100%}.form-actions>*{width:100%}}.project-config-header p{font-size:1.1rem;color:#718096}.config-form{display:flex;flex-direction:column;gap:2.5rem}.form-section{padding-bottom:var(--gap-5);margin-bottom:var(--gap-5);border-bottom:2px solid var(--border)}.form-section:last-of-type{border-bottom:none;margin-bottom:0}.form-section h2{font-size:1.25rem;font-weight:700;color:var(--text);margin-bottom:var(--gap-4);letter-spacing:-.01em}.form-group label{display:block;font-size:1rem;font-weight:600;color:#4a5568;margin-bottom:.5rem}.form-group input[type=text],.form-group input[type=url],.form-group input[type=number]{width:100%;padding:.875rem 1rem;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;transition:all .3s ease;font-family:inherit}.form-group input:focus{outline:none;border-color:#f093fb;box-shadow:0 0 0 3px #f093fb1a}.form-group small{display:block;margin-top:.5rem;font-size:.875rem;color:#718096;font-style:italic}.logo-preview{margin-top:1rem;padding:1rem;background:#f7fafc;border:2px dashed #cbd5e0;border-radius:8px;display:flex;justify-content:center;align-items:center}.logo-preview img{max-width:120px;max-height:120px;object-fit:contain;border-radius:4px;background:#fff;padding:8px}.btn-test-tour{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.875rem 1.5rem;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:.5rem}.btn-test-tour:hover{transform:translateY(-2px);box-shadow:0 4px 15px #667eea66}.info-box{background:#f7fafc;padding:1.25rem;border-radius:8px;margin-bottom:1rem;border:1px solid #e2e8f0}.info-box label{display:block;font-size:.875rem;font-weight:600;color:#4a5568;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.5px}.info-box code{background:#fff;padding:.5rem .75rem;border-radius:4px;font-family:Monaco,Courier New,monospace;font-size:.9rem;color:#f5576c;border:1px solid #e2e8f0}.info-box span{color:#2d3748;font-size:.95rem}.link-display{display:flex;gap:.5rem}.link-input{flex:1;padding:.75rem;border:2px solid #e2e8f0;border-radius:6px;font-size:.9rem;background:#fff;color:#4a5568}.btn-copy{background:#48bb78;color:#fff;border:none;padding:.75rem 1.25rem;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s ease;white-space:nowrap}.btn-copy:hover{background:#38a169;transform:translateY(-2px)}.message{padding:1rem 1.5rem;border-radius:8px;font-weight:500;text-align:center;animation:slideIn .3s ease}.message.success{background:#c6f6d5;color:#22543d;border:2px solid #9ae6b4}.message.error{background:#fed7d7;color:#742a2a;border:2px solid #fc8181}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1rem}.btn-cancel,.btn-save{padding:1rem 2rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;border:none}.btn-cancel{background:#edf2f7;color:#4a5568}.btn-cancel:hover{background:#e2e8f0;transform:translateY(-2px)}.btn-save{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;box-shadow:0 4px 15px #f093fb66}.btn-save:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #f093fb80}.project-config-loading,.project-config-error{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff}.project-config-error h1{font-size:2.5rem;margin-bottom:1.5rem}.project-config-error button{background:#fff;color:#f5576c;border:none;padding:1rem 2rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.project-config-error button:hover{transform:translateY(-2px);box-shadow:0 4px 15px #0003}.management-section{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:2px solid #bae6fd;border-radius:12px;padding:1.5rem;margin-bottom:1rem}.management-section h2{font-size:1.3rem;color:#0c4a6e;margin:0 0 .5rem}.section-description{font-size:.95rem;color:#475569;margin:0 0 1rem;line-height:1.5}.btn-manage{background:linear-gradient(135deg,#0ea5e9,#0284c7);color:#fff;border:none;padding:.875rem 1.5rem;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:600;transition:all .3s ease;box-shadow:0 4px 12px #0ea5e94d;display:inline-flex;align-items:center;gap:.5rem}.btn-manage:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0ea5e966}.btn-manage:active{transform:translateY(0)}.info-note{background:#fff7ed;border:1px solid #fed7aa;border-radius:8px;padding:1rem;color:#9a3412;font-size:.9rem;margin-top:1rem;display:flex;align-items:flex-start;gap:.5rem}.feature-note{display:block;margin-top:.5rem;color:#dc2626;font-size:.85rem;font-weight:600}@media (max-width: 768px){.project-config{padding:1rem}.project-config-container{padding:2rem 1.5rem}.project-config-header h1{font-size:2rem}.form-actions{flex-direction:column}.btn-cancel,.btn-save{width:100%}.link-display{flex-direction:column}.btn-copy{width:100%}.management-section{padding:1rem}.btn-manage{width:100%;justify-content:center}}.perspectives-page{min-height:100vh;background:linear-gradient(135deg,#f093fb,#f5576c);padding:20px}.perspectives-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;background:#fff;padding:20px 30px;border-radius:12px;box-shadow:0 2px 8px #0000001a}.perspectives-content{display:flex;flex-direction:column;gap:30px}.upload-section{background:#fff;padding:30px;border-radius:12px;box-shadow:0 2px 8px #0000001a}.upload-section h2{margin:0 0 10px;font-size:1.4rem;color:#2d3748}.upload-description{margin:0 0 20px;color:#718096;font-size:.95rem}.upload-info{font-size:.85rem;color:#a0aec0;margin-top:5px}.perspectives-grid-section{background:#fff;padding:30px;border-radius:12px;box-shadow:0 2px 8px #0000001a}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px}.section-header h2{margin:0;font-size:1.4rem;color:#2d3748}.perspective-count{background:#edf2f7;padding:6px 15px;border-radius:20px;font-size:.9rem;color:#4a5568;font-weight:600}.empty-state{text-align:center;padding:60px 20px;color:#a0aec0}.empty-icon{font-size:4rem;margin-bottom:20px;opacity:.5}.empty-state p{margin:10px 0;font-size:1.1rem;color:#718096}.empty-hint{font-size:.9rem!important;color:#a0aec0!important}.perspectives-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.perspective-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000001a;transition:all .3s;border:2px solid #e2e8f0}.perspective-card:hover{transform:translateY(-4px);box-shadow:0 8px 16px #00000026;border-color:#f5576c}.perspective-image-container{position:relative;width:100%;padding-top:66.67%;background:#f7fafc;overflow:hidden}.perspective-image{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover}.btn-delete-perspective{position:absolute;top:10px;right:10px;background:#fffffff2;border:none;border-radius:8px;padding:8px 12px;font-size:1.2rem;cursor:pointer;opacity:0;transition:all .2s;box-shadow:0 2px 8px #0003}.perspective-card:hover .btn-delete-perspective{opacity:1}.btn-delete-perspective:hover{background:#fed7d7;transform:scale(1.1)}.perspective-info{padding:15px;background:#f7fafc}.perspective-number{font-size:.9rem;color:#4a5568;font-weight:600}.plan-masse-page{min-height:100vh;background:linear-gradient(135deg,#f093fb,#f5576c);padding:20px}.plan-masse-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;background:#fff;padding:20px 30px;border-radius:12px;box-shadow:0 2px 8px #0000001a}.plan-masse-content{display:flex;flex-direction:column;gap:30px}.input-field,.textarea-field{width:100%;padding:12px 15px;border:2px solid #e2e8f0;border-radius:8px;font-size:.95rem;transition:all .2s;font-family:inherit}.input-field:focus,.textarea-field:focus{outline:none;border-color:#f5576c;box-shadow:0 0 0 3px #f5576c1a}.textarea-field{resize:vertical;min-height:80px}.maps-preview{margin-top:25px;padding-top:25px;border-top:2px solid #e2e8f0}.maps-preview h3{margin:0 0 15px;font-size:1.1rem;color:#2d3748}.maps-iframe{width:100%;height:400px;border:2px solid #e2e8f0;border-radius:12px}.image-upload-zone{margin-top:20px}.upload-zone{border:2px dashed #cbd5e0;border-radius:12px;padding:40px;text-align:center;transition:all .3s;background:#f7fafc}.spinner{width:40px;height:40px;border:4px solid #e2e8f0;border-top-color:#f5576c;border-radius:50%;animation:spin .8s linear infinite}.image-preview-container{display:flex;flex-direction:column;gap:20px;align-items:center}.plan-masse-preview{max-width:100%;height:auto;border-radius:12px;box-shadow:0 4px 12px #0000001a;border:2px solid #e2e8f0}.btn-delete-image{padding:12px 24px;background:#fed7d7;border:2px solid #fc8181;border-radius:8px;color:#742a2a;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-delete-image:hover{background:#fc8181;color:#fff;transform:translateY(-2px);box-shadow:0 4px 8px #fc81814d}.form-actions{background:#fff;padding:25px 30px;border-radius:12px;box-shadow:0 2px 8px #0000001a;display:flex;justify-content:flex-end;gap:15px}.visite-exterieure-page{min-height:100vh;background:linear-gradient(135deg,#f093fb,#f5576c);padding:20px}.visite-exterieure-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;background:#fff;padding:20px 30px;border-radius:12px;box-shadow:0 2px 8px #0000001a}.header-left{display:flex;align-items:center;gap:20px}.header-left h1{margin:0;font-size:1.8rem;color:#2d3748}.header-right{display:flex;align-items:center;gap:15px}.project-name{font-size:1rem;color:#718096;font-weight:500}.btn-back{padding:10px 20px;background:#e2e8f0;border:none;border-radius:8px;color:#2d3748;font-size:.95rem;cursor:pointer;transition:all .2s;font-weight:500}.btn-back:hover{background:#cbd5e0;transform:translate(-2px)}.message{padding:15px 20px;border-radius:8px;margin-bottom:20px;font-weight:500}.message-success{background:#c6f6d5;color:#22543d;border:1px solid #9ae6b4}.message-error{background:#fed7d7;color:#742a2a;border:1px solid #fc8181}.visite-exterieure-content{display:flex;flex-direction:column;gap:30px}.config-section{background:#fff;padding:30px;border-radius:12px;box-shadow:0 2px 8px #0000001a}.config-section h2{margin:0 0 10px;font-size:1.4rem;color:#2d3748}.section-description{margin:0 0 25px;color:#718096;font-size:.95rem}.mode-selector{display:flex;gap:15px;margin-bottom:30px;padding:5px;background:#f7fafc;border-radius:12px}.mode-btn{flex:1;padding:15px 20px;background:#fff;border:2px solid #e2e8f0;border-radius:8px;color:#4a5568;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.mode-btn:hover{border-color:#cbd5e0}.mode-btn.active{background:linear-gradient(135deg,#f093fb,#f5576c);border-color:#f5576c;color:#fff;box-shadow:0 4px 12px #f5576c4d}.info-box{display:flex;gap:20px;padding:20px;background:#e6fffa;border:2px solid #81e6d9;border-radius:12px;margin-bottom:25px}.info-icon{font-size:2rem;flex-shrink:0}.info-content h3{margin:0 0 10px;font-size:1.1rem;color:#234e52}.info-content ul{margin:0;padding-left:20px;color:#2c7a7b}.info-content li{margin:5px 0;font-size:.9rem}.form-group{margin-bottom:25px}.form-group label{display:block;margin-bottom:8px;font-weight:600;color:#2d3748;font-size:.95rem}.input-field{width:100%;padding:12px 15px;border:2px solid #e2e8f0;border-radius:8px;font-size:.95rem;transition:all .2s;font-family:inherit}.input-field:focus{outline:none;border-color:#f5576c;box-shadow:0 0 0 3px #f5576c1a}.field-hint{display:block;margin-top:6px;font-size:.85rem;color:#a0aec0}.upload-zone{border:2px dashed #cbd5e0;border-radius:12px;padding:40px;text-align:center;transition:all .3s;background:#f7fafc;margin-bottom:25px}.upload-zone:hover{border-color:#f5576c;background:#fff5f7}.file-input{display:none}.upload-label{display:flex;flex-direction:column;align-items:center;gap:10px;cursor:pointer}.upload-icon{font-size:3rem;margin-bottom:10px}.upload-text{font-size:1.1rem;color:#2d3748;font-weight:600}.upload-hint{font-size:.9rem;color:#718096}.uploading-state{display:flex;flex-direction:column;align-items:center;gap:15px}.folder-preview{padding:25px;background:#f7fafc;border:2px solid #e2e8f0;border-radius:12px;margin-bottom:25px;display:flex;justify-content:space-between;align-items:center}.folder-info{display:flex;align-items:center;gap:20px}.folder-icon{font-size:3rem}.folder-info h3{margin:0 0 5px;font-size:1.1rem;color:#2d3748}.folder-path{margin:0;font-size:.9rem;color:#718096;font-family:monospace}.btn-delete-folder{padding:12px 24px;background:#fed7d7;border:2px solid #fc8181;border-radius:8px;color:#742a2a;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-delete-folder:hover{background:#fc8181;color:#fff;transform:translateY(-2px);box-shadow:0 4px 8px #fc81814d}.preview-section{margin-top:30px;padding-top:30px;border-top:2px solid #e2e8f0}.preview-section h3{margin:0 0 15px;font-size:1.1rem;color:#2d3748}.preview-container{position:relative;width:100%;padding-top:56.25%;background:#f7fafc;border-radius:12px;overflow:hidden;border:2px solid #e2e8f0}.preview-iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:none}.form-actions{margin-top:30px;padding-top:25px;border-top:2px solid #e2e8f0;display:flex;justify-content:flex-end}.btn-save{padding:14px 30px;background:linear-gradient(135deg,#f093fb,#f5576c);border:none;border-radius:8px;color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #f5576c4d}.btn-save:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #f5576c66}.btn-save:disabled{opacity:.6;cursor:not-allowed}.tips-section{background:#fff;padding:30px;border-radius:12px;box-shadow:0 2px 8px #0000001a}.tips-section h2{margin:0 0 20px;font-size:1.4rem;color:#2d3748}.tips-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px}.tip-card{padding:20px;background:#f7fafc;border-radius:12px;border:2px solid #e2e8f0;transition:all .3s}.tip-card:hover{border-color:#f5576c;transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.tip-icon{font-size:2rem;margin-bottom:10px}.tip-card h3{margin:0 0 8px;font-size:1.1rem;color:#2d3748}.tip-card p{margin:0;font-size:.9rem;color:#718096;line-height:1.5}.loading{text-align:center;padding:60px 20px;color:#fff;font-size:1.2rem}.orbit-viewer{display:flex;height:100%;width:100%;overflow:hidden;background:var(--bg)}.orbit-sidebar{width:280px;background:var(--surface);border-right:1.5px solid var(--border);color:var(--text);display:flex;flex-direction:column;overflow-y:auto;box-shadow:var(--shadow);flex-shrink:0}.orbit-header{padding:var(--gap-6);border-bottom:1.5px solid var(--border);background:var(--surface)}.btn-back-orbit{background:transparent;color:var(--primary-700);border:1.5px solid var(--border);padding:.625rem 1.25rem;border-radius:var(--btn-radius);cursor:pointer;font-size:.85rem;font-weight:700;transition:all .2s ease;margin-bottom:var(--gap-4);width:100%;display:flex;align-items:center;justify-content:center}.btn-back-orbit:hover{background:var(--primary-600);color:#fff;border-color:var(--primary-600);transform:translateY(-2px);box-shadow:var(--btn-shadow)}.orbit-header h2{margin:0 0 var(--gap-3) 0;font-size:1.35rem;font-weight:800;color:var(--text);letter-spacing:-.02em}.orbit-mode-badge{background:var(--primary-600);padding:.5rem 1rem;border-radius:var(--radius);font-size:.8rem;font-weight:700;text-align:center;color:#fff}.floors-list{padding:var(--gap-6);border-bottom:1.5px solid var(--border)}.floors-list h3{margin:0 0 var(--gap-4) 0;font-size:.8rem;text-transform:uppercase;color:var(--muted);font-weight:800;letter-spacing:.05em}.floor-btn{width:100%;padding:var(--gap-4);background:var(--surface);color:var(--text);border:1.5px solid var(--border);border-radius:var(--radius);text-align:left;font-size:.9rem;margin-bottom:var(--gap-3);transition:all .2s ease;font-weight:600;cursor:pointer}.floor-btn:hover{background:var(--primary-50);color:var(--primary-700);transform:translateY(-2px);border-color:var(--primary-300);box-shadow:var(--shadow-sm)}.floor-btn.active{background:var(--primary-600);border-color:var(--primary-600);color:#fff;box-shadow:var(--shadow);transform:translateY(-2px)}.lot-details-orbit{padding:var(--gap-6);background:var(--surface);border-top:1.5px solid var(--border);margin-top:auto;animation:slideInUp .3s ease;position:relative}.lot-details-orbit h3{margin:0 0 var(--gap-4) 0;font-size:1.15rem;font-weight:800;color:var(--text)}.building-name{margin:0 0 var(--gap-4) 0;padding:var(--gap-2) var(--gap-3);background:var(--primary-50);border-left:3px solid var(--primary-600);font-size:.85rem;font-weight:600;color:var(--primary-700);border-radius:4px}.lot-info p{margin:var(--gap-2) 0;font-size:.9rem;color:var(--text)}.lot-info strong{color:var(--muted);font-weight:600}.status-Disponible{color:var(--success-600);font-weight:700}.status-Vendu{color:var(--danger-500);font-weight:700}.status-Option{color:var(--warning-500);font-weight:700}.btn-close-lot{margin-top:var(--gap-4);width:100%;background:transparent;color:var(--text);border:1.5px solid var(--border);padding:var(--gap-3);border-radius:var(--radius);cursor:pointer;font-size:.9rem;font-weight:600;transition:all .2s ease}.btn-close-lot:hover{background:var(--danger-500);color:#fff;border-color:var(--danger-500)}.orbit-main{flex:1;display:flex;align-items:center;justify-content:center;position:relative;padding:0;background:#fff}.orbit-canvas-container{width:100%;height:100%;display:flex;align-items:center;justify-content:center;cursor:grab;position:relative;background:#fff;border-radius:0;box-shadow:none;overflow:hidden}.orbit-canvas-container:active{cursor:grabbing}.orbit-canvas-container canvas{max-width:100%;max-height:100%;display:block}.orbit-controls{position:absolute;bottom:2rem;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:var(--gap-3);pointer-events:none}.frame-indicator{background:#0f172ad9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;padding:var(--gap-3) var(--gap-6);border-radius:24px;font-size:.9rem;font-weight:700;box-shadow:var(--shadow)}.orbit-hint{background:var(--primary-600);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;padding:var(--gap-2) var(--gap-4);border-radius:20px;font-size:.8rem;font-weight:700;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.05)}}.orbit-loading,.orbit-preloader{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text);gap:var(--gap-4)}.loader,.loader-large{width:48px;height:48px;border:4px solid var(--border);border-top-color:var(--primary-600);border-radius:50%;animation:spin 1s linear infinite}.loader-large{width:64px;height:64px;border-width:5px}.orbit-loading p,.orbit-preloader p{font-size:1rem;font-weight:600;color:var(--muted)}.progress-bar{width:240px;height:8px;background:var(--border);border-radius:999px;overflow:hidden}.progress-fill{height:100%;background:var(--primary-600);transition:width .3s ease;border-radius:999px}.progress-text{font-size:1.25rem;font-weight:800;color:var(--primary-600)}.orbit-error{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--gap-6);padding:var(--gap-6);text-align:center}.orbit-error h1{font-size:2rem;color:var(--text);margin:0}.orbit-error button{background:var(--primary-600);color:#fff;border:none;padding:var(--gap-4) var(--gap-6);border-radius:var(--btn-radius);font-size:.9rem;font-weight:700;cursor:pointer;transition:all .2s ease;box-shadow:var(--btn-shadow)}.orbit-error button:hover{background:var(--primary-700);transform:translateY(-2px)}@keyframes slideInUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@media (max-width: 768px){.orbit-sidebar{width:100%;max-height:40vh}.orbit-viewer{flex-direction:column}.orbit-controls{bottom:1rem}}.orbit-header-bar{display:flex;justify-content:space-between;align-items:center;padding:0;min-height:80px;gap:1rem}.orbit-header-info{display:flex;align-items:center;gap:1rem;flex-shrink:0}.orbit-header-title{font-size:1.5rem;font-weight:800;color:var(--text);margin:0;letter-spacing:-.02em;background:linear-gradient(135deg,#1e3a8a,#3b82f6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.orbit-header-actions{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.orbit-header-actions button{display:flex;align-items:center;gap:.5rem}.orbit-header-actions svg{flex-shrink:0;transition:transform .3s ease}.orbit-header-actions button:hover svg{transform:scale(1.1)}.orbit-content{display:grid;grid-template-columns:280px 1fr;gap:var(--gap-5);max-width:100%;margin:0;padding:var(--gap-5);height:calc(100vh - 140px);overflow:hidden}.orbit-sidebar{display:flex;flex-direction:column;gap:var(--gap-3);overflow-y:auto;padding-right:var(--gap-2);height:100%}.orbit-sidebar::-webkit-scrollbar{width:6px}.orbit-sidebar::-webkit-scrollbar-track{background:var(--bg);border-radius:3px}.orbit-sidebar::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.orbit-sidebar::-webkit-scrollbar-thumb:hover{background:var(--muted)}.orbit-sidebar h2{font-size:1rem;font-weight:600;color:var(--text);text-transform:uppercase;letter-spacing:.05em}.floors-list{display:flex;flex-direction:column;gap:var(--gap-2)}.floor-item{display:flex;justify-content:space-between;align-items:center;padding:var(--gap-3);cursor:pointer;transition:background .2s;border-radius:var(--radius-sm)}.floor-item:hover{background:var(--bg)}.floor-item.active{background:var(--primary-50);font-weight:600}.orbit-main{display:flex;flex-direction:column;gap:var(--gap-5);overflow-y:auto;padding-right:var(--gap-2);height:100%;width:100%}.orbit-main>*{width:100%;max-width:100%}.orbit-main::-webkit-scrollbar{width:6px}.orbit-main::-webkit-scrollbar-track{background:var(--bg);border-radius:3px}.orbit-main::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.orbit-main::-webkit-scrollbar-thumb:hover{background:var(--muted)}.floor-info h2{font-size:1.5rem;font-weight:700;color:var(--text);margin-bottom:var(--gap-3)}.floor-stats{display:flex;gap:var(--gap-6)}.stat-item{display:flex;flex-direction:column;gap:var(--gap-1)}.stat-label{font-size:.75rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}.stat-value{font-size:1.5rem;font-weight:700;color:var(--text)}.message-banner{padding:var(--gap-3) var(--gap-4);border-radius:var(--radius);font-size:.875rem;font-weight:500}.message-banner.success{background:#dcfce7;color:#166534;border-left:4px solid #16a34a}.message-banner.error{background:#fee2e2;color:#991b1b;border-left:4px solid #dc2626}.upload-section h3{font-size:1.25rem;font-weight:600;color:var(--text);margin-bottom:var(--gap-3)}.upload-section{width:100%}.upload-instructions{background:var(--bg);padding:var(--gap-3);border-radius:var(--radius-sm);margin-bottom:var(--gap-4);width:100%;box-sizing:border-box}.upload-instructions p{margin:0 0 var(--gap-2) 0;font-weight:600}.upload-instructions ul{margin:0;padding-left:var(--gap-5)}.upload-instructions li{margin-bottom:var(--gap-1);font-size:.875rem;color:var(--muted)}.upload-zone{border:2px dashed var(--border);border-radius:var(--radius);padding:var(--gap-6);text-align:center;transition:all .2s;width:100%;box-sizing:border-box}.upload-zone:hover{border-color:var(--primary-500);background:var(--primary-50)}.upload-label{display:flex;flex-direction:column;align-items:center;gap:var(--gap-2);cursor:pointer}.upload-label.disabled{cursor:not-allowed;opacity:.6}.upload-icon{font-size:3rem}.upload-prompt span:nth-child(2){font-size:1.125rem;font-weight:600;color:var(--text)}.upload-prompt small{font-size:.875rem;color:var(--muted)}.uploading-state{display:flex;align-items:center;gap:var(--gap-3)}.frames-preview h3{font-size:1.25rem;font-weight:600;color:var(--text);margin-bottom:var(--gap-3)}.frames-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:var(--gap-3)}.frame-thumbnail{position:relative;aspect-ratio:16/9;border-radius:var(--radius-sm);overflow:hidden;background:var(--bg);border:1px solid var(--border)}.frame-number{position:absolute;bottom:var(--gap-1);left:var(--gap-1);background:#000000b3;color:#fff;padding:var(--gap-1) var(--gap-2);border-radius:var(--radius-sm);font-size:.75rem}.frame-thumbnail.more{display:flex;align-items:center;justify-content:center;font-weight:600;color:var(--muted)}.orbit-actions{display:flex;gap:var(--gap-3);flex-wrap:wrap}.loading-state,.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:var(--gap-4)}.floor-info-card{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:2rem;border-radius:12px;margin-bottom:2rem;width:100%;max-width:100%;box-sizing:border-box}.floor-info-card h2{margin:0 0 1.5rem;font-size:2rem;font-weight:600}.floor-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1.5rem}.stat{display:flex;flex-direction:column;gap:.5rem}.stat-label{font-size:.875rem;opacity:.9;font-weight:500}.stat-value{font-size:1.75rem;font-weight:700}.stat-badge{padding:.5rem 1rem;border-radius:6px;font-size:.875rem;font-weight:600;display:inline-block;text-align:center}.stat-badge.success{background:#48bb78}.stat-badge.warning{background:#ed8936}.message-orbit{padding:1rem 1.5rem;border-radius:8px;margin-bottom:2rem;font-weight:500;text-align:center;animation:slideIn .3s ease}.message-orbit.success{background:#c6f6d5;color:#22543d;border:2px solid #9ae6b4}.message-orbit.error{background:#fed7d7;color:#742a2a;border:2px solid #fc8181}.upload-section{background:#f7fafc;padding:2rem;border-radius:12px;margin-bottom:2rem}.upload-section h3{margin:0 0 1.5rem;font-size:1.5rem;color:#2d3748;font-weight:600}.upload-instructions{background:#fff;padding:1.5rem;border-radius:8px;margin-bottom:1.5rem;border:2px solid #e2e8f0}.upload-instructions p{margin:0 0 .75rem;color:#4a5568;font-weight:600}.upload-instructions ul{margin:0;padding-left:1.5rem;color:#718096}.upload-instructions li{margin:.5rem 0}.upload-instructions code{background:#edf2f7;padding:.25rem .5rem;border-radius:4px;font-family:Monaco,monospace;color:#667eea}.upload-zone{position:relative}.upload-label{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;border:3px dashed #cbd5e0;border-radius:12px;background:#fff;cursor:pointer;transition:all .3s ease;gap:1rem}.upload-label:hover:not(.disabled){border-color:#667eea;background:#f7fafc;transform:translateY(-2px)}.upload-label.disabled{opacity:.6;cursor:not-allowed}.upload-icon{font-size:4rem}.upload-label span{font-size:1.1rem;font-weight:600;color:#2d3748}.upload-label small{font-size:.875rem;color:#718096}.upload-spinner{border:4px solid #e2e8f0;border-top:4px solid #667eea;border-radius:50%;width:50px;height:50px;animation:spin 1s linear infinite}.upload-progress{margin-top:1rem;height:8px;background:#e2e8f0;border-radius:10px;overflow:hidden}.upload-progress-bar{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);transition:width .3s ease}.frames-preview-section{background:#f7fafc;padding:2rem;border-radius:12px;margin-bottom:2rem}.frames-preview-section h3{margin:0 0 1.5rem;font-size:1.5rem;color:#2d3748;font-weight:600}.frames-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem}.frame-thumbnail{position:relative;aspect-ratio:16/9;border-radius:8px;overflow:hidden;background:#fff;border:2px solid #e2e8f0;display:flex;align-items:center;justify-content:center}.frame-thumbnail img{width:100%;height:100%;object-fit:cover}.frame-number{position:absolute;bottom:0;left:0;right:0;background:#000c;color:#fff;padding:.5rem;font-size:.75rem;font-weight:600;text-align:center}.frame-thumbnail.more{background:#edf2f7;color:#4a5568;font-size:1.5rem;font-weight:700}.actions-section{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.btn-edit-lots,.btn-preview-orbit,.btn-lots-3dsmax,.btn-delete-frames{padding:1rem 2rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;border:none}.btn-edit-lots{background:linear-gradient(135deg,#48bb78,#38a169);color:#fff;box-shadow:0 4px 15px #48bb7866}.btn-edit-lots:hover{transform:translateY(-2px);box-shadow:0 6px 20px #48bb7880}.btn-preview-orbit{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 15px #667eea66}.btn-preview-orbit:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea80}.btn-lots-3dsmax{background:linear-gradient(135deg,#ed8936,#dd6b20);color:#fff;box-shadow:0 4px 15px #ed893666}.btn-lots-3dsmax:hover{transform:translateY(-2px);box-shadow:0 6px 20px #ed893680}.btn-delete-frames{background:#fc8181;color:#fff}.btn-delete-frames:hover{background:#f56565;transform:translateY(-2px)}.no-floor-selected{display:flex;align-items:center;justify-content:center;min-height:400px;font-size:1.25rem;color:#718096}.orbit-editor-loading,.orbit-editor-error{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.orbit-editor-error h1{font-size:2.5rem;margin-bottom:1.5rem}.orbit-editor-error button{background:#fff;color:#667eea;border:none;padding:1rem 2rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.loader{border:4px solid rgba(255,255,255,.3);border-top:4px solid white;border-radius:50%;width:60px;height:60px;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes slideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@media (max-width: 1024px){.orbit-content{grid-template-columns:1fr;height:auto;overflow:visible}.orbit-sidebar{overflow-y:visible;height:auto;max-height:300px;overflow-y:auto}.orbit-main{overflow-y:visible;height:auto}.floors-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--gap-2)}}@media (max-width: 768px){.orbit-content{padding:var(--gap-4)}.orbit-header h1{font-size:1.5rem}.floor-stats{flex-direction:column;gap:var(--gap-3)}}.orbit-building-editor{display:grid;grid-template-columns:300px 1fr 350px;height:100vh;background:#0f172a;color:#e2e8f0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.sidebar-left{background:#1e293b;border-right:2px solid #334155;display:flex;flex-direction:column;overflow:hidden}.sidebar-header{padding:20px;background:#0f172a;border-bottom:1px solid #334155;display:flex;justify-content:space-between;align-items:center}.sidebar-header h3{margin:0;font-size:18px;font-weight:600}.btn-add{background:#3b82f6;color:#fff;border:none;padding:8px 12px;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;transition:all .2s}.btn-add:hover{background:#2563eb;transform:translateY(-1px)}.buildings-tree{flex:1;overflow-y:auto;padding:10px}.buildings-tree::-webkit-scrollbar{width:8px}.buildings-tree::-webkit-scrollbar-track{background:#1e293b}.buildings-tree::-webkit-scrollbar-thumb{background:#475569;border-radius:4px}.building-item{margin-bottom:15px}.building-header{padding:12px;background:#334155;border-radius:8px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:all .2s;border:2px solid transparent;color:#fff}.building-header:hover{background:#475569}.building-header.selected{background:#3b82f6;border-color:#60a5fa}.floor-item{margin-left:20px;margin-top:8px}.floor-header{padding:10px;background:#475569;border-radius:6px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:all .2s;border:2px solid transparent;color:#fff}.floor-header:hover{background:#64748b}.floor-header.selected{background:#8b5cf6;border-color:#a78bfa}.lot-item{padding:8px 12px;margin:4px 0 4px 40px;background:#64748b;border-radius:4px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:all .2s;font-size:13px;border:2px solid transparent;color:#fff}.lot-item:hover{background:#94a3b8}.lot-item.selected{background:#fbbf24;color:#0f172a;border-color:#fcd34d;font-weight:600}.actions{display:flex;gap:5px}.btn-icon{background:transparent;border:none;cursor:pointer;font-size:14px;padding:4px;border-radius:4px;transition:all .2s}.btn-icon:hover{background:#ffffff1a;transform:scale(1.1)}.canvas-container{background:#0f172a;display:flex;flex-direction:column;position:relative;overflow:hidden}.canvas-toolbar{background:#1e293b;padding:15px 20px;border-bottom:1px solid #334155;display:flex;justify-content:space-between;align-items:center;gap:20px}.frame-controls{display:flex;align-items:center;gap:10px;flex:1}.frame-controls button{background:#3b82f6;color:#fff;border:none;padding:8px 12px;border-radius:6px;cursor:pointer;font-size:14px;transition:all .2s}.frame-controls button:hover{background:#2563eb}.frame-controls span{font-weight:600;min-width:130px;text-align:center}.frame-controls input[type=range]{flex:1;max-width:400px}.zoom-controls{display:flex;align-items:center;gap:10px}.zoom-controls button{background:#475569;color:#fff;border:none;padding:8px 12px;border-radius:6px;cursor:pointer;font-size:14px;transition:all .2s;min-width:50px}.zoom-controls button:hover{background:#64748b}.zoom-controls span{min-width:60px;text-align:center;font-weight:600}canvas{display:block;max-width:100%;max-height:calc(100vh - 80px);margin:auto;background:#000}.loading{display:flex;align-items:center;justify-content:center;height:100%;font-size:18px;color:#94a3b8}.projection-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;z-index:1000}.spinner{width:60px;height:60px;border:4px solid #334155;border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite}.projection-overlay p{font-size:18px;color:#e2e8f0}.sidebar-right{background:#1e293b;border-left:2px solid #334155;display:flex;flex-direction:column;overflow-y:auto}.sidebar-right::-webkit-scrollbar{width:8px}.sidebar-right::-webkit-scrollbar-track{background:#1e293b}.sidebar-right::-webkit-scrollbar-thumb{background:#475569;border-radius:4px}.lot-properties{padding:20px}.lot-properties h4{margin:0 0 20px;font-size:24px;color:#fbbf24;border-bottom:2px solid #fbbf24;padding-bottom:10px}.property{margin-bottom:15px;padding:12px;background:#0f172a;border-radius:6px;border-left:3px solid #3b82f6}.property label{display:block;font-size:12px;color:#94a3b8;margin-bottom:5px;text-transform:uppercase;letter-spacing:.5px}.property span{display:block;font-size:16px;font-weight:600;color:#e2e8f0}.status{display:inline-block;padding:4px 12px;border-radius:12px;font-size:13px;font-weight:600}.status-disponible{background:#10b981;color:#fff}.status-réservé{background:#f59e0b;color:#fff}.status-vendu{background:#ef4444;color:#fff}.lot-form{padding:20px}.lot-form h4{margin:0 0 15px;font-size:20px}.instructions{background:#0f172a;padding:15px;border-radius:8px;border-left:4px solid #3b82f6;font-size:13px;line-height:1.6;margin-bottom:20px;color:#94a3b8}.lot-form label{display:block;margin-bottom:15px;font-size:13px;font-weight:600;color:#cbd5e1}.lot-form input,.lot-form select{width:100%;margin-top:6px;padding:10px;background:#0f172a;border:1px solid #475569;border-radius:6px;color:#e2e8f0;font-size:14px;transition:all .2s}.lot-form input:focus,.lot-form select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.checkbox{display:flex!important;align-items:center;gap:10px;cursor:pointer}.checkbox input[type=checkbox]{width:auto;margin:0;cursor:pointer;transform:scale(1.3)}.btn-save{margin:20px;padding:15px;background:#10b981;color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s}.btn-save:hover{background:#059669;transform:translateY(-2px);box-shadow:0 4px 12px #10b9814d}@media (max-width: 1400px){.orbit-building-editor{grid-template-columns:250px 1fr 300px}}@media (max-width: 1024px){.orbit-building-editor{grid-template-columns:1fr;grid-template-rows:auto 1fr}.sidebar-left,.sidebar-right{border:none;border-bottom:2px solid #334155}}.orbit-lots-editor{min-height:100vh;background:linear-gradient(135deg,#1a202c,#2d3748);display:flex;flex-direction:column}.orbit-lots-header{background:#0000004d;color:#fff;padding:2rem;text-align:center;border-bottom:2px solid rgba(255,255,255,.1)}.orbit-lots-header .btn-back{background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2);padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-size:.95rem;font-weight:500;transition:all .3s ease;margin-bottom:1.5rem}.orbit-lots-header .btn-back:hover{background:#fff3;transform:translate(-3px)}.orbit-lots-header h1{margin:0 0 .5rem;font-size:2.5rem;font-weight:700}.orbit-lots-header p{margin:0;font-size:1.1rem;opacity:.9}.orbit-lots-content{display:flex;flex:1}.floors-sidebar{width:250px;background:#2d3748;color:#fff;padding:2rem 1.5rem;border-right:2px solid rgba(255,255,255,.1);overflow-y:auto}.floors-sidebar h3{margin:0 0 1.5rem;font-size:1.1rem;color:#a0aec0;text-transform:uppercase;letter-spacing:.5px;font-weight:600}.floor-btn{width:100%;background:#ffffff0d;color:#fff;border:2px solid rgba(255,255,255,.1);padding:.875rem 1rem;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:500;transition:all .3s ease;margin-bottom:.75rem;text-align:left;display:flex;justify-content:space-between;align-items:center}.floor-btn:hover:not(.disabled){background:#ffffff1a;border-color:#ffffff4d;transform:translate(5px)}.floor-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:transparent;box-shadow:0 4px 15px #667eea66}.floor-btn.disabled{opacity:.5;cursor:not-allowed}.no-orbit{font-size:.875rem}.orbit-lots-main{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem}.no-orbit-frames{text-align:center;color:#fff;max-width:500px}.no-orbit-frames h2{font-size:2rem;margin:0 0 1rem}.no-orbit-frames p{font-size:1.1rem;margin:0 0 2rem;opacity:.9}.btn-upload-frames{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:1rem 2rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-upload-frames:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea80}.orbit-lots-editor-loading,.orbit-lots-editor-error{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a202c,#2d3748);color:#fff}.loader{border:4px solid rgba(255,255,255,.2);border-top:4px solid white;border-radius:50%;width:60px;height:60px;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.orbit-lots-viewer{display:flex;flex-direction:column;height:100vh;background:#1a1a1a;color:#fff}.viewer-header{display:flex;align-items:center;justify-content:space-between;padding:15px 30px;background:#2a2a2a;border-bottom:2px solid #3a3a3a}.viewer-header h1{margin:0;font-size:24px}.btn-back,.btn-refresh{padding:10px 20px;background:#4a4a4a;border:none;color:#fff;cursor:pointer;border-radius:5px;font-size:14px}.btn-back:hover,.btn-refresh:hover{background:#5a5a5a}.viewer-container{display:flex;flex:1;overflow:hidden}.sidebar-left,.sidebar-right{width:300px;background:#2a2a2a;border-right:1px solid #3a3a3a;overflow-y:auto;padding:20px}.sidebar-right{border-left:1px solid #3a3a3a;border-right:none}.section{margin-bottom:30px}.section h3{margin:0 0 15px;font-size:16px;color:#aaa;border-bottom:1px solid #3a3a3a;padding-bottom:10px}.buildings-list,.floors-list,.lots-list{display:flex;flex-direction:column;gap:8px}.building-item,.floor-item,.lot-item{padding:12px;background:#3a3a3a;border-radius:5px;cursor:pointer;transition:all .2s}.building-item:hover,.floor-item:hover,.lot-item:hover{background:#4a4a4a}.building-item.selected,.floor-item.selected{background:#06c;border-left:4px solid #0088ff}.lot-item.highlighted{background:#060;border-left:4px solid #00ff00}.building-item .count,.floor-item .count{display:block;font-size:12px;color:#aaa;margin-top:5px}.lot-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:5px}.lot-type{background:#4a4a4a;padding:3px 8px;border-radius:3px;font-size:11px}.lot-info{font-size:13px;color:#aaa}.canvas-container{flex:1;position:relative;overflow:hidden;background:#000}.main-canvas{display:block;cursor:grab}.main-canvas:active{cursor:grabbing}.canvas-loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#000c;padding:20px 40px;border-radius:10px;font-size:18px}.viewer-controls{display:flex;justify-content:space-between;align-items:center;padding:15px 30px;background:#2a2a2a;border-top:2px solid #3a3a3a}.frame-controls,.view-controls{display:flex;align-items:center;gap:15px}.frame-controls button,.view-controls button{padding:10px 20px;background:#4a4a4a;border:none;color:#fff;cursor:pointer;border-radius:5px;font-size:14px}.frame-controls button:hover,.view-controls button:hover{background:#5a5a5a}.frame-info,.zoom-info{font-size:14px;color:#aaa;min-width:120px;text-align:center}.loading,.error{display:flex;justify-content:center;align-items:center;height:100vh;font-size:20px}.error{flex-direction:column;gap:20px}.error button{padding:10px 30px;background:#06c;border:none;color:#fff;cursor:pointer;border-radius:5px;font-size:16px}.error button:hover{background:#07d}.correction-controls{display:flex;gap:30px;padding:15px;background:#2a2a2a;border-radius:8px;margin-top:10px}.correction-group{display:flex;align-items:center;gap:10px;flex:1}.correction-group label{font-size:13px;color:#aaa;min-width:80px}.correction-group input[type=range]{flex:1;height:6px;background:#3a3a3a;border-radius:3px;outline:none}.correction-group input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;background:#06c;border-radius:50%;cursor:pointer}.correction-group input[type=range]::-moz-range-thumb{width:16px;height:16px;background:#06c;border-radius:50%;cursor:pointer;border:none}.correction-group span{min-width:60px;text-align:right;font-size:13px;color:#fff;font-weight:600}.correction-group button{padding:5px 15px;background:#4a4a4a;border:none;color:#fff;cursor:pointer;border-radius:4px;font-size:12px}.correction-group button:hover{background:#5a5a5a}.perspectives-3d{width:100%;height:100%;display:flex;flex-direction:column;background:#000;overflow:hidden}.perspective-viewer{flex:1;position:relative;display:flex;align-items:center;justify-content:center;background:#000;overflow:hidden}.perspective-image{max-width:100%;max-height:100%;object-fit:contain;animation:fadeIn .3s ease}.perspective-controls{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(0,0,0,.8),transparent);padding:2rem;display:flex;align-items:center;justify-content:space-between;gap:2rem}.control-btn{width:80px;height:80px;background:#fff3;border:2px solid rgba(255,255,255,.3);border-radius:50%;color:#fff;font-size:2.5rem;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;flex-shrink:0;position:relative}.control-btn:before{content:"";position:absolute;top:-20px;left:-20px;right:-20px;bottom:-20px;cursor:pointer}.control-btn:hover{background:#ffffff4d;transform:scale(1.05);border-color:#ffffff80}.control-btn:active{transform:scale(.95)}.perspective-info{flex:1;text-align:center;color:#fff}.perspective-info h3{font-size:1.5rem;margin:0 0 .5rem;font-weight:600}.perspective-info p{font-size:.95rem;margin:0 0 .5rem;opacity:.9}.image-counter{display:inline-block;padding:.4rem 1rem;background:#fff3;border-radius:20px;font-size:.9rem;font-weight:500}.perspective-thumbnails{background:#1a1a1a;padding:1.5rem;border-top:1px solid #333;max-height:200px;overflow-y:auto}.perspective-thumbnails h4{color:#fff;margin:0 0 1rem;font-size:1rem;font-weight:500}.thumbnails-grid{display:flex;gap:1rem;overflow-x:auto;padding-bottom:.5rem}.thumbnail{flex-shrink:0;width:120px;cursor:pointer;border:3px solid transparent;border-radius:8px;overflow:hidden;transition:all .3s ease;position:relative}.thumbnail:hover{border-color:#3b82f6;transform:translateY(-2px)}.thumbnail.active{border-color:#3b82f6;box-shadow:0 0 20px #3b82f680}.thumbnail img{width:100%;height:80px;object-fit:cover;display:block}.thumbnail-label{display:block;padding:.5rem;background:#2a2a2a;color:#fff;font-size:.75rem;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.thumbnail.active .thumbnail-label{background:#3b82f6}.perspectives-empty{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f9fafb,#fff)}.empty-state p{font-size:1rem;color:#6b7280;line-height:1.6}.perspective-help{background:#1a1a1a;padding:.75rem;text-align:center;border-top:1px solid #333}.perspective-help p{margin:0;color:#9ca3af;font-size:.875rem}@media (max-width: 768px){.perspective-controls{padding:1rem;gap:1rem}.control-btn{width:40px;height:40px;font-size:1.5rem}.perspective-info h3{font-size:1.1rem}.perspective-info p{font-size:.85rem}.thumbnails-grid{gap:.5rem}.thumbnail{width:100px}.thumbnail img{height:60px}}.thumbnails-grid::-webkit-scrollbar{height:8px}.thumbnails-grid::-webkit-scrollbar-track{background:#2a2a2a;border-radius:4px}.thumbnails-grid::-webkit-scrollbar-thumb{background:#3b82f6;border-radius:4px}.thumbnails-grid::-webkit-scrollbar-thumb:hover{background:#2563eb}.visites-immersives{width:100%;height:100%;display:flex;background:#f5f5f5}.visite-viewer{flex:1;display:flex;flex-direction:column;background:#000}.viewer-header{background:linear-gradient(135deg,#1e3a8a,#3b82f6);color:#fff;padding:1rem 1.5rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 8px #0003}.visite-title h3{margin:0;font-size:1.25rem;font-weight:600}.visite-title p{margin:.25rem 0 0;font-size:.9rem;opacity:.9}.btn-close-viewer{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;padding:.6rem 1.2rem;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .3s ease}.btn-close-viewer:hover{background:#ffffff4d;transform:translateY(-1px)}.btn-external-link{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;padding:.6rem 1.2rem;border-radius:6px;font-size:.9rem;font-weight:500;text-decoration:none;transition:all .3s ease}.btn-external-link:hover{background:#ffffff4d;transform:translateY(-1px)}.visite-iframe{flex:1;width:100%;border:none;background:#000}.visites-sidebar{width:350px;background:#fff;border-left:1px solid #e5e7eb;display:flex;flex-direction:column;overflow:hidden}.sidebar-header{padding:1.5rem;border-bottom:2px solid #e5e7eb}.sidebar-header h2{margin:0 0 .5rem;font-size:1.5rem;color:#1f2937}.visites-count{margin:0;font-size:.9rem;color:#6b7280}.visites-filters{padding:1rem 1.5rem;background:#f9fafb;border-bottom:1px solid #e5e7eb}.filter-group{margin-bottom:1rem}.filter-group:last-child{margin-bottom:0}.filter-group label{display:block;margin-bottom:.5rem;font-size:.875rem;font-weight:500;color:#374151}.filter-group select{width:100%;padding:.6rem;border:1px solid #d1d5db;border-radius:6px;font-size:.9rem;background:#fff;cursor:pointer;transition:border-color .3s ease}.filter-group select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.visites-list{flex:1;overflow-y:auto;padding:1rem}.visite-card{display:flex;align-items:center;gap:1rem;padding:1rem;background:#fff;border:2px solid #e5e7eb;border-radius:8px;margin-bottom:.75rem;cursor:pointer;transition:all .3s ease}.visite-thumb-container{position:relative;width:70px;height:70px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.visite-thumb{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;border-radius:8px;border:2px solid #3b82f6;box-shadow:0 2px 6px #00000026;animation:fadeIn .25s ease}.visite-thumb-placeholder,.visite-thumb-fallback{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#eff6ff,#dbeafe);border-radius:8px;border:2px solid #3b82f6;box-shadow:0 2px 6px #00000026}.visite-thumb+.visite-icon{position:relative;background:#0000008c;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);border:2px solid rgba(255,255,255,.25)}.visite-card:hover{border-color:#3b82f6;transform:translate(4px);box-shadow:0 2px 8px #3b82f61a}.visite-card.active{border-color:#3b82f6;background:#eff6ff;box-shadow:0 2px 8px #3b82f633}.visite-icon{flex-shrink:0;width:50px;height:50px;background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1.5rem}.visite-card.active .visite-icon{animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.visite-info{flex:1}.visite-info h4{margin:0 0 .25rem;font-size:1.1rem;color:#1f2937;font-weight:600}.visite-type{margin:0 0 .25rem;font-size:.9rem;color:#3b82f6;font-weight:500}.visite-details{margin:0 0 .25rem;font-size:.85rem;color:#6b7280}.visite-surface{margin:0;font-size:.85rem;color:#9ca3af}.visite-action{flex-shrink:0}.action-icon{display:inline-block;width:30px;height:30px;background:#3b82f6;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem}.visite-card.active .action-icon{background:#2563eb}.visites-empty{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f9fafb,#fff)}.empty-state p{font-size:1rem;color:#6b7280;line-height:1.6;margin-bottom:1rem}.empty-state .info-text{font-size:.9rem;color:#9ca3af;font-style:italic}.no-results{text-align:center;padding:2rem;color:#6b7280}@media (max-width: 1024px){.visites-sidebar{width:300px}}@media (max-width: 768px){.visites-immersives{flex-direction:column}.visite-viewer{height:60vh}.visites-sidebar{width:100%;height:40vh;border-left:none;border-top:1px solid #e5e7eb}.sidebar-header{padding:1rem}.visites-filters{padding:.75rem 1rem}.visites-list,.visite-card{padding:.75rem}}.visites-list::-webkit-scrollbar{width:8px}.visites-list::-webkit-scrollbar-track{background:#f3f4f6}.visites-list::-webkit-scrollbar-thumb{background:#3b82f6;border-radius:4px}.visites-list::-webkit-scrollbar-thumb:hover{background:#2563eb}.plan-masse{width:100%;height:100%;display:flex;flex-direction:column;background:#f5f5f5}.plan-masse-controls{background:#fff;padding:1rem 2rem;border-bottom:2px solid #e5e7eb;box-shadow:0 2px 4px #0000000d}.control-group label{display:block;margin-bottom:.75rem;font-size:.9rem;font-weight:500;color:#374151}.mode-selector{display:flex;gap:.75rem}.mode-btn{flex:1;padding:.75rem 1.5rem;background:#fff;border:2px solid #e5e7eb;border-radius:8px;cursor:pointer;font-size:.95rem;font-weight:500;color:#374151;transition:all .3s ease}.mode-btn:hover{border-color:#3b82f6;background:#f0f9ff}.mode-btn.active{border-color:#3b82f6;background:#eff6ff;color:#2563eb}.plan-masse-content{flex:1;position:relative;overflow:hidden}.google-maps-iframe{width:100%;height:100%;border:none}.plan-masse-image-container{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#1a1a1a;position:relative;overflow:auto}.plan-masse-image{max-width:100%;max-height:100%;object-fit:contain;display:block;margin:auto}.image-controls{position:absolute;bottom:2rem;right:2rem;z-index:10}.btn-zoom{background:#fffffff2;border:2px solid #e5e7eb;padding:.75rem 1.25rem;border-radius:8px;cursor:pointer;font-size:.9rem;font-weight:500;color:#374151;box-shadow:0 4px 12px #0003;transition:all .3s ease}.btn-zoom:hover{background:#fff;border-color:#3b82f6;color:#2563eb;transform:translateY(-2px);box-shadow:0 6px 16px #0000004d}.plan-masse-info{background:#fff;padding:1.5rem 2rem;border-top:1px solid #e5e7eb;box-shadow:0 -2px 4px #0000000d}.info-card h3{margin:0 0 .75rem;font-size:1.5rem;color:#1f2937;font-weight:600}.info-card .location{margin:0 0 .5rem;font-size:1rem;color:#3b82f6;font-weight:500}.info-card .address{margin:0;font-size:.95rem;color:#6b7280;line-height:1.6}.plan-masse-empty,.plan-masse-error{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f9fafb,#fff)}.empty-state{text-align:center;padding:3rem;max-width:500px}.empty-icon{font-size:4rem;display:block;margin-bottom:1.5rem;opacity:.7}.empty-state h2{font-size:1.75rem;color:#1f2937;margin-bottom:1rem}.empty-state p{font-size:1rem;color:#6b7280;line-height:1.6;margin-bottom:1.5rem}.info-box{background:#f0f9ff;border:2px solid #bfdbfe;border-radius:8px;padding:1.5rem;text-align:left}.info-box p{margin:0 0 .75rem;color:#1e40af;font-weight:500}.info-box ul{margin:0;padding-left:1.5rem;color:#374151}.info-box li{margin-bottom:.5rem;line-height:1.6}.plan-masse-error{background:#fef2f2}.plan-masse-error p{color:#dc2626;font-size:1.1rem;font-weight:500}@media (max-width: 768px){.plan-masse-controls{padding:1rem}.mode-selector{flex-direction:column;gap:.5rem}.mode-btn{padding:.6rem 1rem;font-size:.875rem}.plan-masse-info{padding:1rem}.info-card h3{font-size:1.25rem}.image-controls{bottom:1rem;right:1rem}.btn-zoom{padding:.6rem 1rem;font-size:.85rem}.empty-state{padding:2rem 1rem}.empty-icon{font-size:3rem}.empty-state h2{font-size:1.5rem}.info-box{padding:1rem}}.plan-masse-content>*{animation:fadeIn .5s ease}.client-portal{width:100%;height:100vh;display:flex;flex-direction:column;background-color:var(--bg);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;overflow:hidden}@media (max-width: 768px) and (orientation: landscape){.client-portal-nav-wrapper{padding:0 .75rem;min-height:56px;top:0!important;opacity:1!important;pointer-events:auto!important}.client-portal-nav{gap:.25rem;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none}.client-portal-nav::-webkit-scrollbar{display:none}.nav-item{padding:.625rem .75rem;font-size:.8rem;flex-shrink:0}.nav-icon{font-size:1rem}.nav-label{display:none}.nav-item.active:after{display:none}.rotate-hint-overlay,.nav-reveal-hint{display:none!important}}@media (max-width: 768px) and (orientation: portrait){.client-portal-nav-wrapper{top:auto!important;bottom:0!important;left:0;right:0;opacity:1!important;pointer-events:auto!important;border-top:1px solid rgba(229,231,235,.8);border-bottom:none;box-shadow:0 -4px 12px #00000014;padding:.5rem;min-height:64px}.client-portal-nav{gap:.5rem;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:.25rem 0}.client-portal-nav::-webkit-scrollbar{display:none}.nav-item{padding:.75rem 1rem;min-width:60px;flex-shrink:0;flex-direction:column;gap:.25rem}.nav-icon{font-size:1.5rem}.nav-label{display:block;font-size:.7rem;white-space:nowrap}.nav-item.active:after{display:none}.client-portal-content{padding-bottom:80px}.nav-reveal-hint{display:none!important}}@media (max-width: 768px){.desktop-only{display:none!important}.portal-welcome{padding:1.5rem 1rem}.portal-welcome h2{font-size:1.75rem}.portal-welcome p{font-size:1rem}}@media (max-width: 480px){.portal-welcome{padding:1.25rem 1rem;border-radius:16px}.portal-welcome h2{font-size:1.5rem}.portal-welcome p{font-size:.95rem}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.96) translateY(10px);filter:blur(4px)}to{opacity:1;transform:scale(1) translateY(0);filter:blur(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes fadeOutScale{0%{opacity:1;transform:scale(1) translateY(0)}to{opacity:0;transform:scale(.96) translateY(-10px)}}@keyframes slideInRight{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}@keyframes slideOutLeft{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(-30px)}}.client-portal-header{background:var(--surface);color:var(--text);padding:var(--gap-4) var(--gap-6);display:flex;justify-content:space-between;align-items:center;border-bottom:1.5px solid var(--border);position:relative;z-index:5;flex-shrink:0;box-sizing:border-box;min-height:72px;box-shadow:0 1px 3px #0000000f}.header-left{display:flex;align-items:center;gap:var(--gap-4);flex:1}.client-logo{width:48px;height:48px;object-fit:contain;background:var(--surface-2);border-radius:var(--radius);padding:6px;box-shadow:var(--shadow-sm);flex-shrink:0;border:1.5px solid var(--border)}.client-logo-placeholder{width:48px;height:48px;background:var(--primary-100);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm);flex-shrink:0;border:1.5px solid var(--primary-200)}.logo-initials{font-size:18px;font-weight:800;color:var(--primary-700)}.project-info{display:flex;flex-direction:row;align-items:center;gap:1.5rem;min-width:0;flex:1}.project-title{font-size:1.25rem;font-weight:800;margin:0;line-height:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text);letter-spacing:-.02em}.project-location{font-size:.9rem;margin:0;font-weight:500;line-height:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--muted);display:flex;align-items:center;gap:.35rem}.project-location:before{content:"📍";font-size:.85rem}.header-right{display:flex;gap:var(--gap-3);align-items:center}.btn-search{background:var(--surface-2);color:var(--text);border:1.5px solid var(--border)}.btn-search:hover{background:var(--primary-50);border-color:var(--primary-300);color:var(--primary-700);transform:translateY(-1px)}.client-portal-nav-wrapper{display:flex;align-items:stretch;background:#ffffffbf;backdrop-filter:blur(24px) saturate(180%);-webkit-backdrop-filter:blur(24px) saturate(180%);border-bottom:1px solid rgba(229,231,235,.8);box-shadow:0 4px 24px #00000014,0 0 1px #ffffff80 inset;position:fixed;top:-100px;left:0;right:0;z-index:1000;flex-shrink:0;padding:0 1.5rem;transition:top .5s cubic-bezier(.34,1.56,.64,1),opacity .4s ease,transform .3s ease;opacity:0;min-height:64px;max-height:72px;pointer-events:none}.client-portal-nav-wrapper.visible{top:0;opacity:1;pointer-events:auto;animation:slideDownNav .5s cubic-bezier(.34,1.56,.64,1) forwards}@keyframes slideDownNav{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}.view-container{animation:fadeInScale .4s cubic-bezier(.34,1.56,.64,1) forwards;will-change:transform,opacity}.view-container.transitioning{animation:fadeOutScale .3s ease-out forwards;pointer-events:none}.view-container.active{animation:fadeInScale .4s cubic-bezier(.34,1.56,.64,1) forwards}.client-portal:before{content:"";position:fixed;top:0;left:0;right:0;height:60px;z-index:999;pointer-events:auto;cursor:pointer}.portal-welcome{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:linear-gradient(135deg,#000000d9,#1e293be6);backdrop-filter:blur(20px) saturate(150%);-webkit-backdrop-filter:blur(20px) saturate(150%);color:#fff;padding:3rem 4.5rem;border-radius:28px;text-align:center;z-index:2000;animation:fadeInOutWelcome 5s ease forwards;pointer-events:none;border:2px solid rgba(59,130,246,.4);box-shadow:0 30px 90px #000000b3,0 0 1px #ffffff4d inset,0 0 40px #3b82f633}.portal-welcome h2{margin:0 0 1rem;font-size:2rem;font-weight:800;background:linear-gradient(135deg,#60a5fa,#3b82f6);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.portal-welcome p{margin:.75rem 0;font-size:1.125rem;opacity:.95}.portal-welcome .hint{margin-top:1.5rem;font-size:.95rem;opacity:.7;font-style:italic}.rotate-hint-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000e6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .3s ease-out}.rotate-hint-content{text-align:center;color:#fff;padding:2rem}.rotate-icon{width:100px;height:100px;margin:0 auto 1.5rem;animation:rotatePhone 2s ease-in-out infinite}.rotate-icon svg{width:100%;height:100%;color:#3b82f6;filter:drop-shadow(0 0 20px rgba(59,130,246,.5))}.rotate-hint-content p{font-size:1.25rem;font-weight:600;margin:.5rem 0;color:#fff}.rotate-hint-sub{font-size:1rem!important;opacity:.7;font-weight:400!important}@keyframes rotatePhone{0%,to{transform:rotate(0)}25%{transform:rotate(-15deg)}75%{transform:rotate(15deg)}}@keyframes fadeInOutWelcome{0%{opacity:0;transform:translate(-50%,-50%) scale(.95)}12%{opacity:1;transform:translate(-50%,-50%) scale(1)}88%{opacity:1;transform:translate(-50%,-50%) scale(1)}to{opacity:0;transform:translate(-50%,-50%) scale(.95);pointer-events:none;display:none}}.nav-reveal-hint{position:fixed;top:12px;left:50%;transform:translate(-50%);display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 20px;background:linear-gradient(135deg,#3b82f6eb,#6366f1eb);border-radius:50px;z-index:998;opacity:.7;transition:all .5s cubic-bezier(.34,1.56,.64,1);pointer-events:auto;cursor:pointer;box-shadow:0 6px 24px #3b82f659,0 0 1px #ffffff80 inset;animation:gentleBounceDown 3s ease-in-out infinite,pulseGlow 2s ease-in-out infinite alternate;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.nav-reveal-hint:hover{opacity:1;transform:translate(-50%) scale(1.08);box-shadow:0 8px 32px #3b82f680,0 0 2px #fffc inset;animation:gentleBounceDown 3s ease-in-out infinite}@keyframes pulseGlow{0%{box-shadow:0 6px 24px #3b82f659,0 0 1px #ffffff80 inset}to{box-shadow:0 6px 28px #3b82f680,0 0 2px #ffffffb3 inset}}.nav-reveal-hint:before{content:"▼";font-size:16px;color:#fff;opacity:.95}.nav-reveal-hint:after{content:"Menu";font-size:13px;font-weight:600;color:#fff;letter-spacing:.5px;opacity:.95}.client-portal-nav-wrapper.visible~.nav-reveal-hint{opacity:0;transform:translate(-50%) translateY(-15px)}@keyframes gentleBounceDown{0%,to{transform:translate(-50%) translateY(0);opacity:.7}50%{transform:translate(-50%) translateY(4px);opacity:.85}}.client-nav-header{display:flex;align-items:center;gap:.75rem;padding:.5rem 1rem .5rem 0;flex-shrink:0;margin-right:1rem}.promoter-access-btn{margin-left:auto;display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:linear-gradient(135deg,#3b82f61a,#2563eb1a);border:1px solid rgba(59,130,246,.3);border-radius:8px;cursor:pointer;transition:all .2s ease;font-size:.875rem;font-weight:500;color:#3b82f6}.promoter-access-btn:hover{background:linear-gradient(135deg,#3b82f626,#2563eb26);border-color:#3b82f680;transform:translateY(-1px);box-shadow:0 2px 8px #3b82f633}.promoter-access-btn.authenticated{background:linear-gradient(135deg,#10b9811a,#0596691a);border-color:#10b9814d;color:#10b981}.promoter-access-btn.authenticated:hover{background:linear-gradient(135deg,#10b98126,#05966926);border-color:#10b98180;box-shadow:0 2px 8px #10b98133}.promoter-icon{font-size:1.1rem;line-height:1}.promoter-label{white-space:nowrap;font-weight:500}.promoter-access-btn-discrete{position:fixed;bottom:20px;left:20px;width:40px;height:40px;background:#3b82f614;border:1px solid rgba(59,130,246,.2);border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.2rem;transition:all .2s ease;z-index:900;opacity:.4}.promoter-access-btn-discrete:hover{opacity:1;background:#3b82f61f;border-color:#3b82f666;transform:scale(1.05);box-shadow:0 2px 8px #3b82f626}[data-theme=dark] .promoter-access-btn-discrete{background:#3b82f61a;border-color:#3b82f640}[data-theme=dark] .promoter-access-btn-discrete:hover{background:#3b82f626;border-color:#3b82f673}@media (max-width: 768px){.promoter-access-btn-discrete{bottom:80px;left:10px;width:36px;height:36px;font-size:1rem}}.client-nav-logo{width:44px;height:44px;object-fit:contain;background:#fff;border-radius:8px;padding:5px;border:1px solid #e5e7eb;box-shadow:0 2px 8px #0000000f}.client-nav-info{display:flex;flex-direction:column;gap:.2rem;min-width:0}.client-nav-name{font-size:.875rem;font-weight:600;color:#1e293b;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.client-portal-nav{background:#fff;display:flex;gap:0;flex:1;padding:0;position:relative;overflow-x:auto}.nav-item{flex:1;min-width:110px;padding:.75rem 1rem;background:transparent;border:none;border-bottom:3px solid transparent;cursor:pointer;display:flex;flex-direction:row;align-items:center;justify-content:center;gap:.5rem;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;font-weight:600;color:#64748b;font-size:.875rem;white-space:nowrap}.nav-item:hover:not(.disabled){background:linear-gradient(to bottom,transparent,rgba(59,130,246,.08));border-bottom-color:#93c5fd;color:#3b82f6;transform:translateY(-2px);box-shadow:0 2px 8px #3b82f626}.nav-item.active{background:linear-gradient(to bottom,transparent,rgba(37,99,235,.12));border-bottom-color:#2563eb;color:#1e40af;animation:navItemActivate .4s cubic-bezier(.34,1.56,.64,1)}@keyframes navItemActivate{0%{transform:translateY(-4px)}50%{transform:translateY(2px)}to{transform:translateY(0)}}.nav-item.active:after{display:none}.nav-item.active .nav-icon{transform:scale(1.15);filter:drop-shadow(0 2px 4px rgba(37,99,235,.3))}.nav-item.disabled{opacity:.4;cursor:not-allowed;background:#f8fafc}.nav-icon{font-size:1.2rem;transition:all .3s cubic-bezier(.4,0,.2,1);flex-shrink:0;line-height:1}.nav-item:hover:not(.disabled) .nav-icon{transform:scale(1.15) rotate(5deg);filter:drop-shadow(0 2px 4px rgba(59,130,246,.3))}.nav-label{font-size:.875rem;font-weight:600;text-align:center;line-height:1.2;letter-spacing:-.01em}.client-portal-content{flex:1;overflow:hidden;position:relative;display:flex;flex-direction:column;height:100%;padding-top:0}.view-container{width:100%;height:100%;flex:1;background:#fff;position:relative;overflow:hidden}.view-container.visite-exterieure{background:linear-gradient(135deg,#1e3a8a,#3b82f6);display:flex;align-items:center;justify-content:center;padding:1rem}.embed-panel{width:100%;height:100%;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;box-shadow:0 10px 40px #0000001a;overflow:hidden}.view-placeholder{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f9fafb,#fff)}.placeholder-content{text-align:center;padding:3rem;max-width:500px}.placeholder-icon{font-size:4rem;display:block;margin-bottom:1.5rem;opacity:.7}.placeholder-content h2{font-size:1.75rem;color:#1f2937;margin-bottom:1rem}.placeholder-content p{font-size:1rem;color:#6b7280;line-height:1.6;margin-bottom:1.5rem}.placeholder-content .info-text{font-size:.9rem;color:#9ca3af;font-style:italic;margin-top:.5rem}.visite-exterieure-iframe{width:100%;height:100%;border:none;background:#000}.btn-primary{background:linear-gradient(135deg,#2563eb,#3b82f6);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 4px #2563eb33}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 8px #2563eb4d}.quick-help{position:fixed;bottom:2rem;right:2rem;z-index:1000;animation:slideInUp .5s ease}.help-tip{background:linear-gradient(135deg,#1e3a8a,#3b82f6);color:#fff;padding:1rem 1.5rem;border-radius:12px;box-shadow:0 4px 12px #00000026;font-size:.9rem;max-width:350px;line-height:1.5}.client-portal-loading,.client-portal-error{width:100%;height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,#f9fafb,#fff)}.client-portal-loading p{margin-top:1rem;font-size:1.1rem;color:#6b7280}.loader{width:50px;height:50px;border:4px solid #e5e7eb;border-top-color:#3b82f6;border-radius:50%;animation:spin .8s linear infinite}.client-portal-error h1{font-size:2rem;color:#dc2626;margin-bottom:1rem}.client-portal-error p{font-size:1.1rem;color:#6b7280}@media (max-width: 768px){.client-portal-header{padding:1rem;flex-direction:column;gap:1rem}.header-left,.header-right{width:100%;justify-content:center}.client-portal-nav-wrapper{flex-direction:column}.client-nav-header{border-right:none;border-bottom:2px solid #e5e7eb;min-width:100%;padding:1rem;justify-content:center}.client-nav-logo{width:50px;height:50px}.client-nav-name{font-size:.9rem}.client-portal-nav{padding:0 .5rem}.project-title{font-size:1.25rem}.client-portal-nav{overflow-x:auto}.nav-item{min-width:100px;padding:.75rem 1rem}.nav-icon{font-size:1.25rem}.nav-label{font-size:.75rem}.quick-help{bottom:1rem;right:1rem;left:1rem}.help-tip{font-size:.85rem;padding:.75rem 1rem}}.view-container .orbit-viewer-container,.view-container .client-viewer-container{width:100%;height:100%}.view-container .back-button,.view-container .project-header{display:none}.promoteur-view{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);overflow:hidden;position:relative}.promoter-website-wrapper{width:100%;height:100%;overflow-y:auto;overflow-x:hidden;position:relative}.promoter-website-iframe{width:100%;min-height:100vh;border:none;background:#fff;display:block}.promoteur-info-card{max-width:800px;margin:3rem auto;background:#fff;border-radius:16px;box-shadow:0 10px 40px #0000001a;overflow:hidden;animation:slideUpFadeIn .5s ease-out}@keyframes slideUpFadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.promoteur-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:2.5rem 2rem;text-align:center;display:flex;flex-direction:column;align-items:center;gap:1rem}.promoteur-icon{font-size:4rem;filter:drop-shadow(0 4px 8px rgba(0,0,0,.2))}.promoteur-header h2{margin:0;font-size:2rem;font-weight:700;letter-spacing:-.5px}.promoteur-content{padding:2.5rem 2rem}.info-section{margin-bottom:2rem;padding-bottom:2rem;border-bottom:1px solid #e5e7eb}.info-section:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.info-section h3{color:#667eea;font-size:1.25rem;font-weight:600;margin:0 0 1rem;display:flex;align-items:center;gap:.5rem}.website-notice{color:#6b7280;font-size:.95rem;line-height:1.6;margin-bottom:1.5rem;padding:1rem;background:#f9fafb;border-radius:8px;border-left:4px solid #667eea}.btn-visit-website{display:inline-flex;align-items:center;gap:.5rem;padding:.875rem 1.75rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;text-decoration:none;border-radius:12px;font-weight:600;font-size:1rem;transition:all .3s ease;box-shadow:0 4px 12px #667eea4d}.btn-visit-website:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.info-section p{color:#4b5563;font-size:1rem;line-height:1.7;margin:0}.contact-link{color:#667eea;text-decoration:none;font-weight:500;font-size:1.1rem;transition:all .3s ease;display:inline-block}.contact-link:hover{color:#764ba2;transform:translate(5px)}@media (max-width: 768px){.promoteur-info-card{margin:1.5rem;border-radius:12px}.promoteur-header{padding:2rem 1.5rem}.promoteur-icon{font-size:3rem}.promoteur-header h2{font-size:1.5rem}.promoteur-content{padding:2rem 1.5rem}.info-section h3{font-size:1.1rem}.info-section p,.contact-link{font-size:.95rem}}.client-portal-loading{width:100%;height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f5f7fa,#c3cfe2)}.loading-progress{display:flex;flex-direction:column;align-items:center;gap:2rem}.progress-circle{width:140px;height:140px;border-radius:50%;background:conic-gradient(#3b82f6 calc(var(--progress) * 1%),#e5e7eb calc(var(--progress) * 1%));display:flex;align-items:center;justify-content:center;position:relative;animation:rotate-circle 2s linear infinite;box-shadow:0 10px 40px #3b82f633}@keyframes rotate-circle{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.progress-inner{width:110px;height:110px;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;box-shadow:inset 0 2px 8px #0000001a}.progress-percent{font-size:1.75rem;font-weight:800;color:#3b82f6;animation:pulse-number 1.5s ease-in-out infinite}@keyframes pulse-number{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.loading-text{font-size:1.125rem;font-weight:600;color:#1e293b;margin:0;animation:fade-in-out 2s ease-in-out infinite}@keyframes fade-in-out{0%,to{opacity:.6}50%{opacity:1}}[data-tooltip]{position:relative}[data-tooltip]:before{content:attr(data-tooltip);position:absolute;bottom:calc(100% + 12px);left:50%;transform:translate(-50%) translateY(-4px);background:#111827f5;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;padding:.625rem 1rem;border-radius:10px;font-size:.8125rem;font-weight:500;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .2s ease,transform .2s ease;z-index:10000;box-shadow:0 4px 12px #0000004d;border:1px solid rgba(255,255,255,.1)}[data-tooltip]:after{content:"";position:absolute;bottom:calc(100% + 4px);left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:#111827f5;opacity:0;pointer-events:none;transition:opacity .2s ease;z-index:10000}[data-tooltip]:hover:before{opacity:1;transform:translate(-50%) translateY(0)}[data-tooltip]:hover:after{opacity:1}@media (hover: none) and (pointer: coarse){[data-tooltip]:before,[data-tooltip]:after{display:none}}.client-portal-nav-wrapper.mobile-nav{opacity:1!important;pointer-events:auto!important;transform:translateY(0)!important}@media (max-width: 768px) and (orientation: portrait){.client-portal-nav-wrapper,.client-portal-nav-wrapper.visible,.client-portal-nav-wrapper.mobile-nav{position:fixed!important;top:auto!important;bottom:0!important;left:0!important;right:0!important;opacity:1!important;pointer-events:auto!important;transform:translateY(0)!important;z-index:1000!important;animation:none!important}}@media (max-width: 768px) and (orientation: landscape){.client-portal-nav-wrapper,.client-portal-nav-wrapper.visible,.client-portal-nav-wrapper.mobile-nav{position:fixed!important;top:0!important;bottom:auto!important;left:0!important;right:0!important;opacity:1!important;pointer-events:auto!important;transform:translateY(0)!important;z-index:1000!important;animation:none!important}}.glass-card{background:#ffffffb3;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:1px solid rgba(255,255,255,.3);box-shadow:0 8px 32px #0000001a,0 0 1px #ffffff80 inset}.interactive-card{transition:all .4s cubic-bezier(.4,0,.2,1);transform-origin:center}.interactive-card:hover{transform:translateY(-8px) scale(1.02);box-shadow:0 20px 40px #00000026,0 0 2px #3b82f64d inset}.skeleton{background:linear-gradient(90deg,#f0f0f0,#e0e0e0,#f0f0f0 40%,#f0f0f0);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:8px}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.parallax-container{transform-style:preserve-3d;perspective:1000px}.parallax-layer{transition:transform .3s ease-out}.parallax-layer:hover{transform:translateZ(20px)}.stagger-item{opacity:0;animation:fadeInUp .6s ease forwards}.stagger-item:nth-child(1){animation-delay:.1s}.stagger-item:nth-child(2){animation-delay:.2s}.stagger-item:nth-child(3){animation-delay:.3s}.stagger-item:nth-child(4){animation-delay:.4s}.stagger-item:nth-child(5){animation-delay:.5s}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.morph-button{position:relative;overflow:hidden;transition:all .4s cubic-bezier(.68,-.55,.265,1.55)}.morph-button:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;background:radial-gradient(circle,rgba(255,255,255,.3) 0%,transparent 70%);transform:translate(-50%,-50%);transition:width .6s ease,height .6s ease;border-radius:50%}.morph-button:hover:before{width:300px;height:300px}.animated-gradient{background:linear-gradient(-45deg,#3b82f6,#2563eb,#1d4ed8,#3b82f6);background-size:400% 400%;animation:gradientFlow 8s ease infinite}@keyframes gradientFlow{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.glow-effect{position:relative}.glow-effect:after{content:"";position:absolute;top:-2px;left:-2px;right:-2px;bottom:-2px;background:linear-gradient(45deg,#3b82f6,#2563eb,#3b82f6);border-radius:inherit;opacity:0;z-index:-1;filter:blur(10px);transition:opacity .4s ease}.glow-effect:hover:after{opacity:.7;animation:glowPulse 2s ease-in-out infinite}@keyframes glowPulse{0%,to{filter:blur(10px);opacity:.7}50%{filter:blur(15px);opacity:1}}.text-reveal{overflow:hidden;display:inline-block}.text-reveal span{display:inline-block;opacity:0;transform:translateY(100%);animation:textReveal .8s cubic-bezier(.68,-.55,.265,1.55) forwards}@keyframes textReveal{to{opacity:1;transform:translateY(0)}}.ripple{position:relative;overflow:hidden}.ripple:after{content:"";position:absolute;top:var(--y);left:var(--x);width:0;height:0;border-radius:50%;background:#ffffff80;transform:translate(-50%,-50%);animation:rippleEffect .6s ease-out}@keyframes rippleEffect{to{width:300px;height:300px;opacity:0}}.flip-card{perspective:1000px}.flip-card-inner{position:relative;width:100%;height:100%;transition:transform .8s;transform-style:preserve-3d}.flip-card:hover .flip-card-inner{transform:rotateY(180deg)}.flip-card-front,.flip-card-back{position:absolute;width:100%;height:100%;backface-visibility:hidden}.flip-card-back{transform:rotateY(180deg)}.scroll-reveal{opacity:0;transform:translateY(50px);filter:blur(5px);transition:all .8s cubic-bezier(.4,0,.2,1)}.scroll-reveal.visible{opacity:1;transform:translateY(0);filter:blur(0)}.neon-text{color:#fff;text-shadow:0 0 7px #fff,0 0 10px #fff,0 0 21px #fff,0 0 42px #3b82f6,0 0 82px #3b82f6,0 0 92px #3b82f6,0 0 102px #3b82f6,0 0 151px #3b82f6;animation:neonFlicker 1.5s infinite alternate}@keyframes neonFlicker{0%,18%,22%,25%,53%,57%,to{text-shadow:0 0 7px #fff,0 0 10px #fff,0 0 21px #fff,0 0 42px #3b82f6,0 0 82px #3b82f6,0 0 92px #3b82f6,0 0 102px #3b82f6,0 0 151px #3b82f6}20%,24%,55%{text-shadow:none}}.liquid-button{position:relative;overflow:hidden}.liquid-button:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(59,130,246,.3) 0%,transparent 70%);animation:liquidWave 3s ease-in-out infinite}@keyframes liquidWave{0%,to{transform:translate(-25%,-25%) rotate(0)}50%{transform:translate(0) rotate(180deg)}}@keyframes particleFloat{0%{transform:translateY(0) translate(0) rotate(0);opacity:0}10%{opacity:1}90%{opacity:1}to{transform:translateY(-100vh) translate(50px) rotate(360deg);opacity:0}}.particle{position:absolute;width:4px;height:4px;background:#3b82f699;border-radius:50%;animation:particleFloat 8s linear infinite}:root[data-theme=light]{--bg: #f8f9fa;--surface: #ffffff;--surface-2: #f3f4f6;--text: #1e293b;--text-muted: #64748b;--border: #e2e8f0;--primary-50: #eff6ff;--primary-100: #dbeafe;--primary-200: #bfdbfe;--primary-300: #93c5fd;--primary-600: #2563eb;--primary-700: #1d4ed8;--shadow: 0 1px 3px rgba(0, 0, 0, .1);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1);--glass-bg: rgba(255, 255, 255, .75);--glass-border: rgba(229, 231, 235, .8)}:root[data-theme=dark]{--bg: #0f172a;--surface: #1e293b;--surface-2: #334155;--text: #f1f5f9;--text-muted: #94a3b8;--border: #334155;--primary-50: #1e3a8a;--primary-100: #1e40af;--primary-200: #2563eb;--primary-300: #3b82f6;--primary-600: #60a5fa;--primary-700: #93c5fd;--shadow: 0 1px 3px rgba(0, 0, 0, .5);--shadow-md: 0 4px 6px rgba(0, 0, 0, .5);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .5);--glass-bg: rgba(30, 41, 59, .75);--glass-border: rgba(51, 65, 85, .8)}*{transition:background-color .3s ease,color .3s ease,border-color .3s ease}.no-theme-transition{transition:none!important}.theme-toggle{display:none!important}.theme-toggle:hover{transform:scale(1.1);box-shadow:0 15px 30px #3b82f666}.theme-toggle:active{transform:scale(.95)}.theme-toggle.switching{animation:rotate-theme .5s ease-in-out}@keyframes rotate-theme{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 768px){.theme-toggle{bottom:5rem;right:1rem;width:48px;height:48px;font-size:1.25rem}}@media (max-width: 768px) and (orientation: portrait){.theme-toggle{bottom:6rem}}.tour-restart-btn{position:fixed;bottom:2rem;left:2rem;width:48px;height:48px;border-radius:50%;background:#3b82f6e6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.25rem;box-shadow:0 4px 12px #3b82f64d;z-index:999;transition:all .2s ease;opacity:.7}.tour-restart-btn:hover{opacity:1;transform:scale(1.1);box-shadow:0 6px 16px #3b82f666}.tour-restart-btn:active{transform:scale(.95)}@media (max-width: 768px){.tour-restart-btn{bottom:5rem;left:1rem;width:44px;height:44px;font-size:1.125rem}}@media (max-width: 768px) and (orientation: portrait){.tour-restart-btn{bottom:6rem}}.tour-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000bf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:9998;animation:fadeIn .3s ease-out}.tour-spotlight{position:fixed;z-index:9999;pointer-events:none;box-shadow:0 0 0 9999px #000000bf;border-radius:12px;transition:all .4s cubic-bezier(.4,0,.2,1);animation:pulse-spotlight 2s ease-in-out infinite}@keyframes pulse-spotlight{0%,to{box-shadow:0 0 0 9999px #000000bf,0 0 0 4px #3b82f680}50%{box-shadow:0 0 0 9999px #000000bf,0 0 0 8px #3b82f6cc}}.tour-card{position:fixed;z-index:10000;background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:380px;width:calc(100vw - 2rem);animation:slideInUp .4s cubic-bezier(.34,1.56,.64,1)}@keyframes slideInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.tour-position-top{bottom:calc(100% + 20px);left:50%;transform:translate(-50%)}.tour-position-bottom{top:calc(100% + 20px);left:50%;transform:translate(-50%)}.tour-position-left{right:calc(100% + 20px);top:50%;transform:translateY(-50%)}.tour-position-right{left:calc(100% + 20px);top:50%;transform:translateY(-50%)}.tour-position-center{top:50%;left:50%;transform:translate(-50%,-50%)}.tour-header{padding:1.5rem 1.5rem 1rem;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #e5e7eb}.tour-header h3{margin:0;font-size:1.25rem;font-weight:700;color:#1e293b}.tour-close{background:none;border:none;font-size:1.5rem;color:#64748b;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .2s ease}.tour-close:hover{background:#f1f5f9;color:#1e293b}.tour-body{padding:1rem 1.5rem}.tour-body p{margin:0;font-size:1rem;line-height:1.6;color:#475569}.tour-footer{padding:1rem 1.5rem 1.5rem;display:flex;flex-direction:column;gap:1rem}.tour-progress{display:flex;gap:.5rem;justify-content:center}.tour-dot{width:10px;height:10px;border-radius:50%;background:#cbd5e1;cursor:pointer;transition:all .3s ease}.tour-dot.active{background:#3b82f6;width:24px;border-radius:5px}.tour-dot.completed{background:#10b981}.tour-dot:hover{transform:scale(1.2)}.tour-buttons{display:flex;gap:.5rem;justify-content:flex-end}.tour-btn-skip{background:none;border:1px solid #e5e7eb;color:#64748b;padding:.625rem 1rem;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease}.tour-btn-skip:hover{background:#f1f5f9;border-color:#cbd5e1}.tour-btn-prev{background:#f1f5f9;border:1px solid #e5e7eb;color:#475569;padding:.625rem 1rem;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease}.tour-btn-prev:hover{background:#e2e8f0}.tour-btn-next{background:#3b82f6;border:none;color:#fff;padding:.625rem 1.25rem;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #3b82f64d}.tour-btn-next:hover{background:#2563eb;transform:translateY(-1px);box-shadow:0 6px 16px #3b82f666}.tour-btn-next:active{transform:translateY(0)}@media (max-width: 768px){.tour-card{max-width:none;width:calc(100vw - 2rem);margin:1rem}.tour-position-top,.tour-position-bottom,.tour-position-left,.tour-position-right{position:fixed;top:auto;bottom:1rem;left:1rem;right:1rem;transform:none}.tour-header h3{font-size:1.125rem}.tour-body p{font-size:.9375rem}.tour-buttons{flex-wrap:wrap}.tour-btn-skip{flex:1;min-width:80px}.tour-btn-prev,.tour-btn-next{flex:1}}[data-theme=dark] .tour-card{background:#1e293b;box-shadow:0 20px 60px #0009}[data-theme=dark] .tour-header{border-bottom-color:#334155}[data-theme=dark] .tour-header h3{color:#f1f5f9}[data-theme=dark] .tour-close{color:#94a3b8}[data-theme=dark] .tour-close:hover{background:#334155;color:#f1f5f9}[data-theme=dark] .tour-body p{color:#cbd5e1}[data-theme=dark] .tour-btn-skip{border-color:#334155;color:#94a3b8}[data-theme=dark] .tour-btn-skip:hover{background:#334155;border-color:#475569}[data-theme=dark] .tour-btn-prev{background:#334155;border-color:#475569;color:#cbd5e1}[data-theme=dark] .tour-btn-prev:hover{background:#475569}.promoter-auth-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .2s ease-out}.promoter-auth-modal{background:var(--surface, #ffffff);border-radius:16px;width:90%;max-width:480px;box-shadow:0 8px 32px #0003;animation:slideInUp .3s ease-out;overflow:hidden}[data-theme=dark] .promoter-auth-modal{background:var(--surface, #1e293b)}.promoter-auth-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid rgba(0,0,0,.1)}[data-theme=dark] .promoter-auth-header{border-bottom-color:#ffffff1a}.promoter-auth-header h2{margin:0;font-size:1.5rem;font-weight:600;color:var(--text, #1e293b)}.close-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-secondary, #64748b);padding:.25rem;line-height:1;transition:color .2s,transform .2s}.close-btn:hover{color:var(--text, #1e293b);transform:scale(1.1)}.promoter-auth-content{padding:1.5rem}.promoter-auth-description{margin:0 0 1rem;color:var(--text-secondary, #64748b);font-size:.95rem}.promoter-auth-features{list-style:none;padding:0;margin:0 0 1.5rem;background:var(--bg, #f8f9fa);padding:1rem;border-radius:8px}[data-theme=dark] .promoter-auth-features{background:var(--bg, #0f172a)}.promoter-auth-features li{padding:.5rem 0;color:var(--text, #1e293b);font-size:.9rem}.promoter-auth-features li:not(:last-child){border-bottom:1px solid rgba(0,0,0,.05)}[data-theme=dark] .promoter-auth-features li:not(:last-child){border-bottom-color:#ffffff0d}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text, #1e293b);font-size:.9rem}.form-group input{width:100%;padding:.75rem 1rem;border:2px solid rgba(0,0,0,.1);border-radius:8px;font-size:1rem;transition:border-color .2s;background:var(--surface, #ffffff);color:var(--text, #1e293b)}[data-theme=dark] .form-group input{background:var(--bg, #0f172a);border-color:#ffffff1a}.form-group input:focus{outline:none;border-color:#3b82f6}.form-group input:disabled{opacity:.6;cursor:not-allowed}.error-message{display:block;margin-top:.5rem;color:#ef4444;font-size:.875rem;font-weight:500}.promoter-auth-actions{display:flex;gap:1rem;justify-content:flex-end}.btn-secondary,.btn-primary{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s;min-width:120px}.btn-secondary{background:var(--bg, #f3f4f6);color:var(--text, #1e293b)}[data-theme=dark] .btn-secondary{background:var(--bg, #0f172a)}.btn-secondary:hover:not(:disabled){background:#0000001a}[data-theme=dark] .btn-secondary:hover:not(:disabled){background:#ffffff1a}.btn-primary{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #3b82f666}.btn-secondary:disabled,.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.promoter-auth-footer{padding:1rem 1.5rem;background:var(--bg, #f8f9fa);border-top:1px solid rgba(0,0,0,.1);text-align:center}[data-theme=dark] .promoter-auth-footer{background:var(--bg, #0f172a);border-top-color:#ffffff1a}.promoter-auth-footer small{color:var(--text-secondary, #64748b);font-size:.875rem}@keyframes slideInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.promoter-auth-modal{width:95%;max-height:90vh;overflow-y:auto}.promoter-auth-header h2{font-size:1.25rem}.promoter-auth-actions{flex-direction:column-reverse}.btn-secondary,.btn-primary{width:100%}}:root{--primary-color: #2563eb;--primary-hover: #1d4ed8;--secondary-color: #64748b;--success-color: #10b981;--danger-color: #ef4444;--border-color: #e2e8f0;--bg-light: #f8fafc;--text-dark: #1e293b;--text-light: #64748b;--shadow: 0 1px 3px 0 rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1)}.app{min-height:100vh;color:#1e293b}.project-card,.option-card,.settings-card{color:#1e293b}.project-card h1,.project-card h2,.project-card h3,.project-card h4,.project-card h5,.project-card h6,.option-card h1,.option-card h2,.option-card h3,.option-card h4,.option-card h5,.option-card h6,.settings-card h1,.settings-card h2,.settings-card h3,.settings-card h4,.settings-card h5,.settings-card h6{color:#2d3748}.project-card p,.option-card p,.settings-card p,.project-info span{color:#718096}label,.form-group label{color:#2d3748!important}:root{--bg: #f6f7fb;--surface: #ffffff;--surface-2: #f8fafc;--border: #e2e8f0;--shadow-sm: 0 1px 2px rgba(0,0,0,.06);--shadow: 0 6px 20px rgba(0,0,0,.08);--shadow-lg: 0 12px 32px rgba(0,0,0,.12);--text: #0f172a;--muted: #475569;--primary-50: #eff6ff;--primary-100: #dbeafe;--primary-200: #bfdbfe;--primary-300: #93c5fd;--primary-400: #60a5fa;--primary-500: #3b82f6;--primary-600: #2563eb;--primary-700: #1d4ed8;--primary-800: #1e40af;--primary-900: #1e3a8a;--success-500: #10b981;--success-600: #059669;--warning-500: #f59e0b;--danger-500: #ef4444;--radius-sm: 8px;--radius: 12px;--radius-lg: 16px;--gap-1: .25rem;--gap-2: .5rem;--gap-3: .75rem;--gap-4: 1rem;--gap-6: 1.5rem;--btn-bg: var(--primary-600);--btn-fg: #fff;--btn-hover: var(--primary-700);--btn-radius: 10px;--btn-shadow: 0 2px 8px rgba(37, 99, 235, .3)}html,body{background:var(--bg);color:var(--text)}h1,h2,h3{color:var(--text);letter-spacing:-.02em}.subtle{color:var(--muted)}.card,.panel{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow)}.card{padding:var(--gap-6)}.panel{padding:var(--gap-4)}.toolbar{display:flex;align-items:center;justify-content:space-between;gap:var(--gap-3)}.btn,.btn-share,.btn-virtual-tour,.btn-export-pdf,.btn-share-small{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1rem;border-radius:var(--btn-radius);border:1.5px solid transparent;background:var(--btn-bg);color:var(--btn-fg);font-weight:700;box-shadow:var(--btn-shadow);transition:all .2s ease}.btn:hover,.btn-share:hover,.btn-virtual-tour:hover,.btn-export-pdf:hover,.btn-share-small:hover{transform:translateY(-2px)}.btn--primary{background:var(--primary-600);border-color:var(--primary-600)}.btn--success,.btn-share,.btn-share-small{background:var(--success-500);border-color:var(--success-600)}.btn--warning{background:var(--warning-500);border-color:var(--warning-500)}.btn--danger{background:var(--danger-500);border-color:var(--danger-500)}.btn--ghost{background:transparent;color:var(--primary-700);border-color:var(--primary-200)}.btn-virtual-tour{background:var(--primary-600);border-color:var(--primary-600)}.btn-export-pdf{background:var(--primary-900);border-color:var(--primary-700)}.btn-sm{padding:.45rem .75rem;font-size:.75rem}.btn-md{padding:.625rem 1rem;font-size:.85rem}.btn-lg{padding:.85rem 1.35rem;font-size:1rem}.btn--loading{position:relative;pointer-events:none;opacity:.7}.btn-spinner{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%)}.btn-content--hidden{visibility:hidden}.badge{display:inline-flex;align-items:center;gap:.35rem;font-weight:700;font-size:.75rem;padding:.25rem .5rem;border-radius:999px;border:1px solid var(--border);background:var(--surface-2);color:var(--text)}.badge.disponible{background:#10b9811a;color:#065f46;border-color:#10b98133}.badge.option{background:#f59e0b1a;color:#92400e;border-color:#f59e0b33}.badge.vendu{background:#ef44441a;color:#7f1d1d;border-color:#ef444433}.input,input,select,textarea{border:1.5px solid var(--border);border-radius:var(--radius);padding:.625rem .75rem;background:var(--surface);color:var(--text)}.input:focus,input:focus,select:focus,textarea:focus{outline:2px solid var(--primary-300)}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 1.25rem}.shadow{box-shadow:var(--shadow)}.shadow-lg{box-shadow:var(--shadow-lg)}.rounded{border-radius:var(--radius)}.rounded-lg{border-radius:var(--radius-lg)}.border{border:1.5px solid var(--border)}.muted{color:var(--muted)}.input-wrapper{position:relative}.input-error{border-color:var(--danger-500)!important}.input-error-text{display:block;margin-top:.35rem;font-size:.75rem;color:var(--danger-500)}.card-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:var(--gap-4);border-bottom:1px solid var(--border);margin-bottom:var(--gap-4)}.card-title{font-size:1.25rem;font-weight:700;margin:0}.card-actions{display:flex;gap:var(--gap-2)}.badge-disponible{background:#10b9811a;color:#065f46;border-color:#10b98133}.badge-option{background:#f59e0b1a;color:#92400e;border-color:#f59e0b33}.badge-vendu,.badge-reserved{background:#ef44441a;color:#7f1d1d;border-color:#ef444433}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:9999;animation:fadeIn .2s}.modal{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);max-width:90vw;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:slideUp .3s}.modal-sm{width:400px}.modal-md{width:600px}.modal-lg{width:900px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--gap-4);border-bottom:1px solid var(--border)}.modal-title{font-size:1.35rem;font-weight:700;margin:0}.modal-close{background:transparent;border:none;font-size:1.5rem;color:var(--muted);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s}.modal-close:hover{background:var(--surface-2);color:var(--text)}.modal-body{padding:var(--gap-4);overflow-y:auto;flex:1}.table-container{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}.table{width:100%;border-collapse:collapse}.table thead{background:var(--bg);border-bottom:2px solid var(--border)}.table th{text-align:left;padding:var(--gap-3) var(--gap-4);font-weight:600;font-size:.875rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}.table td{padding:var(--gap-3) var(--gap-4);border-bottom:1px solid var(--border)}.table tbody tr:last-child td{border-bottom:none}.table tbody tr.clickable{cursor:pointer;transition:background .2s}.table tbody tr.clickable:hover{background:var(--bg)}.select{width:100%;padding:var(--gap-3);border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);font-size:.875rem;font-family:inherit;transition:all .2s;cursor:pointer}.select:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px var(--primary-100)}.select:disabled{opacity:.5;cursor:not-allowed}.spinner{display:inline-flex;align-items:center;justify-content:center}.spinner--sm{width:1rem;height:1rem}.spinner--md{width:2rem;height:2rem}.spinner--lg{width:3rem;height:3rem}.spinner-circle{width:100%;height:100%;border:2px solid var(--border);border-top-color:var(--primary-600);border-radius:50%;animation:spin .8s linear infinite}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;width:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f5f5;color:#1e293b}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}button{cursor:pointer;font-family:inherit}input,textarea,select{font-family:inherit}
