/* ==================== TOKENS ==================== */
:root{
  --bg:#0a1020; --panel:#0f1832; --ink:#fff; --muted:rgba(255,255,255,.65);
  --accent:#1765ff; --accent2:#4cc9f0; --line:rgba(255,255,255,.12);

  --nav-h:60px;
  --wrap-w:1120px;

  /* Chat flotante */
  --chat-gutter:16px;
  --chat-bottom:16px;
}

/* ==================== BASE ==================== */
*{box-sizing:border-box}
html,body{
  margin:0;padding:0;
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,'Helvetica Neue',Arial,sans-serif;
  background:var(--bg); color:var(--ink); line-height:1.45;
}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--wrap-w);margin:0 auto;padding:0 20px}
.no-scroll{overflow:hidden}

/* ==================== HEADER / NAV ==================== */
.nav{
  position:sticky; top:0; z-index:1000;
  background:rgba(10,16,32,.78);
  backdrop-filter:saturate(120%) blur(10px);
  border-bottom:1px solid var(--line);
}
.nav .nav-wrap{
  display:flex; align-items:center; gap:16px;
  min-height:var(--nav-h); flex-wrap:nowrap;
}
.brand{display:flex; align-items:center; gap:10px; font-weight:800}
.brand .logo{width:clamp(90px,12vw,120px); height:auto; filter:drop-shadow(0 0 8px rgba(71,173,255,.6))}

/* Hamburguesa (oculta en desktop) */
#navToggle{
  display:none; border:0; background:transparent; padding:0; margin:0;
  width:36px; height:36px; cursor:pointer;
  font-size:0; line-height:0;
  align-items:center; justify-content:center; flex-direction:column; gap:5px;
}
#navToggle::before{content:none}
#navToggle span{display:block; width:22px; height:2px; background:#fff; border-radius:2px; transition:transform .2s,opacity .2s}
#navToggle.is-open span:nth-child(1){transform:translateY(6px) rotate(45deg)}
#navToggle.is-open span:nth-child(2){opacity:0}
#navToggle.is-open span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

/* Menú desktop */
.menu{
  display:flex; align-items:center; gap:24px;
  flex:1 1 auto; flex-wrap:nowrap;
}
.menu a{
  display:inline-flex; align-items:center;
  height:40px; padding:0 2px;
  border-bottom:2px solid transparent; opacity:.9;
}
.menu a:hover{opacity:1; border-color:var(--line)}
.menu .cta{padding:8px 12px; border:1px solid var(--line); border-radius:999px}

