/* TentuDepto Theme — Main Stylesheet */
:root {
    --teal: #4ec3c4;
    --teal-dark: #35a8a9;
    --teal-glow: rgba(78,195,196,0.18);
    --teal-mid: rgba(78,195,196,0.08);
    --black: #0a0a0a;
    --dark: #111213;
    --card: #161819;
    --card2: #1c1e1f;
    --border: rgba(78,195,196,0.15);
    --border-subtle: rgba(255,255,255,0.06);
    --white: #f5f5f3;
    --muted: #8a8f94;
    --font-display: 'Bebas Neue', sans-serif;
    --font-head: 'Syne', sans-serif;
    --font-body: 'DM Sans', sans-serif;
}

:root {
    --teal: #4ec3c4;
    --teal-dark: #35a8a9;
    --teal-glow: rgba(78,195,196,0.18);
    --teal-mid: rgba(78,195,196,0.08);
    --black: #0a0a0a;
    --dark: #111213;
    --card: #161819;
    --card2: #1c1e1f;
    --border: rgba(78,195,196,0.15);
    --border-subtle: rgba(255,255,255,0.06);
    --white: #f5f5f3;
    --muted: #8a8f94;
    --font-display: 'Bebas Neue', sans-serif;
    --font-head: 'Syne', sans-serif;
    --font-body: 'DM Sans', sans-serif;
  }

  *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
  
  html { scroll-behavior: smooth; }
  
  body {
    background: var(--black);
    color: var(--white);
    font-family: var(--font-body);
    font-size: 16px;
    line-height: 1.6;
    overflow-x: hidden;
  }

  /* ─── PAGES ─── */
  .page { display: none; }
  .page.active { display: block; }

  /* ─── NAV ─── */
  nav {
    position: fixed;
    top: 0; left: 0; right: 0;
    z-index: 100;
    padding: 0 48px;
    height: 72px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: rgba(10,10,10,0.92);
    backdrop-filter: blur(20px);
    border-bottom: 1px solid var(--border-subtle);
  }

  .nav-logo {
    font-family: var(--font-display);
    font-size: 26px;
    letter-spacing: 0.05em;
    color: var(--white);
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 8px;
  }

  .nav-logo span {
    color: var(--teal);
  }

  .nav-links {
    display: flex;
    align-items: center;
    gap: 36px;
    list-style: none;
  }

  .nav-links a {
    color: var(--muted);
    text-decoration: none;
    font-family: var(--font-head);
    font-size: 13px;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    transition: color 0.2s;
    cursor: pointer;
  }

  .nav-links a:hover,
  .nav-links a.active { color: var(--white); }

  .nav-cta {
    background: var(--teal);
    color: var(--black) !important;
    padding: 10px 22px;
    border-radius: 4px;
    font-weight: 700 !important;
    transition: background 0.2s, transform 0.15s !important;
  }

  .nav-cta:hover {
    background: #5dd4d5 !important;
    transform: translateY(-1px);
  }

  /* ─── HERO ─── */
  .hero {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    justify-content: center;
    position: relative;
    overflow: hidden;
    padding: 0;
  }

  .hero-bg {
    position: absolute;
    inset: 0;
    background-color: #0d1415;
    overflow: hidden;
    --hero-bg-image: url('https://images.unsplash.com/photo-1506905925346-21bda4d32df4?w=1920&q=80');
    --hero-bg-opacity: 1;
  }

  .hero-bg::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image: var(--hero-bg-image);
    background-size: cover;
    background-position: center 40%;
    background-repeat: no-repeat;
    opacity: var(--hero-bg-opacity);
  }

  .hero-bg::after {
    content: '';
    position: absolute;
    inset: 0;
    background: 
      linear-gradient(105deg, rgba(10,10,10,0.96) 0%, rgba(10,10,10,0.82) 55%, rgba(10,10,10,0.6) 100%),
      linear-gradient(180deg, rgba(10,10,10,0.2) 0%, rgba(10,10,10,0.9) 100%);
  }

  .hero-grid-lines {
    position: absolute;
    inset: 0;
    background-image: 
      linear-gradient(rgba(78,195,196,0.05) 1px, transparent 1px),
      linear-gradient(90deg, rgba(78,195,196,0.05) 1px, transparent 1px);
    background-size: 80px 80px;
    mask-image: radial-gradient(ellipse 70% 80% at 30% 50%, black 20%, transparent 100%);
  }

  /* ─── FLIP CARDS ─── */
  .flip-section {
    background: var(--dark);
    border-top: 1px solid var(--border-subtle);
    border-bottom: 1px solid var(--border-subtle);
    overflow: hidden;
  }

  .flip-section-header {
    max-width: 1200px;
    margin: 0 auto 56px;
  }

  .flip-cards-grid {
    max-width: 1200px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
  }

  .flip-card-wrap {
    perspective: 1000px;
    height: 260px;
    cursor: pointer;
  }

  .flip-card-inner {
    position: relative;
    width: 100%;
    height: 100%;
    transform-style: preserve-3d;
    transition: transform 0.65s cubic-bezier(0.4, 0.2, 0.2, 1);
  }

  .flip-card-wrap:hover .flip-card-inner {
    transform: rotateY(180deg);
  }

  .flip-front,
  .flip-back {
    position: absolute;
    inset: 0;
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
    border-radius: 8px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    padding: 32px 28px;
    background: var(--teal);
    overflow: hidden;
  }

  .flip-front::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(255,255,255,0.08) 0%, transparent 60%);
    pointer-events: none;
  }

  .flip-back {
    transform: rotateY(180deg);
    background: linear-gradient(135deg, #3aafb0, #2d9899);
    border: 1px solid rgba(255,255,255,0.15);
  }

  .flip-front-title {
    font-family: var(--font-display);
    font-size: 42px;
    line-height: 1;
    letter-spacing: 0.02em;
    color: white;
  }

  .flip-front-tag {
    font-family: var(--font-head);
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: rgba(255,255,255,0.5);
  }

  .flip-back-text {
    font-size: 15px;
    color: white;
    line-height: 1.7;
    font-family: var(--font-body);
    font-weight: 300;
    flex: 1;
    display: flex;
    align-items: center;
  }

  .flip-back-footer {
    font-family: var(--font-head);
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: rgba(255,255,255,0.5);
  }

  /* ─── GOOGLE REVIEWS ─── */
  .reviews-section {
    background: var(--black);
    border-top: 1px solid var(--border-subtle);
  }

  .reviews-header {
    max-width: 1200px;
    margin: 0 auto 56px;
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
  }

  .google-badge {
    display: flex;
    align-items: center;
    gap: 10px;
    background: var(--card);
    border: 1px solid var(--border-subtle);
    border-radius: 8px;
    padding: 12px 20px;
  }

  .google-badge-score {
    font-family: var(--font-display);
    font-size: 32px;
    color: var(--white);
    line-height: 1;
  }

  .google-badge-right {
    display: flex;
    flex-direction: column;
    gap: 2px;
  }

  .google-stars {
    color: #FBBC04;
    font-size: 14px;
    letter-spacing: 2px;
  }

  .google-label {
    font-size: 11px;
    color: var(--muted);
    font-family: var(--font-head);
    font-weight: 600;
    letter-spacing: 0.08em;
  }

  .reviews-grid {
    max-width: 1200px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
  }

  .review-card {
    background: var(--card);
    border: 1px solid var(--border-subtle);
    border-radius: 8px;
    padding: 28px;
    position: relative;
    transition: border-color 0.2s, transform 0.2s;
  }

  .review-card:hover {
    border-color: var(--border);
    transform: translateY(-3px);
  }

  .review-header {
    display: flex;
    align-items: center;
    gap: 14px;
    margin-bottom: 16px;
  }

  .review-avatar {
    width: 44px; height: 44px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-head);
    font-size: 16px;
    font-weight: 700;
    color: white;
    flex-shrink: 0;
  }

  .review-info {
    flex: 1;
  }

  .review-name {
    font-family: var(--font-head);
    font-size: 14px;
    font-weight: 700;
    color: var(--white);
    margin-bottom: 2px;
  }

  .review-meta {
    font-size: 12px;
    color: var(--muted);
  }

  .review-google-icon {
    width: 20px; height: 20px;
    opacity: 0.6;
    font-size: 14px;
  }

  .review-stars-row {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 12px;
  }

  .review-stars-row .stars-gold {
    color: #FBBC04;
    font-size: 13px;
    letter-spacing: 1px;
  }

  .review-date {
    font-size: 11px;
    color: var(--muted);
  }

  .review-text {
    font-size: 14px;
    color: #c0c4c8;
    line-height: 1.7;
    font-style: italic;
  }

  .review-verified {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-top: 16px;
    padding-top: 14px;
    border-top: 1px solid var(--border-subtle);
    font-size: 11px;
    color: var(--muted);
    font-family: var(--font-head);
    font-weight: 600;
    letter-spacing: 0.06em;
  }

  .review-verified::before {
    content: '✓';
    color: #4ade80;
    font-size: 12px;
  }

  .hero-content {
    position: relative;
    z-index: 1;
    max-width: 800px;
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: calc(72px + 60px) 48px calc(100px + 60px);
  }

  .hero-badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: var(--teal-mid);
    border: 1px solid var(--border);
    border-radius: 100px;
    padding: 6px 16px;
    font-family: var(--font-head);
    font-size: 12px;
    font-weight: 600;
    color: var(--teal);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    margin-bottom: 32px;
    animation: fadeUp 0.6s ease both;
  }

  .hero-badge::before {
    content: '';
    width: 6px; height: 6px;
    border-radius: 50%;
    background: var(--teal);
    animation: pulse 2s ease infinite;
  }

  .hero-title {
    font-family: var(--font-display);
    font-size: clamp(50px, 6.3vw, 91px);
    line-height: 0.92;
    letter-spacing: 0.02em;
    color: var(--white);
    margin-bottom: 8px;
    animation: fadeUp 0.6s 0.1s ease both;
  }

  .hero-title .accent {
    color: var(--teal);
    display: block;
  }

  .hero-subtitle {
    font-family: var(--font-head);
    font-size: clamp(14px, 1.5vw, 17px);
    font-weight: 400;
    color: var(--muted);
    max-width: 520px;
    margin: 28px 0 48px;
    line-height: 1.7;
    animation: fadeUp 0.6s 0.2s ease both;
  }

  .hero-actions {
    display: flex;
    gap: 16px;
    flex-wrap: wrap;
    animation: fadeUp 0.6s 0.3s ease both;
  }

  .btn-primary {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: var(--teal);
    color: var(--black);
    padding: 16px 32px;
    border-radius: 4px;
    font-family: var(--font-head);
    font-size: 14px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    text-decoration: none;
    cursor: pointer;
    border: none;
    transition: background 0.2s, transform 0.15s, box-shadow 0.2s;
  }

  .btn-primary:hover {
    background: #5dd4d5;
    transform: translateY(-2px);
    box-shadow: 0 8px 32px rgba(78,195,196,0.3);
  }

  .btn-secondary {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: transparent;
    color: var(--white);
    padding: 16px 32px;
    border-radius: 4px;
    font-family: var(--font-head);
    font-size: 14px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    text-decoration: none;
    cursor: pointer;
    border: 1px solid var(--border-subtle);
    transition: border-color 0.2s, color 0.2s;
  }

  .btn-secondary:hover {
    border-color: var(--teal);
    color: var(--teal);
  }

  /* stats bar */
  .hero-stats {
    position: absolute;
    bottom: 0; left: 0; right: 0;
    border-top: 1px solid var(--border-subtle);
    background: rgba(10,10,10,0.7);
    backdrop-filter: blur(10px);
    display: flex;
    animation: fadeUp 0.6s 0.5s ease both;
  }

  .stat-item {
    flex: 1;
    padding: 28px 48px;
    border-right: 1px solid var(--border-subtle);
  }

  .stat-item:last-child { border-right: none; }

  .stat-num {
    font-family: var(--font-display);
    font-size: 42px;
    color: var(--teal);
    line-height: 1;
    letter-spacing: 0.02em;
  }

  .stat-label {
    font-size: 13px;
    color: var(--muted);
    font-weight: 300;
    margin-top: 4px;
  }

  /* ─── SECTION ─── */
  section {
    padding: 100px 48px;
  }

  .section-tag {
    font-family: var(--font-head);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--teal);
    margin-bottom: 16px;
  }

  .section-title {
    font-family: var(--font-display);
    font-size: clamp(44px, 5vw, 72px);
    line-height: 0.95;
    letter-spacing: 0.02em;
    margin-bottom: 20px;
  }

  .section-desc {
    font-size: 16px;
    color: var(--muted);
    max-width: 560px;
    line-height: 1.75;
  }

  /* ─── ABOUT ─── */
  .about-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 80px;
    align-items: center;
    max-width: 1200px;
    margin: 0 auto;
  }

  .about-visual {
    position: relative;
  }

  .about-card-main {
    background: var(--card);
    border: 1px solid var(--border-subtle);
    border-radius: 8px;
    padding: 40px;
    position: relative;
    overflow: hidden;
  }

  .about-card-main::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--teal), transparent);
  }

  .about-points {
    margin-top: 32px;
    display: flex;
    flex-direction: column;
    gap: 16px;
  }

  .about-point {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    font-size: 15px;
    color: #ccc;
    line-height: 1.5;
  }

  .about-point::before {
    content: '→';
    color: var(--teal);
    font-size: 14px;
    margin-top: 2px;
    flex-shrink: 0;
  }

  .highlight-box {
    background: var(--teal-mid);
    border: 1px solid var(--border);
    border-radius: 6px;
    padding: 20px 24px;
    margin-top: 24px;
    font-size: 14px;
    color: var(--teal);
    font-weight: 500;
    font-family: var(--font-head);
  }

  /* ─── PROCESS ─── */
  .process-section {
    background: var(--dark);
    border-top: 1px solid var(--border-subtle);
    border-bottom: 1px solid var(--border-subtle);
  }

  .process-header {
    max-width: 1200px;
    margin: 0 auto 64px;
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
  }

  .process-steps {
    max-width: 1200px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 0;
    position: relative;
  }

  .process-steps::before {
    content: '';
    position: absolute;
    top: 28px;
    left: 10%;
    right: 10%;
    height: 1px;
    background: linear-gradient(90deg, transparent, var(--border), var(--teal), var(--border), transparent);
  }

  .step {
    padding: 0 24px;
    text-align: center;
    position: relative;
  }

  .step-num {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background: var(--card2);
    border: 1px solid var(--border);
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 24px;
    font-family: var(--font-display);
    font-size: 22px;
    color: var(--teal);
    position: relative;
    z-index: 1;
    transition: background 0.2s, border-color 0.2s;
  }

  .step:hover .step-num {
    background: var(--teal-glow);
    border-color: var(--teal);
  }

  .step-title {
    font-family: var(--font-head);
    font-size: 13px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--white);
    margin-bottom: 10px;
  }

  .step-desc {
    font-size: 13px;
    color: var(--muted);
    line-height: 1.6;
  }

  /* ─── PROJECTS ─── */
  .projects-header {
    max-width: 1200px;
    margin: 0 auto 56px;
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
  }

  .projects-grid {
    max-width: 1200px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
  }

  .project-card {
    background: var(--card);
    border: 1px solid var(--border-subtle);
    border-radius: 8px;
    overflow: hidden;
    transition: border-color 0.25s, transform 0.25s;
    cursor: pointer;
  }

  .project-card:hover {
    border-color: var(--teal);
    transform: translateY(-4px);
  }

  .card-img {
    height: 200px;
    background: linear-gradient(135deg, #161819, #1e2326);
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    overflow: hidden;
  }

  .card-img-icon {
    font-size: 48px;
    opacity: 0.15;
  }

  .card-badge {
    position: absolute;
    top: 14px; left: 14px;
    background: var(--teal);
    color: var(--black);
    font-family: var(--font-head);
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    padding: 4px 10px;
    border-radius: 3px;
  }

  .card-badge.urgent {
    background: #ff6b35;
    color: white;
  }

  .card-commune {
    position: absolute;
    bottom: 14px; right: 14px;
    background: rgba(0,0,0,0.7);
    color: var(--muted);
    font-size: 11px;
    padding: 3px 8px;
    border-radius: 3px;
  }

  .card-body {
    padding: 24px;
  }

  .card-title {
    font-family: var(--font-head);
    font-size: 18px;
    font-weight: 700;
    color: var(--white);
    margin-bottom: 8px;
  }

  .card-type {
    font-size: 13px;
    color: var(--teal);
    font-weight: 500;
    margin-bottom: 16px;
  }

  .card-specs {
    display: flex;
    gap: 12px;
    margin-bottom: 20px;
    flex-wrap: wrap;
  }

  .spec-tag {
    font-size: 12px;
    background: rgba(255,255,255,0.05);
    border: 1px solid var(--border-subtle);
    color: var(--muted);
    padding: 4px 10px;
    border-radius: 3px;
    font-family: var(--font-head);
    font-weight: 600;
  }

  .card-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-top: 20px;
    border-top: 1px solid var(--border-subtle);
  }

  .card-price {
    font-family: var(--font-display);
    font-size: 28px;
    color: var(--white);
    letter-spacing: 0.02em;
  }

  .card-price span {
    font-size: 14px;
    color: var(--muted);
    font-family: var(--font-body);
    font-weight: 300;
  }

  .card-pie {
    font-size: 12px;
    color: var(--teal);
    font-family: var(--font-head);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
  }

  /* ─── TESTIMONIALS ─── */
  .testimonials-section {
    background: var(--dark);
    border-top: 1px solid var(--border-subtle);
  }

  .testimonials-grid {
    max-width: 1200px;
    margin: 56px auto 0;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
  }

  .testimonial-card {
    background: var(--card);
    border: 1px solid var(--border-subtle);
    border-radius: 8px;
    padding: 32px;
    position: relative;
    transition: border-color 0.2s;
  }

  .testimonial-card:hover {
    border-color: var(--border);
  }

  .testimonial-card::before {
    content: '"';
    position: absolute;
    top: 20px; right: 24px;
    font-family: var(--font-display);
    font-size: 72px;
    color: var(--teal);
    opacity: 0.15;
    line-height: 1;
  }

  .stars {
    color: var(--teal);
    font-size: 13px;
    margin-bottom: 16px;
    letter-spacing: 2px;
  }

  .testimonial-text {
    font-size: 14px;
    color: #bbb;
    line-height: 1.75;
    margin-bottom: 24px;
    font-style: italic;
  }

  .testimonial-author {
    font-family: var(--font-head);
    font-size: 13px;
    font-weight: 700;
    color: var(--white);
  }

  .testimonial-source {
    font-size: 12px;
    color: var(--muted);
    margin-top: 2px;
  }

  /* ─── FORM SECTION ─── */
  .form-section {
    background: linear-gradient(135deg, var(--dark) 0%, #0d1415 100%);
    border-top: 1px solid var(--border);
    position: relative;
    overflow: hidden;
  }

  .form-section::before {
    content: '';
    position: absolute;
    top: -200px; right: -200px;
    width: 600px; height: 600px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(78,195,196,0.06), transparent 70%);
    pointer-events: none;
  }

  .form-grid {
    max-width: 1100px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 80px;
    align-items: center;
  }

  .form-pitch .section-title {
    margin-bottom: 24px;
  }

  .form-perks {
    display: flex;
    flex-direction: column;
    gap: 14px;
    margin-top: 32px;
  }

  .perk {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 14px;
    color: #ccc;
  }

  .perk-dot {
    width: 8px; height: 8px;
    border-radius: 50%;
    background: var(--teal);
    flex-shrink: 0;
  }

  .form-card {
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: 10px;
    padding: 40px;
    position: relative;
  }

  .form-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--teal), #35a8a9);
    border-radius: 10px 10px 0 0;
  }

  .form-title {
    font-family: var(--font-head);
    font-size: 20px;
    font-weight: 700;
    margin-bottom: 28px;
  }

  .form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
  }

  .field {
    margin-bottom: 16px;
  }

  .field label {
    display: block;
    font-size: 12px;
    font-family: var(--font-head);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--muted);
    margin-bottom: 8px;
  }

  .field input,
  .field select {
    width: 100%;
    background: rgba(255,255,255,0.04);
    border: 1px solid var(--border-subtle);
    border-radius: 5px;
    padding: 12px 16px;
    font-size: 14px;
    color: var(--white);
    font-family: var(--font-body);
    transition: border-color 0.2s;
    outline: none;
    -webkit-appearance: none;
  }

  .field input:focus,
  .field select:focus {
    border-color: var(--teal);
  }

  .field select option {
    background: var(--card);
    color: var(--white);
  }

  .form-submit {
    width: 100%;
    background: var(--teal);
    color: var(--black);
    border: none;
    border-radius: 5px;
    padding: 16px;
    font-family: var(--font-head);
    font-size: 14px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    cursor: pointer;
    margin-top: 8px;
    transition: background 0.2s, transform 0.15s, box-shadow 0.2s;
  }

  .form-submit:hover {
    background: #5dd4d5;
    transform: translateY(-1px);
    box-shadow: 0 6px 24px rgba(78,195,196,0.35);
  }

  .form-note {
    text-align: center;
    font-size: 12px;
    color: var(--muted);
    margin-top: 14px;
  }

  /* ─── FOOTER ─── */
  footer {
    background: var(--black);
    border-top: 1px solid var(--border-subtle);
    padding: 64px 48px 40px;
  }

  .footer-grid {
    max-width: 1200px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 2fr 1fr 1fr 1fr;
    gap: 48px;
    margin-bottom: 48px;
  }

  .footer-brand .nav-logo {
    font-size: 22px;
    margin-bottom: 16px;
    display: block;
  }

  .footer-desc {
    font-size: 14px;
    color: var(--muted);
    line-height: 1.7;
    max-width: 280px;
    margin-bottom: 24px;
  }

  .social-links {
    display: flex;
    gap: 12px;
  }

  .social-link {
    width: 36px; height: 36px;
    border-radius: 5px;
    background: var(--card);
    border: 1px solid var(--border-subtle);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    color: var(--muted);
    text-decoration: none;
    transition: border-color 0.2s, color 0.2s;
    cursor: pointer;
  }

  .social-link:hover { border-color: var(--teal); color: var(--teal); }

  .footer-col-title {
    font-family: var(--font-head);
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--white);
    margin-bottom: 20px;
  }

  .footer-links {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 10px;
  }

  .footer-links a {
    font-size: 14px;
    color: var(--muted);
    text-decoration: none;
    cursor: pointer;
    transition: color 0.2s;
  }

  .footer-links a:hover { color: var(--teal); }

  .footer-bottom {
    max-width: 1200px;
    margin: 0 auto;
    padding-top: 24px;
    border-top: 1px solid var(--border-subtle);
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 13px;
    color: var(--muted);
  }

  /* ─── WHATSAPP FLOAT ─── */
  .wa-float {
    position: fixed;
    bottom: 28px; right: 28px;
    z-index: 200;
    width: 58px; height: 58px;
    border-radius: 50%;
    background: #25D366;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 26px;
    box-shadow: 0 4px 20px rgba(37,211,102,0.4);
    cursor: pointer;
    transition: transform 0.2s, box-shadow 0.2s;
    text-decoration: none;
    color: white;
  }

  .wa-float:hover {
    transform: scale(1.08);
    box-shadow: 0 6px 28px rgba(37,211,102,0.55);
  }

  /* ─── PAGE HEADER ─── */
  .page-header {
    padding: 140px 48px 80px;
    background: linear-gradient(180deg, #0d1213 0%, var(--black) 100%);
    border-bottom: 1px solid var(--border-subtle);
    position: relative;
    overflow: hidden;
  }

  .page-header::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image: linear-gradient(rgba(78,195,196,0.03) 1px, transparent 1px),
      linear-gradient(90deg, rgba(78,195,196,0.03) 1px, transparent 1px);
    background-size: 60px 60px;
  }

  .page-header-inner {
    position: relative;
    z-index: 1;
    max-width: 1200px;
    margin: 0 auto;
  }

  .page-title {
    font-family: var(--font-display);
    font-size: clamp(56px, 7vw, 96px);
    line-height: 0.95;
    margin-bottom: 16px;
  }

  .page-subtitle {
    font-size: 16px;
    color: var(--muted);
    max-width: 540px;
    line-height: 1.7;
  }

  /* ─── FILTERS ─── */
  .filters-bar {
    padding: 32px 48px;
    background: var(--dark);
    border-bottom: 1px solid var(--border-subtle);
    position: sticky;
    top: 72px;
    z-index: 50;
  }

  .filters-inner {
    max-width: 1200px;
    margin: 0 auto;
    display: flex;
    gap: 12px;
    align-items: center;
    flex-wrap: wrap;
  }

  .filter-label {
    font-family: var(--font-head);
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--muted);
    margin-right: 4px;
  }

  .filter-btn {
    padding: 8px 18px;
    border-radius: 100px;
    border: 1px solid var(--border-subtle);
    background: transparent;
    color: var(--muted);
    font-family: var(--font-head);
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    cursor: pointer;
    transition: all 0.2s;
  }

  .filter-btn:hover,
  .filter-btn.active {
    background: var(--teal-mid);
    border-color: var(--teal);
    color: var(--teal);
  }

  /* ─── COMMUNE GROUP ─── */
  .commune-group {
    max-width: 1200px;
    margin: 0 auto 72px;
  }

  .commune-title {
    font-family: var(--font-display);
    font-size: 42px;
    letter-spacing: 0.02em;
    padding-bottom: 16px;
    margin-bottom: 32px;
    border-bottom: 1px solid var(--border-subtle);
    display: flex;
    align-items: center;
    gap: 16px;
  }

  .commune-count {
    font-family: var(--font-head);
    font-size: 13px;
    font-weight: 600;
    color: var(--teal);
    background: var(--teal-mid);
    border: 1px solid var(--border);
    padding: 4px 12px;
    border-radius: 100px;
  }

  /* ─── TIPS PAGE ─── */
  .tips-grid {
    max-width: 1200px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 28px;
  }

  .tip-card {
    background: var(--card);
    border: 1px solid var(--border-subtle);
    border-radius: 8px;
    overflow: hidden;
    transition: border-color 0.25s, transform 0.25s;
    cursor: pointer;
  }

  .tip-card:hover {
    border-color: var(--teal);
    transform: translateY(-4px);
  }

  .tip-img {
    height: 200px;
    background: linear-gradient(135deg, #161819 0%, #1a2025 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 52px;
    position: relative;
  }

  .tip-category {
    position: absolute;
    top: 14px; left: 14px;
    background: var(--teal-mid);
    border: 1px solid var(--border);
    color: var(--teal);
    font-family: var(--font-head);
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    padding: 4px 10px;
    border-radius: 3px;
  }

  .tip-body {
    padding: 28px;
  }

  .tip-date {
    font-size: 12px;
    color: var(--muted);
    font-family: var(--font-head);
    margin-bottom: 10px;
  }

  .tip-title {
    font-family: var(--font-head);
    font-size: 17px;
    font-weight: 700;
    line-height: 1.4;
    margin-bottom: 12px;
    color: var(--white);
  }

  .tip-excerpt {
    font-size: 14px;
    color: var(--muted);
    line-height: 1.65;
    margin-bottom: 20px;
  }

  .tip-link {
    font-family: var(--font-head);
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--teal);
    text-decoration: none;
    display: flex;
    align-items: center;
    gap: 6px;
    cursor: pointer;
  }

  .tip-link::after {
    content: '→';
    transition: transform 0.2s;
  }

  .tip-card:hover .tip-link::after {
    transform: translateX(4px);
  }

  /* ─── ANIMATIONS ─── */
  @keyframes fadeUp {
    from { opacity: 0; transform: translateY(24px); }
    to { opacity: 1; transform: translateY(0); }
  }

  @keyframes pulse {
    0%, 100% { opacity: 1; transform: scale(1); }
    50% { opacity: 0.5; transform: scale(0.85); }
  }

  /* ─── MOBILE NAV ─── */
  .hamburger {
    display: none;
    flex-direction: column;
    gap: 5px;
    cursor: pointer;
    padding: 8px;
  }

  .hamburger span {
    width: 22px; height: 2px;
    background: var(--white);
    border-radius: 2px;
    transition: all 0.2s;
  }

  @media (max-width: 900px) {
    nav { padding: 0 24px; }
    section { padding: 64px 24px; }
    .hero { padding: 100px 24px 80px; }
    .hero-title { font-size: 45px; }
    .about-grid { grid-template-columns: 1fr; gap: 40px; }
    .process-steps { grid-template-columns: 1fr; }
    .process-steps::before { display: none; }
    .projects-grid { grid-template-columns: 1fr; }
    .form-grid { grid-template-columns: 1fr; gap: 40px; }
    .hero-stats { position: relative; }
    .stat-item { padding: 20px 24px; }
    .testimonials-grid { grid-template-columns: 1fr; }
    .footer-grid { grid-template-columns: 1fr 1fr; }
    .tips-grid { grid-template-columns: 1fr; }
    .page-header { padding: 100px 24px 60px; }
    .filters-bar { padding: 20px 24px; }
    .nav-links { display: none; }
    .hamburger { display: flex; }
    .form-row { grid-template-columns: 1fr; }
    .flip-cards-grid { grid-template-columns: 1fr 1fr; }
    .reviews-grid { grid-template-columns: 1fr; }
    .reviews-header { flex-direction: column; gap: 24px; align-items: flex-start; }
  }

