/* ============================================================
   PAGES.CSS — Estilos compartidos para páginas internas
   ============================================================ */

/* ===== CLIENT NOTICE ===== */
.client-notice {
  background: #fef9c3;
  border-bottom: 1px solid #f5e173;
  padding-block: var(--space-3);
}
.client-notice__inner {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  font-size: var(--text-sm);
  color: #713f12;
}
.client-notice code {
  background: rgba(0,0,0,0.08);
  padding: 0.1em 0.4em;
  border-radius: 3px;
  font-family: monospace;
  font-size: 0.9em;
}
[data-theme='dark'] .client-notice { background: #422006; border-color: #7c2d12; color: #fde68a; }

/* ===== ABOUT PAGE ===== */
.about-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-16);
  align-items: start;
}
.about-text { display: flex; flex-direction: column; gap: var(--space-5); }
.about-text p { font-size: var(--text-base); color: var(--color-text-muted); line-height: 1.75; }

/* Mission/Vision/Values */
.mvv-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
}
.mvv-card {
  background: var(--color-surface);
  border: 1px solid var(--color-divider);
  border-radius: var(--radius-lg);
  padding: var(--space-8);
  display: flex; flex-direction: column; gap: var(--space-4);
  transition: box-shadow var(--ease);
}
.mvv-card:hover { box-shadow: var(--shadow-md); }
.mvv-icon {
  width: 52px; height: 52px;
  background: var(--color-primary-xl);
  border-radius: var(--radius-md);
  display: flex; align-items: center; justify-content: center;
  color: var(--color-primary);
}
.mvv-card h3 {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}
.mvv-card p { font-size: var(--text-sm); color: var(--color-text-muted); line-height: 1.7; }

/* Team */
.team-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-6); }
.team-card {
  background: var(--color-surface);
  border: 1px solid var(--color-divider);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: box-shadow var(--ease);
}
.team-card:hover { box-shadow: var(--shadow-md); }
.team-card__body { padding: var(--space-6); }
.team-card__body h3 {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  margin-bottom: var(--space-1);
}
.team-role { font-size: var(--text-xs); font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: var(--color-accent); margin-bottom: var(--space-3); }
.team-card__body p { font-size: var(--text-sm); color: var(--color-text-muted); line-height: 1.65; }

/* ===== SERVICES PAGE ===== */
.service-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-16);
  align-items: center;
  padding-block: var(--space-12);
}
.service-row--reverse { direction: rtl; }
.service-row--reverse > * { direction: ltr; }
.service-row__media { border-radius: var(--radius-xl); overflow: hidden; }
.service-row__media img { width: 100%; height: 360px; object-fit: cover; border-radius: var(--radius-xl); }
.service-row__body { display: flex; flex-direction: column; gap: var(--space-5); }
.service-tag {
  display: inline-block;
  background: var(--color-primary-xl);
  color: var(--color-primary);
  font-size: var(--text-xs);
  font-weight: 600;
  padding: 0.3em 0.8em;
  border-radius: var(--radius-full);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  border: 1px solid var(--color-primary-light);
  align-self: flex-start;
}
.service-row__title {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}
.service-row__body p { font-size: var(--text-base); color: var(--color-text-muted); line-height: 1.75; }
.service-list { list-style: none; display: flex; flex-direction: column; gap: var(--space-2); }
.service-list li {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  padding-left: var(--space-6);
  position: relative;
}
.service-list li::before {
  content: '✓';
  position: absolute; left: 0;
  color: var(--color-primary);
  font-weight: 700;
}
.service-divider { border: none; border-top: 1px solid var(--color-divider); }

/* Additional services */
.additional-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-4);
}
.add-svc {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  background: var(--color-surface);
  border: 1px solid var(--color-divider);
  border-radius: var(--radius-lg);
  padding: var(--space-5) var(--space-6);
  font-size: var(--text-sm);
  font-weight: 500;
  transition: border-color var(--ease), box-shadow var(--ease);
}
.add-svc svg { color: var(--color-primary); flex-shrink: 0; }
.add-svc:hover { border-color: var(--color-primary); box-shadow: var(--shadow-sm); }

