/* ============================================================
   DietaGo · Sistema de diseño moderno 2026
   Rediseño completo de la landing — independiente de la plantilla.
   Todo está scopeado bajo .dg / .dg-header / .dg-footer para
   no colisionar con el CSS legacy (style.css, bootstrap, etc.)
   ============================================================ */

:root {
    /* Marca */
    --dg-green: #678300;
    --dg-green-600: #5a7300;
    --dg-green-700: #44560a;
    --dg-green-900: #1f2b07;
    --dg-lime: #aee03a;
    --dg-lime-bright: #c6f24b;
    --dg-mint: #eaf5d4;
    --dg-mint-soft: #f4f9e8;

    /* Neutros */
    --dg-ink: #11180a;
    --dg-body: #4d5942;
    --dg-muted: #7d876f;
    --dg-line: #e7ecdc;
    --dg-cream: #f7f9f0;
    --dg-white: #ffffff;

    /* Gradientes */
    --dg-grad-brand: linear-gradient(135deg, #7ba000 0%, #4f6b00 100%);
    --dg-grad-lime: linear-gradient(135deg, #c6f24b 0%, #7ba000 100%);
    --dg-grad-dark: linear-gradient(160deg, #20300a 0%, #0e1606 100%);

    /* Sombras */
    --dg-shadow-sm: 0 2px 8px rgba(31, 43, 7, 0.06);
    --dg-shadow-md: 0 14px 40px -12px rgba(31, 43, 7, 0.18);
    --dg-shadow-lg: 0 30px 70px -20px rgba(31, 43, 7, 0.28);
    --dg-shadow-glow: 0 20px 60px -15px rgba(123, 160, 0, 0.55);

    /* Radios */
    --dg-r-sm: 14px;
    --dg-r-md: 22px;
    --dg-r-lg: 32px;
    --dg-r-pill: 999px;

    --dg-font-head: 'Outfit', system-ui, -apple-system, sans-serif;
    --dg-font-body: 'Inter', system-ui, -apple-system, sans-serif;

    --dg-ease: cubic-bezier(0.22, 1, 0.36, 1);
}

/* ---------- Reset scopeado ---------- */
.dg, .dg-header, .dg-footer { font-family: var(--dg-font-body); }

.dg *, .dg-header *, .dg-footer * { box-sizing: border-box; }

.dg, .dg *,
.dg-header, .dg-header *,
.dg-footer, .dg-footer * {
    -webkit-font-smoothing: antialiased;
}

.dg h1, .dg h2, .dg h3, .dg h4,
.dg-header h1, .dg-header h2, .dg-header h3,
.dg-footer h2, .dg-footer h3 {
    font-family: var(--dg-font-head);
    color: var(--dg-ink);
    line-height: 1.08;
    letter-spacing: -0.02em;
    margin: 0;
    font-weight: 700;
}

.dg p { margin: 0; color: var(--dg-body); line-height: 1.65; }
.dg a { text-decoration: none; color: inherit; }
.dg img { max-width: 100%; display: block; }
.dg ul { list-style: none; margin: 0; padding: 0; }

.dg-wrap {
    width: min(1200px, 100% - 48px);
    margin-inline: auto;
}

/* ---------- Botones ---------- */
.dg-btn {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-family: var(--dg-font-head);
    font-weight: 600;
    font-size: 1rem;
    line-height: 1;
    padding: 16px 28px;
    border-radius: var(--dg-r-pill);
    border: 0;
    cursor: pointer;
    transition: transform .35s var(--dg-ease), box-shadow .35s var(--dg-ease), background .3s;
    white-space: nowrap;
}
.dg-btn--primary {
    background: var(--dg-grad-brand);
    color: #fff;
    box-shadow: var(--dg-shadow-glow);
}
.dg-btn--primary:hover { transform: translateY(-3px); box-shadow: 0 26px 70px -16px rgba(123,160,0,.7); color:#fff; }
.dg-btn--dark { background: var(--dg-ink); color: #fff; }
.dg-btn--dark:hover { transform: translateY(-3px); color:#fff; box-shadow: var(--dg-shadow-lg); }
.dg-btn--ghost {
    background: rgba(255,255,255,.7);
    color: var(--dg-ink);
    border: 1px solid var(--dg-line);
    backdrop-filter: blur(8px);
}
.dg-btn--ghost:hover { transform: translateY(-3px); border-color: var(--dg-green); color: var(--dg-green-700); }

/* Store badges */
.dg-store {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    padding: 12px 22px;
    border-radius: 16px;
    background: var(--dg-ink);
    color: #fff;
    transition: transform .35s var(--dg-ease), box-shadow .35s var(--dg-ease);
}
.dg-store:hover { transform: translateY(-3px); color:#fff; box-shadow: var(--dg-shadow-md); }
.dg-store i { font-size: 1.8rem; line-height: 1; }
.dg-store span { display: flex; flex-direction: column; line-height: 1.15; text-align: left; }
.dg-store span small { font-size: .72rem; opacity: .92; font-weight: 400; letter-spacing: .03em; margin-bottom: 2px; }
.dg-store span b { font-family: var(--dg-font-head); font-size: 1.08rem; font-weight: 600; }
/* Forzamos color (gana al global app.css `a{color:#006bb7}`) */
.dg-store, .dg-store span, .dg-store b, .dg-store small, .dg-store i { color: #fff; }
.dg-store--light, .dg-store--light span, .dg-store--light b,
.dg-store--light small, .dg-store--light i { color: var(--dg-ink); }
.dg-store--light { background: #fff; border: 1px solid var(--dg-line); }
.dg-store--light:hover { color: var(--dg-ink); }
.dg-store--light span small { opacity: .65; }

/* ---------- Fix artefactos legacy (cursor custom + scroll-top roto) ---------- */
.cursor, .cursor-follower { display: none !important; }
.progress-wrap {
    opacity: 0; visibility: hidden;
    transition: opacity .3s, visibility .3s;
}
.progress-wrap.active-progress { opacity: 1; visibility: visible; }

/* ---------- Pill / eyebrow ---------- */
.dg-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-family: var(--dg-font-head);
    font-weight: 600;
    font-size: .82rem;
    letter-spacing: .06em;
    text-transform: uppercase;
    color: var(--dg-green-700);
    background: var(--dg-mint);
    padding: 8px 16px;
    border-radius: var(--dg-r-pill);
}
.dg-eyebrow i { color: var(--dg-green); }

/* ===========================================================
   HEADER
   =========================================================== */
.dg-header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 900;
    transition: background .45s, box-shadow .45s, padding .45s, backdrop-filter .45s;
    padding: 20px 0;
    background: transparent;
    border-bottom: 1px solid transparent;
}
.dg-header.is-stuck {
    padding: 12px 0;
    background: rgba(255,255,255,0.96);
    backdrop-filter: saturate(180%) blur(20px);
    -webkit-backdrop-filter: saturate(180%) blur(20px);
    box-shadow: 0 2px 24px rgba(31,43,7,.09);
    border-bottom-color: var(--dg-line);
}
.dg-header__inner {
    width: min(1200px, 100% - 48px);
    margin-inline: auto;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
}
.dg-header__logo img { height: 42px; width: auto; }
.dg-nav { display: flex; align-items: center; gap: 6px; }
.dg-nav a {
    font-family: var(--dg-font-head);
    font-weight: 500;
    font-size: .98rem;
    color: var(--dg-ink);
    padding: 10px 16px;
    border-radius: var(--dg-r-pill);
    transition: background .25s, color .25s;
}
.dg-nav a:hover { background: var(--dg-mint); color: var(--dg-green-700); }
.dg-header__cta { display: flex; align-items: center; gap: 10px; }
.dg-header__cta .dg-store { padding: 9px 16px; }
.dg-header__cta .dg-store i { font-size: 1.3rem; }

.dg-burger {
    display: none;
    width: 46px; height: 46px;
    border-radius: 14px;
    border: 1px solid var(--dg-line);
    background: #fff;
    color: var(--dg-ink);
    font-size: 1.2rem;
    cursor: pointer;
    align-items: center;
    justify-content: center;
}

/* Mobile drawer */
.dg-drawer {
    position: fixed;
    inset: 0;
    z-index: 1000;
    display: grid;
    grid-template-columns: 1fr;
    pointer-events: none;
}
.dg-drawer__scrim {
    position: absolute; inset: 0;
    background: rgba(17,24,10,.5);
    backdrop-filter: blur(4px);
    opacity: 0; transition: opacity .4s;
}
.dg-drawer__panel {
    position: absolute; top: 0; right: 0; bottom: 0;
    width: min(360px, 86vw);
    background: var(--dg-white);
    padding: 28px 26px;
    transform: translateX(100%);
    transition: transform .45s var(--dg-ease);
    display: flex; flex-direction: column; gap: 8px;
    box-shadow: var(--dg-shadow-lg);
}
.dg-drawer.is-open { pointer-events: auto; }
.dg-drawer.is-open .dg-drawer__scrim { opacity: 1; }
.dg-drawer.is-open .dg-drawer__panel { transform: translateX(0); }
.dg-drawer__head { display:flex; align-items:center; justify-content:space-between; margin-bottom: 14px; }
.dg-drawer__head img { height: 38px; }
.dg-drawer__close { width:44px; height:44px; border-radius:12px; border:1px solid var(--dg-line); background:#fff; font-size:1.2rem; cursor:pointer; }
.dg-drawer a.dg-drawer__link {
    display:flex; align-items:center; gap:14px;
    font-family: var(--dg-font-head); font-weight: 500; font-size: 1.1rem;
    padding: 16px 14px; border-radius: var(--dg-r-md); color: var(--dg-ink);
}
.dg-drawer a.dg-drawer__link:hover { background: var(--dg-mint-soft); }
.dg-drawer a.dg-drawer__link i { color: var(--dg-green); width: 24px; text-align:center; }
.dg-drawer__cta { margin-top: auto; display:flex; flex-direction:column; gap:12px; }

/* ===========================================================
   HERO
   =========================================================== */
.dg-hero {
    position: relative;
    overflow: hidden;
    padding: clamp(126px, 15vw, 160px) 0 clamp(48px, 6vw, 80px);
    background:
        radial-gradient(110% 90% at 80% -15%, rgba(174,224,58,.48) 0%, transparent 50%),
        radial-gradient(80% 100% at 0% 105%, rgba(123,160,0,.22) 0%, transparent 55%),
        var(--dg-cream);
}
.dg-hero__grid {
    width: min(1200px, 100% - 48px);
    margin-inline: auto;
    display: grid;
    grid-template-columns: 1.05fr 0.95fr;
    align-items: center;
    gap: 48px;
}
.dg-hero__title {
    font-size: clamp(2.6rem, 6vw, 4.6rem);
    line-height: 1.02;
    margin: 22px 0 0;
}
.dg-hero__title .dg-grad {
    background: var(--dg-grad-brand);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}
.dg-hero__lead {
    font-size: clamp(1.05rem, 1.6vw, 1.3rem);
    color: var(--dg-body);
    max-width: 540px;
    margin-top: 22px;
}
.dg-hero__actions { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 34px; }
.dg-hero__trust {
    display: flex; align-items: center; gap: 20px;
    margin-top: 34px; flex-wrap: wrap;
}
.dg-hero__stars { color: #f5b513; font-size: 1.1rem; letter-spacing: 2px; }
.dg-hero__trust small { color: var(--dg-muted); font-size: .92rem; }
.dg-hero__trust b { color: var(--dg-ink); font-family: var(--dg-font-head); }
.dg-avatars { display: flex; }
.dg-avatars span {
    width: 40px; height: 40px; border-radius: 50%;
    border: 3px solid var(--dg-cream);
    margin-left: -12px;
    background: var(--dg-grad-lime);
    display: grid; place-items: center;
    font-size: 1.1rem;
}
.dg-avatars span:first-child { margin-left: 0; }

/* Hero visual: phone mockup + floating cards + mascota */
.dg-hero__visual { position: relative; display: grid; place-items: center; min-height: 480px; }
.dg-phone {
    position: relative;
    width: min(320px, 78%);
    aspect-ratio: 320 / 600;
    border-radius: 46px;
    background: var(--dg-grad-dark);
    padding: 12px;
    box-shadow: var(--dg-shadow-lg);
    z-index: 2;
    transform: rotate(-3deg);
}
.dg-phone__screen {
    width: 100%; height: 100%;
    border-radius: 36px;
    overflow: hidden;
    background: #fff;
    position: relative;
}
.dg-phone__screen img { width: 100%; height: 100%; object-fit: cover; }
.dg-phone__notch {
    position: absolute; top: 14px; left: 50%; transform: translateX(-50%);
    width: 110px; height: 26px; border-radius: 999px; background: #0e1606; z-index: 3;
}
.dg-blob {
    position: absolute;
    border-radius: 50%;
    filter: blur(8px);
    z-index: 0;
}
.dg-blob--1 { width: 320px; height: 320px; background: radial-gradient(circle, rgba(174,224,58,.6), transparent 70%); top: -30px; right: -40px; }
.dg-blob--2 { width: 260px; height: 260px; background: radial-gradient(circle, rgba(123,160,0,.4), transparent 70%); bottom: -20px; left: -30px; }

.dg-float {
    position: absolute;
    background: rgba(255,255,255,.85);
    backdrop-filter: blur(12px);
    border: 1px solid rgba(255,255,255,.6);
    border-radius: var(--dg-r-md);
    box-shadow: var(--dg-shadow-md);
    padding: 14px 18px;
    z-index: 3;
    display: flex; align-items: center; gap: 12px;
    animation: dg-bob 5s ease-in-out infinite;
}
.dg-float__ico {
    width: 44px; height: 44px; border-radius: 14px;
    display: grid; place-items: center; font-size: 1.4rem;
    background: var(--dg-mint); flex-shrink: 0;
}
.dg-float small { display:block; color: var(--dg-muted); font-size: .72rem; }
.dg-float b { font-family: var(--dg-font-head); font-size: 1.05rem; color: var(--dg-ink); }
.dg-float--a { top: 8%; left: -4%; animation-delay: 0s; }
.dg-float--b { bottom: 14%; right: -6%; animation-delay: 1.2s; }
.dg-float--c { bottom: -2%; left: 8%; animation-delay: 2.1s; }
@keyframes dg-bob { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-12px); } }

.dg-mascota {
    position: absolute;
    width: 120px; bottom: -10px; right: 2%;
    z-index: 4;
    filter: drop-shadow(0 18px 22px rgba(31,43,7,.25));
    animation: dg-bob 6s ease-in-out infinite;
}

/* ===========================================================
   MARQUEE / STATS
   =========================================================== */
.dg-stats {
    background: var(--dg-ink);
    color: #fff;
    padding: 44px 0;
}
.dg-stats__grid {
    width: min(1100px, 100% - 48px);
    margin-inline: auto;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
    text-align: center;
}
.dg-stats__item h3 {
    font-size: clamp(2.2rem, 4vw, 3.2rem);
    color: #fff;
    background: var(--dg-grad-lime);
    -webkit-background-clip: text; background-clip: text; color: transparent;
}
.dg-stats__item p { color: rgba(255,255,255,.65); margin-top: 4px; font-size: .95rem; }

/* ===========================================================
   SECTION HEADER
   =========================================================== */
.dg-section { padding: clamp(40px, 4.5vw, 64px) 0; }
.dg-section--cream { background: var(--dg-cream); }
.dg-head { text-align: center; max-width: 680px; margin: 0 auto clamp(28px, 3.5vw, 44px); }
.dg-head .dg-eyebrow { margin-bottom: 18px; }
.dg-head h2 { font-size: clamp(2rem, 4.5vw, 3.2rem); }
.dg-head p { margin-top: 16px; font-size: 1.1rem; }

/* ===========================================================
   BENTO FEATURES
   =========================================================== */
.dg-bento {
    width: min(1200px, 100% - 48px);
    margin-inline: auto;
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 20px;
}
.dg-card {
    background: #fff;
    border: 1px solid var(--dg-line);
    border-radius: var(--dg-r-lg);
    padding: 30px;
    position: relative;
    overflow: hidden;
    transition: transform .4s var(--dg-ease), box-shadow .4s var(--dg-ease), border-color .4s;
}
.dg-card:hover { transform: translateY(-6px); box-shadow: var(--dg-shadow-md); border-color: transparent; }
.dg-card__ico {
    width: 58px; height: 58px;
    border-radius: 18px;
    display: grid; place-items: center;
    font-size: 1.7rem;
    background: var(--dg-mint);
    margin-bottom: 18px;
}
.dg-card__ico i {
    font-size: 1.55rem;
    background: var(--dg-grad-brand);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}
.dg-card--feature .dg-card__ico i,
.dg-card--dark .dg-card__ico i {
    background: none;
    -webkit-background-clip: unset;
    background-clip: unset;
    color: var(--dg-lime-bright);
}
.dg-card h3 { font-size: 1.3rem; margin-bottom: 10px; }
.dg-card p { font-size: .98rem; }

/* spans */
.dg-card--lg { grid-column: span 4; }
.dg-card--sm { grid-column: span 2; }
.dg-card--md { grid-column: span 3; }

/* Featured card with brand gradient */
.dg-card--feature {
    grid-column: span 4;
    background: var(--dg-grad-brand);
    color: #fff;
    border: none;
    display: flex; flex-direction: column; justify-content: flex-end;
    min-height: 280px;
}
.dg-card--feature h3, .dg-card--feature p { color: #fff; }
.dg-card--feature p { color: rgba(255,255,255,.85); }
.dg-card--feature .dg-card__ico { background: rgba(255,255,255,.2); }
.dg-card--feature::after {
    content: '';
    position: absolute; width: 280px; height: 280px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(255,255,255,.25), transparent 70%);
    top: -80px; right: -60px;
}
.dg-card--dark {
    grid-column: span 2;
    background: var(--dg-grad-dark);
    color:#fff; border:none;
}
.dg-card--dark h3, .dg-card--dark p { color:#fff; }
.dg-card--dark p { color: rgba(255,255,255,.7); }
.dg-card--dark .dg-card__ico { background: rgba(174,224,58,.18); }

/* ===========================================================
   HOW IT WORKS
   =========================================================== */
.dg-steps {
    width: min(1100px, 100% - 48px);
    margin-inline: auto;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 26px;
    position: relative;
}
.dg-step {
    background: #fff;
    border: 1px solid var(--dg-line);
    border-radius: var(--dg-r-lg);
    padding: 36px 30px;
    text-align: center;
    position: relative;
    transition: transform .4s var(--dg-ease), box-shadow .4s var(--dg-ease);
}
.dg-step:hover { transform: translateY(-6px); box-shadow: var(--dg-shadow-md); }
.dg-step__num {
    width: 64px; height: 64px;
    margin: 0 auto 22px;
    border-radius: 50%;
    background: var(--dg-grad-brand);
    color: #fff;
    font-family: var(--dg-font-head);
    font-weight: 700; font-size: 1.5rem;
    display: grid; place-items: center;
    box-shadow: var(--dg-shadow-glow);
}
.dg-step h3 { font-size: 1.35rem; margin-bottom: 12px; }

/* ===========================================================
   TESTIMONIALS
   =========================================================== */
.dg-quotes {
    width: min(1200px, 100% - 48px);
    margin-inline: auto;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
}
.dg-quote {
    background: #fff;
    border: 1px solid var(--dg-line);
    border-radius: var(--dg-r-lg);
    padding: 34px 30px;
    display: flex; flex-direction: column; gap: 18px;
    transition: transform .4s var(--dg-ease), box-shadow .4s var(--dg-ease);
}
.dg-quote:hover { transform: translateY(-6px); box-shadow: var(--dg-shadow-md); }
.dg-quote__stars { color: #f5b513; letter-spacing: 2px; }
.dg-quote p { font-size: 1.05rem; color: var(--dg-ink); }
.dg-quote__author { display: flex; align-items: center; gap: 14px; margin-top: auto; }
.dg-quote__avatar {
    width: 50px; height: 50px; border-radius: 50%;
    background: var(--dg-grad-lime);
    display: grid; place-items: center;
    font-family: var(--dg-font-head); font-weight: 700; color: var(--dg-green-900);
    font-size: 1.2rem;
}
.dg-quote__author b { font-family: var(--dg-font-head); display:block; color: var(--dg-ink); }
.dg-quote__author small { color: var(--dg-muted); }

/* ===========================================================
   DOWNLOAD CTA
   =========================================================== */
.dg-download { padding: clamp(28px, 3.5vw, 48px) 0; }
.dg-download__panel {
    width: min(1200px, 100% - 48px);
    margin-inline: auto;
    background: var(--dg-grad-dark);
    border-radius: clamp(28px, 4vw, 44px);
    padding: clamp(40px, 6vw, 70px);
    position: relative;
    overflow: hidden;
    display: grid;
    grid-template-columns: 1.1fr .9fr;
    align-items: center;
    gap: 40px;
}
.dg-download__panel::before {
    content:''; position:absolute; width: 420px; height: 420px; border-radius:50%;
    background: radial-gradient(circle, rgba(174,224,58,.4), transparent 65%);
    top: -120px; right: -80px;
}
.dg-download__content { position: relative; z-index: 2; }
.dg-download h2 { color:#fff; font-size: clamp(2rem, 4vw, 3rem); }
.dg-download p { color: rgba(255,255,255,.75); margin-top: 16px; font-size: 1.1rem; max-width: 460px; }
.dg-download__actions { display:flex; flex-wrap: wrap; gap: 14px; margin-top: 30px; }
.dg-download__visual { position: relative; z-index: 2; display:grid; place-items:center; }
.dg-download__visual img { width: min(280px, 80%); border-radius: 28px; box-shadow: var(--dg-shadow-lg); transform: rotate(3deg); }

/* ===========================================================
   FAQ
   =========================================================== */
.dg-faq {
    width: min(820px, 100% - 48px);
    margin-inline: auto;
    display: flex; flex-direction: column; gap: 14px;
}
.dg-faq__item {
    background: #fff;
    border: 1px solid var(--dg-line);
    border-radius: var(--dg-r-md);
    padding: 0 26px;
    cursor: pointer;
    transition: border-color .3s, box-shadow .3s;
}
.dg-faq__item:hover { border-color: var(--dg-green); }
.dg-faq__item.is-open { border-color: var(--dg-green); box-shadow: var(--dg-shadow-sm); }
.dg-faq__q {
    display: flex; align-items: center; justify-content: space-between; gap: 16px;
    font-family: var(--dg-font-head); font-weight: 600; font-size: 1.12rem;
    color: var(--dg-ink); padding: 24px 0;
}
.dg-faq__q i { color: var(--dg-green); transition: transform .35s var(--dg-ease); flex-shrink: 0; }
.dg-faq__item.is-open .dg-faq__q i { transform: rotate(45deg); }
.dg-faq__a {
    display: grid; grid-template-rows: 0fr;
    transition: grid-template-rows .4s var(--dg-ease);
}
.dg-faq__item.is-open .dg-faq__a { grid-template-rows: 1fr; }
.dg-faq__a > div { overflow: hidden; }
.dg-faq__a p { padding-bottom: 24px; color: var(--dg-body); }

/* ===========================================================
   FOOTER
   =========================================================== */
.dg-footer {
    background: var(--dg-grad-dark);
    color: rgba(255,255,255,.72);
    padding: clamp(60px, 8vw, 96px) 0 0;
}
.dg-footer__inner {
    width: min(1200px, 100% - 48px);
    margin-inline: auto;
    display: grid;
    grid-template-columns: 1.6fr 1fr 1fr;
    gap: 48px;
    padding-bottom: 56px;
}
.dg-footer__logo img { height: 46px; margin-bottom: 22px; }
.dg-footer p { color: rgba(255,255,255,.65); max-width: 360px; }
.dg-footer h3 { color: #fff; font-size: 1.1rem; margin-bottom: 22px; font-family: var(--dg-font-head); }
.dg-footer__list li { margin-bottom: 14px; }
.dg-footer__list a { color: rgba(255,255,255,.8) !important; transition: color .25s; }
.dg-footer__list a:hover { color: var(--dg-lime) !important; }
.dg-footer__contact a { color: #fff !important; }
.dg-footer__contact li { display: flex; gap: 14px; align-items: center; margin-bottom: 18px; }
.dg-footer__contact i {
    width: 42px; height: 42px; border-radius: 50%;
    background: rgba(255,255,255,.08); color: var(--dg-lime);
    display: grid; place-items: center; flex-shrink: 0;
}
.dg-footer__contact small { display:block; color: rgba(255,255,255,.45); font-size: .8rem; }
.dg-footer__contact b { color:#fff; font-weight: 500; }
.dg-footer__social { display:flex; gap: 12px; margin-top: 24px; }
.dg-footer__social a {
    width: 46px; height: 46px; border-radius: 14px;
    background: rgba(255,255,255,.16); color:#fff !important;
    border: 1px solid rgba(255,255,255,.18);
    display:grid; place-items:center; font-size: 1.15rem;
    transition: background .25s, transform .25s, border-color .25s;
}
.dg-footer__social a i { color:#fff !important; }
.dg-footer__social a:hover { background: var(--dg-lime); border-color: transparent; transform: translateY(-3px); }
.dg-footer__social a:hover i { color: var(--dg-green-900) !important; }
.dg-footer__bottom {
    border-top: 1px solid rgba(255,255,255,.1);
    padding: 24px clamp(16px, 4vw, 48px);
    width: min(1200px, 100% - 48px);
    margin-inline: auto;
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 8px;
    font-size: .88rem;
    color: rgba(255,255,255,.45);
}
.dg-footer__bottom a { color: #fff !important; font-weight: 500; transition: opacity .25s; }
.dg-footer__bottom a:hover { opacity: .7; }

/* ===========================================================
   MARQUEE (tira de beneficios)
   =========================================================== */
.dg-marquee {
    background: var(--dg-grad-brand);
    overflow: hidden;
    padding: 18px 0;
}
.dg-marquee__track {
    display: flex;
    gap: 48px;
    width: max-content;
    animation: dg-scroll 28s linear infinite;
}
.dg-marquee:hover .dg-marquee__track { animation-play-state: paused; }
.dg-marquee__item {
    display: inline-flex; align-items: center; gap: 12px;
    color: #fff; font-family: var(--dg-font-head); font-weight: 600;
    font-size: 1.15rem; white-space: nowrap;
}
.dg-marquee__item i { color: var(--dg-lime-bright); }
@keyframes dg-scroll { to { transform: translateX(-50%); } }

/* ===========================================================
   SHOWCASE (filas alternas con ilustración)
   =========================================================== */
.dg-showcase { display: flex; flex-direction: column; gap: clamp(48px, 6vw, 80px); }
.dg-show {
    width: min(1140px, 100% - 48px);
    margin-inline: auto;
    display: grid;
    grid-template-columns: 1fr 1fr;
    align-items: center;
    gap: clamp(32px, 6vw, 80px);
}
.dg-show:nth-child(even) .dg-show__media { order: 2; }
.dg-show__media {
    position: relative;
    border-radius: var(--dg-r-lg);
    padding: clamp(28px, 5vw, 56px);
    display: grid; place-items: center;
    aspect-ratio: 1 / 0.82;
    overflow: hidden;
}
.dg-show__media--mint { background: radial-gradient(120% 120% at 30% 20%, #f4f9e8, #dcefbe); }
.dg-show__media--sky  { background: radial-gradient(120% 120% at 30% 20%, #eaf4fb, #cfe6f6); }
.dg-show__media--peach{ background: radial-gradient(120% 120% at 30% 20%, #fdf0e8, #f7d9c6); }
.dg-show__media img { width: 96%; height: auto; }
.dg-show__tag {
    display:inline-flex; align-items:center; gap:8px;
    font-family: var(--dg-font-head); font-weight:600; font-size:.82rem;
    text-transform: uppercase; letter-spacing:.06em;
    color: var(--dg-green-700); background: var(--dg-mint);
    padding: 8px 16px; border-radius: var(--dg-r-pill); margin-bottom: 18px;
}
.dg-show__copy h3 { font-size: clamp(1.7rem, 3.2vw, 2.6rem); margin-bottom: 16px; }
.dg-show__copy p { font-size: 1.1rem; }
.dg-show__list { margin-top: 22px; display:flex; flex-direction:column; gap:12px; }
.dg-show__list li { display:flex; align-items:center; gap:12px; color: var(--dg-ink); font-weight: 500; }
.dg-show__list i {
    width: 26px; height: 26px; border-radius: 50%; flex-shrink:0;
    background: var(--dg-green); color:#fff; display:grid; place-items:center; font-size:.7rem;
}

/* ===========================================================
   DIETAS (nube de etiquetas)
   =========================================================== */
.dg-diets-wrap {
    width: min(1000px, 100% - 48px);
    margin-inline: auto;
    display: flex; flex-wrap: wrap; gap: 14px; justify-content: center;
}
.dg-diet {
    display:inline-flex; align-items:center; gap:10px;
    background:#fff; border:1px solid var(--dg-line);
    padding: 14px 24px; border-radius: var(--dg-r-pill);
    font-family: var(--dg-font-head); font-weight: 600; font-size: 1.05rem; color: var(--dg-ink);
    transition: transform .35s var(--dg-ease), border-color .35s, background .35s, color .35s;
    cursor: default;
}
.dg-diet:hover { transform: translateY(-4px); background: var(--dg-grad-brand); color:#fff; border-color: transparent; box-shadow: var(--dg-shadow-glow); }
.dg-diet span { font-size: 1.3rem; }

/* ===========================================================
   GAMIFICACIÓN (historia de la mascota)
   =========================================================== */
.dg-game {
    position: relative; overflow: hidden;
    background: var(--dg-grad-dark);
    padding: clamp(64px, 9vw, 110px) 0;
}
.dg-game::before {
    content:''; position:absolute; width:500px; height:500px; border-radius:50%;
    background: radial-gradient(circle, rgba(174,224,58,.25), transparent 65%);
    top:-160px; left:-120px;
}
.dg-game .dg-head h2, .dg-game .dg-head p { color:#fff; }
.dg-game .dg-head p { color: rgba(255,255,255,.7); }
.dg-game .dg-eyebrow { background: rgba(255,255,255,.12); color: var(--dg-lime-bright); }
.dg-game__steps {
    width: min(1080px, 100% - 48px);
    margin-inline: auto;
    display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px;
    position: relative; z-index: 2;
}
.dg-game__card {
    background: rgba(255,255,255,.06);
    border: 1px solid rgba(255,255,255,.12);
    border-radius: var(--dg-r-lg);
    padding: 28px 22px; text-align: center;
    transition: transform .4s var(--dg-ease), background .4s;
}
.dg-game__card:hover { transform: translateY(-6px); background: rgba(255,255,255,.1); }
.dg-game__card img { width: 96px; height: 96px; object-fit: contain; margin: 0 auto 16px; }
.dg-game__card h4 { color:#fff; font-family: var(--dg-font-head); font-size: 1.2rem; margin-bottom: 8px; }
.dg-game__card p { color: rgba(255,255,255,.65); font-size: .95rem; }
.dg-game__lvl {
    display:inline-block; font-family: var(--dg-font-head); font-weight: 700;
    font-size: .75rem; letter-spacing:.08em; text-transform: uppercase;
    color: var(--dg-green-900); background: var(--dg-lime-bright);
    padding: 4px 12px; border-radius: var(--dg-r-pill); margin-bottom: 14px;
}

/* ===========================================================
   NEWSLETTER
   =========================================================== */
.dg-news { padding: 0; }
.dg-news__box {
    width: 100%; text-align: center;
    background: var(--dg-grad-lime);
    border-radius: 0;
    padding: clamp(48px, 6vw, 72px) clamp(24px, 5vw, 80px);
    position: relative; overflow: hidden;
}
.dg-news__box h2 { font-size: clamp(1.8rem, 3.6vw, 2.6rem); color: var(--dg-green-900); }
.dg-news__box p { color: var(--dg-green-700); margin-top: 12px; font-size: 1.08rem; }
.dg-news__form {
    margin: 28px auto 0; max-width: 480px;
    display: flex; gap: 10px; background:#fff; padding: 8px; border-radius: var(--dg-r-pill);
    box-shadow: var(--dg-shadow-md);
}
.dg-news__form input {
    flex: 1; border: 0; background: transparent; outline: none;
    padding: 0 18px; font-family: var(--dg-font-body); font-size: 1rem; color: var(--dg-ink);
}
.dg-news__hint { margin-top: 14px; font-size: .85rem; color: var(--dg-green-700); opacity: .8; }

/* ===========================================================
   SCROLL REVEAL
   =========================================================== */
.dg-reveal {
    opacity: 0;
    transform: translateY(28px);
    transition: opacity .7s var(--dg-ease), transform .7s var(--dg-ease);
}
.dg-reveal.is-in { opacity: 1; transform: none; }

/* ===========================================================
   RESPONSIVE
   =========================================================== */
@media (max-width: 1024px) {
    .dg-hero__grid { grid-template-columns: 1fr; text-align: center; }
    .dg-hero__lead { margin-inline: auto; }
    .dg-hero__actions, .dg-hero__trust { justify-content: center; }
    .dg-hero__visual { order: -1; min-height: 420px; }
    .dg-download__panel { grid-template-columns: 1fr; text-align: center; }
    .dg-download p { margin-inline: auto; }
    .dg-download__actions { justify-content: center; }
    .dg-download__visual { order: -1; }
    .dg-card--lg, .dg-card--feature { grid-column: span 6; }
    .dg-card--md { grid-column: span 3; }
    .dg-card--sm, .dg-card--dark { grid-column: span 3; }
}

@media (max-width: 860px) {
    .dg-nav, .dg-header__cta .dg-store { display: none; }
    .dg-burger { display: inline-flex; }
    .dg-stats__grid { grid-template-columns: repeat(2, 1fr); gap: 36px 24px; }
    .dg-steps { grid-template-columns: 1fr; }
    .dg-quotes { grid-template-columns: 1fr; }
    .dg-footer__inner { grid-template-columns: 1fr; gap: 36px; }
    .dg-show { grid-template-columns: 1fr; text-align: center; }
    .dg-show:nth-child(even) .dg-show__media { order: -1; }
    .dg-show__list { display: inline-flex; text-align: left; }
    .dg-show__tag { margin-inline: auto; }
    .dg-footer__bottom { width: 100%; padding-inline: 24px; }
}

@media (max-width: 560px) {
    .dg-wrap, .dg-header__inner, .dg-hero__grid, .dg-bento, .dg-steps,
    .dg-quotes, .dg-stats__grid, .dg-download__panel, .dg-faq, .dg-footer__inner {
        width: 100% - 32px;
    }
    .dg-bento { grid-template-columns: 1fr; }
    .dg-card, .dg-card--lg, .dg-card--sm, .dg-card--md, .dg-card--feature, .dg-card--dark { grid-column: auto; }
    .dg-stats__grid { grid-template-columns: 1fr 1fr; }
    .dg-news__form { flex-direction: column; border-radius: var(--dg-r-md); }
    .dg-news__form .dg-btn { justify-content: center; }
    .dg-float--a { left: 0; top: 2%; }
    .dg-float--b { right: 0; }
    .dg-hero__actions .dg-store, .dg-hero__actions .dg-btn { flex: 1; justify-content: center; }
}

/* respeta reduce motion */
@media (prefers-reduced-motion: reduce) {
    .dg-float, .dg-mascota { animation: none; }
    .dg-reveal { transition: none; opacity: 1; transform: none; }
}
