/* Cortinajes Triana — grid: layouts, hero .splash, tarjetas, tablas, formularios */

/* hero */
.splash{
  position:relative;
  padding:54px 0 64px;
  background:var(--chalk);
  overflow:hidden;
}
.splash .inner{
  display:grid;
  grid-template-columns:1fr;
  gap:34px;
  align-items:center;
}
.splash .copy h1{margin-bottom:18px}
.splash .copy .lede{margin-bottom:26px}
.splash .actions{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:26px}
.splash .trust{
  display:flex;flex-wrap:wrap;gap:22px 34px;
  padding-top:24px;border-top:1px solid var(--rule);
}
.splash .trust div b{display:block;font-family:var(--ff-display);font-size:1.9rem;color:var(--highlight-deep);line-height:1}
.splash .trust div span{font-size:.86rem;color:var(--text-soft)}
.splash .shot{
  position:relative;border-radius:var(--radius-lg);overflow:hidden;
  box-shadow:var(--shadow);
}
.splash .shot img{width:100%;height:100%;object-fit:cover;aspect-ratio:3/2}
.splash .shot::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:38%;
  background:linear-gradient(to top,rgba(10,10,10,.32),transparent);
}
.splash .tag{
  position:absolute;left:16px;bottom:16px;z-index:2;
  background:var(--graphite);color:var(--text-on-dark);
  padding:9px 14px;font-size:.82rem;letter-spacing:.04em;border-radius:var(--radius);
}
.splash .tag b{color:var(--highlight-soft);font-weight:600}

@media (min-width:860px){
  .splash{padding:70px 0 84px}
  .splash .inner{grid-template-columns:1.04fr 1fr;gap:52px}
}

/* rejilla de columnas */
.cols{display:grid;gap:var(--gap)}
.cols-2{grid-template-columns:1fr}
.cols-3{grid-template-columns:1fr}
.cols-4{grid-template-columns:1fr 1fr}
@media (min-width:680px){
  .cols-2{grid-template-columns:1fr 1fr}
  .cols-3{grid-template-columns:1fr 1fr}
}
@media (min-width:960px){
  .cols-3{grid-template-columns:repeat(3,1fr)}
  .cols-4{grid-template-columns:repeat(4,1fr)}
}

/* tarjeta generica */
.card{
  background:#fff;border:1px solid var(--rule);border-radius:var(--radius-lg);
  padding:26px 24px;
  transition:border-color .2s var(--ease),box-shadow .2s var(--ease),transform .2s var(--ease);
}
.card:hover{border-color:var(--highlight-soft);box-shadow:var(--shadow-soft);transform:translateY(-2px)}
.card .num{
  font-family:var(--ff-display);font-size:1.1rem;color:var(--highlight);
  display:inline-flex;width:38px;height:38px;align-items:center;justify-content:center;
  border:1px solid var(--rule);border-radius:50%;margin-bottom:16px;
}
.card h3{margin-bottom:10px}
.card p{margin-bottom:0;color:var(--text-soft);font-size:.98rem}
.card .price{display:block;margin-top:14px;font-weight:600;color:var(--highlight-deep)}