/* ===== PROJECTS PAGE ===== */
.video-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-8); }
.project-video { display: flex; flex-direction: column; gap: var(--space-3); }
.project-video iframe { width: 100%; aspect-ratio: 16/9; border-radius: var(--radius-lg); border: none; }
.project-video__caption { font-size: var(--text-sm); font-weight: 600; color: var(--color-text-muted); font-family: var(--font-display); text-transform: uppercase; letter-spacing: 0.04em; }

.gallery-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-4);
  grid-auto-rows: 220px;
}
.gallery-item { overflow: hidden; border-radius: var(--radius-lg); }
.gallery-item img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s ease; border-radius: var(--radius-lg); }
.gallery-item:hover img { transform: scale(1.04); }
.gallery-item--wide { grid-column: span 2; }

/* ===== SERVICE AREA PAGE ===== */
.area-layout { display: grid; grid-template-columns: 1.2fr 1fr; gap: var(--space-16); align-items: start; }
.county-section { margin-bottom: var(--space-6); }
.county-title {
  font-family: var(--font-display);
  font-size: var(--text-sm);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--color-primary);
  margin-bottom: var(--space-3);
  padding-bottom: var(--space-2);
  border-bottom: 1px solid var(--color-primary-light);
}
.city-tags { display: flex; flex-wrap: wrap; gap: var(--space-2); }
.city-tag {
  background: var(--color-primary-xl);
  color: var(--color-primary);
  border: 1px solid var(--color-primary-light);
  font-size: var(--text-xs);
  font-weight: 600;
  padding: 0.3em 0.8em;
  border-radius: var(--radius-full);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.area-note { font-size: var(--text-sm); color: var(--color-text-faint); font-style: italic; }
.map-embed {
  border-radius: var(--radius-xl);
  overflow: hidden;
  border: 1px solid var(--color-divider);
  margin-bottom: var(--space-6);
}
.map-embed iframe { width: 100%; aspect-ratio: 1; border: none; display: block; }
.map-embed__placeholder {
  aspect-ratio: 1;
  background: var(--color-surface);
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: var(--space-4);
  text-align: center;
  padding: var(--space-8);
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}
.map-embed__placeholder p { font-family: var(--font-display); font-size: var(--text-lg); font-weight: 600; text-transform: uppercase; letter-spacing: 0.04em; }
.map-embed__placeholder span { font-size: var(--text-xs); color: var(--color-text-faint); max-width: 24ch; }

.area-stats { display: grid; grid-template-columns: repeat(3,1fr); gap: var(--space-4); }
.area-stat {
  background: var(--color-surface);
  border: 1px solid var(--color-divider);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  text-align: center;
  display: flex; flex-direction: column; gap: var(--space-1);
}
.area-stat__num { font-family: var(--font-display); font-size: var(--text-2xl); font-weight: 700; color: var(--color-primary); line-height: 1; }
.area-stat__label { font-size: var(--text-xs); font-weight: 600; text-transform: uppercase; letter-spacing: 0.08em; color: var(--color-text-muted); }

/* ===== CONTACT PAGE ===== */
.contact-layout { display: grid; grid-template-columns: 1fr 1.2fr; gap: var(--space-16); align-items: start; }
.contact-info__title {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  margin-bottom: var(--space-4);
}
.contact-info__desc { font-size: var(--text-base); color: var(--color-text-muted); line-height: 1.7; margin-bottom: var(--space-8); }
.contact-cards { display: flex; flex-direction: column; gap: var(--space-4); margin-bottom: var(--space-10); }
.contact-card {
  display: flex;
  align-items: flex-start;
  gap: var(--space-5);
  background: var(--color-surface);
  border: 1px solid var(--color-divider);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  transition: border-color var(--ease), box-shadow var(--ease);
}
a.contact-card:hover { border-color: var(--color-primary); box-shadow: var(--shadow-sm); }
.contact-card__icon {
  width: 46px; height: 46px; flex-shrink: 0;
  background: var(--color-primary-xl);
  border-radius: var(--radius-md);
  display: flex; align-items: center; justify-content: center;
  color: var(--color-primary);
}
.contact-card__label { font-size: var(--text-xs); font-weight: 600; text-transform: uppercase; letter-spacing: 0.08em; color: var(--color-text-muted); margin-bottom: var(--space-1); }
.contact-card__value { font-family: var(--font-display); font-size: var(--text-lg); font-weight: 600; color: var(--color-text); }
.contact-card__sub { font-size: var(--text-xs); color: var(--color-text-faint); margin-top: var(--space-1); }

/* Redes en contacto */
.contact-socials__label { font-size: var(--text-xs); font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em; color: var(--color-text-muted); margin-bottom: var(--space-4); }
.contact-socials__links { display: flex; flex-wrap: wrap; gap: var(--space-3); }
.contact-social-btn {
  display: flex; align-items: center; gap: var(--space-2);
  background: var(--color-surface);
  border: 1px solid var(--color-divider);
  border-radius: var(--radius-md);
  padding: var(--space-3) var(--space-4);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-text-muted);
  transition: border-color var(--ease), color var(--ease), background var(--ease);
}
.contact-social-btn:hover { border-color: var(--color-primary); color: var(--color-primary); background: var(--color-primary-xl); }