.about-video-box {
          position: relative;
          width: 100%;
          aspect-ratio: 16 / 10;
          background: var(--card2);
          overflow: hidden;
        }

        .about-video-box video {
          position: relative;
          z-index: 1;
        }

        /* Placeholder — se oculta cuando el video carga */
        .about-video-placeholder {
          position: absolute;
          inset: 0;
          z-index: 0;
          display: flex;
          flex-direction: column;
          align-items: center;
          justify-content: center;
          gap: 8px;
          background: linear-gradient(135deg, #161819, #1c2224);
          border-bottom: 1px solid var(--border-subtle);
        }

        .video-placeholder-icon {
          width: 56px; height: 56px;
          border-radius: 50%;
          background: var(--teal-mid);
          border: 2px solid var(--border);
          display: flex;
          align-items: center;
          justify-content: center;
          font-size: 20px;
          color: var(--teal);
          margin-bottom: 8px;
        }

        .video-placeholder-text {
          font-family: var(--font-head);
          font-size: 14px;
          font-weight: 700;
          color: var(--white);
          letter-spacing: 0.05em;
        }

        .video-placeholder-sub {
          font-size: 11px;
          color: var(--muted);
          font-family: var(--font-body);
        }

        /* Cuando el video carga exitosamente, oculta el placeholder */
        .about-video-box video:not([src=""]) + .about-video-placeholder {
          display: none;
        }

/* ─── FORM VIDEO INNER LAYOUT ─── */
    .form-video-inner {
      position: relative;
      z-index: 1;
      max-width: 1100px;
      margin: 0 auto;
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 80px;
      align-items: center;
    }

    /* spinner */
    .spinner {
      display: inline-block;
      width: 14px; height: 14px;
      border: 2px solid rgba(0,0,0,0.3);
      border-top-color: var(--black);
      border-radius: 50%;
      animation: spin 0.7s linear infinite;
      vertical-align: middle;
      margin-right: 4px;
    }

    @keyframes spin {
      to { transform: rotate(360deg); }
    }

    @media (max-width: 900px) {
      .form-video-inner {
        grid-template-columns: 1fr;
        gap: 40px;
        padding: 64px 24px;
      }
    }

/* ─── FEATURED TIP ─── */
  .tip-featured {
    display: grid;
    grid-template-columns: 1fr 1fr;
    background: var(--card);
    border: 1px solid var(--border-subtle);
    border-radius: 10px;
    overflow: hidden;
    cursor: pointer;
    transition: border-color 0.25s, transform 0.25s;
    margin-bottom: 0;
  }
  .tip-featured:hover {
    border-color: var(--teal);
    transform: translateY(-3px);
  }
  .tip-featured-img {
    min-height: 340px;
    background: linear-gradient(135deg, #161819, #1c2226);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 72px;
    position: relative;
  }
  .tip-featured-placeholder { opacity: 0.2; }
  .tip-featured-badge {
    position: absolute;
    top: 20px; left: 20px;
    background: var(--teal);
    color: var(--black);
    font-family: var(--font-head);
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    padding: 5px 12px;
    border-radius: 3px;
  }
  .tip-featured-body {
    padding: 48px 44px;
    display: flex;
    flex-direction: column;
    justify-content: center;
  }
  .tip-featured-title {
    font-family: var(--font-head);
    font-size: 26px;
    font-weight: 800;
    line-height: 1.3;
    color: var(--white);
    margin-bottom: 16px;
  }
  .tip-featured-excerpt {
    font-size: 15px;
    color: var(--muted);
    line-height: 1.75;
  }

  /* ─── BLOG DETAIL PAGE ─── */
  .blog-hero {
    padding: 130px 48px 64px;
    background: linear-gradient(180deg, #0d1415 0%, var(--black) 100%);
    border-bottom: 1px solid var(--border-subtle);
    position: relative;
    overflow: hidden;
  }
  .blog-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image:
      linear-gradient(rgba(78,195,196,0.03) 1px, transparent 1px),
      linear-gradient(90deg, rgba(78,195,196,0.03) 1px, transparent 1px);
    background-size: 60px 60px;
  }
  .blog-hero-inner {
    position: relative;
    z-index: 1;
    max-width: 800px;
    margin: 0 auto;
  }
  .blog-back {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-family: var(--font-head);
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--muted);
    cursor: pointer;
    background: none;
    border: none;
    padding: 0;
    margin-bottom: 24px;
    transition: color 0.2s;
  }
  .blog-back:hover { color: var(--teal); }
  .blog-back::before { content: '←'; font-size: 14px; }

  .blog-meta-row {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 20px;
    flex-wrap: wrap;
  }
  .blog-category-pill {
    background: var(--teal-mid);
    border: 1px solid var(--border);
    color: var(--teal);
    font-family: var(--font-head);
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    padding: 4px 12px;
    border-radius: 100px;
  }
  .blog-date {
    font-size: 13px;
    color: var(--muted);
  }
  .blog-hero-title {
    font-family: var(--font-head);
    font-size: clamp(28px, 4vw, 48px);
    font-weight: 800;
    line-height: 1.2;
    color: var(--white);
    margin-bottom: 20px;
  }
  .blog-hero-excerpt {
    font-size: 17px;
    color: #999;
    line-height: 1.75;
  }

  /* Cover image */
  .blog-cover {
    max-width: 800px;
    margin: 0 auto;
    padding: 48px 48px 0;
  }
  .blog-cover-img {
    width: 100%;
    aspect-ratio: 16/7;
    border-radius: 10px;
    background: linear-gradient(135deg, #161819, #1c2226);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 72px;
    opacity: 0.4;
    border: 1px solid var(--border-subtle);
  }

  /* Article body */
  .blog-body {
    max-width: 800px;
    margin: 0 auto;
    padding: 56px 48px;
  }
  .blog-content h2 {
    font-family: var(--font-head);
    font-size: 22px;
    font-weight: 800;
    color: var(--white);
    margin: 40px 0 16px;
  }
  .blog-content h3 {
    font-family: var(--font-head);
    font-size: 17px;
    font-weight: 700;
    color: var(--teal);
    margin: 28px 0 12px;
  }
  .blog-content p {
    font-size: 16px;
    color: #bbb;
    line-height: 1.85;
    margin-bottom: 20px;
  }
  .blog-content ul, .blog-content ol {
    margin: 0 0 20px 20px;
  }
  .blog-content li {
    font-size: 16px;
    color: #bbb;
    line-height: 1.75;
    margin-bottom: 8px;
  }
  .blog-content li::marker { color: var(--teal); }
  .blog-callout {
    background: var(--teal-mid);
    border-left: 3px solid var(--teal);
    border-radius: 0 8px 8px 0;
    padding: 20px 24px;
    margin: 32px 0;
    font-size: 15px;
    color: #ddd;
    line-height: 1.7;
  }
  .blog-formula {
    background: var(--card2);
    border: 1px solid var(--border-subtle);
    border-radius: 8px;
    padding: 20px 24px;
    margin: 24px 0;
    font-family: 'Courier New', monospace;
    font-size: 15px;
    color: var(--teal);
    text-align: center;
  }

  /* Share bar */
  .blog-share {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 24px 0;
    border-top: 1px solid var(--border-subtle);
    border-bottom: 1px solid var(--border-subtle);
    margin: 40px 0 48px;
  }
  .blog-share-label {
    font-family: var(--font-head);
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--muted);
  }
  .share-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 16px;
    border-radius: 4px;
    border: 1px solid var(--border-subtle);
    background: var(--card);
    color: var(--muted);
    font-family: var(--font-head);
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    cursor: pointer;
    text-decoration: none;
    transition: border-color 0.2s, color 0.2s;
  }
  .share-btn:hover { border-color: var(--teal); color: var(--teal); }

  /* Related articles */
  .blog-related {
    max-width: 800px;
    margin: 0 auto;
    padding: 0 48px 64px;
  }
  .blog-related-title {
    font-family: var(--font-display);
    font-size: 36px;
    margin-bottom: 28px;
    letter-spacing: 0.02em;
  }
  .blog-related-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
  }
  .blog-related-card {
    background: var(--card);
    border: 1px solid var(--border-subtle);
    border-radius: 8px;
    padding: 24px;
    cursor: pointer;
    transition: border-color 0.2s, transform 0.2s;
  }
  .blog-related-card:hover {
    border-color: var(--teal);
    transform: translateY(-2px);
  }
  .blog-related-card .tip-category { position:static; margin-bottom:10px; display:inline-block; }
  .blog-related-card-title {
    font-family: var(--font-head);
    font-size: 14px;
    font-weight: 700;
    line-height: 1.4;
    color: var(--white);
    margin-bottom: 12px;
  }
  .blog-related-card-date {
    font-size: 12px;
    color: var(--muted);
  }

  /* Prev/Next nav */
  .blog-prevnext {
    max-width: 800px;
    margin: 0 auto;
    padding: 0 48px 64px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
  }
  .prevnext-btn {
    background: var(--card);
    border: 1px solid var(--border-subtle);
    border-radius: 8px;
    padding: 20px 24px;
    cursor: pointer;
    transition: border-color 0.2s;
    text-align: left;
  }
  .prevnext-btn:hover { border-color: var(--teal); }
  .prevnext-btn.next { text-align: right; }
  .prevnext-label {
    font-family: var(--font-head);
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--muted);
    margin-bottom: 8px;
  }
  .prevnext-title {
    font-family: var(--font-head);
    font-size: 14px;
    font-weight: 700;
    color: var(--white);
    line-height: 1.4;
  }

  @media (max-width: 900px) {
    .tip-featured { grid-template-columns: 1fr; }
    .tip-featured-img { min-height: 220px; }
    .tip-featured-body { padding: 28px 24px; }
    .blog-hero { padding: 110px 24px 48px; }
    .blog-cover { padding: 32px 24px 0; }
    .blog-body { padding: 40px 24px; }
    .blog-related { padding: 0 24px 48px; }
    .blog-related-grid { grid-template-columns: 1fr; }
    .blog-prevnext { padding: 0 24px 48px; grid-template-columns: 1fr; }
  }

