*{box-sizing:border-box}html{height:100%;height:-webkit-fill-available}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;display:flex;flex-direction:column;background-color:#f7f7f7;color:#333;overflow:hidden;margin:0;padding:0;min-height:100vh;min-height:-webkit-fill-available;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;contain:layout style paint}#main-container{display:flex;flex:1;height:100vh}#map{width:65%;height:100vh;cursor:grab;box-shadow:0 8px 16px #0000001a;transition:cursor .2s ease-in-out;transform:translateZ(0);will-change:transform;contain:layout style paint}@media (min-width: 769px){#mobile-header{display:none}}#map:active{cursor:grabbing}#bbox-panel{width:35%;height:100vh;background-color:#fff;border-left:1px solid #ddd;padding:30px;box-sizing:border-box;overflow-y:auto;box-shadow:-2px 0 10px #0000000d;display:flex;flex-direction:column}.integrated-user-menu{background:linear-gradient(135deg,#1976d214,#1565c00d);border-radius:12px;padding:20px;margin-bottom:24px;border:1px solid rgba(25,118,210,.15);box-shadow:0 2px 8px #0000000d;transition:all .3s ease}.integrated-user-menu.collapsed{padding:16px 20px}.integrated-user-info{display:flex;align-items:center;gap:15px;margin-bottom:0;position:relative}.integrated-menu-toggle-wrapper{position:absolute;right:0;top:50%;transform:translateY(-50%);display:flex;align-items:center;gap:8px}.integrated-menu-toggle-text{font-size:.85rem;font-weight:600;color:#1976d2;white-space:nowrap;transition:color .3s ease;user-select:none}.integrated-menu-toggle-wrapper:hover .integrated-menu-toggle-text{color:#1565c0}.integrated-menu-toggle{background:#1976d21a;border:1px solid rgba(25,118,210,.2);border-radius:8px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;color:#1976d2;padding:0;flex-shrink:0}.integrated-menu-toggle:hover{background:#1976d233;border-color:#1976d266;transform:scale(1.05)}.integrated-menu-toggle svg{transition:transform .3s ease}.integrated-menu-collapsible{max-height:1000px;opacity:1;overflow:hidden;transition:max-height .4s ease,opacity .3s ease,margin-top .3s ease;margin-top:0}.integrated-user-menu.collapsed .integrated-menu-collapsible{max-height:0;opacity:0;margin-top:0}.integrated-user-menu.collapsed .integrated-user-info{margin-bottom:0}.integrated-user-avatar{width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.2rem;color:#fff;flex-shrink:0;overflow:hidden;border:3px solid rgba(255,255,255,.5);box-shadow:0 4px 12px #00000026}.integrated-user-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%}.integrated-user-details{flex:1;min-width:0;margin-right:120px}.integrated-user-name{font-size:1.1rem;font-weight:700;color:#1a2332;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.integrated-user-email{font-size:.85rem;color:#64748b;margin-bottom:8px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.integrated-user-badge{display:inline-block;padding:4px 10px;background:#4caf5026;color:#2e7d32;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;border:1px solid rgba(76,175,80,.3)}.integrated-menu-divider{height:1px;background:linear-gradient(90deg,transparent,rgba(25,118,210,.2),transparent);margin:16px 0}.integrated-menu-links{display:flex;flex-direction:column;gap:8px}.integrated-menu-link{display:flex;align-items:center;gap:12px;padding:10px 14px;color:#475569;text-decoration:none;border-radius:8px;transition:all .3s;font-size:.95rem;font-weight:500;background:#ffffff80;border:1px solid rgba(25,118,210,.1)}.integrated-menu-link:hover{background:#1976d21a;color:#1976d2;transform:translate(4px)}.integrated-menu-link.highlight{background:#4caf501a;color:#2e7d32;border:1px solid rgba(76,175,80,.3);font-weight:600}.integrated-menu-link.highlight:hover{background:#4caf5033;color:#1b5e20}.integrated-menu-link svg{flex-shrink:0}.integrated-menu-actions{display:flex;flex-direction:column;gap:8px}.integrated-menu-button{display:flex;align-items:center;gap:12px;padding:10px 14px;background:#fff9;border:1px solid rgba(25,118,210,.15);border-radius:8px;color:#475569;cursor:pointer;transition:all .3s;font-size:.95rem;font-weight:500;font-family:inherit;text-align:left;width:100%}.integrated-menu-button:hover{background:#1976d21f;color:#1976d2;transform:translate(4px);border-color:#1976d24d}.integrated-menu-button svg{flex-shrink:0}.integrated-menu-button.logout{color:#dc2626;border-color:#dc262633}.integrated-menu-button.logout:hover{background:#dc26261a;border-color:#dc262666;color:#b91c1c}.personal-info-footer{margin-top:auto;border-top:2px solid #e2e8f0;display:flex;align-items:center;gap:15px;background:linear-gradient(135deg,#673ab70d,#9c27b00d);padding:20px;border-radius:12px;box-shadow:0 2px 8px #0000000d}.personal-info-footer .profile-pic{width:60px;height:60px;border-radius:50%;border:3px solid #9c27b0;flex-shrink:0;box-shadow:0 4px 12px #9c27b04d}.personal-info-footer .personal-text{flex:1;min-width:0}.personal-info-footer .personal-text h4{font-size:1rem;margin:0 0 4px;color:#4a148c;font-weight:700}.personal-info-footer .personal-text .nickname{font-style:italic;color:#7b1fa2;margin:0;font-size:.9rem;font-weight:500}.personal-info{display:flex;align-items:center;padding-bottom:20px;margin-bottom:20px;border-bottom:2px solid #eee}.profile-pic{width:70px;height:70px;border-radius:50%;margin-right:15px;border:2px solid #ddd}.personal-text h2{font-size:1.5em;margin:0 0 5px;color:#333}.personal-text .nickname{font-style:italic;color:#777;margin-bottom:5px}.personal-text a{color:#007bff;text-decoration:none;font-size:1em}.personal-text a:hover{text-decoration:underline}#bbox-panel hr{border:0;border-bottom:1px solid #eee;margin-bottom:20px}#bbox-panel h2{color:#333;margin-bottom:20px;padding-bottom:10px;border-bottom:2px solid #eee;font-size:24px}#bbox-list{list-style:none;padding:0}#bbox-list li{margin-bottom:25px;padding:25px;border:1px solid #e2e8f0;border-radius:12px;background-color:#f9fafb;font-size:16px;box-shadow:0 4px 10px #0000000d;transition:background-color .3s,transform .3s}#bbox-list li:hover{background-color:#f0f4f8;transform:translateY(-5px)}#bbox-list li .bbox-title-container{display:flex;align-items:center;justify-content:space-between;margin-bottom:15px}#bbox-list li .bbox-title-container span{font-weight:700;color:#333;font-size:1.1em;margin:0}#bbox-list li .bbox-title-container .bbox-title-actions{display:flex;gap:6px;align-items:center}#bbox-list li .bbox-title-container .bbox-title-actions button{padding:5px 8px;font-size:.8em;border-radius:5px;border:none;cursor:pointer;transition:background-color .3s,transform .2s;color:#000;font-weight:500;white-space:nowrap}#bbox-list li .bbox-title-container .bbox-title-actions button:hover{transform:translateY(-1px)}#bbox-list li .bbox-title-container .bbox-title-actions button:active{transform:translateY(0)}#bbox-list li .bbox-title-container .bbox-title-actions button.rename-button{background-color:#4caf50}#bbox-list li .bbox-title-container .bbox-title-actions button.rename-button:hover{background-color:#388e3c}#bbox-list li .bbox-title-container .bbox-title-actions button.toggle-button{background-color:#ff0}#bbox-list li .bbox-title-container .bbox-title-actions button.toggle-button:hover{background-color:#ee0}#bbox-list li .bbox-title-container .bbox-title-actions button.delete-button{background-color:red;color:#fff}#bbox-list li .bbox-title-container .bbox-title-actions button.delete-button:hover{background-color:#d32f2f}#bbox-list li .coordinates{margin-bottom:15px;display:grid;grid-template-columns:repeat(2,1fr);gap:0px;border:1px solid black}#bbox-list li .coordinates span{display:flex;align-items:center;justify-content:center;padding:10px;background-color:#f0f4f8;color:#424242;font-size:.95em;font-weight:700;box-shadow:none;position:relative;overflow:hidden;border-right:1px solid black;border-bottom:1px solid black;font-family:Courier New,Courier,monospace}#bbox-list li .coordinates span:nth-child(2n){border-right:none}#bbox-list li .coordinates span:nth-last-child(-n+2){border-bottom:none}#bbox-list li .coordinates span:before{content:"";position:absolute;top:0;left:0;width:100%;height:5px;background-color:transparent}#bbox-list li .action-buttons{display:flex;justify-content:space-between;align-items:center}#bbox-list li .action-buttons button{padding:8px 12px;border:none;border-radius:6px;cursor:pointer;transition:background-color .3s,color .3s,box-shadow .3s;font-size:.9em;font-family:inherit;box-shadow:0 2px 6px #0000001a;outline:none;width:48%;box-sizing:border-box}#bbox-list li .action-buttons button.toggle-button{background-color:#ff0;color:#000}#bbox-list li .action-buttons button.toggle-button:hover{background-color:#ee0}#bbox-list li .action-buttons button.delete-button{background-color:red;color:#000}#bbox-list li .action-buttons button.delete-button:hover{background-color:#f44336}#draw-bbox-button.desktop-only{position:absolute;top:20px;left:10px;z-index:1001;background-color:#64b5f6;color:#000;border:1px solid #ced4da;padding:8px 16px;border-radius:4px;cursor:pointer;transition:background-color .3s,color .3s,box-shadow .3s;font-size:14px;font-family:inherit;box-shadow:0 2px 8px #00000026;outline:none;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent;pointer-events:auto;display:block;white-space:nowrap}#draw-bbox-button:hover{background-color:#2196f3;color:#fff;transform:translateY(-1px);box-shadow:0 4px 12px #0003}#mobile-header{display:none;width:100%;height:60px;background:linear-gradient(135deg,#007bff,#0056b3);box-shadow:0 2px 10px #00000026;z-index:1001;position:relative}#mobile-toggle-button{width:100%;height:100%;background:transparent;color:#fff;border:none;padding:0;font-size:18px;font-weight:600;cursor:pointer;transition:none!important;text-align:center;line-height:60px;letter-spacing:.5px}#mobile-toggle-button:hover{background-color:#ffffff1a;transform:scale(1.02)}#mobile-toggle-button:active{background-color:#fff3;transform:scale(.98)}.mobile-only{display:none}.desktop-only{display:none!important}@media (min-width: 769px){.desktop-only{display:block!important}}#mobile-draw-button{width:100%;padding:12px 16px;background-color:#ff4081;color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:700;cursor:pointer;margin-bottom:20px;transition:all .3s ease;box-shadow:0 2px 6px #0000001a}#mobile-draw-button:hover{background-color:#f50057;transform:translateY(-2px)}#mobile-draw-button:active{transform:translateY(0)}.leaflet-control-layers{background:#fff!important;padding:6px 10px!important;border:1px solid #ccc!important;border-radius:5px!important;box-shadow:0 1px 5px #00000026!important;font-size:12px!important;min-width:auto!important}.leaflet-control-layers label{font-weight:400!important;font-size:12px!important;margin:2px 0!important;color:#333!important}.leaflet-control-layers-toggle{background-color:transparent!important;border:1px solid #ddd!important;border-radius:4px!important;width:34px!important;height:34px!important;box-shadow:0 2px 8px #00000026!important;transition:all .2s ease!important}.leaflet-control-layers-toggle:hover{background-color:#f8f9facc!important;border-color:#007bff!important}.leaflet-control-zoom{top:60px!important}.leaflet-control-zoom a{background-color:#fff!important;border:1px solid #ddd!important;color:#555!important;font-weight:700!important;transition:all .2s ease!important;width:30px!important;height:30px!important;line-height:30px!important;border-radius:4px!important}.leaflet-control-zoom a:hover{background-color:#f8f9fa!important;border-color:#007bff!important;color:#007bff!important}@media (max-width: 768px){.leaflet-control-zoom{top:10px!important}}@media (min-width: 769px) and (max-width: 1024px){#draw-bbox-button{left:100px;font-size:13px;padding:6px 12px}}@media (min-width: 1400px){#draw-bbox-button{left:140px;padding:10px 20px;font-size:15px}}.leaflet-tile-container{transition:transform .3s ease-out}.loading-spinner,.model-preview,.modal-overlay,#bbox-panel{will-change:auto}#bbox-panel{-webkit-overflow-scrolling:touch;scroll-behavior:smooth;overscroll-behavior:contain}.loading-indicator,.progress-bar{will-change:transform,opacity;contain:layout style paint}.generation-settings{margin-top:20px;padding:15px;border:1px solid #ddd;border-radius:8px;background-color:#f8f8f8}.generation-settings h4{margin-top:0;margin-bottom:10px;color:#555}.generation-settings label{display:block;margin-bottom:5px;color:#777;font-size:.9em}.generation-settings input[type=number],.generation-settings select{width:100%;padding:8px;margin-bottom:10px;border:1px solid #ccc;border-radius:4px;box-sizing:border-box;font-size:14px}@media screen and (max-width: 768px){.generation-settings input[type=number],.generation-settings select{font-size:16px}}.generation-settings button{background-color:#26a69a;color:#fff;padding:10px 15px;border:none;border-radius:5px;cursor:pointer;font-size:1em;transition:background-color .3s}.generation-settings button:hover{background-color:#2bbbad}.loading-indicator{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000000b3;display:flex;flex-direction:column;justify-content:center;align-items:center;z-index:9999;color:#fff;font-size:18px}.loading-spinner{border:5px solid #f3f3f3;border-top:5px solid #26a69a;border-radius:50%;width:50px;height:50px;animation:spin 2s linear infinite;margin-bottom:20px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.progress-container{width:80%;max-width:400px;margin-top:15px;background-color:#f1f1f1;border-radius:5px;overflow:hidden}.progress-bar{height:10px;background-color:#26a69a;width:0%;transition:width .3s ease}.success-message{position:fixed;top:20px;right:20px;background-color:#4caf50;color:#fff;padding:15px 20px;border-radius:5px;box-shadow:0 4px 8px #0003;z-index:9999;animation:fadeIn .5s,fadeOut .5s 3.5s forwards}@keyframes fadeIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-20px)}}.model-preview{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background-color:#fff;padding:25px;border-radius:12px;box-shadow:0 5px 25px #0000004d;z-index:10000;width:90%;max-width:1000px;height:85vh;max-height:800px;display:flex;flex-direction:column;overflow:hidden}.model-preview h3{margin:0 0 15px;color:#333;font-size:22px;border-bottom:2px solid #eee;padding-bottom:10px;flex-shrink:0}.preview-3d{width:100%;flex-grow:1;border:1px solid #ddd;border-radius:5px;background-color:#f0f0f0;overflow:hidden;position:relative;margin-bottom:15px}.model-info{text-align:left;margin-bottom:10px;padding:8px 12px;background-color:#e8f5e9;border-radius:5px;border-left:4px solid #4CAF50;flex-shrink:0}.model-info p{margin:5px 0;color:#2e7d32;font-size:14px}.model-stats{text-align:left;margin-bottom:15px;padding:10px 12px;background-color:#f9f9f9;border-radius:5px;border-left:4px solid #26a69a;flex-shrink:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:5px 15px}.model-stats p{margin:5px 0;color:#555;font-size:14px}.model-actions{display:flex;justify-content:space-between;gap:15px;flex-shrink:0}.download-button{flex:1;padding:10px 15px;background-color:#64b5f6;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:15px;font-weight:700;transition:background-color .3s,transform .2s;display:flex;align-items:center;justify-content:center;gap:10px;text-decoration:none;box-shadow:0 2px 6px #0000001a}.download-button:hover{background-color:#2196f3;transform:translateY(-2px)}.download-button:active{transform:translateY(0)}.close-button{flex:1;padding:10px 15px;background-color:#e57373;color:#000;border:none;border-radius:6px;cursor:pointer;font-size:15px;font-weight:700;transition:background-color .3s;box-shadow:0 2px 6px #0000001a}.close-button:hover{background-color:#f44336}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;z-index:9999}@media (max-width: 768px){body{overflow:auto}#main-container{display:flex;flex-direction:column;height:calc(100vh - 56px);overflow:hidden}#mobile-header{display:block}#mobile-draw-button{display:block;width:100%;margin:0 0 18px;position:static;z-index:2;top:0;left:0;border-radius:12px;font-size:1em;font-weight:600;background:linear-gradient(135deg,#26a69a,#00897b)!important;color:#fff!important;border:none!important;box-shadow:0 4px 12px #26a69a4d;padding:14px 0;transition:all .3s ease}#mobile-draw-button:active{transform:scale(.98);box-shadow:0 2px 8px #26a69a4d}#draw-bbox-button,#draw-bbox-button.desktop-only{display:none!important;visibility:hidden!important}#bbox-panel{width:100%;height:0;min-height:0;max-height:none;overflow-y:auto;-webkit-overflow-scrolling:touch;order:2;padding:0;border-left:none;border-top:1px solid #ddd;border-bottom:none;display:none;position:relative;z-index:1000;background:#fff;transition:height .3s ease}#bbox-panel[style*="display: flex"]{display:flex!important;padding:16px}#map{width:100%;height:100%;flex-shrink:0;order:1;touch-action:pan-x pan-y;position:relative;z-index:1}.personal-info-footer{margin-top:24px;padding:16px;gap:12px;background:linear-gradient(135deg,#673ab714,#9c27b014);border-radius:10px}.personal-info-footer .profile-pic{width:50px;height:50px;border:2px solid #9c27b0}.personal-info-footer .personal-text h4{font-size:.95rem}.personal-info-footer .personal-text .nickname{font-size:.85rem}.personal-info{flex-direction:row;text-align:left;padding:16px;margin:0 0 16px;background:linear-gradient(135deg,#1976d214,#1565c00d);border-radius:12px;border:1px solid rgba(25,118,210,.1)}.profile-pic{width:52px;height:52px;margin:0 12px 0 0;border:2px solid rgba(25,118,210,.3);box-shadow:0 2px 8px #0000001a}.personal-text h4{font-size:1.05em;margin:0 0 4px;color:#1976d2}.personal-text .nickname{font-size:.85em;color:#666;font-style:italic}#bbox-panel h2{font-size:20px;text-align:center;margin-bottom:15px}#bbox-list li{margin-bottom:16px;padding:16px;font-size:14px;border-radius:16px;border:1px solid #e0e0e0;box-shadow:0 2px 8px #00000014}#bbox-list li .bbox-title-container{flex-direction:column;align-items:flex-start;gap:10px;margin-bottom:12px}#bbox-list li .bbox-title-container span{font-size:1.05em;color:#1976d2}#bbox-list li .bbox-title-container .bbox-title-actions{display:flex;gap:6px;width:100%}#bbox-list li .bbox-title-container .bbox-title-actions button{flex:1;min-width:0;padding:10px 8px;font-size:.85em;border-radius:8px;font-weight:600;transition:all .3s ease;border:none;cursor:pointer;white-space:nowrap}#bbox-list li .bbox-title-container .bbox-title-actions button:active{transform:scale(.98)}#bbox-list li .bbox-title-container .bbox-title-actions button.rename-button{background-color:#4caf50;color:#000}#bbox-list li .bbox-title-container .bbox-title-actions button.rename-button:hover{background-color:#388e3c}#bbox-list li .bbox-title-container .bbox-title-actions button.toggle-button{background-color:#ff0;color:#000}#bbox-list li .bbox-title-container .bbox-title-actions button.toggle-button:hover{background-color:#ee0}#bbox-list li .bbox-title-container .bbox-title-actions button.delete-button{background-color:red;color:#fff}#bbox-list li .bbox-title-container .bbox-title-actions button.delete-button:hover{background-color:#d32f2f}#bbox-list li .coordinates{grid-template-columns:1fr;font-size:.85em}#bbox-list li .coordinates span{padding:8px;border-right:none;border-bottom:1px solid black}#bbox-list li .coordinates span:last-child{border-bottom:none}#bbox-list li .action-buttons{flex-direction:row;gap:8px;margin-top:12px}#bbox-list li .action-buttons button{flex:1;padding:12px;font-size:.9em;border-radius:10px;font-weight:600;transition:all .3s ease}#bbox-list li .action-buttons button:active{transform:scale(.95)}#bbox-list li .action-buttons button.toggle-button{background:linear-gradient(135deg,#ffd54f,#ffca28);color:#000}#bbox-list li .action-buttons button.delete-button{background:linear-gradient(135deg,#ef5350,#e53935);color:#fff}#draw-bbox-button{display:none!important;visibility:hidden!important}.generation-settings{margin:12px 0 0;padding:14px;background:linear-gradient(135deg,#26a69a0d,#00897b08);border:1px solid rgba(38,166,154,.2);border-radius:12px}.generation-settings h4{font-size:1.05em;margin-bottom:12px;color:#00897b;font-weight:600}.generation-settings label{font-size:.9em;margin-bottom:6px;font-weight:500;color:#555}.generation-settings input[type=number],.generation-settings select{padding:10px;font-size:16px;border-radius:8px;border:1px solid #ddd;transition:border-color .3s ease}.generation-settings input[type=number]:focus,.generation-settings select:focus{border-color:#26a69a;outline:none}.generation-settings button{padding:14px 16px;font-size:1em;margin-top:12px;border-radius:10px;background:linear-gradient(135deg,#26a69a,#00897b);font-weight:600;box-shadow:0 4px 12px #26a69a4d;transition:all .3s ease}.generation-settings button:active{transform:scale(.98);box-shadow:0 2px 8px #26a69a4d}.model-preview{width:98vw!important;max-width:100vw!important;height:95vh!important;max-height:100vh!important;overflow-y:auto!important;padding-bottom:140px!important;margin:2vh auto 0!important;box-sizing:border-box}.model-preview h3{font-size:18px;margin-bottom:10px}.model-stats{grid-template-columns:1fr;gap:5px;padding:8px}.model-stats p,.model-info p{font-size:13px}.model-actions{position:fixed;left:0;bottom:0;width:100vw;background:linear-gradient(180deg,#fafafafa,#fffffffc);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);z-index:3000;padding:10px 12px 14px;box-shadow:0 -4px 16px #00000014;border-top:1px solid rgba(0,0,0,.08)}.model-actions>div{display:flex!important;flex-direction:column!important;gap:8px!important;width:100%!important}.model-actions>div>div:first-child{display:flex!important;flex-direction:row!important;gap:8px!important;width:100%!important}.model-actions>div>div:first-child>*{flex:1!important;display:flex!important}.model-actions>div>div:last-child{display:flex!important;flex-direction:column!important;align-items:center!important;gap:6px!important;width:100%!important}.model-actions>div>div:last-child>button,.model-actions>div>div:last-child>a{width:70%!important;max-width:280px!important}.model-actions>div>div:last-child>div[style*=font-size]{display:block!important;text-align:center!important;font-size:11px!important;color:#666!important;line-height:1.3!important;padding:0 16px!important;margin:0!important}.model-actions .download-button,.model-actions .close-button,.model-actions button,.model-actions a{flex-shrink:0!important;min-width:0!important;height:52px!important;padding:8px 12px!important;font-size:12px!important;border-radius:10px!important;display:flex!important;flex-direction:row!important;align-items:center!important;justify-content:center!important;gap:8px!important;text-align:center!important;line-height:1.3!important;font-weight:600!important;box-shadow:0 2px 6px #00000014!important;white-space:nowrap!important;transition:all .2s ease!important}.model-actions .download-button svg,.model-actions .close-button svg,.model-actions button svg,.model-actions a svg{width:20px!important;height:20px!important;margin:0!important;flex-shrink:0!important}.model-actions .download-button:active,.model-actions .close-button:active,.model-actions button:active,.model-actions a:active{transform:scale(.97)!important}.loading-indicator{width:100%;padding:20px;box-sizing:border-box}.success-message{top:10px;right:10px;left:10px;padding:12px 15px;font-size:14px}.leaflet-control-layers{padding:5px 8px!important;font-size:11px!important}.leaflet-control-layers label{font-size:11px!important;margin:1px 0!important}.leaflet-control-layers-toggle{width:32px!important;height:32px!important}.leaflet-control-zoom{font-size:14px}.leaflet-control-zoom a{width:28px!important;height:28px!important;line-height:28px!important}.leaflet-control-zoom a{width:35px;height:35px;line-height:35px;font-size:16px}#mobile-header-fixed{position:fixed;top:0;left:0;right:0;width:100vw;min-width:100vw;max-width:100vw;height:60px;background:linear-gradient(135deg,#1976d2,#1565c0);box-shadow:0 2px 12px #00000026;z-index:2000;display:flex;align-items:center;justify-content:space-between;padding:0 12px;border-bottom:1px solid rgba(255,255,255,.1);backdrop-filter:blur(10px);margin:0;border-radius:0;overflow:visible}.mobile-panel-toggle{font-size:1rem;font-weight:600;border-radius:10px!important;padding:10px 20px!important;background:#ffffff26;color:#fff;border:1px solid rgba(255,255,255,.2)!important;box-shadow:0 2px 8px #0000001a!important;margin:0!important;height:44px!important;display:flex;align-items:center;justify-content:center;text-align:center;transition:all .3s ease!important;box-sizing:border-box;outline:none!important;cursor:pointer;backdrop-filter:blur(10px)}.mobile-panel-toggle:hover,.mobile-panel-toggle:active{background:#ffffff40!important;border-color:#ffffff4d!important;transform:scale(.98)}#mobile-user-menu-container{display:flex;align-items:center}.mobile-user-menu{position:relative}.mobile-user-menu-button{width:44px;height:44px;border-radius:50%;background:#ffffff26;border:2px solid rgba(255,255,255,.3);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;padding:0;outline:none;backdrop-filter:blur(10px)}.mobile-user-menu-button:active{background:#ffffff40;transform:scale(.95)}.mobile-user-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem;color:#fff;overflow:hidden}.mobile-user-avatar img{width:100%;height:100%;object-fit:cover}.mobile-user-menu-dropdown{position:absolute;top:calc(100% + 12px);right:0;background:linear-gradient(135deg,#1a2332,#0f1621);border:1px solid rgba(100,181,246,.3);border-radius:16px;min-width:260px;max-width:90vw;box-shadow:0 12px 40px #00000080;opacity:0;visibility:hidden;transform:translateY(-10px) scale(.95);transition:all .3s cubic-bezier(.4,0,.2,1);z-index:2001;overflow:hidden}.mobile-user-menu-dropdown.active{opacity:1;visibility:visible;transform:translateY(0) scale(1)}.mobile-menu-header{padding:16px;border-bottom:1px solid rgba(255,255,255,.1);background:#ffffff08}.mobile-menu-user-info{display:flex;flex-direction:column;gap:4px}.mobile-user-name{font-weight:600;color:#fff;font-size:1rem}.mobile-user-email{font-size:.85rem;color:#fff9;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-user-badge{display:inline-block;padding:4px 10px;background:#4caf5033;color:#4caf50;border-radius:12px;font-size:.7rem;font-weight:600;margin-top:6px;text-transform:uppercase;letter-spacing:.05em;width:fit-content}.mobile-menu-items{padding:8px}.mobile-menu-item{display:flex;align-items:center;gap:12px;padding:12px 14px;color:#ffffffd9;border-radius:10px;transition:all .2s ease;cursor:pointer;background:none;border:none;width:100%;text-align:left;font-size:.95rem;font-family:inherit;margin-bottom:4px}.mobile-menu-item:last-child{margin-bottom:0}.mobile-menu-item:active{background:#ffffff1f;transform:scale(.98)}.mobile-menu-item svg{flex-shrink:0}.mobile-menu-item.logout{color:#ff6b6b;margin-top:4px;border-top:1px solid rgba(255,255,255,.08);padding-top:16px}.mobile-menu-item.logout:active{background:#ff6b6b26}#main-container{padding-top:60px;padding-left:0;padding-right:0}#bbox-panel{padding-top:12px;padding-left:0;padding-right:0}.model-preview-titlebar{display:flex;flex-direction:row;align-items:center;justify-content:space-between;width:100%;padding:8px 12px 0;box-sizing:border-box}.model-preview-titlebar h3{font-size:1.1em;margin:0;flex:1 1 auto;text-align:left;font-weight:600;color:#222}.close-button.top-right{font-size:1.3em;width:36px;height:36px;min-width:36px;min-height:36px;max-width:36px;max-height:36px;border-radius:50%;background:#eee;color:#900;border:none;margin-left:8px;margin-right:0;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 1px 4px #00000012;transition:background .15s;position:static}.close-button.top-right:hover,.close-button.top-right:active{background:#ffb3b3;color:#900}.model-actions{justify-content:center}.model-actions .download-button{font-size:.98em;padding:8px 18px;border-radius:6px;margin:0 auto;min-width:0;min-height:0;max-width:220px;width:auto;display:block;box-sizing:border-box}.model-info,.model-stats{font-size:.85em!important;padding:0 6px!important;margin:0!important;line-height:1.2!important}.model-info p,.model-stats p{margin:2px 0!important;padding:0!important}.preview-3d{width:90%!important;height:40vh!important;padding:10px!important;margin:3vh auto 0!important;box-sizing:border-box;background:#f7f7f7;flex:none!important;min-height:unset!important;min-width:unset!important}.download-button{font-size:.95em!important;padding:2px 14px!important;border-radius:18px!important;margin:10px auto 0!important;display:flex!important;align-items:center!important;justify-content:center!important;min-width:auto!important;width:auto!important;max-width:100%!important;min-height:24px!important;height:auto!important;box-sizing:border-box;text-align:center!important;white-space:nowrap!important;line-height:1.1!important;gap:6px}}@media (max-width: 480px){#map{height:40vh}#bbox-panel{min-height:60vh;padding:10px}.profile-pic{width:50px;height:50px}.personal-text h4{font-size:1.1em}#bbox-panel h2{font-size:18px}#bbox-list li{padding:12px;margin-bottom:12px}#bbox-list li .coordinates span{padding:6px;font-size:.8em}#draw-bbox-button{display:none!important;visibility:hidden!important}.generation-settings{padding:10px}.generation-settings input[type=number]{padding:6px}.model-preview{width:98%;height:95vh;padding:10px;margin:2.5vh auto}.model-preview h3{font-size:16px}}@media (max-width: 768px) and (orientation: landscape){body{flex-direction:column}#bbox-panel{width:100%;height:auto;min-height:50vh;order:1;padding:15px;border-left:none;border-bottom:1px solid #ddd;border-top:none;border-right:none;display:none;overflow-y:auto}#map{width:100%;height:100vh;order:2}#draw-bbox-button,#draw-bbox-button.desktop-only{display:none!important;visibility:hidden!important}}@media (pointer: coarse){button,.leaflet-control a{min-height:44px;min-width:44px}#bbox-list li .action-buttons button{min-height:44px;padding:12px}.generation-settings input[type=number],.generation-settings select{min-height:44px;font-size:16px}.leaflet-control-zoom a{width:32px!important;height:32px!important;line-height:32px!important;font-size:16px!important}.leaflet-control-layers{padding:6px 8px!important}.leaflet-control-layers label{padding:2px 0!important;font-size:12px!important;min-height:20px!important}}@media (max-width: 768px){#bbox-panel{-webkit-overflow-scrolling:touch;scroll-behavior:smooth}body{padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom)}#mobile-toggle-button{top:calc(20px + env(safe-area-inset-top));left:calc(20px + env(safe-area-inset-left))}#draw-bbox-button{display:none!important;visibility:hidden!important}}@supports (padding: max(0px)){@media (max-width: 768px){body{padding-top:max(20px,env(safe-area-inset-top));padding-bottom:max(20px,env(safe-area-inset-bottom))}}}.generation-settings label[for^=resolution-reduction]{margin-top:15px}@media (min-width: 769px){.mobile-only{display:none!important}#bbox-panel{display:flex!important;width:35%!important;height:100vh!important;position:static!important}#map{width:65%!important;height:100vh!important}}.leaflet-top .leaflet-control-geocoder{margin-top:70px!important}@media (max-width: 768px){.leaflet-top .leaflet-control-geocoder{margin-top:24px!important}}@media (min-width: 769px){.model-preview .download-button{display:flex!important;align-items:center!important;justify-content:center!important;margin:24px auto 0!important;padding:0 10px!important;font-size:15px!important;width:90vw!important;max-width:420px!important;min-width:180px!important;height:38px!important;min-height:0!important;border-radius:8px;text-align:center;line-height:1.2;box-sizing:border-box;background:#64b5f6;color:#fff;font-weight:700;transition:background .2s}.model-preview .download-button:hover{background:#2196f3}}@media (max-width: 768px){.model-preview .download-button{display:flex!important;align-items:center!important;justify-content:center!important;margin:24px auto 0!important;width:220px!important;height:44px!important;min-height:0!important;font-size:16px!important;border-radius:10px;background:#1976d2;color:#fff;font-weight:700;box-shadow:0 2px 8px #1976d21a;text-align:center;line-height:1.2;box-sizing:border-box;border:none;transition:background .2s}.model-preview .download-button:active{background:#1565c0}}@media (max-width: 768px){.model-preview .download-button{height:44px!important;min-height:0!important;max-height:44px!important;line-height:44px!important;padding-top:0!important;padding-bottom:0!important;box-sizing:border-box!important}}.modal{display:none;position:fixed;z-index:10000;left:0;top:0;width:100%;height:100%;background-color:#00000080;backdrop-filter:blur(4px);animation:fadeIn .3s ease}.modal.active{display:flex;align-items:center;justify-content:center}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background-color:#fff;border-radius:12px;width:90%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 8px 32px #0000004d;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px 30px;border-bottom:2px solid #eee}.modal-header h2{margin:0;font-size:24px;color:#333;display:flex;align-items:center;gap:10px}.modal-close{background:none;border:none;font-size:32px;color:#999;cursor:pointer;line-height:1;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.modal-close:hover{background:#f0f0f0;color:#333}.modal-body{padding:30px}.settings-section{margin-bottom:20px}.settings-section h3{margin:0 0 10px;font-size:20px;color:#333}.settings-description{color:#666;line-height:1.6;margin-bottom:20px}.api-key-status{display:flex;align-items:center;gap:10px;padding:12px 16px;background:#f5f5f5;border-radius:8px;margin-bottom:20px}.status-indicator{font-size:20px}#status-text{font-weight:500;color:#666}.api-key-status.configured{background:#e8f5e9}.api-key-status.configured #status-text{color:#2e7d32}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:600;color:#333}.form-control{width:100%;padding:12px 16px;border:2px solid #ddd;border-radius:8px;font-size:14px;transition:border-color .3s ease;box-sizing:border-box}.form-control:focus{outline:none;border-color:#2196f3;box-shadow:0 0 0 3px #2196f31a}.form-help{display:block;margin-top:8px;color:#666;font-size:13px}.form-help a{color:#2196f3;text-decoration:none;font-weight:600}.form-help a:hover{text-decoration:underline}.button-group{display:flex;gap:12px;margin-bottom:20px}.btn{padding:12px 24px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-primary{background:#2196f3;color:#fff}.btn-primary:hover{background:#1976d2;transform:translateY(-1px);box-shadow:0 4px 8px #2196f34d}.btn-secondary{background:#f5f5f5;color:#666}.btn-secondary:hover{background:#e0e0e0}.btn:active{transform:translateY(0)}.settings-info{background:#fff3e0;padding:16px;border-radius:8px;border-left:4px solid #ff9800}.settings-info h4{margin:0 0 12px;font-size:16px;color:#e65100;display:flex;align-items:center;gap:8px}.settings-info ul{margin:0;padding-left:20px}.settings-info li{color:#666;margin-bottom:8px;line-height:1.5}@media (max-width: 768px){.modal-content{width:95%;max-height:85vh}.modal-header{padding:20px}.modal-header h2{font-size:20px}.modal-body{padding:20px}.button-group{flex-direction:column}.btn{width:100%}}input[type=color]{width:100%;height:50px;border:2px solid #ddd;border-radius:8px;cursor:pointer;padding:4px;transition:border-color .3s ease,box-shadow .3s ease}input[type=color]:hover{border-color:#2196f3}input[type=color]:focus{outline:none;border-color:#2196f3;box-shadow:0 0 0 3px #2196f31a}.color-preview{margin-top:8px;min-height:60px}[id^=solid-color-controls-],[id^=topo-color-controls-]{margin-top:10px;padding:10px;background-color:#f9f9f9;border-radius:8px;border:1px solid #e0e0e0}.generation-settings select#color-mode{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-weight:600}.generation-settings h4{color:#444;font-size:16px;margin-bottom:12px}select#color-scheme{background:linear-gradient(135deg,#11998e,#38ef7d);color:#fff;font-weight:600;border:none;padding:10px}select#color-scheme option{background:#fff;color:#333}.input-valid{border:2px solid #4CAF50!important;box-shadow:0 0 0 3px #4caf501a;transition:all .3s ease}.input-invalid{border:2px solid #f44336!important;box-shadow:0 0 0 3px #f443361a;animation:shake .5s ease;transition:all .3s ease}.validation-error{color:#f44336;font-size:12px;margin-top:4px;display:block;animation:fadeIn .3s ease}.validation-summary{position:fixed;top:20px;right:20px;background:#fff3cd;border:2px solid #ffc107;border-radius:8px;padding:16px;max-width:400px;z-index:10000;box-shadow:0 4px 12px #0000004d;animation:slideInRight .3s ease}.validation-summary-content h4{margin:0 0 12px;color:#856404;font-size:18px}.validation-summary-content ul{margin:0;padding-left:20px;color:#856404}.validation-summary-content li{margin-bottom:8px}@keyframes shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-5px)}20%,40%,60%,80%{transform:translate(5px)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{transform:translate(400px);opacity:0}to{transform:translate(0);opacity:1}}.area-warning-notification{position:fixed;top:20px;right:20px;background:linear-gradient(135deg,#ff9800,#f57c00);color:#fff;padding:16px 24px;border-radius:8px;box-shadow:0 4px 12px #0000004d;z-index:10001;max-width:400px;animation:slideInRight .3s ease}.area-warning-notification .warning-content{display:flex;align-items:flex-start;gap:12px}.area-warning-notification .warning-icon{font-size:24px;flex-shrink:0}.area-warning-notification .warning-text{flex:1}.area-warning-notification .warning-text strong{display:block;font-size:16px;margin-bottom:8px}.area-warning-notification .warning-text p{margin:4px 0;font-size:14px;line-height:1.4}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}.area-warning-badge{background:#fff3e0;border:1px solid #ff9800;border-radius:4px;padding:10px 12px;margin-top:12px;margin-bottom:16px;font-size:12px;color:#e65100;line-height:1.5;box-shadow:0 2px 4px #ff98001a}.area-warning-badge strong{display:block;margin-bottom:6px;font-size:13px}.processing-mode-intro{text-align:center;margin-bottom:32px}.processing-mode-subtitle{font-size:16px;color:#666;margin:0;font-weight:400;line-height:1.6}.processing-mode-options{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:24px}.processing-mode-card{position:relative;cursor:pointer;transition:all .4s cubic-bezier(.4,0,.2,1)}.processing-mode-card .card-content{position:relative;display:flex;flex-direction:column;align-items:center;text-align:center;padding:32px 24px;border:4px solid #d0d0d0;border-radius:20px;background:linear-gradient(135deg,#fff,#f5f5f5);transition:all .4s cubic-bezier(.4,0,.2,1);height:100%;overflow:hidden;box-shadow:0 4px 12px #00000014,inset 0 0 #1976d200}.processing-mode-card .card-content:before{content:"";position:absolute;top:0;left:0;right:0;height:6px;background:linear-gradient(90deg,#1976d2,#42a5f5);transform:scaleX(0);transform-origin:center;transition:transform .4s cubic-bezier(.4,0,.2,1)}.processing-mode-card .card-content:after{content:"✓ SELECTED";position:absolute;top:16px;right:16px;background:linear-gradient(135deg,#1976d2,#1565c0);color:#fff;padding:6px 14px;border-radius:20px;font-size:11px;font-weight:800;letter-spacing:1px;opacity:0;transform:scale(.8) translateY(-10px);transition:all .4s cubic-bezier(.4,0,.2,1);box-shadow:0 3px 10px #1976d266}.processing-mode-card.active .card-content{border-color:#1976d2;border-width:5px;background:linear-gradient(135deg,#e3f2fd,#bbdefb);box-shadow:0 12px 32px #1976d24d,inset 0 0 0 3px #1976d21a;transform:translateY(-6px) scale(1.02)}.processing-mode-card.active .card-content:before{transform:scaleX(1)}.processing-mode-card.active .card-content:after{opacity:1;transform:scale(1) translateY(0)}.processing-mode-card:hover .card-content{border-color:#64b5f6;border-width:5px;transform:translateY(-8px) scale(1.03);box-shadow:0 16px 40px #00000026;cursor:pointer}.processing-mode-card.active:hover .card-content{border-color:#1565c0;box-shadow:0 16px 40px #1976d259;cursor:pointer}.processing-mode-card:active .card-content{transform:translateY(-2px) scale(.98);transition:all .1s ease}.card-icon-wrapper{margin-bottom:20px}.card-icon-circle{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#1976d2,#42a5f5);display:flex;align-items:center;justify-content:center;box-shadow:0 6px 20px #1976d266;transition:all .4s cubic-bezier(.4,0,.2,1)}.card-icon-circle.cloud-icon{background:linear-gradient(135deg,#ff9800,#ffb74d);box-shadow:0 6px 20px #ff980066}.processing-mode-card:hover .card-icon-circle{transform:scale(1.15) rotate(10deg);box-shadow:0 8px 24px #1976d280}.processing-mode-card.active .card-icon-circle{transform:scale(1.1);box-shadow:0 8px 24px #1976d299}.card-icon-circle svg{color:#fff;filter:drop-shadow(0 2px 6px rgba(0,0,0,.3))}.card-details{width:100%}.card-header{display:flex;flex-direction:column;align-items:center;gap:12px;margin-bottom:16px}.card-title{font-size:22px;font-weight:700;color:#1a1a1a;margin:0;line-height:1.2}.card-badge{padding:6px 16px;border-radius:24px;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:1.2px;white-space:nowrap;box-shadow:0 2px 8px #0003;transition:all .3s ease}.card-badge-free{background:linear-gradient(135deg,#4caf50,#66bb6a);color:#fff}.card-badge-premium{background:linear-gradient(135deg,#ff9800,#ffb74d);color:#fff}.processing-mode-card.active .card-badge{transform:scale(1.05);box-shadow:0 3px 12px #0000004d}.card-description{font-size:14px;color:#666;line-height:1.6;margin:0 0 20px;min-height:42px}.card-features{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px;align-items:flex-start;width:100%}.card-features li{display:flex;align-items:center;gap:10px;font-size:13px;color:#555;font-weight:500;width:100%;padding:8px 12px;border-radius:8px;background:#fff9;transition:all .3s ease}.processing-mode-card.active .card-features li{background:#ffffffe6;color:#333}.processing-mode-card:hover .card-features li{transform:translate(4px)}.feature-icon{font-size:16px;flex-shrink:0}.cloud-notice{display:flex;align-items:flex-start;gap:14px;margin-top:20px;padding:16px 18px;background:linear-gradient(135deg,#fff3e0,#ffe0b2);border:2px solid #ffb74d;border-radius:12px;box-shadow:0 2px 8px #ff980026}.notice-icon{font-size:24px;flex-shrink:0;line-height:1}.notice-content{flex:1}.notice-content strong{display:block;color:#e65100;font-size:14px;margin-bottom:4px}.notice-content p{color:#bf360c;font-size:13px;line-height:1.5;margin:0}.processing-save-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;margin-top:24px;padding:14px 24px;font-size:16px;font-weight:600;background:linear-gradient(135deg,#1976d2,#1565c0);box-shadow:0 4px 12px #1976d24d;transition:all .3s ease}.processing-save-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #1976d266;background:linear-gradient(135deg,#1565c0,#0d47a1)}.processing-save-btn svg{flex-shrink:0}.generate-button-container{display:flex;align-items:center;gap:12px;margin-top:30px;flex-wrap:wrap}.generate-button{flex:1;min-width:200px}.processing-mode-badge{display:inline-flex;align-items:center;padding:6px 12px;border-radius:20px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;transition:all .3s ease;white-space:nowrap;box-shadow:0 2px 4px #0000001a}.processing-mode-badge.browser-mode{background:linear-gradient(135deg,#f5f5f5,#e0e0e0);color:#666;border:1px solid #ccc}.processing-mode-badge.cloud-mode{background:linear-gradient(135deg,#e3f2fd,#90caf9);color:#1976d2;border:1px solid #64b5f6}@media (max-width: 768px){.generate-button-container{flex-direction:row;justify-content:space-between}.generate-button{flex:0 1 auto;min-width:auto;flex-grow:1}.processing-mode-badge{font-size:10px;padding:5px 10px}}@media (max-width: 768px){.processing-mode-options{grid-template-columns:1fr;gap:20px}.processing-mode-card .card-content{padding:28px 20px}.card-icon-circle{width:70px;height:70px}.card-icon-circle svg{width:36px;height:36px}.card-title{font-size:20px}.card-description{font-size:13px;min-height:auto}.card-features li{font-size:12px;padding:6px 10px}.cloud-notice{flex-direction:column;gap:10px;padding:14px}.processing-save-btn{padding:12px 20px;font-size:15px}}#settings-modal.modal{background-color:#000c;backdrop-filter:blur(10px)}#settings-modal .modal-content{background-color:#fff;border:3px solid #e0e0e0;box-shadow:0 20px 60px #00000080;border-radius:16px}#settings-modal .modal-header{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);padding:30px 35px;border-bottom:2px solid #d0d0d0;border-radius:16px 16px 0 0}#settings-modal .modal-header h2{color:#1a1a1a!important;font-weight:700;font-size:26px}#settings-modal .modal-close{background:#00000014;color:#333!important;font-weight:300}#settings-modal .modal-close:hover{background:#f4433626;color:#f44336!important;transform:rotate(90deg)}#settings-modal .modal-body{background:#fff;padding:35px}#settings-modal .settings-section h3{color:#1a1a1a!important;font-weight:700;font-size:22px;margin-bottom:15px}#settings-modal .settings-description{color:#2c3e50!important;font-size:15px;line-height:1.7;margin-bottom:25px}#settings-modal .api-key-status{background:#f5f5f5;border:2px solid #d0d0d0;padding:18px 22px;border-radius:10px;box-shadow:0 2px 8px #00000014}#settings-modal .status-indicator{font-size:24px}#settings-modal #status-text{color:#1a1a1a!important;font-weight:700;font-size:16px}#settings-modal .api-key-status.configured{background:#e8f5e9;border-color:#4caf50}#settings-modal .api-key-status.configured #status-text{color:#1b5e20!important}#settings-modal .form-group label{color:#1a1a1a!important;font-weight:700;font-size:16px;margin-bottom:10px}#settings-modal .form-control{background:#fafafa;border:2px solid #d0d0d0;color:#1a1a1a!important;font-size:15px;padding:14px 18px;border-radius:10px;font-family:Courier New,Consolas,monospace;font-weight:600}#settings-modal .form-control:focus{background:#fff;border-color:#2196f3;box-shadow:0 0 0 4px #2196f333}#settings-modal .form-control::placeholder{color:#999!important;font-weight:400}#settings-modal .form-help{color:#444!important;font-size:14px;line-height:1.6;margin-top:10px}#settings-modal .form-help a{color:#2196f3!important;font-weight:700;text-decoration:none}#settings-modal .form-help a:hover{color:#1976d2!important;text-decoration:underline}#settings-modal .btn{font-size:16px;font-weight:700;padding:14px 28px;border-radius:10px;box-shadow:0 4px 12px #00000026;transition:all .3s ease}#settings-modal .btn-primary{background:linear-gradient(135deg,#2196f3,#1976d2);color:#fff!important;border:none}#settings-modal .btn-primary:hover{background:linear-gradient(135deg,#1976d2,#1565c0);transform:translateY(-3px);box-shadow:0 6px 16px #2196f366}#settings-modal .btn-secondary{background:#f5f5f5;color:#1a1a1a!important;border:2px solid #d0d0d0}#settings-modal .btn-secondary:hover{background:#e8e8e8;border-color:#b0b0b0;transform:translateY(-2px)}#settings-modal .settings-info{background:linear-gradient(135deg,#e3f2fd,#f1f8ff);border-left:5px solid #2196F3;padding:24px;border-radius:12px;box-shadow:0 2px 10px #2196f326;margin-top:25px}#settings-modal .settings-info h4{color:#1a1a1a!important;font-weight:700;font-size:18px;margin-bottom:15px}#settings-modal .settings-info ul{margin:0;padding-left:22px}#settings-modal .settings-info li{color:#2c3e50!important;font-size:14px;line-height:1.8;margin-bottom:10px;font-weight:500}#settings-modal .settings-info li::marker{color:#2196f3}@media (max-width: 768px){#settings-modal .modal-content{width:95%;max-height:85vh}#settings-modal .modal-header{padding:24px 20px}#settings-modal .modal-header h2{font-size:22px}#settings-modal .modal-body{padding:24px 20px}#settings-modal .btn{font-size:15px;padding:12px 20px}}#subscription-modal.modal{background-color:#000c;backdrop-filter:blur(10px)}#subscription-modal .modal-content{background-color:#fff;border:3px solid #e0e0e0;box-shadow:0 20px 60px #00000080;border-radius:16px}#subscription-modal .modal-header{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);padding:30px 35px;border-bottom:2px solid #d0d0d0;border-radius:16px 16px 0 0}#subscription-modal .modal-header h2{color:#1a1a1a!important;font-weight:700;font-size:26px}#subscription-modal .modal-close{background:#00000014;color:#333!important;font-weight:300}#subscription-modal .modal-close:hover{background:#f4433626;color:#f44336!important;transform:rotate(90deg)}#subscription-modal .modal-body{background:#fff;padding:35px}#subscription-modal .settings-section h3{color:#1a1a1a!important;font-weight:700;font-size:22px;margin-bottom:15px}#subscription-modal .settings-description{color:#2c3e50!important;font-size:15px;line-height:1.7;margin-bottom:25px}.subscription-status{background:linear-gradient(135deg,#e8f5e9,#f1f8ff);border:2px solid #4caf50;border-radius:12px;padding:24px;margin-bottom:30px;box-shadow:0 4px 12px #4caf5026}.status-badge{display:flex;align-items:center;gap:12px;margin-bottom:12px}.status-icon{font-size:28px}#subscription-tier-text{color:#1a1a1a!important;font-weight:700;font-size:20px}.subscription-description{color:#2c3e50!important;font-size:15px;line-height:1.6;margin:0}.subscription-action-section{margin-top:30px;padding-top:30px;border-top:2px solid #e0e0e0}.subscription-action-section h3{color:#1a1a1a!important;font-weight:700;font-size:20px;margin-bottom:12px}.beta-info-box{background:linear-gradient(135deg,#e3f2fd,#f1f8ff);border:2px solid #2196F3;border-radius:10px;padding:18px;margin:15px 0;box-shadow:0 2px 8px #2196f31a}.beta-info-box p{color:#1a1a1a!important;font-size:14px;line-height:1.6;margin:0 0 10px}.beta-info-box p:last-child{margin-bottom:0}.beta-info-box strong{color:#1976d2!important;font-weight:700;font-size:15px}.danger-zone{background:linear-gradient(135deg,#f443360d,#f4433605);border:2px solid rgba(244,67,54,.3);border-radius:12px;padding:24px;margin-top:30px}.danger-zone h3{color:#d32f2f!important;font-size:20px;margin-bottom:15px}.warning-box{background:#ff98001a;border:2px solid rgba(255,152,0,.4);border-radius:8px;padding:16px;margin:20px 0}.warning-box p{color:#1a1a1a!important;font-size:14px;line-height:1.6;margin:0}.warning-box strong{color:#e65100!important;font-weight:700}#subscription-modal .btn{font-size:16px;font-weight:700;padding:14px 28px;border-radius:10px;box-shadow:0 4px 12px #00000026;transition:all .3s ease;cursor:pointer;border:none}#subscription-modal .btn-primary{background:linear-gradient(135deg,#2196f3,#1976d2);color:#fff!important}#subscription-modal .btn-primary:hover{background:linear-gradient(135deg,#1976d2,#1565c0);transform:translateY(-3px);box-shadow:0 6px 16px #2196f366}#resubscribe-button{background:linear-gradient(135deg,#4caf50,#388e3c)!important;color:#fff!important;font-weight:600!important;position:relative;overflow:hidden}#resubscribe-button:before{content:"✨";margin-right:6px}#resubscribe-button:hover{background:linear-gradient(135deg,#388e3c,#2e7d32)!important;transform:translateY(-3px);box-shadow:0 6px 16px #4caf5080!important}#subscription-modal .btn-warning{background:linear-gradient(135deg,#ff9800,#f57c00);color:#fff!important}#subscription-modal .btn-warning:hover{background:linear-gradient(135deg,#f57c00,#e65100);transform:translateY(-3px);box-shadow:0 6px 16px #ff980066}#subscription-modal .btn-danger{background:linear-gradient(135deg,#f44336,#d32f2f);color:#fff!important}#subscription-modal .btn-danger:hover{background:linear-gradient(135deg,#d32f2f,#b71c1c);transform:translateY(-3px);box-shadow:0 6px 16px #f4433666}@media (max-width: 768px){#subscription-modal .modal-content{width:95%;max-height:85vh}#subscription-modal .modal-header{padding:24px 20px}#subscription-modal .modal-header h2{font-size:22px}#subscription-modal .modal-body{padding:24px 20px}#subscription-modal .btn{font-size:15px;width:100%}#cancel-subscription-section>div[style*=flex]{flex-direction:column!important}#cancel-subscription-section>div[style*=flex] button{width:100%!important}.subscription-status{padding:20px}#subscription-tier-text{font-size:18px}.danger-zone{padding:20px}.warning-box{padding:14px}}#welcome-modal.modal{background-color:#000c;backdrop-filter:blur(10px)}#welcome-modal .modal-content{background-color:#fff;border:3px solid #e0e0e0;box-shadow:0 20px 60px #00000080;border-radius:16px;max-width:650px;max-height:90vh;display:flex;flex-direction:column}#welcome-modal .modal-header{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);padding:20px 30px;border-bottom:2px solid #d0d0d0;border-radius:16px 16px 0 0;flex-shrink:0}#welcome-modal .modal-header h2{color:#1a1a1a!important;font-weight:700;font-size:24px;margin:0}#welcome-modal .modal-close{background:#00000014;color:#333!important;font-weight:300}#welcome-modal .modal-close:hover{background:#f4433626;color:#f44336!important;transform:rotate(90deg)}#welcome-modal .modal-body{background:#fff;padding:25px 30px;overflow-y:auto;flex:1;min-height:0}#welcome-modal .settings-section h3{color:#1a1a1a!important;font-weight:700;font-size:20px;margin:0 0 10px}#welcome-modal .settings-description{color:#2c3e50!important;font-size:14px;line-height:1.6;margin-bottom:18px}.welcome-steps{margin:18px 0}.welcome-step{display:flex;align-items:flex-start;gap:12px;margin-bottom:12px;padding:14px;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-radius:10px;border-left:3px solid #2196F3;box-shadow:0 2px 6px #0000000f;transition:transform .2s ease,box-shadow .2s ease}.welcome-step:hover{transform:translateY(-2px);box-shadow:0 3px 10px #2196f326}.step-number{background:linear-gradient(135deg,#2196f3,#1976d2);color:#fff;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px;flex-shrink:0;box-shadow:0 2px 6px #2196f34d}.step-content{flex:1}.step-content h4{color:#1a1a1a!important;font-weight:700;font-size:15px;margin:0 0 4px}.step-content p{color:#2c3e50!important;font-size:13px;line-height:1.5;margin:0}#welcome-modal .welcome-info{background:linear-gradient(135deg,#e8f5e9,#f1f8e9);border-left:4px solid #4caf50;padding:14px 18px;border-radius:10px;box-shadow:0 2px 8px #4caf501f;margin-top:18px;margin-bottom:18px}#welcome-modal .welcome-info h4{color:#1a1a1a!important;font-weight:700;font-size:15px;margin:0 0 10px}#welcome-modal .welcome-info ul{margin:0;padding-left:20px}#welcome-modal .welcome-info li{color:#2c3e50!important;font-size:13px;line-height:1.6;margin-bottom:6px;font-weight:500}#welcome-modal .welcome-info li:last-child{margin-bottom:0}#welcome-modal .welcome-info li::marker{color:#4caf50}.welcome-checkbox-container{margin:18px 0;padding:14px;background:#f5f5f5;border:2px solid #d0d0d0;border-radius:8px}.welcome-checkbox-label{display:flex;align-items:center;gap:10px;cursor:pointer;color:#1a1a1a!important;font-size:14px;font-weight:600;margin:0}.welcome-checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#2196F3;flex-shrink:0}.welcome-checkbox-label span{color:#1a1a1a!important;user-select:none}#welcome-modal .btn{font-size:15px;font-weight:700;padding:12px 24px;border-radius:10px;box-shadow:0 4px 12px #00000026;transition:all .3s ease;cursor:pointer;border:none;width:100%}#welcome-modal .btn-primary{background:linear-gradient(135deg,#2196f3,#1976d2);color:#fff!important}#welcome-modal .btn-primary:hover{background:linear-gradient(135deg,#1976d2,#1565c0);transform:translateY(-2px);box-shadow:0 6px 16px #2196f366}@media (max-width: 768px){#welcome-modal .modal-content{width:95%;max-width:95%;max-height:92vh;margin:4vh auto}#welcome-modal .modal-header{padding:16px 18px}#welcome-modal .modal-header h2{font-size:20px}#welcome-modal .modal-body{padding:18px}#welcome-modal .settings-section h3{font-size:18px;margin-bottom:8px}#welcome-modal .settings-description{font-size:13px;margin-bottom:14px}.welcome-steps{margin:14px 0}.welcome-step{padding:12px;gap:10px;margin-bottom:10px}.step-number{width:28px;height:28px;font-size:14px}.step-content h4{font-size:14px;margin-bottom:3px}.step-content p{font-size:12px;line-height:1.4}#welcome-modal .welcome-info{padding:12px 14px;margin-top:14px;margin-bottom:14px}#welcome-modal .welcome-info h4{font-size:14px;margin-bottom:8px}#welcome-modal .welcome-info li{font-size:12px;line-height:1.5;margin-bottom:5px}.welcome-checkbox-container{padding:12px;margin:14px 0}.welcome-checkbox-label{font-size:13px;gap:8px}.welcome-checkbox-label input[type=checkbox]{width:16px;height:16px}#welcome-modal .btn{font-size:14px;padding:11px 18px}}
