/* =============================================================
   WORKANA EXPLAINED · Hoja de estilos
   Paleta extraída del sitio oficial de Workana
   ============================================================= */
:root{
  --c-primary: #002D72;        /* azul corporativo */
  --c-orange:  #FF4807;        /* CTA principal */
  --c-blue:    #0A78FF;        /* enlace / acento */
  --c-green:   #00B450;        /* éxito */
  --c-magenta: #BF17A7;        /* acento secundario */
  --c-pink:    #FF97B1;        /* suave */
  --c-yellow:  #FFC600;        /* destacado */

  --c-bg:      #FFFFFF;
  --c-bg-soft: #F6F8FC;
  --c-bg-alt:  #EEF3FB;
  --c-ink:     #0A1733;
  --c-ink-2:   #3B4A6B;
  --c-line:    #E3E8F1;

  --shadow-sm: 0 1px 2px rgba(0,45,114,.06), 0 1px 3px rgba(0,45,114,.05);
  --shadow-md: 0 8px 24px -8px rgba(0,45,114,.18), 0 4px 12px -4px rgba(0,45,114,.10);
  --shadow-lg: 0 30px 60px -20px rgba(0,45,114,.30), 0 12px 32px -8px rgba(0,45,114,.18);

  --radius-sm: 8px;
  --radius:    14px;
  --radius-lg: 22px;
  --radius-xl: 32px;

  --font: 'Inter', system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;

  --max:    1200px;
  --pad:    clamp(20px, 4vw, 40px);

  --ease:   cubic-bezier(.2,.7,.2,1);
}

/* ============= Lucide icons base ============= */
[data-lucide], i[data-lucide] svg, svg.lucide{
  display:inline-block; vertical-align:middle;
  width:1em; height:1em; stroke-width:2;
}
/* placeholder size while lucide.js carga */
i[data-lucide]:not(:has(svg)){
  display:inline-block; width:1em; height:1em;
}

/* ============= reset ============= */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0; font-family:var(--font); font-size:16px; line-height:1.6;
  color:var(--c-ink); background:var(--c-bg);
  -webkit-font-smoothing:antialiased;
}
img,svg{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; }
h1,h2,h3,h4,h5{ margin:0; font-weight:800; letter-spacing:-.02em; line-height:1.15; }
p{ margin:0; }
ol,ul{ margin:0; padding:0; list-style:none; }