/* ─── PROJECT DETAIL PAGE ─── */
  .proj-hero {
    padding: 130px 48px 80px;
    background: linear-gradient(180deg, #0d1415 0%, var(--black) 100%);
    border-bottom: 1px solid var(--border-subtle);
    position: relative;
    overflow: hidden;
  }

  .proj-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image:
      linear-gradient(rgba(78,195,196,0.035) 1px, transparent 1px),
      linear-gradient(90deg, rgba(78,195,196,0.035) 1px, transparent 1px);
    background-size: 60px 60px;
  }

  .proj-hero-inner {
    position: relative;
    z-index: 1;
    max-width: 1200px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 48px;
    align-items: flex-end;
  }

  .proj-back {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-family: var(--font-head);
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--muted);
    cursor: pointer;
    background: none;
    border: none;
    padding: 0;
    margin-bottom: 24px;
    transition: color 0.2s;
  }

  .proj-back:hover { color: var(--teal); }
  .proj-back::before { content: '←'; font-size: 14px; }

  .proj-commune-tag {
    font-family: var(--font-head);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--teal);
    margin-bottom: 12px;
  }

  .proj-name {
    font-family: var(--font-display);
    font-size: clamp(56px, 7vw, 96px);
    line-height: 0.95;
    margin-bottom: 24px;
    letter-spacing: 0.02em;
  }

  .proj-hero-tags {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
  }

  .proj-tag {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: var(--card);
    border: 1px solid var(--border-subtle);
    border-radius: 4px;
    padding: 8px 16px;
    font-family: var(--font-head);
    font-size: 13px;
    font-weight: 600;
    color: var(--white);
  }

  .proj-tag.highlight {
    background: var(--teal-mid);
    border-color: var(--border);
    color: var(--teal);
  }

  .proj-price-box {
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: 10px;
    padding: 32px 36px;
    text-align: center;
    min-width: 240px;
    position: relative;
    overflow: hidden;
  }

  .proj-price-box::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--teal), #35a8a9);
  }

  .proj-price-label {
    font-family: var(--font-head);
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--muted);
    margin-bottom: 8px;
  }

  .proj-price-value {
    font-family: var(--font-display);
    font-size: 52px;
    color: var(--white);
    line-height: 1;
    letter-spacing: 0.02em;
  }

  .proj-price-uf {
    font-size: 16px;
    color: var(--muted);
    font-family: var(--font-body);
    font-weight: 300;
    margin-bottom: 20px;
  }

  /* Gallery */
  .proj-gallery {
    max-width: 1200px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 2fr 1fr 1fr;
    grid-template-rows: 240px 240px;
    gap: 8px;
    border-radius: 10px;
    overflow: hidden;
  }

  .proj-gallery-item {
    background: var(--card2);
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    overflow: hidden;
  }

  .proj-gallery-item:first-child {
    grid-row: 1 / 3;
  }

  .gallery-placeholder {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    color: var(--muted);
  }

  .gallery-placeholder-icon { font-size: 32px; opacity: 0.3; }
  .gallery-placeholder-text {
    font-size: 11px;
    font-family: var(--font-head);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    opacity: 0.4;
  }

  .proj-gallery-item img {
    width: 100%; height: 100%;
    object-fit: cover;
    display: block;
  }

  /* Content grid */
  .proj-content-grid {
    max-width: 1200px;
    margin: 64px auto 0;
    display: grid;
    grid-template-columns: 1fr 380px;
    gap: 56px;
    align-items: start;
  }

  .proj-section-title {
    font-family: var(--font-head);
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.2em;
    color: var(--teal);
    margin-bottom: 24px;
  }

  .proj-features-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 24px;
    margin-bottom: 48px;
  }

  .proj-feature-block {
    background: var(--card);
    border: 1px solid var(--border-subtle);
    border-radius: 8px;
    padding: 28px;
  }

  .proj-feature-block-title {
    font-family: var(--font-head);
    font-size: 14px;
    font-weight: 700;
    color: var(--white);
    margin-bottom: 16px;
    display: flex;
    align-items: center;
    gap: 10px;
  }

  .proj-feature-block-title span {
    width: 28px; height: 28px;
    border-radius: 6px;
    background: var(--teal-mid);
    border: 1px solid var(--border);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
  }

  .proj-feature-list {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 10px;
  }

  .proj-feature-list li {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    font-size: 14px;
    color: #bbb;
    line-height: 1.5;
  }

  .proj-feature-list li::before {
    content: '✓';
    color: var(--teal);
    font-size: 12px;
    margin-top: 2px;
    flex-shrink: 0;
  }

  .proj-description {
    font-size: 15px;
    color: #bbb;
    line-height: 1.8;
    padding-top: 32px;
    border-top: 1px solid var(--border-subtle);
  }

  /* Sticky sidebar form */
  .proj-sidebar {
    position: sticky;
    top: 92px;
  }

  .proj-sidebar .form-card {
    border-radius: 10px;
  }

  /* Amenities strip */
  .proj-amenities {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    margin-bottom: 32px;
  }

  .amenity-chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: var(--card);
    border: 1px solid var(--border-subtle);
    border-radius: 100px;
    padding: 7px 14px;
    font-size: 12px;
    color: var(--muted);
    font-family: var(--font-head);
    font-weight: 600;
    transition: border-color 0.2s, color 0.2s;
  }

  .amenity-chip:hover {
    border-color: var(--teal);
    color: var(--teal);
  }

  @media (max-width: 900px) {
    .proj-hero-inner { grid-template-columns: 1fr; }
    .proj-price-box { min-width: auto; }
    .proj-gallery { grid-template-columns: 1fr 1fr; grid-template-rows: 180px 180px 180px; }
    .proj-gallery-item:first-child { grid-row: 1 / 2; grid-column: 1 / 3; }
    .proj-content-grid { grid-template-columns: 1fr; }
    .proj-features-grid { grid-template-columns: 1fr; }
    .proj-sidebar { position: static; }
    .proj-hero { padding: 110px 24px 60px; }
  }