/* Formulario */
.quote-form-wrap {
  background: var(--color-surface);
  border: 1px solid var(--color-divider);
  border-radius: var(--radius-xl);
  padding: clamp(var(--space-8), 4vw, var(--space-12));
  box-shadow: var(--shadow-md);
}
.quote-form { display: flex; flex-direction: column; gap: var(--space-5); }
.quote-form__title {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-bottom: var(--space-1);
}
.quote-form__sub { font-size: var(--text-sm); color: var(--color-text-muted); margin-bottom: var(--space-4); }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-4); }
.form-group { display: flex; flex-direction: column; gap: var(--space-2); }
.form-group label { font-size: var(--text-xs); font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: var(--color-text-muted); }
.form-group label span { color: var(--color-accent); }
.form-group input,
.form-group select,
.form-group textarea {
  padding: 0.75em 1em;
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-bg);
  font-size: var(--text-sm);
  color: var(--color-text);
  width: 100%;
  transition: border-color var(--ease), box-shadow var(--ease);
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px var(--color-primary-xl);
}
.form-group textarea { resize: vertical; min-height: 100px; }
.btn--submit { width: 100%; justify-content: center; padding: 1em; font-size: var(--text-base); }
.form-note { font-size: var(--text-xs); color: var(--color-text-faint); text-align: center; }

