/* blocks.css — content sections, cards, lists, forms, cookie */

/* === categorias grid === */
.categorias{display:grid;grid-template-columns:1fr;gap:24px}
@media(min-width:680px){.categorias{grid-template-columns:repeat(2,1fr)}}
@media(min-width:980px){.categorias{grid-template-columns:repeat(3,1fr)}}

.cat-card{
  display:block;
  background:var(--paper);
  border:1px solid var(--line);
  text-decoration:none;
  color:var(--ink);
  position:relative;
  transition:transform .25s ease, border-color .25s ease;
}
.cat-card:hover{transform:translateY(-3px);border-color:var(--bronze)}
.cat-card .pic{aspect-ratio:1/1;overflow:hidden;background:var(--paper-soft)}
.cat-card .pic img{width:100%;height:100%;object-fit:cover;filter:saturate(.92)}
.cat-card .body{padding:20px 22px 24px}
.cat-card .tag{
  margin:0 0 8px;
  padding:0;
  border:0;
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:2px;
  color:var(--bronze-dark);
}
.cat-card h3{
  font-size:24px;
  margin:0 0 8px;
  color:var(--navy);
}
.cat-card p{font-size:15px;color:var(--ink-soft);margin:0;max-width:none}
.cat-card .arrow{
  display:inline-block;
  margin-top:14px;
  font-family:var(--font-mono);
  font-size:12px;
  letter-spacing:1.5px;
  text-transform:uppercase;
  color:var(--bronze-dark);
}
.cat-card:hover .arrow{color:var(--navy)}

/* === split (two-column) === */
.split{
  display:grid;
  grid-template-columns:1fr;
  gap:32px;
  align-items:center;
}
@media(min-width:880px){.split{grid-template-columns:1fr 1fr;gap:64px}}
.split.r .text{order:2}
.split .pic{aspect-ratio:3/2;overflow:hidden;border:1px solid var(--line)}
.split .pic img{width:100%;height:100%;object-fit:cover}

.split .meta-list{
  list-style:none;padding:0;margin:24px 0 0;
  display:flex;flex-direction:column;gap:14px;
}
.split .meta-list li{
  display:flex;gap:14px;align-items:flex-start;
  padding-bottom:14px;
  border-bottom:1px dashed var(--line);
}
.split .meta-list li:last-child{border:0;padding-bottom:0}
.split .meta-list .n{
  font-family:var(--font-display);
  font-size:28px;
  color:var(--bronze);
  flex:0 0 56px;
  line-height:1;
}
.split .meta-list strong{display:block;font-size:17px;margin-bottom:2px}
.split .meta-list span{color:var(--ink-soft);font-size:15px}

/* === stats strip === */
.stats{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:24px;
  padding:32px 0;
}
@media(min-width:780px){.stats{grid-template-columns:repeat(4,1fr)}}
.stats .stat strong{
  display:block;
  font-family:var(--font-display);
  font-weight:800;
  font-size:clamp(40px,5vw,52px);
  color:var(--sand);
  line-height:1;
  margin-bottom:8px;
}
.stats .stat span{
  font-family:var(--font-mono);
  font-size:12px;
  letter-spacing:1.5px;
  text-transform:uppercase;
  color:#bcc7d8;
}

/* === por que nosotros === */
.reasons{
  display:grid;
  grid-template-columns:1fr;
  gap:20px;
}
@media(min-width:720px){.reasons{grid-template-columns:repeat(2,1fr)}}
@media(min-width:980px){.reasons{grid-template-columns:repeat(3,1fr)}}
.reasons .item{
  padding:24px;
  background:var(--paper);
  border:1px solid var(--line);
  border-left:3px solid var(--bronze);
}
.reasons .item .num{
  font-family:var(--font-mono);
  font-size:11px;letter-spacing:2px;
  color:var(--bronze-dark);
  margin-bottom:12px;
  display:block;
}
.reasons .item h3{font-size:20px;margin:0 0 10px}
.reasons .item p{margin:0;font-size:15px;color:var(--ink-soft)}