/* ─── LOGO IMAGE ─── */
.nav-logo-img-link img {
  height: 40px;
  width: auto;
  max-width: 220px;
  object-fit: contain;
  display: block;
  transition: opacity 0.2s;
}
.nav-logo-img-link:hover img { opacity: 0.85; }

.footer-brand .nav-logo-img-link img {
  height: 48px;
  max-width: 260px;
}

/* Ensure nav stays aligned with image logo */
#mainNav { align-items: center; }


/* ─── ABOUT VIDEO CONTENT / CTA ─── */
.about-desc {
  white-space: normal;
}

.about-video-content {
  padding: 24px 32px 32px;
  border-top: 1px solid var(--border-subtle);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 22px;
  text-align: center;
}

.about-video-stats {
  width: 100%;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  gap: 56px;
  flex-wrap: wrap;
}

.about-video-stat {
  min-width: 150px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

.about-video-stat-num {
  font-family: var(--font-display);
  font-size: 36px;
  color: var(--teal);
  line-height: 1;
}

.about-video-stat-label {
  font-size: 14px;
  color: var(--muted);
  margin-top: 8px;
  line-height: 1.4;
}

.about-video-cta-wrap {
  display: flex;
  justify-content: center;
  width: 100%;
}

@media (max-width: 768px) {
  .about-card-main {
    padding: 24px;
  }

  .about-video-content {
    padding: 22px 18px 24px;
  }

  .about-video-stats {
    gap: 28px;
  }

  .about-video-stat {
    min-width: 120px;
  }

  .about-video-stat-num {
    font-size: 30px;
  }

  .about-video-stat-label {
    font-size: 13px;
  }
}


/* ─── THANK YOU PAGE ─── */
.thankyou-page {
  min-height: 100vh;
  position: relative;
  overflow: hidden;
  background: linear-gradient(180deg, #0d1415 0%, var(--black) 100%);
  padding: 140px 48px 96px;
}
.thankyou-page::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(78,195,196,0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(78,195,196,0.03) 1px, transparent 1px);
  background-size: 60px 60px;
}
.thankyou-inner {
  position: relative;
  z-index: 1;
  max-width: 980px;
  margin: 0 auto;
}
.thankyou-card {
  background: var(--card);
  border: 1px solid var(--border-subtle);
  border-radius: 10px;
  padding: 56px 48px;
  text-align: center;
}
.thankyou-icon {
  width: 88px;
  height: 88px;
  border-radius: 999px;
  margin: 0 auto 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--teal-mid);
  border: 1px solid var(--border);
  color: var(--teal);
  font-size: 42px;
}
.thankyou-title {
  font-family: var(--font-head);
  font-size: clamp(34px, 5vw, 58px);
  line-height: 1.05;
  color: var(--white);
  margin: 0 0 18px;
}
.thankyou-desc {
  max-width: 720px;
  margin: 0 auto 28px;
  font-family: var(--font-body);
  font-size: 17px;
  line-height: 1.8;
  color: var(--muted);
}
.thankyou-note {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 16px;
  background: var(--teal-mid);
  border: 1px solid var(--border);
  border-radius: 999px;
  font-family: var(--font-head);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--teal);
  margin-bottom: 32px;
}
.thankyou-actions {
  display: flex;
  justify-content: center;
  gap: 16px;
  flex-wrap: wrap;
  margin-bottom: 40px;
}
.thankyou-links {
  border-top: 1px solid var(--border-subtle);
  padding-top: 28px;
}
.thankyou-links-title {
  font-family: var(--font-head);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 14px;
}
.thankyou-links-grid {
  display: flex;
  justify-content: center;
  gap: 12px;
  flex-wrap: wrap;
}
.thankyou-link {
  padding: 10px 16px;
  border: 1px solid var(--border-subtle);
  border-radius: 4px;
  color: var(--muted);
  text-decoration: none;
  font-family: var(--font-head);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  transition: border-color 0.2s, color 0.2s;
}
.thankyou-link:hover {
  border-color: var(--teal);
  color: var(--teal);
}

/* ─── TYPOGRAPHY ALIGNMENT: TIPS + SINGLE POST ─── */
.page-title,
.tip-featured-title,
.tip-title,
.tip-link,
.blog-hero-title,
.blog-related-title,
.blog-related-card-title,
.prevnext-title {
  font-family: var(--font-head);
  letter-spacing: normal;
}

.page-subtitle,
.tip-featured-excerpt,
.tip-date,
.tip-excerpt,
.blog-date,
.blog-hero-excerpt,
.blog-content,
.blog-content p,
.blog-content li,
.blog-callout,
.blog-related-card-date {
  font-family: var(--font-body);
}

.blog-content h2,
.blog-content h3,
.blog-share-label,
.share-btn,
.prevnext-label {
  font-family: var(--font-head);
}

@media (max-width: 900px) {
  .thankyou-page {
    padding: 120px 24px 72px;
  }
  .thankyou-card {
    padding: 40px 24px;
  }
  .thankyou-desc {
    font-size: 16px;
  }
}


/* ─── PROJECT TYPOLOGIES / DYNAMIC SINGLE ─── */
.proj-price-context {
  margin-bottom: 18px;
  font-size: 13px;
  color: var(--teal);
  font-family: var(--font-head);
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.proj-typology-section {
  padding: 28px 48px 0;
}

.proj-typology-inner,
.proj-typology-showcase-inner {
  max-width: 1200px;
  margin: 0 auto;
}

.proj-typology-nav {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

.proj-typology-chip {
  appearance: none;
  border: 1px solid var(--border-subtle);
  background: var(--card);
  border-radius: 8px;
  padding: 14px 18px;
  min-width: 220px;
  text-align: left;
  cursor: pointer;
  transition: border-color 0.2s, transform 0.2s, background 0.2s;
}

.proj-typology-chip:hover,
.proj-typology-chip.is-active {
  border-color: var(--teal);
  background: rgba(78,195,196,0.08);
  transform: translateY(-2px);
}

.proj-typology-chip-title {
  display: block;
  font-family: var(--font-head);
  font-size: 15px;
  font-weight: 700;
  color: var(--white);
  margin-bottom: 6px;
}

.proj-typology-chip-meta {
  display: block;
  font-size: 12px;
  color: var(--muted);
  line-height: 1.5;
}

.proj-typology-showcase {
  padding: 36px 48px 0;
}

.proj-typology-showcase-inner {
  display: grid;
  grid-template-columns: minmax(0, 2fr) minmax(320px, 1fr);
  gap: 32px;
  align-items: start;
}

.proj-gallery--dynamic {
  margin-bottom: 18px;
}

.proj-plan-card,
.proj-typology-summary-card,
.proj-benefit-card,
.proj-calc-placeholder,
.proj-extra-option,
.proj-extra-total {
  background: var(--card);
  border: 1px solid var(--border-subtle);
  border-radius: 10px;
}

.proj-plan-card {
  padding: 20px;
}

.proj-plan-card-header {
  font-family: var(--font-head);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--teal);
  margin-bottom: 16px;
}

.proj-plan-card img {
  width: 100%;
  display: block;
  border-radius: 8px;
  border: 1px solid var(--border-subtle);
  background: #0f1214;
}

.proj-plan-empty {
  min-height: 140px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--muted);
  text-align: center;
  line-height: 1.6;
  background: var(--card2);
  border-radius: 8px;
  padding: 20px;
}

.proj-typology-summary-card {
  padding: 28px;
}

.proj-typology-summary-top {
  display: flex;
  gap: 18px;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 22px;
}

.proj-typology-summary-name {
  font-family: var(--font-head);
  font-size: 28px;
  font-weight: 800;
  color: var(--white);
  line-height: 1.05;
  margin-bottom: 8px;
}

.proj-typology-summary-layout {
  font-size: 14px;
  color: var(--muted);
}

.proj-typology-status {
  white-space: nowrap;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(78,195,196,0.1);
  border: 1px solid rgba(78,195,196,0.18);
  color: var(--teal);
  font-family: var(--font-head);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.proj-typology-status.is-off {
  background: rgba(255,255,255,0.04);
  border-color: rgba(255,255,255,0.08);
  color: #d4d4d8;
}

.proj-typology-metrics {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 22px;
}

.proj-typology-metric {
  background: var(--card2);
  border: 1px solid var(--border-subtle);
  border-radius: 8px;
  padding: 14px;
}

.proj-typology-metric span,
.proj-price-stack-label {
  display: block;
  font-size: 11px;
  color: var(--muted);
  font-family: var(--font-head);
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-bottom: 8px;
}

.proj-typology-metric strong {
  font-size: 16px;
  color: var(--white);
  font-weight: 700;
}

.proj-price-stack {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  margin-bottom: 20px;
}

.proj-price-stack > div {
  background: var(--card2);
  border: 1px solid var(--border-subtle);
  border-radius: 8px;
  padding: 16px;
}

.proj-price-stack-old,
.proj-price-stack-new {
  font-family: var(--font-display);
  font-size: 34px;
  line-height: 1;
}

.proj-price-stack-old {
  color: #f8fafc;
  opacity: 0.55;
  text-decoration: line-through;
}

.proj-price-stack-old.is-muted {
  opacity: 1;
  text-decoration: none;
}

.proj-price-stack-new {
  color: var(--teal);
}

.proj-typology-copy {
  font-size: 14px;
  line-height: 1.75;
  color: var(--muted);
  padding-top: 18px;
  border-top: 1px solid var(--border-subtle);
}

.proj-dynamic-block {
  margin-bottom: 36px;
}

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

.proj-extra-option {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 18px 20px;
  font-size: 14px;
  color: var(--white);
}

.proj-extra-option input {
  margin-right: 10px;
}

.proj-extra-option span {
  flex: 1;
}

.proj-extra-option strong {
  color: var(--teal);
  font-family: var(--font-head);
  font-weight: 700;
}

.proj-extra-option.is-disabled {
  opacity: 0.7;
}

.proj-extra-total {
  margin-top: 14px;
  padding: 16px 18px;
  color: var(--muted);
  font-size: 14px;
}

.proj-extra-total strong {
  color: var(--white);
}

.proj-benefit-card {
  padding: 20px;
}

.proj-benefit-title {
  font-family: var(--font-head);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--teal);
  margin-bottom: 12px;
}

.proj-benefit-text {
  font-size: 14px;
  line-height: 1.7;
  color: var(--muted);
}