/* CTA BAND (compartido en todas las páginas) */
.cta-band { background: var(--color-primary); padding-block: clamp(var(--space-12), 6vw, var(--space-20)); }
.cta-band__inner { display: flex; align-items: center; justify-content: space-between; gap: var(--space-8); flex-wrap: wrap; }
.cta-band__title { font-family: var(--font-display); font-size: var(--text-xl); font-weight: 700; color: #fff; text-transform: uppercase; letter-spacing: 0.03em; }
.cta-band__sub { font-size: var(--text-sm); color: rgba(255,255,255,0.75); margin-top: var(--space-2); }
.cta-band__actions { display: flex; gap: var(--space-4); flex-wrap: wrap; }

/* ===== RESPONSIVE ===== */
@media (max-width: 1024px) {
  .about-layout { grid-template-columns: 1fr; }
  .mvv-grid { grid-template-columns: 1fr 1fr; }
  .team-grid { grid-template-columns: 1fr 1fr; }
  .service-row { grid-template-columns: 1fr; gap: var(--space-8); }
  .service-row--reverse { direction: ltr; }
  .additional-grid { grid-template-columns: 1fr 1fr; }
  .gallery-grid { grid-template-columns: 1fr 1fr; }
  .gallery-item--wide { grid-column: span 2; }
  .area-layout { grid-template-columns: 1fr; gap: var(--space-10); }
  .contact-layout { grid-template-columns: 1fr; gap: var(--space-10); }
  .video-grid { grid-template-columns: 1fr; }
}
@media (max-width: 768px) {
  .mvv-grid { grid-template-columns: 1fr; }
  .team-grid { grid-template-columns: 1fr; }
  .additional-grid { grid-template-columns: 1fr; }
  .gallery-grid { grid-template-columns: 1fr; grid-auto-rows: auto; }
  .gallery-item--wide { grid-column: span 1; }
  .form-row { grid-template-columns: 1fr; }
  .area-stats { grid-template-columns: repeat(3, 1fr); }
  .cta-band__inner { flex-direction: column; text-align: center; }
  .cta-band__actions { justify-content: center; }
}

/* ===== PROJECT TYPES GRID ===== */
.project-types-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-6);
  margin-top: var(--space-10);
}
.ptype-card {
  background: var(--color-surface);
  border: 1px solid var(--color-divider);
  border-radius: var(--radius-xl);
  overflow: hidden;
  transition: box-shadow var(--ease), transform var(--ease);
}
.ptype-card:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); }
.ptype-card__media {
  width: 100%;
  height: 200px;
  overflow: hidden;
  background: var(--color-primary-xl);
  display: flex; align-items: center; justify-content: center;
}
.ptype-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s ease; }
.ptype-card:hover .ptype-card__media img { transform: scale(1.05); }
.ptype-card__media-ph {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: var(--space-2); text-align: center; padding: var(--space-6);
  color: var(--color-primary); font-size: var(--text-sm);
}
.ptype-card__body { padding: var(--space-6); display: flex; flex-direction: column; gap: var(--space-3); }
.ptype-card__body h3 {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}
.ptype-card__body p { font-size: var(--text-sm); color: var(--color-text-muted); line-height: 1.7; }
.ptype-card__list { list-style: none; display: flex; flex-direction: column; gap: var(--space-1); }
.ptype-card__list li {
  font-size: var(--text-sm); color: var(--color-text-muted);
  padding-left: var(--space-5); position: relative;
}
.ptype-card__list li::before { content: '✓'; position: absolute; left: 0; color: var(--color-primary); font-weight: 700; }

/* ===== SERVICE TAG VARIANTS ===== */
.svc-tag--urgent {
  display: inline-block;
  background: rgba(232,113,10,0.12);
  color: var(--color-accent);
  font-size: var(--text-xs);
  font-weight: 700;
  padding: 0.3em 0.8em;
  border-radius: var(--radius-full);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  border: 1px solid rgba(232,113,10,0.3);
  align-self: flex-start;
}

/* ===== COMPLIANCE BOX ===== */
.compliance-box {
  display: flex;
  align-items: flex-start;
  gap: var(--space-4);
  background: var(--color-primary-xl);
  border: 1px solid var(--color-primary-light);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
}
.compliance-box__icon {
  width: 44px; height: 44px; flex-shrink: 0;
  background: var(--color-primary);
  color: #fff;
  border-radius: var(--radius-md);
  display: flex; align-items: center; justify-content: center;
}
.compliance-box__h {
  font-family: var(--font-display);
  font-size: var(--text-base);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  margin-bottom: var(--space-1);
}
.compliance-box__p { font-size: var(--text-sm); color: var(--color-text-muted); line-height: 1.65; }

/* ===== SVC AREAS LABEL ===== */
.svc-areas {
  font-size: var(--text-xs);
  color: var(--color-text-faint);
  font-style: italic;
  margin-top: var(--space-2);
}

/* ===== SERVICE AREA PAGE — EXTRA ===== */
.area-intro { font-size: var(--text-base); color: var(--color-text-muted); line-height: 1.75; }
.area-intro strong { color: var(--color-primary); font-weight: 600; }