/* === testimonios === */
.testimonios{
  display:grid;
  grid-template-columns:1fr;
  gap:24px;
}
@media(min-width:780px){.testimonios{grid-template-columns:repeat(2,1fr)}}
.testimonios .quote{
  padding:28px;
  border-top:3px solid var(--bronze);
  background:var(--paper);
  border-left:1px solid var(--line);
  border-right:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.testimonios blockquote{
  margin:0 0 16px;
  font-size:17px;
  line-height:1.55;
  color:var(--ink);
}
.testimonios blockquote::before{
  content:"";display:block;
  width:24px;height:2px;
  background:var(--bronze);
  margin-bottom:16px;
}
.testimonios .who{
  font-family:var(--font-mono);
  font-size:12px;
  letter-spacing:1.5px;
  color:var(--ink-soft);
}
.testimonios .who strong{
  display:block;color:var(--navy);
  font-family:var(--font-display);
  font-size:16px;letter-spacing:1px;
}

/* === pricing tackle-row === */
.pricing{
  border-top:2px solid var(--navy);
  border-bottom:2px solid var(--navy);
}
.pricing-row{
  display:grid;
  grid-template-columns:1fr;
  gap:8px;
  padding:24px 0;
  border-bottom:1px solid var(--line);
}
.pricing-row:last-child{border-bottom:0}
@media(min-width:780px){
  .pricing-row{
    grid-template-columns:auto 1fr auto auto;
    gap:32px;
    align-items:center;
  }
}
.pricing-row .ref{
  font-family:var(--font-mono);
  font-size:12px;
  letter-spacing:1.5px;
  color:var(--bronze-dark);
}
.pricing-row .name strong{
  display:block;
  font-family:var(--font-display);
  font-size:22px;
  color:var(--navy);
  letter-spacing:.5px;
}
.pricing-row .name p{margin:4px 0 0;font-size:14px;color:var(--ink-soft);max-width:none}
.pricing-row .spec{
  font-family:var(--font-mono);
  font-size:12px;
  letter-spacing:1px;
  color:var(--ink-soft);
}
.pricing-row .price{
  font-family:var(--font-display);
  font-size:24px;
  color:var(--bronze-dark);
  white-space:nowrap;
}

/* === FAQ === */
.faq-item{
  border-top:1px solid var(--line);
}
.faq-item:last-child{border-bottom:1px solid var(--line)}
.faq-item .q{
  width:100%;
  background:transparent;
  border:0;
  text-align:left;
  padding:22px 0;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:24px;
  cursor:pointer;
  font-family:var(--font-display);
  font-weight:700;
  font-size:18px;
  letter-spacing:.5px;
  color:var(--navy);
  text-transform:none;
}
.faq-item .q .sign{
  flex:0 0 22px;
  width:22px;height:22px;
  border:1px solid var(--bronze);
  position:relative;
  transition:transform .25s ease;
}
.faq-item .q .sign::before,
.faq-item .q .sign::after{
  content:"";position:absolute;background:var(--bronze);
  left:50%;top:50%;transform:translate(-50%,-50%);
}
.faq-item .q .sign::before{width:10px;height:2px}
.faq-item .q .sign::after{width:2px;height:10px;transition:opacity .25s ease}
.faq-item[data-open="true"] .q .sign::after{opacity:0}
.faq-item .a{
  display:none;
  padding:0 0 22px;
  font-size:16px;
  color:var(--ink-soft);
  max-width:72ch;
}
.faq-item[data-open="true"] .a{display:block}

/* === form === */
.form-wrap{
  background:var(--paper);
  padding:32px;
  border:1px solid var(--line);
  border-left:4px solid var(--bronze);
}
.section.navy .form-wrap{
  background:rgba(245,242,234,.04);
  border-color:rgba(245,242,234,.25);
}
.form{
  display:grid;
  grid-template-columns:1fr;
  gap:16px;
}
.form .field label{
  display:block;
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:1.5px;
  text-transform:uppercase;
  color:var(--ink-soft);
  margin-bottom:6px;
}
.section.navy .form .field label{color:#bcc7d8}
.form .field input,
.form .field textarea{
  width:100%;
  font-family:var(--font-body);
  font-size:16px;
  color:var(--ink);
  background:var(--paper-soft);
  border:1px solid var(--line);
  padding:14px 16px;
  border-radius:0;
  transition:border-color .2s ease;
}
.section.navy .form .field input,
.section.navy .form .field textarea{
  background:rgba(0,0,0,.18);
  color:var(--paper);
  border-color:rgba(245,242,234,.25);
}
.form .field input:focus,
.form .field textarea:focus{
  outline:0;
  border-color:var(--bronze);
}
.form .field textarea{min-height:120px;resize:vertical}
.form .hp{
  position:absolute;
  left:-9999px;
  width:1px;height:1px;
  opacity:0;pointer-events:none;
}
.form .consent{
  display:flex;
  gap:10px;
  font-size:14px;
  color:var(--ink-soft);
  line-height:1.45;
}
.section.navy .form .consent{color:#cdd6e3}
.form .consent input{margin-top:4px}
.form .submit-row{
  display:flex;
  align-items:center;
  gap:18px;
  flex-wrap:wrap;
}
.form-status{
  font-family:var(--font-mono);
  font-size:12px;
  letter-spacing:1px;
}
.form-status[data-state="ok"]{color:#3e7a44}
.form-status[data-state="err"]{color:#a02a2a}

/* === contacto grid === */
.contact-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:32px;
}
@media(min-width:880px){
  .contact-grid{grid-template-columns:1fr 1fr;gap:64px}
}
.contact-info dl{margin:0;display:grid;gap:20px}
.contact-info dt{
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:2px;
  text-transform:uppercase;
  color:var(--bronze-dark);
  margin-bottom:4px;
}
.contact-info dd{
  margin:0;
  font-size:17px;
  color:var(--ink);
  font-weight:600;
}
.contact-info dd a{color:var(--ink)}
.contact-info dd a:hover{color:var(--bronze-dark)}
.contact-info .horario{
  margin-top:20px;
  padding:20px;
  background:var(--paper-soft);
  border-left:3px solid var(--bronze);
  font-size:15px;
}
.contact-info .horario strong{
  display:block;
  font-family:var(--font-display);
  font-size:18px;
  color:var(--navy);
  margin-bottom:8px;
}

/* === team grid === */
.team{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:20px;
}
@media(min-width:880px){.team{grid-template-columns:repeat(4,1fr);gap:24px}}
.team .person{display:block}
.team .person .pic{
  aspect-ratio:1/1;
  overflow:hidden;
  border:1px solid var(--line);
  margin-bottom:14px;
  background:var(--paper-soft);
}
.team .person .pic img{width:100%;height:100%;object-fit:cover;filter:saturate(.9)}
.team .person h3{
  font-size:18px;margin:0 0 4px;
  font-family:var(--font-display);
  letter-spacing:.5px;
  color:var(--navy);
}
.team .person .role{
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:1.5px;
  text-transform:uppercase;
  color:var(--bronze-dark);
  margin-bottom:8px;
}
.team .person p{font-size:14px;color:var(--ink-soft);margin:0}

/* === lists prose === */
.prose ul,.prose ol{padding-left:22px;line-height:1.7}
.prose li{margin-bottom:6px}
.prose h3{margin-top:32px}
.prose h2{margin-top:48px}

/* === cookie banner — bottom-right card === */
.cc-tray{
  position:fixed;
  bottom:20px;
  right:20px;
  width:calc(100% - 40px);
  max-width:380px;
  background:var(--paper);
  color:var(--ink);
  border:1px solid var(--navy);
  border-top:3px solid var(--bronze);
  padding:20px 22px 22px;
  z-index:120;
  box-shadow:0 12px 32px rgba(0,51,102,.18);
  font-size:14px;
  line-height:1.45;
  animation:cc-rise .35s ease;
}
@keyframes cc-rise{from{transform:translateY(20px);opacity:0}to{transform:none;opacity:1}}
.cc-tray .title{
  display:block;
  font-family:var(--font-display);
  font-weight:800;
  letter-spacing:1px;
  text-transform:uppercase;
  font-size:14px;
  color:var(--navy);
  margin-bottom:8px;
}
.cc-tray p{margin:0 0 14px;color:var(--ink-soft);font-size:14px;max-width:none}
.cc-tray .actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.cc-tray .actions button{
  flex:1 1 auto;
  font-family:var(--font-display);
  font-weight:700;
  font-size:13px;
  letter-spacing:1.5px;
  text-transform:uppercase;
  padding:11px 16px;
  cursor:pointer;
  border-radius:0;
  transition:background .2s ease;
}
.cc-tray .actions [data-cc="accept"]{
  background:var(--navy);color:var(--paper);
  border:2px solid var(--bronze);
}
.cc-tray .actions [data-cc="accept"]:hover{background:var(--bronze);border-color:var(--bronze-dark)}
.cc-tray .actions [data-cc="reject"]{
  background:transparent;color:var(--navy);
  border:2px solid var(--navy);
}
.cc-tray .actions [data-cc="reject"]:hover{background:var(--navy);color:var(--paper)}
@media(max-width:520px){
  .cc-tray{bottom:0;right:0;left:0;width:100%;max-width:none;border-left:0;border-right:0}
}

/* fade-in on scroll (in-view.js) */
.fx-in{opacity:0;transform:translateY(18px);transition:opacity .55s ease,transform .55s ease}
.fx-in.is-in{opacity:1;transform:none}