.proj-calc-placeholder {
  padding: 24px;
  margin-bottom: 40px;
}

.proj-calc-placeholder-title {
  font-family: var(--font-head);
  font-size: 17px;
  font-weight: 800;
  color: var(--white);
  margin-bottom: 10px;
}

.proj-calc-placeholder p {
  font-size: 14px;
  line-height: 1.7;
  color: var(--muted);
}

.proj-gallery--general {
  margin-top: 8px;
}

@media (max-width: 900px) {
  .proj-typology-section,
  .proj-typology-showcase,
  .proj-gallery--general {
    padding-left: 24px;
    padding-right: 24px;
  }

  .proj-typology-showcase-inner,
  .proj-typology-metrics,
  .proj-price-stack,
  .proj-extras-grid,
  .proj-benefits-grid {
    grid-template-columns: 1fr;
  }

  .proj-typology-chip {
    min-width: 100%;
  }
}

/* ─── PHASE 3: TYPOLOGY COMMERCIAL POLISH ─── */
.proj-price-old {
  font-family: var(--font-head);
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.45);
  text-decoration: line-through;
  margin-bottom: 10px;
}

.proj-price-delta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(78,195,196,0.12);
  border: 1px solid rgba(78,195,196,0.22);
  color: var(--teal);
  font-family: var(--font-head);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-bottom: 14px;
}

.proj-price-mini-benefits {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 18px;
}

.proj-price-mini-chip {
  display: inline-flex;
  align-items: center;
  padding: 7px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.08);
  color: var(--white);
  font-family: var(--font-head);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.proj-typology-nav {
  overflow-x: auto;
  flex-wrap: nowrap;
  padding-bottom: 4px;
  scrollbar-width: thin;
  scroll-snap-type: x proximity;
}

.proj-typology-chip {
  flex: 0 0 240px;
  scroll-snap-align: start;
  box-shadow: 0 6px 18px rgba(0,0,0,0.12);
}

.proj-typology-chip.is-active {
  box-shadow: 0 14px 34px rgba(0,0,0,0.22);
}

.proj-price-stack-savings {
  margin-top: 10px;
  font-size: 12px;
  color: var(--teal);
  font-family: var(--font-head);
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.proj-opportunity-strip {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 12px;
  margin-bottom: 18px;
}

.proj-opportunity-item {
  background: linear-gradient(180deg, rgba(78,195,196,0.08), rgba(78,195,196,0.02));
  border: 1px solid rgba(78,195,196,0.14);
  border-radius: 8px;
  padding: 14px;
}

.proj-opportunity-item.is-neutral {
  background: var(--card2);
  border-color: var(--border-subtle);
}

.proj-opportunity-item span {
  display: block;
  margin-bottom: 8px;
  color: var(--muted);
  font-family: var(--font-head);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.proj-opportunity-item strong {
  color: var(--white);
  font-size: 14px;
  line-height: 1.45;
}

.proj-extra-total {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}

#projExtraSelectionSummary {
  color: var(--teal);
  font-size: 12px;
  font-family: var(--font-head);
  font-weight: 700;
  letter-spacing: 0.06em;
}

.proj-calc-placeholder {
  background: linear-gradient(180deg, rgba(78,195,196,0.06), rgba(78,195,196,0.02));
}

@media (max-width: 900px) {
  .proj-price-mini-benefits {
    margin-bottom: 16px;
  }

  .proj-typology-nav {
    gap: 10px;
  }

  .proj-typology-chip {
    flex-basis: 88%;
    min-width: 88%;
  }

  .proj-opportunity-strip {
    grid-template-columns: 1fr;
  }
}


/* ─── PHASE 4: TYPOLOGY UX POLISH ─── */
.proj-section-heading-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 16px;
  flex-wrap: wrap;
}

.proj-media-switch {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px;
  background: var(--card);
  border: 1px solid var(--border-subtle);
  border-radius: 999px;
}

.proj-media-switch-btn {
  appearance: none;
  border: 0;
  background: transparent;
  color: var(--muted);
  font-family: var(--font-head);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 10px 14px;
  border-radius: 999px;
  cursor: pointer;
  transition: background 0.2s, color 0.2s;
}

.proj-media-switch-btn:hover,
.proj-media-switch-btn.is-active {
  background: var(--teal-mid);
  color: var(--teal);
}

.proj-media-switch-btn:disabled {
  opacity: 0.45;
  cursor: not-allowed;
}

.proj-media-mode-label {
  margin-bottom: 14px;
  font-size: 12px;
  color: var(--muted);
  font-family: var(--font-head);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.proj-sidebar-live-card {
  background: linear-gradient(135deg, rgba(78,195,196,0.14), rgba(78,195,196,0.05));
  border: 1px solid rgba(78,195,196,0.18);
  border-radius: 10px;
  padding: 18px 18px 16px;
  margin-bottom: 16px;
}

.proj-sidebar-live-label {
  font-family: var(--font-head);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--teal);
  margin-bottom: 8px;
}

.proj-sidebar-live-title {
  font-family: var(--font-head);
  font-size: 20px;
  font-weight: 800;
  color: var(--white);
  line-height: 1.15;
  margin-bottom: 8px;
}

.proj-sidebar-live-meta {
  font-size: 14px;
  color: var(--white);
  margin-bottom: 8px;
}

.proj-sidebar-live-note {
  font-size: 13px;
  color: var(--muted);
  line-height: 1.5;
}

@media (max-width: 900px) {
  .proj-section-heading-row {
    align-items: flex-start;
  }

  .proj-media-switch {
    width: 100%;
    justify-content: flex-start;
    overflow-x: auto;
  }

  .proj-media-switch-btn {
    white-space: nowrap;
  }
}


/* ─── PHASE 4B: SINGLE WIDTH + COMPACT CALCULATOR HOST ─── */
.proj-hero-inner,
.proj-typology-inner,
.proj-typology-showcase-inner,
.proj-content-grid,
.proj-gallery {
  max-width: 1380px;
}

.proj-typology-section {
  padding: 22px 32px 0;
}

.proj-typology-showcase {
  padding: 28px 32px 0;
}

.proj-content-grid {
  margin: 42px auto 0;
  grid-template-columns: minmax(0, 1.38fr) minmax(270px, 300px);
  gap: 28px;
}

.proj-sidebar {
  top: 84px;
}

.proj-sidebar-live-card {
  padding: 16px 16px 14px;
  margin-bottom: 14px;
}

.proj-sidebar-live-title {
  font-size: 18px;
  margin-bottom: 6px;
}

.proj-sidebar-live-meta,
.proj-sidebar-live-note {
  font-size: 12px;
}

.proj-sidebar .form-card {
  padding: 18px;
}

.proj-sidebar .form-title {
  margin-bottom: 14px;
}

.proj-sidebar .field label {
  font-size: 11px;
}

.proj-sidebar .field input,
.proj-sidebar .field select {
  min-height: 44px;
  padding: 10px 12px;
}

.proj-sidebar .form-note {
  font-size: 11px;
  line-height: 1.55;
}

.proj-calc-placeholder,
#projectMortgageCalculator {
  margin-bottom: 28px;
}

#projectMortgageCalculator .tdh-calculator-shell {
  border-radius: 18px !important;
}

@media (max-width: 1200px) {
  .proj-hero-inner,
  .proj-typology-inner,
  .proj-typology-showcase-inner,
  .proj-content-grid,
  .proj-gallery {
    max-width: 100%;
  }

  .proj-content-grid {
    grid-template-columns: minmax(0, 1fr) minmax(250px, 280px);
    gap: 22px;
  }
}

@media (max-width: 1024px) {
  .proj-content-grid,
  .proj-typology-showcase-inner {
    grid-template-columns: 1fr;
  }

  .proj-sidebar {
    position: static;
  }
}

@media (max-width: 900px) {
  .proj-typology-section,
  .proj-typology-showcase,
  .proj-gallery--general,
  .proj-hero,
  section[style="padding:64px 48px;"] {
    padding-left: 20px !important;
    padding-right: 20px !important;
  }

  .proj-content-grid {
    margin-top: 28px;
    gap: 18px;
  }

  .proj-section-title {
    margin-bottom: 14px;
  }

  .proj-dynamic-block {
    margin-bottom: 22px;
  }
}

@media (max-width: 640px) {
  .proj-price-box,
  .proj-sidebar .form-card,
  .proj-plan-card,
  .proj-typology-summary-card,
  .proj-benefit-card,
  .proj-extra-option,
  .proj-extra-total,
  .proj-calc-placeholder {
    border-radius: 14px;
  }
}


