/* ============================================================
   SÓCRATES ONE — main.css
   Shared across all pages: variables, nav, buttons, footer
   ============================================================ */

/* ============================================================
   RESET & VARIABLES — Pantone 540 C background
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;overflow-x:hidden}
:root{
  --bg:      #002855;
  --bg2:     #002060;
  --bg3:     #001d52;
  --card:    #003070;
  --card2:   #002868;
  --mid:     #003880;
  --accent:  #A8E63D;
  --blue:    #0074C7;
  --lblue:   #31B4E7;
  --yellow:  #F6BD00;
  --orange:  #FF5300;
  --dnavy:   #001540;
  --white:   #FFFFFF;
  --soft:    #c8ddf0;
  --muted:   #7aaac8;
  --border:  rgba(255,255,255,.1);
  --bord-a:  rgba(168,230,61,.25);
  --font:    'Ubuntu', sans-serif;
}
body{font-family:var(--font);background:var(--bg);color:var(--white);overflow-x:hidden;line-height:1.6;max-width:100%;position:relative}


/* ============================================================
   NAV
   ============================================================ */
nav{
  position:fixed;top:0;left:0;right:0;z-index:99999;isolation:isolate;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 48px;height:68px;
  background:rgba(0,28,64,.92);
  backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
  transition:background .3s;
}
nav.scrolled{background:rgba(0,20,50,.98)}
.n-logo img{height:32px;display:block}
.n-links{display:flex;align-items:center;gap:2px}
.n-links a{
  color:var(--soft);text-decoration:none;font-size:.86rem;
  font-weight:400;letter-spacing:.5px;text-transform:uppercase;
  padding:7px 13px;border-radius:6px;border:1px solid transparent;
  transition:color .18s,background .18s,border-color .18s;
  position:relative;
}
.n-links a:hover{
  color:var(--accent);
  background:transparent;
  border:1px solid var(--accent);
  padding:6px 12px;
}
.n-cta{
  background:var(--accent)!important;color:#001540!important;
  font-weight:700!important;margin-left:6px;
  box-shadow:0 0 18px rgba(168,230,61,.35);
  border-radius:5px;padding:6px 14px!important;
}
.n-cta:hover{opacity:.9!important;transform:translateY(-1px)!important;
  box-shadow:0 0 28px rgba(168,230,61,.55)!important}
.mob-menu-btn{flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:8px}

/* Lang switcher */
.lang-sw{position:relative;margin-left:18px;padding-left:18px;border-left:1px solid rgba(255,255,255,.15)}
.lang-btn{
  display:flex;align-items:center;gap:6px;
  background:rgba(255,255,255,.08);border:1px solid var(--border);
  border-radius:5px;padding:5px 10px;cursor:pointer;
  font-size:.74rem;font-weight:600;color:var(--soft);
  font-family:var(--font);transition:all .18s;
}
.lang-btn:hover{background:rgba(168,230,61,.08);border-color:var(--bord-a);color:var(--accent)}
.lang-chev{font-size:.55rem;transition:transform .2s}
.lang-sw.open .lang-chev{transform:rotate(180deg)}
.lang-drop{
  position:absolute;top:calc(100% + 8px);right:0;
  background:rgba(0,30,70,.98);border:1px solid var(--border);
  border-radius:10px;overflow:hidden;min-width:148px;
  box-shadow:0 20px 50px rgba(0,0,0,.5);display:none;z-index:600;
  backdrop-filter:blur(20px);
}
.lang-sw.open .lang-drop{display:block}
.lang-opt{
  display:flex;align-items:center;gap:10px;padding:10px 15px;
  cursor:pointer;font-size:.8rem;font-weight:500;color:var(--soft);
  transition:background .15s,color .15s;
}
.lang-opt:hover{background:rgba(168,230,61,.08);color:var(--accent)}
.lang-opt.active{color:var(--accent);font-weight:700;background:rgba(168,230,61,.05)}