/* Idiomas */
.langs{
  margin-left:16px; display:flex; align-items:center; gap:8px;
  height:40px; flex:0 0 auto;
}
.lang{
  display:inline-flex; align-items:center; justify-content:center;
  height:32px; min-width:36px; padding:0 10px; line-height:1; font-size:12px;
  border-radius:999px; border:1px solid var(--line);
  background:rgba(255,255,255,.04); color:#e7ecff;
}
.lang.on{background:#fff; color:#0a1020}

/* NAV móvil */
.nav-backdrop{
  position:fixed; inset:0; z-index:1050;
  background:rgba(0,0,0,.35); backdrop-filter:blur(2px);
  display:none;
}
.nav-backdrop.on{display:block}

.menu-close{
  display:none; /* sólo móvil */
  position:absolute; top:10px; right:10px;
  appearance:none; border:0; background:transparent; color:#fff;
  font-size:22px; line-height:1; cursor:pointer; padding:6px; border-radius:8px;
}
.menu-close:hover{background:rgba(255,255,255,.06)}

@media (max-width:980px){
  #navToggle{display:flex}

  .menu{
    position:fixed; inset:0 0 0 auto;
    width:min(320px,85vw); height:100dvh;
    display:flex; flex-direction:column; gap:12px; padding:18px;
    background:rgba(15,24,50,.98); border-left:1px solid var(--line);
    transform:translateX(100%); transition:transform .25s ease; z-index:1100;
    overflow:auto;
  }
  .menu.open{transform:translateX(0)}
  .menu a{border:0; padding:12px 4px; height:auto; font-size:18px}
  .menu-close{display:inline-block}

  .langs{position:absolute; right:12px; top:10px; margin:0; height:34px}
  .lang{height:30px; padding:0 10px}
}
body.nav-open{overflow:hidden}
.menu::before{content:none}

/* ==================== HERO ==================== */
.hero{position:relative; padding:64px 0}
.hero--mock{
  background:
    radial-gradient(1200px 380px at 10% -10%, rgba(23,101,255,.18), transparent),
    radial-gradient(1000px 380px at 110% 120%, rgba(76,201,240,.16), transparent)
}
.hero-grid{display:grid; grid-template-columns:1.1fr .9fr; gap:28px; align-items:center}
@media (max-width:980px){ .hero-grid{grid-template-columns:1fr} }

.hero-title{font-size:clamp(28px,6vw,48px); line-height:1.1; margin:0 0 10px; font-weight:800}
.hero-subtitle{font-size:clamp(16px,3.2vw,22px); color:var(--muted); margin:0 0 18px}
.pill{background:var(--accent); color:#fff; border:0; border-radius:999px; padding:10px 16px; font-weight:600; cursor:pointer}
.cta-row{display:flex; gap:10px; margin-top:8px; flex-wrap:wrap}

/* Tarjeta/Video hero (estable en móvil) */
.bit3d-card{
  width:100%; max-width:100%;
  height: clamp(240px, 42vw, 420px);
  border-radius:18px; overflow:hidden;
  background:#000; border:1px solid rgba(255,255,255,.08);
}
.bit3d-card>video{width:100%; height:100%; display:block; object-fit:cover}
@media (max-width:600px){ .bit3d-card{ height:220px } }

/* Fade-in del video cuando está listo */
.hero-video{opacity:0; transition:opacity .18s ease; width:100%; height:100%; object-fit:cover; display:block}
.hero-video.is-ready{opacity:1}
/* Variante auto-ajustada: el contenedor toma la altura del medio interno */
.bit3d-card--auto{ height:auto; }

/* Imágenes y videos dentro: que definan ellos la altura */
.bit3d-card--auto > img,
.bit3d-card--auto > video{
  display:block;
  width:100%;
  height:auto !important;   /* anula la regla global de 100% */
  object-fit:contain;       /* no recorta, respeta proporción */
}

/* (Opcional) si quieres que el fondo “marco” no fuerce altura cuando no hay medio */
.bit3d-card--auto{ background:#000; }

/* ==================== SECCIONES / TILES ==================== */
.section{padding:32px 0}
.section-title{font-size:28px; margin:0 0 14px}

.tiles{display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:16px}
.tile{
  border:1px solid var(--line); border-radius:16px; background:rgba(255,255,255,.03);
  padding:18px 18px 22px; min-height:110px;
  display:flex; flex-direction:column; justify-content:flex-end;
  transition:transform .18s ease, border-color .18s ease, background .18s ease;
}
.tile:hover{transform:translateY(-2px); border-color:rgba(255,255,255,.22); background:rgba(255,255,255,.05)}
.tile--dark{background:rgba(255,255,255,.025)}
.meta{color:var(--muted)}

/* Tiles con imagen de fondo */
.tile.tile-img{position:relative; padding:0; min-height:160px; border-radius:16px; overflow:hidden; border:1px solid var(--line); background:#050a1a; isolation:isolate}
.tile-media{position:absolute; inset:0; width:100%; height:100%; object-fit:cover; transform:scale(1.02); transition:transform .35s, filter .35s; z-index:0}
.tile-overlay{position:absolute; inset:0; z-index:1; background:linear-gradient(to top, rgba(0,0,0,.55), rgba(0,0,0,.05) 60%, rgba(0,0,0,0)); opacity:.9; transition:opacity .25s ease}
.tile-meta{position:absolute; left:14px; right:14px; bottom:12px; z-index:2; display:flex; flex-direction:column}
.tile.tile-img .tile-title{font-size:22px; font-weight:800; color:#fff}
.tile.tile-img .tile-sub{font-size:13px; color:rgba(255,255,255,.85); margin-top:2px}
.tile.tile-img:hover .tile-media{transform:scale(1.06); filter:saturate(110%)}
.tile.tile-img:hover .tile-overlay{opacity:1}
@media (max-width:560px){ .tile.tile-img{min-height:140px} .tile.tile-img .tile-title{font-size:20px} }

/* Variante: card con imagen + texto debajo */
.tile.tile--img{display:grid; grid-template-rows:auto min-content; gap:10px; padding:12px}
.tile-imgbox{width:100%; aspect-ratio:16/9; border-radius:12px; overflow:hidden; border:1px solid var(--line); background:rgba(255,255,255,.03)}
.tile-img{width:100%; height:100%; object-fit:cover; display:block}
.tile-text .tile-title{font-size:22px; font-weight:800; line-height:1.1}
.tile-text .tile-sub{color:var(--muted); font-size:14px; margin-top:2px}

@media (max-width:980px){ .tiles{grid-template-columns:repeat(2,minmax(0,1fr))} }
@media (max-width:560px){
  .hero-title{font-size:38px}
  .hero-subtitle{font-size:18px}
  .tiles{grid-template-columns:1fr}
  .fmeta{flex-direction:column; gap:6px; align-items:flex-start}
}

/* ==================== TEAM ==================== */
.team{
  position:relative; padding:56px 0 64px;
  background:
    radial-gradient(900px 300px at 20% 0%, rgba(23,101,255,.15), transparent),
    radial-gradient(700px 260px at 100% 120%, rgba(76,201,240,.12), transparent)
}
.team__overlay{position:absolute; inset:0; z-index:0; background:url("../img/team-bg.jpg") center/cover no-repeat; opacity:.18}
.team .wrap{position:relative; z-index:1}
.team-title{margin:0; font-size:34px; font-weight:800; letter-spacing:.5px; text-transform:uppercase}
.team-title span{background:linear-gradient(90deg,#4cc9f0,#1765ff); -webkit-background-clip:text; background-clip:text; color:transparent}
.team-bar{width:56px; height:4px; border-radius:2px; margin:10px 0 24px; background:linear-gradient(90deg,#ffcc66,#ff9f1c)}
.team-grid{display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:22px}
.member{text-align:center}
.avatar{width:148px; height:148px; margin:0 auto 12px; border-radius:50%; overflow:hidden; border:3px solid rgba(255,255,255,.85); box-shadow:0 8px 24px rgba(0,0,0,.35)}
.avatar img{width:100%; height:100%; object-fit:cover; display:block}
.name{margin:6px 0 6px; font-size:20px; font-weight:800}
.role{margin:0; color:var(--muted); font-size:14px; line-height:1.35}

/* ==================== MAROC ==================== */
.maroc-strip{padding:20px 0 10px}
.maroc-strip__inner{display:grid; grid-template-columns:1fr 1.1fr; align-items:center; gap:24px}
@media (max-width:980px){ .maroc-strip__inner{grid-template-columns:1fr} }
.maroc-title{margin:0; font-size:34px; line-height:1.1; font-weight:800}
.maroc-underline{width:48px; height:4px; background:#ffcc66; border-radius:2px; margin:10px 0 12px}
.maroc-name{font-size:20px; font-weight:700}
.maroc-role{color:var(--muted); margin-top:4px}
.maroc-photo{position:relative; min-height:240px; display:grid; place-items:end}
.maroc-photo-img{display:block; position:relative; z-index:1; max-height:280px; width:auto; object-fit:contain; background:transparent; border:none; border-radius:0; box-shadow:none}

/* ==================== FOOTER ==================== */
.footer{
  border-top:1px solid var(--line); padding:36px 0 20px;
  background:
    radial-gradient(1100px 400px at 10% -20%, rgba(23,101,255,.15), transparent),
    radial-gradient(900px 320px at 120% 140%, rgba(76,201,240,.12), transparent)
}
.fgrid{display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:24px}
.fcol .ftitle{font-weight:800; margin:0 0 10px}
.footer ul{list-style:none; margin:0; padding:0; display:grid; gap:8px}
.footer a{color:var(--muted)}
.footer a:hover{color:#fff}
.fbrand .flogo{display:flex; align-items:center; gap:10px; font-weight:800; font-size:18px; margin-bottom:8px}
.fbrand .flogo img{width:28px; height:28px; filter:drop-shadow(0 0 8px rgba(71,173,255,.6))}
.fline{height:1px; background:var(--line); margin:18px 0 12px}
.fmeta{display:flex; justify-content:space-between; align-items:center; color:var(--muted); font-size:13px; gap:10px; flex-wrap:wrap}
.fgeo{opacity:.9}

/* ==================== TOUR VIRTUAL (overlay único) ==================== */
.tour{
  position:fixed; inset:0;
  display:flex; align-items:center; justify-content:center;
  background:rgba(0,0,0,.65); backdrop-filter:blur(4px);
  z-index:6000;
}
.tour.hidden{display:none}

.tour-panel{
  width:min(940px,96vw);
  max-height:92vh;
  background:var(--panel);
  border:1px solid var(--line);
  border-radius:22px;
  overflow:hidden;
}
.tour-head{
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 16px; border-bottom:1px solid var(--line);
}
.tour-body{padding:16px}
.tour-mini{display:grid; grid-template-columns:1fr 1fr; gap:16px}

.tv-card{background:rgba(255,255,255,.03); border:1px solid var(--line); border-radius:14px; padding:12px; display:grid; gap:8px}
.tv-media{width:100%; aspect-ratio:16/9; border-radius:10px; overflow:hidden; border:1px solid var(--line); background:#000}
.tv-media video{width:100%; height:100%; object-fit:cover; display:block}

@media (max-width:980px){
  .tour-panel{
    width:100vw; height:100dvh; max-height:none; max-width:none; border-radius:0;
  }
  .tour-head{height:52px}
  .tour-body{height:calc(100dvh - 52px); overflow:auto; padding:12px}
  .tour-mini{grid-template-columns:1fr}
}

/* ==================== MINI PORTALES (si usas el tour con carrusel) ==================== */
.mini-portal{border:1px solid var(--line); border-radius:14px; background:rgba(255,255,255,.03); padding:14px}
.mini-portal .title{font-weight:800}
.mini-portal .subtitle{color:var(--muted); font-size:14px; margin-bottom:10px}
.mp-card{aspect-ratio:var(--ar,16/9); width:100%; border-radius:12px; overflow:hidden; position:relative; cursor:pointer; background:#000; border:1px solid var(--line); display:grid; place-items:center}
.mp-thumb,.mp-video{width:100%; height:100%; display:block; object-fit:contain; background:#000}
.mp-video{display:none}
.mp-controls{display:flex; align-items:center; gap:8px; margin-top:10px; flex-wrap:wrap}
.mp-btn{height:28px; min-width:32px; padding:0 8px; border:1px solid var(--line); background:rgba(255,255,255,.06); color:#fff; border-radius:8px; cursor:pointer; font-weight:600}
.mp-btn:hover{background:rgba(255,255,255,.1)}
.mp-toggle{display:flex; align-items:center; gap:6px; font-size:13px; color:var(--muted)}
.mp-caption{text-align:center; margin-top:8px; color:var(--muted); font-size:14px}
@media (max-width:420px){ .mp-card{aspect-ratio:4/3} }

/* ==================== CHAT FLOTANTE (versión legacy) ==================== */
.sb-backdrop{
  position:fixed; inset:0; z-index:2990;
  background:rgba(0,0,0,.35); backdrop-filter:blur(2px);
  opacity:0; pointer-events:none; transition:opacity .18s ease;
}
.sb-backdrop.on{opacity:1; pointer-events:auto}

.sb-chat-launcher{
  position:fixed; z-index:3000;
  right:calc(max(var(--chat-gutter),(100vw - var(--wrap-w))/2 + var(--chat-gutter)) + env(safe-area-inset-right,0px));
  bottom:calc(var(--chat-bottom) + env(safe-area-inset-bottom,0px));
  display:inline-flex; align-items:center; gap:10px;
  background:transparent; border:0; padding:0; cursor:pointer; touch-action:manipulation;
}
.sb-chat-label{
  background:#0f1832; border:1px solid var(--line); color:#fff;
  padding:10px 12px; border-radius:12px; font-size:13px;
  box-shadow:0 8px 24px rgba(0,0,0,.35);
}
.sb-chat-whats{width:56px; height:56px; border-radius:50%; display:grid; place-items:center}

.sb-chat{
  position:fixed; z-index:3010;
  right:calc(max(var(--chat-gutter),(100vw - var(--wrap-w))/2 + var(--chat-gutter)) + env(safe-area-inset-right,0px));
  bottom:calc(62px + var(--chat-bottom) + env(safe-area-inset-bottom,0px));
  width:min(420px,96vw);
  max-height:min(80vh,640px);
  background:var(--panel);
  border:1px solid var(--line); border-radius:16px;
  box-shadow:0 12px 40px rgba(0,0,0,.45);
  overflow:hidden; display:flex; flex-direction:column;
  transform:translateY(16px); opacity:0; pointer-events:none;
  transition:transform .18s ease, opacity .18s ease;
}
.sb-chat.open,.sb-chat.is-open{transform:translateY(0); opacity:1; pointer-events:auto}

@media (max-width:600px){
  .sb-chat-label{display:none}
  .sb-chat{
    left:max(10px, env(safe-area-inset-left,0px) + 10px);
    right:max(10px, env(safe-area-inset-right,0px) + 10px);
    width:auto; max-height:72vh;
    bottom:calc(62px + var(--chat-bottom) + env(safe-area-inset-bottom,0px));
  }
  .sb-chat-launcher{
    right:max(10px, env(safe-area-inset-right,0px) + 10px);
    bottom:calc(12px + var(--chat-bottom) + env(safe-area-inset-bottom,0px));
  }
}

/* Componentes internos del chat */
.sb-chat-head{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-bottom:1px solid var(--line);background:rgba(255,255,255,.02)}
.agent{display:flex;gap:10px;align-items:center}
.agent-avatar{width:32px;height:32px;border-radius:50%;object-fit:cover;border:2px solid rgba(255,255,255,.9)}
.agent-name{font-weight:800}
.agent-role{color:var(--muted);font-size:12px;margin-top:2px}
.close{border:none;background:transparent;color:#fff;font-size:18px;cursor:pointer;opacity:.9}
.sb-chat-log{flex:1;overflow:auto;padding:10px 12px;display:grid;gap:8px;background:rgba(255,255,255,.02)}
.sb-msg{max-width:85%;padding:10px 12px;border-radius:12px;line-height:1.3}
.sb-msg.bot{background:rgba(255,255,255,.06);border:1px solid var(--line)}
.sb-msg.user{background:#1765ff}
.sb-chat-suggest{display:flex;gap:8px;padding:8px 12px;flex-wrap:wrap;border-top:1px solid var(--line);background:rgba(255,255,255,.02)}
.sg-title{width:100%;color:var(--muted);font-size:12px}
.sb-chip{border:1px solid var(--line);border-radius:999px;padding:6px 10px;font-size:12px;cursor:pointer;background:rgba(255,255,255,.03);color:#fff}
.sb-chip:hover{background:rgba(255,255,255,.08)}
.sb-chat-entry{display:flex;gap:8px;padding:10px 12px;border-top:1px solid var(--line)}
.sb-chat-entry input{flex:1;border:1px solid var(--line);border-radius:10px;padding:10px 12px;background:rgba(255,255,255,.03);color:#fff}

/* ==================== LOGIN OVERLAY ==================== */
.login-overlay{position:fixed; inset:0; z-index:6500}
/* Logo/hero de cada proyecto (jpg) */
.project-head{display:flex;align-items:center;gap:14px;margin-bottom:10px}
.project-logo{
  width: clamp(96px, 14vw, 140px);
  aspect-ratio: 16/9;           /* mantiene formato del jpg ancho */
  border-radius: 12px;
  border: 1px solid var(--line);
  box-shadow: 0 8px 18px rgba(0,0,0,.25);
  object-fit: cover;            /* llena el marco sin deformarse */
  background:#000;              /* por si hay bordes oscuros del jpg */
  image-rendering: -webkit-optimize-contrast;
  image-rendering: optimizeQuality;
}
@media (max-width:560px){
  .project-logo{ width: 110px; }
}
/* === Chat failsafe: botón + panel siempre visibles cuando .open === */
.sb-chat-launcher{
  position: fixed !important;
  z-index: 5000 !important;
  right: 16px !important;
  bottom: 16px !important;
  display: inline-flex !important;
  gap: 10px; align-items: center;
  background: transparent; border: 0; padding: 0; cursor: pointer;
}
.sb-chat-label{ background:#0f1832;border:1px solid var(--line);padding:10px 12px;border-radius:12px }

.sb-chat{
  position: fixed !important;
  z-index: 5010 !important;
  right: 16px !important;
  bottom: 74px !important;  /* sobre el botón */
  width: min(420px, 96vw) !important;
  max-height: min(80vh, 640px) !important;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 16px;
  box-shadow: 0 12px 40px rgba(0,0,0,.45);
  overflow: hidden;
  display: none;           /* cerrado */
  opacity: 0;
  transform: translateY(8px);
}
.sb-chat.open{
  display: flex !important;    /* abierto */
  opacity: 1 !important;
  transform: none !important;
  pointer-events: auto !important;
}

@media (max-width:600px){
  .sb-chat-label{ display:none !important; }
  .sb-chat{
    left: 12px !important; right: 12px !important; bottom: 74px !important;
    width: auto !important; max-height: 72vh !important;
  }
  .sb-chat-launcher{ right: 12px !important; bottom: 12px !important; }
}