/* ─── OPTION B REFINEMENT: clearer single proyecto ─── */
.proj-content-grid--b {
  align-items: start;
}
.proj-b-main {
  display: grid;
  gap: 22px;
}
.proj-b-card {
  background: linear-gradient(180deg, rgba(22,24,25,.96), rgba(19,22,24,.96));
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 18px;
  padding: 22px;
}
.proj-b-kicker {
  font-family: var(--font-head);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--teal);
  margin-bottom: 10px;
}
.proj-b-heading {
  font-family: var(--font-head);
  font-size: 24px;
  font-weight: 700;
  letter-spacing: -0.03em;
  line-height: 1.15;
  margin: 0 0 10px;
  color: var(--white);
}
.proj-b-copy {
  color: var(--muted);
  font-size: 14px;
  line-height: 1.7;
  margin: 0 0 18px;
}
.proj-b-split,
.proj-b-info-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}
.proj-b-meta-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin-bottom: 16px;
}
.proj-b-meta-item,
.proj-b-meta-row,
.proj-b-info-card {
  background: rgba(255,255,255,0.02);
  border: 1px solid rgba(255,255,255,0.05);
  border-radius: 14px;
}
.proj-b-meta-item {
  padding: 16px;
}
.proj-b-meta-item span {
  display: block;
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 8px;
}
.proj-b-meta-item strong {
  display: block;
  color: var(--white);
  font-family: var(--font-head);
  font-size: 18px;
  line-height: 1.2;
}
.proj-b-meta-list {
  display: grid;
  gap: 10px;
}
.proj-b-meta-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 16px;
  color: var(--white);
}
.proj-b-meta-row span {
  color: var(--muted);
  font-size: 13px;
}
.proj-b-meta-row strong {
  color: var(--teal);
  font-family: var(--font-head);
  font-size: 16px;
}
.proj-b-info-card {
  padding: 18px;
}
.proj-b-info-card--full {
  grid-column: 1 / -1;
}
.proj-b-info-title {
  font-family: var(--font-head);
  font-size: 14px;
  font-weight: 700;
  color: var(--white);
  margin-bottom: 12px;
}
.proj-description--within {
  padding-top: 0;
  border-top: 0;
}
.proj-gallery--inside {
  padding: 0;
}
.proj-b-card .proj-dynamic-block,
.proj-b-card .proj-benefits-grid,
.proj-b-card #projectMortgageCalculator {
  margin-bottom: 0;
}
.proj-b-card .proj-extra-total {
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.05);
  border-radius: 14px;
}
@media (max-width: 1100px) {
  .proj-b-split,
  .proj-b-info-grid,
  .proj-b-meta-grid {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 768px) {
  .proj-b-card {
    padding: 18px;
    border-radius: 16px;
  }
  .proj-b-heading {
    font-size: 21px;
  }
  .proj-b-meta-row {
    flex-direction: column;
    align-items: flex-start;
  }
}


/* ─── REBUILD SINGLE PROYECTO V1.1.13 ─── */
.proj-c-top {
  padding: 104px 48px 28px;
  border-bottom: 1px solid rgba(255,255,255,0.05);
  background:
    radial-gradient(circle at top right, rgba(78,195,196,0.08), transparent 28%),
    linear-gradient(180deg, rgba(10,10,10,0.92), rgba(10,10,10,0.78));
}
.proj-c-top-inner {
  max-width: 1360px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(0, 1.45fr) 360px;
  gap: 24px;
  align-items: start;
}
.proj-c-top-copy {
  display: grid;
  gap: 12px;
}
.proj-c-top-description {
  margin: 0;
  max-width: 780px;
  color: var(--muted);
  font-size: 16px;
  line-height: 1.7;
}
.proj-c-selector {
  max-width: 1360px;
  margin: 24px auto 0;
}
.proj-price-box--compact {
  padding: 22px;
  background: linear-gradient(180deg, rgba(22,24,25,.96), rgba(19,22,24,.96));
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 18px;
}
.proj-content-grid--c {
  max-width: 1360px;
  margin: 0 auto;
  padding: 28px 48px 48px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 340px;
  gap: 24px;
  align-items: start;
}
.proj-c-main { display: grid; gap: 22px; }
.proj-c-media-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) 360px;
  gap: 18px;
  align-items: start;
}
.proj-b-card--media-summary #projectTypologyMedia { display: grid; gap: 14px; }
.proj-plan-card.is-empty { display: none; }
.proj-b-card--commercial-context .proj-b-copy,
.proj-b-card--benefits .proj-b-copy,
.proj-b-card--project-meta .proj-b-copy,
.proj-b-card--calculator .proj-b-copy,
.proj-b-card--project-info .proj-b-copy { max-width: 840px; }
.proj-b-card--commercial-context .proj-extra-total {
  margin-top: 14px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.05);
}
.proj-extras-grid--triple {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
.proj-extra-option--bonus strong { color: var(--teal); }
.proj-sidebar {
  position: sticky;
  top: 96px;
  display: grid;
  gap: 16px;
}
.proj-sidebar .form-card,
.proj-sidebar-live-card {
  border-radius: 18px;
}
.proj-b-card--project-info .proj-b-info-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.proj-b-card--project-gallery .proj-gallery { margin-top: 0; }
@media (max-width: 1200px) {
  .proj-c-top-inner,
  .proj-content-grid--c,
  .proj-c-media-grid {
    grid-template-columns: 1fr;
  }
  .proj-sidebar {
    position: static;
  }
}
@media (max-width: 768px) {
  .proj-c-top { padding: 96px 20px 22px; }
  .proj-content-grid--c { padding: 22px 20px 32px; }
  .proj-c-top-description { font-size: 15px; }
  .proj-extras-grid--triple,
  .proj-b-card--project-info .proj-b-info-grid { grid-template-columns: 1fr; }
}


/* ─── SINGLE PROYECTO REFINEMENT V1.1.14 ─── */
.proj-c-top-inner { grid-template-columns: minmax(0, 1.5fr) 340px; gap: 20px; }
.proj-content-grid--c { grid-template-columns: minmax(0, 1fr) 320px; gap: 20px; }
.proj-c-media-grid { grid-template-columns: minmax(0, 1.05fr) 320px; gap: 16px; }
.proj-b-main { gap: 18px; }
.proj-b-card { padding: 18px; border-radius: 16px; }
.proj-b-kicker { font-size: 10px; margin-bottom: 8px; }
.proj-b-heading { font-size: 20px; margin-bottom: 8px; }
.proj-b-copy { font-size: 13px; line-height: 1.6; margin-bottom: 14px; }
.proj-typology-summary-card { padding: 22px; }
.proj-typology-summary-top { gap: 14px; margin-bottom: 18px; }
.proj-typology-summary-name { font-size: 22px; margin-bottom: 6px; }
.proj-typology-summary-layout { font-size: 13px; }
.proj-typology-status { padding: 7px 10px; font-size: 10px; }
.proj-typology-metrics { gap: 10px; margin-bottom: 18px; }
.proj-typology-metric { padding: 12px; }
.proj-typology-metric span,
.proj-price-stack-label { font-size: 10px; margin-bottom: 6px; }
.proj-typology-metric strong { font-size: 15px; }
.proj-price-stack { gap: 12px; margin-bottom: 16px; }
.proj-price-stack > div { padding: 14px; }
.proj-price-stack-old,
.proj-price-stack-new { font-size: 28px; }
.proj-opportunity-strip { gap: 10px; }
.proj-opportunity-item { padding: 12px 14px; }
.proj-opportunity-item strong { font-size: 15px; }
.proj-b-split { grid-template-columns: 1fr; }
.proj-b-info-grid { gap: 16px; }
.proj-benefits-grid { grid-template-columns: 1fr; }
.proj-benefit-card { padding: 16px; }
.proj-benefit-title { font-size: 11px; margin-bottom: 10px; }
.proj-benefit-text { font-size: 13px; line-height: 1.6; }

/* Galería: una imagen grande cuadrada y miniaturas cuadradas abajo */
.proj-gallery--dynamic {
  max-width: none;
  margin: 0;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  grid-template-rows: auto auto;
  gap: 10px;
}
.proj-gallery--dynamic .proj-gallery-item {
  aspect-ratio: 1 / 1;
  border-radius: 12px;
}
.proj-gallery--dynamic .proj-gallery-item:first-child {
  grid-column: 1 / -1;
  grid-row: 1;
}
.proj-gallery--dynamic .proj-gallery-item:nth-child(n+2) {
  grid-row: 2;
}
.proj-gallery--general {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  grid-template-rows: auto auto;
  gap: 10px;
}
.proj-gallery--general .proj-gallery-item {
  aspect-ratio: 1 / 1;
  border-radius: 12px;
}
.proj-gallery--general .proj-gallery-item:first-child {
  grid-column: 1 / -1;
  grid-row: 1;
}
.proj-gallery--general .proj-gallery-item:nth-child(n+2) {
  grid-row: 2;
}

/* Checkbox y opciones comerciales */
.proj-extras-grid--triple { grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; }
.proj-extra-option {
  display: grid;
  grid-template-columns: 16px minmax(0, 1fr) auto;
  align-items: center;
  gap: 10px;
  padding: 14px 16px;
  min-height: 58px;
  font-size: 13px;
}
.proj-extra-option input {
  width: 16px;
  height: 16px;
  margin: 0;
  accent-color: var(--teal);
}
.proj-extra-option span { font-size: 13px; line-height: 1.35; }
.proj-extra-option strong { font-size: 14px; }
.proj-extra-total { margin-top: 12px; padding: 14px 16px; font-size: 13px; }

.proj-b-meta-item { padding: 14px; }
.proj-b-meta-item strong { font-size: 16px; }
.proj-b-meta-row { padding: 12px 14px; }
.proj-b-meta-row strong { font-size: 15px; }
.proj-sidebar { gap: 14px; }
.proj-sidebar-live-card { padding: 18px; }
.proj-sidebar-live-title { font-size: 18px; }

@media (max-width: 1100px) {
  .proj-c-top-inner,
  .proj-content-grid--c,
  .proj-c-media-grid { grid-template-columns: 1fr; }
  .proj-extras-grid--triple { grid-template-columns: 1fr; }
}
@media (max-width: 768px) {
  .proj-b-card { padding: 16px; }
  .proj-b-heading { font-size: 18px; }
  .proj-typology-summary-card { padding: 18px; }
  .proj-typology-summary-name { font-size: 20px; }
  .proj-price-stack-old,
  .proj-price-stack-new { font-size: 24px; }
  .proj-gallery--dynamic,
  .proj-gallery--general { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .proj-gallery--dynamic .proj-gallery-item:first-child,
  .proj-gallery--general .proj-gallery-item:first-child { grid-column: 1 / -1; }
}


/* ─── GALLERY LIGHTBOX V1.1.15 ─── */
.proj-gallery-item img,
.proj-plan-card img {
  cursor: zoom-in;
}
.proj-lightbox-overlay {
  position: fixed;
  inset: 0;
  background: rgba(5, 9, 12, 0.92);
  display: none;
  align-items: center;
  justify-content: center;
  padding: 28px;
  z-index: 9999;
}
.proj-lightbox-overlay.is-open {
  display: flex;
}
.proj-lightbox-dialog {
  position: relative;
  width: min(92vw, 1280px);
  max-height: 92vh;
  display: grid;
  grid-template-columns: 56px minmax(0, 1fr) 56px;
  align-items: center;
  gap: 14px;
}
.proj-lightbox-stage {
  position: relative;
  background: rgba(255,255,255,0.02);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 18px;
  overflow: hidden;
  min-height: 220px;
}
.proj-lightbox-stage img {
  display: block;
  width: 100%;
  height: auto;
  max-height: 82vh;
  object-fit: contain;
  background: #05090c;
}
.proj-lightbox-close {
  position: absolute;
  top: -10px;
  right: -10px;
  width: 44px;
  height: 44px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(15,20,23,0.96);
  color: #fff;
  font-size: 26px;
  line-height: 1;
  cursor: pointer;
  z-index: 2;
}
.proj-lightbox-nav {
  width: 56px;
  height: 56px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.1);
  background: rgba(15,20,23,0.96);
  color: #fff;
  font-size: 26px;
  line-height: 1;
  cursor: pointer;
}
.proj-lightbox-nav[disabled] {
  opacity: 0.35;
  cursor: default;
}
.proj-lightbox-caption {
  position: absolute;
  left: 14px;
  right: 14px;
  bottom: 14px;
  padding: 10px 12px;
  border-radius: 12px;
  background: rgba(5, 9, 12, 0.74);
  color: #d8e0e6;
  font-size: 13px;
  line-height: 1.45;
}
@media (max-width: 768px) {
  .proj-lightbox-overlay { padding: 14px; }
  .proj-lightbox-dialog {
    width: 100%;
    grid-template-columns: 1fr;
    gap: 10px;
  }
  .proj-lightbox-stage img { max-height: 74vh; }
  .proj-lightbox-close {
    top: 10px;
    right: 10px;
    width: 40px;
    height: 40px;
  }
  .proj-lightbox-nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 2;
    width: 42px;
    height: 42px;
    font-size: 22px;
  }
  .proj-lightbox-nav--prev { left: 8px; }
  .proj-lightbox-nav--next { right: 8px; }
}


/* ─── IMPLEMENTATION V1.1.16 ─── */
/* Tipografía global unificada */
body,
input,
textarea,
select,
button,
.archive,
.single,
.page,
.page-template-page-tips,
.post-type-archive-proyecto,
.single-post,
.single-proyecto {
  font-family: var(--font-body);
}
h1,h2,h3,h4,h5,h6,
.page-template-page-tips .tips-hero-title,
.post-type-archive-proyecto .projects-title,
.single-post .entry-title,
.single-proyecto .proj-name,
.single-proyecto .proj-b-heading,
.single-proyecto .proj-typology-summary-name {
  font-family: var(--font-head);
}
.proj-c-media-grid { grid-template-columns: minmax(0, 1fr) 420px; }
.proj-gallery--dynamic,
.proj-gallery--general { max-width:none; margin:0; grid-template-columns:repeat(4,minmax(0,1fr)); grid-template-rows:auto auto; gap:10px; }
.proj-gallery--dynamic .proj-gallery-item,
.proj-gallery--general .proj-gallery-item { aspect-ratio:1 / 1; border-radius:14px; }
.proj-gallery--dynamic .proj-gallery-item:first-child,
.proj-gallery--general .proj-gallery-item:first-child { grid-column:1 / -1; grid-row:1; }
.proj-gallery--dynamic .proj-gallery-item:nth-child(n+2),
.proj-gallery--general .proj-gallery-item:nth-child(n+2) { grid-row:2; }
.proj-typology-summary-card { padding:20px; }
.proj-typology-summary-top { align-items:flex-start; gap:12px; }
.proj-typology-status { white-space:normal; text-align:center; max-width:140px; line-height:1.2; align-self:flex-start; }
.proj-price-stack--vertical { grid-template-columns:1fr; }
.proj-price-stack--vertical .proj-price-stack-old.is-compare {
  text-decoration:none;
  opacity:1;
  color:#cfd6dc;
  font-family: var(--font-head);
  font-size:22px;
}
.proj-price-stack--vertical .proj-price-stack-new { font-size:30px; }
.proj-opportunity-strip { display:grid; grid-template-columns:1fr; gap:10px; }
.proj-opportunity-item { padding:12px 14px; min-height:unset; }
.proj-opportunity-item span { display:block; font-size:10px; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); margin-bottom:6px; }
.proj-opportunity-item strong { display:block; font-size:18px; line-height:1.3; }
.proj-opportunity-item strong small { display:block; font-size:12px; color:var(--muted); font-weight:600; margin-top:4px; }
.proj-b-split { grid-template-columns:1fr; }
.proj-benefits-grid { grid-template-columns:repeat(2,minmax(0,1fr)); gap:12px; }
.proj-extra-option { grid-template-columns:16px minmax(0,1fr) auto; align-items:center; gap:10px; padding:14px 16px; min-height:56px; }
.proj-extra-option input { width:16px; height:16px; margin:0; accent-color:var(--teal); }
.proj-extra-option--bonus input { width:14px; height:14px; }
.proj-extra-option span { font-size:13px; line-height:1.35; }
.proj-extra-option strong { font-size:14px; text-align:right; }
@media (max-width: 1200px) {
  .proj-c-media-grid { grid-template-columns:1fr; }
}
@media (max-width: 768px) {
  .proj-gallery--dynamic,
  .proj-gallery--general { grid-template-columns:repeat(2,minmax(0,1fr)); }
  .proj-gallery--dynamic .proj-gallery-item:first-child,
  .proj-gallery--general .proj-gallery-item:first-child { grid-column:1 / -1; }
  .proj-benefits-grid { grid-template-columns:1fr; }
}

/* =========================================================
   TentuDepto single proyecto — rediseño full v1.1.23
   ========================================================= */
