:root{--accent:#00e6ff}
html,body{height:100%;margin:0;font-family:Inter, system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial;overflow:hidden}
body{background:radial-gradient(1200px 600px at 10% 10%, #071029 0%, #00020a 40%, #000000 100%); color:#e6f1ff;-webkit-font-smoothing:antialiased}
.app-header{background:linear-gradient(180deg, rgba(255,255,255,0.02), transparent); border-bottom:1px solid rgba(255,255,255,0.03)}
.app-header h1,.app-header p{color:#e6f1ff}
.search-row input.form-control{max-width:520px;border-radius:10px;box-shadow:0 8px 30px rgba(0,0,0,0.6);background:rgba(255,255,255,0.03);color:inherit;border:1px solid rgba(255,255,255,0.06)}
.search-row button{border-radius:10px;padding:0.6rem 1.1rem;box-shadow:0 6px 18px rgba(0,0,0,0.5)}

.globe-wrap{position:relative;margin-top:22px;display:flex;justify-content:center;align-items:center}
#globeCanvas{width:100%;height:min(68vh,680px);border-radius:14px;overflow:hidden;background:linear-gradient(180deg, rgba(255,255,255,0.02), rgba(0,0,0,0.12));box-shadow:0 20px 60px rgba(0,0,0,0.7);cursor:grab}
#globeCanvas:active{cursor:grabbing}

/* Static overlay (modo leve) */
.static-overlay{position:absolute;left:0;top:0;width:100%;height:100%;border-radius:14px;pointer-events:auto;z-index:2;background:transparent;display:block}
.static-overlay.d-none{display:none}

.brand-card{position:absolute;right:18px;top:18px;background:linear-gradient(135deg, rgba(9,10,14,0.7), rgba(2,6,12,0.6));border-radius:10px;padding:8px 12px;box-shadow:0 8px 30px rgba(0,0,0,0.6);color:#bfefff;backdrop-filter:blur(6px)}
.brand-card a{color:var(--accent);font-weight:600;text-decoration:none}
.loader{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);color:rgba(255,255,255,0.9);font-weight:600;background:rgba(0,0,0,0.45);padding:10px 16px;border-radius:8px;box-shadow:0 6px 24px rgba(0,0,0,0.6)}

ul#suggestions{list-style:none;padding:0;margin:0;display:flex;gap:8px;justify-content:center;flex-wrap:wrap}
ul#suggestions{list-style:none;padding:0;margin:0;display:flex;gap:8px;justify-content:center;flex-wrap:wrap}
ul#suggestions li{display:inline-block;background:rgba(255,255,255,0.03);padding:6px 10px;border-radius:999px;font-size:0.9rem;color:#dbefff;cursor:pointer;border:1px solid rgba(255,255,255,0.04)}
ul#suggestions li:hover{background:rgba(0,230,255,0.08);color:var(--accent);transform:translateY(-3px);transition:all .18s ease}

@media (max-width:767px){
  .search-row{flex-direction:column;gap:8px}
  .search-row input.form-control{width:100%;max-width:100%}
  .search-row button{width:100%}
  #globeCanvas{height:54vh}
  .brand-card{right:10px;top:10px;padding:6px 10px}
}

#globeCanvas::after{content:"";position:absolute;inset:0;pointer-events:none;background-image:linear-gradient(rgba(255,255,255,0.015) 1px, transparent 1px);background-size:100% 24px;mix-blend-mode:overlay;opacity:0.6;animation:scan 12s linear infinite}
@keyframes scan{from{background-position-y:0}to{background-position-y:24px}}

/* pequenos toques para acessibilidade */
input.form-control:focus{outline:none;box-shadow:0 0 0 4px rgba(0,230,255,0.06)}

/* Sugestões (lista de marcas) */
ul#suggestions{gap:10px}
ul#suggestions li.suggestion-item{display:inline-flex;align-items:center;gap:10px;padding:6px 10px;border-radius:12px;background:rgba(255,255,255,0.02);cursor:pointer;border:1px solid rgba(255,255,255,0.02)}
ul#suggestions li.suggestion-item strong{color:#e6f7ff;margin-right:6px}
.siglas-container{display:inline-flex;gap:6px;align-items:center}
.sigla{background:rgba(255,255,255,0.03);color:#dbefff;border:0;padding:4px 8px;border-radius:999px;font-size:0.85rem;cursor:pointer}
.sigla:hover{background:rgba(0,230,255,0.08);color:var(--accent)}

/* Card lateral da marca */
.brand-card{position:absolute;right:18px;top:18px;background:linear-gradient(135deg, rgba(9,10,14,0.75), rgba(2,6,12,0.6));border-radius:12px;padding:10px 12px;box-shadow:0 10px 36px rgba(0,0,0,0.6);color:#bfefff;backdrop-filter:blur(6px);text-align:right;min-width:160px;max-width:320px}
.brand-card .brand-cta{display:inline-block;background:linear-gradient(90deg,var(--accent),#00bcd4);color:#02131a;padding:8px 12px;border-radius:10px;font-weight:700;text-decoration:none;box-shadow:0 8px 20px rgba(0,0,0,0.45)}
.brand-card .brand-desc{color:#cfefff;opacity:0.95;margin-top:8px;font-size:0.9rem;line-height:1.2}

@media (max-width:767px){
  .brand-card{right:10px;top:10px;padding:8px 10px}
  .brand-card .brand-cta{padding:7px 10px}
}

/* Company menu component */
.company-menu-component{display:flex;flex-direction:column;align-items:flex-start;gap:10px;position:relative}
.company-main-row{display:flex;align-items:center;gap:8px}
.company-main-row{position:relative}
.company-main-btn{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;background:linear-gradient(180deg,rgba(255,255,255,0.02),rgba(255,255,255,0.01));border-radius:12px;border:1px solid rgba(255,255,255,0.04);cursor:pointer}
.company-main-logo{width:44px;height:44px;border-radius:8px;object-fit:cover}
.company-toggle-btn{width:36px;height:36px;border-radius:8px;background:transparent;border:1px solid rgba(255,255,255,0.04);color:var(--accent);display:inline-flex;align-items:center;justify-content:center;font-size:14px;cursor:pointer}
.company-main-label{position:relative;left:auto;top:auto;margin-left:8px;transform:translateX(-6px);visibility:hidden;opacity:0;transition:all .18s ease;pointer-events:none;background:linear-gradient(90deg,rgba(255,255,255,0.03),rgba(255,255,255,0.02));padding:6px 10px;border-radius:10px;color:#dbefff;font-weight:700;box-shadow:0 8px 30px rgba(0,0,0,0.6);white-space:nowrap;z-index:10055;display:inline-block}
.company-main-row:hover .company-main-label{visibility:visible;opacity:1;transform:translateX(0)}
.company-main-row.main-label-visible .company-main-label{visibility:visible;opacity:1;transform:translateX(0)}
.company-toggle-btn{z-index:10060}
.company-list-wrap{position:relative;overflow:visible;transition:all .18s ease;width:auto}
.company-menu-component.list-hidden .company-list-wrap{display:none}
.company-grid{display:flex;flex-direction:column;gap:6px;padding:6px;background:transparent;border-radius:10px;width:64px}
.company-item{display:flex;align-items:center;justify-content:center;gap:8px;padding:8px;border-radius:10px;background:transparent;border:0;cursor:pointer;width:64px;position:relative;overflow:visible}
.company-item-logo{width:44px;height:44px;border-radius:50%;object-fit:cover}
.company-item-label{position:absolute;left:76px;top:50%;transform:translateY(-50%) translateX(-10px);opacity:0;visibility:hidden;transition:all .18s cubic-bezier(.2,.9,.2,1);background:linear-gradient(90deg,rgba(255,255,255,0.03),rgba(255,255,255,0.02));padding:8px 12px;border-radius:10px;color:#dbefff;font-weight:700;white-space:nowrap;pointer-events:none;box-shadow:0 8px 30px rgba(0,0,0,0.6);z-index:10050}
.company-item{transform:none}

/* quando em touch o botão pode adicionar .label-visible para manter o rótulo visível */
.company-item.label-visible .company-item-label{opacity:1;transform:translateY(-50%) translateX(0);pointer-events:auto;visibility:visible}

/* Mostrar rótulo no hover (desktop) e no foco (acessibilidade) */
.company-item:hover .company-item-label,
.company-item:focus .company-item-label,
.company-item:focus-within .company-item-label {
  opacity: 1;
  transform: translateY(-50%) translateX(0);
  pointer-events: auto;
  visibility: visible;
}

/* Rótulo flutuante (fallback quando o label interno fica cortado/oculto) */
.company-item-floating-label{
  position:fixed;
  z-index:2147483647;
  pointer-events:none;
  padding:8px 12px;
  background:linear-gradient(90deg,rgba(255,255,255,0.03),rgba(255,255,255,0.02));
  color:#dbefff;
  border-radius:10px;
  box-shadow:0 8px 30px rgba(0,0,0,0.6);
  white-space:nowrap;
  transition:opacity .12s ease,transform .12s ease;
  opacity:0;
}

/* quando o rótulo não cabe à direita, aplicar .label-left para posicionar à esquerda */
.company-item.label-left .company-item-label{left:auto;right:76px}

/* scroll dentro do limite de visão */
.company-list-wrap{overflow-y:auto;-webkit-overflow-scrolling:touch}
.company-menu-component.expanded .company-list-wrap{max-height:calc(60vh);}

/* esconder barras de rolagem grandes, deixar discreto */
.company-list-wrap::-webkit-scrollbar{width:6px}
.company-list-wrap::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.06);border-radius:999px}
.company-list-wrap{scrollbar-width:thin;scrollbar-color:rgba(255,255,255,0.06) transparent}

/* indicador discreto de que há mais itens para rolar */
.company-scroll-indicator{position:absolute;right:10px;bottom:8px;width:20px;height:20px;border-radius:999px;background:linear-gradient(180deg,rgba(255,255,255,0.06),rgba(255,255,255,0.02));display:flex;align-items:center;justify-content:center;opacity:0.95;box-shadow:0 6px 18px rgba(0,0,0,0.45);z-index:10060}
.company-scroll-indicator:after{content:"";display:block;width:8px;height:8px;border-left:2px solid rgba(0,0,0,0.25);border-bottom:2px solid rgba(0,0,0,0.25);transform:rotate(-45deg);}

@media (max-width:767px){
  .company-main-btn{width:48px;height:48px}
  .company-main-logo{width:36px;height:36px}
  .company-grid{gap:8px;padding:8px}
  .company-item-logo{width:34px;height:34px}
  /* no mobile, exibir nomes por padrão (sem hover) */
  /* manter rótulos ocultos por padrão no mobile também; serão exibidos apenas ao clicar */
}

/* Quando o menu for inserido dentro de .globe-wrap, posicioná-lo como overlay */

.globe-wrap .company-menu-component{position:absolute;left:18px;top:18px;z-index:9999;width:auto}
.globe-wrap .company-list-wrap{background:linear-gradient(180deg, rgba(2,6,12,0.75), rgba(2,6,12,0.45));padding:6px;border-radius:12px;width:64px}

@media (max-width:767px){
  .globe-wrap .company-menu-component{left:10px;top:6px;width:auto}
  .globe-wrap .company-list-wrap{max-height:calc(56vh);width:64px}
}

/* garantir overflow-x visível para labels absolutos */
.globe-wrap .company-list-wrap{overflow-x:visible;overflow-y:auto}

/* chevron (toggle) fica visível apenas quando o nome é mostrado ou lista está aberta */
.company-toggle-btn{visibility:hidden;opacity:0;transition:opacity .18s ease,visibility .18s}
.company-main-row:hover .company-toggle-btn,
.company-main-row.main-label-visible .company-toggle-btn,
.company-menu-component:not(.list-hidden) .company-toggle-btn{visibility:visible;opacity:1}

/* ajustar posição mobile do menu para não ficar coberto pelo globo */
@media (max-width:480px){
  .globe-wrap .company-menu-component{top:4px;left:8px}
  #globeCanvas{height:50vh}
}