/* ============= helpers ============= */
.container{ width:100%; max-width:var(--max); margin:0 auto; padding:0 var(--pad); }
.kicker{
  display:inline-block; font-size:.78rem; letter-spacing:.16em; text-transform:uppercase;
  color:var(--c-orange); font-weight:700; margin-bottom:14px;
}
.grad{
  background:linear-gradient(90deg, var(--c-orange), var(--c-magenta) 60%, var(--c-blue));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.eyebrow{
  display:inline-flex; align-items:center; gap:8px;
  font-size:.85rem; font-weight:600; color:var(--c-primary);
  background:#E6F0FF; padding:6px 14px; border-radius:999px;
}
.eyebrow .dot{ width:8px; height:8px; border-radius:50%; background:var(--c-green); animation:pulse 1.6s infinite; }
@keyframes pulse{
  0%,100%{ box-shadow:0 0 0 0 rgba(0,180,80,.5); }
  70%{ box-shadow:0 0 0 8px rgba(0,180,80,0); }
}

/* ============= botones ============= */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:11px 18px; border-radius:999px; font-weight:700; font-size:.95rem;
  border:1.5px solid transparent; cursor:pointer; transition:transform .15s var(--ease), box-shadow .2s var(--ease), background .2s, color .2s;
  white-space:nowrap;
}
.btn:hover{ transform:translateY(-1px); }
.btn--lg{ padding:15px 28px; font-size:1rem; }
.btn--primary{
  background:var(--c-orange); color:#fff; box-shadow:0 8px 18px -8px rgba(255,72,7,.6);
}
.btn--primary:hover{ background:#e63d00; box-shadow:0 12px 24px -8px rgba(255,72,7,.7); }
.btn--outline{
  background:transparent; color:var(--c-primary); border-color:var(--c-primary);
}
.btn--outline:hover{ background:var(--c-primary); color:#fff; }
.btn--ghost{
  background:transparent; color:var(--c-ink);
}
.btn--ghost:hover{ background:var(--c-bg-alt); }
.btn--white{
  background:#fff; color:var(--c-primary);
}
.btn--white:hover{ background:#FFE9DD; color:var(--c-orange); }
.btn--ghost-white{
  background:transparent; color:#fff; border-color:rgba(255,255,255,.5);
}
.btn--ghost-white:hover{ background:rgba(255,255,255,.1); border-color:#fff; }

/* ============= NAV ============= */
.nav{
  position:sticky; top:0; z-index:50;
  background:rgba(255,255,255,.85); backdrop-filter:saturate(180%) blur(14px);
  border-bottom:1px solid transparent;
  transition:border-color .2s, box-shadow .2s, background .2s;
}
.nav.is-scrolled{
  border-bottom-color:var(--c-line);
  box-shadow:var(--shadow-sm);
}
.nav__inner{
  display:flex; align-items:center; gap:24px; padding:14px 0;
}
.logo{
  display:inline-flex; align-items:center; gap:10px;
  font-weight:900; font-size:1.4rem; letter-spacing:-.03em; color:var(--c-primary);
}
.logo__icon{
  display:inline-grid; place-items:center;
  width:36px; height:36px; border-radius:10px;
  background:linear-gradient(135deg, var(--c-orange), var(--c-magenta));
  color:#fff;
  box-shadow:0 6px 14px -4px rgba(255,72,7,.5);
  flex-shrink:0;
}
.logo__icon svg{ width:20px; height:20px; }
.logo__text{ display:inline-flex; align-items:baseline; }
.logo__dot{ color:var(--c-orange); }
.logo__sub{
  margin-left:4px; padding:3px 8px; border-radius:6px;
  background:var(--c-bg-alt); color:var(--c-ink-2);
  font-size:.7rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase;
  align-self:center;
}
.logo--light{ color:#fff; }
.logo--light .logo__sub{ background:rgba(255,255,255,.12); color:rgba(255,255,255,.85); }

.nav__links{
  display:flex; gap:6px; flex:1; justify-content:center;
}
.nav__links a{
  padding:8px 14px; border-radius:999px; font-weight:600; color:var(--c-ink-2);
  transition:color .15s, background .15s;
}
.nav__links a:hover{ color:var(--c-primary); background:var(--c-bg-alt); }

.nav__cta{ display:flex; gap:8px; align-items:center; }
.nav__burger{
  display:none; flex-direction:column; gap:5px;
  background:none; border:0; cursor:pointer; padding:8px;
}
.nav__burger span{ width:24px; height:2px; background:var(--c-ink); border-radius:2px; transition:transform .2s, opacity .2s; }
.nav__burger.is-open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav__burger.is-open span:nth-child(2){ opacity:0; }
.nav__burger.is-open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

@media (max-width: 980px){
  .nav__links{
    position:absolute; left:0; right:0; top:100%;
    flex-direction:column; gap:0; padding:18px;
    background:#fff; border-bottom:1px solid var(--c-line);
    transform:translateY(-12px); opacity:0; pointer-events:none;
    transition:transform .2s var(--ease), opacity .2s;
  }
  .nav__links a{ padding:14px; border-radius:10px; }
  .nav.is-mobile-open .nav__links{ transform:translateY(0); opacity:1; pointer-events:auto; }
  .nav__cta{ display:none; }
  .nav__burger{ display:flex; margin-left:auto; }
}

/* ============= HERO ============= */
.hero{
  position:relative; overflow:hidden;
  padding:80px 0 40px;
  background:
    radial-gradient(900px 500px at 90% -10%, #FFE3D6 0%, transparent 60%),
    radial-gradient(700px 400px at 0% 30%, #DEEBFF 0%, transparent 60%),
    #fff;
}
.hero__bg{ position:absolute; inset:0; pointer-events:none; }
.blob{
  position:absolute; border-radius:50%; filter:blur(40px); opacity:.5;
  animation:floaty 14s ease-in-out infinite;
}
.blob--orange{ width:280px; height:280px; background:var(--c-orange); top:10%; right:8%; }
.blob--blue{ width:340px; height:340px; background:var(--c-blue); bottom:10%; left:-5%; animation-delay:-3s; }
.blob--magenta{ width:200px; height:200px; background:var(--c-magenta); top:50%; right:30%; animation-delay:-6s; opacity:.3; }
.blob--yellow{ width:160px; height:160px; background:var(--c-yellow); top:5%; left:30%; animation-delay:-9s; opacity:.4; }
@keyframes floaty{
  0%,100%{ transform:translate(0,0) scale(1); }
  50%{ transform:translate(30px,-20px) scale(1.05); }
}

.hero__inner{
  position:relative;
  display:grid; grid-template-columns:1.05fr 1fr; gap:60px; align-items:center;
}
.hero__title{
  font-size:clamp(2.2rem, 5vw, 4rem);
  margin:18px 0 18px;
}
.hero__lead{
  font-size:1.1rem; color:var(--c-ink-2); max-width:520px; margin-bottom:28px;
}
.hero__cta{ display:flex; gap:12px; flex-wrap:wrap; margin-bottom:32px; }
.hero__trust{ display:flex; align-items:center; gap:14px; }
.hero__trust p{ font-size:.92rem; color:var(--c-ink-2); }
.trust__avatars{ display:flex; }
.trust__avatars img,
.trust__avatars span{
  width:36px; height:36px; border-radius:50%; border:2px solid #fff;
  margin-left:-10px; box-shadow:var(--shadow-sm); object-fit:cover;
  background:var(--c-bg-alt);
}
.trust__avatars img:first-child,
.trust__avatars span:first-child{ margin-left:0; }

/* card del hero */
.hero__card{
  position:relative;
  background:#fff; border-radius:var(--radius-xl);
  box-shadow:var(--shadow-lg);
  overflow:visible;
  transform:perspective(1200px) rotateY(-6deg) rotateX(2deg);
  transition:transform .6s var(--ease);
}
.hero__card:hover{ transform:perspective(1200px) rotateY(-2deg) rotateX(0deg); }
.card__head{
  display:flex; align-items:center; gap:12px;
  padding:14px 18px; border-bottom:1px solid var(--c-line);
  background:#fafbfd; border-radius:var(--radius-xl) var(--radius-xl) 0 0;
}
.card__dots{ display:flex; gap:6px; }
.card__dots span{ width:11px; height:11px; border-radius:50%; background:#e0e4ec; }
.card__dots span:nth-child(1){ background:#FF6058; }
.card__dots span:nth-child(2){ background:#FFBD2E; }
.card__dots span:nth-child(3){ background:#27CA40; }
.card__url{ font-family:ui-monospace, SFMono-Regular, Menlo, monospace; font-size:.82rem; color:var(--c-ink-2); }
.card__body{ padding:24px; position:relative; }

.proj{ }
.proj__row{ display:flex; gap:8px; margin-bottom:14px; }
.proj h3{ font-size:1.25rem; margin-bottom:10px; }
.proj > p{ color:var(--c-ink-2); margin-bottom:18px; }
.proj__meta{ display:flex; flex-wrap:wrap; gap:10px 18px; font-size:.88rem; color:var(--c-ink-2); margin-bottom:20px; }
.proj__meta span{ display:inline-flex; align-items:center; gap:6px; }
.proj__meta svg{ width:16px; height:16px; }
.proj__bids{ display:flex; align-items:center; gap:14px; padding-top:18px; border-top:1px dashed var(--c-line); }
.bids__avatars{ display:flex; align-items:center; }
.bids__avatars span{
  width:32px; height:32px; border-radius:50%; border:2px solid #fff; margin-left:-8px;
  display:grid; place-items:center; font-size:.72rem; font-weight:800; color:#fff;
  letter-spacing:.02em;
}
.bids__avatars span:first-child{ margin-left:0; }
.bids__avatars .initial--more{ background:var(--c-bg-alt); color:var(--c-ink-2); }
.bids__label{ font-size:.88rem; color:var(--c-ink-2); }

.badge{
  display:inline-block; padding:4px 10px; border-radius:999px;
  font-size:.72rem; font-weight:700; letter-spacing:.04em;
}
.badge--blue   { background:#E2EEFF; color:var(--c-blue); }
.badge--green  { background:#DEF7E8; color:var(--c-green); }
.badge--orange { background:#FFE5D9; color:var(--c-orange); }

.float{
  position:absolute;
  display:flex; align-items:center; gap:12px;
  background:#fff; padding:12px 16px; border-radius:14px;
  box-shadow:var(--shadow-md);
  animation:bob 3s ease-in-out infinite;
}
.float strong{ font-size:.92rem; }
.float p{ font-size:.78rem; color:var(--c-ink-2); }
.float__icon{
  width:38px; height:38px; border-radius:10px;
  display:inline-grid; place-items:center; flex-shrink:0;
}
.float__icon svg{ width:20px; height:20px; }
.float--match{ left:-30px; bottom:90px; animation-delay:-1s; }
.float--pay{ right:-20px; top:80px; animation-delay:-2s; }
@keyframes bob{
  0%,100%{ transform:translateY(0); }
  50%{ transform:translateY(-8px); }
}

/* marquee */
.marquee{
  margin-top:60px; overflow:hidden;
  border-top:1px solid var(--c-line); border-bottom:1px solid var(--c-line);
  background:#fff;
}
.marquee__track{
  display:flex; gap:48px; padding:18px 0;
  animation:scroll 35s linear infinite;
  white-space:nowrap; width:max-content;
}
.marquee__track span{
  font-weight:700; color:var(--c-ink-2); font-size:.95rem; letter-spacing:.02em;
}
.marquee__track span::before{
  content:"●"; color:var(--c-orange); margin-right:48px; font-size:.6rem; vertical-align:middle;
}
@keyframes scroll{
  0%{ transform:translateX(0); }
  100%{ transform:translateX(-50%); }
}

@media (max-width: 980px){
  .hero{ padding:50px 0 30px; }
  .hero__inner{ grid-template-columns:1fr; gap:50px; }
  .hero__card{ transform:none; max-width:480px; margin:0 auto; }
  .float--match{ left:-10px; bottom:60px; }
  .float--pay{ right:-10px; top:60px; }
}

/* ============= STATS ============= */
.stats{
  background:linear-gradient(135deg, var(--c-primary), #001a4a);
  color:#fff; padding:50px 0;
}
.stats__grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:32px; text-align:center; }
.stat__num{
  font-size:clamp(2rem, 4.5vw, 3.4rem); font-weight:900; letter-spacing:-.03em;
  background:linear-gradient(135deg, #fff, #FF97B1); -webkit-background-clip:text; background-clip:text; color:transparent;
}
.stat__label{ color:rgba(255,255,255,.75); font-size:.95rem; margin-top:6px; }
@media (max-width:760px){ .stats__grid{ grid-template-columns:repeat(2,1fr); gap:24px; } }

/* ============= sections ============= */
.section{ padding:90px 0; }
.section--alt{ background:var(--c-bg-soft); }
.section__head{ max-width:720px; margin:0 auto 50px; text-align:center; }
.section__title{ font-size:clamp(1.8rem, 3.6vw, 2.6rem); margin-bottom:14px; }
.section__lead{ color:var(--c-ink-2); font-size:1.05rem; }

/* ============= features ============= */
.features{ display:grid; grid-template-columns:repeat(4,1fr); gap:22px; }
.feature{
  background:#fff; padding:26px; border-radius:var(--radius-lg);
  border:1px solid var(--c-line); transition:transform .25s var(--ease), box-shadow .25s var(--ease), border-color .25s;
}
.feature:hover{ transform:translateY(-4px); box-shadow:var(--shadow-md); border-color:transparent; }
.feature__icon{
  width:54px; height:54px; border-radius:14px;
  display:grid; place-items:center; margin-bottom:18px;
  background:color-mix(in srgb, var(--c) 14%, transparent);
  color:var(--c);
}
.feature__icon svg{ width:28px; height:28px; stroke-width:2; }
.feature h3{ font-size:1.15rem; margin-bottom:8px; }
.feature p{ color:var(--c-ink-2); font-size:.95rem; }
@media (max-width:980px){ .features{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){ .features{ grid-template-columns:1fr; } }

/* ============= tabs ============= */
.tabs{
  display:inline-flex; padding:6px; background:#fff;
  border-radius:999px; box-shadow:var(--shadow-sm); margin:0 auto 36px;
  display:flex; max-width:max-content; margin-left:auto; margin-right:auto;
}
.tab{
  padding:12px 26px; border-radius:999px; border:0; background:transparent;
  font-weight:700; color:var(--c-ink-2); cursor:pointer; transition:all .2s var(--ease);
  font-size:.95rem;
  display:inline-flex; align-items:center; gap:8px;
}
.tab svg{ width:18px; height:18px; }
.tab:hover{ color:var(--c-ink); }
.tab.is-active{
  background:var(--c-primary); color:#fff;
  box-shadow:0 4px 12px -4px rgba(0,45,114,.5);
}

.steps{ display:none; max-width:880px; margin:0 auto; }
.steps.is-active{ display:block; animation:fadeUp .35s var(--ease); }
.steps__list{
  display:grid; grid-template-columns:repeat(2,1fr); gap:24px;
}
.step{
  display:flex; gap:18px; padding:24px;
  background:#fff; border-radius:var(--radius);
  border:1px solid var(--c-line);
  transition:transform .2s var(--ease), border-color .2s;
}
.step:hover{ transform:translateY(-3px); border-color:var(--c-orange); }
.step__num{
  flex-shrink:0;
  width:42px; height:42px; border-radius:12px;
  display:grid; place-items:center;
  background:linear-gradient(135deg, var(--c-orange), var(--c-magenta));
  color:#fff; font-weight:900; font-size:1.1rem;
}
.step h3{ font-size:1.05rem; margin-bottom:6px; }
.step p{ color:var(--c-ink-2); font-size:.94rem; }
@media (max-width:760px){ .steps__list{ grid-template-columns:1fr; } }

/* ============= bench (beneficios) ============= */
.bench__inner{
  display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center;
}
.bench__inner--reverse{ direction:rtl; }
.bench__inner--reverse > *{ direction:ltr; }

.bench__copy .section__title{ text-align:left; font-size:clamp(1.6rem, 3vw, 2.2rem); }
.bench__copy .kicker{ display:inline-block; }
.bench__copy .section__lead{ text-align:left; }
.bench__copy{ }

.checks{ display:flex; flex-direction:column; gap:14px; margin:30px 0; }
.checks li{ display:flex; gap:14px; align-items:flex-start; }
.checks div strong{ color:var(--c-primary); }
.checks div{ color:var(--c-ink-2); font-size:.97rem; }
.checks__icon{
  flex-shrink:0;
  width:26px; height:26px; border-radius:50%;
  display:grid; place-items:center;
  background:#DEF7E8; color:var(--c-green);
  margin-top:2px;
}
.checks__icon svg{ width:14px; height:14px; stroke-width:3; }

/* visual cliente */
.bench__visual{ position:relative; }
.bench__cardA{
  background:#fff; padding:28px; border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg); border:1px solid var(--c-line);
}
.bench__cardA h4{ margin:14px 0 22px; font-size:1.1rem; }
.bench__cardA .cat{ margin-bottom:18px; }
.bench__cardA .cat span{ font-size:.9rem; font-weight:600; display:block; margin-bottom:6px; }
.bar{ height:8px; background:var(--c-bg-alt); border-radius:999px; overflow:hidden; }
.bar i{
  display:block; height:100%; width:0;
  background:var(--c); border-radius:999px;
  transition:width 1.2s var(--ease);
}
.bench__cardA.is-visible .bar i{ width:var(--w); }

.bench__cardB{
  position:absolute; bottom:-30px; right:-20px;
  background:#fff; padding:16px 20px; border-radius:14px;
  box-shadow:var(--shadow-md);
  display:flex; align-items:center; gap:14px;
  max-width:260px;
}
.bench__cardB strong{ display:block; font-size:1rem; }
.bench__cardB p{ font-size:.82rem; color:var(--c-ink-2); }
.bench__cardB__avatar{
  width:44px; height:44px; border-radius:12px;
  background:linear-gradient(135deg, var(--c-green), var(--c-blue));
  flex-shrink:0; color:#fff;
  display:grid; place-items:center;
}
.bench__cardB__avatar svg{ width:24px; height:24px; }

/* visual freelancer */
.profile{
  background:#fff; padding:28px; border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg); border:1px solid var(--c-line);
  max-width:440px; margin:0 auto;
}
.profile__top{ display:flex; gap:18px; align-items:center; margin-bottom:20px; }
.profile__avatar{
  width:72px; height:72px; border-radius:50%; flex-shrink:0;
  background:linear-gradient(135deg, var(--c-pink), var(--c-magenta));
  position:relative; overflow:visible;
}
.profile__avatar img{
  width:100%; height:100%; border-radius:50%; object-fit:cover;
  border:3px solid #fff; box-shadow:var(--shadow-sm);
}
.profile__avatar::after{
  content:""; position:absolute; bottom:0; right:0;
  width:18px; height:18px; border-radius:50%; background:var(--c-green); border:3px solid #fff;
  z-index:2;
}
.profile__top h4{ font-size:1.1rem; }
.profile__top p{ color:var(--c-ink-2); font-size:.88rem; margin:2px 0 4px; }
.verified{
  display:inline-grid; place-items:center;
  width:18px; height:18px; border-radius:50%;
  background:var(--c-blue); color:#fff; font-weight:900;
  margin-left:4px; vertical-align:middle;
}
.verified svg{ width:12px; height:12px; stroke-width:3.5; }
.stars{ display:inline-flex; align-items:center; gap:1px; color:var(--c-yellow); font-size:.95rem; }
.stars svg{ width:16px; height:16px; fill:var(--c-yellow); stroke:var(--c-yellow); }
.stars span{ color:var(--c-ink-2); font-size:.82rem; margin-left:8px; }

.profile__skills{ display:flex; flex-wrap:wrap; gap:6px; margin-bottom:22px; }
.profile__skills span{
  background:var(--c-bg-alt); color:var(--c-primary);
  padding:5px 12px; border-radius:999px; font-size:.8rem; font-weight:600;
}
.profile__earnings{
  display:grid; grid-template-columns:1fr 1fr; gap:12px;
  border-top:1px dashed var(--c-line); padding-top:18px;
}
.profile__num{ display:block; font-size:1.4rem; font-weight:900; color:var(--c-primary); letter-spacing:-.02em; }
.profile__lbl{ display:block; font-size:.82rem; color:var(--c-ink-2); }

@media (max-width:980px){
  .bench__inner, .bench__inner--reverse{ grid-template-columns:1fr; gap:50px; direction:ltr; }
  .bench__cardB{ position:static; margin:20px auto 0; }
}

/* ============= categorías ============= */
.cats__grid{
  display:grid; grid-template-columns:repeat(4,1fr); gap:18px;
}
.cat-card{
  display:block; padding:24px; border-radius:var(--radius-lg);
  background:#fff; border:1px solid var(--c-line);
  transition:transform .25s var(--ease), box-shadow .25s var(--ease), border-color .25s;
  position:relative; overflow:hidden;
}
.cat-card::before{
  content:""; position:absolute; top:0; left:0; right:0; height:4px;
  background:var(--c); transform:scaleX(0); transform-origin:left;
  transition:transform .3s var(--ease);
}
.cat-card:hover{ transform:translateY(-4px); box-shadow:var(--shadow-md); border-color:transparent; }
.cat-card:hover::before{ transform:scaleX(1); }
.cat-card__ico{
  display:inline-grid; place-items:center;
  width:54px; height:54px; border-radius:14px; margin-bottom:14px;
  background:color-mix(in srgb, var(--c) 14%, transparent);
  color:var(--c);
}
.cat-card__ico svg{ width:28px; height:28px; }
.cat-card h4{ font-size:1.05rem; margin-bottom:6px; color:var(--c-primary); }
.cat-card p{ color:var(--c-ink-2); font-size:.88rem; }
@media (max-width:980px){ .cats__grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:480px){ .cats__grid{ grid-template-columns:1fr; } }

/* ============= FAQ ============= */
.faq__list{ max-width:800px; margin:0 auto; display:flex; flex-direction:column; gap:14px; }
.qa{
  background:#fff; border:1px solid var(--c-line);
  border-radius:var(--radius); overflow:hidden;
  transition:border-color .2s, box-shadow .2s;
}
.qa[open]{ border-color:var(--c-orange); box-shadow:var(--shadow-sm); }
.qa summary{
  list-style:none; cursor:pointer;
  padding:20px 24px;
  display:flex; justify-content:space-between; align-items:center; gap:18px;
  font-weight:700; font-size:1.02rem; color:var(--c-primary);
}
.qa summary::-webkit-details-marker{ display:none; }
.qa__icon{
  flex-shrink:0;
  width:32px; height:32px; border-radius:50%;
  background:var(--c-bg-alt); color:var(--c-primary);
  display:grid; place-items:center; font-size:1.3rem; font-weight:300;
  transition:transform .25s var(--ease), background .2s, color .2s;
}
.qa[open] .qa__icon{ transform:rotate(45deg); background:var(--c-orange); color:#fff; }
.qa__body{ padding:0 24px 22px; color:var(--c-ink-2); font-size:.97rem; }

/* ============= CTA final ============= */
.cta-final{
  position:relative; overflow:hidden;
  padding:80px 0; color:#fff;
  background:
    radial-gradient(600px 300px at 20% 20%, rgba(255,72,7,.4) 0%, transparent 60%),
    radial-gradient(500px 300px at 80% 80%, rgba(191,23,167,.4) 0%, transparent 60%),
    linear-gradient(135deg, var(--c-primary), #001a4a);
  text-align:center;
}
.cta-final h2{ font-size:clamp(1.8rem, 4vw, 2.8rem); margin-bottom:14px; }
.cta-final p{ font-size:1.1rem; color:rgba(255,255,255,.85); margin-bottom:30px; }
.cta-final__btns{ display:flex; gap:14px; flex-wrap:wrap; justify-content:center; }

/* ============= footer ============= */
.footer{ background:#031130; color:rgba(255,255,255,.7); padding:60px 0 30px; }
.footer__inner{ display:grid; grid-template-columns:1fr 2fr; gap:50px; padding-bottom:40px; border-bottom:1px solid rgba(255,255,255,.08); }
.footer__note{ font-size:.85rem; margin-top:14px; max-width:340px; }
.footer__cols{ display:grid; grid-template-columns:repeat(3,1fr); gap:30px; }
.footer__cols h5{ color:#fff; margin-bottom:14px; font-size:.95rem; }
.footer__cols a{ display:block; padding:6px 0; font-size:.92rem; transition:color .15s; }
.footer__cols a:hover{ color:var(--c-orange); }
.footer__bottom{
  display:flex; justify-content:space-between; align-items:center;
  margin-top:24px; font-size:.82rem; flex-wrap:wrap; gap:10px;
}
@media (max-width:760px){
  .footer__inner{ grid-template-columns:1fr; gap:30px; }
  .footer__cols{ grid-template-columns:repeat(3,1fr); }
}
@media (max-width:480px){ .footer__cols{ grid-template-columns:1fr; } }

/* ============= scroll-top ============= */
.totop{
  position:fixed; right:24px; bottom:24px; z-index:60;
  width:48px; height:48px; border-radius:50%;
  background:var(--c-orange); color:#fff;
  border:0; cursor:pointer;
  display:grid; place-items:center;
  box-shadow:var(--shadow-md);
  opacity:0; pointer-events:none;
  transform:translateY(10px);
  transition:opacity .25s, transform .25s var(--ease), background .2s;
}
.totop svg{ width:20px; height:20px; stroke-width:2.5; }
.totop:hover{ background:#e63d00; }
.totop.is-visible{ opacity:1; pointer-events:auto; transform:translateY(0); }

/* ============= reveal animations ============= */
.reveal{ opacity:0; transform:translateY(24px); transition:opacity .6s var(--ease), transform .6s var(--ease); }
.reveal.is-visible{ opacity:1; transform:none; }
@keyframes fadeUp{
  from{ opacity:0; transform:translateY(10px); }
  to{ opacity:1; transform:none; }
}

@media (prefers-reduced-motion: reduce){
  *{ animation-duration:.01ms !important; animation-iteration-count:1 !important; transition-duration:.01ms !important; }
  html{ scroll-behavior:auto; }
}