.td-single-redesign{position:relative;overflow:hidden;background:#050809;color:#fff;padding:72px 0 96px;min-height:100vh}.td-single-redesign:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(8,19,21,.95),rgba(5,8,9,.88) 42%,rgba(7,13,15,.98)),radial-gradient(circle at 70% 20%,rgba(78,195,196,.16),transparent 32%);pointer-events:none}.td-single-bg-glow{position:absolute;width:520px;height:520px;border-radius:50%;filter:blur(70px);opacity:.22;pointer-events:none}.td-single-bg-glow--one{top:80px;left:-160px;background:#4ec3c4}.td-single-bg-glow--two{top:120px;right:-160px;background:#124f55}.td-single-shell{position:relative;z-index:1;width:min(1560px,calc(100% - 56px));margin:0 auto}.td-back-link{display:inline-flex;align-items:center;gap:8px;margin-bottom:34px;color:#65eeee;text-transform:uppercase;letter-spacing:.16em;font-size:13px;font-weight:800;text-decoration:none}.td-hero-grid{display:grid;grid-template-columns:minmax(360px,.9fr) minmax(420px,1.15fr) minmax(340px,.68fr);gap:24px;align-items:stretch}.td-hero-copy,.td-gallery-panel,.td-decision-card,.td-panel,.td-lead-form-panel{background:linear-gradient(145deg,rgba(255,255,255,.055),rgba(255,255,255,.025));border:1px solid rgba(78,195,196,.2);box-shadow:0 24px 90px rgba(0,0,0,.34);border-radius:28px}.td-hero-copy{padding:42px;display:flex;flex-direction:column;justify-content:center;min-height:620px}.td-eyebrow,.td-section-label{display:block;color:#59e3e4;text-transform:uppercase;letter-spacing:.22em;font-weight:900;font-size:13px}.td-eyebrow--small{font-size:11px;margin-bottom:5px}.td-hero-title{font-size:clamp(54px,7vw,104px);line-height:.92;margin:20px 0 22px;letter-spacing:-.06em;color:#fff}.td-hero-subtitle{font-size:22px;line-height:1.45;color:rgba(255,255,255,.72);max-width:640px}.td-hero-badges{display:flex;gap:10px;flex-wrap:wrap;margin:28px 0}.td-pill{display:inline-flex;padding:10px 13px;border-radius:999px;border:1px solid rgba(78,195,196,.22);background:rgba(4,14,17,.72);color:rgba(255,255,255,.78);font-weight:750;font-size:13px}.td-pill--strong{color:#68eeee;background:rgba(78,195,196,.12)}.td-key-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:auto}.td-metric-card{min-height:118px;border-radius:20px;padding:20px;background:rgba(0,8,12,.64);border:1px solid rgba(78,195,196,.18)}.td-metric-card span,.td-metric-card small{display:block;color:rgba(255,255,255,.58);font-size:13px}.td-metric-card strong{display:block;margin:8px 0 4px;font-size:25px;line-height:1.1}.td-mini-benefits{display:flex;flex-direction:column;gap:6px;margin-top:8px}.td-mini-benefits em,.proj-price-mini-chip{font-style:normal;color:#61e8e8;font-size:12px}.td-gallery-panel{padding:20px}.td-gallery-topbar{display:flex;justify-content:space-between;gap:16px;align-items:center;margin-bottom:16px;padding:8px 6px}.td-gallery-topbar strong{font-size:18px}.td-media-switch{display:flex;gap:8px}.td-media-switch .proj-media-switch-btn{border:1px solid rgba(78,195,196,.22);background:rgba(255,255,255,.04);color:rgba(255,255,255,.72);border-radius:999px;padding:9px 12px;font-weight:800;cursor:pointer}.td-media-switch .proj-media-switch-btn.is-active{background:#4ec3c4;color:#031010}.td-photo-grid,.td-gallery-panel .proj-gallery--dynamic{display:grid!important;grid-template-columns:1.35fr .8fr;grid-template-rows:260px 170px 170px;gap:12px}.td-photo-grid .proj-gallery-item:first-child,.td-gallery-panel .proj-gallery--dynamic .proj-gallery-item:first-child{grid-row:1/3}.td-photo-grid .proj-gallery-item:nth-child(4),.td-gallery-panel .proj-gallery--dynamic .proj-gallery-item:nth-child(4){grid-column:1/3}.td-photo-grid .proj-gallery-item:nth-child(n+5),.td-gallery-panel .proj-gallery--dynamic .proj-gallery-item:nth-child(n+5){display:none}.td-photo-item,.td-gallery-panel .proj-gallery-item{overflow:hidden;border-radius:20px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.05);min-height:120px}.td-photo-item img,.td-gallery-panel .proj-gallery-item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .45s ease}.td-photo-item:hover img,.td-gallery-panel .proj-gallery-item:hover img{transform:scale(1.04)}.td-gallery-placeholder{height:100%;display:grid;place-items:center;text-align:center;color:rgba(255,255,255,.45)}.td-plan-card{margin-top:12px;border-radius:20px;overflow:hidden;border:1px solid rgba(78,195,196,.18);background:rgba(0,0,0,.3)}.td-plan-card img{width:100%;max-height:340px;object-fit:contain;background:#0b1114}.td-decision-card{padding:28px;position:sticky;top:92px;align-self:start;border-color:rgba(78,195,196,.45);background:linear-gradient(150deg,rgba(16,82,82,.45),rgba(5,11,14,.85) 48%,rgba(5,8,9,.94))}.td-decision-header span{display:block;color:#5deaea;text-transform:uppercase;letter-spacing:.18em;font-size:12px;font-weight:900}.td-decision-header h2{font-size:35px;line-height:1.05;margin:12px 0;color:#fff}.td-decision-header p{color:rgba(255,255,255,.68);line-height:1.5}.td-selector-block{margin:24px 0}.td-typology-list{display:grid;gap:10px;margin-top:12px}.td-typology-option{width:100%;text-align:left;border:1px solid rgba(78,195,196,.24);background:rgba(0,8,12,.62);border-radius:18px;padding:18px 18px;color:#fff;cursor:pointer}.td-typology-option.is-active{border-color:#5eeeea;background:rgba(78,195,196,.12);box-shadow:0 0 0 1px rgba(78,195,196,.26) inset}.proj-typology-chip-title{display:block;font-weight:900;font-size:18px}.proj-typology-chip-meta{display:block;margin-top:5px;color:rgba(255,255,255,.6)}.td-live-card{border-radius:18px;padding:18px;background:rgba(0,0,0,.28);border:1px solid rgba(255,255,255,.12);display:grid;gap:6px}.td-live-card span{color:#59e3e4;text-transform:uppercase;letter-spacing:.15em;font-size:11px;font-weight:900}.td-live-card strong{font-size:22px}.td-live-card small,.td-live-card em{color:rgba(255,255,255,.64);font-style:normal}.td-primary-cta,.td-secondary-cta{display:flex;align-items:center;justify-content:center;width:100%;min-height:58px;border-radius:16px;margin-top:16px;text-decoration:none;font-weight:950}.td-primary-cta{background:linear-gradient(90deg,#4ec3c4,#56f0e8);color:#031010}.td-secondary-cta{border:1px solid rgba(78,195,196,.4);color:#fff;background:rgba(0,0,0,.16)}.td-section{margin-top:24px}.td-split-section{display:grid;grid-template-columns:1fr 1fr;gap:24px}.td-panel{padding:30px}.td-panel h2,.td-lead-copy h2{font-size:32px;margin:10px 0;color:#fff}.td-panel p,.td-lead-copy p{color:rgba(255,255,255,.68);line-height:1.6}.td-summary-dynamic{background:transparent!important;border:0!important;padding:0!important}.proj-typology-summary-top,.proj-typology-metrics,.proj-price-stack,.proj-opportunity-strip{margin-top:14px}.proj-typology-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.proj-typology-metric,.proj-opportunity-item,.proj-benefit-card,.td-info-card{border-radius:16px;padding:16px;background:rgba(0,8,12,.56);border:1px solid rgba(78,195,196,.15)}.proj-typology-metric span,.proj-opportunity-item span{display:block;color:rgba(255,255,255,.54);font-size:12px}.proj-typology-metric strong,.proj-opportunity-item strong{display:block;color:#fff;margin-top:4px}.proj-price-stack-new{font-size:26px;font-weight:950;color:#5deaea}.proj-price-stack-old{text-decoration:line-through;color:rgba(255,255,255,.45)}.proj-extras-grid{display:grid;gap:12px}.proj-extra-option{display:flex;align-items:center;justify-content:space-between;gap:12px;border-radius:16px;padding:16px;background:rgba(0,8,12,.58);border:1px solid rgba(78,195,196,.16);color:#fff}.proj-extra-option input{accent-color:#4ec3c4}.proj-extra-total{margin-top:14px;color:rgba(255,255,255,.66)}.proj-extra-total strong{color:#5deaea}.td-benefits-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.proj-benefit-title{font-weight:900;color:#5deaea;margin-bottom:6px}.proj-benefit-text{color:rgba(255,255,255,.75)}.td-calc-host{margin-top:22px;border-radius:22px!important;min-height:220px;background:rgba(0,8,12,.55)!important;border:1px dashed rgba(78,195,196,.28)!important}.td-info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:22px}.td-info-card--full{grid-column:1/-1}.td-photo-row{display:grid!important;grid-template-columns:repeat(5,1fr);gap:12px}.td-row-photo{height:170px;border-radius:18px;overflow:hidden}.td-row-photo img{width:100%;height:100%;object-fit:cover}.td-lead-form-panel{display:grid;grid-template-columns:.85fr 1.15fr;gap:30px;align-items:start;margin-top:24px;padding:34px}.td-form-card{background:rgba(0,8,12,.58)!important;border-color:rgba(78,195,196,.18)!important}.td-lead-copy{padding:10px 0}.amenity-chip{border:1px solid rgba(78,195,196,.18);background:rgba(78,195,196,.08);color:#fff;border-radius:999px;padding:9px 12px;display:inline-flex;margin:4px}.proj-feature-list{padding-left:18px;color:rgba(255,255,255,.72)}@media(max-width:1180px){.td-hero-grid{grid-template-columns:1fr}.td-hero-copy{min-height:auto}.td-decision-card{position:relative;top:auto}.td-split-section,.td-lead-form-panel{grid-template-columns:1fr}.td-benefits-grid,.td-info-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:760px){.td-single-redesign{padding:34px 0 70px}.td-single-shell{width:min(100% - 28px,1560px)}.td-hero-copy,.td-gallery-panel,.td-decision-card,.td-panel,.td-lead-form-panel{border-radius:22px;padding:22px}.td-hero-title{font-size:54px}.td-hero-subtitle{font-size:18px}.td-key-metrics,.td-benefits-grid,.td-info-grid{grid-template-columns:1fr}.td-photo-grid,.td-gallery-panel .proj-gallery--dynamic{grid-template-columns:1fr;grid-template-rows:none}.td-photo-grid .proj-gallery-item,.td-gallery-panel .proj-gallery--dynamic .proj-gallery-item{height:210px;grid-column:auto!important;grid-row:auto!important}.td-photo-grid .proj-gallery-item:nth-child(n+4),.td-gallery-panel .proj-gallery--dynamic .proj-gallery-item:nth-child(n+4){display:none}.td-gallery-topbar{align-items:flex-start;flex-direction:column}.td-panel h2,.td-lead-copy h2,.td-decision-header h2{font-size:27px}.proj-typology-metrics{grid-template-columns:1fr}.td-photo-row{grid-template-columns:1fr}.td-row-photo{height:210px}}

/* Manual mortgage simulation panel */
.td-manual-sim {
  margin: 22px 0;
  padding: 18px;
  border: 1px solid rgba(116, 255, 214, .18);
  border-radius: 24px;
  background: linear-gradient(135deg, rgba(14, 39, 43, .92), rgba(5, 18, 24, .92));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.06);
}
.td-manual-sim.is-active {
  border-color: rgba(116, 255, 214, .45);
  box-shadow: 0 20px 60px rgba(0,0,0,.25), 0 0 0 1px rgba(116,255,214,.12) inset;
}
.td-manual-sim__head {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: flex-start;
}
.td-manual-sim__head strong {
  display: block;
  color: #fff;
  font-size: clamp(18px, 2vw, 24px);
  margin-top: 4px;
}
.td-manual-sim__head p {
  margin: 6px 0 0;
  color: rgba(255,255,255,.68);
  max-width: 720px;
}
.td-switch {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  user-select: none;
  color: rgba(255,255,255,.82);
  font-weight: 700;
  white-space: nowrap;
}
.td-switch input { position: absolute; opacity: 0; pointer-events: none; }
.td-switch span {
  width: 54px;
  height: 30px;
  border-radius: 999px;
  background: rgba(255,255,255,.14);
  border: 1px solid rgba(255,255,255,.18);
  position: relative;
  transition: .2s ease;
}
.td-switch span::after {
  content: '';
  position: absolute;
  width: 22px;
  height: 22px;
  top: 3px;
  left: 4px;
  border-radius: 50%;
  background: #fff;
  transition: .2s ease;
}
.td-switch input:checked + span {
  background: rgba(116,255,214,.35);
  border-color: rgba(116,255,214,.55);
}
.td-switch input:checked + span::after { transform: translateX(23px); background: #74ffd6; }
.td-manual-sim__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-top: 18px;
}
.td-manual-sim__grid label {
  display: grid;
  gap: 8px;
  padding: 12px;
  border-radius: 18px;
  background: rgba(255,255,255,.055);
  border: 1px solid rgba(255,255,255,.10);
}
.td-manual-sim__grid label span {
  color: rgba(255,255,255,.70);
  font-size: 13px;
  font-weight: 700;
}
.td-manual-sim__grid input {
  width: 100%;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(2, 12, 16, .72);
  color: #fff;
  border-radius: 14px;
  padding: 12px 14px;
  font-weight: 800;
  outline: none;
}
.td-manual-sim__grid input:focus {
  border-color: rgba(116,255,214,.65);
  box-shadow: 0 0 0 3px rgba(116,255,214,.12);
}
.td-manual-sim__result {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid rgba(255,255,255,.10);
}
.td-manual-sim__result > div {
  flex: 1;
  padding: 14px;
  border-radius: 18px;
  background: rgba(116,255,214,.08);
  border: 1px solid rgba(116,255,214,.16);
}
.td-manual-sim__result span {
  display: block;
  color: rgba(255,255,255,.68);
  font-size: 13px;
  margin-bottom: 4px;
}
.td-manual-sim__result strong {
  color: #fff;
  font-size: 22px;
}
.td-manual-reset { border: 0; cursor: pointer; align-self: stretch; }
@media (max-width: 900px) {
  .td-manual-sim__head, .td-manual-sim__result { flex-direction: column; align-items: stretch; }
  .td-manual-sim__grid { grid-template-columns: 1fr; }
}
.td-manual-sim [hidden] { display: none !important; }

/* v1.1.25 — simulación manual más visible */
.td-manual-sim {
  outline: 2px solid rgba(116,255,214,.22);
  outline-offset: 4px;
}
.td-switch em {
  font-style: normal;
  color: #74ffd6;
}
.td-manual-sim__grid::before {
  content: 'Campos manuales opcionales';
  grid-column: 1 / -1;
  display: block;
  color: #74ffd6;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
  font-size: 12px;
}
.td-standard-bonus-card {
  display: grid;
  gap: 7px;
  padding: 12px;
  border-radius: 18px;
  background: rgba(116,255,214,.08);
  border: 1px solid rgba(116,255,214,.20);
}
.td-standard-bonus-card span {
  color: rgba(255,255,255,.70);
  font-size: 13px;
  font-weight: 700;
}
.td-standard-bonus-card strong {
  color: #74ffd6;
  font-size: 20px;
}
.td-standard-bonus-card small {
  color: rgba(255,255,255,.52);
  font-weight: 700;
}