/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:13px 26px;border-radius:6px;
  font-weight:700;font-size:.88rem;font-family:var(--font);
  text-decoration:none;cursor:pointer;border:none;
  letter-spacing:.3px;transition:all .22s;text-transform:none;
}
.btn:hover{transform:translateY(-2px)}
.btn-solid{background:var(--accent);color:#001540;box-shadow:0 0 20px rgba(168,230,61,.28);text-transform:uppercase;}
.btn-solid:hover{box-shadow:0 0 36px rgba(168,230,61,.5)}
.btn-line{background:transparent;border:1px solid rgba(255,255,255,.2)!important;color:var(--white)}
.btn-line:hover{border-color:var(--bord-a)!important;color:var(--accent)}
.btn-ghost{background:transparent;border:1px solid var(--bord-a)!important;color:var(--accent);font-size:.82rem;padding:10px 20px}
.btn-ghost:hover{background:rgba(168,230,61,.08)}
.btn-orange{background:var(--orange);color:var(--white)}
.btn-orange:hover{box-shadow:0 0 28px rgba(255,83,0,.4)}

/* ============================================================
   MARQUEE
   ============================================================ */
.marquee-wrap{
  border-top:1px solid var(--border);border-bottom:1px solid var(--border);
  background:rgba(0,20,50,.4);padding:16px 0;overflow:hidden;position:relative;
}
.marquee-wrap::before,.marquee-wrap::after{
  content:'';position:absolute;top:0;bottom:0;width:100px;z-index:2;pointer-events:none;
}
.marquee-wrap::before{left:0;background:linear-gradient(to right,var(--bg),transparent)}
.marquee-wrap::after{right:0;background:linear-gradient(to left,var(--bg),transparent)}
.marquee-track{display:flex;animation:marquee 55s linear infinite;width:max-content}
.marquee-track:hover{animation-play-state:paused}
.marquee-item{text-decoration:none;
  padding:0 36px;font-size:.71rem;font-weight:600;letter-spacing:1.8px;
  text-transform:uppercase;color:var(--muted);
  border-right:1px solid var(--border);white-space:nowrap;
  transition:color .2s;
}
.marquee-item:hover{color:var(--accent)}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}


/* ============================================================
   SECTION BASE
   ============================================================ */
.sec{padding:88px 48px}
.wrap{max-width:1400px;margin:0 auto}

.eyebrow{
  font-size:.78rem;font-weight:700;letter-spacing:3px;
  text-transform:uppercase;color:var(--accent);
  display:flex;align-items:center;gap:12px;margin-bottom:16px;
}
.eyebrow::before{content:'';width:22px;height:1px;background:var(--accent);flex-shrink:0}
.eyebrow.center{justify-content:center}.eyebrow.center::before{display:none}
.s-title{
  font-size:clamp(1.9rem,3.2vw,3.4rem);font-weight:700;
  line-height:1.02;text-transform:uppercase;letter-spacing:-.8px;
  font-family:var(--font);
}
.prob-title{font-size:clamp(1.7rem,2.8vw,3.4rem);line-height:1.04}
.s-title em{color:var(--accent);font-style:normal}
.s-title .t-lblue{color:var(--lblue)}
.s-title .t-yellow{color:var(--yellow)}
.s-title .t-orange{color:var(--orange)}
.s-desc{font-size:.95rem;color:var(--soft);line-height:1.85}
.hr{height:1px;background:var(--border)}


/* ============================================================
   FOOTER
   ============================================================ */
