@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Manrope:wght@500;600;700;800&display=swap');

:root{
  --oe-navy:#141947;
  --oe-navy-2:#0d1234;
  --oe-ink:#121526;
  --oe-yellow:#ffcc0a;
  --oe-amber:#e5b83f;
  --oe-white:#ffffff;
  --oe-line:rgba(20,25,71,.14);
  --oe-soft:rgba(20,25,71,.06);
  --oe-shadow:0 24px 60px rgba(13,18,52,.17);
  --oe-radius:22px;
}

*{
  box-sizing:border-box;
}

.catalog-page{
  color:var(--oe-ink);
  background:
    radial-gradient(1200px 640px at 0% 0%, rgba(255,204,10,.14), transparent 58%),
    radial-gradient(1200px 640px at 100% 0%, rgba(20,25,71,.10), transparent 55%),
    #fdfdff;
  overflow:hidden;
}

.catalog-shell{
  width:min(1160px, calc(100% - 40px));
  margin:0 auto;
}

.catalog-page h1,
.catalog-page h2,
.catalog-page h3{
  margin:0;
  font-family:'Bebas Neue', sans-serif;
  letter-spacing:.06em;
  color:var(--oe-navy-2);
}

.catalog-page p,
.catalog-page li,
.catalog-page span,
.catalog-page a{
  font-family:'Manrope', sans-serif;
}

.catalog-hero{
  padding:84px 0 58px;
}

.catalog-hero .catalog-shell{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:24px;
  align-items:stretch;
}

.catalog-hero__copy{
  padding:10px 6px;
}

.catalog-hero__kicker{
  margin:0 0 14px;
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 12px;
  border-radius:999px;
  background:var(--oe-white);
  border:1px solid var(--oe-line);
  font-size:12px;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:rgba(20,25,71,.78);
}

.catalog-hero__copy h1{
  font-size:clamp(42px, 6.2vw, 78px);
  line-height:.94;
  max-width:10ch;
}

.catalog-hero__copy p{
  margin:18px 0 0;
  max-width:56ch;
  color:rgba(18,21,38,.78);
  line-height:1.62;
}

.catalog-hero__actions{
  margin-top:24px;
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

.catalog-hero__panel{
  position:relative;
  border-radius:var(--oe-radius);
  border:1px solid var(--oe-line);
  overflow:hidden;
  background:
    linear-gradient(160deg, rgba(20,25,71,.94), rgba(20,25,71,.76)),
    radial-gradient(720px 280px at 15% 15%, rgba(255,204,10,.25), transparent 58%),
    radial-gradient(720px 280px at 85% 80%, rgba(255,255,255,.15), transparent 62%);
  box-shadow:var(--oe-shadow);
  min-height:260px;
}

.hero-panel__header{
  display:flex;
  gap:8px;
  padding:14px 16px;
  border-bottom:1px solid rgba(255,255,255,.22);
}

.hero-dot{
  width:10px;
  height:10px;
  border-radius:999px;
  background:rgba(255,255,255,.45);
}

.hero-panel__body{
  padding:22px 20px 24px;
  display:grid;
  gap:8px;
}

.hero-panel__body p{
  margin:0;
  color:rgba(255,255,255,.74);
  font-size:14px;
}

.hero-panel__body strong{
  font-family:'Bebas Neue', sans-serif;
  letter-spacing:.08em;
  font-size:52px;
  line-height:.9;
  color:#fff;
}

.hero-panel__body small{
  color:rgba(255,255,255,.74);
  font-weight:700;
  letter-spacing:.04em;
  text-transform:uppercase;
}

.catalog-grid-wrap{
  padding:8px 0 62px;
}

.catalog-head{
  margin-bottom:18px;
}

.catalog-head__kicker{
  margin:0 0 8px;
  color:rgba(20,25,71,.74);
  font-size:12px;
  font-weight:800;
  letter-spacing:.09em;
  text-transform:uppercase;
}

.catalog-head h2{
  font-size:clamp(30px, 4.3vw, 48px);
  line-height:.95;
}

.catalog-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:16px;
}

.catalog-card{
  border-radius:var(--oe-radius);
  border:1px solid var(--oe-line);
  overflow:hidden;
  background:var(--oe-white);
  box-shadow:0 16px 44px rgba(12,17,45,.1);
  display:flex;
  flex-direction:column;
  min-height:100%;
}

.catalog-card__cover{
  position:relative;
  min-height:180px;
  padding:18px;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  gap:8px;
  border-bottom:1px solid rgba(255,255,255,.2);
}

.catalog-card__cover span{
  color:rgba(255,255,255,.82);
  font-size:12px;
  font-weight:800;
  letter-spacing:.09em;
  text-transform:uppercase;
}

.catalog-card__cover strong{
  font-family:'Bebas Neue', sans-serif;
  font-size:42px;
  line-height:.9;
  letter-spacing:.08em;
  color:#fff;
}

.catalog-card__body{
  padding:18px 18px 20px;
  display:flex;
  flex-direction:column;
  gap:10px;
  flex:1;
}

.catalog-card__body h3{
  font-size:34px;
  line-height:.95;
}

.catalog-card__body p{
  margin:0;
  color:rgba(18,21,38,.78);
  line-height:1.56;
}