/* Single proyecto – diseño limpio v1.1.27 */
.td-single-redesign{background:#f6f8f8;color:#061014;padding-bottom:48px;overflow:hidden}
.td-single-redesign .td-single-shell{max-width:1440px;margin:0 auto;padding:22px 32px 46px;position:relative;z-index:1}
.td-single-redesign .td-back-link{display:inline-flex;align-items:center;gap:8px;margin:0 0 18px;color:#34434a;font-weight:800;text-decoration:none}
.td-single-redesign .td-hero-grid{display:grid;grid-template-columns:minmax(0,1fr) 390px;gap:18px;align-items:start}
.td-single-redesign .td-hero-copy{position:relative;min-height:560px;border-radius:0 0 0 24px;overflow:hidden;color:#fff;padding:70px 54px 44px;background:linear-gradient(90deg,rgba(4,13,17,.96) 0%,rgba(4,13,17,.82) 48%,rgba(4,13,17,.34) 100%),var(--td-project-hero-bg,linear-gradient(135deg,#071217,#23333a));box-shadow:0 18px 50px rgba(6,16,20,.12)}
.td-single-redesign .td-hero-copy:before{content:"";position:absolute;inset:0;background:var(--td-project-hero-image,none) center/cover no-repeat;z-index:-2;opacity:.95}
.td-single-redesign .td-hero-copy:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(4,13,17,.96) 0%,rgba(4,13,17,.76) 50%,rgba(4,13,17,.22) 100%);z-index:-1}
.td-single-redesign .td-eyebrow{color:#16c7b7;font-size:17px;font-weight:900;letter-spacing:.14em;text-transform:uppercase;margin-bottom:18px}
.td-single-redesign .td-eyebrow--small{font-size:12px;letter-spacing:.16em;margin-bottom:6px;display:block}
.td-single-redesign .td-hero-title{font-size:clamp(48px,7vw,92px);line-height:.92;margin:0 0 22px;letter-spacing:-.065em;color:#fff}
.td-single-redesign .td-hero-subtitle{font-size:clamp(20px,2.2vw,29px);line-height:1.35;max-width:760px;color:#eef5f5;margin:0 0 42px}
.td-clean-dynamic-metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));background:rgba(6,16,20,.84);border:1px solid rgba(255,255,255,.18);border-radius:16px;backdrop-filter:blur(14px);overflow:hidden;margin-top:42px;max-width:100%}
.td-clean-metric-card{min-height:128px;display:flex;flex-direction:column;justify-content:center;padding:23px 26px;border-right:1px solid rgba(255,255,255,.16)}
.td-clean-metric-card:last-child{border-right:0}.td-clean-metric-card span{font-size:19px;line-height:1.25;color:#c5d0d4}.td-clean-metric-card strong{display:block;margin-top:8px;color:#fff;font-size:clamp(26px,2.4vw,34px);line-height:1.05;letter-spacing:-.035em}.td-clean-metric-card strong#tdMetricArriendo{font-size:clamp(23px,2vw,30px)}
.td-single-redesign .td-gallery-panel{background:#fff;border:1px solid #dfe8e8;border-radius:16px;padding:18px;box-shadow:0 8px 28px rgba(6,16,20,.06)}
.td-single-redesign .td-gallery-topbar{display:flex;justify-content:space-between;gap:16px;align-items:center;margin-bottom:16px}.td-single-redesign .td-gallery-topbar strong{display:block;font-size:18px;color:#061014}.td-single-redesign .td-media-switch{display:flex;gap:8px;background:#eef6f5;border-radius:999px;padding:5px}.td-single-redesign .proj-media-switch-btn{border:0;background:transparent;border-radius:999px;padding:8px 12px;font-weight:800;color:#0a8f84;cursor:pointer}.td-single-redesign .proj-media-switch-btn.is-active{background:#fff;color:#061014;box-shadow:0 3px 12px rgba(6,16,20,.08)}
.td-single-redesign .td-photo-grid,.td-single-redesign .proj-gallery--dynamic{display:grid;grid-template-columns:1.25fr .75fr;grid-template-rows:repeat(4,120px);gap:10px}.td-single-redesign .td-photo-item,.td-single-redesign .proj-gallery-item{border-radius:12px;overflow:hidden;background:#edf3f3}.td-single-redesign .td-photo-item--1,.td-single-redesign .proj-gallery-item:first-child{grid-row:span 4}.td-single-redesign .proj-gallery-item img,.td-single-redesign .td-photo-item img{width:100%;height:100%;object-fit:cover;display:block}.td-single-redesign .gallery-placeholder,.td-single-redesign .td-gallery-placeholder{height:100%;display:grid;place-items:center;text-align:center;color:#728086;background:#edf3f3}.td-single-redesign .proj-media-mode-label{display:none}.td-single-redesign .td-plan-card,.td-single-redesign .proj-plan-card{margin-top:12px;background:#f8fbfb;border:1px solid #dfe8e8;border-radius:12px;padding:12px}.td-single-redesign .proj-plan-card img{width:100%;height:auto;border-radius:8px}
.td-single-redesign .td-decision-card,.td-single-redesign .td-panel,.td-single-redesign .td-lead-form-panel{background:#fff;border:1px solid #dfe8e8;border-radius:16px;box-shadow:0 8px 28px rgba(6,16,20,.06)}
.td-single-redesign .td-decision-card{position:sticky;top:96px;padding:24px}.td-single-redesign .td-decision-header span,.td-single-redesign .td-section-label{color:#0a8f84;font-weight:900;letter-spacing:.12em;text-transform:uppercase;font-size:12px}.td-single-redesign .td-decision-header h2{font-size:28px;line-height:1.05;margin:8px 0 10px;color:#061014}.td-single-redesign .td-decision-header p,.td-single-redesign .td-panel p{color:#66737a;line-height:1.5}.td-single-redesign .td-typology-list{display:grid;gap:10px;margin:14px 0 20px}.td-single-redesign .td-typology-option{width:100%;text-align:left;border:1px solid #dfe8e8;background:#fff;border-radius:12px;padding:16px;cursor:pointer}.td-single-redesign .td-typology-option.is-active{border-color:#16c7b7;background:#effcfa}.td-single-redesign .proj-typology-chip-title{display:block;font-weight:900;color:#061014}.td-single-redesign .proj-typology-chip-meta{display:block;color:#66737a;margin-top:5px}.td-single-redesign .td-live-card{background:linear-gradient(135deg,#effcfa,#e7f8f4);border-radius:12px;padding:18px;margin:20px 0}.td-single-redesign .proj-sidebar-live-label{display:block;color:#0a8f84;font-weight:900;font-size:12px;text-transform:uppercase;letter-spacing:.12em}.td-single-redesign .proj-sidebar-live-title{display:block;font-size:24px;margin-top:8px}.td-single-redesign .proj-sidebar-live-meta,.td-single-redesign .proj-sidebar-live-note{display:block;color:#66737a;margin-top:6px}
.td-single-redesign .td-primary-cta,.td-single-redesign .td-secondary-cta{display:flex;align-items:center;justify-content:center;width:100%;min-height:54px;border-radius:10px;font-weight:900;text-decoration:none;margin-top:12px}.td-single-redesign .td-primary-cta{background:#061014;color:#fff}.td-single-redesign .td-secondary-cta{background:#fff;color:#0a8f84;border:1px solid #0a8f84}.td-single-redesign .td-section{margin-top:22px}.td-single-redesign .td-panel{padding:28px}.td-single-redesign .td-split-section{display:grid;grid-template-columns:1fr 1fr;gap:18px}.td-single-redesign .td-panel h2{color:#061014;font-size:30px;line-height:1.1;margin:10px 0 12px}.td-single-redesign .td-benefits-grid,.td-single-redesign .proj-benefits-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin-top:18px}.td-single-redesign .proj-benefit-card{background:#f7fbfb;border:1px solid #dfe8e8;border-radius:12px;padding:18px}.td-single-redesign .proj-benefit-title{font-weight:900;color:#061014}.td-single-redesign .proj-benefit-text{color:#66737a;margin-top:8px}.td-single-redesign .td-info-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;margin-top:18px}.td-single-redesign .td-info-card{background:#f7fbfb;border:1px solid #dfe8e8;border-radius:12px;padding:20px}.td-single-redesign .td-info-card--full{grid-column:1/-1}.td-single-redesign .proj-b-info-title{font-weight:900;margin-bottom:12px}.td-single-redesign .td-project-gallery .td-photo-row{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin-top:18px}.td-single-redesign .td-row-photo{height:160px;border-radius:12px;overflow:hidden}.td-single-redesign .td-row-photo img{width:100%;height:100%;object-fit:cover}.td-single-redesign .td-lead-form-panel{margin-top:28px;padding:28px;display:grid;grid-template-columns:.85fr 1.15fr;gap:28px;align-items:start}.td-single-redesign .td-lead-copy h2{font-size:34px;margin:10px 0}.td-single-redesign .td-form-card{box-shadow:none;border:1px solid #dfe8e8;border-radius:14px;background:#fff}
@media(max-width:1100px){.td-single-redesign .td-hero-grid{grid-template-columns:1fr}.td-single-redesign .td-decision-card{position:static}.td-single-redesign .td-hero-copy{min-height:auto}.td-single-redesign .td-gallery-panel{order:2}.td-single-redesign .td-decision-card{order:3}.td-single-redesign .td-split-section,.td-single-redesign .td-lead-form-panel{grid-template-columns:1fr}.td-single-redesign .td-photo-grid,.td-single-redesign .proj-gallery--dynamic{grid-template-rows:repeat(3,120px)}}
@media(max-width:720px){.td-single-redesign .td-single-shell{padding:18px}.td-single-redesign .td-hero-copy{padding:42px 24px 28px;border-radius:18px}.td-clean-dynamic-metrics{grid-template-columns:1fr;margin-top:28px}.td-clean-metric-card{border-right:0;border-bottom:1px solid rgba(255,255,255,.16);min-height:104px}.td-clean-metric-card:last-child{border-bottom:0}.td-single-redesign .td-photo-grid,.td-single-redesign .proj-gallery--dynamic{grid-template-columns:1fr;grid-template-rows:none}.td-single-redesign .proj-gallery-item,.td-single-redesign .td-photo-item{height:220px}.td-single-redesign .td-photo-item--1,.td-single-redesign .proj-gallery-item:first-child{grid-row:auto}.td-single-redesign .td-info-grid,.td-single-redesign .td-project-gallery .td-photo-row{grid-template-columns:1fr}.td-single-redesign .td-row-photo{height:220px}}


/* =========================================================
   v1.1.36 — Sistema tipográfico global TentuDepto
   Fuente display: Bebas Neue | Head: Syne | Body: DM Sans
   Este bloque alinea home, proyectos, single, tips, formularios y footer.
   ========================================================= */
:root{
  --font-display:'Bebas Neue', sans-serif;
  --font-head:'Syne', sans-serif;
  --font-body:'DM Sans', sans-serif;
}
html, body{
  font-family:var(--font-body);
  font-size:16px;
}
body,
p,
li,
input,
select,
textarea{
  font-family:var(--font-body) !important;
}
button,
.btn,
.nav-links a,
.nav-cta,
.footer-col-title,
.form-submit,
.section-label,
.td-section-label,
.eyebrow,
.badge,
.project-badge,
label{
  font-family:var(--font-head) !important;
}
.nav-links a{
  font-size:13px !important;
  font-weight:600 !important;
  letter-spacing:.08em !important;
  text-transform:uppercase !important;
}
.nav-cta,
button,
.btn,
.form-submit{
  font-size:14px !important;
  font-weight:700 !important;
  letter-spacing:.08em !important;
}
.nav-logo,
.hero-title,
.hero h1,
.section-title,
.section h1,
.section h2,
.final-form-title,
.footer-logo,
.metric-number,
.project-price,
.archive-title,
.page-title,
.entry-title,
.error-code{
  font-family:var(--font-display) !important;
  font-weight:400 !important;
  letter-spacing:.01em;
}
.hero-title,
.hero h1{
  font-size:clamp(72px,9vw,130px);
  line-height:.86;
}
.section-title,
.section h2,
.archive-title,
.page-title{
  font-size:clamp(44px,5vw,72px);
  line-height:.92;
}
.final-form-title{
  font-size:clamp(52px,6vw,90px);
  line-height:.92;
}
.section-label,
.td-section-label,
.eyebrow{
  font-size:11px;
  font-weight:800;
  letter-spacing:.12em;
  text-transform:uppercase;
}
.project-card h3,
.project-title,
.review-name{
  font-family:var(--font-head) !important;
  font-weight:700;
}
.project-card h3,
.project-title{font-size:18px;}
.project-card .project-type,
.project-meta,
.footer-desc,
.footer-links a,
.review-text{
  font-family:var(--font-body) !important;
}
.footer-col-title{
  font-size:12px !important;
  letter-spacing:.14em !important;
  text-transform:uppercase !important;
}
.footer-links a,
.footer-desc{font-size:14px !important;}
.footer-bottom{font-family:var(--font-body) !important;font-size:13px !important;}

/* Single Proyecto: hereda el look del home sin interferir con el plugin calculadora */
.td-clean-single{
  font-family:var(--font-body) !important;
}
.td-clean-single .hero h1{
  font-family:var(--font-display) !important;
  font-size:clamp(72px,9vw,130px) !important;
  line-height:.86 !important;
  font-weight:400 !important;
}
.td-clean-single .lead{
  font-family:var(--font-head) !important;
  font-size:clamp(14px,1.5vw,17px) !important;
  line-height:1.65 !important;
}
.td-clean-single .metric strong,
.td-clean-single .price-box strong,
.td-clean-single .result strong{
  font-family:var(--font-display) !important;
  font-weight:400 !important;
}
.td-clean-single .metric span,
.td-clean-single .mini-icons div,
.td-clean-single .row,
.td-clean-single .note,
.td-clean-single .project-description p{
  font-family:var(--font-body) !important;
}
.td-clean-single .panel h3,
.td-clean-single .panel h4,
.td-clean-single label,
.td-clean-single .select-card strong,
.td-clean-single .btn,
.td-clean-single .td-form .form-submit{
  font-family:var(--font-head) !important;
}
.td-clean-single .section h2,
.td-clean-single .project-description h2,
.td-clean-single .cta-strip h2,
.td-clean-single .td-lead-horizontal__copy h2{
  font-family:var(--font-display) !important;
  font-size:clamp(44px,5vw,72px) !important;
  line-height:.92 !important;
  font-weight:400 !important;
}