footer{background:rgba(0,15,40,.98);border-top:1px solid var(--border);padding:52px 48px 0;font-family:var(--font)}
.footer-top{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:40px;padding-bottom:40px;border-bottom:1px solid var(--border);align-items:start}
.footer-brand img{height:22px;margin-bottom:12px;display:block}
.foot-tagline{font-size:.82rem;color:var(--white);font-weight:700;letter-spacing:1.8px;text-transform:uppercase;line-height:1.5;margin-bottom:6px;font-family:var(--font)}
.foot-tagline span{color:var(--accent)}
.foot-countries{font-size:.78rem;color:var(--muted);letter-spacing:.5px;margin-bottom:0;font-family:var(--font);display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.foot-countries img{vertical-align:middle}
.footer-social{display:flex;gap:7px;margin-top:16px}
.social-btn{width:34px;height:34px;border-radius:7px;background:rgba(255,255,255,.06);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;text-decoration:none;color:var(--soft);transition:all .18s}
.social-btn:hover{background:rgba(168,230,61,.1);border-color:var(--bord-a);color:var(--accent)}
.footer-col h5{font-size:.68rem;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--accent);margin-bottom:12px;font-family:var(--font)}
.footer-col a{display:flex;align-items:center;gap:8px;font-size:.84rem;color:var(--muted);text-decoration:none;margin-bottom:7px;transition:color .18s;line-height:1.4;font-family:var(--font)}
.footer-col a svg{flex-shrink:0;opacity:.65;transition:opacity .18s}
.footer-col a:hover{color:var(--white)}
.footer-col a:hover svg{opacity:1}
.footer-bottom{
  display:flex;align-items:center;justify-content:center;gap:20px;
  padding:18px 0;font-size:.8rem;color:rgba(255,255,255,.5);
  flex-wrap:wrap;text-align:center;font-family:var(--font);
}
.footer-bottom a{color:rgba(255,255,255,.5);text-decoration:none;transition:color .18s;font-family:var(--font)}
.footer-bottom a:hover{color:var(--accent)}
.footer-bottom .fb-sep{opacity:.3}
.footer-flags{display:flex;gap:10px}
.f-flag{font-size:1rem;cursor:pointer;opacity:.4;transition:opacity .18s}
.f-flag:hover,.f-flag.active{opacity:1}
.foot-btn{
  display:inline-flex;align-items:center;gap:7px;
  padding:6px 12px;border-radius:6px;
  font-size:.78rem;font-weight:600;text-decoration:none;
  margin-bottom:6px;transition:all .2s;font-family:var(--font);
  width:fit-content;
}
.foot-btn-wa{background:rgba(37,211,102,.1);border:1px solid rgba(37,211,102,.25);color:#25D366}
.foot-btn-wa:hover{background:rgba(37,211,102,.2)}
.foot-btn-quote{background:rgba(168,230,61,.08);border:1px solid var(--bord-a);color:var(--accent)}
.foot-btn-quote:hover{background:rgba(168,230,61,.16)}

/* ============================================================
   SCROLL TO TOP
   ============================================================ */
.scroll-top{
  position:fixed;bottom:26px;right:26px;z-index:500;width:46px;height:46px;border-radius:50%;
  background:var(--accent);color:#001540;border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;font-size:1.1rem;font-weight:700;
  box-shadow:0 0 20px rgba(168,230,61,.4);
  opacity:0;transform:translateY(12px);transition:opacity .25s,transform .25s;pointer-events:none;
}
.scroll-top.visible{opacity:1;transform:none;pointer-events:all}
.scroll-top{display:none!important}

/* ============================================================
   REVEAL
   ============================================================ */
[data-r]{opacity:0;transform:translateY(24px);transition:opacity .55s ease,transform .55s ease}
[data-r].on{opacity:1;transform:none}
[data-d="1"]{transition-delay:.1s}[data-d="2"]{transition-delay:.2s}
[data-d="3"]{transition-delay:.3s}[data-d="4"]{transition-delay:.4s}

/* ============================================================
   RESPONSIVE
   ============================================================ */

.svc-header-pill{
  display:inline-flex;align-items:center;gap:10px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.15);
  border-radius:30px;padding:9px 20px;
  font-size:.82rem;font-weight:400;color:var(--soft);
  letter-spacing:.3px;white-space:nowrap;
}
.svc-header-dot{
  width:10px;height:10px;border-radius:50%;
  background:var(--accent);flex-shrink:0;
  animation:blink 1.6s ease-in-out infinite;
}

/* Services section — more compact */
#services.sec{padding:56px 48px}
.nav-drop{position:relative}
.nav-drop-btn{
  display:flex;align-items:center;gap:6px;
  color:var(--soft);text-decoration:none;font-size:.86rem;
  font-weight:400;letter-spacing:.5px;text-transform:uppercase;
  padding:6px 11px;border-radius:5px;cursor:pointer;
  background:none;border:none;font-family:var(--font);
  transition:color .18s,background .18s;
}
.nav-drop-btn:hover,.nav-drop.open .nav-drop-btn,.nav-drop:hover .nav-drop-btn{color:var(--accent);background:transparent;border-color:var(--accent)}
.nav-drop-chev{font-size:.5rem;transition:transform .2s}
.nav-drop.open .nav-drop-chev,.nav-drop:hover .nav-drop-chev{transform:rotate(180deg)}