.catalog-card__list{
  margin:2px 0 0;
  padding:0;
  list-style:none;
  display:grid;
  gap:8px;
}

.catalog-card__list li{
  position:relative;
  padding-left:18px;
  color:rgba(18,21,38,.78);
  line-height:1.48;
}

.catalog-card__list li::before{
  content:"";
  position:absolute;
  left:0;
  top:8px;
  width:8px;
  height:8px;
  border-radius:99px;
  background:linear-gradient(135deg, var(--oe-yellow), var(--oe-amber));
}

.catalog-card__meta{
  margin-top:auto;
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}

.catalog-card__meta span{
  font-size:12px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.05em;
  color:rgba(20,25,71,.74);
  background:var(--oe-soft);
  border:1px solid rgba(20,25,71,.14);
  border-radius:999px;
  padding:7px 10px;
}

.catalog-card__actions{
  margin-top:12px;
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

.catalog-card--bodas .catalog-card__cover{
  background:
    linear-gradient(150deg, rgba(20,25,71,.94), rgba(103,40,102,.92)),
    radial-gradient(700px 260px at 15% 25%, rgba(255,204,10,.3), transparent 58%);
}

.catalog-card--empresas .catalog-card__cover{
  background:
    linear-gradient(150deg, rgba(12,30,70,.95), rgba(22,84,136,.9)),
    radial-gradient(700px 260px at 85% 20%, rgba(255,204,10,.22), transparent 58%);
}

.catalog-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:44px;
  padding:12px 16px;
  border-radius:14px;
  border:1px solid transparent;
  text-decoration:none;
  font-size:14px;
  font-weight:800;
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease, background .18s ease;
}

.catalog-btn:hover{
  transform:translateY(-2px);
}

.catalog-btn--primary{
  background:linear-gradient(135deg, var(--oe-yellow), var(--oe-amber));
  color:#111;
  box-shadow:0 14px 32px rgba(255,204,10,.24);
}

.catalog-btn--primary:hover{
  box-shadow:0 18px 40px rgba(255,204,10,.3);
}

.catalog-btn--ghost{
  background:rgba(20,25,71,.04);
  border-color:rgba(20,25,71,.18);
  color:var(--oe-navy-2);
}

.catalog-btn--whatsapp{
  background:linear-gradient(135deg, #25d366, #1dab53);
  color:#fff;
  box-shadow:0 14px 30px rgba(37,211,102,.24);
}

.catalog-flow{
  padding:8px 0 62px;
}

.catalog-flow__grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:14px;
}

.flow-item{
  border-radius:18px;
  border:1px solid var(--oe-line);
  background:linear-gradient(180deg, rgba(255,255,255,.96), rgba(255,255,255,.83));
  box-shadow:0 12px 30px rgba(20,25,71,.08);
  padding:18px;
}

.flow-item span{
  display:inline-flex;
  width:34px;
  height:34px;
  border-radius:10px;
  align-items:center;
  justify-content:center;
  font-size:17px;
  font-weight:800;
  color:#111;
  background:linear-gradient(135deg, var(--oe-yellow), var(--oe-amber));
  margin-bottom:10px;
}

.flow-item h3{
  font-size:28px;
  line-height:.95;
}

.flow-item p{
  margin:10px 0 0;
  color:rgba(18,21,38,.76);
  line-height:1.56;
}

.catalog-cta{
  padding:0 0 74px;
}

.catalog-cta__inner{
  border-radius:calc(var(--oe-radius) + 6px);
  border:1px solid rgba(20,25,71,.16);
  background:
    radial-gradient(900px 420px at 12% 25%, rgba(255,204,10,.2), transparent 55%),
    radial-gradient(900px 420px at 88% 80%, rgba(20,25,71,.18), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.98), rgba(255,255,255,.88));
  box-shadow:var(--oe-shadow);
  padding:22px;
  display:flex;
  gap:18px;
  align-items:center;
  justify-content:space-between;
}

.catalog-cta__inner h2{
  font-size:42px;
  line-height:.92;
}

.catalog-cta__inner p{
  margin:10px 0 0;
  color:rgba(18,21,38,.78);
}

.catalog-cta__actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

[data-reveal]{
  opacity:0;
  transform:translateY(14px);
  filter:blur(2px);
  transition:opacity .5s ease, transform .5s ease, filter .5s ease;
}

[data-reveal].is-visible{
  opacity:1;
  transform:none;
  filter:none;
}

@media (max-width: 1080px){
  .catalog-hero .catalog-shell{
    grid-template-columns:1fr;
  }

  .catalog-hero__copy h1{
    max-width:100%;
  }

  .catalog-grid{
    grid-template-columns:1fr;
  }

  .catalog-flow__grid{
    grid-template-columns:1fr;
  }
}

@media (max-width: 760px){
  .catalog-hero{
    padding:72px 0 46px;
  }

  .catalog-shell{
    width:min(1160px, calc(100% - 28px));
  }

  .catalog-btn{
    width:100%;
  }

  .catalog-card__actions{
    flex-direction:column;
  }

  .catalog-cta__inner{
    flex-direction:column;
    align-items:flex-start;
  }

  .catalog-cta__actions{
    width:100%;
  }
}
