 .pp-section {
            padding: 40px 0 !important;
            clear: both !important;
            display: block !important;
            width: 100% !important;
        }
        .pp-section::after {
            content: "";
            display: table;
            clear: both;
        }

        .pp-occasions {
            display: flex !important;
            flex-wrap: wrap !important;
            gap: 10px !important;
            margin: 18px 0 10px 0 !important;
            padding: 0 !important;
            list-style: none !important;
        }
        .pp-occasions span {
            display: inline-block !important;
            background: #fdf3f7 !important;
            color: #b8336a !important;
            padding: 8px 16px !important;
            border-radius: 30px !important;
            font-size: 14px !important;
            font-weight: 600 !important;
            border: 1px solid #f0dde6 !important;
            line-height: 1.2 !important;
        }

        .pp-flavors-wrap {
            padding: 40px 0 !important;
            clear: both !important;
            width: 100% !important;
            display: block !important;
        }
        .pp-flavors-wrap .row {
            margin-bottom: 20px !important;
        }
        .pp-card {
            background: #ffffff !important;
            border: 1px solid #f0e6e6 !important;
            border-radius: 14px !important;
            padding: 25px 28px !important;
            margin-bottom: 25px !important;
            box-shadow: 0 4px 18px rgba(0,0,0,0.06) !important;
            transition: transform .3s ease, box-shadow .3s ease !important;
        }
        .pp-card:hover {
            transform: translateY(-4px) !important;
            box-shadow: 0 10px 26px rgba(0,0,0,0.10) !important;
        }
        .pp-card h3 {
            font-size: 22px !important;
            margin: 0 0 15px 0 !important;
            color: #b8336a !important;
            border-bottom: 2px solid #f5d6e3 !important;
            padding-bottom: 10px !important;
            font-weight: 700 !important;
        }
        .pp-card.premium h3 {
            color: #8a5a00 !important;
            border-bottom-color: #f3e2b3 !important;
        }
        .pp-card.fillings h3 {
            color: #7a4321 !important;
            border-bottom-color: #f2dcc8 !important;
        }
        .pp-card.fillings-premium h3 {
            color: #5c3d8a !important;
            border-bottom-color: #e0d3f0 !important;
        }
        .pp-card ul {
            list-style: none !important;
            padding: 0 !important;
            margin: 0 !important;
        }
        .pp-card ul li {
            padding: 9px 0 9px 28px !important;
            position: relative !important;
            border-bottom: 1px dashed #f1eaea !important;
            font-size: 15px !important;
            color: #555 !important;
            line-height: 1.4 !important;
        }
        .pp-card ul li:last-child {
            border-bottom: none !important;
        }
        .pp-card ul li:before {
            content: "🎂";
            position: absolute;
            left: 0;
            top: 8px;
            font-size: 14px;
        }
        .pp-card.premium ul li:before { content: "⭐"; }
        .pp-card.fillings ul li:before { content: "🍮"; }
        .pp-card.fillings-premium ul li:before { content: "✨"; }

        .pp-form-section {
            background: linear-gradient(135deg, #fff8fb 0%, #fef3e7 100%) !important;
            padding: 60px 20px !important;
            margin: 40px 0 !important;
            border-radius: 14px !important;
            clear: both !important;
            display: block !important;
            width: 100% !important;
            box-sizing: border-box !important;
        }
        .pp-form-wrapper {
            background: #ffffff !important;
            padding: 40px !important;
            border-radius: 14px !important;
            box-shadow: 0 6px 25px rgba(0,0,0,0.08) !important;
            max-width: 720px !important;
            margin: 0 auto !important;
            box-sizing: border-box !important;
        }
        .pp-form-wrapper h2 {
            text-align: center !important;
            color: #b8336a !important;
            margin: 0 0 10px 0 !important;
            font-size: 28px !important;
        }
        .pp-form-wrapper .pp-subtitle {
            text-align: center !important;
            color: #777 !important;
            margin: 0 0 30px 0 !important;
            font-size: 15px !important;
        }
        .pp-form-wrapper label {
            display: block !important;
            font-weight: 600 !important;
            color: #444 !important;
            margin: 16px 0 6px 0 !important;
            font-size: 15px !important;
        }
        .pp-form-wrapper input[type="text"],
        .pp-form-wrapper input[type="tel"],
        .pp-form-wrapper input[type="date"],
        .pp-form-wrapper input[type="file"],
        .pp-form-wrapper textarea {
            width: 100% !important;
            padding: 12px 14px !important;
            border: 1px solid #e0d4d4 !important;
            border-radius: 8px !important;
            font-size: 15px !important;
            background: #fdfafa !important;
            box-sizing: border-box !important;
            font-family: inherit !important;
        }
        .pp-form-wrapper input:focus,
        .pp-form-wrapper textarea:focus {
            outline: none !important;
            border-color: #b8336a !important;
        }
        .pp-form-wrapper textarea {
            min-height: 110px !important;
            resize: vertical !important;
        }
        .pp-radio-group {
            display: flex !important;
            flex-wrap: wrap !important;
            gap: 10px !important;
            margin-top: 8px !important;
        }
        .pp-radio-group label {
            display: inline-flex !important;
            align-items: center !important;
            gap: 8px !important;
            font-weight: 400 !important;
            background: #fdf3f7 !important;
            padding: 10px 16px !important;
            border-radius: 30px !important;
            cursor: pointer !important;
            margin: 0 !important;
            border: 1px solid #f0dde6 !important;
            font-size: 14px !important;
            color: #555 !important;
        }
        .pp-radio-group input[type="radio"] {
            margin: 0 !important;
        }
        .pp-submit-btn {
            display: block !important;
            width: 100% !important;
            background: linear-gradient(135deg, #b8336a 0%, #e85a8a 100%) !important;
            color: #ffffff !important;
            border: none !important;
            padding: 15px !important;
            border-radius: 8px !important;
            font-size: 17px !important;
            font-weight: 600 !important;
            cursor: pointer !important;
            margin-top: 28px !important;
            transition: transform .2s, box-shadow .2s !important;
        }
        .pp-submit-btn:hover {
            transform: translateY(-2px) !important;
            box-shadow: 0 6px 18px rgba(184,51,106,0.35) !important;
        }
        .pp-success-msg {
            display: none;
            background: #e8f7ee !important;
            color: #1d6b3a !important;
            padding: 18px !important;
            border-radius: 8px !important;
            text-align: center !important;
            margin-top: 20px !important;
            font-size: 15px !important;
            border: 1px solid #b6e2c5 !important;
        }

        .pp-gallery-item {
            margin-bottom: 25px !important;
            text-align: center !important;
        }
        .pp-gallery-item img {
            max-width: 100% !important;
            height: auto !important;
            border-radius: 10px !important;
            box-shadow: 0 4px 14px rgba(0,0,0,0.08) !important;
        }
        .pp-gallery-item p {
            margin-top: 10px !important;
            font-weight: 600 !important;
            color: #555 !important;
        }

        .pp-heading {
            text-align: center !important;
            margin: 30px 0 25px 0 !important;
            clear: both !important;
        }
        .pp-heading h2 {
            color: #b8336a !important;
            font-weight: 700 !important;
        }

        @media (max-width: 768px) {
            .pp-form-wrapper {
                padding: 25px 20px !important;
            }
            .pp-form-section {
                padding: 30px 10px !important;
            }
        }

.pp-section {
    padding: 40px 0 !important;
    clear: both !important;
    display: block !important;
    width: 100% !important;
}
.pp-section::after {
    content: "";
    display: table;
    clear: both;
}

.pp-occasions {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 10px !important;
    margin: 18px 0 10px 0 !important;
    padding: 0 !important;
    list-style: none !important;
}
.pp-occasions span {
    display: inline-block !important;
    background: #fdf3f7 !important;
    color: #b8336a !important;
    padding: 8px 16px !important;
    border-radius: 30px !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    border: 1px solid #f0dde6 !important;
    line-height: 1.2 !important;
}

.pp-flavors-wrap {
    padding: 40px 0 !important;
    clear: both !important;
    width: 100% !important;
    display: block !important;
}
.pp-flavors-wrap .row {
    margin-bottom: 20px !important;
}
.pp-card {
    background: #ffffff !important;
    border: 1px solid #f0e6e6 !important;
    border-radius: 14px !important;
    padding: 25px 28px !important;
    margin-bottom: 25px !important;
    box-shadow: 0 4px 18px rgba(0,0,0,0.06) !important;
    transition: transform .3s ease, box-shadow .3s ease !important;
}
.pp-card:hover {
    transform: translateY(-4px) !important;
    box-shadow: 0 10px 26px rgba(0,0,0,0.10) !important;
}
.pp-card h3 {
    font-size: 22px !important;
    margin: 0 0 15px 0 !important;
    color: #b8336a !important;
    border-bottom: 2px solid #f5d6e3 !important;
    padding-bottom: 10px !important;
    font-weight: 700 !important;
}
.pp-card.premium h3 {
    color: #8a5a00 !important;
    border-bottom-color: #f3e2b3 !important;
}
.pp-card.fillings h3 {
    color: #7a4321 !important;
    border-bottom-color: #f2dcc8 !important;
}
.pp-card.fillings-premium h3 {
    color: #5c3d8a !important;
    border-bottom-color: #e0d3f0 !important;
}
.pp-card ul {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
}
.pp-card ul li {
    padding: 9px 0 9px 28px !important;
    position: relative !important;
    border-bottom: 1px dashed #f1eaea !important;
    font-size: 15px !important;
    color: #555 !important;
    line-height: 1.4 !important;
}
.pp-card ul li:last-child {
    border-bottom: none !important;
}
.pp-card ul li:before {
    content: "🎂";
    position: absolute;
    left: 0;
    top: 8px;
    font-size: 14px;
}
.pp-card.premium ul li:before { content: "⭐"; }
.pp-card.fillings ul li:before { content: "🍮"; }
.pp-card.fillings-premium ul li:before { content: "✨"; }

.pp-form-section {
    background: linear-gradient(135deg, #fff8fb 0%, #fef3e7 100%) !important;
    padding: 60px 20px !important;
    margin: 40px 0 !important;
    border-radius: 14px !important;
    clear: both !important;
    display: block !important;
    width: 100% !important;
    box-sizing: border-box !important;
}
.pp-form-wrapper {
    background: #ffffff !important;
    padding: 40px !important;
    border-radius: 14px !important;
    box-shadow: 0 6px 25px rgba(0,0,0,0.08) !important;
    max-width: 720px !important;
    margin: 0 auto !important;
    box-sizing: border-box !important;
}
.pp-form-wrapper h2 {
    text-align: center !important;
    color: #b8336a !important;
    margin: 0 0 10px 0 !important;
    font-size: 28px !important;
}
.pp-form-wrapper .pp-subtitle {
    text-align: center !important;
    color: #777 !important;
    margin: 0 0 30px 0 !important;
    font-size: 15px !important;
}
.pp-form-wrapper label {
    display: block !important;
    font-weight: 600 !important;
    color: #444 !important;
    margin: 16px 0 6px 0 !important;
    font-size: 15px !important;
}
.pp-form-wrapper input[type="text"],
.pp-form-wrapper input[type="tel"],
.pp-form-wrapper input[type="date"],
.pp-form-wrapper input[type="file"],
.pp-form-wrapper textarea {
    width: 100% !important;
    padding: 12px 14px !important;
    border: 1px solid #e0d4d4 !important;
    border-radius: 8px !important;
    font-size: 15px !important;
    background: #fdfafa !important;
    box-sizing: border-box !important;
    font-family: inherit !important;
}
.pp-form-wrapper input:focus,
.pp-form-wrapper textarea:focus {
    outline: none !important;
    border-color: #b8336a !important;
}
.pp-form-wrapper textarea {
    min-height: 110px !important;
    resize: vertical !important;
}
.pp-radio-group {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 10px !important;
    margin-top: 8px !important;
}
.pp-radio-group label {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    font-weight: 400 !important;
    background: #fdf3f7 !important;
    padding: 10px 16px !important;
    border-radius: 30px !important;
    cursor: pointer !important;
    margin: 0 !important;
    border: 1px solid #f0dde6 !important;
    font-size: 14px !important;
    color: #555 !important;
}
.pp-radio-group input[type="radio"] {
    margin: 0 !important;
}
.pp-submit-btn {
    display: block !important;
    width: 100% !important;
    background: linear-gradient(135deg, #b8336a 0%, #e85a8a 100%) !important;
    color: #ffffff !important;
    border: none !important;
    padding: 15px !important;
    border-radius: 8px !important;
    font-size: 17px !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    margin-top: 28px !important;
    transition: transform .2s, box-shadow .2s !important;
}
.pp-submit-btn:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 6px 18px rgba(184,51,106,0.35) !important;
}
.pp-success-msg {
    display: none;
    background: #e8f7ee !important;
    color: #1d6b3a !important;
    padding: 18px !important;
    border-radius: 8px !important;
    text-align: center !important;
    margin-top: 20px !important;
    font-size: 15px !important;
    border: 1px solid #b6e2c5 !important;
}

.pp-gallery-item {
    margin-bottom: 25px !important;
    text-align: center !important;
}
.pp-gallery-item img {
    max-width: 100% !important;
    height: auto !important;
    border-radius: 10px !important;
    box-shadow: 0 4px 14px rgba(0,0,0,0.08) !important;
}
.pp-gallery-item p {
    margin-top: 10px !important;
    font-weight: 600 !important;
    color: #555 !important;
}

.pp-heading {
    text-align: center !important;
    margin: 30px 0 25px 0 !important;
    clear: both !important;
}
.pp-heading h2 {
    color: #b8336a !important;
    font-weight: 700 !important;
}

@media (max-width: 768px) {
    .pp-form-wrapper {
        padding: 25px 20px !important;
    }
    .pp-form-section {
        padding: 30px 10px !important;
    }
}

/* ── GALERÍA PASTELES RESPONSIVE ── */
.pp-gallery-item img {
    width: 100% !important;
    height: 280px !important;
    object-fit: cover !important;
    border-radius: 10px !important;
    display: block !important;
}

.pp-gallery-item p {
    margin-top: 10px !important;
    font-weight: 600 !important;
    color: #555 !important;
    text-align: center !important;
    font-size: 14px !important;
}

.pp-gallery-item {
    margin-bottom: 25px !important;
}

/* Tablet: 2 columnas */
@media (max-width: 991px) and (min-width: 577px) {
    .pp-section .col-sm-6 {
        width: 50% !important;
        float: left !important;
    }
    .pp-gallery-item img {
        height: 240px !important;
    }
}

/* Móvil: 2 columnas pequeñas */
@media (max-width: 576px) {
    .pp-section .row {
        display: flex !important;
        flex-wrap: wrap !important;
    }
    .pp-section .col-xs-6,
    .pp-section .col-sm-6 {
        width: 50% !important;
        float: left !important;
        padding: 6px !important;
    }
    .pp-gallery-item img {
        height: 160px !important;
    }
    .pp-gallery-item p {
        font-size: 12px !important;
    }
}

/* Móvil muy pequeño: 1 columna */
@media (max-width: 360px) {
    .pp-section .col-xs-6,
    .pp-section .col-sm-6 {
        width: 100% !important;
        float: none !important;
    }
    .pp-gallery-item img {
        height: 200px !important;
    }
}

/* Clearfix para filas con float */
.pp-section .row::after {
    content: "";
    display: table;
    clear: both;
}
 :root {
    --rose: #c94b6e;
    --rose-light: #fceef3;
    --rose-mid: #e8a0b8;
    --rose-dark: #8a2a45;
    --cream: #fdf8f2;
    --warm: #f5ede0;
    --brown: #7a4e2d;
    --brown-light: #f0e4d4;
    --plum: #6b3fa0;
    --plum-light: #f0e8fa;
    --text: #2c1a14;
    --text-muted: #7a6060;
    --white: #ffffff;
    --border: rgba(201,75,110,0.15);
    --gold: #c89a3a;
  }

  * { box-sizing: border-box; margin: 0; padding: 0; }

  body {
    font-family: 'DM Sans', sans-serif;
    background: var(--cream);
    color: var(--text);
    overflow-x: hidden;
  }

  /* ── HERO ── */
  .hero {
    background: linear-gradient(135deg, #261904 0%, #6a580a 50%, #341e00 100%);
    min-height: 92vh;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 80px 24px 60px;
    position: relative;
    overflow: hidden;
  }
  .hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse 80% 60% at 50% 40%, rgba(201,75,110,0.18) 0%, transparent 70%);
  }
  .hero-dots {
    position: absolute;
    inset: 0;
    background-image: radial-gradient(rgba(255,255,255,0.06) 1px, transparent 1px);
    background-size: 32px 32px;
  }
  .hero-badge {
    display: inline-block;
    background: rgba(201,75,110,0.25);
    border: 1px solid rgba(201,75,110,0.5);
    color: var(--rose-mid);
    font-size: 12px;
    font-weight: 500;
    letter-spacing: 2px;
    text-transform: uppercase;
    padding: 8px 20px;
    border-radius: 30px;
    margin-bottom: 28px;
    position: relative;
  }
  .hero h1 {
    font-family: 'Playfair Display', serif;
    font-size: clamp(42px, 8vw, 90px);
    color: #fff;
    line-height: 1.05;
    position: relative;
    max-width: 900px;
    margin-bottom: 12px;
  }
  .hero h1 em {
    font-style: italic;
    color: var(--rose-mid);
  }
  .hero-sub {
    font-size: 18px;
    color: rgba(255,255,255,0.6);
    max-width: 580px;
    line-height: 1.7;
    position: relative;
    margin-bottom: 44px;
  }
  .hero-actions {
    display: flex;
    gap: 14px;
    flex-wrap: wrap;
    justify-content: center;
    position: relative;
  }
  .btn-primary {
    background: var(--rose);
    color: #fff;
    padding: 15px 34px;
    border-radius: 50px;
    font-size: 16px;
    font-weight: 500;
    text-decoration: none;
    transition: transform 0.2s, background 0.2s;
    display: inline-flex;
    align-items: center;
    gap: 8px;
  }
  .btn-primary:hover { transform: translateY(-2px); background: var(--rose-dark); }
  .btn-outline {
    background: transparent;
    color: rgba(255,255,255,0.85);
    border: 1px solid rgba(255,255,255,0.3);
    padding: 15px 34px;
    border-radius: 50px;
    font-size: 16px;
    font-weight: 400;
    text-decoration: none;
    transition: border-color 0.2s, color 0.2s;
  }
  .btn-outline:hover { border-color: rgba(255,255,255,0.7); color: #fff; }
  .hero-scroll {
    position: absolute;
    bottom: 32px;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
    color: rgba(255,255,255,0.3);
    font-size: 11px;
    letter-spacing: 1px;
    text-transform: uppercase;
  }
  .hero-scroll-line {
    width: 1px;
    height: 40px;
    background: linear-gradient(to bottom, rgba(255,255,255,0.3), transparent);
    animation: scrollpulse 2s ease-in-out infinite;
  }
  @keyframes scrollpulse { 0%,100%{opacity:0.4} 50%{opacity:1} }

  /* ── SECTION BASE ── */
  section { padding: 90px 24px; }
  .container { max-width: 1100px; margin: 0 auto; }
  .section-label {
    font-size: 11px;
    letter-spacing: 3px;
    text-transform: uppercase;
    color: var(--rose);
    font-weight: 500;
    margin-bottom: 14px;
  }
  .section-title {
    font-family: 'Playfair Display', serif;
    font-size: clamp(30px, 5vw, 52px);
    line-height: 1.15;
    color: var(--text);
    margin-bottom: 20px;
  }
  .section-body {
    font-size: 16px;
    line-height: 1.8;
    color: var(--text-muted);
    max-width: 640px;
  }

  /* ── INTRO / CUPCAKES ── */
  .intro { background: var(--white); }
  .intro-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 80px;
    align-items: center;
  }
  .intro-visual {
    background: var(--rose-light);
    border-radius: 24px;
    aspect-ratio: 4/5;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    position: relative;
  }
  .intro-visual-inner {
    font-size: 100px;
    line-height: 1;
    text-align: center;
  }
  .intro-visual-tag {
    position: absolute;
    bottom: 24px;
    left: 24px;
    right: 24px;
    background: rgba(255,255,255,0.92);
    backdrop-filter: blur(8px);
    border-radius: 14px;
    padding: 16px 20px;
    display: flex;
    align-items: center;
    gap: 14px;
  }
  .intro-visual-tag-icon { font-size: 28px; }
  .intro-visual-tag-text p:first-child { font-size: 13px; font-weight: 500; color: var(--text); }
  .intro-visual-tag-text p:last-child { font-size: 12px; color: var(--text-muted); }

  .checkmarks { margin-top: 28px; display: flex; flex-direction: column; gap: 12px; }
  .check-item {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    font-size: 15px;
    color: var(--text-muted);
    line-height: 1.5;
  }
  .check-dot {
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background: var(--rose-light);
    color: var(--rose);
    font-size: 12px;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    margin-top: 2px;
  }

  /* ── TORTAS SECTION ── */
  .tortas { background: var(--warm); }
  .tortas-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 20px;
    margin-top: 50px;
  }
  .torta-card {
    background: var(--white);
    border-radius: 18px;
    padding: 28px 22px;
    border: 1px solid rgba(0,0,0,0.06);
    transition: transform 0.25s, box-shadow 0.25s;
  }
  .torta-card:hover { transform: translateY(-5px); box-shadow: 0 16px 40px rgba(0,0,0,0.1); }
  .torta-card-icon {
    width: 54px;
    height: 54px;
    border-radius: 14px;
    background: var(--rose-light);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 26px;
    margin-bottom: 18px;
  }
  .torta-card h3 {
    font-family: 'Playfair Display', serif;
    font-size: 19px;
    color: var(--rose-dark);
    margin-bottom: 10px;
  }
  .torta-card p { font-size: 14px; color: var(--text-muted); line-height: 1.7; }

  /* ── MASAS Y RELLENOS ── */
  .masas { background: var(--white); }
  .masas-intro {
    max-width: 680px;
    margin: 0 auto 60px;
    text-align: center;
  }
  .masas-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 24px;
  }
  .masa-card {
    border-radius: 20px;
    padding: 32px;
    position: relative;
    overflow: hidden;
  }
  .masa-card.clasica { background: var(--rose-light); }
  .masa-card.premium { background: #fdf4e3; }
  .masa-card.relleno-c { background: var(--brown-light); }
  .masa-card.relleno-p { background: var(--plum-light); }
  .masa-card-head {
    display: flex;
    align-items: center;
    gap: 14px;
    margin-bottom: 24px;
    padding-bottom: 16px;
    border-bottom: 1px dashed rgba(0,0,0,0.1);
  }
  .masa-card-icon { font-size: 28px; }
  .masa-card h3 {
    font-family: 'Playfair Display', serif;
    font-size: 20px;
  }
  .masa-card.clasica h3 { color: var(--rose-dark); }
  .masa-card.premium h3 { color: var(--brown); }
  .masa-card.relleno-c h3 { color: #6b3a1f; }
  .masa-card.relleno-p h3 { color: var(--plum); }
  .masa-tag-list { display: flex; flex-wrap: wrap; gap: 8px; }
  .masa-tag {
    font-size: 13px;
    font-weight: 500;
    padding: 5px 14px;
    border-radius: 20px;
    background: rgba(255,255,255,0.7);
    color: var(--text);
  }

  /* ── PASTELES PERSONALIZADOS ── */
  .pasteles { background: var(--cream); }
  .pasteles-intro-grid {
    display: grid;
    grid-template-columns: 1.2fr 1fr;
    gap: 70px;
    align-items: center;
    margin-bottom: 70px;
  }
  .occasions-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 24px;
  }
  .occasion-pill {
    background: var(--white);
    border: 1px solid var(--border);
    color: var(--rose);
    font-size: 13px;
    font-weight: 500;
    padding: 8px 18px;
    border-radius: 30px;
    display: flex;
    align-items: center;
    gap: 6px;
  }
  .occasion-icon { font-size: 14px; }

  .pasteles-visual-stack {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
  }
  .p-visual-card {
    border-radius: 18px;
    aspect-ratio: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    font-size: 40px;
    font-weight: 400;
    position: relative;
    overflow: hidden;
  }
  .p-visual-card:nth-child(1) { background: #fce8ef; grid-row: span 2; aspect-ratio: auto; }
  .p-visual-card:nth-child(2) { background: #fdf4e3; }
  .p-visual-card:nth-child(3) { background: var(--plum-light); }
  .p-visual-label {
    font-size: 12px;
    font-weight: 500;
    color: var(--text-muted);
    margin-top: 8px;
    font-family: 'DM Sans', sans-serif;
  }

  /* ── POSTRES ── */
  .postres { background: var(--warm); }
  .postres-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 22px;
    margin-top: 50px;
  }
  .postre-card {
    background: var(--white);
    border-radius: 18px;
    padding: 28px 24px;
    transition: transform 0.2s;
    border: 1px solid rgba(0,0,0,0.05);
  }
  .postre-card:hover { transform: translateY(-4px); }
  .postre-icon {
    font-size: 36px;
    margin-bottom: 16px;
    display: block;
  }
  .postre-card h3 {
    font-size: 16px;
    font-weight: 500;
    color: var(--text);
    margin-bottom: 8px;
  }
  .postre-card p { font-size: 14px; color: var(--text-muted); line-height: 1.6; }

  /* ── FORM ── */
  .formulario { background: #1a0a10; }
  .form-wrap {
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.1);
    border-radius: 28px;
    padding: 56px 48px;
    max-width: 740px;
    margin: 0 auto;
  }
  .form-wrap .section-label { color: var(--rose-mid); }
  .form-wrap .section-title { color: #fff; }
  .form-wrap .section-body { color: rgba(255,255,255,0.5); margin-bottom: 40px; }

  .form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
  .form-group { margin-bottom: 22px; }
  .form-group label {
    display: block;
    font-size: 13px;
    font-weight: 500;
    color: rgba(255,255,255,0.6);
    margin-bottom: 8px;
    text-transform: uppercase;
    letter-spacing: 0.8px;
  }
  .form-group input,
  .form-group textarea,
  .form-group select {
    width: 100%;
    background: rgba(255,255,255,0.07);
    border: 1px solid rgba(255,255,255,0.12);
    border-radius: 12px;
    padding: 14px 18px;
    font-size: 15px;
    color: #fff;
    font-family: 'DM Sans', sans-serif;
    outline: none;
    transition: border-color 0.2s;
    appearance: none;
  }
  .form-group input::placeholder,
  .form-group textarea::placeholder { color: rgba(255,255,255,0.25); }
  .form-group input:focus,
  .form-group textarea:focus,
  .form-group select:focus { border-color: var(--rose); }
  .form-group textarea { min-height: 120px; resize: vertical; }
  .form-group select option { background: #2c1a14; color: #fff; }

  .radio-pills { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 2px; }
  .radio-pill {
    position: relative;
    cursor: pointer;
  }
  .radio-pill input { position: absolute; opacity: 0; width: 0; height: 0; }
  .radio-pill span {
    display: inline-block;
    background: rgba(255,255,255,0.07);
    border: 1px solid rgba(255,255,255,0.12);
    color: rgba(255,255,255,0.65);
    font-size: 14px;
    padding: 9px 18px;
    border-radius: 30px;
    cursor: pointer;
    transition: all 0.18s;
  }
  .radio-pill input:checked + span {
    background: rgba(201,75,110,0.25);
    border-color: var(--rose);
    color: var(--rose-mid);
  }

  .btn-submit {
    width: 100%;
    background: linear-gradient(135deg, var(--rose-dark), var(--rose));
    color: #fff;
    border: none;
    padding: 17px;
    border-radius: 14px;
    font-size: 16px;
    font-weight: 500;
    font-family: 'DM Sans', sans-serif;
    cursor: pointer;
    margin-top: 10px;
    transition: transform 0.2s, opacity 0.2s;
    letter-spacing: 0.3px;
  }
  .btn-submit:hover { transform: translateY(-2px); opacity: 0.92; }

  .success-msg {
    display: none;
    background: rgba(30,100,60,0.3);
    border: 1px solid rgba(80,200,120,0.4);
    color: #7de8a8;
    border-radius: 12px;
    padding: 18px 22px;
    text-align: center;
    font-size: 15px;
    margin-top: 20px;
  }

  /* ── FOOTER ── */
  footer {
    background: #120609;
    padding: 70px 24px 40px;
    color: rgba(255,255,255,0.45);
  }
  .footer-grid {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr;
    gap: 60px;
    max-width: 1100px;
    margin: 0 auto 50px;
  }
  .footer-brand h2 {
    font-family: 'Playfair Display', serif;
    font-size: 28px;
    color: #fff;
    margin-bottom: 8px;
  }
  .footer-brand p { font-size: 14px; line-height: 1.7; max-width: 320px; }
  .footer-col h4 {
    font-size: 13px;
    font-weight: 500;
    color: rgba(255,255,255,0.7);
    letter-spacing: 1px;
    text-transform: uppercase;
    margin-bottom: 18px;
  }
  .footer-col ul { list-style: none; }
  .footer-col li { font-size: 14px; margin-bottom: 10px; }
  .footer-divider {
    max-width: 1100px;
    margin: 0 auto;
    border: none;
    border-top: 1px solid rgba(255,255,255,0.07);
    margin-bottom: 28px;
  }
  .footer-bottom {
    max-width: 1100px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 13px;
    flex-wrap: wrap;
    gap: 12px;
  }

  /* ── WHATSAPP ── */
  .wa-float {
    position: fixed;
    bottom: 28px;
    right: 28px;
    z-index: 999;
    width: 58px;
    height: 58px;
    background: #25d366;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 6px 24px rgba(37,211,102,0.4);
    cursor: pointer;
    text-decoration: none;
    transition: transform 0.2s;
    animation: wapulse 3s ease-in-out infinite;
  }
  .wa-float:hover { transform: scale(1.1); }
  @keyframes wapulse {
    0%,100%{box-shadow:0 6px 24px rgba(37,211,102,0.4)}
    50%{box-shadow:0 6px 32px rgba(37,211,102,0.65)}
  }
  .wa-float svg { width: 30px; height: 30px; fill: #fff; }

  /* ── NAV ── */
  nav {
    position: fixed;
    top: 0; left: 0; right: 0;
    z-index: 100;
    background: rgba(18,6,9,0.85);
    backdrop-filter: blur(12px);
    padding: 0 32px;
    border-bottom: 1px solid rgba(255,255,255,0.06);
  }
  .nav-inner {
    max-width: 1100px;
    margin: 0 auto;
    height: 64px;
    display: flex;
    align-items: center;
    justify-content: space-between;
  }
  .nav-logo {
    font-family: 'Playfair Display', serif;
    font-size: 22px;
    color: #fff;
    text-decoration: none;
    font-style: italic;
  }
  .nav-logo span { color: var(--rose-mid); font-style: normal; }
  .nav-links { display: flex; gap: 32px; }
  .nav-links a {
    font-size: 14px;
    color: rgba(255,255,255,0.6);
    text-decoration: none;
    transition: color 0.2s;
  }
  .nav-links a:hover { color: #fff; }
  .nav-wa {
    background: rgba(37,211,102,0.15);
    border: 1px solid rgba(37,211,102,0.35);
    color: #25d366;
    font-size: 13px;
    font-weight: 500;
    padding: 8px 18px;
    border-radius: 30px;
    text-decoration: none;
    transition: background 0.2s;
  }
  .nav-wa:hover { background: rgba(37,211,102,0.25); }

  /* ── DIVIDER ── */
  .wave-divider { display: block; line-height: 0; }
  .wave-divider svg { display: block; width: 100%; }

  /* ── RESPONSIVE ── */
  @media (max-width: 860px) {
    .intro-grid, .pasteles-intro-grid, .footer-grid { grid-template-columns: 1fr; gap: 40px; }
    .intro-visual { aspect-ratio: 16/9; }
    .masas-grid { grid-template-columns: 1fr; }
    .form-row { grid-template-columns: 1fr; }
    .form-wrap { padding: 36px 24px; }
    .nav-links { display: none; }
    .footer-grid { grid-template-columns: 1fr; gap: 36px; }
  }

.instagram-card {
  max-width: 420px;
  border-radius: 20px;
  overflow: hidden;
  background: linear-gradient(135deg, #833ab4, #fd1d1d, #fcb045);
  padding: 2px;
  margin: 30px auto;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.instagram-card a {
  display: block;
  background: #fff;
  color: #333;
  text-decoration: none;
  border-radius: 18px;
  padding: 20px;
}

.instagram-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 10px 30px rgba(0,0,0,0.2);
}

.ig-header {
  display: flex;
  align-items: center;
  gap: 10px;
  font-weight: bold;
  margin-bottom: 10px;
}

.ig-header img {
  width: 28px;
}

.ig-content h3 {
  margin: 10px 0 5px;
}

.ig-content p {
  font-size: 14px;
  color: #666;
}

.ig-cta {
  margin-top: 15px;
  font-weight: bold;
  color: #E1306C;
}
.ig-preview {
  max-width: 400px;
  margin: auto;
  text-align: center;
}

.ig-preview .grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 5px;
  margin-bottom: 10px;
}

.ig-preview img {
  width: 100%;
  border-radius: 10px;
}

.ig-preview span {
  font-weight: bold;
  color: #E1306C;
}
.maps-card {
  max-width: 420px;
  border-radius: 20px;
  overflow: hidden;
  background: linear-gradient(135deg, #34a853, #4285f4);
  padding: 2px;
  margin: 30px auto;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.maps-card a {
  display: block;
  background: #fff;
  color: #333;
  text-decoration: none;
  border-radius: 18px;
  padding: 20px;
}

.maps-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 10px 30px rgba(0,0,0,0.2);
}

.maps-header {
  display: flex;
  align-items: center;
  gap: 10px;
  font-weight: bold;
  margin-bottom: 10px;
}

.maps-header img {
  width: 28px;
}

.maps-content h3 {
  margin: 10px 0 5px;
}

.maps-content p {
  font-size: 14px;
  color: #666;
}

.maps-cta {
  margin-top: 15px;
  font-weight: bold;
  color: #34a853;
}
.maps-card,
.instagram-card {
  width: 100%;
  max-width: 420px;
}
.intro-visual {
  display: flex;
  flex-direction: column; /* 👈 ESTO ES LO IMPORTANTE */
  gap: 20px; /* espacio entre tarjetas */
  align-items: center; /* opcional: centra */
}