.area-contact-card {
  background: var(--color-surface);
  border: 1px solid var(--color-divider);
  border-radius: var(--radius-xl);
  padding: var(--space-8);
  margin-top: var(--space-6);
  display: flex; flex-direction: column; gap: var(--space-4);
}
.area-contact-card__h {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}
.area-contact-card__p { font-size: var(--text-sm); color: var(--color-text-muted); line-height: 1.65; }
.area-contact-card__actions { display: flex; gap: var(--space-3); flex-wrap: wrap; }

/* Area reasons grid */
.area-reasons-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
}
.area-reason {
  background: var(--color-bg);
  border: 1px solid var(--color-divider);
  border-radius: var(--radius-xl);
  padding: var(--space-8);
  display: flex; flex-direction: column; gap: var(--space-3);
  transition: box-shadow var(--ease);
}
.area-reason:hover { box-shadow: var(--shadow-md); }
.area-reason__icon {
  width: 52px; height: 52px;
  background: var(--color-primary-xl);
  border-radius: var(--radius-md);
  display: flex; align-items: center; justify-content: center;
  color: var(--color-primary);
}
.area-reason__h {
  font-family: var(--font-display);
  font-size: var(--text-base);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}
.area-reason__p { font-size: var(--text-sm); color: var(--color-text-muted); line-height: 1.65; }

/* Responsive additions */
@media (max-width: 1024px) {
  .project-types-grid { grid-template-columns: 1fr 1fr; }
  .area-reasons-grid { grid-template-columns: 1fr; gap: var(--space-4); }
}

/* Teléfonos medianos — ajuste de cards de páginas internas */
@media (max-width: 768px) {
  .project-types-grid { grid-template-columns: 1fr; }
  .area-reasons-grid { grid-template-columns: 1fr; }
  .area-contact-card__actions { flex-direction: column; }
  /* Stats: 3 col → 1 fila pero comprimido a 2 */
  .area-stats { grid-template-columns: repeat(3, 1fr); gap: var(--space-2); }
  .area-stat { padding: var(--space-4); }
  .area-stat__num { font-size: var(--text-xl); }
  /* Cards internas: reducir padding */
  .mvv-card { padding: var(--space-6); }
  .why-card { padding: var(--space-6); }
  .service-row { padding-block: var(--space-8); }
  .service-row__media img { height: 260px; }
}

/* Teléfonos medianos (480px) */
@media (max-width: 480px) {
  /* Area stats: apilar a 1 col */
  .area-stats { grid-template-columns: 1fr; gap: var(--space-3); }
  .area-stat { flex-direction: row; align-items: center; justify-content: flex-start; gap: var(--space-4); text-align: left; padding: var(--space-4) var(--space-5); }
  .area-stat__num { font-size: var(--text-xl); }
  /* Additional services: 2 col → 1 col */
  .additional-grid { grid-template-columns: 1fr; }
  /* Gallery: single col with auto row height */
  .gallery-grid { grid-auto-rows: 200px; }
  /* Contact form */
  .quote-form-wrap { padding: var(--space-6); }
  /* CTA band buttons full-width */
  .cta-band__actions .btn { width: 100%; justify-content: center; }
  /* Service row media */
  .service-row__media img { height: 220px; }
  /* Page hero tighter */
  .page-hero { padding-block: var(--space-10); }
  /* MVV cards */
  .mvv-card { padding: var(--space-5); }
  /* Area contact */
  .area-contact-card { padding: var(--space-6); }
  .area-reason { padding: var(--space-6); }
  /* Compliance box */
  .compliance-box { flex-direction: column; gap: var(--space-3); }
}

/* Teléfonos pequeños (360px) */
@media (max-width: 360px) {
  .service-row__media img { height: 200px; }
  .ptype-card__media { height: 160px; }
  .video-grid { grid-template-columns: 1fr; }
  .contact-layout { gap: var(--space-8); }
  .page-hero { padding-block: var(--space-8); }
  .section-header { margin-bottom: var(--space-8); }
  /* Reducir padding de botones largos para evitar overflow */
  .btn { padding-inline: 1em; font-size: 0.78rem; letter-spacing: 0.03em; }
}
