.contact-form-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:2000;padding:20px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.contact-form-modal{background:#fff;border-radius:12px;width:100%;max-width:520px;max-height:90vh;overflow:hidden;box-shadow:0 20px 60px #0000004d;animation:contactFormSlideIn .3s ease-out;display:flex;flex-direction:column}@keyframes contactFormSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.contact-form-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;background:linear-gradient(135deg,#a63d2e,#c74634);color:#fff}.contact-form-header h2{margin:0;font-size:18px;font-weight:600}.contact-form-close{background:none;border:none;color:#fff;font-size:28px;line-height:1;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background .2s ease}.contact-form-close:hover{background:#fff3}.contact-form-body{padding:24px;overflow-y:auto;flex:1;min-height:0;scroll-behavior:auto}.contact-form-body>form:first-child{display:block}.contact-form-body .form-group{display:block;width:100%;box-sizing:border-box}.contact-form-body input,.contact-form-body select,.contact-form-body textarea{display:block;box-sizing:border-box;min-height:40px}.contact-form-body textarea{min-height:120px}.contact-form-body .form-group{margin-bottom:20px;display:block!important;visibility:visible!important;opacity:1!important}.contact-form-body .form-group label{display:block;font-size:14px;font-weight:600;color:#312d2a!important;margin-bottom:6px}.contact-form-body .form-group input,.contact-form-body .form-group select,.contact-form-body .form-group textarea{width:100%;padding:10px 14px;border:1px solid #ddd!important;border-radius:6px;font-size:14px;font-family:inherit;transition:all .2s ease;background:#fff!important;color:#312d2a!important;display:block!important;visibility:visible!important;opacity:1!important;position:static!important;clip:auto!important;clip-path:none!important;overflow:visible!important}.contact-form-body .form-group input:focus,.contact-form-body .form-group select:focus,.contact-form-body .form-group textarea:focus{outline:none;border-color:#c74634!important;box-shadow:0 0 0 3px #2474ad1a;background:#fff!important;color:#312d2a!important}.contact-form-body .form-group input:disabled,.contact-form-body .form-group select:disabled,.contact-form-body .form-group textarea:disabled{background:#f5f5f5!important;cursor:not-allowed}.contact-form-body .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='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23666' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px;background-color:#fff!important;color:#312d2a!important}.contact-form-body .form-group textarea{resize:vertical;min-height:120px;background:#fff!important;color:#312d2a!important}.contact-form-body .form-group input::placeholder,.contact-form-body .form-group textarea::placeholder{color:#999!important;opacity:1!important}.contact-form-body .field-description{display:block;font-size:12px;color:#5c5c5c!important;margin-top:4px}.contact-form-error{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#fff3f3;border:1px solid #ffcdd2;border-radius:6px;color:#c62828;font-size:14px;margin-bottom:20px}.error-icon{font-size:16px;flex-shrink:0}.contact-form-success{text-align:center;padding:20px 10px}.success-icon{width:64px;height:64px;background:linear-gradient(135deg,#4caf50,#2e7d32);color:#fff;font-size:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;margin:0 auto 20px;animation:successPulse .5s ease-out}@keyframes successPulse{0%{transform:scale(0)}50%{transform:scale(1.1)}to{transform:scale(1)}}.contact-form-success h3{margin:0 0 12px;font-size:20px;color:#2e7d32}.contact-form-success p{margin:0 0 8px;color:#5c5c5c;font-size:14px}.contact-form-issue-ref{margin:8px 0 16px;font-size:14px;color:#312d2a}.contact-form-issue-ref strong{color:#a63d2e}.contact-form-success .success-detail{color:#999;font-size:13px;margin-bottom:20px}.contact-form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:8px}.btn-cancel,.btn-submit,.btn-view-issue,.btn-close-success{padding:10px 20px;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;border:none}.btn-cancel{background:#f5f5f5;color:#5c5c5c}.btn-cancel:hover:not(:disabled){background:#e0e0e0}.btn-submit{background:linear-gradient(135deg,#c74634,#a63d2e);color:#fff;display:flex;align-items:center;gap:8px}.btn-submit:hover:not(:disabled){background:linear-gradient(135deg,#a63d2e,#124a70);transform:translateY(-1px);box-shadow:0 4px 12px #c746344d}.btn-submit:disabled{opacity:.7;cursor:not-allowed}.btn-view-issue{background:linear-gradient(135deg,#4caf50,#2e7d32);color:#fff;margin-bottom:12px}.btn-view-issue:hover{background:linear-gradient(135deg,#2e7d32,#1b5e20);transform:translateY(-1px);box-shadow:0 4px 12px #4caf504d}.btn-close-success{background:#f5f5f5;color:#5c5c5c}.btn-close-success:hover{background:#e0e0e0}.spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@media (max-width: 480px){.contact-form-overlay{padding:10px}.contact-form-modal{max-height:95vh}.contact-form-header{padding:16px 20px}.contact-form-body{padding:20px}.contact-form-actions{flex-direction:column-reverse}.btn-cancel,.btn-submit{width:100%;justify-content:center}}.app-header{background:linear-gradient(135deg,#312d2a,#c74634);color:#fff;box-shadow:0 2px 8px #00000026;position:sticky;top:0;z-index:1000}.header-content{display:flex;align-items:center;justify-content:space-between;max-width:1400px;margin:0 auto;padding:0 16px;height:42px}.header-logo{display:flex;align-items:center;gap:10px;text-decoration:none;color:#fff}.logo-icon{width:24px;height:24px}.logo-icon svg{width:100%;height:100%}.logo-text{font-size:14px;font-weight:600;letter-spacing:-.3px}.header-nav{display:flex;align-items:center;gap:8px}.nav-link{padding:5px 12px;color:#ffffffd9;text-decoration:none;font-size:13px;font-weight:500;border-radius:4px;transition:all .2s ease}.nav-link:hover{color:#fff;background:#ffffff1a}.nav-link.active{color:#fff;background:#ffffff26}.topology-dropdown{position:relative}.dropdown-toggle{display:flex;align-items:center;gap:6px;padding:5px 10px;background:#ffffff26;border:1px solid rgba(255,255,255,.3);border-radius:4px;color:#fff;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease}.dropdown-toggle:hover{background:#ffffff40;border-color:#ffffff80}.dropdown-chevron{transition:transform .2s ease}.dropdown-chevron.open{transform:rotate(180deg)}.dropdown-menu{position:absolute;top:calc(100% + 8px);right:0;min-width:320px;white-space:nowrap;background:#fff;border-radius:8px;box-shadow:0 4px 16px #00000026;margin:0;padding:6px 0;z-index:1001;max-height:70vh;overflow-y:auto}.dropdown-menu-list{list-style:none;margin:0;padding:0}.dropdown-menu-list>li{margin:0}.dropdown-group{border-top:1px solid #f0eded}.dropdown-group:first-of-type{border-top:none}.dropdown-group-header{display:flex;align-items:center;gap:8px;width:100%;padding:8px 14px;background:#faf9f8;border:none;text-align:left;font-size:12px;font-weight:600;color:#6b6460;text-transform:uppercase;letter-spacing:.5px;cursor:pointer;transition:all .15s ease}.dropdown-group-header:hover{background:#f5f3f1;color:#312d2a}.group-chevron{transition:transform .2s ease;flex-shrink:0}.group-chevron.open{transform:rotate(90deg)}.group-count{margin-left:auto;font-size:11px;font-weight:500;color:#a09890;background:#f0eded;padding:1px 6px;border-radius:10px}.dropdown-group-items{list-style:none;margin:0;padding:0}.dropdown-group-items li{margin:0}.dropdown-item{display:block;width:100%;padding:8px 16px 8px 34px;background:none;border:none;text-align:left;font-size:13px;color:#312d2a;cursor:pointer;transition:all .15s ease}.dropdown-item:hover{background:#fff5f4;color:#c74634}.dropdown-item.active{background:#c74634;color:#fff}.dropdown-menu-list>li:first-child>.dropdown-item{padding-left:16px;font-weight:500}.contact-btn{display:flex;align-items:center;gap:6px;padding:6px 12px;background:#ffffff1f;border:1px solid rgba(255,255,255,.25);border-radius:6px;color:#fff;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease;margin-left:12px;white-space:nowrap}.contact-btn:hover{background:#ffffff40;border-color:#fff6;transform:translateY(-1px);box-shadow:0 2px 8px #00000026}.contact-btn:active{transform:translateY(0)}.contact-btn svg{flex-shrink:0}@media (max-width: 768px){.contact-btn span{display:none}}.user-menu{position:relative;margin-left:10px}.user-menu-toggle{display:flex;align-items:center;gap:6px;padding:4px 10px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:16px;color:#fff;font-size:12px;cursor:pointer;transition:all .2s ease}.user-menu-toggle:hover{background:#fff3;border-color:#fff6}.user-avatar{width:22px;height:22px;border-radius:50%;background:linear-gradient(135deg,#c74634,#a63d2e);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:600}.user-name{font-weight:500}.user-dropdown-menu{position:absolute;top:calc(100% + 8px);right:0;min-width:200px;background:#fff;border-radius:10px;box-shadow:0 4px 20px #00000026;list-style:none;margin:0;padding:8px 0;z-index:1001;overflow:hidden}.user-dropdown-menu .user-info{padding:12px 16px;display:flex;flex-direction:column;gap:6px}.user-dropdown-menu .user-role{font-size:12px;color:#5c5c5c;text-transform:capitalize}.user-dropdown-menu .user-permission{display:inline-block;padding:3px 8px;border-radius:12px;font-size:10px;font-weight:600;width:fit-content;background:#4caf5026;color:#2e7d32}.user-dropdown-menu .menu-divider{height:1px;background:#eee;margin:4px 0}.user-dropdown-menu .dropdown-item{display:block;width:100%;padding:10px 16px;background:none;border:none;text-align:left;font-size:13px;color:#312d2a;cursor:pointer;transition:all .2s ease;text-decoration:none}.user-dropdown-menu .dropdown-item:hover{background:#f5f5f5}.user-dropdown-menu .dropdown-item.logout{color:#d32f2f}.user-dropdown-menu .dropdown-item.logout:hover{background:#ffebee}@media (max-width: 768px){.header-content{padding:0 16px}.header-nav{display:none}.logo-text{font-size:16px}.user-name{display:none}}.app-layout{min-height:100vh;display:flex;flex-direction:column;background:var(--oracle-bg, #F5F5F5)}.app-main{flex:1;display:flex;flex-direction:column}.app-footer{background:var(--oracle-bark, #312D2A);color:#ffffffbf;padding:6px 16px;text-align:center;font-size:11px}.app-footer p{margin:0}.home{padding:40px 24px}.container{max-width:1400px;margin:0 auto}.catalog-stats-banner{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}.stat-pill{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:20px;font-size:13px;font-weight:600;letter-spacing:.2px}.stat-available{background:#e8f5e9;color:#2e7d32}.stat-construction{background:#fff3e0;color:#e65100}.stat-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.available-dot{background:#4caf50}.construction-dot{background:#ff9800}.stat-divider{width:1px;height:16px;background:#ccc}.stat-updated{font-size:12px;color:#999;font-style:italic}.home-header{text-align:center;margin-bottom:40px}.home-header h1{font-size:36px;font-weight:700;color:#a63d2e;margin:0 0 16px;letter-spacing:-.5px}.subtitle{font-size:18px;color:#5c5c5c;max-width:700px;margin:0 auto;line-height:1.6}.filter-section{margin-bottom:32px;padding:24px;background:#f8f9fa;border-radius:12px;border:1px solid #e9ecef}.search-box{position:relative;margin-bottom:20px}.search-box svg{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:#6c757d;pointer-events:none}.search-box input{width:100%;padding:14px 16px 14px 48px;font-size:16px;border:2px solid #dee2e6;border-radius:8px;background:#fff;transition:all .2s ease;box-sizing:border-box}.search-box input:focus{outline:none;border-color:#c74634;box-shadow:0 0 0 3px #2474ad1a}.search-box input::placeholder{color:#adb5bd}.clear-search{position:absolute;right:16px;top:50%;transform:translateY(-50%);background:none;border:none;font-size:24px;color:#6c757d;cursor:pointer;padding:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.clear-search:hover{background:#e9ecef;color:#5c5c5c}.category-tabs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px;padding-bottom:8px;overflow-x:auto;scrollbar-width:thin;scrollbar-color:#adb5bd #f8f9fa}.category-tabs::-webkit-scrollbar{height:6px}.category-tabs::-webkit-scrollbar-track{background:#f8f9fa}.category-tabs::-webkit-scrollbar-thumb{background:#adb5bd;border-radius:3px}.category-tab{padding:8px 16px;font-size:14px;font-weight:500;color:#6c757d;background:#fff;border:1px solid #dee2e6;border-radius:20px;cursor:pointer;transition:all .2s ease;white-space:nowrap}.category-tab:hover{background:#e9ecef;color:#5c5c5c}.category-tab.active{background:#c74634;color:#fff;border-color:#c74634}.tag-filter-section{margin-top:16px;padding-top:16px;border-top:1px solid #e9ecef}.tag-filter-header{display:flex;flex-direction:column;gap:10px}.tag-filter-toggle{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;font-size:13px;font-weight:600;color:#5c5c5c;background:#fff;border:1px solid #dee2e6;border-radius:8px;cursor:pointer;transition:all .2s ease;align-self:flex-start}.tag-filter-toggle:hover{background:#e9ecef;border-color:#ced4da}.tag-filter-toggle.open{background:#f0f0f0;border-color:#ced4da}.tag-chevron{transition:transform .2s ease;margin-left:2px}.tag-filter-toggle.open .tag-chevron{transform:rotate(180deg)}.tag-count-badge{background:#c74634;color:#fff;font-size:11px;font-weight:700;padding:1px 7px;border-radius:10px;min-width:18px;text-align:center;line-height:1.4}.selected-tags-chips{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.selected-chip{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;font-size:12px;font-weight:500;color:#fff;background:#c74634;border:none;border-radius:16px;cursor:pointer;transition:background .15s ease}.selected-chip:hover{background:#a63d2e}.chip-remove{font-size:14px;font-weight:700;opacity:.7;line-height:1}.selected-chip:hover .chip-remove{opacity:1}.tag-clear-btn{padding:4px 10px;font-size:12px;color:#c74634;background:#fff;border:1px solid #C74634;border-radius:16px;cursor:pointer;transition:all .2s ease}.tag-clear-btn:hover{background:#c74634;color:#fff}.tag-filter-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:12px}.tag-group-card{background:#fff;border:1px solid #e9ecef;border-radius:8px;padding:12px}.tag-group-title{display:block;font-size:11px;font-weight:700;color:#6c757d;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;padding-bottom:6px;border-bottom:2px solid #e9ecef}.tag-pills{display:flex;flex-wrap:wrap;gap:6px}.tag-pill{padding:4px 10px;font-size:12px;color:#5c5c5c;background:#f8f9fa;border:1px solid #dee2e6;border-radius:16px;cursor:pointer;transition:all .2s ease;white-space:nowrap}.tag-pill:hover{background:#e9ecef;border-color:#ced4da}.tag-pill.active{background:#c74634;color:#fff;border-color:#c74634}.results-info{font-size:14px;color:#6c757d;text-align:center}.results-info strong{color:#c74634}.results-info em{color:#5c5c5c;font-style:normal;font-weight:500}.no-results{text-align:center;padding:60px 20px;color:#6c757d}.no-results-icon{font-size:48px;margin-bottom:16px}.no-results h3{margin:0 0 8px;color:#5c5c5c;font-size:20px}.no-results p{margin:0}.topology-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px;margin-bottom:60px}.topology-card{display:flex;flex-direction:column;background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;overflow:hidden;text-decoration:none;color:inherit;transition:all .3s ease;border:1px solid #e9ecef}.topology-card.available{cursor:pointer}.topology-card.available:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f;border-color:#c74634}.topology-card.placeholder{cursor:default;opacity:.75}.card-icon{padding:20px;background:linear-gradient(135deg,#f8f9fa,#e9ecef);display:flex;align-items:center;justify-content:center}.topo-icon{width:90px;height:68px}.card-content{padding:16px;flex:1}.card-header-row{display:flex;align-items:center;gap:8px;margin-bottom:8px}.card-code{font-size:11px;font-weight:600;color:#c74634;background:#e7f3ff;padding:2px 6px;border-radius:4px;text-transform:uppercase}.card-title{font-size:15px;font-weight:600;color:#312d2a;margin:0;line-height:1.3;flex:1}.card-description{font-size:13px;color:#5c5c5c;line-height:1.5;margin:0 0 12px}.card-features{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:6px}.card-features li{display:flex;align-items:center;gap:4px;font-size:11px;color:#555;background:#fff5f4;padding:3px 8px;border-radius:4px}.feature-check{color:#28a745;font-weight:700;font-size:10px}.card-action{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 16px;background:#c74634;color:#fff;font-size:13px;font-weight:500;transition:background .2s ease}.topology-card.available:hover .card-action{background:#a63d2e}.card-action svg{transition:transform .2s ease}.topology-card.available:hover .card-action svg{transform:translate(4px)}.card-action.disabled{background:#adb5bd;cursor:not-allowed}.construction-badge{display:flex;align-items:center;gap:6px;font-size:12px}.docs-section{margin-bottom:60px}.docs-card{display:flex;justify-content:space-between;gap:24px;align-items:center;background:#fff;border-radius:12px;padding:28px;box-shadow:0 2px 8px #00000014;border:1px solid #e9ecef}.docs-content h2{margin:0 0 10px;font-size:22px;color:#a63d2e}.docs-content p{margin:0 0 12px;color:#5c5c5c;line-height:1.6}.docs-content ul{margin:0;padding-left:18px;color:#555;line-height:1.6}.docs-btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 16px;background:#c74634;color:#fff;text-decoration:none;border-radius:6px;font-weight:600;font-size:14px;white-space:nowrap}.docs-btn:hover{background:#a63d2e}.features-section{background:#fff;border-radius:12px;padding:40px;box-shadow:0 2px 8px #00000014}.features-section h2{text-align:center;font-size:24px;font-weight:600;color:#312d2a;margin:0 0 16px}.features-intro{text-align:center;font-size:14px;color:#555;line-height:1.6;max-width:720px;margin:0 auto 32px}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:24px}.feature-item{text-align:center;padding:20px}.feature-icon{font-size:40px;margin-bottom:16px}.feature-item h4{font-size:16px;font-weight:600;color:#312d2a;margin:0 0 8px}.feature-item p{font-size:14px;color:#5c5c5c;line-height:1.5;margin:0 0 10px}.feature-who{display:inline-block;font-size:11px;font-weight:600;padding:3px 8px;border-radius:6px;text-transform:uppercase;letter-spacing:.02em}.feature-who-all{background:#e8f4ea;color:#2e7d32}.feature-who-deploy{background:#fff5f4;color:#c74634}.feature-who-admin{background:#f3e5f5;color:#7b1fa2}.home-footer{margin-top:48px;padding:24px 0;text-align:center;border-top:1px solid #e9ecef}.home-footer p{margin:0;color:#5c5c5c;font-size:14px}.author-link{color:#c74634;text-decoration:none;font-weight:500;transition:color .2s ease}.author-link:hover{color:#a63d2e;text-decoration:underline}@media (max-width: 768px){.home{padding:24px 16px}.home-header h1{font-size:28px}.subtitle{font-size:16px}.filter-section{padding:16px}.category-tabs{gap:6px}.category-tab{padding:6px 12px;font-size:12px}.tag-filter-grid,.topology-grid{grid-template-columns:1fr}.features-section{padding:24px}.docs-card{flex-direction:column;align-items:flex-start}}@media (max-width: 480px){.card-header-row{flex-direction:column;align-items:flex-start;gap:4px}}.availability-toggle{display:inline-flex;flex-direction:row;gap:12px;margin-bottom:16px;padding:4px;background:#f0f0f0;border-radius:24px;border:1px solid #dee2e6}.toggle-btn{padding:8px 16px;font-size:16px;font-weight:600;color:#6c757d;background:transparent;border:none;border-radius:20px;cursor:pointer;transition:all .2s ease;white-space:nowrap;position:relative;z-index:1;min-width:44px;display:flex;align-items:center;justify-content:center}.toggle-btn:hover{color:#5c5c5c}.toggle-btn.active{background:#fff;color:#28a745;box-shadow:0 2px 4px #0000001a}@media (min-width: 1200px){.tag-filter-grid{grid-template-columns:repeat(3,1fr)}}.login-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,#312d2a,#4a3f3d,#5c4d4a);font-family:Segoe UI,-apple-system,BlinkMacSystemFont,Helvetica Neue,Arial,sans-serif;padding:20px}.login-container{width:100%;max-width:360px;text-align:center}.login-logo{margin-bottom:24px}.logo-icon{width:64px;height:64px;margin:0 auto;background:#ffffff0f;border:1px solid rgba(255,255,255,.12);border-radius:16px;display:flex;align-items:center;justify-content:center;color:#c74634}.logo-icon svg{width:32px;height:32px}.login-title{margin-bottom:32px}.login-title h1{font-size:1.5rem;font-weight:600;margin-bottom:4px;color:#fff}.login-subtitle{font-size:.9rem;color:#ffffff80;margin:0}.login-success{background:#4caf5026;border:1px solid rgba(76,175,80,.4);color:#81c784;padding:12px 16px;border-radius:8px;margin-bottom:20px;font-size:.9rem}.login-error{display:flex;align-items:center;justify-content:center;gap:8px;background:#c7463426;border:1px solid rgba(199,70,52,.4);color:#ff8a80;padding:12px 16px;border-radius:8px;margin-bottom:20px;font-size:.9rem}.oracle-sso-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:12px;padding:14px 20px;background:#fff;border:1px solid #ddd;border-radius:8px;color:#333;font-size:1rem;font-weight:500;font-family:inherit;cursor:pointer;transition:all .2s ease;margin-bottom:16px;position:relative;z-index:1}.oracle-sso-btn:hover{background:#f5f5f5;border-color:#ccc;box-shadow:0 2px 8px #0000001a}.oracle-sso-btn:active{transform:scale(.98)}.oracle-icon{width:24px;height:24px;flex-shrink:0}.login-divider{position:relative;margin:16px 0;text-align:center}.login-divider:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background:#ffffff1a}.login-divider span{position:relative;display:inline-block;padding:0 16px;background:transparent;color:#fff6;font-size:.85rem}.local-login-section{width:100%}.local-login-toggle{width:100%;padding:12px;background:transparent;border:1px solid rgba(255,255,255,.2);border-radius:8px;color:#fffc;font-size:.95rem;font-family:inherit;cursor:pointer;transition:all .2s ease;position:relative;z-index:1}.local-login-toggle:hover{background:#ffffff0d;border-color:#ffffff4d}.local-login-toggle:active{transform:scale(.98)}.local-login-form{display:block;width:100%;text-align:left;background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:20px;margin-top:8px}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:6px;font-size:.85rem;color:#ffffffb3}.form-group input{width:100%;padding:12px 14px;border:1px solid rgba(255,255,255,.15);border-radius:8px;background:#ffffff0f;color:#fff;font-size:1rem;font-family:inherit;transition:all .2s ease;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#c74634;background:#ffffff14}.form-group input::placeholder{color:#ffffff4d}.local-error{background:#c7463426;border:1px solid rgba(199,70,52,.4);color:#ff8a80;padding:10px 12px;border-radius:6px;margin-bottom:16px;font-size:.85rem}.local-login-btn{width:100%;padding:12px;background:linear-gradient(135deg,#c74634,#a63d2e);border:none;border-radius:8px;color:#fff;font-size:1rem;font-weight:500;font-family:inherit;cursor:pointer;transition:all .2s ease;margin-bottom:10px;position:relative;z-index:1}.local-login-btn:hover{box-shadow:0 4px 12px #c7463466}.local-login-btn:active{transform:scale(.98)}.cancel-btn{width:100%;padding:10px;background:transparent;border:none;color:#ffffff80;font-size:.9rem;font-family:inherit;cursor:pointer;transition:color .2s ease;position:relative;z-index:1}.cancel-btn:hover{color:#fffc}.login-footer{margin-top:24px;font-size:.8rem;color:#fff6}.login-loading{min-height:100vh;display:flex;justify-content:center;align-items:center;background:linear-gradient(135deg,#312d2a,#4a3f3d)}.login-spinner{width:40px;height:40px;border:3px solid rgba(255,255,255,.1);border-top:3px solid #C74634;border-radius:50%}@media (max-width: 400px){.login-container{padding:0 16px}.local-login-form{padding:16px}}.profile-manager{background:#f0f4f8;border-radius:8px;border:1px solid #d1d9e0;margin-bottom:20px;overflow:hidden}.profile-manager-header{width:100%;display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:transparent;border:none;cursor:pointer;transition:background .2s ease}.profile-manager-header:hover{background:#6c5ce714}.profile-manager-title{margin:0;font-size:14px;font-weight:600;color:#495057;display:flex;align-items:center;gap:8px}.profile-manager-title:before{content:"";width:4px;height:16px;background:#6c5ce7;border-radius:2px}.collapse-icon{color:#6c757d;transition:transform .3s ease;flex-shrink:0}.profile-manager.collapsed .collapse-icon{transform:rotate(-90deg)}.profile-manager-content{padding:0 16px 16px;animation:slideDown .2s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.profile-message{padding:8px 12px;border-radius:6px;font-size:13px;margin-top:12px;margin-bottom:0;animation:fadeIn .2s ease}.profile-message.success{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.profile-message.error{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.profile-selector{margin-bottom:8px}.profile-select{width:100%;padding:10px 12px;border:1px solid #dee2e6;border-radius:6px;font-size:14px;color:#312d2a;background:#fff;cursor:pointer;transition:all .2s ease}.profile-select:focus{outline:none;border-color:#6c5ce7;box-shadow:0 0 0 3px #6c5ce71a}.profile-info{margin-bottom:12px;padding:6px 10px;background:#fff;border-radius:4px;border:1px solid #e9ecef}.profile-date{font-size:12px;color:#6c757d}.profile-actions{display:flex;gap:8px;margin-bottom:12px}.profile-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:8px 12px;border:none;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease}.profile-btn:disabled{opacity:.5;cursor:not-allowed}.profile-btn svg{flex-shrink:0}.save-btn{background:#e8f5e9;color:#2e7d32;border:1px solid #a5d6a7}.save-btn:hover:not(:disabled){background:#c8e6c9}.clone-btn{background:#e0f7fa;color:#00695c;border:1px solid #80cbc4}.clone-btn:hover:not(:disabled){background:#b2ebf2}.delete-btn{background:#ffebee;color:#c62828;border:1px solid #ef9a9a}.delete-btn:hover:not(:disabled){background:#ffcdd2}.profile-io{display:flex;gap:8px;padding-top:12px;border-top:1px solid #dee2e6}.export-btn{flex:1;background:#fff3e0;color:#e65100;border:1px solid #ffcc80}.export-btn:hover:not(:disabled){background:#ffe0b2}.import-btn{flex:1;background:#f3e5f5;color:#7b1fa2;border:1px solid #ce93d8}.import-btn:hover:not(:disabled){background:#e1bee7}.profile-dialog-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .15s ease}.profile-dialog{background:#fff;padding:24px;border-radius:12px;width:90%;max-width:400px;box-shadow:0 20px 60px #0000004d;animation:slideIn .2s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.profile-dialog h5{margin:0 0 12px;font-size:18px;font-weight:600;color:#312d2a}.profile-dialog p{margin:0 0 16px;font-size:14px;color:#5c5c5c}.profile-dialog input{width:100%;padding:12px 14px;border:2px solid #dee2e6;border-radius:8px;font-size:15px;color:#312d2a;box-sizing:border-box;transition:all .2s ease}.profile-dialog input:focus{outline:none;border-color:#6c5ce7;box-shadow:0 0 0 4px #6c5ce71a}.overwrite-warning{color:#f39c12!important;font-size:13px!important;margin-top:8px!important}.delete-warning{color:#c62828!important;font-size:13px!important;font-weight:500}.dialog-actions{display:flex;gap:12px;margin-top:20px}.dialog-btn{flex:1;padding:12px 20px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.dialog-btn.cancel{background:#f8f9fa;color:#495057;border:1px solid #dee2e6}.dialog-btn.cancel:hover{background:#e9ecef}.dialog-btn.confirm{background:linear-gradient(135deg,#6c5ce7,#5b4cdb);color:#fff}.dialog-btn.confirm:hover{transform:translateY(-1px);box-shadow:0 4px 12px #6c5ce766}.dialog-btn.delete{background:linear-gradient(135deg,#e74c3c,#c0392b);color:#fff}.dialog-btn.delete:hover{transform:translateY(-1px);box-shadow:0 4px 12px #e74c3c66}@media (max-width: 480px){.profile-actions{flex-wrap:wrap}.profile-btn{min-width:calc(50% - 4px)}.profile-io{flex-direction:column}}.cidr-calc-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:9000;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:24px 16px;box-sizing:border-box}.cidr-calc-modal{background:#fff;border-radius:12px;box-shadow:0 24px 64px #00000047;width:100%;max-width:800px;margin:0 auto}.cidr-calc-header{display:flex;align-items:center;justify-content:space-between;padding:18px 24px 14px;border-bottom:2px solid #C74634;position:sticky;top:0;background:#fff;z-index:2;border-radius:12px 12px 0 0}.cidr-calc-header-left{display:flex;align-items:center;gap:10px}.cidr-calc-header-icon{color:#c74634;flex-shrink:0}.cidr-calc-title{margin:0;font-size:17px;font-weight:700;color:#1a1a2e;line-height:1.3}.cidr-calc-subtitle{margin:2px 0 0;font-size:12px;color:#6c757d}.cidr-calc-close-btn{background:none;border:none;cursor:pointer;color:#6c757d;padding:6px;border-radius:6px;display:flex;align-items:center;transition:background .15s,color .15s}.cidr-calc-close-btn:hover{background:#f0f0f0;color:#312d2a}.cidr-calc-toolbar{display:flex;align-items:center;gap:10px;padding:14px 24px 12px;background:#f8f9fa;border-bottom:1px solid #e9ecef;flex-wrap:wrap;position:sticky;top:62px;z-index:2}.cidr-calc-toolbar-label{font-size:13px;font-weight:500;color:#495057;white-space:nowrap}.cidr-calc-base-select{padding:7px 10px;border:1px solid #dee2e6;border-radius:6px;font-size:13px;color:#312d2a;background:#fff;cursor:pointer;min-width:160px}.cidr-calc-base-select:focus{outline:none;border-color:#c74634;box-shadow:0 0 0 3px #2474ad1a}.cidr-calc-base-input{padding:7px 10px;border:1px solid #dee2e6;border-radius:6px;font-size:13px;color:#312d2a;background:#fff;width:140px;font-family:Courier New,monospace}.cidr-calc-base-input:focus{outline:none;border-color:#c74634;box-shadow:0 0 0 3px #2474ad1a}.cidr-calc-base-input.input-error{border-color:#c62828;background:#ffebee}.cidr-calc-propose-btn{display:flex;align-items:center;gap:6px;padding:7px 14px;background:linear-gradient(135deg,#c74634,#a63d2e);color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:opacity .15s,transform .1s;white-space:nowrap}.cidr-calc-propose-btn:hover{opacity:.9;transform:translateY(-1px)}.cidr-calc-propose-btn:active{transform:translateY(0)}.cidr-calc-banner{display:flex;align-items:flex-start;gap:8px;padding:10px 24px;font-size:13px}.cidr-calc-banner-error{background:#ffebee;border-bottom:1px solid #ffcdd2;color:#b71c1c}.cidr-calc-banner-error ul{margin:4px 0 0 16px;padding:0}.cidr-calc-banner-error li{margin:2px 0}.cidr-calc-body{padding:20px 24px;display:flex;flex-direction:column;gap:18px}.cidr-calc-vcn-card{border:1px solid #dee2e6;border-radius:10px;overflow:hidden}.cidr-calc-vcn-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:#c74634;color:#fff;gap:8px}.cidr-calc-vcn-title{font-size:14px;font-weight:600;display:flex;align-items:center;gap:6px}.cidr-calc-vcn-index{background:#fff3;border-radius:4px;padding:1px 7px;font-size:11px;font-weight:700}.cidr-calc-vcn-body{padding:16px;background:#fff;display:flex;flex-direction:column;gap:14px}.cidr-row{display:flex;flex-direction:column;gap:6px}.cidr-row-label{font-size:11px;font-weight:600;color:#6c757d;text-transform:uppercase;letter-spacing:.4px}.cidr-row-inputs{display:flex;align-items:center;gap:8px}.cidr-input{flex:1;padding:9px 12px;border:1px solid #dee2e6;border-radius:6px;font-size:14px;font-family:Courier New,monospace;color:#1a1a2e;background:#fdfdfd;transition:border-color .15s,box-shadow .15s;min-width:0}.cidr-input:focus{outline:none;border-color:#c74634;box-shadow:0 0 0 3px #2474ad1a}.cidr-input.input-error{border-color:#c62828;background:#ffebee}.cidr-input.input-error:focus{border-color:#b71c1c;box-shadow:0 0 0 3px #c628281a}.cidr-input.vcn-cidr{font-weight:600;background:#f0f7ff;border-color:#90caf9}.cidr-input.vcn-cidr:focus{border-color:#c74634;background:#fff}.cidr-field-error{font-size:12px;color:#c62828}.copy-btn{display:inline-flex;align-items:center;gap:4px;padding:7px 10px;background:#f1f3f5;border:1px solid #dee2e6;border-radius:6px;font-size:12px;color:#495057;cursor:pointer;white-space:nowrap;transition:background .15s,border-color .15s,color .15s;flex-shrink:0}.copy-btn:hover{background:#e2e6ea;border-color:#ced4da}.copy-btn.copied{background:#e8f5e9;border-color:#a5d6a7;color:#2e7d32}.vcn-base-row{display:flex;align-items:center;gap:8px;padding:10px 12px;background:#f0f7ff;border:1px solid #c9dff5;border-radius:8px;flex-wrap:wrap}.vcn-base-label{font-size:12px;font-weight:600;color:#1565c0;white-space:nowrap}.vcn-base-select{padding:5px 8px;border:1px solid #90caf9;border-radius:5px;font-size:12px;color:#312d2a;background:#fff;cursor:pointer;min-width:140px}.vcn-base-select:focus{outline:none;border-color:#c74634;box-shadow:0 0 0 3px #2474ad1f}.vcn-propose-btn{display:inline-flex;align-items:center;gap:4px;padding:7px 10px;background:linear-gradient(135deg,#c74634,#a63d2e);color:#fff;border:none;border-radius:6px;font-size:11px;font-weight:600;cursor:pointer;white-space:nowrap;transition:opacity .15s,transform .1s;flex-shrink:0}.vcn-propose-btn:hover{opacity:.9;transform:translateY(-1px)}.vcn-propose-btn:active{transform:translateY(0)}.vcn-propose-btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.cidr-row-hint{font-size:11px;color:#8a9bb0;font-style:italic;line-height:1.3}.apply-vcn-btn{padding:5px 12px;background:#ffffff2e;border:1px solid rgba(255,255,255,.5);border-radius:5px;color:#fff;font-size:12px;font-weight:600;cursor:pointer;transition:background .15s;white-space:nowrap;flex-shrink:0}.apply-vcn-btn:hover{background:#ffffff4d}.vcn-info-row{display:flex;flex-wrap:wrap;gap:0;background:#e3f2fd;border:1px solid #90caf9;border-radius:7px;font-size:12px;color:#1565c0;overflow:hidden}.vcn-info-chip{display:flex;align-items:center;gap:5px;padding:7px 14px;border-right:1px solid #90caf9;white-space:nowrap}.vcn-info-chip:last-child{border-right:none}.vcn-info-chip strong{font-size:15px;font-weight:700;color:#0d47a1}.cidr-calc-reserved-notice{display:flex;align-items:center;gap:8px;background:#fff8e1;border:1px solid #ffe082;border-radius:6px;padding:8px 14px;margin:0 20px;font-size:12px;color:#6d4c00}.cidr-calc-empty-hint{background:#f0f7ff;border:1px dashed #90caf9;border-radius:8px;padding:12px 16px;font-size:13px;color:#1976d2;text-align:center;width:100%;box-sizing:border-box}.subnets-divider{display:flex;align-items:center;gap:8px;font-size:11px;font-weight:600;color:#6c757d;text-transform:uppercase;letter-spacing:.4px}.subnets-divider:before,.subnets-divider:after{content:"";flex:1;height:1px;background:#dee2e6}.subnet-block{display:flex;flex-direction:column;gap:6px;padding:12px;background:#f8f9fa;border-radius:8px;border:1px solid #e9ecef}.subnet-header{display:flex;align-items:center;gap:6px}.subnet-badge{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;background:#e3f2fd;color:#1565c0;border-radius:4px;padding:2px 7px}.subnet-label{font-size:13px;font-weight:600;color:#312d2a}.subnet-info-box{display:flex;flex-wrap:wrap;gap:0;background:#f8faff;border:1px solid #c9dff5;border-radius:8px;font-size:12px;color:#555;overflow:hidden}.subnet-info-stats-row{display:flex;flex-wrap:wrap;gap:0;width:100%;border-bottom:1px solid #c9dff5}.subnet-info-stat{display:flex;flex-direction:column;gap:2px;padding:8px 14px;border-right:1px solid #c9dff5;min-width:90px;flex:1}.subnet-info-stat:last-child{border-right:none}.subnet-info-stat-label{font-size:10px;font-weight:700;text-transform:uppercase;color:#7a9cc0;letter-spacing:.4px}.subnet-info-stat-value{font-size:15px;font-weight:700;color:#1565c0;font-family:Courier New,monospace}.subnet-info-reserved{display:flex;flex-direction:column;gap:0;width:100%;padding:0}.subnet-info-reserved-title{font-weight:700;background:#e8f0fe;color:#1a4f8a;font-size:10px;text-transform:uppercase;letter-spacing:.4px;padding:5px 14px;border-bottom:1px solid #c9dff5}.subnet-info-reserved-entry{display:flex;align-items:center;gap:0;border-bottom:1px solid #e6eef9;padding:5px 14px}.subnet-info-reserved-entry:last-child{border-bottom:none}.subnet-info-reserved-badge{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;padding:1px 6px;border-radius:3px;margin-right:10px;flex-shrink:0;min-width:72px;text-align:center}.subnet-info-reserved-badge.reserved{background:#ffebee;color:#c62828}.subnet-info-reserved-badge.gateway{background:#e8f5e9;color:#2e7d32}.subnet-info-reserved-badge.usable{background:#e3f2fd;color:#1565c0}.subnet-info-reserved-ip,.subnet-info-gateway-ip{font-family:Courier New,monospace;font-weight:700;font-size:12px;color:#312d2a;min-width:120px;margin-right:10px}.subnet-info-reserved-desc{color:#6c757d;font-size:11px}.cidr-calc-footer{display:flex;align-items:center;justify-content:flex-end;gap:8px;padding:14px 24px;border-top:1px solid #dee2e6;background:#f8f9fa;flex-wrap:wrap;position:sticky;bottom:0;z-index:2;border-radius:0 0 12px 12px}.cidr-calc-apply-all-btn{display:flex;align-items:center;gap:6px;padding:9px 18px;background:linear-gradient(135deg,#28a745,#218838);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:opacity .15s,transform .1s}.cidr-calc-apply-all-btn:hover{opacity:.9;transform:translateY(-1px)}.cidr-calc-apply-all-btn:active{transform:translateY(0)}.cidr-calc-apply-all-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.cidr-calc-copy-btn{display:flex;align-items:center;gap:6px;padding:9px 14px;background:#fff;border:1px solid #dee2e6;border-radius:8px;font-size:13px;font-weight:500;color:#495057;cursor:pointer;transition:background .15s,border-color .15s}.cidr-calc-copy-btn:hover{background:#f1f3f5;border-color:#ced4da}.cidr-calc-copy-btn.copied{background:#e8f5e9;border-color:#a5d6a7;color:#2e7d32}.cidr-calc-cancel-btn{padding:9px 16px;background:none;border:1px solid #dee2e6;border-radius:8px;font-size:13px;color:#6c757d;cursor:pointer;transition:background .15s}.cidr-calc-cancel-btn:hover{background:#f0f0f0}@media (max-width: 600px){.cidr-calc-overlay{padding:8px}.cidr-calc-header,.cidr-calc-toolbar,.cidr-calc-body,.cidr-calc-footer{padding-left:14px;padding-right:14px}.cidr-calc-toolbar{gap:8px}.cidr-calc-footer{flex-direction:column;align-items:stretch}.cidr-calc-apply-all-btn,.cidr-calc-copy-btn,.cidr-calc-cancel-btn{justify-content:center}}.topology-form{padding:20px;height:100%;overflow-y:auto;background:#fff}.topology-form.error{display:flex;align-items:center;justify-content:center;color:#dc3545}.form-title{margin:0 0 20px;font-size:18px;font-weight:600;color:#312d2a;padding-bottom:12px;border-bottom:2px solid #C74634}.form-section{margin-bottom:24px;padding:16px;background:#f8f9fa;border-radius:8px;border:1px solid #e9ecef;overflow:hidden}.section-title{margin:0 0 16px;font-size:14px;font-weight:600;color:#495057;display:flex;align-items:center;gap:8px}.section-title:before{content:"";width:4px;height:16px;background:#c74634;border-radius:2px}.section-fields{display:grid;gap:16px}.form-field{display:flex;flex-direction:column;gap:6px;min-width:0}.form-field label{font-size:12px;font-weight:500;color:#5c5c5c;text-transform:uppercase;letter-spacing:.5px}.form-field input,.form-field select,.form-field textarea{width:100%;box-sizing:border-box;padding:10px 12px;border:1px solid #dee2e6;border-radius:6px;font-size:14px;color:#312d2a;background:#fff;transition:all .2s ease;min-width:0}.form-field input:focus,.form-field select:focus,.form-field textarea:focus{outline:none;border-color:#c74634;box-shadow:0 0 0 3px #2474ad1a}.form-field input::placeholder{color:#adb5bd}.form-field input:disabled,.form-field select:disabled,.form-field textarea:disabled{background:#e9ecef;cursor:not-allowed}.form-field input.input-error,.form-field select.input-error,.form-field textarea.input-error{border-color:#c62828;background-color:#ffebee}.form-field input.input-error:focus,.form-field select.input-error:focus,.form-field textarea.input-error:focus{border-color:#b71c1c;box-shadow:0 0 0 3px #c628281a}.form-field-error{display:block;font-size:12px;color:#c62828;margin-top:4px}.form-field textarea{resize:vertical;min-height:80px}.form-actions{margin-top:24px;padding-top:20px;border-top:1px solid #dee2e6;display:flex;flex-direction:column;gap:10px}.cidr-calc-section{margin-bottom:24px}.cidr-calc-section .cidr-calc-open-btn{width:100%}.cidr-calc-open-btn{width:100%;padding:10px 20px;background:linear-gradient(135deg,#c74634,#a63d2e);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:8px}.cidr-calc-open-btn:hover{opacity:.9;transform:translateY(-1px);box-shadow:0 4px 12px #2474ad4d}.cidr-calc-open-btn:active{transform:translateY(0)}.cidr-calc-open-btn:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.populate-btn{width:100%;padding:10px 20px;background:#6c757d;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.populate-btn:hover{background:#5a6268}.populate-btn:disabled{opacity:.6;cursor:not-allowed}.submit-btn{width:100%;padding:12px 24px;background:linear-gradient(135deg,#28a745,#218838);color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:8px}.submit-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #2474ad4d}.submit-btn:active{transform:translateY(0)}.submit-btn:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}@media (min-width: 600px){.section-fields{grid-template-columns:repeat(2,minmax(0,1fr))}}.minimap{position:absolute;bottom:12px;right:12px;width:180px;height:120px;border-radius:8px;overflow:hidden;box-shadow:0 2px 12px #0003;border:1px solid rgba(0,0,0,.12);cursor:grab;z-index:20;background:#f5f5f5;-webkit-user-select:none;user-select:none;resize:none}.minimap:active,.minimap.minimap-dragging{cursor:grabbing}.minimap:hover{border-color:#0003;box-shadow:0 4px 16px #00000040}.minimap:focus{outline:2px solid var(--focus-color, #C74634);outline-offset:2px}.minimap-inner{position:relative;width:100%;height:100%;pointer-events:none;-webkit-user-select:none;user-select:none}.minimap-diagram-img{position:absolute;object-fit:none;object-position:0 0;pointer-events:none;-webkit-user-select:none;user-select:none;resize:none}.minimap-diagram-svg{position:absolute;pointer-events:none;-webkit-user-select:none;user-select:none}.minimap-diagram-svg svg{display:block;max-width:none;max-height:none;-webkit-user-select:none;user-select:none;pointer-events:none}.minimap-diagram-svg *{-webkit-user-select:none;user-select:none;pointer-events:none}.minimap-flow-overlay-wrap{position:absolute;pointer-events:none;-webkit-user-select:none;user-select:none}.minimap-flow-overlay-wrap svg{display:block;max-width:none;max-height:none}.minimap-flow-overlay-wrap .minimap-flow-overlay path{vector-effect:non-scaling-stroke}.minimap-viewport{position:absolute;border:2px solid rgba(33,150,243,.9);background:#2196f326;pointer-events:none;border-radius:2px;box-sizing:border-box;resize:none;-webkit-user-select:none;user-select:none}.minimap:hover .minimap-viewport{border-color:#2196f3;background:#2196f333}.diagram-container{display:flex;flex-direction:column;height:100%;background:#fff;border-radius:8px;box-shadow:0 2px 8px #00000014;overflow:hidden}.diagram-header{display:flex;justify-content:space-between;align-items:center;padding:6px 12px;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-bottom:1px solid #dee2e6;flex-shrink:0}.diagram-header h3{margin:0;font-size:13px;font-weight:600;color:#312d2a}.zoom-controls{display:flex;align-items:center;gap:4px;background:#fff;padding:4px 8px;border-radius:6px;box-shadow:0 1px 3px #0000001a}.zoom-controls button{width:28px;height:28px;border:none;background:#f5f5f5;border-radius:4px;cursor:pointer;font-size:16px;font-weight:700;color:#312d2a;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.zoom-controls button:hover{background:#e0e0e0}.zoom-level{min-width:50px;text-align:center;font-size:12px;font-weight:500;color:#5c5c5c}.diagram-viewer-wrapper{flex:1;min-height:0;overflow:hidden;position:relative;background:#f8f9fa;contain:size layout}.diagram-content{position:absolute;top:0;left:0;min-width:100%;min-height:100%;transition:transform .1s ease}.diagram-image{display:block;max-width:none;pointer-events:none}.clickable-element{position:absolute;width:18px;height:18px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;z-index:15;transform:translate(-50%,-50%);box-shadow:0 2px 4px #0003}.clickable-element:hover{transform:translate(-50%,-50%) scale(1.3);box-shadow:0 3px 8px #0000004d}.clickable-element .element-label{display:none}.security-list{background:linear-gradient(135deg,#667eea,#764ba2);border:2px solid #fff}.route-table.rt-type-vcn{background:linear-gradient(135deg,#f093fb,#f5576c);border:2px solid #fff}.route-table.rt-type-drg{background:linear-gradient(135deg,#11998e,#38ef7d);border:2px solid #fff}.route-table.rt-type-gateway{background:linear-gradient(135deg,#f7971e,#ffd200);border:2px solid #fff}.route-table{background:linear-gradient(135deg,#f093fb,#f5576c);border:2px solid #fff}.clickable-element.updated{box-shadow:0 0 0 3px #28a74599,0 2px 4px #0003;animation:pulse-updated 1.5s ease-in-out infinite}.clickable-element.route-table.rt-dot-highlight,.clickable-element.security-list.rt-dot-highlight{outline:4px solid #fff;outline-offset:6px;z-index:100;animation:rt-dot-pulse 1s ease-in-out infinite;transform:translate(-50%,-50%) scale(1.3)}.clickable-element.route-table.rt-dot-highlight:before,.clickable-element.security-list.rt-dot-highlight:before{content:"";position:absolute;top:50%;left:50%;width:100%;height:100%;border-radius:50%;transform:translate(-50%,-50%);animation:rt-ring-expand 1.5s ease-out infinite;pointer-events:none}@keyframes rt-dot-pulse{0%,to{box-shadow:0 0 0 8px #ffd700cc,0 0 20px 10px #ffd70066,0 0 40px 20px #ffd70033;transform:translate(-50%,-50%) scale(1.3)}50%{box-shadow:0 0 0 12px #ffd70099,0 0 30px 15px #ffd7004d,0 0 50px 25px #ffd70026;transform:translate(-50%,-50%) scale(1.4)}}@keyframes rt-ring-expand{0%{box-shadow:0 0 #ffd700cc;opacity:1}to{box-shadow:0 0 0 40px #ffd70000;opacity:0}}@keyframes pulse-updated{0%,to{box-shadow:0 0 0 3px #28a74599,0 2px 4px #0003}50%{box-shadow:0 0 0 5px #28a74566,0 2px 4px #0003}}.clickable-element:after{content:attr(data-tooltip);position:absolute;bottom:100%;left:50%;transform:translate(-50%);background:#000000d9;color:#fff;padding:4px 8px;border-radius:4px;font-size:11px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .2s ease;margin-bottom:5px}.clickable-element:hover:after{opacity:1}.updated-badge{display:none;background:#28a745;color:#fff;padding:2px 6px;border-radius:3px;font-size:9px;font-weight:600;text-transform:uppercase;animation:pulse 1.5s ease infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.endpoint-marker{position:absolute;width:45px;height:45px;padding:0;border-radius:50%;border:3px solid rgba(0,0,0,.3);display:flex;align-items:center;justify-content:center;font-size:7.5px;font-weight:700;text-align:center;line-height:1.1;overflow:hidden;color:#312d2a;z-index:20;box-shadow:0 3px 10px #00000040,inset 0 1px #ffffff80;transform:translate(-50%,-50%);pointer-events:none;text-shadow:0 1px 0 rgba(255,255,255,.5);animation:endpointPulse 2s ease-in-out infinite}@keyframes endpointPulse{0%,to{box-shadow:0 3px 10px #00000040,inset 0 1px #ffffff80}50%{box-shadow:0 3px 15px #00000059,inset 0 1px #ffffff80,0 0 20px #0000001a}}.connections-overlay{position:absolute;top:0;left:0;width:100%;height:100%;z-index:15;pointer-events:none}.flow-dot{opacity:.8}.flow-controls{position:absolute;top:12px;right:12px;width:260px;max-height:70vh;overflow-y:auto;overflow-x:hidden;padding:16px;background:#fff;border-radius:8px;box-shadow:0 2px 12px #00000026;border:1px solid #dee2e6;z-index:100;contain:layout style}.flow-panel .flow-controls{position:static;width:100%;max-height:none;min-height:auto;padding:16px;contain:none;box-shadow:none;border:none;border-radius:0;overflow:visible}.flow-controls h4{margin:0 0 12px;font-size:14px;font-weight:600;color:#312d2a;padding-bottom:8px;border-bottom:1px solid #dee2e6}.flow-hint{font-size:11px;color:#5c5c5c;margin:0 0 8px;font-style:italic}.variant-selector{border-bottom:1px solid #6c757d;padding-bottom:12px;margin-bottom:4px}.variant-hint{font-size:11px;color:#5c5c5c;margin:0 0 8px;font-style:italic}.variant-radio-group{display:flex;flex-direction:column;gap:6px}.variant-radio-label{display:flex;align-items:center;gap:8px;padding:8px 10px;background:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;cursor:pointer;font-size:11px;line-height:1.4;color:#312d2a;transition:all .2s ease}.variant-radio-label:hover{border-color:#c74634;background:#f0f7ff}.variant-radio-label.active{background:#e7f3ff;border-color:#c74634;color:#a63d2e;font-weight:500}.variant-radio-label input{position:absolute;opacity:0;pointer-events:none}.variant-radio-label .radio-custom{width:14px;height:14px;min-width:14px;border-radius:50%;border:2px solid #C74634;background:#fff;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.variant-radio-label.active .radio-custom{background:#c74634;box-shadow:inset 0 0 0 3px #fff}.variant-radio-label.disabled{opacity:.5;pointer-events:none;cursor:not-allowed}.flow-show-all-label{margin-bottom:6px}.flow-checkbox-group{display:flex;flex-direction:column;gap:6px;padding:6px 0;border-bottom:1px solid #6c757d}.flow-checkbox-group:last-child{border-bottom:none}.flow-checkbox-group.primary{border-bottom:1px solid #6c757d;padding-bottom:12px;margin-bottom:4px}.flow-checkbox-group.disabled{opacity:.5;pointer-events:none}.flow-checkbox-groups{animation:slideIn .3s ease}.flow-panel .flow-controls .flow-checkbox-groups{animation:none}@keyframes slideIn{0%{opacity:0;transform:translate(10px)}to{opacity:1;transform:translate(0)}}.flow-checkbox-label{display:flex;align-items:flex-start;gap:8px;padding:8px 10px;background:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;cursor:pointer;font-size:11px;line-height:1.4;color:#312d2a;transition:all .2s ease}.flow-checkbox-label:hover{border-color:#c74634;background:#f0f7ff}.flow-checkbox-label:has(input:checked){background:#e7f3ff;border-color:#c74634;color:#a63d2e;font-weight:500}.flow-checkbox-label input{position:absolute;opacity:0;pointer-events:none}.checkbox-custom{width:16px;height:16px;border:2px solid #adb5bd;border-radius:3px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s ease}.flow-checkbox-label input:checked+.checkbox-custom{background:#c74634;border-color:#c74634}.flow-checkbox-label input:checked+.checkbox-custom:after{content:"✓";color:#fff;font-size:10px;font-weight:700}.diagram-actions{display:flex;gap:10px;padding:12px 16px;background:#f8f9fa;border-top:1px solid #dee2e6;flex-wrap:wrap}.action-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;background:#c74634;color:#fff;border:none;border-radius:6px;font-family:inherit;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease}.action-btn:hover{background:#a63d2e;transform:translateY(-1px)}.action-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.action-btn.pdf-btn{background:#dc3545}.action-btn.pdf-btn:hover{background:#c82333}.action-btn.orm-btn{background:#6f42c1}.action-btn.orm-btn:hover{background:#5a32a3}.diagram-export-dropup{position:relative}button.diagram-export-select{min-width:160px;padding-right:28px;background-color:#0d6efd;font-family:inherit;font-size:13px;font-weight:500}button.diagram-export-select:hover{background-color:#0b5ed7}button.diagram-export-select:focus{outline:none}.diagram-export-chevron{margin-left:4px;font-size:10px;opacity:.9;transition:transform .2s ease}.diagram-export-chevron.open{transform:rotate(180deg)}.diagram-export-menu{position:absolute;bottom:calc(100% + 6px);left:0;min-width:100%;background:#fff;border-radius:6px;box-shadow:0 -4px 16px #00000026;list-style:none;margin:0;padding:4px 0;z-index:1001;overflow:hidden}.diagram-export-menu li{margin:0}.diagram-export-menu-item{display:block;width:100%;padding:8px 16px;background:none;border:none;text-align:left;font-family:inherit;font-size:13px;font-weight:500;color:#312d2a;cursor:pointer;transition:background .15s ease}.diagram-export-menu-item:hover{background:#f0f7ff;color:#0d6efd}.popup-wrapper{position:fixed;top:0;left:0;right:0;bottom:0;z-index:9999;pointer-events:none}.popup-wrapper .popup{pointer-events:auto}.flow-legend{border-top:2px solid #b91c1c;background:#fff5f5;margin:12px -16px -16px;border-radius:0 0 8px 8px}.flow-legend-toggle{width:100%;display:flex;align-items:center;gap:8px;padding:12px 16px;background:linear-gradient(135deg,#fee2e2,#fecaca);border:none;cursor:pointer;font-size:13px;font-weight:600;color:#991b1b;text-align:left;transition:all .2s ease;border-radius:0 0 8px 8px}.flow-legend-toggle:hover{background:linear-gradient(135deg,#fecaca,#fca5a5)}.flow-legend .legend-icon{transition:transform .2s ease;flex-shrink:0}.flow-legend .legend-icon.expanded{transform:rotate(90deg)}.flow-legend-list{list-style:none;margin:0;padding:12px 16px;display:flex;flex-direction:column;gap:10px;background:#fff5f5;border-radius:0 0 8px 8px}.flow-legend-item{display:flex;align-items:center;gap:10px;font-size:12px;color:#312d2a}.flow-legend-swatch{flex-shrink:0;width:24px;height:4px;border-radius:2px;display:inline-block}.flow-legend-label{line-height:1.3}@media (max-width: 1200px){.flow-controls{width:220px}}@media (max-width: 768px){.flow-controls{position:fixed;top:auto;bottom:60px;left:12px;right:12px;width:auto;max-height:40vh;contain:layout style}}.route-tables-panel{padding:12px;flex:1 1 0;min-height:0;overflow:hidden;background:#fff;display:flex;flex-direction:column}.section-toggle{display:flex;gap:0;margin-bottom:10px;background:#f0f0f0;border-radius:6px;padding:3px;flex-shrink:0}.section-toggle-btn{flex:1;padding:6px 8px;border:none;background:transparent;font-size:12px;font-weight:500;color:#5c5c5c;cursor:pointer;border-radius:4px;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:4px}.section-toggle-btn:hover{color:#312d2a;background:#ffffff80}.section-toggle-btn.active{background:#fff;color:#c74634;box-shadow:0 1px 3px #0000001a}.section-toggle-btn .count{background:#c74634;color:#fff;padding:1px 5px;border-radius:8px;font-size:10px;font-weight:600}.section-toggle-btn.active .count{background:#f093fb}.section-content{flex:1 1 0;display:flex;flex-direction:column;min-height:0;overflow-y:auto;overflow-x:hidden}.route-tables-panel .panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;padding-bottom:6px;border-bottom:2px solid #C74634;flex-shrink:0}.route-tables-panel .panel-header h3{margin:0;font-size:14px;font-weight:600;color:#312d2a}.route-tables-panel .panel-header-actions{display:flex;align-items:center;gap:8px}.route-tables-panel .show-all-btn,.route-tables-panel .show-all-security-lists-btn{padding:4px 10px;background:#c74634;color:#fff;border:none;border-radius:4px;font-size:11px;font-weight:500;cursor:pointer;transition:background .2s ease}.route-tables-panel .show-all-btn:hover,.route-tables-panel .show-all-security-lists-btn:hover{background:#a63d2e}.route-tables-panel .show-all-security-lists-btn{margin-top:12px;padding:8px 16px;font-size:13px}.route-tables-panel .close-all-btn{padding:4px 10px;background:#dc3545;color:#fff;border:none;border-radius:4px;font-size:11px;font-weight:500;cursor:pointer;transition:background .2s ease}.route-tables-panel .close-all-btn:hover{background:#c82333}.route-tables-panel .no-popups-message{text-align:center;padding:40px 20px;color:#5c5c5c}.route-tables-panel .no-popups-message p{margin:0 0 8px}.route-tables-panel .no-popups-message .hint{font-size:13px;color:#888;font-style:italic}.legend{margin-top:20px;display:flex;flex-direction:column;gap:8px;align-items:center}.legend-item{display:flex;align-items:center;gap:8px;font-size:12px;color:#5c5c5c}.legend-dot{width:14px;height:14px;border-radius:50%;border:2px solid white;box-shadow:0 1px 3px #0003}.legend-dot.vcn{background:linear-gradient(135deg,#f093fb,#f5576c)}.legend-dot.drg{background:linear-gradient(135deg,#11998e,#38ef7d)}.legend-dot.gateway{background:linear-gradient(135deg,#f7971e,#ffd200)}.legend-dot.onprem{background:linear-gradient(135deg,#667eea,#764ba2)}.route-tables-panel .popups-container{display:flex;flex-direction:column;gap:6px;overflow:visible;padding-right:4px;padding-bottom:40px}.route-tables-panel .popups-container::-webkit-scrollbar{width:6px}.route-tables-panel .popups-container::-webkit-scrollbar-track{background:#f0f0f0;border-radius:3px}.route-tables-panel .popups-container::-webkit-scrollbar-thumb{background:#bbb;border-radius:3px}.route-tables-panel .popups-container::-webkit-scrollbar-thumb:hover{background:#888}.popup-card{background:#f8f9fa;border-radius:6px;border:1px solid #dee2e6;overflow:hidden;flex-shrink:0}.route-table-card.highlighted-for-flow{border:2px solid #C74634;box-shadow:0 0 0 2px #2474ad59}.route-table-card.dimmed-for-flow{opacity:.5}.popup-card-content tr.highlighted-route-for-flow td{background:#2474ad33;font-weight:500}.popup-card-header{display:flex;justify-content:space-between;align-items:center;padding:4px 8px;background:linear-gradient(135deg,#495057,#343a40);color:#fff}.popup-card-header h4{margin:0;font-size:10px;font-weight:600}.popup-card-header-actions{display:flex;align-items:center;gap:6px}.locate-on-diagram-btn{padding:3px 8px;font-size:9px;font-weight:600;border:1px solid rgba(255,255,255,.8);background:#fff3;color:#fff;border-radius:4px;cursor:pointer;white-space:nowrap;transition:background .2s,border-color .2s}.locate-on-diagram-btn:hover{background:#ffffff59;border-color:#fff}.locate-on-diagram-btn.is-active{background:#ffffffe6;color:#312d2a;border-color:#fff;box-shadow:inset 0 2px 4px #0003}.locate-on-diagram-btn.is-active:hover{background:#fff}.locate-on-diagram-btn.focused-from-diagram{border:2px solid rgba(255,215,0,.95);box-shadow:0 0 0 2px #ffd70080;animation:locate-btn-focus-pulse 1.5s ease-in-out 2}@keyframes locate-btn-focus-pulse{0%,to{border-color:#ffd700f2;box-shadow:0 0 0 2px #ffd70080}50%{border-color:gold;box-shadow:0 0 0 4px #ffd70099}}.popup-card-header .close-btn{background:#fff3;border:none;color:#fff;width:16px;height:16px;border-radius:50%;font-size:12px;line-height:1;cursor:pointer;transition:background .2s ease;display:flex;align-items:center;justify-content:center}.popup-card-header .close-btn:hover{background:#ffffff4d}.security-list-card .popup-card-header{background:linear-gradient(135deg,#667eea,#764ba2)}.route-table-card .popup-card-header,.route-table-card.rt-card-vcn .popup-card-header{background:linear-gradient(135deg,#f093fb,#f5576c)}.route-table-card.rt-card-drg .popup-card-header{background:linear-gradient(135deg,#11998e,#38ef7d)}.route-table-card.rt-card-gateway .popup-card-header{background:linear-gradient(135deg,#f7971e,#ffd200)}.route-table-card.rt-card-onprem .popup-card-header{background:linear-gradient(135deg,#667eea,#764ba2)}.popup-card-content{padding:4px 6px;max-height:150px;overflow-y:auto}.popup-card-content h5{margin:0 0 3px;font-size:9px;font-weight:600;color:#5c5c5c;text-transform:uppercase}.popup-card-content h5:not(:first-child){margin-top:6px}.popup-card-content table{width:100%;border-collapse:collapse;font-size:9px;table-layout:fixed}.popup-card-content th,.popup-card-content td{padding:2px;text-align:left;border-bottom:1px solid #e9ecef;word-wrap:break-word;overflow-wrap:break-word}.popup-card-content th{background:#e9ecef;font-weight:600;color:#495057;font-size:8px;text-transform:uppercase;word-wrap:break-word;overflow-wrap:break-word;-webkit-hyphens:auto;hyphens:auto}.popup-card-content tr:last-child td{border-bottom:none}.popup-card-content tr:hover td{background:#f0f7ff}.popup-card-content tr.static td:first-child{color:#28a745;font-weight:500}.popup-card-content tr.dynamic td:first-child{color:#007bff;font-weight:500}.route-table-card-editing .popup-card-content{max-height:none}.route-tables-panel .edit-routes-btn{padding:3px 8px;font-size:9px;font-weight:600;border:1px solid rgba(255,255,255,.8);background:#ffffff40;color:#fff;border-radius:4px;cursor:pointer;white-space:nowrap;transition:background .2s,border-color .2s}.route-tables-panel .edit-routes-btn:hover{background:#fff6;border-color:#fff}.route-table-editor{margin-top:4px}.route-table-editor table{margin-bottom:8px}.route-table-editor input{width:100%;max-width:120px;padding:2px 4px;font-size:9px;border:1px solid #ced4da;border-radius:3px;box-sizing:border-box}.route-table-editor input:focus{outline:none;border-color:#c74634;box-shadow:0 0 0 2px #2474ad33}.route-row-remove{padding:2px 6px;font-size:12px;line-height:1;background:#dc3545;color:#fff;border:none;border-radius:3px;cursor:pointer;transition:background .2s}.route-row-remove:hover{background:#c82333}.route-editor-actions{display:flex;flex-wrap:wrap;gap:6px;align-items:center;margin-top:8px;padding-top:6px;border-top:1px solid #dee2e6}.route-editor-add,.route-editor-save,.route-editor-reset{padding:4px 10px;font-size:10px;font-weight:500;border:none;border-radius:4px;cursor:pointer;transition:background .2s}.route-editor-add{background:#c74634;color:#fff}.route-editor-add:hover{background:#a63d2e}.route-editor-save{background:#28a745;color:#fff}.route-editor-save:hover{background:#218838}.route-editor-reset{background:#6c757d;color:#fff}.route-editor-reset:hover{background:#5a6268}.sl-profile-cards{display:flex;flex-direction:column;gap:6px}.sl-profile-selector{display:flex;align-items:center;gap:6px;padding:3px 0;margin-bottom:2px}.sl-profile-selector label{font-size:9px;font-weight:600;color:#495057;white-space:nowrap;min-width:60px}.sl-profile-selector select{font-size:9px;padding:2px 4px;border:1px solid #ced4da;border-radius:3px;background:#fff;color:#495057;cursor:pointer;flex:1}.sl-profile-selector select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 2px #667eea40}.topology-editor{display:flex;flex-direction:column;height:calc(100vh - 66px);overflow:hidden}.editor-toolbar{display:flex;align-items:center;justify-content:space-between;padding:6px 16px;background:#fff;border-bottom:1px solid #dee2e6;flex-shrink:0}.toolbar-left h2{margin:0;font-size:14px;font-weight:600;color:#312d2a}.view-toggle{display:flex;background:#f5f5f5;border-radius:8px;padding:4px}.toggle-btn{display:flex;align-items:center;justify-content:center;width:36px;height:32px;border:none;background:transparent;border-radius:6px;cursor:pointer;color:#5c5c5c;transition:all .2s ease}.toggle-btn:hover{color:#312d2a;background:#0000000d}.toggle-btn.active{background:#fff;color:#c74634;box-shadow:0 1px 3px #0000001a}.viewer-toggle{display:flex;align-items:center;gap:8px}.toggle-label{font-size:13px;color:#5c5c5c}.viewer-select{padding:6px 16px;border:1px solid #dee2e6;border-radius:6px;font-size:13px;color:#312d2a;background:#fff;cursor:pointer}.viewer-select:focus{outline:none;border-color:#c74634}.editor-content{flex:1;min-height:0;display:flex;overflow:hidden;background:#f5f5f5}.editor-content.view-split{flex-direction:row}.editor-content.view-split .form-panel{order:1}.editor-content.view-split .diagram-panel{order:2}.editor-content.view-split .flow-panel{order:3}.editor-content.view-split .form-panel{width:420px;min-width:420px;flex-shrink:0;border-right:1px solid #dee2e6;overflow:hidden;background:#fff;display:flex;flex-direction:column;transition:width .3s ease,min-width .3s ease}.editor-content.view-split .form-panel.collapsed{width:48px;min-width:48px}.editor-content.view-split .diagram-panel{flex:1;padding:8px;overflow:hidden;transition:all .3s ease}.editor-content.view-split .flow-panel,.editor-content.view-diagram .flow-panel{position:relative;width:280px;min-width:280px;flex-shrink:0;border-left:1px solid #dee2e6;overflow:hidden;background:#fff;transition:width .3s ease,min-width .3s ease}.editor-content.view-split .flow-panel.collapsed,.editor-content.view-diagram .flow-panel.collapsed{width:48px;min-width:48px}.flow-panel .flow-panel-content{position:absolute;top:0;left:0;right:0;bottom:0;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}.flow-panel .flow-controls-slot{display:block;width:100%}.flow-panel .panel-collapse-toggle.flow-panel-toggle{left:12px;right:auto;z-index:20}.flow-panel.collapsed .panel-collapse-toggle.flow-panel-toggle{position:absolute;left:50%;top:16px;transform:translate(-50%);margin:0;z-index:20}.flow-panel.collapsed .flow-panel-content{flex:0;min-height:0;overflow:hidden;max-height:0}.flow-panel.collapsed .collapsed-label{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;margin-top:0}.editor-content.view-split .form-panel.collapsed~.diagram-panel{flex:1}.editor-content.view-diagram .form-panel{display:none}.editor-content.view-diagram .diagram-panel{order:2;flex:1;padding:8px}.editor-content.view-diagram .flow-panel{order:3}.editor-content.view-form .diagram-panel{display:none}.editor-content.view-form .form-panel{flex:1;max-width:800px;margin:0 auto;background:#fff;border-radius:0;box-shadow:0 0 20px #0000000d}.panel-mode-toggle{display:flex;background:#f5f5f5;padding:3px;margin:8px 12px;border-radius:6px;flex-shrink:0}.panel-toggle-btn{min-width:100px;white-space:nowrap;flex:1;padding:6px 16px;border:none;background:transparent;border-radius:5px;font-size:11px;font-weight:500;color:#5c5c5c;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:5px}.panel-toggle-btn:hover{color:#312d2a;background:#ffffff80}.panel-toggle-btn.active{background:#fff;color:#c74634;box-shadow:0 1px 3px #0000001a}.panel-toggle-btn .popup-count{background:#dc3545;color:#fff;padding:2px 6px;border-radius:10px;font-size:11px;font-weight:600}.form-panel{background:#fff;display:flex;flex-direction:column;height:100%;max-height:100%;overflow:hidden;position:relative;transition:width .3s ease,min-width .3s ease}.form-panel.collapsed{width:48px!important;min-width:48px!important;max-width:48px!important}.panel-collapse-toggle{position:absolute;top:16px;right:12px;width:32px;height:32px;border:1px solid #dee2e6;background:#fff;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#5c5c5c;z-index:10;transition:all .2s ease}.form-panel.collapsed .panel-collapse-toggle{position:relative;top:0;right:0;margin:8px auto}.diagram-panel{display:flex;flex-direction:column}.update-notice{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;background:linear-gradient(135deg,#fff3cd,#ffeeba);border-top:1px solid #ffc107;animation:slideUp .3s ease}.update-notice span{font-size:13px;color:#856404;font-weight:500}.update-notice button{padding:6px 16px;background:#28a745;color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease}.update-notice button:hover{background:#218838;transform:translateY(-1px)}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.diagram-placeholder{flex:1;display:flex;align-items:center;justify-content:center;background:#fff;border-radius:8px}.placeholder-content{text-align:center;padding:40px}.placeholder-content svg{margin-bottom:20px}.placeholder-content p{color:#5c5c5c;font-size:15px;max-width:300px;line-height:1.6}.topology-editor.topology-placeholder{height:auto;min-height:50vh;justify-content:center;align-items:center}.topology-placeholder .placeholder-content{max-width:420px}.topology-placeholder .placeholder-content h2{margin:0 0 12px;font-size:20px;color:#312d2a}.placeholder-status{font-weight:600;color:#d79b00!important;margin:0 0 16px!important}.placeholder-description{max-width:360px;margin:0 auto 24px!important}.placeholder-actions{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}.placeholder-actions .doc-btn{padding:10px 20px;border-radius:6px;font-size:14px;font-weight:600;text-decoration:none;border:none;cursor:pointer;transition:background .2s ease}.placeholder-actions .doc-btn.primary{background:#a63d2e;color:#fff}.placeholder-actions .doc-btn.primary:hover{background:#c74634}.placeholder-actions .doc-btn:not(.primary){background:#f5f5f5;color:#312d2a}.placeholder-actions .doc-btn:not(.primary):hover{background:#e0e2e5}@media (max-width: 992px){.editor-content.view-split{flex-direction:column}.editor-content.view-split .form-panel{width:100%;max-height:40vh;border-right:none;border-bottom:1px solid #dee2e6}.editor-content.view-split .diagram-panel{flex:1;min-height:0}}@media (max-width: 768px){.editor-toolbar{flex-wrap:wrap;gap:12px;padding:12px 16px}.toolbar-left{flex:1}.toolbar-left h2{font-size:16px}.toolbar-right{width:100%;order:3}.viewer-toggle{justify-content:flex-end}}.documentation-page{padding:32px 20px 60px;background:#f7f9fc}.doc-container{max-width:1100px;margin:0 auto}.doc-container a:not(.doc-btn){color:#c74634;text-decoration:none}.doc-container a:not(.doc-btn):hover{text-decoration:underline}.doc-hero{background:#fff;border-radius:12px;padding:32px;box-shadow:0 2px 8px #00000014;margin-bottom:28px}.doc-hero h1{margin:0 0 12px;font-size:32px;color:#a63d2e}.doc-hero p{margin:0;color:#555;line-height:1.6}.doc-hero-actions{margin-top:20px;display:flex;gap:12px;flex-wrap:wrap}.doc-btn{display:inline-flex;align-items:center;justify-content:center;padding:8px 14px;background:#e9f3ff;color:#a63d2e;border-radius:6px;text-decoration:none;font-weight:600;font-size:14px}.doc-btn.primary{background:#c74634;color:#fff}.doc-toc{background:#fff;border-radius:12px;padding:0;box-shadow:0 2px 8px #0000000f;margin-bottom:20px;border:1px solid #e6eef7}.doc-toc-summary{padding:14px 20px;font-weight:600;font-size:16px;color:#a63d2e;cursor:pointer;list-style:none;-webkit-user-select:none;user-select:none}.doc-toc-summary::-webkit-details-marker{display:none}.doc-toc-summary:before{content:"";display:inline-block;width:0;height:0;margin-right:10px;border-left:6px solid #A63D2E;border-top:5px solid transparent;border-bottom:5px solid transparent;vertical-align:middle;transition:transform .2s ease}.doc-toc[open] .doc-toc-summary:before{transform:rotate(90deg)}.doc-toc-nav{padding:0 20px 16px}.doc-toc-list{margin:0;padding-left:24px;font-size:15px;line-height:1.8}.doc-toc-list a{color:#c74634;text-decoration:none}.doc-toc-list a:hover{text-decoration:underline}.doc-section{background:#fff;border-radius:12px;padding:28px;box-shadow:0 2px 8px #0000000f;margin-bottom:20px}.doc-section-collapsible{padding:0}.doc-section-collapsible .doc-section-summary{display:flex;align-items:center;gap:12px;padding:20px 28px;cursor:pointer;list-style:none;-webkit-user-select:none;user-select:none;font-weight:600}.doc-section-collapsible .doc-section-summary::-webkit-details-marker{display:none}.doc-section-collapsible .doc-section-summary:before{content:"";flex-shrink:0;width:0;height:0;border-left:6px solid #A63D2E;border-top:5px solid transparent;border-bottom:5px solid transparent;transition:transform .2s ease}.doc-section-collapsible[open] .doc-section-summary:before{transform:rotate(90deg)}.doc-section-collapsible .doc-section-summary h2{margin:0;color:#a63d2e;font-size:22px;font-weight:600;flex:1;min-width:0}.doc-section-collapsible .doc-section-content{padding:0 28px 28px 38px}.doc-section-collapsible .doc-section-content h3{margin:18px 0 8px}.doc-section-collapsible .doc-section-content h3:first-child{margin-top:0}.doc-section h2{margin:0 0 16px;color:#a63d2e;font-size:22px}.doc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}.doc-card{border:1px solid #e6eef7;border-radius:10px;padding:16px;background:#f9fbff}.doc-card h3{margin:0 0 8px;font-size:16px;color:#2b3b4b}.doc-card p{margin:0;color:#555;font-size:14px;line-height:1.5}.doc-steps{margin:0;padding-left:20px;color:#444;line-height:1.7}.doc-steps li{margin:6px 0}.doc-callout{margin-top:14px;padding:12px 14px;background:#f0f7ff;border-left:4px solid #C74634;color:#37546b;border-radius:6px;font-size:14px}.doc-list{margin:0;padding-left:18px;color:#444;line-height:1.7}.doc-list li{margin:6px 0}.doc-footer{background:#f9fbff}@media (max-width: 768px){.doc-hero h1{font-size:26px}.doc-section{padding:20px}.doc-grid{grid-template-columns:1fr}}.version-updates{display:flex;flex-direction:column;gap:20px;margin-top:30px}.version-card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:20px;box-shadow:0 2px 4px #0000000d;transition:box-shadow .2s}.version-card:hover{box-shadow:0 4px 12px #0000001a}.version-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}.version-date{font-size:14px;color:#5c5c5c;font-weight:500}.version-badge{background:#2196f3;color:#fff;font-size:12px;font-weight:600;padding:4px 10px;border-radius:12px}.version-title{font-size:18px;font-weight:600;color:#312d2a;margin:0 0 10px}.version-description{font-size:14px;color:#555;line-height:1.6;margin:0}.doc-table.topologies-table{width:100%;border-collapse:collapse;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000f;overflow:hidden}.doc-table.topologies-table th,.doc-table.topologies-table td{padding:12px 16px;text-align:left;border-bottom:1px solid #e6eef7;font-size:12px}.doc-table.topologies-table th{background:#f0f6fc;font-weight:600;color:#a63d2e}.doc-table.topologies-table tbody tr:hover{background:#fafcff}.doc-table.topologies-table th:first-child,.doc-table.topologies-table td:first-child{min-width:100px;white-space:nowrap}.doc-table.topologies-table code{background:#e9f3ff;padding:2px 6px;border-radius:4px;font-size:12px}.doc-table.topologies-table .topology-tags-cell{max-width:320px;line-height:1.4;word-wrap:break-word}.status-available{color:#2e7d32;font-weight:500}.status-construction{color:#ed6c02;font-weight:500}.text-muted{color:#999}.oci-connections{padding:32px 24px;min-height:60vh}.oci-connections-container{max-width:900px;margin:0 auto}.oci-connections-header{margin-bottom:32px}.oci-connections-header h1{font-size:28px;font-weight:700;color:#4a148c;margin:0 0 8px}.oci-connections-subtitle{color:#555;margin:0 0 8px;line-height:1.5}.oci-connections-hint{font-size:13px;color:#5c5c5c;margin:0 0 20px;line-height:1.5}.oci-connections-hint code{background:#f0f0f0;padding:2px 6px;border-radius:4px;font-size:12px}.oci-header-actions{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:16px}.oci-btn{padding:10px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;border:none;transition:background .2s,color .2s}.oci-btn-primary{background:linear-gradient(135deg,#7b1fa2,#6a1b9a);color:#fff}.oci-btn-primary:hover{background:linear-gradient(135deg,#6a1b9a,#4a148c)}.oci-btn-secondary{background:#f5f5f5;color:#312d2a;border:1px solid #ddd}.oci-btn-secondary:hover:not(:disabled){background:#eee}.oci-btn-secondary:disabled{opacity:.7;cursor:not-allowed}.oci-btn-danger{background:#fff;color:#c62828;border:1px solid #ef9a9a}.oci-btn-danger:hover{background:#ffebee}.oci-btn-outline{background:transparent;color:#6a1b9a;border:1px solid #6a1b9a}.oci-btn-outline:hover{background:#6a1b9a14}.oci-btn-continue{background:linear-gradient(135deg,#7b1fa2,#6a1b9a);color:#fff;padding:12px 24px;width:100%;max-width:200px}.oci-btn-continue:hover{background:linear-gradient(135deg,#6a1b9a,#4a148c)}.oci-message{padding:12px 16px;border-radius:8px;margin-bottom:16px}.oci-message-error{background:#ffebee;color:#c62828;border:1px solid #ef9a9a}.oci-message-success{background:#e8f5e9;color:#2e7d32;border:1px solid #a5d6a7}.oci-message-success code,.oci-message-warning code{background:#0000000f;padding:2px 6px;border-radius:4px}.oci-message-warning{background:#fff8e1;color:#f57f17;border:1px solid #ffca28}.oci-projects-section h2{font-size:20px;color:#312d2a;margin:0 0 16px}.oci-empty{color:#5c5c5c;padding:24px;background:#fafafa;border-radius:8px;border:1px dashed #ddd}.oci-project-list{list-style:none;margin:0;padding:0}.oci-project-card{padding:16px 20px;background:#fff;border:1px solid #e0e0e0;border-radius:8px;margin-bottom:12px;box-shadow:0 1px 3px #0000000f}.oci-project-card-list{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}.oci-project-card-list .oci-project-actions{margin-top:0}.oci-project-card-list .oci-project-actions a.oci-btn{text-decoration:none}.oci-project-info h3{margin:0 0 4px;font-size:16px;color:#312d2a}.oci-project-meta{margin:0;font-size:13px;color:#5c5c5c}.oci-project-command{margin-top:12px;padding-top:12px;border-top:1px solid #eee}.oci-command-label{display:block;font-size:13px;font-weight:500;color:#555;margin-bottom:6px}.oci-command-input{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;font-family:ui-monospace,monospace;margin-bottom:10px;box-sizing:border-box}.oci-command-input:focus{outline:none;border-color:#7b1fa2}.oci-project-actions{display:flex;flex-wrap:wrap;gap:10px}.oci-network-result{margin-top:32px;padding:20px;background:#f8f9fa;border:1px solid #dee2e6;border-radius:8px}.oci-network-result h2{margin:0 0 12px;font-size:18px;color:#312d2a}.oci-result-json{margin:0;padding:16px;background:#fff;border:1px solid #e9ecef;border-radius:6px;font-size:12px;overflow:auto;max-height:400px;white-space:pre-wrap;word-break:break-all}.oci-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:10000;display:flex;align-items:center;justify-content:center;padding:24px}.oci-modal{background:#fff;border-radius:12px;box-shadow:0 8px 32px #0003;max-width:520px;width:100%;max-height:90vh;overflow-y:auto}.oci-modal-header{padding:24px 24px 8px;position:relative}.oci-modal-header h2{font-size:22px;font-weight:700;color:#4a148c;margin:0 0 8px}.oci-modal-subtitle{color:#555;margin:0;font-size:14px;line-height:1.4}.oci-modal-close{position:absolute;top:20px;right:20px;background:none;border:none;font-size:24px;color:#5c5c5c;cursor:pointer;line-height:1;padding:4px}.oci-modal-close:hover{color:#312d2a}.oci-modal-form{padding:8px 24px 24px}.oci-form-breadcrumb{font-size:12px;color:#888;margin-bottom:20px}.oci-form-group{margin-bottom:18px}.oci-form-group label{display:block;font-size:14px;font-weight:500;color:#312d2a;margin-bottom:6px}.oci-label-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:#7b1fa2;margin-right:6px;vertical-align:middle}.oci-required{color:#c62828}.oci-form-hint{font-size:12px;color:#5c5c5c;margin:0 0 8px;line-height:1.4}.oci-form-hint code,.oci-form-key-path code{background:#f0f0f0;padding:2px 6px;border-radius:4px;font-size:12px}.oci-form-key-path{font-size:12px;color:#555;margin:8px 0 0}.oci-form-group-checkbox{display:flex;flex-direction:column;gap:4px}.oci-form-group-checkbox label{display:flex;align-items:center;gap:8px;cursor:pointer}.oci-form-group-checkbox input[type=checkbox]{width:18px;height:18px}.oci-input{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;box-sizing:border-box}.oci-input:focus{outline:none;border-color:#7b1fa2;box-shadow:0 0 0 2px #7b1fa233}.oci-file-drop{border:2px dashed #ccc;border-radius:8px;padding:20px;text-align:center;position:relative;background:#fafafa}.oci-file-drop .oci-file-text{display:block;color:#5c5c5c;font-size:14px;margin-bottom:10px}.oci-file-input{position:absolute;left:0;top:0;width:100%;height:100%;opacity:0;cursor:pointer}.oci-form-error{color:#c62828;font-size:13px;margin:0 0 12px}.oci-form-warning{font-size:12px;color:#888;margin:0 0 16px}.oci-modal-footer{margin-top:8px}.oci-modal-footer-split{display:flex;justify-content:space-between;align-items:center;gap:12px}.oci-modal-footer-split .oci-btn-continue{width:auto;max-width:none}.oci-step-indicator{display:flex;align-items:center;justify-content:center;padding:16px 24px 8px;gap:0}.oci-step{display:flex;flex-direction:column;align-items:center;gap:4px;opacity:.4;transition:opacity .3s}.oci-step-active{opacity:1}.oci-step-done .oci-step-number{background:#4caf50;border-color:#4caf50}.oci-step-number{width:28px;height:28px;border-radius:50%;border:2px solid #7b1fa2;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#7b1fa2;background:#fff}.oci-step-active .oci-step-number{background:#7b1fa2;color:#fff}.oci-step-label{font-size:11px;color:#5c5c5c;font-weight:500}.oci-step-line{width:40px;height:2px;background:#ddd;margin:0 8px 18px}.oci-step-content{animation:oci-fade-in .3s ease}@keyframes oci-fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.oci-progress-bar{position:relative;height:6px;background:#e0e0e0;border-radius:3px;margin-bottom:20px;overflow:hidden}.oci-progress-fill{height:100%;background:linear-gradient(90deg,#7b1fa2,#4caf50);border-radius:3px;transition:width .4s ease}.oci-progress-text{position:absolute;top:10px;left:0;font-size:11px;color:#888}.oci-form-group-error .oci-input,.oci-input-error{border-color:#c62828;background:#fff5f5}.oci-input-error:focus{border-color:#c62828;box-shadow:0 0 0 2px #c6282833}.oci-input-valid{border-color:#4caf50}.oci-input-valid:focus{border-color:#4caf50;box-shadow:0 0 0 2px #4caf5033}.oci-field-error{color:#c62828;font-size:12px;margin:4px 0 0;line-height:1.3}.oci-field-valid{color:#4caf50;font-size:12px;margin:4px 0 0}.oci-file-drop-error{border-color:#c62828;background:#fff5f5}.oci-file-drop-valid{border-color:#4caf50;background:#f5fff5}.oci-file-icon{color:#4caf50;font-weight:700}.oci-review-section{margin-bottom:20px}.oci-review-section h3{font-size:16px;color:#4a148c;margin:0 0 12px}.oci-review-grid{display:flex;flex-direction:column;gap:8px}.oci-review-item{display:flex;justify-content:space-between;align-items:flex-start;padding:8px 12px;background:#fafafa;border-radius:6px;border:1px solid #eee;gap:12px}.oci-review-label{font-size:13px;color:#5c5c5c;font-weight:500;white-space:nowrap}.oci-review-value{font-size:13px;color:#312d2a;text-align:right;word-break:break-all}.oci-review-mono{font-family:ui-monospace,monospace;font-size:12px}.oci-empty-state{text-align:center;padding:40px 24px;background:#fafafa;border-radius:8px;border:1px dashed #ddd}.oci-empty-icon{font-size:48px;margin-bottom:12px}.oci-empty-state .oci-empty{border:none;background:none;padding:0;margin-bottom:16px}.oci-error-actions{display:flex;gap:8px;margin-top:8px}.oci-btn-inline{background:none;border:1px solid currentColor;border-radius:4px;padding:4px 10px;font-size:12px;cursor:pointer;color:inherit;opacity:.8}.oci-project-date{font-size:11px;color:#999;margin:4px 0 0}.oci-btn:disabled{opacity:.5;cursor:not-allowed}.zoomable-svg-viewer{position:relative;width:100%;height:100%;min-height:500px;background:transparent;border-radius:6px;overflow:hidden;-webkit-user-select:none;user-select:none}.zoomable-svg-container{width:100%;height:100%;min-height:500px;overflow:hidden;position:relative}.zoomable-svg-wrapper{position:absolute;top:0;left:0;will-change:transform}.zoomable-svg-wrapper svg{display:block;max-width:none;box-shadow:0 4px 20px #0000001a;background:#fff;border-radius:4px}.zoomable-svg-wrapper svg text{pointer-events:auto;cursor:help}.zoomable-svg-wrapper svg rect,.zoomable-svg-wrapper svg circle,.zoomable-svg-wrapper svg path{pointer-events:auto}.zoomable-viewer-controls{position:absolute;top:12px;right:12px;z-index:100;display:flex;align-items:center;gap:4px;background:#fff;padding:4px 8px;border-radius:6px;box-shadow:0 1px 3px #0000001a}.zoomable-viewer-controls button{width:28px;height:28px;border:none;background:#f5f5f5;border-radius:4px;cursor:pointer;font-size:16px;font-weight:700;color:#312d2a;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.zoomable-viewer-controls button:hover{background:#e0e0e0}.zoomable-viewer-controls button:active{background:#d0d0d0}.zoomable-viewer-controls .zoom-level{min-width:50px;text-align:center;font-size:12px;font-weight:500;color:#5c5c5c}.zoomable-viewer-instructions{position:absolute;bottom:12px;left:50%;transform:translate(-50%);z-index:100;background:#0009;color:#fff;padding:6px 14px;border-radius:20px;font-size:12px;opacity:0;transition:opacity .3s ease;pointer-events:none}.zoomable-svg-viewer:hover .zoomable-viewer-instructions{opacity:1}.zoomable-svg-tooltip{position:fixed;z-index:1000;background:#212121f2;color:#fff;padding:8px 12px;border-radius:6px;font-size:13px;font-weight:500;max-width:350px;word-wrap:break-word;box-shadow:0 4px 15px #0000004d;pointer-events:none;animation:tooltipFadeIn .15s ease;border:1px solid rgba(255,255,255,.1)}@keyframes tooltipFadeIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.zoomable-svg-viewer:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background-image:linear-gradient(rgba(0,0,0,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(0,0,0,.03) 1px,transparent 1px);background-size:20px 20px;pointer-events:none}.zoomable-svg-viewer.loading{display:flex;align-items:center;justify-content:center}.zoomable-svg-viewer.loading:after{content:"";width:40px;height:40px;border:3px solid #e0e0e0;border-top-color:#c74634;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 768px){.zoomable-svg-viewer{min-height:350px}.zoomable-viewer-controls{top:8px;right:8px;padding:3px 6px}.zoomable-viewer-controls button{width:26px;height:26px;font-size:14px}.zoomable-viewer-controls .zoom-level{min-width:45px;font-size:11px}.zoomable-svg-tooltip{max-width:250px;font-size:12px}}.zoomable-viewer-controls button:focus{outline:2px solid #C74634;outline-offset:2px}.zoomable-viewer-controls button:disabled{opacity:.5;cursor:not-allowed;transform:none}.zoom-presets{display:flex;align-items:center;gap:2px;margin:0 4px;padding:0 4px;border-left:1px solid #ddd;border-right:1px solid #ddd}.zoom-presets button{width:36px;height:24px;border:none;background:#f0f0f0;border-radius:3px;cursor:pointer;font-size:11px;font-weight:600;color:#555;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.zoom-presets button:hover{background:#e0e0e0;color:#312d2a}.zoom-presets button.active{background:#c74634;color:#fff}.saved-collections-panel{background:#fff;border-radius:8px;border:1px solid #e1e4e8;padding:16px;margin:16px 0}.saved-collections-panel.compact{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:90%;max-width:600px;max-height:80vh;overflow-y:auto;box-shadow:0 4px 20px #0000004d;z-index:1000}.saved-collections-compact{display:inline-block}.saved-collections-toggle{display:flex;align-items:center;gap:8px}.saved-collections-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid #e1e4e8}.saved-collections-header h3{margin:0;font-size:1.1rem;color:#312d2a}.saved-collections-close{background:none;border:none;font-size:24px;color:#5c5c5c;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.saved-collections-close:hover{background:#f3f4f6;color:#312d2a}.saved-collections-notification{padding:10px 16px;border-radius:6px;margin-bottom:12px;font-size:.9rem;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.saved-collections-notification.success{background:#d1fae5;color:#065f46;border:1px solid #a7f3d0}.saved-collections-notification.error{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}.saved-collections-toolbar{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:16px;align-items:center}.saved-collections-search{flex:1;min-width:200px}.saved-collections-search input{width:100%}.saved-collections-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.saved-collections-view-toggle{display:flex;gap:4px;background:#f3f4f6;padding:4px;border-radius:6px}.saved-collections-view-toggle .view-btn{padding:6px 12px;border:none;background:transparent;color:#5c5c5c;font-size:.85rem;cursor:pointer;border-radius:4px;transition:all .2s}.saved-collections-view-toggle .view-btn:hover{color:#312d2a}.saved-collections-view-toggle .view-btn.active{background:#fff;color:#2563eb;box-shadow:0 1px 3px #0000001a}.saved-collections-list{max-height:400px;overflow-y:auto}.saved-collections-empty{text-align:center;padding:40px 20px;color:#5c5c5c}.saved-collections-empty-icon{font-size:48px;margin-bottom:12px}.saved-collections-empty p{margin:0 0 16px}.saved-collection-item{display:flex;justify-content:space-between;align-items:flex-start;padding:12px;border:1px solid #e1e4e8;border-radius:6px;margin-bottom:8px;cursor:pointer;transition:all .2s;background:#fff}.saved-collection-item:hover{border-color:#2563eb;box-shadow:0 2px 8px #2563eb1a}.saved-collection-item.selected{border-color:#2563eb;background:#eff6ff}.saved-collection-info{flex:1;min-width:0}.saved-collection-name{font-weight:600;color:#312d2a;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.saved-collection-meta{display:flex;gap:12px;font-size:.8rem;color:#5c5c5c;margin-bottom:4px}.saved-collection-project{background:#e5e7eb;padding:2px 8px;border-radius:4px;font-weight:500}.saved-collection-counts{font-size:.8rem;color:#059669;font-weight:500}.saved-collection-actions{display:flex;gap:4px;opacity:0;transition:opacity .2s}.saved-collection-item:hover .saved-collection-actions{opacity:1}.saved-collection-action-btn{background:none;border:none;padding:6px;cursor:pointer;border-radius:4px;font-size:14px;transition:all .2s}.saved-collection-action-btn:hover{background:#f3f4f6}.saved-collection-action-btn.delete:hover{background:#fee2e2}@media (max-width: 768px){.saved-collections-toolbar{flex-direction:column;align-items:stretch}.saved-collections-actions{justify-content:flex-start}.saved-collection-actions{opacity:1}.saved-collection-meta{flex-direction:column;gap:4px}}.saved-collections-list::-webkit-scrollbar{width:8px}.saved-collections-list::-webkit-scrollbar-track{background:#f1f5f9;border-radius:4px}.saved-collections-list::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.saved-collections-list::-webkit-scrollbar-thumb:hover{background:#94a3b8}.saved-collections-panel.compact .oci-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1001}.collapsible-section{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;overflow:hidden;margin-bottom:0}.collapsible-section.collapsed .collapsible-content{display:none!important;height:0!important;overflow:hidden!important}.collapsible-toggle{width:100%;display:flex;align-items:center;gap:10px;padding:12px 16px;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border:none;border-bottom:1px solid #dee2e6;cursor:pointer;font-size:14px;font-weight:600;color:#312d2a;text-align:left;transition:all .2s ease}.collapsible-toggle:hover{background:linear-gradient(135deg,#e9ecef,#dee2e6)}.collapsible-section.collapsed .collapsible-toggle{border-bottom:none}.toggle-icon{transition:transform .3s ease;flex-shrink:0}.toggle-title{flex:1}.collapsible-content{overflow:hidden}.collapsible-content>*{padding:16px}.oci-project-detail{padding:24px 20px;min-height:60vh}.oci-project-detail-container{max-width:100%;margin:0 auto}.oci-error-inline{margin-bottom:16px;padding:10px 14px;border-radius:6px;font-size:13px;max-width:100%}.oci-project-detail-header{margin-bottom:24px}.oci-back-link{display:inline-block;font-size:14px;color:#6a1b9a;text-decoration:none;margin-bottom:8px}.oci-back-link:hover{text-decoration:underline}.oci-project-detail-header h1{font-size:24px;font-weight:700;color:#4a148c;margin:0 0 4px}.oci-project-title-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.oci-project-title-row h1{margin:0 0 4px}.oci-rename-link{font-size:14px;color:#6a1b9a;background:none;border:none;cursor:pointer;text-decoration:none;padding:4px 0}.oci-rename-link:hover{text-decoration:underline}.oci-project-detail-meta{font-size:13px;color:#5c5c5c;margin:0}.oci-quick-actions{margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid #eee}.oci-quick-actions-title{font-size:14px;font-weight:600;color:#555;margin:0 0 10px}.oci-quick-actions-buttons{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.oci-quick-action-wrap{display:inline-flex;align-items:center;gap:4px}.oci-btn-quick{padding:8px 14px;font-size:13px;background:#ede7f6;color:#4a148c;border:1px solid #ce93d8;border-radius:6px;cursor:pointer;font-weight:500}.oci-btn-quick:hover:not(:disabled){background:#e1bee7}.oci-btn-quick:disabled{opacity:.7;cursor:not-allowed}.oci-quick-action-remove{width:24px;height:24px;padding:0;border:1px solid #e0e0e0;border-radius:4px;background:#fff;color:#5c5c5c;font-size:16px;line-height:1;cursor:pointer;transition:background .2s,color .2s}.oci-quick-action-remove:hover{background:#ffebee;color:#c62828;border-color:#ef9a9a}.oci-add-quick-btn,.oci-add-quick-btn-first{font-size:13px}.oci-add-quick-btn-first{margin-bottom:20px}.oci-project-detail-body{display:flex;gap:24px;align-items:flex-start}.oci-project-pages-sidebar{flex:0 0 220px;min-width:220px;background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:16px;box-shadow:0 1px 3px #0000000f;display:flex;flex-direction:column;overflow:hidden;position:relative;transition:flex-basis .3s ease,min-width .3s ease,width .3s ease}.oci-project-pages-sidebar.collapsed{flex:0 0 48px;min-width:48px;width:48px;padding:0}.oci-project-pages-sidebar h2{font-size:14px;font-weight:600;color:#312d2a;margin:0 0 12px}.oci-sidebar-content{display:flex;flex-direction:column;flex:1;overflow:hidden}.panel-collapse-toggle{position:absolute;top:12px;right:12px;width:32px;height:32px;border:1px solid #dee2e6;background:#fff;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#5c5c5c;z-index:10;transition:all .2s ease}.panel-collapse-toggle:hover{background:#f5f5f5;color:#c74634;border-color:#c74634}.oci-project-pages-sidebar.collapsed .panel-collapse-toggle{position:relative;top:0;right:0;margin:8px auto}.collapsed-label{writing-mode:vertical-rl;text-orientation:mixed;transform:rotate(180deg);display:flex;align-items:center;justify-content:center;flex:1;padding:16px 0}.collapsed-label-text{font-size:13px;font-weight:500;color:#5c5c5c;white-space:nowrap}.oci-add-page-btn{width:100%;margin-bottom:12px;font-size:13px}.oci-project-pages-list{list-style:none;margin:0;padding:0}.oci-project-pages-list li{display:flex;align-items:center;gap:4px;margin-bottom:4px}.oci-page-tab{flex:1;text-align:left;padding:10px 12px;border:1px solid #e0e0e0;border-radius:6px;background:#fafafa;font-size:14px;cursor:pointer;transition:background .2s,border-color .2s}.oci-page-tab:hover{background:#f0f0f0}.oci-page-tab.active{background:#ede7f6;border-color:#7b1fa2;color:#4a148c;font-weight:500}.oci-page-delete{flex:0 0 32px;width:32px;height:32px;padding:0;border:1px solid #e0e0e0;border-radius:6px;background:#fff;color:#5c5c5c;font-size:18px;line-height:1;cursor:pointer;transition:background .2s,color .2s}.oci-page-delete:hover{background:#ffebee;color:#c62828;border-color:#ef9a9a}.oci-no-pages{font-size:13px;color:#888;margin:8px 0 0}.oci-project-page-content{flex:1;min-width:0;background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:20px;box-shadow:0 1px 3px #0000000f;transition:padding .3s ease}.oci-project-pages-sidebar.collapsed~.oci-project-page-content{padding:24px}.oci-page-title{font-size:18px;font-weight:600;color:#312d2a;margin:0 0 16px}.oci-select-page-hint{color:#888;font-size:14px;margin:0}.oci-project-page-content .oci-form-group{margin-bottom:16px}.oci-project-page-content .oci-form-group .oci-btn{margin-top:8px}.oci-compartment-panel{margin-bottom:20px;padding:16px;background:#f6f5ff;border:1px solid #d7c8ff;border-radius:8px}.oci-compartment-row{display:flex;flex-wrap:wrap;gap:10px;align-items:flex-end}.oci-compartment-row label{flex:0 0 100%}.oci-compartment-input{flex:1;min-width:200px}.oci-compartment-row>label{font-size:13px;color:#4a148c;margin-bottom:4px}.oci-compartment-status{margin:10px 0 0;color:#2e7d32;font-size:13px}.oci-compartment-error{margin:6px 0 0;color:#c62828;font-size:13px}.oci-compartment-selector-row{display:flex;flex-wrap:wrap;gap:10px;align-items:flex-start;margin-bottom:12px}.oci-compartment-selector-row>label{flex:0 0 100%;font-size:13px;color:#4a148c;margin-bottom:4px;font-weight:500}.oci-compartment-dropdown-container{position:relative;flex:1;min-width:280px}.oci-compartment-dropdown-trigger{width:100%;padding:10px 14px;background:#fff;border:1px solid #ce93d8;border-radius:6px;font-size:14px;color:#4a148c;cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:border-color .2s,box-shadow .2s}.oci-compartment-dropdown-trigger:hover:not(:disabled){border-color:#7b1fa2}.oci-compartment-dropdown-trigger:disabled{opacity:.6;cursor:not-allowed;background:#f5f5f5}.oci-dropdown-arrow{font-size:10px;color:#6a1b9a;margin-left:8px}.oci-compartment-dropdown-menu{position:absolute;top:100%;left:0;right:0;margin-top:4px;background:#fff;border:1px solid #ce93d8;border-radius:6px;box-shadow:0 4px 12px #00000026;z-index:100;max-height:320px;display:flex;flex-direction:column}.oci-compartment-dropdown-header{display:flex;justify-content:space-between;padding:8px 12px;border-bottom:1px solid #f0f0f0;background:#fafafa;border-radius:6px 6px 0 0}.oci-compartment-dropdown-header-left{display:flex;gap:8px}.oci-compartment-refresh-btn,.oci-compartment-clear-btn,.oci-compartment-expand-btn,.oci-compartment-collapse-btn{font-size:11px;padding:4px 10px;background:transparent;border:1px solid #ddd;border-radius:4px;cursor:pointer;color:#6a1b9a;transition:background .2s}.oci-compartment-refresh-btn:hover:not(:disabled),.oci-compartment-clear-btn:hover,.oci-compartment-expand-btn:hover,.oci-compartment-collapse-btn:hover{background:#ede7f6}.oci-compartment-refresh-btn:disabled{opacity:.6;cursor:not-allowed}.oci-compartment-expand-btn,.oci-compartment-collapse-btn{color:#555;border-color:#ccc}.oci-compartment-expand-btn:hover,.oci-compartment-collapse-btn:hover{background:#e8e8e8}.oci-compartment-dropdown-tree{overflow-y:auto;max-height:320px;padding:4px 0}.oci-compartment-dropdown-list{overflow-y:auto;max-height:260px;padding:4px 0}.oci-compartment-dropdown-empty{padding:16px;text-align:center;color:#888;font-size:13px}.oci-compartment-dropdown-item{display:flex;align-items:center;gap:10px;padding:8px 12px;cursor:pointer;transition:background .15s;font-size:13px}.oci-compartment-dropdown-item:hover{background:#f5f5f5}.oci-compartment-dropdown-item.selected{background:#ede7f6}.oci-compartment-dropdown-item input[type=checkbox]{margin:0;flex-shrink:0}.oci-compartment-name{flex:1;font-weight:500;color:#312d2a}.oci-compartment-ocid{font-size:11px;color:#888;font-family:monospace}.oci-compartment-tree-node{display:flex;flex-direction:column}.oci-compartment-tree-row{display:flex;align-items:center;gap:6px;padding:6px 12px;cursor:pointer;transition:background .15s;min-height:32px;border-bottom:1px solid #f5f5f5}.oci-compartment-tree-row:hover{background:#f8f8f8}.oci-compartment-tree-row.selected{background:#ede7f6}.oci-compartment-tree-toggle{width:20px;height:20px;padding:0;border:none;background:transparent;cursor:pointer;font-size:10px;color:#6a1b9a;display:flex;align-items:center;justify-content:center;flex-shrink:0}.oci-compartment-tree-toggle:hover{background:#e0e0e0;border-radius:3px}.oci-compartment-tree-spacer{width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:8px;color:#bbb;flex-shrink:0}.oci-compartment-tree-label{display:flex;align-items:center;gap:8px;flex:1;cursor:pointer;min-width:0}.oci-compartment-tree-label input[type=checkbox]{margin:0;flex-shrink:0}.oci-compartment-tree-name{font-size:13px;color:#312d2a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.oci-compartment-tree-count{font-size:11px;color:#888;background:#f0f0f0;padding:1px 6px;border-radius:10px;flex-shrink:0}.oci-compartment-tree-select-all{font-size:10px;padding:2px 8px;border:1px solid #ce93d8;background:#fff;color:#6a1b9a;border-radius:4px;cursor:pointer;transition:all .15s;white-space:nowrap;flex-shrink:0}.oci-compartment-tree-select-all:hover{background:#ede7f6}.oci-compartment-tree-select-all.all-selected{background:#4caf50;color:#fff;border-color:#4caf50}.oci-compartment-tree-select-all.some-selected{background:#ff9800;color:#fff;border-color:#ff9800}.oci-compartment-tree-children{display:flex;flex-direction:column}.oci-selected-compartments{margin:12px 0;padding:12px;background:#fff;border:1px solid #e0e0e0;border-radius:6px}.oci-selected-compartments>label{display:block;font-size:12px;color:#5c5c5c;margin-bottom:8px;font-weight:500}.oci-selected-compartments-list{display:flex;flex-wrap:wrap;gap:8px}.oci-compartment-tag{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;background:linear-gradient(135deg,#7b1fa2,#6a1b9a);color:#fff;border-radius:16px;font-size:12px;font-weight:500}.oci-compartment-tag-remove{width:16px;height:16px;padding:0;border:none;background:#ffffff4d;color:#fff;border-radius:50%;cursor:pointer;font-size:12px;line-height:1;display:flex;align-items:center;justify-content:center;transition:background .2s}.oci-compartment-tag-remove:hover{background:#ffffff80}.oci-compartment-options{display:flex;flex-wrap:wrap;gap:16px;margin:12px 0;padding:10px 12px;background:#7b1fa20d;border-radius:6px}.oci-compartment-option{display:flex;align-items:center;gap:8px;font-size:13px;color:#4a148c;cursor:pointer}.oci-compartment-option input[type=checkbox]{margin:0}.oci-cascading-compartments{display:flex;flex-direction:row;flex-wrap:wrap;gap:20px;margin-bottom:16px;align-items:flex-start}.oci-cascading-row{display:flex;flex-direction:column;gap:8px;flex:1;min-width:280px;max-width:450px}.oci-cascading-label{font-size:13px;font-weight:600;color:#4a148c;display:flex;align-items:center;gap:10px}.oci-cascading-parent-badge{font-size:11px;font-weight:500;color:#6a1b9a;background:#ede7f6;padding:2px 10px;border-radius:12px}.oci-cascading-controls{display:flex;flex-direction:column;gap:8px}.oci-cascading-select-wrapper{display:flex;flex-direction:column;gap:6px}.oci-cascading-search{padding:8px 12px;border:1px solid #ce93d8;border-radius:6px;font-size:13px;background:#fff}.oci-cascading-search:focus{outline:none;border-color:#7b1fa2;box-shadow:0 0 0 3px #7b1fa21f}.oci-select.oci-cascading-select{width:100%;padding:0;border:1px solid #ce93d8;border-radius:6px;font-size:13px;font-family:inherit;background:#fff;cursor:pointer;overflow-y:auto}.oci-select.oci-cascading-select option{padding:8px 12px;border-bottom:1px solid #f5f5f5}.oci-select.oci-cascading-select option:checked{background:#ede7f6;color:#4a148c;font-weight:600}.oci-select.oci-cascading-select option:hover{background:#f8f4ff}.oci-cascading-count{font-size:11px;color:#888;padding-left:2px}.oci-cascading-loading{font-size:13px;color:#6a1b9a;font-style:italic;padding:8px 0}.oci-cascading-empty{font-size:13px;color:#888;font-style:italic;padding:8px 0}.oci-cascading-add-parent{padding-top:4px;flex-basis:100%;margin-top:-8px}.oci-cascading-add-parent .oci-btn{font-size:12px;padding:6px 12px}.oci-compartment-divider{display:flex;align-items:center;margin:16px 0;gap:12px}.oci-compartment-divider:before,.oci-compartment-divider:after{content:"";flex:1;height:1px;background:#d7c8ff}.oci-compartment-divider span{font-size:12px;color:#888;white-space:nowrap;text-transform:uppercase;letter-spacing:.5px}.oci-compartment-manual-row{margin-top:16px;padding-top:16px;border-top:1px dashed #d7c8ff}.oci-compartment-manual-row>label{display:block;font-size:12px;color:#5c5c5c;margin-bottom:8px}.oci-compartment-manual-input-group{display:flex;flex-wrap:wrap;gap:10px;align-items:flex-end}.oci-compartment-manual-input-group .oci-compartment-input{flex:1;min-width:200px}.oci-compartment-parse-row{margin-top:8px;display:flex;align-items:center;gap:10px}.oci-compartment-parse-row .oci-btn-sm{padding:6px 12px;font-size:12px;background:#4caf50;color:#fff;border:none;border-radius:4px;cursor:pointer}.oci-compartment-parse-row .oci-btn-sm:hover{background:#45a049}.oci-btn-clear{margin-top:10px;padding:6px 12px;font-size:12px;background:#f5f5f5;color:#5c5c5c;border:1px solid #ddd;border-radius:4px;cursor:pointer}.oci-btn-clear:hover{background:#e0e0e0}.oci-compartment-actions{margin-top:16px;display:flex;flex-wrap:wrap;gap:10px}.oci-network-inventory-section{margin-bottom:24px;padding:18px;background:#f8f9fa;border:1px solid #e5e5e5;border-radius:8px}.oci-network-inventory-section .oci-quick-actions-title{margin-top:0}.oci-network-inventory-section .oci-form-hint{margin:0 0 12px}.oci-inventory-buttons{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.oci-btn-inventory{padding:8px 14px;font-size:13px;background:#fff;color:#4a148c;border:1px solid #ce93d8;border-radius:6px;cursor:pointer;font-weight:500}.oci-btn-inventory:hover:not(:disabled){background:#ede7f6}.oci-btn-inventory:disabled{opacity:.7;cursor:not-allowed}.oci-full-inventory-row{display:flex;flex-wrap:wrap;gap:12px;align-items:center}.oci-inventory-dashboard{margin-top:16px;padding:12px 16px;background:#fff;border:1px solid #e0e0e0;border-radius:6px;font-size:13px}.oci-inventory-dashboard-title{margin:0 0 8px;font-size:13px;font-weight:600;color:#312d2a}.oci-inventory-dashboard-list{margin:0;padding:0;list-style:none;display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:6px 16px}.oci-inventory-dashboard-list li{margin:0}.oci-dash-ok{color:#2e7d32}.oci-dash-ok strong{font-weight:600}.oci-dash-fail{color:#5c5c5c}.oci-dash-fail em{font-style:normal;color:#999}.oci-network-data{margin-top:20px;background:#fff;border:1px solid #e0e0f0;border-radius:8px;padding:16px}.oci-network-data h4{margin:0 0 12px;font-size:16px;color:#312d2a}.oci-network-list{margin:0;padding:0;list-style:none;display:grid;gap:8px}.oci-network-item{padding:12px;border:1px solid #e0e0e0;border-radius:6px;background:#fafafa;display:flex;flex-direction:column;gap:4px;font-size:13px}.oci-network-item strong{font-size:14px;color:#4a148c}.oci-command-template-list{margin:16px 0 0;list-style:none;padding:0;display:flex;flex-wrap:wrap;gap:8px}.oci-command-template{border:1px solid #dcdcdc;border-radius:6px;padding:6px 10px;background:#fff;font-size:12px;cursor:pointer;transition:background .2s}.oci-command-template:hover{background:#ede7f6}.oci-template-status{margin-top:6px;font-size:12px;color:#2e7d32}.oci-modal-sm{max-width:400px}.oci-step-badge{display:inline-block;background:linear-gradient(135deg,#7b1fa2,#6a1b9a);color:#fff;font-size:11px;font-weight:700;padding:3px 10px;border-radius:12px;margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.oci-panel-title{font-size:16px;font-weight:600;color:#312d2a;margin:0 0 12px}.oci-inventory-progress{margin-top:12px}.oci-inventory-progress-bar{height:6px;background:#e0e0e0;border-radius:3px;overflow:hidden;margin-bottom:6px}.oci-inventory-progress-fill{height:100%;background:linear-gradient(90deg,#7b1fa2,#4caf50);border-radius:3px;transition:width .3s ease}.oci-inventory-progress-text{font-size:12px;color:#5c5c5c}.oci-dash-empty{color:#999}.oci-dash-icon{display:inline-block;width:16px;font-size:12px}.oci-dash-ok .oci-dash-icon{color:#4caf50}.oci-dash-empty .oci-dash-icon{color:#ccc}.oci-completeness-section{margin-bottom:24px;padding:18px;background:#f0f7ff;border:1px solid #bbdefb;border-radius:8px}.oci-completeness-group-title{font-size:13px;font-weight:600;color:#555;margin:10px 0 6px;text-transform:uppercase;letter-spacing:.04em}.oci-completeness-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:8px;margin-bottom:16px}.oci-completeness-grid-compact{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:5px}.oci-completeness-grid-compact .oci-completeness-item{padding:5px 8px;font-size:12px}.oci-completeness-grid-compact .oci-completeness-icon,.oci-completeness-grid-compact .oci-completeness-count{font-size:12px}.oci-completeness-item{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:6px;font-size:13px;border:1px solid transparent}.oci-completeness-ok{background:#e8f5e9;border-color:#c8e6c9;color:#2e7d32}.oci-completeness-missing{background:#fff3e0;border-color:#ffe0b2;color:#e65100}.oci-completeness-empty{background:#f5f5f5;border-color:#e0e0e0;color:#888}.oci-completeness-icon{font-size:14px;font-weight:700;flex-shrink:0}.oci-completeness-label{flex:1}.oci-completeness-count{font-weight:700;font-size:14px}.oci-completeness-summary{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:16px;font-size:13px}.oci-completeness-stat{color:#312d2a}.oci-completeness-warning{color:#e65100}.oci-detected-topology{margin-bottom:16px}.oci-detected-label{display:block;font-size:13px;font-weight:500;color:#555;margin-bottom:8px}.oci-topology-selector{display:flex;flex-wrap:wrap;gap:8px}.oci-topology-option{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#fff;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;transition:all .2s;font-size:13px}.oci-topology-option:hover{border-color:#7b1fa2;background:#faf5ff}.oci-topology-selected{border-color:#7b1fa2;background:#ede7f6}.oci-topo-number{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:#7b1fa2;color:#fff;font-size:12px;font-weight:700;flex-shrink:0}.oci-topo-name{font-size:12px;color:#312d2a}.oci-topo-badge{font-size:10px;background:#4caf50;color:#fff;padding:2px 6px;border-radius:8px;font-weight:600;text-transform:uppercase}.oci-diagram-actions{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:12px}.oci-btn-generate{padding:12px 20px;font-size:14px}.oci-diagram-hint{font-size:13px;color:#e65100;margin:8px 0 0;line-height:1.4}.oci-loading-state{display:flex;align-items:center;gap:10px;padding:16px;color:#5c5c5c;font-size:14px}.oci-spinner{display:inline-block;width:20px;height:20px;border:3px solid #e0e0e0;border-top-color:#7b1fa2;border-radius:50%;animation:oci-spin .8s linear infinite}@keyframes oci-spin{to{transform:rotate(360deg)}}.oci-empty-page-state{text-align:center;padding:40px 24px}.oci-empty-page-state .oci-empty-icon{font-size:48px;margin-bottom:12px}.oci-error-inline{display:flex;flex-wrap:wrap;align-items:flex-start;gap:8px}.oci-error-inline .oci-error-actions{display:flex;gap:6px;margin-left:auto}.oci-btn-inline{background:none;border:1px solid currentColor;border-radius:4px;padding:3px 8px;font-size:11px;cursor:pointer;color:inherit;opacity:.8;white-space:nowrap}.oci-btn-inline:hover{opacity:1;background:#0000000d}.oci-diagram-viewer-section{margin-bottom:24px;padding:18px;background:#f8f5ff;border:2px solid #ce93d8;border-radius:8px;transition:margin .3s ease}.oci-project-pages-sidebar.collapsed~.oci-project-page-content .oci-diagram-viewer-section{margin-left:0;margin-right:0}.oci-diagram-toolbar{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:16px}.oci-diagram-canvas{background:#fff;border:1px solid #e0e0e0;border-radius:8px;overflow:auto;max-height:700px;position:relative}.oci-diagram-canvas-zoomable{overflow:hidden;max-height:none;min-height:500px;height:70vh;padding:0;width:100%;margin:0;border-radius:8px;border:2px solid #ce93d8;box-shadow:0 4px 12px #4a148c26;background:linear-gradient(135deg,#fafafa,#f0f0f0);transition:height .3s ease}.oci-project-pages-sidebar.collapsed~.oci-project-page-content .oci-diagram-canvas-zoomable{height:75vh;min-height:550px}@media (min-width: 1400px){.oci-project-pages-sidebar.collapsed~.oci-project-page-content .oci-diagram-canvas-zoomable{height:80vh;min-height:600px}}.oci-zoomable-viewer{width:100%;height:100%;min-height:500px;border-radius:6px}.oci-diagram-svg{width:100%;min-height:400px;display:block}.oci-custom-diagram-svg{width:100%;min-height:400px;display:block;padding:8px}.oci-custom-diagram-svg svg{width:100%;height:auto;display:block}.oci-custom-diagram-svg svg text,.oci-custom-diagram-svg svg rect{cursor:help}.oci-custom-diagram-svg svg text:hover,.oci-custom-diagram-svg svg rect:hover{filter:brightness(.95)}.oci-topology-custom .oci-topo-number{background:#e65100;font-size:14px}.oci-topology-custom:hover{border-color:#e65100;background:#fff3e0}.oci-topology-custom.oci-topology-selected{border-color:#e65100;background:#ffe0b2}.oci-export-dropdown{position:relative;display:inline-block}.oci-btn.oci-btn-export-dropdown{background-color:#0d6efd;color:#fff;border-color:#0d6efd;padding-right:28px;min-width:160px}.oci-btn.oci-btn-export-dropdown:hover{background-color:#0b5ed7;border-color:#0b5ed7}.oci-export-chevron{margin-left:4px;font-size:10px;opacity:.9;transition:transform .2s ease}.oci-export-chevron.open{transform:rotate(180deg)}.oci-export-menu{position:absolute;bottom:calc(100% + 6px);left:0;min-width:100%;background:#fff;border-radius:6px;box-shadow:0 -4px 16px #00000026;list-style:none;margin:0;padding:4px 0;z-index:1001;overflow:hidden}.oci-export-menu li{margin:0}.oci-export-menu-item{display:block;width:100%;padding:8px 16px;background:none;border:none;text-align:left;font-family:inherit;font-size:13px;font-weight:500;color:#312d2a;cursor:pointer;transition:background .15s ease}.oci-export-menu-item:hover{background:#f0f7ff;color:#0d6efd}.oci-inventory-category{margin-bottom:14px}.oci-inventory-categories-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px 20px;margin-bottom:16px}@media (max-width: 768px){.oci-inventory-categories-grid{grid-template-columns:1fr;gap:10px}}.oci-inventory-category-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#6c757d;margin:0 0 6px;padding-bottom:4px;border-bottom:1px solid #e9ecef}.oci-btn-collected{background:#e8f5e9!important;border-color:#4caf50!important;color:#2e7d32!important}.oci-btn-collected:hover{background:#c8e6c9!important}.oci-hint-note{font-size:11px;color:#888;margin-top:4px}:root{color-scheme:light;--oracle-red: #C74634;--oracle-red-dark: #A63D2E;--oracle-bark: #312D2A;--oracle-white: #FFFFFF;--oracle-bg: #F5F5F5;--oracle-border: #E0E0E0;--oracle-text: #312D2A;--oracle-text-muted: #5C5C5C;--oracle-success: #2e7d32;--oracle-focus: #C74634}*{box-sizing:border-box}html,body{margin:0;padding:0;font-family:Segoe UI,-apple-system,BlinkMacSystemFont,Helvetica Neue,Arial,sans-serif;font-size:16px;line-height:1.5;color:var(--oracle-text);background:var(--oracle-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh}h1,h2,h3,h4,h5,h6,p{margin:0}a{color:inherit;text-decoration:none}button{font-family:inherit}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#ececec}::-webkit-scrollbar-thumb{background:#c74634;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#a63d2e}.container{max-width:1200px;margin:0 auto;padding:0 24px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}:focus-visible{outline:2px solid var(--oracle-red);outline-offset:2px}button:focus:not(:focus-visible),a:focus:not(:focus-visible){outline:none}
