/* ============================================================
   Panama Translator — Design System
   ============================================================ */

:root{
  --navy-900:#0a1c33;
  --navy-800:#0f2744;
  --navy-700:#163a5f;
  --navy-600:#1f4d7a;
  --gold-500:#c9a24b;
  --gold-600:#ad8636;
  --gold-100:#f4e9d2;
  --ink:#1b2430;
  --slate:#5b6472;
  --slate-light:#88919c;
  --line:#e6e8ec;
  --paper:#f7f7f5;
  --white:#ffffff;

  --serif: "Source Serif 4", Georgia, "Times New Roman", serif;
  --sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;

  --container: 1400px;
  --radius: 14px;
  --radius-sm: 8px;
  --shadow-sm: 0 1px 3px rgba(10,28,51,0.08);
  --shadow-md: 0 8px 24px rgba(10,28,51,0.10);
  --shadow-lg: 0 24px 60px rgba(10,28,51,0.18);
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
html,body{ max-width:100%; overflow-x:hidden; }
body{
  margin:0;
  font-family:var(--sans);
  color:var(--ink);
  background:var(--white);
  -webkit-font-smoothing:antialiased;
  line-height:1.6;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
ul{ margin:0; padding:0; list-style:none; }
h1,h2,h3,h4{ font-family:var(--serif); font-weight:600; line-height:1.15; margin:0 0 .5em; color:var(--navy-900); }
p{ margin:0 0 1em; color:var(--slate); }
.container{ max-width:var(--container); margin:0 auto; padding:0 24px; }
section{ padding:96px 0; }
@media (max-width:900px){ section{ padding:64px 0; } }
@media (max-width:640px){ section{ padding:48px 0; } }

.eyebrow{
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--sans); font-weight:700; font-size:.78rem;
  letter-spacing:.14em; text-transform:uppercase; color:var(--gold-600);
  margin-bottom:14px;
}
.eyebrow::before{ content:""; width:22px; height:2px; background:var(--gold-500); display:inline-block; }

.section-head{ max-width:640px; margin-bottom:56px; }
.section-head.center{ margin-left:auto; margin-right:auto; text-align:center; max-width:1000px; }
.section-head.center p{ text-align:left; }
.section-head h2{ font-size:clamp(1.7rem,3vw,2.4rem); }
.section-head p{ font-size:1.05rem; }
@media (max-width:640px){ .section-head{ margin-bottom:32px; } }

/* -------------------- Buttons -------------------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding:14px 28px; border-radius:100px; font-weight:600; font-size:.95rem;
  border:1px solid transparent; cursor:pointer; transition:.2s ease;
  white-space:nowrap;
}
.btn-gold{ background:var(--gold-500); color:var(--navy-900); }
.btn-gold:hover{ background:var(--gold-600); transform:translateY(-1px); }
.btn-outline{ background:transparent; border-color:rgba(255,255,255,.5); color:#fff; }
.btn-outline:hover{ background:rgba(255,255,255,.12); border-color:#fff; }
.btn-navy{ background:var(--navy-900); color:#fff; }
.btn-navy:hover{ background:var(--navy-700); }
.btn-ghost{ background:transparent; color:var(--navy-900); border-color:var(--line); }
.btn-ghost:hover{ border-color:var(--navy-900); }
.btn-sm{ padding:10px 20px; font-size:.85rem; }
.btn-block{ width:100%; }

/* -------------------- Header -------------------- */
.site-header{
  position:sticky; top:0; z-index:1000;
  background:#fff;
  border-bottom:1px solid var(--line);
}
.site-header .container{ display:flex; align-items:center; justify-content:space-between; height:84px; gap:24px; }
.brand{ display:flex; align-items:center; flex-shrink:0; }
.brand img{ height:36px; width:auto; display:block; }

.main-nav{ display:flex; align-items:center; gap:4px; }
.main-nav a{
  padding:10px 16px; font-weight:600; font-size:.92rem; color:var(--navy-800);
  border-radius:8px; transition:.15s;
}
.main-nav a:hover{ background:var(--paper); }
.main-nav a.active{ color:var(--gold-600); }

.header-right{ display:flex; align-items:center; gap:16px; }

.lang-switch{
  display:flex; align-items:center; background:var(--paper); border:1px solid var(--line);
  border-radius:100px; padding:3px; gap:2px; flex-shrink:0;
}
.lang-switch a{
  padding:7px 12px; font-size:.78rem; font-weight:700; letter-spacing:.03em; border-radius:100px; color:var(--slate);
  transition:.15s;
}
.lang-switch a.is-active{ background:var(--navy-900); color:#fff; }
.lang-switch a:not(.is-active):hover{ color:var(--navy-900); }

.nav-toggle{ display:none; background:none; border:0; cursor:pointer; padding:8px; }
.nav-toggle span{ display:block; width:24px; height:2px; background:var(--navy-900); margin:5px 0; transition:.2s; }

@media (max-width:960px){
  .main-nav{
    position:fixed; inset:84px 0 0 0; background:#fff; flex-direction:column; align-items:stretch;
    padding:20px; gap:4px; transform:translateX(100%); transition:.25s ease; overflow-y:auto;
  }
  .main-nav.is-open{ transform:translateX(0); }
  .main-nav a{ padding:16px; font-size:1.05rem; border-bottom:1px solid var(--line); border-radius:0; }
  .nav-toggle{ display:block; }
}

@media (max-width:480px){
  .site-header .container{ gap:10px; padding:0 16px; height:72px; }
  .brand img{ height:28px; }
  .header-right{ gap:10px; }
  .lang-switch a{ padding:6px 9px; font-size:.72rem; }
  .main-nav{ inset:72px 0 0 0; }
}

/* -------------------- Hero -------------------- */
.hero{
  position:relative; color:#fff; display:flex; align-items:center;
  min-height:640px; overflow:hidden;
}
.hero-bg{ position:absolute; inset:0; }
.hero-bg img{ width:100%; height:100%; object-fit:cover; }
.hero-bg::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(115deg, rgba(10,20,40,.94) 30%, rgba(10,28,51,.72) 60%, rgba(10,28,51,.45));
}
.hero-inner{ position:relative; z-index:2; padding-top:120px; padding-bottom:90px; }
@media (max-width:640px){ .hero-inner{ padding-top:64px; padding-bottom:56px; } }
.hero .eyebrow{ color:var(--gold-100); }
.hero .eyebrow::before{ background:var(--gold-500); }
.hero h1{ color:#fff; font-size:clamp(2.2rem,5vw,3.6rem); max-width:800px; }
.hero .lead{ color:rgba(255,255,255,.82); font-size:1.15rem; max-width:560px; margin-bottom:32px; }
.hero-cta{ display:flex; gap:14px; flex-wrap:wrap; }
.hero-badges{ display:grid; grid-template-columns:repeat(4,auto); gap:28px; margin-top:56px; }
@media (max-width:640px){ .hero-badges{ grid-template-columns:repeat(2,1fr); gap:24px 16px; } }
.hero-badges div{ font-size:.85rem; color:rgba(255,255,255,.7); }
.hero-badges strong{ display:block; font-family:var(--serif); font-size:1.6rem; color:#fff; }

.page-hero{ min-height:340px; }
.page-hero .hero-inner{ padding-top:70px; padding-bottom:60px; }
@media (max-width:640px){ .page-hero .hero-inner{ padding-top:48px; padding-bottom:40px; } }

/* -------------------- Service cards -------------------- */
.grid-3{ display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.grid-2{ display:grid; grid-template-columns:repeat(2,1fr); gap:28px; }
@media (max-width:900px){ .grid-3, .grid-2{ grid-template-columns:1fr; } }

.card{
  background:#fff; border:1px solid var(--line); border-radius:var(--radius);
  overflow:hidden; transition:.25s ease; box-shadow:var(--shadow-sm);
}
.card:hover{ box-shadow:var(--shadow-md); transform:translateY(-3px); }
.card-media{ height:190px; overflow:hidden; }
.card-media img{ width:100%; height:100%; object-fit:cover; transition:.4s; }
.card:hover .card-media img{ transform:scale(1.05); }
.card-body{ padding:28px; }
.card-icon{
  width:48px; height:48px; border-radius:10px; background:var(--gold-100);
  display:flex; align-items:center; justify-content:center; margin-bottom:16px;
}
.card-icon svg{ width:24px; height:24px; color:var(--gold-600); }
.card-body h3{ font-size:1.25rem; margin-bottom:10px; }
.card-link{ font-weight:700; font-size:.88rem; color:var(--navy-800); display:inline-flex; align-items:center; gap:6px; }
.card-link svg{ width:14px; height:14px; transition:.2s; }
.card:hover .card-link svg{ transform:translateX(3px); }

.tag-list{ display:flex; flex-wrap:wrap; gap:8px; margin-top:16px; }
.tag{ font-size:.78rem; font-weight:600; color:var(--navy-700); background:var(--paper); border:1px solid var(--line); padding:6px 12px; border-radius:100px; }

/* -------------------- Stats band -------------------- */
.stats-band{ background:var(--navy-900); color:#fff; }
.stats-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; text-align:center; }
@media (max-width:760px){ .stats-grid{ grid-template-columns:repeat(2,1fr); } }
.stat strong{ font-family:var(--serif); font-size:clamp(1.9rem,4vw,2.6rem); color:var(--gold-500); display:block; }
.stat span{ font-size:.88rem; color:rgba(255,255,255,.7); }

/* -------------------- Split / about -------------------- */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:stretch; }
@media (max-width:900px){ .split{ grid-template-columns:1fr; gap:36px; } }
.split img{ border-radius:var(--radius); box-shadow:var(--shadow-md); width:100%; height:100%; object-fit:cover; min-height:340px; }
@media (max-width:900px){ .split img{ min-height:240px; } }
.check-list li{ display:flex; gap:12px; margin-bottom:14px; color:var(--ink); font-weight:500; }
.check-list svg{ width:20px; height:20px; color:var(--gold-600); flex-shrink:0; margin-top:2px; }

/* -------------------- Testimonials -------------------- */
.testi-viewport{
  overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg, transparent, #000 48px, #000 calc(100% - 48px), transparent);
  mask-image:linear-gradient(90deg, transparent, #000 48px, #000 calc(100% - 48px), transparent);
}
.testi-scroller{ display:flex; gap:24px; width:max-content; padding-bottom:8px; will-change:transform; }
.testi-scroller.marquee{ animation:testi-marquee var(--marquee-duration, 45s) linear infinite; }
.testi-scroller.marquee.is-paused,
.testi-scroller.marquee:hover,
.testi-scroller.marquee:focus-within{ animation-play-state:paused; }
@keyframes testi-marquee{ from{ transform:translateX(0); } to{ transform:translateX(-50%); } }
@media (prefers-reduced-motion:reduce){ .testi-scroller.marquee{ animation:none; } }
.testi-card{
  flex:0 0 340px; background:var(--paper); border:1px solid var(--line);
  border-radius:var(--radius); padding:28px;
}
.testi-quote{ color:var(--gold-500); font-family:var(--serif); font-size:2.4rem; line-height:1; margin-bottom:8px; }
.testi-card p{ color:var(--ink); font-style:italic; font-size:.96rem; }
.testi-name{ font-weight:700; color:var(--navy-900); margin-top:16px; font-size:.92rem; }
.testi-role{ color:var(--slate-light); font-size:.82rem; }

/* -------------------- Client logo wall --------------------
   Flexbox (not grid) so an incomplete last row is auto-centered
   by the browser instead of left-stranded. */
.logo-wall{
  display:flex; flex-wrap:wrap; justify-content:center;
  border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; background:#fff;
}
.logo-cell{
  flex:0 0 20%; max-width:20%; box-sizing:border-box;
  background:#fff; display:flex; align-items:center; justify-content:center; padding:30px 20px; min-height:130px;
  box-shadow: -1px 0 0 0 var(--line), 0 -1px 0 0 var(--line);
}
@media (max-width:900px){ .logo-cell{ flex-basis:33.334%; max-width:33.334%; } }
@media (max-width:640px){ .logo-cell{ flex-basis:50%; max-width:50%; } }
.logo-cell img{ max-height:64px; width:auto; transition:.25s; }
.logo-cell:hover img{ transform:scale(1.05); }
.logo-cell.text-badge{ font-family:var(--serif); font-weight:600; color:var(--navy-800); font-size:1.05rem; text-align:center; transition:.25s; letter-spacing:.01em; }
.logo-cell.text-badge:hover{ color:var(--gold-600); }

/* -------------------- Team -------------------- */
.team-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:28px; max-width:900px; margin:0 auto; }
@media (max-width:760px){ .team-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:520px){ .team-grid{ grid-template-columns:1fr; } }
.team-card{ text-align:center; }
.avatar{
  width:120px; height:120px; border-radius:50%; margin:0 auto 16px; overflow:hidden;
  background:linear-gradient(150deg,var(--navy-700),var(--navy-900));
  display:flex; align-items:center; justify-content:center;
  font-family:var(--serif); font-size:1.7rem; color:var(--gold-500); font-weight:600;
  border:4px solid var(--gold-100);
}
.avatar img{ width:100%; height:100%; object-fit:cover; }
.team-card h4{ font-size:1.05rem; margin-bottom:2px; }
.team-card .role{ color:var(--gold-600); font-weight:600; font-size:.82rem; margin-bottom:10px; display:block; }
.team-card p{ font-size:.88rem; }

/* -------------------- FAQ accordion -------------------- */
.faq-list{ max-width:800px; margin:0 auto; }
.faq-item{ border-bottom:1px solid var(--line); }
.faq-item summary{
  list-style:none; cursor:pointer; padding:24px 0; font-weight:600; font-size:1.05rem;
  color:var(--navy-900); display:flex; justify-content:space-between; align-items:center; gap:20px;
}
.faq-item summary::-webkit-details-marker{ display:none; }
.faq-item .icon-plus{ width:22px; height:22px; flex-shrink:0; position:relative; }
.faq-item .icon-plus::before,.faq-item .icon-plus::after{
  content:""; position:absolute; background:var(--navy-900); border-radius:2px; transition:.2s;
}
.faq-item .icon-plus::before{ width:100%; height:2px; top:50%; left:0; transform:translateY(-50%); }
.faq-item .icon-plus::after{ width:2px; height:100%; left:50%; top:0; transform:translateX(-50%); }
.faq-item[open] .icon-plus::after{ opacity:0; }
.faq-item[open] summary{ color:var(--gold-600); }
.faq-item p{ padding-bottom:24px; margin:0; max-width:680px; }

/* -------------------- Contact -------------------- */
.contact-grid{ display:grid; grid-template-columns:.9fr 1.1fr; gap:48px; }
@media (max-width:900px){ .contact-grid{ grid-template-columns:1fr; } }
.contact-info-card{ background:var(--navy-900); color:#fff; border-radius:var(--radius); padding:40px; }
.contact-info-card h3{ color:#fff; }
.contact-row{ display:flex; gap:16px; padding:18px 0; border-bottom:1px solid rgba(255,255,255,.12); }
.contact-row:last-child{ border-bottom:0; }
.contact-row .ic{ width:40px; height:40px; border-radius:10px; background:rgba(255,255,255,.08); display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.contact-row .ic svg{ width:19px; height:19px; color:var(--gold-500); }
.contact-row a, .contact-row span{ font-size:.95rem; color:rgba(255,255,255,.88); }
.contact-row a:hover{ color:var(--gold-500); }
.social-row{ display:flex; gap:10px; margin-top:28px; }
.social-row a{
  width:38px; height:38px; border-radius:50%; background:rgba(255,255,255,.08); display:flex; align-items:center; justify-content:center;
  transition:.2s;
}
.social-row a:hover{ background:var(--gold-500); }
.social-row svg{ width:16px; height:16px; color:#fff; }

.field{ margin-bottom:18px; }
.field label{ display:block; font-weight:600; font-size:.85rem; margin-bottom:6px; color:var(--navy-900); }
.field input, .field select, .field textarea{
  width:100%; padding:13px 16px; border:1px solid var(--line); border-radius:var(--radius-sm);
  font-family:var(--sans); font-size:.95rem; color:var(--ink); background:#fff;
}
.field input:focus, .field select:focus, .field textarea:focus{ outline:2px solid var(--gold-500); outline-offset:1px; border-color:var(--gold-500); }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
@media (max-width:560px){ .field-row{ grid-template-columns:1fr; } }
.form-note{ font-size:.8rem; color:var(--slate-light); margin-top:10px; }

/* -------------------- CTA band -------------------- */
.cta-band{
  background:linear-gradient(120deg,var(--navy-900),var(--navy-700));
  color:#fff; border-radius:24px; padding:64px; text-align:center; position:relative; overflow:hidden;
}
.cta-band h2{ color:#fff; }
.cta-band p{ color:rgba(255,255,255,.8); max-width:520px; margin-left:auto; margin-right:auto; }
.cta-actions{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; margin-top:8px; }

/* -------------------- Footer -------------------- */
.site-footer{ background:var(--navy-900); color:rgba(255,255,255,.72); padding:80px 0 0; }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:40px; padding-bottom:56px; border-bottom:1px solid rgba(255,255,255,.1); }
@media (max-width:900px){ .footer-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:560px){ .footer-grid{ grid-template-columns:1fr; } }
.footer-grid h5{ color:#fff; font-family:var(--sans); font-size:.85rem; letter-spacing:.06em; text-transform:uppercase; margin-bottom:18px; }
.footer-grid ul li{ margin-bottom:10px; }
.footer-grid a:hover{ color:var(--gold-500); }
.footer-brand .brand{ margin-bottom:14px; }
.footer-brand .brand img{ height:40px; }
.footer-certs-row{ padding:32px 0; border-bottom:1px solid rgba(255,255,255,.1); }
.footer-certs-label{
  display:block; font-size:.78rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
  color:rgba(255,255,255,.5); margin-bottom:16px;
}
.footer-certs{ display:flex; flex-wrap:wrap; justify-content:space-between; gap:22px; align-items:flex-start; }
.cert-item{ display:flex; flex-direction:column; align-items:center; gap:10px; text-decoration:none; width:150px; }
@media (max-width:640px){
  .footer-certs{ justify-content:center; gap:14px; }
  .cert-item{ width:calc(33.333% - 10px); }
}
.cert-item .cert-badge{ background:#fff; border-radius:8px; padding:10px 14px; display:flex; align-items:center; justify-content:center; height:68px; width:100%; transition:.2s; }
.cert-item .cert-badge.on-dark{ background:rgba(255,255,255,.1); }
.cert-item:hover .cert-badge{ transform:translateY(-2px); box-shadow:0 6px 16px rgba(0,0,0,.25); }
.cert-item .cert-badge img{ max-height:48px; max-width:100%; width:auto; }
.cert-item .cert-name{ font-size:.72rem; color:rgba(255,255,255,.55); text-align:center; line-height:1.3; transition:.2s; }
.cert-item:hover .cert-name{ color:var(--gold-500); }

/* -------------------- Hero trust badges -------------------- */
.trust-strip{ padding:44px 0; background:var(--navy-900); }
.trust-strip-label{
  text-align:center; font-size:.78rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
  color:rgba(255,255,255,.5); margin-bottom:24px;
}
.trust-badges{ display:flex; flex-wrap:wrap; justify-content:center; gap:36px; }
.trust-badge{
  display:flex; flex-direction:column; align-items:center; text-align:center; gap:16px;
  text-decoration:none; padding:24px 20px; border-radius:14px; transition:.2s; width:210px;
}
.trust-badge:hover{ background:rgba(255,255,255,.06); }
.trust-badge .badge-icon{
  width:100%; height:80px; display:flex; align-items:center; justify-content:center;
  background:#fff; border-radius:10px; padding:12px;
}
.trust-badge .badge-icon.on-dark{ background:rgba(255,255,255,.08); }
.trust-badge .badge-icon img{ max-height:56px; max-width:100%; width:auto; }
.trust-badge .badge-icon.on-dark img{ max-height:44px; }
.trust-badge .badge-copy{ display:flex; flex-direction:column; line-height:1.3; }
.trust-badge .badge-copy strong{ color:#fff; font-size:.92rem; }
.trust-badge .badge-copy span{ color:rgba(255,255,255,.6); font-size:.78rem; }
@media (max-width:640px){
  .trust-badges{ gap:20px; }
  .trust-badge{ width:100%; max-width:320px; }
}

.footer-bottom{ display:flex; justify-content:space-between; align-items:center; padding:24px 0; flex-wrap:wrap; gap:12px; font-size:.82rem; }
.footer-bottom .lang-switch{ background:rgba(255,255,255,.06); border-color:rgba(255,255,255,.14); }
.footer-bottom .lang-switch a{ color:rgba(255,255,255,.6); }
.footer-bottom .lang-switch a.is-active{ background:var(--gold-500); color:var(--navy-900); }

/* -------------------- Breadcrumb / misc -------------------- */
.breadcrumb{ font-size:.85rem; color:rgba(255,255,255,.65); display:flex; gap:8px; align-items:center; margin-bottom:18px; }
.breadcrumb a:hover{ color:#fff; }

.wa-float{
  position:fixed; bottom:24px; right:24px; z-index:900; width:58px; height:58px; border-radius:50%;
  background:#25D366; display:flex; align-items:center; justify-content:center; box-shadow:var(--shadow-lg);
  transition:.2s;
}
.wa-float:hover{ transform:scale(1.06); }
.wa-float svg{ width:28px; height:28px; color:#fff; }

.reveal{ opacity:0; transform:translateY(18px); transition:opacity .6s ease, transform .6s ease; }
.reveal.in{ opacity:1; transform:translateY(0); }