.nav-drop-menu{
  display:none;
  position:absolute;top:calc(100% + 2px);left:0;
  background:rgba(0,48,112,.97);backdrop-filter:blur(20px);
  border:1px solid var(--border);border-radius:12px;
  min-width:260px;overflow:hidden;
  box-shadow:0 20px 50px rgba(0,0,0,.5);
  z-index:600;
}
.nav-drop-menu::before{content:"";position:absolute;top:-10px;left:0;right:0;height:10px;background:transparent}
.nav-drop.open .nav-drop-menu,.nav-drop:hover .nav-drop-menu{display:block}
.nav-drop-item{
  display:flex;align-items:center;gap:12px;
  padding:11px 18px;text-decoration:none;
  color:var(--soft);font-size:.82rem;
  transition:background .15s,color .15s;border-bottom:1px solid rgba(255,255,255,.04);
}
.nav-drop-item:last-child{border-bottom:none}
.nav-drop-item:hover{background:rgba(168,230,61,.1);color:var(--accent)}
.nav-drop-item:hover svg g{stroke:var(--accent)}
.nav-drop-item-text{display:flex;flex-direction:column;gap:1px}
.nav-drop-item-name{font-weight:500;font-size:.82rem;letter-spacing:.2px;text-transform:uppercase}
.nav-drop-item-sub{font-size:.68rem;color:var(--muted);text-transform:none;letter-spacing:0}

/* ── TABLET (≤1200px) ── */
@media(max-width:1200px){
  .hero-inner{grid-template-columns:1fr}
  .hero-right{display:none}
  .aio-grid{grid-template-columns:1fr 1fr}
  .services-grid{grid-template-columns:repeat(3,1fr)}
  .clients-grid{grid-template-columns:repeat(3,1fr)}
  .products-grid{grid-template-columns:repeat(4,1fr);gap:1px}
  .footer-top{grid-template-columns:1fr 1fr;gap:36px}
  .blog-grid{grid-template-columns:1fr 1fr}
  .plans-grid{grid-template-columns:1fr 1fr}
  .company-layout{grid-template-columns:1fr 1fr;gap:44px}
}

/* ── MOBILE NAV ── */
@media(max-width:960px){
  nav{padding:0 16px;height:60px;position:fixed;z-index:500}
  .n-links{display:none!important}
  .lang-sw{display:none}
  .n-logo img{height:22px}
  /* Hamburger always visible */
  .mob-menu-btn{
    display:flex!important;flex-direction:column!important;gap:5px;cursor:pointer;
    background:none!important;border:none!important;padding:8px;margin-left:auto;
    visibility:visible!important;opacity:1!important;
  }
  .mob-menu-btn span{
    display:block;width:24px;height:2.5px;background:var(--white);
    border-radius:2px;transition:transform .22s,opacity .22s;
  }
  nav.mob-open .mob-menu-btn span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  nav.mob-open .mob-menu-btn span:nth-child(2){opacity:0}
  nav.mob-open .mob-menu-btn span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  /* Open menu overlay */
  nav.mob-open{z-index:99999!important}
  nav.mob-open .n-links{
    display:flex!important;flex-direction:column;align-items:flex-start;gap:0;
    position:fixed;top:60px;left:0;right:0;bottom:0;
    background:rgba(0,20,55,.99);padding:20px 24px;
    overflow-y:auto;z-index:99998!important;width:100vw;
    isolation:isolate;
  }
  nav.mob-open .n-links a{
    font-size:1rem;padding:14px 0;
    border-bottom:1px solid rgba(255,255,255,.07)!important;
    border:none;width:100%;
  }
  nav.mob-open .lang-sw{display:flex;margin:20px 0 0;padding:0;border:none}
  .nav-drop-btn{width:100%;justify-content:flex-start}
  .nav-drop-menu{position:static!important;border-radius:8px;
    max-height:none;box-shadow:none;border-color:rgba(255,255,255,.08)}

  /* Sections */
  .sec{padding:56px 16px}
  .problem-sec{padding-top:88px!important}
  .problem-layout{grid-template-columns:1fr;gap:32px}
  .services-grid{grid-template-columns:1fr 1fr;gap:10px}
  .svc-card.wide{grid-column:span 1}
  .svc-mockup{min-height:auto;padding:12px}
  .aio-grid{grid-template-columns:1fr;gap:10px}
  .aio-mockup{min-height:auto}
  .plans-grid{grid-template-columns:1fr;gap:14px}
  .plan-card.featured{order:-1}
  .clients-grid{grid-template-columns:1fr 1fr}
  .products-grid{grid-template-columns:repeat(3,1fr);gap:1px}
  .company-layout{grid-template-columns:1fr;gap:32px}
  .footer-top{grid-template-columns:1fr 1fr;gap:24px}
  footer{padding:40px 16px 0}
  .footer-bottom{flex-direction:column;align-items:center;gap:8px;text-align:center}
  .hero-stats{display:none}
  .marquee-wrap{padding:12px 0}
  .chaos-row{overflow-x:auto;flex-wrap:nowrap;padding-bottom:6px;-webkit-overflow-scrolling:touch}
  .eyebrow{font-size:.68rem}
  /* Pills — wrap text, no overflow */
  .svc-header-pill{white-space:normal!important;width:100%!important;max-width:100%!important;text-align:left;overflow:hidden}
  .cta-band-sub{white-space:normal!important}
}