/* tarjeta con imagen (mosaicos) */
.tile{
  position:relative;border-radius:var(--radius-lg);overflow:hidden;
  border:1px solid var(--rule);background:var(--graphite);
}
.tile img{width:100%;height:240px;object-fit:cover;opacity:.92;transition:opacity .3s var(--ease),transform .4s var(--ease)}
.tile:hover img{opacity:1;transform:scale(1.03)}
.tile .label{
  position:absolute;left:0;right:0;bottom:0;padding:18px 18px 16px;
  background:linear-gradient(to top,rgba(10,10,10,.78),transparent);
  color:#fff;
}
.tile .label h3{color:#fff;margin:0 0 4px;font-size:1.25rem}
.tile .label p{margin:0;color:#D8D6D2;font-size:.88rem}

/* lista de checks */
.checks{list-style:none;padding:0;margin:0}
.checks li{position:relative;padding-left:30px;margin-bottom:14px;color:var(--text-soft)}
.checks li::before{
  content:"";position:absolute;left:0;top:3px;width:18px;height:18px;
  border:1px solid var(--highlight);border-radius:50%;
  background:
    linear-gradient(45deg,transparent 46%,var(--highlight) 46%,var(--highlight) 54%,transparent 54%) center/10px 10px no-repeat;
}
.checks li strong{color:var(--text)}

/* tabla de precios */
.ptable{width:100%;border-collapse:collapse;font-size:.97rem}
.ptable caption{text-align:left;color:var(--text-soft);font-size:.9rem;margin-bottom:12px}
.ptable th,.ptable td{padding:14px 16px;text-align:left;border-bottom:1px solid var(--rule);vertical-align:top}
.ptable thead th{
  font-family:var(--ff-body);font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;
  color:var(--text-soft);font-weight:600;border-bottom-color:var(--highlight);
}
.ptable tbody tr:hover{background:var(--chalk-soft)}
.ptable td.amount{font-weight:600;color:var(--highlight-deep);white-space:nowrap}

/* pasos */
.steps{counter-reset:step;list-style:none;padding:0;margin:0;display:grid;gap:18px}
.steps li{
  position:relative;padding:22px 22px 22px 70px;
  background:#fff;border:1px solid var(--rule);border-radius:var(--radius-lg);
}
.steps li::before{
  counter-increment:step;content:counter(step);
  position:absolute;left:20px;top:22px;
  width:34px;height:34px;display:flex;align-items:center;justify-content:center;
  font-family:var(--ff-display);font-size:1.15rem;color:#F6EFE4;
  background:var(--highlight-deep);border-radius:50%;
}
.steps li h3{margin:0 0 6px;font-size:1.18rem}
.steps li p{margin:0;color:var(--text-soft);font-size:.96rem}

/* equipo */
.member{text-align:left}
.member .ph{border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--rule);margin-bottom:16px}
.member .ph img{width:100%;height:auto;aspect-ratio:2/3;object-fit:cover}
.member h3{margin:0 0 2px;font-size:1.3rem}
.member .role{color:var(--highlight);font-size:.86rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;display:block;margin-bottom:10px}
.member p{color:var(--text-soft);font-size:.95rem;margin:0}

/* FAQ */
.faq{border-top:1px solid var(--rule)}
.faq details{border-bottom:1px solid var(--rule)}
.faq summary{
  cursor:pointer;list-style:none;padding:20px 44px 20px 0;position:relative;
  font-family:var(--ff-display);font-size:1.22rem;color:var(--text);
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{
  content:"+";position:absolute;right:6px;top:50%;transform:translateY(-50%);
  font-family:var(--ff-body);font-size:1.5rem;color:var(--highlight);transition:transform .2s var(--ease)
}
.faq details[open] summary::after{content:"\2013"}
.faq .answer{padding:0 0 22px;color:var(--text-soft);max-width:70ch}
.faq .answer p:last-child{margin-bottom:0}

/* contacto */
.contact-grid{display:grid;gap:var(--gap)}
@media (min-width:880px){.contact-grid{grid-template-columns:1fr 1fr;align-items:start}}
.info-line{display:flex;gap:14px;padding:18px 0;border-bottom:1px solid var(--rule)}
.info-line:last-child{border-bottom:0}
.info-line .k{min-width:108px;font-weight:600;color:var(--text);font-size:.92rem}
.info-line .v{color:var(--text-soft)}
.info-line .v a{font-weight:600}

/* formulario */
.form{background:#fff;border:1px solid var(--rule);border-radius:var(--radius-lg);padding:28px 26px}
.form .field{margin-bottom:18px}
.form label{display:block;font-size:.88rem;font-weight:600;margin-bottom:7px;color:var(--text)}
.form input[type=text],.form input[type=email],.form input[type=tel],.form textarea,.form select{
  width:100%;padding:13px 15px;font:inherit;font-size:1rem;color:var(--text);
  background:var(--chalk);border:1px solid var(--rule);border-radius:var(--radius);
  transition:border-color .18s var(--ease),background .18s var(--ease);
}
.form input:focus,.form textarea:focus,.form select:focus{outline:none;border-color:var(--highlight);background:#fff}
.form textarea{resize:vertical;min-height:110px}
.form .consent{display:flex;gap:11px;align-items:flex-start;font-size:.9rem;color:var(--text-soft);margin-bottom:20px}
.form .consent input{margin-top:3px;width:18px;height:18px;flex-shrink:0;accent-color:var(--highlight-deep)}
.form .hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.form button[type=submit]{width:100%}
.form .note{font-size:.82rem;color:var(--text-soft);margin:14px 0 0;text-align:center}
.form-status{margin-top:14px;font-size:.95rem;font-weight:600;min-height:1.2em}
.form-status.err{color:#9a2b2b}

/* bloque de gracias en linea */
.thanks-block{
  display:none;background:var(--graphite);color:var(--text-on-dark);
  border-radius:var(--radius-lg);padding:30px 28px;text-align:left;
}
.thanks-block.is-shown{display:block}
.thanks-block h3{color:#fff;margin-bottom:12px}
.thanks-block p,.thanks-block li{color:#CFCDC9}
.thanks-block ul{margin:14px 0 0}

/* migas visuales */
.crumbs{font-size:.84rem;color:var(--text-soft);padding:20px 0 0}
.crumbs a{color:var(--text-soft);font-weight:500}
.crumbs a:hover{color:var(--highlight-deep)}
.crumbs span{color:var(--text)}

/* reveal (IO inyectado en side-drawer.js) */
[data-rise]{opacity:0;transform:translateY(18px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
[data-rise].in-view{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  [data-rise]{opacity:1;transform:none}
}

/* prosa legal */
.prose{max-width:74ch}
.prose h2{margin-top:40px}
.prose h3{margin-top:28px}
.prose ul{margin-bottom:1.2em}
.prose address{font-style:normal;color:var(--text-soft)}