/* ── SMALL MOBILE (≤480px) ── */
@media(max-width:480px){
  nav{padding:0 14px}
  .sec{padding:52px 14px}
  .problem-sec{padding-top:88px!important}

  .s-title{font-size:clamp(1.6rem,7vw,2.6rem);letter-spacing:-.5px}
  .prob-title{font-size:clamp(1.5rem,6.5vw,2.4rem)}
  .hero-title{font-size:clamp(1.8rem,7.5vw,3rem)}

  .clients-grid{grid-template-columns:1fr}
  .products-grid{grid-template-columns:repeat(3,1fr)}
  .plans-grid{grid-template-columns:1fr}
  .services-grid{grid-template-columns:1fr 1fr}

  /* Blog v2 small */
  .blog2-grid{grid-template-columns:1fr}

  /* Testimonials */
  .testi2-card{width:calc(100vw - 60px)}
  .testi2-track{gap:12px}

  /* Footer small */
  .footer-top{grid-template-columns:1fr}
  .footer-bottom{align-items:center}

  .chaos-chip{font-size:.7rem;padding:8px 11px}
  .h-stat-val{font-size:1.6rem}

  .cta-band{padding:52px 14px}
  .cta-band-title{font-size:clamp(1.8rem,7vw,3rem)}

  .one-card{padding:22px 18px}
  .one-tags{gap:5px}
  .one-tag{font-size:.58rem;padding:3px 8px}

  .footer-social{flex-wrap:wrap}

  .n-cta{display:none}
}


/* ============================================================
   CRITICAL MOBILE OVERRIDES — highest specificity, end of file
   ============================================================ */
@media screen and (max-width:960px){
  /* Hamburger — force visible */
  button.mob-menu-btn,
  .mob-menu-btn{
    display:flex!important;
    flex-direction:column!important;
    gap:5px!important;
    cursor:pointer!important;
    background:transparent!important;
    border:none!important;
    padding:8px!important;
    margin-left:auto!important;
  }
  button.mob-menu-btn span,
  .mob-menu-btn span{
    display:block!important;
    width:24px!important;height:2.5px!important;
    background:#FFFFFF!important;
    border-radius:2px!important;
  }

  /* Pill — no overflow */
  .svc-header-pill{
    white-space:normal!important;
    width:auto!important;
    max-width:calc(100vw - 40px)!important;
    overflow:visible!important;
  }
  .cta-band-sub{
    white-space:normal!important;
    max-width:calc(100vw - 40px)!important;
    overflow:visible!important;
  }

  /* No horizontal scroll on page */
  body,html{overflow-x:hidden!important;max-width:100vw!important}

  /* Problem image hidden */
  .problem-layout>div:first-child{display:none!important}
  .problem-layout{grid-template-columns:1fr!important}

  /* Chaos chips scroll */
  .chaos-row{
    overflow-x:auto!important;
    flex-wrap:nowrap!important;
    padding-bottom:8px!important;
    -webkit-overflow-scrolling:touch!important;
    max-width:calc(100vw - 36px)!important;
  }
}

@media screen and (max-width:480px){
  button.mob-menu-btn,
  .mob-menu-btn{display:flex!important}
}

/* Mobile language row — only visible in open mobile menu */
.mob-lang-row{display:none!important;padding:14px 0;border-top:1px solid rgba(255,255,255,.07);margin-top:4px;width:100%}
@media(max-width:960px){
  nav.mob-open .mob-lang-row{display:block!important}
}

/* Hamburger open state animation */
@media(max-width:960px){
  .mob-menu-btn.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .mob-menu-btn.is-open span:nth-child(2){opacity:0}
  .mob-menu-btn.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
}

/* Mobile nav controls (flags + hamburger) */
.mob-controls{display:none;align-items:center;gap:10px;margin-left:auto}
.mob-flags{display:flex;gap:6px;align-items:center}
.mob-flag{
  width:26px;height:18px;object-fit:cover;border-radius:3px;
  cursor:pointer;opacity:.45;transition:opacity .2s;border:0;
}
.mob-flag:hover,.mob-flag.active{opacity:1}
@media(max-width:960px){
  .mob-controls{display:flex!important}
  .mob-menu-btn{margin-left:0}
}
