.dpc-app,
.dpc-app *{box-sizing:border-box}
.dpc-app{
    --dpc-bg:#f6f0e5;
    --dpc-card:#fffdfa;
    --dpc-cream:#f8f3e9;
    --dpc-cream-2:#f3ebdd;
    --dpc-cream-3:#efe4d2;
    --dpc-line:#e6dbc8;
    --dpc-line-2:#dcc8a4;
    --dpc-ink:#132519;
    --dpc-ink-soft:#27362d;
    --dpc-muted:#6d7067;
    --dpc-green:#5b7841;
    --dpc-green-dark:#224a2f;
    --dpc-gold:#d3b169;
    --dpc-gold-dark:#a67f35;
    --dpc-shadow:0 22px 50px rgba(72,49,28,.10);
    --dpc-shadow-soft:0 14px 32px rgba(72,49,28,.08);
    position:relative;
    max-width:1440px;
    margin:0 auto;
    font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
    color:var(--dpc-ink-soft);
    line-height:1.45;
}
.dpc-app a{color:inherit;text-decoration:none}
.dpc-app p{font-size:17px;line-height:1.65}
.dpc-app h2,
.dpc-app h3,
.dpc-app h4,
.dpc-app strong,
.dpc-app b{
    font-family:Georgia,"Times New Roman",serif;
    color:#15281a;
}
.dpc-app img{max-width:100%;display:block}
.dpc-app button,
.dpc-app input,
.dpc-app select{font:inherit}
.dpc-app button{cursor:pointer}

.dpc-kicker,
.dpc-card-label,
.dpc-result__eyebrow{
    display:inline-flex;
    align-items:center;
    gap:8px;
    min-height:40px;
    padding:8px 18px;
    border-radius:999px;
    border:1px solid var(--dpc-line);
    background:rgba(255,255,255,.72);
    font-size:13px;
    font-weight:800;
    letter-spacing:.12em;
    text-transform:uppercase;
    color:var(--dpc-green-dark);
}
.dpc-card-label{min-height:34px;padding:6px 14px;font-size:12px}
.dpc-result__eyebrow{background:#edf2e8;border-color:#d8e2cf;color:#557440}

.dpc-hero,
.dpc-section{
    position:relative;
    overflow:hidden;
    border:1px solid rgba(214,196,164,.72);
    background:
        radial-gradient(circle at 18% 12%, rgba(255,255,255,.92), rgba(255,255,255,0) 18%),
        radial-gradient(circle at 86% 8%, rgba(255,255,255,.65), rgba(255,255,255,0) 17%),
        linear-gradient(180deg, #fcf9f2 0%, #f6efe3 100%);
    box-shadow:var(--dpc-shadow);
}
.dpc-hero{
    display:grid;
    grid-template-columns:minmax(0,1.12fr) minmax(360px,.88fr);
    gap:26px;
    padding:28px;
    border-radius:36px;
    min-height:620px;
}
.dpc-hero:before{
    content:"";
    position:absolute;
    left:-120px;
    top:-80px;
    width:330px;
    height:260px;
    border-radius:0 0 220px 0;
    background:radial-gradient(circle at 40% 40%, rgba(129,152,96,.18), rgba(129,152,96,0) 60%);
}
.dpc-hero:after{
    content:"";
    position:absolute;
    right:180px;
    top:0;
    width:260px;
    height:84px;
    border-radius:0 0 80px 80px;
    background:linear-gradient(180deg, rgba(211,177,105,.22), rgba(211,177,105,.08));
}
.dpc-hero__copy{position:relative;z-index:1;display:flex;flex-direction:column;min-width:0}
.dpc-hero__copy h2{
    margin:12px 0 16px;
    max-width:520px;
    font-size:72px;
    line-height:.96;
    letter-spacing:-.055em;
}
.dpc-hero__copy>p{
    max-width:460px;
    margin:0 0 20px;
    font-size:18px;
    color:#536055;
}
.dpc-mini-stats{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:14px;
    max-width:540px;
    margin:0 0 18px;
}
.dpc-mini-stats span{
    min-height:128px;
    display:flex;
    flex-direction:column;
    justify-content:center;
    gap:8px;
    padding:16px 14px;
    background:rgba(255,255,255,.80);
    border:1px solid rgba(221,207,184,.95);
    border-radius:20px;
    box-shadow:var(--dpc-shadow-soft);
    text-align:center;
}
.dpc-mini-stats i{
    width:38px;height:38px;display:grid;place-items:center;margin:0 auto;
    border-radius:12px;background:#edf0df;border:1px solid #dfe8ce;font-style:normal;font-size:18px
}
.dpc-mini-stats strong{font-size:27px;line-height:1;color:#26391f}
.dpc-mini-stats em{font-style:normal;font-size:14px;line-height:1.3;color:var(--dpc-muted)}

.dpc-jump-nav{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:14px;
    max-width:545px;
    margin-top:2px;
}
.dpc-jump-card{
    display:grid;
    grid-template-columns:44px 1fr 20px;
    align-items:center;
    gap:12px;
    padding:14px 16px;
    min-height:92px;
    background:rgba(255,255,255,.84);
    border:1px solid rgba(221,207,184,.95);
    border-radius:20px;
    box-shadow:var(--dpc-shadow-soft);
    transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.dpc-jump-card:hover{transform:translateY(-2px);box-shadow:0 18px 36px rgba(72,49,28,.12);border-color:#d4bf95}
.dpc-jump-card__icon{
    width:40px;height:40px;display:grid;place-items:center;
    border-radius:12px;background:#eef2e6;border:1px solid #dae4ca;font-size:18px
}
.dpc-jump-card strong{display:block;font-size:20px;line-height:1.1}
.dpc-jump-card small{display:block;margin-top:3px;font-size:13px;line-height:1.35;color:var(--dpc-muted)}
.dpc-jump-card em{font-style:normal;font-size:18px;color:#9f8550;justify-self:end}

.dpc-hero__dog-box{
    position:absolute;
    left:330px;
    bottom:-6px;
    width:min(36vw,390px);
    pointer-events:none;
}
.dpc-hero__dog-box img{width:100%;height:auto;filter:drop-shadow(0 18px 28px rgba(0,0,0,.12))}

.dpc-panel{
    position:relative;
    z-index:1;
    background:rgba(255,255,255,.90);
    border:1px solid rgba(233,224,209,.95);
    border-radius:30px;
    padding:22px;
    box-shadow:0 18px 36px rgba(72,49,28,.12);
    backdrop-filter:blur(12px);
}
.dpc-main{align-self:start;max-width:520px;justify-self:end}
.dpc-panel__head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:16px}
.dpc-panel__head h3,
.dpc-panel__head h4{margin:10px 0 0;font-size:28px;line-height:.98;letter-spacing:-.04em}
.dpc-panel__head--hero h3{font-size:30px;max-width:280px}
.dpc-panel__head--sub{margin-bottom:12px}
.dpc-icon-btn,
.dpc-soft-btn,
.dpc-ghost-btn,
.dpc-primary-btn{
    border:0;
    border-radius:18px;
    min-height:54px;
    padding:14px 18px;
    font-size:17px;
    font-weight:700;
    transition:transform .18s ease, box-shadow .18s ease, background .18s ease;
}
.dpc-icon-btn{
    width:42px;height:42px;min-height:42px;padding:0;border-radius:999px;
    background:#fcf4e2;color:#af8b4f;border:1px solid #eadab7;box-shadow:none
}
.dpc-soft-btn{background:#fcf7ee;border:1px solid #e4d5bd;color:#48683f}
.dpc-ghost-btn{background:#fff;border:1px solid #e3d6c7;color:#304a35}
.dpc-primary-btn{
    color:#fff;
    background:linear-gradient(135deg, #315d36 0%, #648246 100%);
    box-shadow:0 14px 28px rgba(49,93,54,.22), inset 0 1px 0 rgba(255,255,255,.18);
}
.dpc-icon-btn:hover,
.dpc-soft-btn:hover,
.dpc-ghost-btn:hover,
.dpc-primary-btn:hover{transform:translateY(-1px)}

.dpc-field-grid{display:grid;grid-template-columns:1fr;gap:12px}
.dpc-field-grid--diary,
.dpc-field-grid--nutrition{grid-template-columns:repeat(2,minmax(0,1fr))}
.dpc-field--full{grid-column:1 / -1}
.dpc-field{display:grid;gap:7px;margin:0}
.dpc-field span{font-size:13px;font-weight:700;color:#425246}
.dpc-field em{font-style:normal;color:#8b9084}
.dpc-field input,
.dpc-field select{
    width:100%;
    min-height:52px;
    border-radius:14px;
    border:1px solid #e2d7c7;
    background:#fff;
    padding:0 14px;
    color:var(--dpc-ink-soft);
    box-shadow:inset 0 1px 0 rgba(255,255,255,.8);
}
.dpc-field input:focus,
.dpc-field select:focus{
    outline:none;
    border-color:#9eb279;
    box-shadow:0 0 0 4px rgba(117,147,74,.12)
}
.dpc-main-actions{display:grid;grid-template-columns:1.1fr .9fr;gap:12px;margin:16px 0}

.dpc-result{
    padding:18px;
    border-radius:22px;
    background:linear-gradient(180deg,#fbf8ef 0%, #f3f1e7 100%);
    border:1px solid #e4decc;
}
.dpc-result__hero{display:grid;gap:8px;padding-bottom:14px;border-bottom:1px solid rgba(214,196,164,.55)}
.dpc-result__hero strong{font-size:56px;line-height:.95;letter-spacing:-.045em;color:#24381e}
.dpc-result__hero small{font-weight:600;color:#657466}
.dpc-result-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:14px}
.dpc-result-grid article{
    display:grid;
    gap:5px;
    padding:14px;
    border-radius:16px;
    background:#fffdf7;
    border:1px solid #e7dfcf;
}
.dpc-result-grid span{font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:#786f60}
.dpc-result-grid b{font-size:18px;line-height:1.1;color:#22361b}
.dpc-result-grid small{font-size:12px;line-height:1.35;color:#6f726b}
.dpc-formula-note{margin:12px 0 0 !important;font-size:13px !important;line-height:1.5 !important;color:#6a6f67 !important}

.dpc-section{margin-top:24px;padding:28px;border-radius:34px}
.dpc-section:before,
.dpc-section:after{
    content:"";position:absolute;pointer-events:none;opacity:.45
}
.dpc-section:before{
    left:-32px;bottom:-30px;width:180px;height:180px;border-radius:50%;
    background:radial-gradient(circle at 60% 40%, rgba(120,145,90,.18), rgba(120,145,90,0) 65%)
}
.dpc-section:after{
    right:-30px;top:-18px;width:180px;height:180px;border-radius:50%;
    background:radial-gradient(circle at 40% 60%, rgba(211,177,105,.18), rgba(211,177,105,0) 65%)
}
.dpc-section__head{position:relative;z-index:1;display:grid;gap:10px;margin-bottom:20px}
.dpc-section__head h3{margin:0;max-width:760px;font-size:64px;line-height:.96;letter-spacing:-.05em}
.dpc-section__head p{margin:0;max-width:760px;color:#646c64}
.dpc-section__head--split{display:flex;justify-content:space-between;align-items:flex-start;gap:20px}
.dpc-section__head--diary,
.dpc-section__head--nutrition{display:grid;grid-template-columns:1fr auto;align-items:start;gap:18px}
.dpc-section-dog{pointer-events:none}
.dpc-section-dog--timeline{position:absolute;right:8px;top:-16px;width:250px}
.dpc-section-dog--diary{width:330px;justify-self:end;align-self:start}
.dpc-section-dog--nutrition{width:270px;justify-self:end;align-self:start;opacity:.8}

.dpc-timeline-scene{position:absolute;right:18px;top:18px;width:300px;height:190px;pointer-events:none;z-index:0}
.dpc-timeline-badge{
    position:absolute;left:10px;top:64px;display:grid;place-items:center;
    width:92px;height:92px;border-radius:50%;background:rgba(255,249,239,.85);border:1px solid #eadcbc;
    color:#b59050;font-size:11px;line-height:1.25;text-align:center;text-transform:uppercase;letter-spacing:.11em;
}
.dpc-timeline-progress{
    position:relative;z-index:1;height:10px;border-radius:999px;background:#ece4d3;border:1px solid rgba(214,196,164,.6);
    overflow:hidden;margin:12px 0 18px
}
.dpc-timeline-progress span{
    display:block;height:100%;width:0;border-radius:inherit;
    background:linear-gradient(90deg,#92a46a 0%, #d0af68 48%, #e6c98a 100%);
    transition:width .35s ease
}
.dpc-timeline{position:relative;z-index:1;display:grid;gap:10px}
.dpc-milestone{
    display:grid;grid-template-columns:78px 110px 1fr auto;align-items:center;gap:16px;
    padding:14px 18px;border-radius:18px;background:rgba(255,255,255,.86);border:1px solid #e9dfd0;box-shadow:var(--dpc-shadow-soft)
}
.dpc-milestone.is-current{background:#f3f5ea;border-color:#d5ddc7}
.dpc-milestone.is-past{background:#faf7ef}
.dpc-milestone__icon{
    width:60px;height:60px;display:grid;place-items:center;border-radius:18px;background:#f0f2e4;border:1px solid #dfe6ce;font-size:24px
}
.dpc-milestone__day{font-weight:700;font-size:28px;line-height:1.1;color:#22391f}
.dpc-milestone__day small{display:block;font-size:14px;line-height:1.2;color:#5d695e;font-family:Inter,system-ui,sans-serif}
.dpc-milestone h4{margin:0 0 4px;font-size:22px;line-height:1.1}
.dpc-milestone p{margin:0;font-size:14px;line-height:1.5;color:#646d64}
.dpc-milestone__status{
    min-width:96px;text-align:center;padding:9px 14px;border-radius:999px;font-size:12px;font-weight:800;
    border:1px solid #e7d8b8;background:#fff9ed;color:#9d844f
}
.dpc-milestone.is-current .dpc-milestone__status{background:#eef4e4;border-color:#d8e1c9;color:#60764a}
.dpc-milestone.is-past .dpc-milestone__status{background:#f6f0e3;color:#8f886e}

.dpc-kit-meter{
    display:flex;align-items:center;gap:16px;padding:14px 16px;margin-bottom:16px;
    border-radius:999px;background:#fbf5ea;border:1px solid #eadfcf;position:relative;z-index:1
}
.dpc-kit-meter span{
    min-width:66px;height:42px;padding:0 16px;border-radius:999px;display:grid;place-items:center;
    background:linear-gradient(135deg,#708952,#9ab36f);color:#fff;font-size:18px;font-weight:800
}
.dpc-kit-meter em{position:relative;display:block;flex:1;height:18px;border-radius:999px;background:#eee4d6;overflow:hidden}
.dpc-kit-meter em:before{content:"";position:absolute;inset:0;width:var(--dpc-kit-pct,0%);background:linear-gradient(90deg,#8ba15b,#d1b06b);border-radius:inherit;transition:width .2s ease}
.dpc-kit-grid{position:relative;z-index:1;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.dpc-kit-item{
    display:grid;grid-template-columns:170px 42px 1fr;align-items:center;gap:16px;
    padding:14px;border-radius:22px;background:rgba(255,255,255,.88);border:1px solid #eadfcf;box-shadow:var(--dpc-shadow-soft);cursor:pointer
}
.dpc-kit-item input{position:absolute;opacity:0;pointer-events:none}
.dpc-kit-thumb{overflow:hidden;border-radius:16px;background:#efe8dd;border:1px solid #e2d8c7;height:90px}
.dpc-kit-thumb img{width:100%;height:100%;object-fit:cover}
.dpc-kit-check{
    width:38px;height:38px;border-radius:50%;border:2px solid #91a46c;background:#fff;display:grid;place-items:center;transition:all .18s ease
}
.dpc-kit-item input:checked + .dpc-kit-check{background:#8ca060;border-color:#8ca060;box-shadow:0 8px 18px rgba(73,113,53,.18)}
.dpc-kit-item input:checked + .dpc-kit-check:before{content:"✓";font-size:18px;color:#fff;font-weight:800}
.dpc-kit-copy strong{display:block;font-size:20px;line-height:1.15;margin-bottom:7px}
.dpc-kit-copy small{display:block;font-size:13px;line-height:1.5;color:#677067}

.dpc-diary-layout,
.dpc-nutrition-layout{position:relative;z-index:1;display:grid;grid-template-columns:minmax(0,.88fr) minmax(0,1fr);gap:18px;align-items:start}
.dpc-diary-form,
.dpc-chart-panel,
.dpc-nutrition-form,
.dpc-food-panel{border-radius:26px}
.dpc-alert{margin-top:14px;padding:14px 16px;border-radius:16px;background:#fff2e7;border:1px solid #efcfbd;color:#744831;font-size:14px;font-weight:700;line-height:1.5}
.dpc-chart{
    min-height:260px;border-radius:18px;background:#fffdf8;border:1px solid #e7dfcf;overflow:hidden;display:grid;place-items:center
}
.dpc-chart span{padding:24px;color:#6f756d;text-align:center}
.dpc-chart svg{display:block;width:100%;height:260px}
.dpc-chart .grid{stroke:rgba(113,120,111,.22);stroke-width:1}
.dpc-chart .warn{stroke:rgba(199,165,95,.8);stroke-width:2;stroke-dasharray:7 7}
.dpc-chart .line{fill:none;stroke:#3d6840;stroke-width:4;stroke-linecap:round;stroke-linejoin:round}
.dpc-chart .dot{fill:#34633e;stroke:#fff8ec;stroke-width:3}
.dpc-chart .label{font-size:11px;fill:#6e756e;font-weight:700}
.dpc-diary-list{display:grid;gap:10px;margin-top:12px;max-height:340px;overflow:auto;padding-right:4px}
.dpc-diary-entry{
    display:grid;grid-template-columns:1fr auto;align-items:center;gap:10px;padding:14px;border-radius:16px;
    background:#fff;border:1px solid #e9dfcf
}
.dpc-diary-entry strong{display:block;font-size:18px;line-height:1.1}
.dpc-diary-entry small{display:block;margin-top:4px;color:#666f66;font-size:14px}
.dpc-diary-entry button{width:38px;height:38px;border-radius:12px;border:1px solid #eadfcf;background:#fcf7ef;color:#8b6c4c;font-size:22px;line-height:1}

.dpc-food-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:14px}
.dpc-food-grid article{
    display:grid;align-content:start;gap:10px;padding:18px;border-radius:20px;background:rgba(255,255,255,.86);border:1px solid #eadfcf
}
.dpc-food-grid article span{
    width:64px;height:64px;display:grid;place-items:center;border-radius:50%;border:3px solid #d7b56e;
    background:radial-gradient(circle at 35% 35%, #35593d 0%, #183322 100%);color:#fff6dd;font-size:28px;box-shadow:0 8px 22px rgba(28,51,34,.18)
}
.dpc-food-grid strong{display:block;font-size:22px;line-height:1.12}
.dpc-food-grid small{display:block;font-size:14px;line-height:1.55;color:#667066}
.dpc-today-food{
    margin-top:14px;padding:18px 18px 16px;border-radius:22px;border:1px solid #c9a85f;
    background:radial-gradient(circle at 82% 35%, rgba(232,209,145,.18), rgba(232,209,145,0) 20%), linear-gradient(135deg,#113d2c 0%, #23553d 55%, #0f3f2d 100%);
    color:#fffbe8;box-shadow:0 14px 30px rgba(21,61,44,.24), inset 0 1px 0 rgba(255,255,255,.15)
}
.dpc-today-food span{display:block;font-size:14px;line-height:1.55;color:#edf0e0}
.dpc-today-food strong{display:block;margin:10px 0 8px;font-size:54px;line-height:.95;color:#ffe6a6}

.dpc-table-wrap{position:relative;z-index:1;overflow:auto;margin-top:18px;border-radius:26px;border:1px solid #d9bf83;box-shadow:var(--dpc-shadow-soft);background:#fffbf5;padding:14px}
.dpc-food-table{width:100%;border-collapse:separate;border-spacing:0;overflow:hidden;border-radius:24px;background:#fffdf8}
.dpc-food-table th,
.dpc-food-table td{padding:24px 20px;text-align:left;border-right:1px solid #ecd9b9;border-bottom:1px solid #efe4d1;vertical-align:top}
.dpc-food-table th:last-child,
.dpc-food-table td:last-child{border-right:0}
.dpc-food-table tr:last-child td{border-bottom:0}
.dpc-food-table thead th{
    background:linear-gradient(180deg,#f1dfb4 0%, #e3c88e 100%);
    color:#966b20;font-size:15px;font-weight:800;letter-spacing:.03em;text-transform:uppercase
}
.dpc-food-table tbody td{font-size:22px;line-height:1.4;color:#3b3a36}
.dpc-food-table tbody td strong{font-size:22px}
.dpc-food-table tbody tr.is-active td{background:#fbf7ee}
.dpc-food-table tbody td:last-child{font-size:18px;color:#514f49}

.dpc-copy-grid{position:relative;z-index:1;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}
.dpc-copy-grid article{
    padding:24px;border-radius:24px;background:rgba(255,255,255,.86);border:1px solid #e2cfaa;box-shadow:var(--dpc-shadow-soft)
}
.dpc-copy-grid h4{margin:0 0 14px;font-size:28px;line-height:1.1}
.dpc-copy-grid p{margin:0;font-size:17px;line-height:1.75;color:#61665e}
.dpc-medical-note{
    position:relative;z-index:1;margin:18px 0 0;padding:20px 22px 20px 104px;min-height:96px;border-radius:24px;
    background:linear-gradient(180deg,#fffdfa 0%, #faf5ea 100%);border:1px solid #e1d1b2;font-size:17px;line-height:1.65;color:#575f57
}
.dpc-medical-note:before{
    content:"🐾";position:absolute;left:24px;top:50%;transform:translateY(-50%);width:58px;height:58px;border-radius:50%;display:grid;place-items:center;
    background:radial-gradient(circle at 35% 35%, #e3c98b 0%, #c39a4a 100%);color:#fff8e8;font-size:28px;box-shadow:0 10px 20px rgba(167,127,53,.22)
}
.dpc-medical-note strong{color:#9b6f1d}

@media (max-width:1320px){
    .dpc-hero__copy h2,
    .dpc-section__head h3{font-size:56px}
    .dpc-hero__dog-box{left:280px;width:310px}
    .dpc-main{max-width:none}
}
@media (max-width:1180px){
    .dpc-hero{grid-template-columns:1fr;min-height:auto}
    .dpc-main{justify-self:stretch;max-width:none}
    .dpc-hero__dog-box{position:relative;left:auto;bottom:auto;width:300px;margin:16px auto 0}
    .dpc-diary-layout,
    .dpc-nutrition-layout,
    .dpc-copy-grid{grid-template-columns:1fr}
    .dpc-section-dog--diary,
    .dpc-section-dog--nutrition{display:none}
    .dpc-timeline-scene{display:none}
}
@media (max-width:940px){
    .dpc-kit-grid,
    .dpc-food-grid,
    .dpc-result-grid{grid-template-columns:1fr}
    .dpc-kit-item{grid-template-columns:120px 42px 1fr}
    .dpc-milestone{grid-template-columns:70px 96px 1fr;grid-template-areas:"icon day status" "icon copy copy"}
    .dpc-milestone__icon{grid-area:icon}
    .dpc-milestone__day{grid-area:day;font-size:24px}
    .dpc-milestone>div:nth-of-type(2){grid-area:copy}
    .dpc-milestone__status{grid-area:status;justify-self:end}
    .dpc-field-grid--diary,
    .dpc-field-grid--nutrition{grid-template-columns:1fr 1fr}
    .dpc-food-table{min-width:980px}
}
@media (max-width:720px){
    .dpc-app p{font-size:15px}
    .dpc-hero,.dpc-section{padding:18px;border-radius:26px}
    .dpc-hero__copy h2,.dpc-section__head h3{font-size:42px}
    .dpc-mini-stats,
    .dpc-jump-nav,
    .dpc-field-grid--diary,
    .dpc-field-grid--nutrition,
    .dpc-main-actions{grid-template-columns:1fr}
    .dpc-panel{padding:16px;border-radius:22px}
    .dpc-result__hero strong{font-size:38px}
    .dpc-section__head--split{display:grid}
    .dpc-kit-item{grid-template-columns:1fr;gap:12px}
    .dpc-kit-thumb{height:120px}
    .dpc-kit-check{order:2}
    .dpc-milestone{grid-template-columns:1fr;gap:12px}
    .dpc-milestone__status{justify-self:start}
    .dpc-copy-grid h4{font-size:24px}
    .dpc-medical-note{padding:94px 16px 18px}
    .dpc-medical-note:before{left:16px;top:18px;transform:none}
    .dpc-jump-card{grid-template-columns:40px 1fr 16px;min-height:82px}
}

/* Compact hero redesign: image-background first screen */
.dpc-app .dpc-hidden-control{display:none!important}
.dpc-app .dpc-hero.dpc-hero--landing{
    display:block;
    width:100%;
    height:clamp(540px,56vw,720px);
    min-height:0;
    padding:0;
    border:0;
    border-radius:28px;
    overflow:hidden;
    background-image:linear-gradient(90deg,rgba(253,248,239,.10) 0%,rgba(253,248,239,.03) 45%,rgba(253,248,239,0) 100%),url('decor/hero-bg.webp');
    background-size:cover;
    background-position:center center;
    box-shadow:0 16px 42px rgba(64,43,24,.10);
}
.dpc-app .dpc-hero.dpc-hero--landing:before,
.dpc-app .dpc-hero.dpc-hero--landing:after{display:none!important}
.dpc-app .dpc-hero__stage{position:absolute;inset:0;z-index:1}
.dpc-app .dpc-hero__title-wrap{position:absolute;left:44px;top:26px;width:520px;z-index:3}
.dpc-app .dpc-hero__title-wrap h2{
    margin:0;
    font-size:clamp(58px,6.8vw,88px);
    line-height:.82;
    letter-spacing:-.064em;
    color:#0f2b1d;
    text-shadow:0 1px 0 rgba(255,255,255,.55);
}
.dpc-app .dpc-hero__title-wrap h2 span{display:block;font-family:Georgia,"Times New Roman",serif}
.dpc-app .dpc-hero__title-wrap h2 span:nth-child(2){color:#aa8b32}
.dpc-app .dpc-title-flourish{
    display:block;
    width:190px;
    margin:10px 0 0 118px;
    color:#d1b96f;
    opacity:.72;
    font-size:26px;
    line-height:1;
    text-align:center;
    border-top:1px solid rgba(191,166,92,.28);
}
.dpc-app .dpc-title-flourish:after{content:"♡";margin-left:12px;color:#c7bd8e;font-size:16px;vertical-align:middle}

.dpc-app .dpc-hero--landing .dpc-main{
    position:absolute;
    left:48px;
    top:278px;
    width:400px;
    max-width:none;
    justify-self:auto;
    align-self:auto;
    padding:18px 20px 18px;
    border-radius:22px;
    background:rgba(255,255,255,.88);
    border:1px solid rgba(235,228,217,.86);
    box-shadow:0 16px 36px rgba(58,42,26,.13);
    backdrop-filter:blur(8px);
}
.dpc-app .dpc-hero--landing .dpc-main .dpc-field-grid{gap:10px}
.dpc-app .dpc-hero--landing .dpc-field{position:relative;gap:5px}
.dpc-app .dpc-hero--landing .dpc-field span{
    font-size:13px;
    line-height:1.1;
    color:#1f2f28;
    font-weight:700;
}
.dpc-app .dpc-hero--landing .dpc-field:after{
    position:absolute;
    left:16px;
    bottom:12px;
    z-index:2;
    font-size:18px;
    color:#6e765f;
    pointer-events:none;
}
.dpc-app .dpc-hero--landing .dpc-field--calendar:after{content:"▣"}
.dpc-app .dpc-hero--landing .dpc-field--paw:after{content:"♣"}
.dpc-app .dpc-hero--landing .dpc-field--dog:after{content:"♞"}
.dpc-app .dpc-hero--landing .dpc-field input,
.dpc-app .dpc-hero--landing .dpc-field select{
    min-height:38px;
    border-radius:8px;
    border:1px solid #ded9d0;
    background:rgba(255,255,255,.76);
    padding:0 13px 0 48px;
    color:#1e2e26;
    font-size:15px;
    box-shadow:none;
}
.dpc-app .dpc-hero--landing .dpc-field input:focus,
.dpc-app .dpc-hero--landing .dpc-field select:focus{
    border-color:#bda970;
    box-shadow:0 0 0 3px rgba(177,154,89,.14)
}
.dpc-app .dpc-hero--landing .dpc-main-actions{display:block;margin:14px 0 0}
.dpc-app .dpc-hero--landing .dpc-primary-btn{
    width:100%;
    min-height:45px;
    border-radius:9px;
    padding:10px 18px;
    font-size:16px;
    letter-spacing:.01em;
    background:linear-gradient(180deg,#17452e 0%,#06351f 100%);
    box-shadow:0 12px 24px rgba(11,61,35,.20), inset 0 1px 0 rgba(255,255,255,.20);
}

.dpc-app .dpc-hero--landing .dpc-jump-nav{
    position:absolute;
    left:48px;
    bottom:32px;
    z-index:3;
    display:grid;
    grid-template-columns:repeat(4,104px);
    gap:10px;
    max-width:none;
    margin:0;
}
.dpc-app .dpc-hero--landing .dpc-jump-card{
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    gap:8px;
    min-height:126px;
    padding:12px 10px;
    border-radius:18px;
    text-align:center;
    box-shadow:0 12px 28px rgba(66,47,27,.13), inset 0 1px 0 rgba(255,255,255,.55);
    border:1px solid rgba(255,255,255,.62);
}
.dpc-app .dpc-hero--landing .dpc-jump-card--green{background:linear-gradient(180deg,#f5f8dc,#dcebc4)}
.dpc-app .dpc-hero--landing .dpc-jump-card--gold{background:linear-gradient(180deg,#fff8df,#f3e3a9)}
.dpc-app .dpc-hero--landing .dpc-jump-card--peach{background:linear-gradient(180deg,#fff0e8,#f7d8c1)}
.dpc-app .dpc-hero--landing .dpc-jump-card--sage{background:linear-gradient(180deg,#f3f8e9,#dae8d2)}
.dpc-app .dpc-hero--landing .dpc-jump-card__icon{
    width:34px;
    height:34px;
    border-radius:10px;
    background:transparent;
    border:0;
    color:#173e28;
    font-size:26px;
    line-height:1;
}
.dpc-app .dpc-hero--landing .dpc-jump-card strong{
    font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
    font-size:15px;
    line-height:1.18;
    font-weight:800;
    letter-spacing:-.02em;
    color:#13261d;
}
.dpc-app .dpc-hero--landing .dpc-jump-card small{display:none!important}
.dpc-app .dpc-hero--landing .dpc-jump-card em{
    display:grid;
    place-items:center;
    width:28px;
    height:28px;
    border-radius:999px;
    margin-top:1px;
    justify-self:auto;
    background:rgba(255,255,255,.38);
    color:#586c40;
    font-size:18px;
    box-shadow:inset 0 1px 0 rgba(255,255,255,.42);
}

.dpc-app .dpc-hero--landing .dpc-result{
    position:absolute;
    right:52px;
    bottom:52px;
    z-index:3;
    display:grid;
    grid-template-columns:76px 1fr 20px;
    gap:18px;
    align-items:center;
    width:390px;
    min-height:122px;
    padding:18px 18px;
    border-radius:22px;
    background:rgba(255,255,255,.84);
    border:1px solid rgba(235,227,212,.86);
    box-shadow:0 15px 34px rgba(64,45,27,.14);
    backdrop-filter:blur(9px);
}
.dpc-app .dpc-hero--landing .dpc-result__icon{
    width:72px;
    height:72px;
    display:grid;
    place-items:center;
    border-radius:50%;
    background:linear-gradient(180deg,#759251,#355d35);
    color:#fff9df;
    font-size:38px;
    box-shadow:0 10px 18px rgba(43,82,46,.20);
}
.dpc-app .dpc-hero--landing .dpc-result__hero{
    display:block;
    padding:0;
    border:0;
}
.dpc-app .dpc-hero--landing .dpc-result__eyebrow{
    display:block;
    min-height:0;
    padding:0;
    border:0;
    background:transparent;
    color:#577044;
    font-size:14px;
    line-height:1.2;
    font-weight:800;
    letter-spacing:0;
    text-transform:none;
    font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
}
.dpc-app .dpc-hero--landing .dpc-result__hero strong{
    display:block;
    margin-top:5px;
    font-size:28px;
    line-height:1.03;
    letter-spacing:-.035em;
    color:#15311f;
}
.dpc-app .dpc-hero--landing .dpc-result__hero small{
    display:block;
    margin-top:7px;
    font-size:13px;
    line-height:1.25;
    color:#667062;
}
.dpc-app .dpc-hero--landing .dpc-result__hero small b{
    font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
    font-weight:600;
    color:#58625a;
}
.dpc-app .dpc-result-hidden{display:none!important}
.dpc-app .dpc-result-heart{align-self:start;justify-self:end;color:#c5b881;font-size:22px;line-height:1}

@media (max-width:1180px){
    .dpc-app .dpc-hero.dpc-hero--landing{height:620px;background-position:center center}
    .dpc-app .dpc-hero__title-wrap{left:34px;top:28px;width:470px}
    .dpc-app .dpc-hero__title-wrap h2{font-size:70px}
    .dpc-app .dpc-hero--landing .dpc-main{left:38px;top:252px;width:380px}
    .dpc-app .dpc-hero--landing .dpc-jump-nav{left:38px;grid-template-columns:repeat(4,96px)}
    .dpc-app .dpc-hero--landing .dpc-result{right:34px;width:360px}
}
@media (max-width:940px){
    .dpc-app .dpc-hero.dpc-hero--landing{height:auto;min-height:0;padding:18px;background-position:62% center}
    .dpc-app .dpc-hero.dpc-hero--landing:before{content:"";display:block!important;position:absolute;inset:0;background:linear-gradient(90deg,rgba(255,250,241,.88),rgba(255,250,241,.70) 48%,rgba(255,250,241,.18));z-index:0;opacity:1;border-radius:0}
    .dpc-app .dpc-hero__stage{position:relative;inset:auto;display:grid;gap:14px;z-index:1}
    .dpc-app .dpc-hero__title-wrap,
    .dpc-app .dpc-hero--landing .dpc-main,
    .dpc-app .dpc-hero--landing .dpc-jump-nav,
    .dpc-app .dpc-hero--landing .dpc-result{position:relative;left:auto;right:auto;top:auto;bottom:auto;width:auto}
    .dpc-app .dpc-hero__title-wrap{width:100%;max-width:470px}
    .dpc-app .dpc-hero__title-wrap h2{font-size:58px}
    .dpc-app .dpc-hero--landing .dpc-jump-nav{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
    .dpc-app .dpc-hero--landing .dpc-result{grid-template-columns:64px 1fr 16px;min-height:105px}
    .dpc-app .dpc-hero--landing .dpc-result__icon{width:62px;height:62px;font-size:31px}
}
@media (max-width:560px){
    .dpc-app .dpc-hero__title-wrap h2{font-size:46px}
    .dpc-app .dpc-title-flourish{margin-left:60px;width:150px}
    .dpc-app .dpc-hero--landing .dpc-jump-nav{grid-template-columns:1fr 1fr}
    .dpc-app .dpc-hero--landing .dpc-jump-card{min-height:108px}
    .dpc-app .dpc-hero--landing .dpc-result{grid-template-columns:1fr;text-align:left}
    .dpc-app .dpc-result-heart{position:absolute;right:16px;top:14px}
}

/* v2.2 mobile-first polish: compact first screen + result popup + clean mobile table */
.dpc-app .dpc-hero-tagline{
    margin:8px 0 0;
    max-width:320px;
    font-family:Georgia,"Times New Roman",serif;
    font-style:italic;
    font-size:17px;
    line-height:1.2;
    color:#8b806e;
}
.dpc-app .dpc-result-modal[hidden]{display:none!important}
.dpc-app .dpc-result-modal{
    position:fixed;
    inset:0;
    z-index:99999;
    display:grid;
    place-items:center;
    padding:18px;
}
.dpc-app .dpc-result-modal__backdrop{
    position:absolute;
    inset:0;
    background:rgba(24,21,17,.58);
    backdrop-filter:blur(3px);
}
.dpc-app .dpc-result-modal__card{
    position:relative;
    z-index:1;
    width:min(100%,360px);
    min-height:304px;
    padding:28px 32px 24px;
    border-radius:24px;
    background:rgba(255,253,248,.96);
    border:1px solid rgba(232,222,204,.95);
    box-shadow:0 28px 60px rgba(0,0,0,.22), inset 0 1px 0 rgba(255,255,255,.9);
}
.dpc-app .dpc-result-modal__close{
    position:absolute;
    right:18px;
    top:16px;
    width:32px;
    height:32px;
    border:0;
    background:transparent;
    color:#b7a46c;
    font-size:30px;
    line-height:1;
}
.dpc-app .dpc-result-modal__icon{
    width:74px;
    height:74px;
    display:grid;
    place-items:center;
    border-radius:50%;
    background:linear-gradient(180deg,#79a64f 0%,#2d6738 100%);
    color:#fff6dc;
    font-size:38px;
    box-shadow:0 12px 24px rgba(45,103,56,.22);
    margin:0 0 18px;
}
.dpc-app .dpc-result-modal__label{
    display:block;
    color:#4c7a40;
    font-size:19px;
    font-weight:800;
    line-height:1.1;
    margin-bottom:8px;
}
.dpc-app .dpc-result-modal__card strong{
    display:block;
    max-width:250px;
    font-size:38px;
    line-height:.98;
    letter-spacing:-.04em;
    color:#0d2c1d;
}
.dpc-app .dpc-result-modal__range{
    display:flex;
    align-items:center;
    gap:10px;
    min-height:42px;
    margin:18px 0 18px;
    padding:9px 13px;
    border-radius:16px;
    background:#fbf8ef;
    border:1px solid #eadfcb;
    color:#667164;
    font-size:14px;
}
.dpc-app .dpc-result-modal__range b{font-family:Inter,system-ui,sans-serif;color:#3d463f;font-weight:700}
.dpc-app .dpc-result-modal__cta{
    display:flex;
    align-items:center;
    justify-content:center;
    gap:8px;
    min-height:50px;
    border-radius:15px;
    color:#fff;
    font-weight:800;
    background:linear-gradient(180deg,#25b658 0%,#087332 100%);
    box-shadow:0 14px 26px rgba(13,124,55,.25), inset 0 1px 0 rgba(255,255,255,.22);
}
.dpc-app .dpc-result-modal__cta em{
    display:grid;
    place-items:center;
    width:28px;
    height:28px;
    border-radius:50%;
    background:#fff;
    color:#27833c;
    font-style:normal;
    font-size:18px;
}
html.dpc-modal-open{overflow:hidden}

@media (min-width:941px){
    .dpc-app .dpc-hero.dpc-hero--landing{
        height:clamp(520px,52vw,660px);
        border-radius:30px;
    }
    .dpc-app .dpc-hero__title-wrap{top:30px;left:44px;width:510px}
    .dpc-app .dpc-hero__title-wrap h2{font-size:clamp(62px,6vw,82px)}
    .dpc-app .dpc-hero--landing .dpc-main{top:245px;left:46px;width:398px}
    .dpc-app .dpc-hero--landing .dpc-jump-nav{bottom:26px;left:46px;grid-template-columns:repeat(4,105px)}
    .dpc-app .dpc-hero--landing .dpc-result{right:44px;bottom:44px;width:385px}
}

@media (max-width:720px){
    .dpc-app{
        max-width:430px;
        margin-inline:auto;
    }
    .dpc-app .dpc-hero.dpc-hero--landing{
        height:730px!important;
        min-height:730px!important;
        padding:0!important;
        border-radius:24px!important;
        background-image:linear-gradient(90deg,rgba(255,250,243,.18),rgba(255,250,243,.04) 52%,rgba(255,250,243,0)),url('decor/hero-bg.webp')!important;
        background-size:cover!important;
        background-position:63% top!important;
        box-shadow:0 14px 34px rgba(55,38,22,.12)!important;
    }
    .dpc-app .dpc-hero.dpc-hero--landing:before{
        content:"";
        display:block!important;
        position:absolute;
        inset:0;
        z-index:0;
        border-radius:0;
        background:linear-gradient(90deg,rgba(255,250,242,.48) 0%,rgba(255,250,242,.18) 50%,rgba(255,250,242,0) 100%);
        opacity:1;
    }
    .dpc-app .dpc-hero__stage{position:absolute!important;inset:0!important;display:block!important;z-index:1}
    .dpc-app .dpc-hero__title-wrap{
        position:absolute!important;
        left:32px!important;
        top:30px!important;
        width:250px!important;
        max-width:250px!important;
        z-index:2;
    }
    .dpc-app .dpc-hero__title-wrap:before{
        content:"—  🐾  —";
        display:block;
        width:150px;
        margin:0 0 10px 52px;
        color:#c9aa67;
        font-size:20px;
        letter-spacing:.12em;
        text-align:center;
    }
    .dpc-app .dpc-hero__title-wrap h2{
        font-size:44px!important;
        line-height:.82!important;
        letter-spacing:-.055em!important;
        text-shadow:0 1px 0 rgba(255,255,255,.5);
    }
    .dpc-app .dpc-hero__title-wrap h2 span:nth-child(2){color:#aa8c2e!important}
    .dpc-app .dpc-hero-tagline{
        margin-top:8px;
        font-size:13px;
        color:#8d836f;
    }
    .dpc-app .dpc-title-flourish{
        width:auto!important;
        margin:8px 0 0 70px!important;
        border:0!important;
        font-size:0!important;
    }
    .dpc-app .dpc-title-flourish:after{content:"♡";font-size:17px;color:#c5b985}
    .dpc-app .dpc-hero--landing .dpc-main{
        position:absolute!important;
        left:30px!important;
        right:30px!important;
        top:250px!important;
        width:auto!important;
        max-width:none!important;
        padding:17px 18px 14px!important;
        border-radius:24px!important;
        background:rgba(255,255,255,.90)!important;
        border:1px solid rgba(235,228,215,.92)!important;
        box-shadow:0 15px 34px rgba(55,38,22,.14)!important;
        backdrop-filter:blur(8px);
    }
    .dpc-app .dpc-hero--landing .dpc-main .dpc-field-grid{gap:10px!important}
    .dpc-app .dpc-hero--landing .dpc-field span{font-size:11px!important;font-weight:800!important;color:#20342a!important}
    .dpc-app .dpc-hero--landing .dpc-field:before{
        content:"";
        position:absolute;
        left:-46px;
        bottom:0;
        width:36px;
        height:36px;
        border-radius:11px;
        background:#edf5e7;
        border:1px solid rgba(223,232,207,.85);
        box-shadow:0 6px 14px rgba(72,49,28,.06);
        z-index:0;
    }
    .dpc-app .dpc-hero--landing .dpc-field:nth-child(2):before{background:#e8f7ee}
    .dpc-app .dpc-hero--landing .dpc-field:nth-child(3):before{background:#efe7ff}
    .dpc-app .dpc-hero--landing .dpc-field:after{
        left:-36px!important;
        bottom:9px!important;
        font-size:16px!important;
        z-index:2;
    }
    .dpc-app .dpc-hero--landing .dpc-field--calendar:after{content:"▣"!important;color:#5f7641!important}
    .dpc-app .dpc-hero--landing .dpc-field--paw:after{content:"♞"!important;color:#3f8750!important}
    .dpc-app .dpc-hero--landing .dpc-field--dog:after{content:"♣"!important;color:#6d4cb4!important}
    .dpc-app .dpc-hero--landing .dpc-field input,
    .dpc-app .dpc-hero--landing .dpc-field select{
        min-height:37px!important;
        border-radius:10px!important;
        padding:0 12px!important;
        font-size:14px!important;
        background:rgba(255,255,255,.82)!important;
    }
    .dpc-app .dpc-hero--landing .dpc-primary-btn{
        min-height:45px!important;
        border-radius:17px!important;
        font-size:16px!important;
        background:linear-gradient(180deg,#24b85a 0%,#087432 100%)!important;
        box-shadow:0 13px 22px rgba(17,137,62,.25), inset 0 1px 0 rgba(255,255,255,.28)!important;
    }
    .dpc-app .dpc-hero--landing .dpc-jump-nav{
        position:absolute!important;
        left:30px!important;
        right:30px!important;
        bottom:34px!important;
        display:grid!important;
        grid-template-columns:1fr 1fr!important;
        gap:10px!important;
        width:auto!important;
        margin:0!important;
    }
    .dpc-app .dpc-hero--landing .dpc-jump-card{
        min-height:102px!important;
        border-radius:18px!important;
        padding:13px 12px 12px!important;
        align-items:flex-start!important;
        justify-content:center!important;
        text-align:left!important;
        gap:8px!important;
    }
    .dpc-app .dpc-hero--landing .dpc-jump-card__icon{
        width:44px!important;
        height:44px!important;
        display:grid!important;
        place-items:center!important;
        border-radius:16px!important;
        background:#fff!important;
        border:1px solid rgba(255,255,255,.7)!important;
        box-shadow:0 8px 18px rgba(36,61,37,.11)!important;
        font-size:25px!important;
    }
    .dpc-app .dpc-hero--landing .dpc-jump-card strong{
        font-family:Georgia,"Times New Roman",serif!important;
        font-size:18px!important;
        line-height:1.05!important;
        color:#14281b!important;
    }
    .dpc-app .dpc-hero--landing .dpc-jump-card em{
        position:absolute;
        right:14px;
        bottom:12px;
        width:24px!important;
        height:24px!important;
        font-size:15px!important;
    }
    .dpc-app .dpc-hero--landing .dpc-result{display:none!important}
    .dpc-app .dpc-section{border-radius:22px!important;padding:18px!important}
    .dpc-app .dpc-section__head h3{font-size:36px!important;line-height:1!important}
    .dpc-app .dpc-table-wrap{
        overflow:visible!important;
        padding:0!important;
        border:0!important;
        box-shadow:none!important;
        background:transparent!important;
    }
    .dpc-app .dpc-food-table,
    .dpc-app .dpc-food-table thead,
    .dpc-app .dpc-food-table tbody,
    .dpc-app .dpc-food-table tr,
    .dpc-app .dpc-food-table td,
    .dpc-app .dpc-food-table th{
        display:block!important;
        width:100%!important;
        min-width:0!important;
        border:0!important;
    }
    .dpc-app .dpc-food-table thead{display:none!important}
    .dpc-app .dpc-food-table{background:transparent!important;border-collapse:separate!important;border-spacing:0!important}
    .dpc-app .dpc-food-table tbody{display:grid!important;gap:12px!important}
    .dpc-app .dpc-food-table tbody tr{
        padding:14px!important;
        border-radius:18px!important;
        background:#fffdf8!important;
        border:1px solid #eadfcf!important;
        box-shadow:0 10px 24px rgba(72,49,28,.07)!important;
    }
    .dpc-app .dpc-food-table tbody tr.is-active{background:#f5faef!important;border-color:#dce8cf!important}
    .dpc-app .dpc-food-table tbody td{
        display:grid!important;
        grid-template-columns:120px 1fr!important;
        gap:10px!important;
        align-items:start!important;
        padding:8px 0!important;
        font-size:15px!important;
        line-height:1.35!important;
        color:#3d403a!important;
        border-bottom:1px solid rgba(230,219,200,.72)!important;
    }
    .dpc-app .dpc-food-table tbody td:last-child{border-bottom:0!important;font-size:15px!important}
    .dpc-app .dpc-food-table tbody td:before{
        content:attr(data-label);
        font-size:11px;
        font-weight:900;
        letter-spacing:.07em;
        text-transform:uppercase;
        color:#9a7c38;
        font-family:Inter,system-ui,sans-serif;
    }
    .dpc-app .dpc-food-table tbody td strong{font-size:17px!important}
}

/* ===== v2.3.0 polish: hero nav, timeline, kit button, mobile adaptive ===== */
.dpc-app .dpc-timeline-section,
.dpc-app .dpc-kit-section{
    border-radius:30px;
}

@media (min-width:941px){
    .dpc-app .dpc-hero--landing .dpc-jump-nav{
        bottom:12px !important;
    }
}

.dpc-app .dpc-timeline-section{
    padding:28px 30px 18px;
    background:
        linear-gradient(180deg, rgba(255,250,242,.90), rgba(255,250,242,.86)),
        url('/dog-pregnancy-calculator-app/assets/decor/timeline-bg.webp') no-repeat top center / cover !important;
    box-shadow:0 18px 40px rgba(90,69,31,.09);
}
.dpc-app .dpc-timeline-section:before,
.dpc-app .dpc-timeline-section:after,
.dpc-app .dpc-timeline-scene{display:none !important;}
.dpc-app .dpc-timeline-section .dpc-section__head{
    max-width:560px;
    margin-bottom:14px;
}
.dpc-app .dpc-timeline-section .dpc-kicker{
    min-height:38px;
    padding:8px 18px;
    color:#f9e4a9;
    background:linear-gradient(180deg,#113f2e 0%, #2a5d43 100%);
    border:1px solid #b89249;
    box-shadow:inset 0 1px 0 rgba(255,255,255,.16), 0 6px 16px rgba(20,63,46,.16);
}
.dpc-app .dpc-timeline-section .dpc-section__head h3{
    font-size:62px;
    line-height:.96;
    letter-spacing:-.05em;
    max-width:520px;
    margin:0;
}
.dpc-app .dpc-timeline-section .dpc-section__head p{
    max-width:460px;
    margin-top:6px;
    font-size:16px;
    line-height:1.45;
    color:#585d52;
}
.dpc-app .dpc-timeline-progress{
    margin:10px 0 14px;
    height:8px;
    background:rgba(228,216,189,.86);
    border-color:rgba(208,184,125,.52);
}
.dpc-app .dpc-timeline-progress span{
    background:linear-gradient(90deg,#50724c 0%, #c9a157 54%, #efd88f 100%);
}
.dpc-app .dpc-timeline{
    gap:8px;
}
.dpc-app .dpc-milestone{
    grid-template-columns:72px 108px minmax(0,1fr) 112px;
    gap:14px;
    min-height:84px;
    padding:9px 14px;
    border-radius:12px;
    background:rgba(255,255,255,.72);
    border:1px solid rgba(220,210,191,.92);
    box-shadow:0 3px 10px rgba(72,49,28,.06);
}
.dpc-app .dpc-milestone.is-current{
    background:rgba(243,248,232,.92);
    border-color:#cfdbba;
}
.dpc-app .dpc-milestone__icon{
    width:58px;
    height:58px;
    border-radius:50%;
    background:radial-gradient(circle at 35% 35%, #f8eaa8 0%, #ba9345 100%);
    border:3px solid rgba(255,247,219,.82);
    box-shadow:0 8px 18px rgba(139,102,32,.16);
    overflow:hidden;
}
.dpc-app .dpc-milestone__icon img{
    width:100%;
    height:100%;
    object-fit:cover;
    border-radius:50%;
}
.dpc-app .dpc-milestone__icon span{
    font-size:26px;
    color:#fff7df;
}
.dpc-app .dpc-milestone__day{
    font-size:22px;
    font-weight:800;
    line-height:1.06;
    color:#20361e;
}
.dpc-app .dpc-milestone__day small{
    margin-top:2px;
    font-size:16px;
    line-height:1.05;
    font-weight:800;
    color:#20361e;
}
.dpc-app .dpc-milestone__copy{
    position:relative;
    padding-left:18px;
}
.dpc-app .dpc-milestone__copy:before{
    content:"";
    position:absolute;
    left:0;
    top:6px;
    bottom:6px;
    width:2px;
    border-radius:99px;
    background:linear-gradient(180deg,#dcc07d 0%, #c8a559 100%);
}
.dpc-app .dpc-milestone h4{
    margin:0 0 2px;
    font-size:20px;
    line-height:1.12;
}
.dpc-app .dpc-milestone p{
    margin:0;
    font-size:13px;
    line-height:1.35;
    color:#5e635d;
}
.dpc-app .dpc-milestone__status{
    min-width:96px;
    padding:10px 14px;
    background:linear-gradient(180deg,#fff8eb 0%, #f6edd8 100%);
    border:1px solid #ead7a8;
    color:#b28b44;
    font-size:16px;
    font-weight:700;
    font-family:Georgia,"Times New Roman",serif;
    box-shadow:0 4px 10px rgba(150,121,54,.08);
}
.dpc-app .dpc-milestone.is-current .dpc-milestone__status{
    background:linear-gradient(180deg,#eef7dd 0%, #e2eed1 100%);
    border-color:#cddcaf;
    color:#5e7a48;
}
.dpc-app .dpc-milestone.is-past .dpc-milestone__status{
    color:#9a8d70;
    background:linear-gradient(180deg,#f7f1e5 0%, #f4ece0 100%);
}

.dpc-app .dpc-kit-section .dpc-section__head--split{
    align-items:flex-end;
}
.dpc-app .dpc-kit-section .dpc-soft-btn{
    align-self:flex-end;
    margin-top:18px;
    min-height:62px;
    min-width:250px;
    padding:16px 28px;
    border-radius:18px;
    background:linear-gradient(180deg,#eed792 0%, #d0a450 100%);
    border:1px solid #c29543;
    box-shadow:0 14px 24px rgba(188,142,55,.18), inset 0 1px 0 rgba(255,255,255,.28);
    color:#fffaf0;
    font-size:20px;
    font-weight:800;
}
.dpc-app .dpc-kit-section .dpc-soft-btn:hover{
    background:linear-gradient(180deg,#f1dc9e 0%, #d7a953 100%);
}

@media (max-width:980px){
    .dpc-app .dpc-timeline-section{padding:22px 18px 16px;background-position:68% top !important;}
    .dpc-app .dpc-timeline-section .dpc-section__head h3{font-size:46px;max-width:420px;}
    .dpc-app .dpc-milestone{grid-template-columns:64px 86px minmax(0,1fr) 98px;gap:10px;padding:10px 12px;}
    .dpc-app .dpc-milestone__day{font-size:19px;}
    .dpc-app .dpc-milestone__day small{font-size:14px;}
    .dpc-app .dpc-milestone h4{font-size:18px;}
    .dpc-app .dpc-milestone p{font-size:12px;}
    .dpc-app .dpc-milestone__status{font-size:14px;min-width:88px;padding:9px 10px;}
    .dpc-app .dpc-kit-section .dpc-soft-btn{min-width:220px;font-size:18px;}
}

@media (max-width:720px){
    .dpc-app .dpc-section{
        padding:18px 14px !important;
        border-radius:24px !important;
    }
    .dpc-app .dpc-section__head h3{font-size:34px !important;line-height:.98 !important;max-width:100% !important;}
    .dpc-app .dpc-section__head p{font-size:14px !important;line-height:1.45 !important;max-width:100% !important;}

    .dpc-app .dpc-timeline-section{
        background-position:72% top !important;
        background-size:cover !important;
    }
    .dpc-app .dpc-timeline-progress{margin:12px 0 12px !important;}
    .dpc-app .dpc-milestone{
        grid-template-columns:56px 1fr;
        grid-template-areas:
            "icon day"
            "copy copy"
            "status status";
        padding:12px 12px 14px;
        gap:10px;
    }
    .dpc-app .dpc-milestone__icon{grid-area:icon;width:54px;height:54px;}
    .dpc-app .dpc-milestone__day{grid-area:day;font-size:21px;display:flex;align-items:center;gap:6px;flex-wrap:wrap;}
    .dpc-app .dpc-milestone__day small{display:inline-block;margin:0;font-size:21px;}
    .dpc-app .dpc-milestone__copy{grid-area:copy;padding-left:0;}
    .dpc-app .dpc-milestone__copy:before{display:none;}
    .dpc-app .dpc-milestone__status{grid-area:status;justify-self:start;min-width:0;font-size:14px;}

    .dpc-app .dpc-section__head--split{
        display:grid !important;
        gap:14px;
    }
    .dpc-app .dpc-kit-section .dpc-soft-btn{
        width:100%;
        margin-top:0;
        min-width:0;
        justify-self:stretch;
        font-size:18px;
    }
    .dpc-app .dpc-kit-grid{grid-template-columns:1fr !important;gap:12px !important;}
    .dpc-app .dpc-kit-item{grid-template-columns:92px 36px 1fr !important;gap:10px !important;padding:12px !important;}
    .dpc-app .dpc-kit-thumb{height:78px !important;}
    .dpc-app .dpc-kit-copy strong{font-size:17px !important;}
    .dpc-app .dpc-kit-copy small{font-size:12px !important;line-height:1.4 !important;}
    .dpc-app .dpc-kit-meter{padding:10px 12px !important;gap:12px !important;}
    .dpc-app .dpc-kit-meter span{min-width:58px !important;height:38px !important;font-size:16px !important;}

    .dpc-app .dpc-diary-layout,
    .dpc-app .dpc-nutrition-layout,
    .dpc-app .dpc-copy-grid{grid-template-columns:1fr !important;gap:14px !important;}
    .dpc-app .dpc-field-grid--diary,
    .dpc-app .dpc-field-grid--nutrition{grid-template-columns:1fr !important;}
    .dpc-app .dpc-food-grid{grid-template-columns:1fr !important;}
    .dpc-app .dpc-table-wrap{padding:0 !important;border:0 !important;background:transparent !important;box-shadow:none !important;}
    .dpc-app .dpc-food-table{min-width:720px !important;}
}


/* ===== v2.4.0 final mobile hero + late timeline icons + mobile cards ===== */

/* Mobile first screen: taller portrait layout, no overlapping */
@media (max-width:720px){
    .dpc-app{
        max-width:430px!important;
        width:100%!important;
        margin-inline:auto!important;
    }

    .dpc-app .dpc-hero.dpc-hero--landing{
        height:1080px!important;
        min-height:1080px!important;
        padding:0!important;
        border-radius:28px!important;
        background-image:url('decor/hero-mobile-bg.webp')!important;
        background-size:100% 100%!important;
        background-position:center top!important;
        background-repeat:no-repeat!important;
        overflow:hidden!important;
        box-shadow:0 18px 40px rgba(55,38,22,.14)!important;
    }
    .dpc-app .dpc-hero.dpc-hero--landing:before,
    .dpc-app .dpc-hero.dpc-hero--landing:after{
        display:none!important;
        content:none!important;
    }
    .dpc-app .dpc-hero__stage{
        position:absolute!important;
        inset:0!important;
        display:block!important;
        z-index:1!important;
    }

    .dpc-app .dpc-hero__title-wrap{
        position:absolute!important;
        left:46px!important;
        top:120px!important;
        width:300px!important;
        max-width:300px!important;
        z-index:3!important;
    }
    .dpc-app .dpc-hero__title-wrap:before{
        content:"—  🐾  —"!important;
        display:block!important;
        width:190px!important;
        margin:0 0 24px 70px!important;
        color:#d5a33b!important;
        font-size:24px!important;
        letter-spacing:.14em!important;
        text-align:center!important;
        line-height:1!important;
    }
    .dpc-app .dpc-hero__title-wrap h2{
        font-size:58px!important;
        line-height:.82!important;
        letter-spacing:-.06em!important;
        text-shadow:0 1px 0 rgba(255,255,255,.55)!important;
        margin:0!important;
    }
    .dpc-app .dpc-hero__title-wrap h2 span:nth-child(2){
        color:#b98e27!important;
    }
    .dpc-app .dpc-hero-tagline{
        margin:20px 0 0!important;
        max-width:280px!important;
        font-size:19px!important;
        line-height:1.25!important;
        color:#697565!important;
    }
    .dpc-app .dpc-title-flourish{
        display:block!important;
        width:auto!important;
        margin:22px 0 0 130px!important;
        border:0!important;
        font-size:0!important;
        line-height:1!important;
    }
    .dpc-app .dpc-title-flourish:after{
        content:"♡"!important;
        font-size:24px!important;
        color:#d0a23a!important;
    }

    .dpc-app .dpc-hero--landing .dpc-main{
        position:absolute!important;
        left:28px!important;
        right:28px!important;
        top:510px!important;
        width:auto!important;
        max-width:none!important;
        padding:25px 22px 24px!important;
        border-radius:28px!important;
        background:rgba(255,255,255,.94)!important;
        border:1px solid rgba(237,229,216,.96)!important;
        box-shadow:0 18px 42px rgba(55,38,22,.16)!important;
        backdrop-filter:blur(8px)!important;
    }
    .dpc-app .dpc-hero--landing .dpc-main .dpc-field-grid{
        gap:16px!important;
    }
    .dpc-app .dpc-hero--landing .dpc-field{
        position:relative!important;
        gap:8px!important;
        margin-left:0!important;
        padding-left:0!important;
    }
    .dpc-app .dpc-hero--landing .dpc-field span{
        font-size:18px!important;
        line-height:1.1!important;
        font-family:Georgia,"Times New Roman",serif!important;
        color:#29432e!important;
        font-weight:800!important;
    }
    .dpc-app .dpc-hero--landing .dpc-field:before,
    .dpc-app .dpc-hero--landing .dpc-field:after{
        display:none!important;
        content:none!important;
    }
    .dpc-app .dpc-hero--landing .dpc-field input,
    .dpc-app .dpc-hero--landing .dpc-field select{
        min-height:56px!important;
        border-radius:12px!important;
        padding:0 18px!important;
        font-size:17px!important;
        background:rgba(255,255,255,.90)!important;
        border:1px solid #dfd8cd!important;
        box-shadow:inset 0 1px 0 rgba(255,255,255,.9)!important;
    }
    .dpc-app .dpc-hero--landing .dpc-main-actions{
        margin-top:22px!important;
        display:block!important;
    }
    .dpc-app .dpc-hero--landing .dpc-primary-btn{
        min-height:70px!important;
        width:100%!important;
        border-radius:30px!important;
        font-size:25px!important;
        font-weight:900!important;
        background:linear-gradient(180deg,#19d44d 0%,#008b30 100%)!important;
        box-shadow:0 0 22px rgba(34,214,76,.35),0 18px 28px rgba(17,137,62,.26), inset 0 1px 0 rgba(255,255,255,.34)!important;
    }

    .dpc-app .dpc-hero--landing .dpc-jump-nav{
        position:absolute!important;
        left:28px!important;
        right:28px!important;
        top:805px!important;
        bottom:auto!important;
        width:auto!important;
        display:grid!important;
        grid-template-columns:1fr 1fr!important;
        gap:16px!important;
        margin:0!important;
    }
    .dpc-app .dpc-hero--landing .dpc-jump-card{
        position:relative!important;
        min-height:120px!important;
        border-radius:24px!important;
        padding:18px 15px 16px!important;
        display:grid!important;
        grid-template-columns:58px 1fr!important;
        gap:13px!important;
        align-items:center!important;
        text-align:left!important;
        border:1px solid rgba(255,255,255,.88)!important;
        box-shadow:0 14px 28px rgba(64,43,24,.10)!important;
    }
    .dpc-app .dpc-hero--landing .dpc-jump-card--green{background:linear-gradient(145deg,#eefbea 0%,#d7f1d6 100%)!important;}
    .dpc-app .dpc-hero--landing .dpc-jump-card--gold{background:linear-gradient(145deg,#fff9e7 0%,#f8e8ae 100%)!important;}
    .dpc-app .dpc-hero--landing .dpc-jump-card--peach{background:linear-gradient(145deg,#fff0f0 0%,#ffdfe2 100%)!important;}
    .dpc-app .dpc-hero--landing .dpc-jump-card--sage{background:linear-gradient(145deg,#f2fbff 0%,#d8f0ff 100%)!important;}
    .dpc-app .dpc-hero--landing .dpc-jump-card__icon{
        width:62px!important;
        height:62px!important;
        border-radius:50%!important;
        background:#fff!important;
        border:1px solid rgba(255,255,255,.86)!important;
        box-shadow:0 10px 22px rgba(36,61,37,.12)!important;
        font-size:30px!important;
    }
    .dpc-app .dpc-hero--landing .dpc-jump-card strong{
        font-size:27px!important;
        line-height:1.02!important;
        letter-spacing:-.03em!important;
        color:#11281b!important;
    }
    .dpc-app .dpc-hero--landing .dpc-jump-card em{
        position:absolute!important;
        right:18px!important;
        bottom:18px!important;
        width:34px!important;
        height:34px!important;
        display:grid!important;
        place-items:center!important;
        border-radius:50%!important;
        background:#fff!important;
        color:#16813a!important;
        font-size:20px!important;
        box-shadow:0 8px 16px rgba(64,43,24,.10)!important;
    }
    .dpc-app .dpc-hero--landing .dpc-result{
        display:none!important;
    }
}

/* smaller phones */
@media (max-width:430px){
    .dpc-app .dpc-hero.dpc-hero--landing{
        height:1000px!important;
        min-height:1000px!important;
    }
    .dpc-app .dpc-hero__title-wrap{
        left:34px!important;
        top:92px!important;
        width:260px!important;
        max-width:260px!important;
    }
    .dpc-app .dpc-hero__title-wrap:before{
        margin-left:58px!important;
        margin-bottom:18px!important;
        font-size:20px!important;
    }
    .dpc-app .dpc-hero__title-wrap h2{
        font-size:50px!important;
    }
    .dpc-app .dpc-hero-tagline{
        font-size:16px!important;
        margin-top:14px!important;
    }
    .dpc-app .dpc-title-flourish{
        margin-top:14px!important;
        margin-left:112px!important;
    }
    .dpc-app .dpc-hero--landing .dpc-main{
        top:430px!important;
        left:22px!important;
        right:22px!important;
        padding:20px 18px!important;
    }
    .dpc-app .dpc-hero--landing .dpc-field span{
        font-size:16px!important;
    }
    .dpc-app .dpc-hero--landing .dpc-field input,
    .dpc-app .dpc-hero--landing .dpc-field select{
        min-height:48px!important;
        font-size:15px!important;
    }
    .dpc-app .dpc-hero--landing .dpc-primary-btn{
        min-height:60px!important;
        font-size:19px!important;
    }
    .dpc-app .dpc-hero--landing .dpc-jump-nav{
        top:700px!important;
        left:22px!important;
        right:22px!important;
        gap:12px!important;
    }
    .dpc-app .dpc-hero--landing .dpc-jump-card{
        min-height:112px!important;
        grid-template-columns:52px 1fr!important;
        padding:15px 12px!important;
    }
    .dpc-app .dpc-hero--landing .dpc-jump-card__icon{
        width:54px!important;
        height:54px!important;
        font-size:26px!important;
    }
    .dpc-app .dpc-hero--landing .dpc-jump-card strong{
        font-size:22px!important;
    }
}

/* Timeline icons: keep real images round and avoid emoji fallback look */
.dpc-app .dpc-milestone__icon img{
    display:block!important;
    width:100%!important;
    height:100%!important;
    object-fit:cover!important;
    border-radius:50%!important;
}

/* Mobile: make all complex sections single-column and prevent table-in-table look */
@media (max-width:720px){
    .dpc-app .dpc-section,
    .dpc-app .dpc-panel{
        max-width:100%!important;
        overflow:hidden!important;
    }
    .dpc-app .dpc-diary-layout,
    .dpc-app .dpc-nutrition-layout,
    .dpc-app .dpc-copy-grid,
    .dpc-app .dpc-food-grid{
        display:grid!important;
        grid-template-columns:1fr!important;
        gap:14px!important;
    }
    .dpc-app .dpc-field-grid,
    .dpc-app .dpc-field-grid--diary,
    .dpc-app .dpc-field-grid--nutrition{
        display:grid!important;
        grid-template-columns:1fr!important;
        gap:12px!important;
    }
    .dpc-app .dpc-table-wrap{
        overflow:visible!important;
        padding:0!important;
        border:0!important;
        box-shadow:none!important;
        background:transparent!important;
    }
    .dpc-app .dpc-food-table,
    .dpc-app .dpc-food-table thead,
    .dpc-app .dpc-food-table tbody,
    .dpc-app .dpc-food-table tr,
    .dpc-app .dpc-food-table td,
    .dpc-app .dpc-food-table th{
        display:block!important;
        width:100%!important;
        min-width:0!important;
        max-width:100%!important;
        border:0!important;
    }
    .dpc-app .dpc-food-table thead{
        display:none!important;
    }
    .dpc-app .dpc-food-table{
        background:transparent!important;
        border-collapse:separate!important;
        border-spacing:0!important;
        table-layout:auto!important;
    }
    .dpc-app .dpc-food-table tbody{
        display:grid!important;
        gap:12px!important;
    }
    .dpc-app .dpc-food-table tbody tr{
        display:grid!important;
        gap:0!important;
        padding:14px!important;
        border-radius:18px!important;
        background:#fffdf8!important;
        border:1px solid #eadfcf!important;
        box-shadow:0 10px 24px rgba(72,49,28,.07)!important;
    }
    .dpc-app .dpc-food-table tbody tr.is-active{
        background:#f5faef!important;
        border-color:#dce8cf!important;
    }
    .dpc-app .dpc-food-table tbody td{
        display:grid!important;
        grid-template-columns:118px 1fr!important;
        gap:10px!important;
        align-items:start!important;
        padding:8px 0!important;
        font-size:15px!important;
        line-height:1.35!important;
        color:#3d403a!important;
        border-bottom:1px solid rgba(230,219,200,.72)!important;
    }
    .dpc-app .dpc-food-table tbody td:last-child{
        border-bottom:0!important;
        font-size:15px!important;
    }
    .dpc-app .dpc-food-table tbody td:before{
        content:attr(data-label)!important;
        font-size:11px!important;
        font-weight:900!important;
        letter-spacing:.07em!important;
        text-transform:uppercase!important;
        color:#9a7c38!important;
        font-family:Inter,system-ui,sans-serif!important;
    }
}


/* ===== v2.5.1 responsive reupload fix ===== */
.dpc-app,.dpc-app *{box-sizing:border-box}
.dpc-app{overflow-x:hidden}
.dpc-app img{max-width:100%;height:auto}
.dpc-app .dpc-section,.dpc-app .dpc-panel,.dpc-app .dpc-table-wrap{max-width:100%}

@media (min-width:941px){
    .dpc-app .dpc-hero.dpc-hero--landing{
        height:760px!important;
        min-height:760px!important;
        background-position:center center!important;
    }
    .dpc-app .dpc-hero__title-wrap{left:46px!important;top:34px!important;width:370px!important;max-width:370px!important}
    .dpc-app .dpc-hero__title-wrap h2{font-size:76px!important;line-height:.84!important}
    .dpc-app .dpc-hero-tagline{margin-top:10px!important;font-size:18px!important}
    .dpc-app .dpc-hero--landing .dpc-main{left:48px!important;top:255px!important;width:380px!important;padding:18px 20px!important}
    .dpc-app .dpc-hero--landing .dpc-jump-nav{
        left:48px!important;right:auto!important;bottom:18px!important;width:436px!important;
        grid-template-columns:repeat(4,1fr)!important;gap:10px!important
    }
    .dpc-app .dpc-hero--landing .dpc-jump-card{min-height:136px!important;padding:15px 12px 12px!important}
    .dpc-app .dpc-hero--landing .dpc-jump-card strong{font-size:20px!important;line-height:1.05!important}
    .dpc-app .dpc-hero--landing .dpc-result{
        right:40px!important;bottom:44px!important;width:395px!important;min-height:140px!important;
        padding:18px 20px!important;grid-template-columns:78px 1fr 18px!important;gap:14px!important
    }
    .dpc-app .dpc-hero--landing .dpc-result__hero strong{font-size:30px!important;line-height:.96!important}
}

@media (min-width:721px) and (max-width:940px){
    .dpc-app .dpc-hero.dpc-hero--landing{height:auto!important;min-height:0!important;padding:22px!important;background-position:68% center!important}
    .dpc-app .dpc-hero.dpc-hero--landing:before{
        content:""!important;display:block!important;position:absolute;inset:0;
        background:linear-gradient(90deg,rgba(255,250,241,.92),rgba(255,250,241,.78) 48%,rgba(255,250,241,.30));z-index:0
    }
    .dpc-app .dpc-hero__stage{position:relative!important;display:grid!important;gap:16px!important;z-index:1!important}
    .dpc-app .dpc-hero__title-wrap,
    .dpc-app .dpc-hero--landing .dpc-main,
    .dpc-app .dpc-hero--landing .dpc-jump-nav,
    .dpc-app .dpc-hero--landing .dpc-result{
        position:relative!important;inset:auto!important;width:auto!important;max-width:100%!important;left:auto!important;right:auto!important;top:auto!important;bottom:auto!important
    }
    .dpc-app .dpc-hero__title-wrap{max-width:320px!important}
    .dpc-app .dpc-hero--landing .dpc-jump-nav{grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:12px!important}
}

@media (max-width:720px){
    .dpc-app{width:100%!important;max-width:100%!important;overflow-x:hidden!important}
    .dpc-app .dpc-hero.dpc-hero--landing{
        position:relative!important;height:1420px!important;min-height:1420px!important;padding:0!important;overflow:hidden!important;
        border-radius:28px!important;background:url('decor/hero-mobile-bg-plain.webp') no-repeat center top / cover!important;
        box-shadow:0 16px 36px rgba(55,38,22,.14)!important
    }
    .dpc-app .dpc-hero.dpc-hero--landing:before{display:none!important;content:none!important}
    .dpc-app .dpc-hero.dpc-hero--landing:after{
        content:""!important;position:absolute!important;top:72px!important;right:6px!important;width:46%!important;max-width:220px!important;height:420px!important;
        background:url('decor/hero-mobile-dog.webp') no-repeat center top / contain!important;z-index:1!important;pointer-events:none!important
    }
    .dpc-app .dpc-hero__stage{position:absolute!important;inset:0!important;display:block!important;z-index:2!important}
    .dpc-app .dpc-hero__title-wrap{position:absolute!important;left:28px!important;top:54px!important;width:52%!important;max-width:210px!important;z-index:3!important}
    .dpc-app .dpc-hero__title-wrap:before{
        content:"—  🐾  —"!important;display:block!important;width:150px!important;margin:0 0 14px 42px!important;
        color:#cc9a27!important;text-align:center!important;font-size:18px!important;letter-spacing:.12em!important
    }
    .dpc-app .dpc-hero__title-wrap h2{margin:0!important;font-size:54px!important;line-height:.82!important;letter-spacing:-.06em!important}
    .dpc-app .dpc-hero__title-wrap h2 span:nth-child(2){color:#c39020!important}
    .dpc-app .dpc-hero-tagline{margin:14px 0 0!important;max-width:240px!important;font-size:16px!important;line-height:1.25!important;color:#6f7964!important}
    .dpc-app .dpc-title-flourish{width:auto!important;margin:14px 0 0 98px!important;border:0!important;font-size:0!important}
    .dpc-app .dpc-title-flourish:after{content:"♡"!important;font-size:20px!important;color:#d2a031!important}
    .dpc-app .dpc-hero--landing .dpc-main{
        position:absolute!important;left:22px!important;right:22px!important;top:360px!important;width:auto!important;max-width:none!important;
        padding:18px 16px 16px!important;border-radius:26px!important;background:rgba(255,255,255,.94)!important;
        border:1px solid rgba(233,225,213,.96)!important;box-shadow:0 16px 34px rgba(55,38,22,.16)!important;backdrop-filter:blur(6px)!important
    }
    .dpc-app .dpc-hero--landing .dpc-main .dpc-field-grid{display:grid!important;grid-template-columns:1fr!important;gap:12px!important}
    .dpc-app .dpc-hero--landing .dpc-field{gap:7px!important;padding-left:0!important;margin-left:0!important}
    .dpc-app .dpc-hero--landing .dpc-field:before,.dpc-app .dpc-hero--landing .dpc-field:after{display:none!important;content:none!important}
    .dpc-app .dpc-hero--landing .dpc-field span{font-size:16px!important;font-weight:800!important;line-height:1.15!important;color:#233728!important}
    .dpc-app .dpc-hero--landing .dpc-field input,.dpc-app .dpc-hero--landing .dpc-field select{
        min-height:50px!important;padding:0 14px!important;border-radius:12px!important;font-size:16px!important;background:#fff!important;border:1px solid #ded8cf!important
    }
    .dpc-app .dpc-hero--landing .dpc-main-actions{margin-top:14px!important;display:block!important}
    .dpc-app .dpc-hero--landing .dpc-primary-btn{
        width:100%!important;min-height:58px!important;padding:0 18px!important;border-radius:18px!important;font-size:18px!important;
        line-height:1.15!important;white-space:normal!important;text-align:center!important;
        background:linear-gradient(180deg,#2ac65d 0%,#0b8936 100%)!important;box-shadow:0 12px 24px rgba(17,137,62,.28), inset 0 1px 0 rgba(255,255,255,.24)!important
    }
    .dpc-app .dpc-hero--landing .dpc-jump-nav{
        position:absolute!important;left:22px!important;right:22px!important;top:716px!important;bottom:auto!important;width:auto!important;
        display:grid!important;grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:12px!important;margin:0!important
    }
    .dpc-app .dpc-hero--landing .dpc-jump-card{
        min-width:0!important;min-height:164px!important;padding:16px 14px!important;border-radius:22px!important;
        display:grid!important;grid-template-columns:1fr!important;gap:10px!important;align-content:start!important;justify-items:start!important;
        text-align:left!important;overflow:hidden!important;box-shadow:0 12px 24px rgba(65,45,24,.10)!important
    }
    .dpc-app .dpc-hero--landing .dpc-jump-card__icon{width:56px!important;height:56px!important;border-radius:50%!important;background:#fff!important;font-size:28px!important;box-shadow:0 8px 18px rgba(36,61,37,.12)!important}
    .dpc-app .dpc-hero--landing .dpc-jump-card strong{display:block!important;max-width:100%!important;font-size:19px!important;line-height:1.12!important;overflow-wrap:anywhere!important}
    .dpc-app .dpc-hero--landing .dpc-jump-card em{position:absolute!important;right:14px!important;bottom:14px!important;width:28px!important;height:28px!important;font-size:16px!important}
    .dpc-app .dpc-hero--landing .dpc-result{display:none!important}

    .dpc-app .dpc-section,.dpc-app .dpc-panel{width:100%!important;max-width:100%!important;border-radius:22px!important;padding:18px 14px!important;overflow:hidden!important}
    .dpc-app .dpc-section__head h3{font-size:32px!important;line-height:1.02!important;max-width:100%!important}
    .dpc-app .dpc-section__head p{font-size:14px!important;line-height:1.45!important;max-width:100%!important}
    .dpc-app .dpc-field-grid,.dpc-app .dpc-field-grid--diary,.dpc-app .dpc-field-grid--nutrition,.dpc-app .dpc-diary-layout,.dpc-app .dpc-nutrition-layout,.dpc-app .dpc-copy-grid,.dpc-app .dpc-food-grid{display:grid!important;grid-template-columns:1fr!important;gap:14px!important}
    .dpc-app .dpc-kit-grid{grid-template-columns:1fr!important;gap:12px!important}
    .dpc-app .dpc-kit-item{grid-template-columns:86px 34px 1fr!important;gap:10px!important;padding:12px!important}
    .dpc-app .dpc-kit-thumb{height:74px!important}
    .dpc-app .dpc-diary-list{max-height:none!important;padding-right:0!important}
    .dpc-app .dpc-chart-panel,.dpc-app .dpc-diary-form,.dpc-app .dpc-nutrition-form,.dpc-app .dpc-food-panel{padding:16px 14px!important}

    .dpc-app .dpc-table-wrap{width:100%!important;max-width:100%!important;overflow:visible!important;padding:0!important;border:0!important;background:transparent!important;box-shadow:none!important;margin-top:14px!important}
    .dpc-app .dpc-food-table,.dpc-app .dpc-food-table thead,.dpc-app .dpc-food-table tbody,.dpc-app .dpc-food-table tr,.dpc-app .dpc-food-table td,.dpc-app .dpc-food-table th{display:block!important;width:100%!important;max-width:100%!important;min-width:0!important;border:0!important}
    .dpc-app .dpc-food-table{min-width:0!important;background:transparent!important;border-spacing:0!important;table-layout:auto!important}
    .dpc-app .dpc-food-table thead{display:none!important}
    .dpc-app .dpc-food-table tbody{display:grid!important;gap:12px!important}
    .dpc-app .dpc-food-table tbody tr{display:grid!important;gap:0!important;padding:14px!important;border-radius:18px!important;background:#fffdf8!important;border:1px solid #eadfcf!important;box-shadow:0 10px 24px rgba(72,49,28,.07)!important}
    .dpc-app .dpc-food-table tbody tr.is-active{background:#f5faef!important;border-color:#dce8cf!important}
    .dpc-app .dpc-food-table tbody td{
        display:grid!important;grid-template-columns:110px minmax(0,1fr)!important;gap:10px!important;align-items:start!important;
        padding:8px 0!important;border-bottom:1px solid rgba(230,219,200,.72)!important;font-size:14px!important;line-height:1.35!important;
        color:#3d403a!important;word-break:break-word!important;overflow-wrap:anywhere!important;white-space:normal!important
    }
    .dpc-app .dpc-food-table tbody td:last-child{border-bottom:0!important}
    .dpc-app .dpc-food-table tbody td:before{
        content:attr(data-label)!important;display:block!important;font-size:11px!important;line-height:1.3!important;font-weight:900!important;
        letter-spacing:.06em!important;text-transform:uppercase!important;color:#9a7c38!important;white-space:normal!important
    }
}

@media (max-width:430px){
    .dpc-app .dpc-hero.dpc-hero--landing{height:1360px!important;min-height:1360px!important}
    .dpc-app .dpc-hero.dpc-hero--landing:after{top:66px!important;right:4px!important;width:44%!important;max-width:190px!important;height:360px!important}
    .dpc-app .dpc-hero__title-wrap{left:20px!important;top:48px!important;width:50%!important;max-width:190px!important}
    .dpc-app .dpc-hero__title-wrap:before{margin-left:34px!important;width:140px!important;font-size:16px!important}
    .dpc-app .dpc-hero__title-wrap h2{font-size:44px!important}
    .dpc-app .dpc-hero-tagline{font-size:14px!important;max-width:180px!important}
    .dpc-app .dpc-title-flourish{margin-left:82px!important}
    .dpc-app .dpc-hero--landing .dpc-main{top:330px!important;left:16px!important;right:16px!important;padding:16px 14px!important}
    .dpc-app .dpc-hero--landing .dpc-field span{font-size:15px!important}
    .dpc-app .dpc-hero--landing .dpc-field input,.dpc-app .dpc-hero--landing .dpc-field select{min-height:46px!important;font-size:15px!important}
    .dpc-app .dpc-hero--landing .dpc-primary-btn{min-height:54px!important;font-size:17px!important}
    .dpc-app .dpc-hero--landing .dpc-jump-nav{top:670px!important;left:16px!important;right:16px!important;gap:10px!important}
    .dpc-app .dpc-hero--landing .dpc-jump-card{min-height:148px!important;padding:14px 12px!important}
    .dpc-app .dpc-hero--landing .dpc-jump-card strong{font-size:17px!important}
    .dpc-app .dpc-food-table tbody td{grid-template-columns:1fr!important;gap:4px!important}
}

/* ===== v2.6.0 hard fix: clean form, no dog-name, real mobile dog, full-width mobile, table cards ===== */
.dpc-app .dpc-hero-tagline,
.dpc-app .dpc-title-flourish{display:none!important;}
.dpc-app .dpc-mobile-dog{display:none;}
.dpc-app .dpc-hero--landing .dpc-field:before,
.dpc-app .dpc-hero--landing .dpc-field:after{display:none!important;content:none!important;}
.dpc-app .dpc-hero--landing .dpc-field input,
.dpc-app .dpc-hero--landing .dpc-field select{padding-left:16px!important;}
.dpc-app .dpc-hero--landing .dpc-primary-btn{white-space:normal!important;}

@media (min-width:941px){
    .dpc-app .dpc-hero.dpc-hero--landing{
        height:820px!important;
        min-height:820px!important;
        background-position:center center!important;
    }
    .dpc-app .dpc-hero__title-wrap{
        left:48px!important;
        top:42px!important;
        width:430px!important;
        max-width:430px!important;
    }
    .dpc-app .dpc-hero__title-wrap h2{
        font-size:82px!important;
        line-height:.84!important;
    }
    .dpc-app .dpc-hero--landing .dpc-main{
        left:48px!important;
        top:300px!important;
        width:390px!important;
        padding:20px!important;
    }
    .dpc-app .dpc-hero--landing .dpc-main .dpc-field-grid{gap:14px!important;}
    .dpc-app .dpc-hero--landing .dpc-field input,
    .dpc-app .dpc-hero--landing .dpc-field select{min-height:48px!important;font-size:16px!important;}
    .dpc-app .dpc-hero--landing .dpc-primary-btn{min-height:60px!important;font-size:17px!important;}
    .dpc-app .dpc-hero--landing .dpc-jump-nav{
        left:48px!important;
        bottom:34px!important;
        width:460px!important;
        display:grid!important;
        grid-template-columns:repeat(4,1fr)!important;
        gap:12px!important;
        align-items:stretch!important;
    }
    .dpc-app .dpc-hero--landing .dpc-jump-card{
        height:142px!important;
        min-height:142px!important;
        width:100%!important;
        min-width:0!important;
        display:flex!important;
        flex-direction:column!important;
        align-items:center!important;
        justify-content:center!important;
        text-align:center!important;
        gap:10px!important;
        padding:14px 10px!important;
        overflow:hidden!important;
    }
    .dpc-app .dpc-hero--landing .dpc-jump-card__icon{width:48px!important;height:48px!important;margin:0!important;}
    .dpc-app .dpc-hero--landing .dpc-jump-card strong{font-size:18px!important;line-height:1.05!important;}
    .dpc-app .dpc-hero--landing .dpc-jump-card em{position:static!important;width:28px!important;height:28px!important;margin-top:auto!important;}
    .dpc-app .dpc-hero--landing .dpc-result{
        right:44px!important;
        bottom:58px!important;
        width:395px!important;
        min-height:136px!important;
        padding:18px 20px!important;
    }
    .dpc-app .dpc-hero--landing .dpc-result__hero strong{font-size:28px!important;line-height:1!important;}
}

@media (min-width:721px) and (max-width:940px){
    .dpc-app .dpc-hero.dpc-hero--landing{height:auto!important;min-height:0!important;padding:24px!important;}
    .dpc-app .dpc-hero__stage{position:relative!important;display:grid!important;grid-template-columns:1fr!important;gap:16px!important;}
    .dpc-app .dpc-hero__title-wrap,
    .dpc-app .dpc-hero--landing .dpc-main,
    .dpc-app .dpc-hero--landing .dpc-jump-nav,
    .dpc-app .dpc-hero--landing .dpc-result{
        position:relative!important;left:auto!important;right:auto!important;top:auto!important;bottom:auto!important;width:auto!important;max-width:100%!important;
    }
    .dpc-app .dpc-hero--landing .dpc-jump-nav{grid-template-columns:repeat(2,minmax(0,1fr))!important;}
    .dpc-app .dpc-hero--landing .dpc-jump-card{height:120px!important;min-height:120px!important;}
}

@media (max-width:720px){
    article.content-panel:has(.dpc-app),
    .legal-content:has(.dpc-app),
    .app-main-panel:has(.dpc-app),
    .app-stage-panel:has(.dpc-app),
    .app-stage-panel-wide:has(.dpc-app){
        padding-left:0!important;
        padding-right:0!important;
        margin-left:0!important;
        margin-right:0!important;
        max-width:none!important;
        width:100%!important;
        overflow:visible!important;
    }
    .dpc-app{
        width:100vw!important;
        max-width:100vw!important;
        margin-left:calc(50% - 50vw)!important;
        margin-right:calc(50% - 50vw)!important;
        padding:0 8px!important;
        overflow-x:hidden!important;
    }
    .dpc-app .dpc-hero.dpc-hero--landing{
        position:relative!important;
        width:100%!important;
        height:980px!important;
        min-height:980px!important;
        padding:0!important;
        border-radius:28px!important;
        overflow:hidden!important;
        background:url('decor/hero-mobile-bg-plain.webp') no-repeat center top / cover!important;
    }
    .dpc-app .dpc-hero.dpc-hero--landing:before,
    .dpc-app .dpc-hero.dpc-hero--landing:after{display:none!important;content:none!important;}
    .dpc-app .dpc-hero__stage{position:absolute!important;inset:0!important;display:block!important;z-index:2!important;}
    .dpc-app .dpc-mobile-dog{
        display:block!important;
        position:absolute!important;
        top:42px!important;
        right:-12px!important;
        width:46%!important;
        max-width:210px!important;
        height:auto!important;
        z-index:2!important;
        pointer-events:none!important;
        object-fit:contain!important;
    }
    .dpc-app .dpc-hero__title-wrap{
        position:absolute!important;
        left:24px!important;
        top:54px!important;
        width:52%!important;
        max-width:225px!important;
        z-index:3!important;
    }
    .dpc-app .dpc-hero__title-wrap:before{
        content:"—  🐾  —"!important;
        display:block!important;
        width:140px!important;
        margin:0 0 14px 34px!important;
        color:#c99728!important;
        text-align:center!important;
        font-size:17px!important;
        line-height:1!important;
        letter-spacing:.12em!important;
    }
    .dpc-app .dpc-hero__title-wrap h2{font-size:48px!important;line-height:.82!important;letter-spacing:-.06em!important;margin:0!important;}
    .dpc-app .dpc-hero__title-wrap h2 span:nth-child(2){color:#bd8e23!important;}
    .dpc-app .dpc-hero--landing .dpc-main{
        position:absolute!important;
        left:20px!important;
        right:20px!important;
        top:310px!important;
        width:auto!important;
        max-width:none!important;
        padding:18px 16px!important;
        border-radius:24px!important;
        background:rgba(255,255,255,.95)!important;
        box-shadow:0 16px 34px rgba(55,38,22,.15)!important;
    }
    .dpc-app .dpc-hero--landing .dpc-main .dpc-field-grid{display:grid!important;grid-template-columns:1fr!important;gap:13px!important;}
    .dpc-app .dpc-hero--landing .dpc-field{padding:0!important;margin:0!important;gap:7px!important;}
    .dpc-app .dpc-hero--landing .dpc-field span{font-size:15px!important;line-height:1.15!important;color:#20342a!important;font-weight:800!important;}
    .dpc-app .dpc-hero--landing .dpc-field input,
    .dpc-app .dpc-hero--landing .dpc-field select{min-height:48px!important;border-radius:12px!important;font-size:15px!important;padding:0 14px!important;background:#fff!important;}
    .dpc-app .dpc-hero--landing .dpc-main-actions{margin-top:14px!important;display:block!important;}
    .dpc-app .dpc-hero--landing .dpc-primary-btn{width:100%!important;min-height:58px!important;border-radius:18px!important;font-size:18px!important;padding:0 16px!important;}
    .dpc-app .dpc-hero--landing .dpc-jump-nav{
        position:absolute!important;
        left:20px!important;
        right:20px!important;
        top:565px!important;
        bottom:auto!important;
        width:auto!important;
        margin:0!important;
        display:grid!important;
        grid-template-columns:repeat(2,minmax(0,1fr))!important;
        gap:12px!important;
        align-items:stretch!important;
    }
    .dpc-app .dpc-hero--landing .dpc-jump-card{
        height:150px!important;
        min-height:150px!important;
        width:100%!important;
        min-width:0!important;
        display:flex!important;
        flex-direction:column!important;
        justify-content:center!important;
        align-items:center!important;
        text-align:center!important;
        padding:14px 10px!important;
        border-radius:20px!important;
        gap:9px!important;
        overflow:hidden!important;
    }
    .dpc-app .dpc-hero--landing .dpc-jump-card__icon{width:54px!important;height:54px!important;font-size:27px!important;margin:0!important;}
    .dpc-app .dpc-hero--landing .dpc-jump-card strong{font-size:18px!important;line-height:1.08!important;max-width:100%!important;overflow-wrap:anywhere!important;}
    .dpc-app .dpc-hero--landing .dpc-jump-card em{position:static!important;width:28px!important;height:28px!important;margin-top:auto!important;}
    .dpc-app .dpc-hero--landing .dpc-result{display:none!important;}
}

@media (max-width:390px){
    .dpc-app{padding:0 6px!important;}
    .dpc-app .dpc-hero.dpc-hero--landing{height:930px!important;min-height:930px!important;}
    .dpc-app .dpc-mobile-dog{top:50px!important;right:-18px!important;width:45%!important;max-width:170px!important;}
    .dpc-app .dpc-hero__title-wrap{left:18px!important;top:50px!important;max-width:190px!important;}
    .dpc-app .dpc-hero__title-wrap:before{width:120px!important;margin-left:30px!important;font-size:15px!important;}
    .dpc-app .dpc-hero__title-wrap h2{font-size:42px!important;}
    .dpc-app .dpc-hero--landing .dpc-main{left:14px!important;right:14px!important;top:295px!important;padding:16px 14px!important;}
    .dpc-app .dpc-hero--landing .dpc-jump-nav{left:14px!important;right:14px!important;top:535px!important;gap:10px!important;}
    .dpc-app .dpc-hero--landing .dpc-jump-card{height:142px!important;min-height:142px!important;}
    .dpc-app .dpc-hero--landing .dpc-jump-card strong{font-size:16px!important;}
}

@media (max-width:720px){
    .dpc-app .dpc-section,
    .dpc-app .dpc-panel{width:100%!important;max-width:100%!important;padding:18px 14px!important;border-radius:22px!important;overflow:hidden!important;}
    .dpc-app .dpc-section__head h3{font-size:32px!important;line-height:1.03!important;max-width:100%!important;}
    .dpc-app .dpc-section__head p{font-size:14px!important;line-height:1.45!important;max-width:100%!important;}
    .dpc-app .dpc-field-grid,
    .dpc-app .dpc-field-grid--diary,
    .dpc-app .dpc-field-grid--nutrition,
    .dpc-app .dpc-diary-layout,
    .dpc-app .dpc-nutrition-layout,
    .dpc-app .dpc-copy-grid,
    .dpc-app .dpc-food-grid{display:grid!important;grid-template-columns:minmax(0,1fr)!important;gap:14px!important;}
    .dpc-app .dpc-chart{width:100%!important;overflow:hidden!important;}
    .dpc-app .dpc-chart svg{width:100%!important;height:auto!important;max-width:100%!important;}
    .dpc-app .dpc-kit-grid{display:grid!important;grid-template-columns:minmax(0,1fr)!important;gap:12px!important;}
    .dpc-app .dpc-kit-item{grid-template-columns:82px 34px minmax(0,1fr)!important;gap:10px!important;padding:12px!important;}
    .dpc-app .dpc-kit-thumb{height:70px!important;}
    .dpc-app .dpc-kit-copy{min-width:0!important;}
    .dpc-app .dpc-kit-copy strong{font-size:16px!important;overflow-wrap:anywhere!important;}
    .dpc-app .dpc-kit-copy small{font-size:12px!important;line-height:1.35!important;overflow-wrap:anywhere!important;}
    .dpc-app .dpc-food-panel article{min-width:0!important;}
    .dpc-app .dpc-table-wrap{width:100%!important;max-width:100%!important;min-width:0!important;overflow:visible!important;padding:0!important;border:0!important;box-shadow:none!important;background:transparent!important;}
    .dpc-app table.dpc-food-table,
    .dpc-app .dpc-food-table thead,
    .dpc-app .dpc-food-table tbody,
    .dpc-app .dpc-food-table tr,
    .dpc-app .dpc-food-table th,
    .dpc-app .dpc-food-table td{display:block!important;width:100%!important;max-width:100%!important;min-width:0!important;border:0!important;}
    .dpc-app table.dpc-food-table{table-layout:auto!important;border-collapse:separate!important;border-spacing:0!important;background:transparent!important;overflow:visible!important;}
    .dpc-app .dpc-food-table thead{display:none!important;}
    .dpc-app .dpc-food-table tbody{display:grid!important;gap:12px!important;}
    .dpc-app .dpc-food-table tr{padding:14px!important;border-radius:18px!important;background:#fffdf8!important;border:1px solid #eadfcf!important;box-shadow:0 10px 24px rgba(72,49,28,.07)!important;}
    .dpc-app .dpc-food-table tr.is-active{background:#f5faef!important;border-color:#dce8cf!important;}
    .dpc-app .dpc-food-table td{display:flex!important;gap:10px!important;align-items:flex-start!important;justify-content:space-between!important;padding:8px 0!important;border-bottom:1px solid rgba(230,219,200,.72)!important;font-size:14px!important;line-height:1.35!important;white-space:normal!important;word-break:break-word!important;overflow-wrap:anywhere!important;color:#3d403a!important;}
    .dpc-app .dpc-food-table td:last-child{border-bottom:0!important;}
    .dpc-app .dpc-food-table td:before{content:attr(data-label)!important;display:block!important;flex:0 0 104px!important;font-size:11px!important;line-height:1.25!important;font-weight:900!important;letter-spacing:.05em!important;text-transform:uppercase!important;color:#9a7c38!important;}
    .dpc-app .dpc-food-table td > *{min-width:0!important;}
}

@media (max-width:360px){
    .dpc-app .dpc-food-table td{display:block!important;}
    .dpc-app .dpc-food-table td:before{margin-bottom:3px!important;}
}


/* ===== v2.7.0 hard mobile/layout fix ===== */

/* Remove ugly pseudo-icons inside the main calculator fields */
.dpc-app .dpc-hero--landing .dpc-field:before,
.dpc-app .dpc-hero--landing .dpc-field:after{
    display:none!important;
    content:none!important;
}

/* Desktop: give hero enough height and keep nav from touching form */
@media (min-width:941px){
    .dpc-app .dpc-hero.dpc-hero--landing{
        height:790px!important;
        min-height:790px!important;
    }
    .dpc-app .dpc-hero--landing .dpc-main{
        top:268px!important;
    }
    .dpc-app .dpc-hero--landing .dpc-jump-nav{
        bottom:24px!important;
        align-items:stretch!important;
    }
    .dpc-app .dpc-hero--landing .dpc-jump-card{
        height:142px!important;
        min-height:142px!important;
        max-height:142px!important;
    }
}

/* Mobile: break app out to useful width inside the site's content panel */
@media (max-width:720px){
    .content-panel.legal-content.app-main-panel:has(.dpc-app){
        padding-left:0!important;
        padding-right:0!important;
        overflow:visible!important;
    }
    .content-panel.legal-content.app-main-panel .dpc-app,
    .app-main-panel .dpc-app{
        width:calc(100vw - 16px)!important;
        max-width:calc(100vw - 16px)!important;
        margin-left:calc(50% - 50vw + 8px)!important;
        margin-right:calc(50% - 50vw + 8px)!important;
        overflow-x:hidden!important;
    }

    .dpc-app .dpc-hero.dpc-hero--landing{
        height:1180px!important;
        min-height:1180px!important;
        border-radius:24px!important;
    }

    /* title and dog area */
    .dpc-app .dpc-hero.dpc-hero--landing:after{
        top:62px!important;
        right:0!important;
        width:45%!important;
        max-width:188px!important;
        height:330px!important;
        background-size:contain!important;
    }
    .dpc-app .dpc-hero__title-wrap{
        left:22px!important;
        top:62px!important;
        width:53%!important;
        max-width:210px!important;
    }
    .dpc-app .dpc-hero__title-wrap:before{
        display:none!important;
        content:none!important;
    }
    .dpc-app .dpc-hero__title-wrap h2{
        font-size:42px!important;
        line-height:.82!important;
    }
    .dpc-app .dpc-hero-tagline,
    .dpc-app .dpc-title-flourish{
        display:none!important;
    }

    /* form */
    .dpc-app .dpc-hero--landing .dpc-main{
        top:300px!important;
        left:16px!important;
        right:16px!important;
        padding:18px 16px!important;
        border-radius:22px!important;
    }
    .dpc-app .dpc-hero--landing .dpc-main .dpc-field-grid{
        gap:14px!important;
    }
    .dpc-app .dpc-hero--landing .dpc-field span{
        font-size:15px!important;
    }
    .dpc-app .dpc-hero--landing .dpc-field input,
    .dpc-app .dpc-hero--landing .dpc-field select{
        min-height:52px!important;
        font-size:16px!important;
        padding:0 14px!important;
    }
    .dpc-app .dpc-hero--landing .dpc-primary-btn{
        min-height:58px!important;
        font-size:18px!important;
    }

    /* lower nav cards: moved down and equalized */
    .dpc-app .dpc-hero--landing .dpc-jump-nav{
        top:610px!important;
        left:16px!important;
        right:16px!important;
        bottom:auto!important;
        display:grid!important;
        grid-template-columns:1fr 1fr!important;
        gap:12px!important;
        width:auto!important;
        align-items:stretch!important;
    }
    .dpc-app .dpc-hero--landing .dpc-jump-card{
        height:148px!important;
        min-height:148px!important;
        max-height:148px!important;
        min-width:0!important;
        display:grid!important;
        grid-template-columns:1fr!important;
        grid-template-rows:54px auto 28px!important;
        align-content:start!important;
        justify-items:start!important;
        padding:14px 12px!important;
        overflow:hidden!important;
    }
    .dpc-app .dpc-hero--landing .dpc-jump-card__icon{
        width:52px!important;
        height:52px!important;
        font-size:25px!important;
    }
    .dpc-app .dpc-hero--landing .dpc-jump-card strong{
        font-size:17px!important;
        line-height:1.08!important;
        min-height:38px!important;
    }
    .dpc-app .dpc-hero--landing .dpc-jump-card em{
        right:12px!important;
        bottom:12px!important;
        width:28px!important;
        height:28px!important;
    }
}

/* Very narrow mobile */
@media (max-width:390px){
    .dpc-app .dpc-hero.dpc-hero--landing{
        height:1120px!important;
        min-height:1120px!important;
    }
    .dpc-app .dpc-hero.dpc-hero--landing:after{
        top:60px!important;
        width:42%!important;
        max-width:160px!important;
        height:300px!important;
    }
    .dpc-app .dpc-hero__title-wrap h2{
        font-size:36px!important;
    }
    .dpc-app .dpc-hero--landing .dpc-main{
        top:280px!important;
    }
    .dpc-app .dpc-hero--landing .dpc-jump-nav{
        top:570px!important;
    }
    .dpc-app .dpc-hero--landing .dpc-jump-card{
        height:138px!important;
        min-height:138px!important;
        max-height:138px!important;
    }
}

/* Timeline mobile: no narrow multi-column mess */
@media (max-width:720px){
    .dpc-app .dpc-timeline-section{
        padding:18px 12px!important;
        background-position:70% top!important;
    }
    .dpc-app .dpc-timeline{
        display:grid!important;
        gap:12px!important;
    }
    .dpc-app .dpc-milestone{
        width:100%!important;
        display:grid!important;
        grid-template-columns:64px 1fr!important;
        grid-template-areas:
            "icon day"
            "copy copy"
            "status status"!important;
        gap:10px 12px!important;
        padding:14px!important;
        min-height:auto!important;
        border-radius:18px!important;
    }
    .dpc-app .dpc-milestone__icon{
        grid-area:icon!important;
        width:62px!important;
        height:62px!important;
    }
    .dpc-app .dpc-milestone__day{
        grid-area:day!important;
        display:flex!important;
        align-items:center!important;
        gap:6px!important;
        flex-wrap:wrap!important;
        font-size:24px!important;
        line-height:1.1!important;
    }
    .dpc-app .dpc-milestone__day small{
        display:inline!important;
        margin:0!important;
        font-size:20px!important;
    }
    .dpc-app .dpc-milestone__copy{
        grid-area:copy!important;
        padding-left:0!important;
    }
    .dpc-app .dpc-milestone__copy:before{
        display:none!important;
    }
    .dpc-app .dpc-milestone h4{
        font-size:22px!important;
    }
    .dpc-app .dpc-milestone p{
        font-size:14px!important;
        line-height:1.45!important;
    }
    .dpc-app .dpc-milestone__status{
        grid-area:status!important;
        justify-self:start!important;
        min-width:0!important;
    }
}

/* Whelping kit mobile: image on top, clean full-width cards */
@media (max-width:720px){
    .dpc-app .dpc-kit-grid{
        display:grid!important;
        grid-template-columns:1fr!important;
        gap:14px!important;
    }
    .dpc-app .dpc-kit-item{
        display:grid!important;
        grid-template-columns:82px 1fr 36px!important;
        grid-template-areas:"thumb copy check"!important;
        align-items:center!important;
        gap:12px!important;
        padding:12px!important;
        width:100%!important;
    }
    .dpc-app .dpc-kit-thumb{
        grid-area:thumb!important;
        width:82px!important;
        height:68px!important;
        border-radius:14px!important;
    }
    .dpc-app .dpc-kit-check{
        grid-area:check!important;
        width:34px!important;
        height:34px!important;
        justify-self:end!important;
    }
    .dpc-app .dpc-kit-copy{
        grid-area:copy!important;
        min-width:0!important;
    }
    .dpc-app .dpc-kit-copy strong{
        font-size:17px!important;
        line-height:1.15!important;
    }
    .dpc-app .dpc-kit-copy small{
        font-size:12px!important;
        line-height:1.35!important;
    }
}

/* Nutrition mobile: force true card layout, no scroll/table look */
@media (max-width:720px){
    .dpc-app .dpc-table-wrap{
        display:block!important;
        width:100%!important;
        max-width:100%!important;
        overflow:visible!important;
        padding:0!important;
        margin:14px 0 0!important;
        border:0!important;
        background:transparent!important;
        box-shadow:none!important;
    }
    .dpc-app table.dpc-food-table,
    .dpc-app table.dpc-food-table thead,
    .dpc-app table.dpc-food-table tbody,
    .dpc-app table.dpc-food-table tr,
    .dpc-app table.dpc-food-table th,
    .dpc-app table.dpc-food-table td{
        display:block!important;
        width:100%!important;
        min-width:0!important;
        max-width:100%!important;
        box-sizing:border-box!important;
        border:0!important;
    }
    .dpc-app table.dpc-food-table{
        table-layout:fixed!important;
        border-collapse:separate!important;
        border-spacing:0!important;
        background:transparent!important;
    }
    .dpc-app table.dpc-food-table thead{
        display:none!important;
    }
    .dpc-app table.dpc-food-table tbody{
        display:grid!important;
        gap:12px!important;
    }
    .dpc-app table.dpc-food-table tr{
        display:grid!important;
        gap:0!important;
        padding:14px!important;
        border-radius:18px!important;
        background:#fffdf8!important;
        border:1px solid #eadfcf!important;
        box-shadow:0 10px 22px rgba(72,49,28,.08)!important;
    }
    .dpc-app table.dpc-food-table tr.is-active{
        background:#f5faef!important;
        border-color:#dce8cf!important;
    }
    .dpc-app table.dpc-food-table td{
        display:grid!important;
        grid-template-columns:1fr!important;
        gap:3px!important;
        padding:9px 0!important;
        border-bottom:1px solid rgba(230,219,200,.75)!important;
        font-size:15px!important;
        line-height:1.35!important;
        white-space:normal!important;
        word-break:normal!important;
        overflow-wrap:break-word!important;
    }
    .dpc-app table.dpc-food-table td:last-child{
        border-bottom:0!important;
    }
    .dpc-app table.dpc-food-table td:before{
        content:attr(data-label)!important;
        display:block!important;
        font-size:11px!important;
        font-weight:900!important;
        line-height:1.25!important;
        letter-spacing:.06em!important;
        text-transform:uppercase!important;
        color:#9a7c38!important;
    }
    .dpc-app table.dpc-food-table td strong{
        font-size:18px!important;
    }
}

/* Center food icons on mobile */
@media (max-width:720px){
    .dpc-app .dpc-food-grid article{
        justify-items:center!important;
        text-align:center!important;
    }
    .dpc-app .dpc-food-grid article span{
        margin-inline:auto!important;
    }
}


/* ===== v2.7.1 final cleanup ===== */
.dpc-app .dpc-hero-tagline,
.dpc-app .dpc-title-flourish{display:none!important;}
.dpc-app .dpc-hero--landing .dpc-field:after,
.dpc-app .dpc-hero--landing .dpc-field:before{display:none!important;content:none!important;}
.dpc-app .dpc-hero--landing .dpc-field input,
.dpc-app .dpc-hero--landing .dpc-field select{padding-left:14px!important;}
.dpc-app .dpc-result-modal__close{font-size:34px!important;font-weight:700!important;line-height:1!important;}

/* Desktop kit thumbs */
@media (min-width:721px){
  .dpc-app .dpc-kit-thumb{
    height:90px!important;
    display:flex!important;
    align-items:center!important;
    justify-content:center!important;
    padding:8px!important;
  }
  .dpc-app .dpc-kit-thumb img{
    width:auto!important;
    height:auto!important;
    max-width:100%!important;
    max-height:100%!important;
    object-fit:contain!important;
    display:block!important;
  }
}

/* Better mobile first screen */
@media (max-width:720px){
  .content-panel.legal-content.app-main-panel:has(.dpc-app){padding-left:0!important;padding-right:0!important;overflow:visible!important;}
  .content-panel.legal-content.app-main-panel .dpc-app,
  .app-main-panel .dpc-app{
    width:calc(100vw - 18px)!important;
    max-width:calc(100vw - 18px)!important;
    margin-left:calc(50% - 50vw + 9px)!important;
    margin-right:calc(50% - 50vw + 9px)!important;
    overflow-x:hidden!important;
  }
  .dpc-app .dpc-hero.dpc-hero--landing{
    height:auto!important;
    min-height:0!important;
    padding:16px!important;
    background-position:center top!important;
    background-size:cover!important;
  }
  .dpc-app .dpc-hero__stage{
    position:relative!important;
    inset:auto!important;
    display:grid!important;
    gap:14px!important;
    align-items:start!important;
  }
  .dpc-app .dpc-mobile-dog{
    display:block!important;
    position:absolute!important;
    right:-6px!important;
    top:18px!important;
    width:40%!important;
    max-width:150px!important;
    height:auto!important;
    object-fit:contain!important;
    z-index:2!important;
  }
  .dpc-app .dpc-hero__title-wrap{
    position:relative!important;
    left:auto!important;top:auto!important;right:auto!important;
    width:58%!important;
    max-width:230px!important;
    z-index:3!important;
    padding-top:10px!important;
  }
  .dpc-app .dpc-hero__title-wrap h2{
    font-size:44px!important;
    line-height:.84!important;
    letter-spacing:-.06em!important;
  }
  .dpc-app .dpc-hero--landing .dpc-main{
    position:relative!important;
    left:auto!important;top:auto!important;right:auto!important;bottom:auto!important;
    width:100%!important;
    padding:16px!important;
    margin-top:4px!important;
    z-index:3!important;
  }
  .dpc-app .dpc-hero--landing .dpc-main .dpc-field-grid{
    grid-template-columns:1fr!important;
    gap:12px!important;
  }
  .dpc-app .dpc-hero--landing .dpc-field span{
    font-size:15px!important;
    text-align:left!important;
  }
  .dpc-app .dpc-hero--landing .dpc-field input,
  .dpc-app .dpc-hero--landing .dpc-field select{
    min-height:50px!important;
    font-size:16px!important;
    border-radius:12px!important;
  }
  .dpc-app .dpc-hero--landing .dpc-main-actions{margin-top:12px!important;}
  .dpc-app .dpc-hero--landing .dpc-primary-btn{
    min-height:54px!important;
    border-radius:14px!important;
    font-size:18px!important;
    padding:12px 16px!important;
  }
  .dpc-app .dpc-hero--landing .dpc-jump-nav{
    position:relative!important;
    left:auto!important;right:auto!important;top:auto!important;bottom:auto!important;
    width:100%!important;
    margin-top:6px!important;
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
    gap:12px!important;
  }
  .dpc-app .dpc-hero--landing .dpc-jump-card{
    min-height:144px!important;
    height:144px!important;
    padding:14px 10px!important;
    display:flex!important;
    align-items:center!important;
    justify-content:center!important;
    gap:10px!important;
    text-align:center!important;
  }
  .dpc-app .dpc-hero--landing .dpc-jump-card__icon{
    width:44px!important;height:44px!important;
    display:grid!important;place-items:center!important;
    font-size:28px!important;line-height:1!important;
    margin:0 auto!important;
  }
  .dpc-app .dpc-hero--landing .dpc-jump-card strong{
    display:block!important;
    font-size:17px!important;
    line-height:1.15!important;
    text-align:center!important;
  }
  .dpc-app .dpc-hero--landing .dpc-jump-card em{
    margin:0 auto!important;
  }
  .dpc-app .dpc-hero--landing .dpc-result{
    position:relative!important;
    left:auto!important;right:auto!important;bottom:auto!important;
    width:100%!important;
    grid-template-columns:1fr!important;
    text-align:center!important;
    justify-items:center!important;
  }
  .dpc-app .dpc-result-heart{right:16px!important;top:12px!important;}
}

/* Narrower phones */
@media (max-width:420px){
  .dpc-app .dpc-hero__title-wrap{width:56%!important;max-width:200px!important;}
  .dpc-app .dpc-hero__title-wrap h2{font-size:39px!important;}
  .dpc-app .dpc-mobile-dog{width:41%!important;max-width:138px!important;top:22px!important;}
  .dpc-app .dpc-hero--landing .dpc-jump-card{min-height:132px!important;height:132px!important;}
  .dpc-app .dpc-hero--landing .dpc-jump-card strong{font-size:15px!important;}
}

/* Timeline centered mobile cards */
@media (max-width:720px){
  .dpc-app .dpc-timeline{display:grid!important;gap:12px!important;}
  .dpc-app .dpc-milestone{
    display:grid!important;
    grid-template-columns:1fr!important;
    gap:10px!important;
    justify-items:center!important;
    text-align:center!important;
    padding:16px 14px!important;
  }
  .dpc-app .dpc-milestone__icon{
    width:68px!important;height:68px!important;
    margin:0 auto!important;
  }
  .dpc-app .dpc-milestone__day{
    display:block!important;
    font-size:26px!important;
    text-align:center!important;
  }
  .dpc-app .dpc-milestone__day small{
    display:block!important;
    margin-top:4px!important;
    font-size:17px!important;
  }
  .dpc-app .dpc-milestone__copy{
    padding-left:0!important;
    text-align:center!important;
  }
  .dpc-app .dpc-milestone__copy:before{display:none!important;}
  .dpc-app .dpc-milestone h4{font-size:22px!important;text-align:center!important;}
  .dpc-app .dpc-milestone p{text-align:center!important;}
  .dpc-app .dpc-milestone__status{
    justify-self:center!important;
    text-align:center!important;
  }
}

/* Mobile kit cards */
@media (max-width:720px){
  .dpc-app .dpc-kit-grid{grid-template-columns:1fr!important;gap:14px!important;}
  .dpc-app .dpc-kit-item{
    grid-template-columns:1fr!important;
    gap:10px!important;
    justify-items:center!important;
    text-align:center!important;
    padding:14px!important;
  }
  .dpc-app .dpc-kit-thumb{
    width:100%!important;
    max-width:170px!important;
    height:90px!important;
    display:flex!important;
    align-items:center!important;
    justify-content:center!important;
    margin:0 auto!important;
    padding:6px!important;
  }
  .dpc-app .dpc-kit-thumb img{
    width:auto!important;height:auto!important;max-width:100%!important;max-height:100%!important;object-fit:contain!important;
  }
  .dpc-app .dpc-kit-check{order:0!important;justify-self:center!important;}
  .dpc-app .dpc-kit-copy{text-align:center!important;}
}

/* Food icons centered mobile */
@media (max-width:720px){
  .dpc-app .dpc-food-grid article{justify-items:center!important;text-align:center!important;}
  .dpc-app .dpc-food-grid article span{margin:0 auto!important;}
}


/* ===== v2.8.0 smooth scroll, centered cards, kit images, quiz ===== */
html{scroll-behavior:auto!important;}
.dpc-app{scroll-behavior:auto!important;}
.dpc-app *{scroll-margin-top:96px;}
.dpc-app .dpc-hero--landing .dpc-jump-card,
.dpc-app .dpc-milestone,
.dpc-app .dpc-kit-item{
    transform:none!important;
    transition:box-shadow .16s ease,border-color .16s ease,background .16s ease!important;
}
.dpc-app .dpc-hero--landing .dpc-jump-card:hover,
.dpc-app .dpc-milestone:hover,
.dpc-app .dpc-kit-item:hover{transform:none!important;}

/* Mobile first-screen nav: remove useless long empty background */
@media (max-width:720px){
    .dpc-app .dpc-hero.dpc-hero--landing{
        height:auto!important;
        min-height:0!important;
        padding-bottom:18px!important;
    }
    .dpc-app .dpc-hero--landing .dpc-jump-nav{
        margin-top:10px!important;
    }
    .dpc-app .dpc-hero--landing .dpc-jump-card{
        height:128px!important;
        min-height:128px!important;
        max-height:128px!important;
        display:flex!important;
        flex-direction:column!important;
        align-items:center!important;
        justify-content:center!important;
        text-align:center!important;
        padding:12px 10px!important;
    }
    .dpc-app .dpc-hero--landing .dpc-jump-card__icon{
        width:46px!important;
        height:46px!important;
        margin:0 auto!important;
        display:grid!important;
        place-items:center!important;
        line-height:1!important;
        text-align:center!important;
        font-size:26px!important;
    }
    .dpc-app .dpc-hero--landing .dpc-jump-card strong{
        width:100%!important;
        text-align:center!important;
        font-size:16px!important;
        line-height:1.12!important;
        min-height:auto!important;
    }
    .dpc-app .dpc-hero--landing .dpc-jump-card em{
        position:static!important;
        margin:0 auto!important;
        display:grid!important;
        place-items:center!important;
    }
}

/* Timeline mobile: centered, readable cards */
@media (max-width:720px){
    .dpc-app .dpc-timeline-section{
        padding:18px 12px!important;
    }
    .dpc-app .dpc-timeline{
        display:grid!important;
        gap:12px!important;
    }
    .dpc-app .dpc-milestone{
        display:grid!important;
        grid-template-columns:1fr!important;
        justify-items:center!important;
        align-items:center!important;
        text-align:center!important;
        gap:10px!important;
        padding:16px 14px!important;
        border-radius:20px!important;
        min-height:auto!important;
    }
    .dpc-app .dpc-milestone__icon{
        width:72px!important;
        height:72px!important;
        margin:0 auto!important;
        display:grid!important;
        place-items:center!important;
        border-radius:50%!important;
    }
    .dpc-app .dpc-milestone__icon img{
        width:100%!important;
        height:100%!important;
        object-fit:cover!important;
        display:block!important;
        border-radius:50%!important;
    }
    .dpc-app .dpc-milestone__day{
        text-align:center!important;
        display:block!important;
        width:100%!important;
        font-size:26px!important;
        line-height:1.05!important;
    }
    .dpc-app .dpc-milestone__day small{
        display:block!important;
        margin-top:4px!important;
        text-align:center!important;
        font-size:17px!important;
    }
    .dpc-app .dpc-milestone__copy{
        text-align:center!important;
        padding-left:0!important;
        width:100%!important;
    }
    .dpc-app .dpc-milestone__copy:before{display:none!important;}
    .dpc-app .dpc-milestone h4{
        text-align:center!important;
        font-size:22px!important;
    }
    .dpc-app .dpc-milestone p{
        text-align:center!important;
        font-size:14px!important;
        line-height:1.45!important;
    }
    .dpc-app .dpc-milestone__status{
        justify-self:center!important;
        text-align:center!important;
        min-width:0!important;
        padding:9px 16px!important;
    }
}

/* Whelping kit: image above title, stable equal cards */
.dpc-app .dpc-kit-grid{
    align-items:stretch!important;
}
.dpc-app .dpc-kit-item{
    display:grid!important;
    grid-template-columns:1fr!important;
    grid-template-areas:"thumb" "check" "copy"!important;
    justify-items:center!important;
    align-content:start!important;
    text-align:center!important;
    gap:10px!important;
    min-height:245px!important;
}
.dpc-app .dpc-kit-thumb{
    grid-area:thumb!important;
    width:170px!important;
    height:90px!important;
    max-width:100%!important;
    display:flex!important;
    align-items:center!important;
    justify-content:center!important;
    padding:6px!important;
    margin:0 auto!important;
    border-radius:16px!important;
}
.dpc-app .dpc-kit-thumb img{
    width:auto!important;
    height:auto!important;
    max-width:100%!important;
    max-height:100%!important;
    object-fit:contain!important;
    display:block!important;
}
.dpc-app .dpc-kit-check{
    grid-area:check!important;
    justify-self:center!important;
}
.dpc-app .dpc-kit-copy{
    grid-area:copy!important;
    text-align:center!important;
}
.dpc-app .dpc-kit-copy strong,
.dpc-app .dpc-kit-copy small{
    text-align:center!important;
}
@media (max-width:720px){
    .dpc-app .dpc-kit-item{
        min-height:auto!important;
        padding:14px!important;
    }
    .dpc-app .dpc-kit-thumb{
        width:170px!important;
        height:92px!important;
    }
}

/* Signal quiz replacing diary */
.dpc-app .dpc-quiz-section .dpc-section-dog--diary{
    max-width:260px;
}
.dpc-app .dpc-quiz-card{
    max-width:860px;
    margin:0 auto;
    overflow:hidden;
}
.dpc-app .dpc-quiz-progress{
    display:flex;
    align-items:center;
    gap:14px;
    margin-bottom:18px;
}
.dpc-app .dpc-quiz-progress span{
    flex:0 0 auto;
    font-weight:900;
    color:#42683c;
}
.dpc-app .dpc-quiz-progress em{
    position:relative;
    flex:1;
    height:12px;
    border-radius:999px;
    overflow:hidden;
    background:#eee4d6;
}
.dpc-app .dpc-quiz-progress em:before{
    content:"";
    display:block;
    height:100%;
    width:var(--dpc-quiz-pct,0%);
    border-radius:999px;
    background:linear-gradient(90deg,#6f8e4b,#d5ad54);
    transition:width .22s ease;
}
.dpc-app .dpc-quiz-question{
    display:none;
    text-align:center;
    justify-items:center;
    gap:14px;
}
.dpc-app .dpc-quiz-question.is-active{
    display:grid;
}
.dpc-app .dpc-quiz-emoji{
    width:78px;
    height:78px;
    border-radius:50%;
    display:grid;
    place-items:center;
    margin:0 auto;
    background:#fff9ef;
    border:1px solid #eadfcf;
    box-shadow:0 12px 26px rgba(72,49,28,.10);
    font-size:38px;
}
.dpc-app .dpc-quiz-question h4{
    margin:0;
    max-width:650px;
    font-size:34px;
    line-height:1.08;
    text-align:center;
}
.dpc-app .dpc-quiz-options{
    width:100%;
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:12px;
}
.dpc-app .dpc-quiz-options button{
    min-height:62px;
    border-radius:18px;
    border:1px solid #e4d4b8;
    background:#fffdf8;
    color:#17301f;
    font-size:16px;
    font-weight:800;
    box-shadow:0 10px 20px rgba(72,49,28,.06);
}
.dpc-app .dpc-quiz-options button:hover{
    background:#f6f0df;
}
.dpc-app .dpc-quiz-reset{
    display:block;
    margin:18px auto 0;
}
.dpc-app .dpc-quiz-result-copy{
    margin:12px 0 0;
    color:#5f6a61;
    font-size:16px;
    line-height:1.55;
}
.dpc-app .dpc-quiz-modal .dpc-result-modal__cta{
    border:0;
    cursor:pointer;
}
@media (max-width:720px){
    .dpc-app .dpc-quiz-section .dpc-section__head--diary{
        display:block!important;
        text-align:center!important;
    }
    .dpc-app .dpc-quiz-section .dpc-section-dog--diary{
        display:none!important;
    }
    .dpc-app .dpc-quiz-card{
        padding:16px!important;
    }
    .dpc-app .dpc-quiz-progress{
        display:grid;
        gap:8px;
        text-align:center;
    }
    .dpc-app .dpc-quiz-question h4{
        font-size:25px;
    }
    .dpc-app .dpc-quiz-options{
        grid-template-columns:1fr;
        gap:10px;
    }
    .dpc-app .dpc-quiz-options button{
        min-height:58px;
        font-size:15px;
    }
}


/* ===== v2.8.1 mobile timeline: date top, emoji/image under date, all centered ===== */
@media (max-width:720px){
    .dpc-app .dpc-timeline .dpc-milestone{
        display:flex!important;
        flex-direction:column!important;
        align-items:center!important;
        justify-content:flex-start!important;
        text-align:center!important;
        gap:10px!important;
        padding:18px 14px!important;
    }

    .dpc-app .dpc-timeline .dpc-milestone__day{
        order:1!important;
        width:100%!important;
        display:block!important;
        text-align:center!important;
        margin:0!important;
        padding:0!important;
        font-size:27px!important;
        line-height:1.05!important;
        font-weight:900!important;
    }

    .dpc-app .dpc-timeline .dpc-milestone__day small{
        display:block!important;
        margin:4px auto 0!important;
        padding:0!important;
        text-align:center!important;
        font-size:18px!important;
        line-height:1.05!important;
        font-weight:900!important;
    }

    .dpc-app .dpc-timeline .dpc-milestone__icon{
        order:2!important;
        width:74px!important;
        height:74px!important;
        margin:0 auto!important;
        display:grid!important;
        place-items:center!important;
        flex:0 0 auto!important;
    }

    .dpc-app .dpc-timeline .dpc-milestone__icon img{
        display:block!important;
        width:100%!important;
        height:100%!important;
        object-fit:cover!important;
        object-position:center!important;
        border-radius:50%!important;
        margin:0 auto!important;
    }

    .dpc-app .dpc-timeline .dpc-milestone__icon span{
        display:grid!important;
        place-items:center!important;
        width:100%!important;
        height:100%!important;
        text-align:center!important;
        line-height:1!important;
    }

    .dpc-app .dpc-timeline .dpc-milestone__copy{
        order:3!important;
        width:100%!important;
        max-width:100%!important;
        text-align:center!important;
        padding:0!important;
        margin:0!important;
    }

    .dpc-app .dpc-timeline .dpc-milestone__copy:before{
        display:none!important;
        content:none!important;
    }

    .dpc-app .dpc-timeline .dpc-milestone__copy h4,
    .dpc-app .dpc-timeline .dpc-milestone__copy p{
        text-align:center!important;
        margin-left:auto!important;
        margin-right:auto!important;
    }

    .dpc-app .dpc-timeline .dpc-milestone__status{
        order:4!important;
        align-self:center!important;
        justify-self:center!important;
        margin:2px auto 0!important;
        text-align:center!important;
    }
}


/* ===== v2.8.2 quiz screen redesign ===== */
.dpc-app .dpc-quiz-section{
    min-height:720px;
    padding:46px 56px 56px!important;
    border-radius:34px!important;
    background:
        linear-gradient(90deg, rgba(255,250,241,.92) 0%, rgba(255,250,241,.84) 44%, rgba(255,250,241,.20) 100%),
        url('/dog-pregnancy-calculator-app/assets/decor/quiz-bg.webp') no-repeat center center / cover!important;
    box-shadow:0 24px 56px rgba(82,56,27,.12)!important;
    overflow:hidden!important;
}
.dpc-app .dpc-quiz-section:before,
.dpc-app .dpc-quiz-section:after{
    display:none!important;
    content:none!important;
}
.dpc-app .dpc-quiz-section .dpc-section__head{
    display:grid!important;
    grid-template-columns:170px minmax(0,760px) 1fr!important;
    gap:34px!important;
    align-items:center!important;
    margin:0 auto 36px!important;
    max-width:1480px!important;
    position:relative!important;
    z-index:2!important;
}
.dpc-app .dpc-quiz-section .dpc-section__head:before{
    content:""!important;
    display:block!important;
    width:170px!important;
    height:170px!important;
    border-radius:36px!important;
    background:
        linear-gradient(180deg, rgba(255,255,255,.82), rgba(255,244,214,.88)),
        url('/dog-pregnancy-calculator-app/assets/icon.webp') no-repeat center center / 118px 118px!important;
    border:1px solid rgba(222,200,150,.68)!important;
    box-shadow:0 18px 38px rgba(82,56,27,.13)!important;
}
.dpc-app .dpc-quiz-section .dpc-section__head > div{
    grid-column:2!important;
    min-width:0!important;
}
.dpc-app .dpc-quiz-section .dpc-section-dog--diary{
    display:none!important;
}
.dpc-app .dpc-quiz-section .dpc-kicker{
    background:rgba(255,255,255,.72)!important;
    border-color:#dfcf9f!important;
    color:#24723f!important;
    box-shadow:0 8px 20px rgba(82,56,27,.08)!important;
}
.dpc-app .dpc-quiz-section .dpc-section__head h3{
    margin:16px 0 12px!important;
    max-width:760px!important;
    font-size:74px!important;
    line-height:.96!important;
    letter-spacing:-.055em!important;
}
.dpc-app .dpc-quiz-section .dpc-section__head p{
    max-width:690px!important;
    font-size:20px!important;
    line-height:1.5!important;
    color:#6c5e51!important;
}
.dpc-app .dpc-quiz-card{
    max-width:1280px!important;
    margin:0 auto!important;
    padding:38px 46px 34px!important;
    border-radius:32px!important;
    background:rgba(255,255,255,.88)!important;
    border:1px solid rgba(232,220,202,.94)!important;
    box-shadow:0 22px 52px rgba(82,56,27,.14)!important;
    backdrop-filter:blur(10px)!important;
    position:relative!important;
    z-index:2!important;
}
.dpc-app .dpc-quiz-progress{
    display:grid!important;
    grid-template-columns:170px 1fr!important;
    align-items:center!important;
    gap:22px!important;
    max-width:1050px!important;
    margin:0 auto 28px!important;
}
.dpc-app .dpc-quiz-progress span{
    font-family:Georgia,"Times New Roman",serif!important;
    font-size:25px!important;
    color:#225a33!important;
    font-weight:900!important;
}
.dpc-app .dpc-quiz-progress em{
    height:18px!important;
    border-radius:999px!important;
    background:#eee4d7!important;
}
.dpc-app .dpc-quiz-progress em:before{
    background:linear-gradient(90deg,#2e7c43 0%,#3f9253 100%)!important;
}
.dpc-app .dpc-quiz-question{
    max-width:1100px!important;
    margin:0 auto!important;
}
.dpc-app .dpc-quiz-emoji{
    width:104px!important;
    height:104px!important;
    font-size:54px!important;
    background:linear-gradient(180deg,#e7faeb 0%,#d6f1dc 100%)!important;
    border:2px solid #b7dfc3!important;
    box-shadow:0 16px 32px rgba(41,115,65,.14)!important;
}
.dpc-app .dpc-quiz-question h4{
    max-width:760px!important;
    margin:6px auto 28px!important;
    font-size:44px!important;
    line-height:1.12!important;
    color:#163a24!important;
}
.dpc-app .dpc-quiz-options{
    display:grid!important;
    grid-template-columns:repeat(3,minmax(0,1fr))!important;
    gap:24px!important;
}
.dpc-app .dpc-quiz-options button{
    position:relative!important;
    min-height:78px!important;
    padding:18px 20px 18px 84px!important;
    border-radius:20px!important;
    text-align:left!important;
    font-size:20px!important;
    font-weight:900!important;
    border-width:2px!important;
    box-shadow:0 16px 28px rgba(82,56,27,.08)!important;
}
.dpc-app .dpc-quiz-options button:nth-child(1){
    background:linear-gradient(180deg,#e8f8e7 0%,#d7f2d8 100%)!important;
    border-color:#9bd8a9!important;
    color:#173d24!important;
}
.dpc-app .dpc-quiz-options button:nth-child(2){
    background:linear-gradient(180deg,#fff4e4 0%,#fee8c7 100%)!important;
    border-color:#f2c177!important;
    color:#5b3a17!important;
}
.dpc-app .dpc-quiz-options button:nth-child(3){
    background:linear-gradient(180deg,#fff0f0 0%,#ffe0e2 100%)!important;
    border-color:#ef9fa8!important;
    color:#572227!important;
}
.dpc-app .dpc-quiz-options button:before{
    position:absolute!important;
    left:22px!important;
    top:50%!important;
    transform:translateY(-50%)!important;
    width:46px!important;
    height:46px!important;
    border-radius:50%!important;
    display:grid!important;
    place-items:center!important;
    color:#fff!important;
    font-size:25px!important;
    font-weight:900!important;
    box-shadow:0 9px 18px rgba(0,0,0,.10)!important;
}
.dpc-app .dpc-quiz-options button:nth-child(1):before{content:"✓"!important;background:#31934a!important;}
.dpc-app .dpc-quiz-options button:nth-child(2):before{content:"↓"!important;background:#f0a318!important;}
.dpc-app .dpc-quiz-options button:nth-child(3):before{content:"?"!important;background:#e74e61!important;}
.dpc-app .dpc-quiz-reset{
    min-width:220px!important;
    margin:30px auto 0!important;
    background:rgba(255,252,245,.90)!important;
    color:#437548!important;
    border:1px solid #dccca7!important;
    box-shadow:0 12px 24px rgba(82,56,27,.08)!important;
}

/* mobile quiz: compact and full-width friendly */
@media (max-width:720px){
    .dpc-app .dpc-quiz-section{
        min-height:auto!important;
        padding:22px 14px 24px!important;
        background:
            linear-gradient(180deg, rgba(255,250,241,.94) 0%, rgba(255,250,241,.86) 58%, rgba(255,250,241,.42) 100%),
            url('/dog-pregnancy-calculator-app/assets/decor/quiz-bg.webp') no-repeat 70% top / auto 100%!important;
    }
    .dpc-app .dpc-quiz-section .dpc-section__head{
        display:grid!important;
        grid-template-columns:1fr!important;
        justify-items:center!important;
        text-align:center!important;
        gap:12px!important;
        margin-bottom:18px!important;
    }
    .dpc-app .dpc-quiz-section .dpc-section__head:before{
        width:104px!important;
        height:104px!important;
        border-radius:26px!important;
        background:
            linear-gradient(180deg, rgba(255,255,255,.82), rgba(255,244,214,.88)),
            url('/dog-pregnancy-calculator-app/assets/icon.webp') no-repeat center center / 78px 78px!important;
    }
    .dpc-app .dpc-quiz-section .dpc-section__head > div{
        grid-column:auto!important;
    }
    .dpc-app .dpc-quiz-section .dpc-section__head h3{
        font-size:38px!important;
        text-align:center!important;
        margin:10px 0!important;
    }
    .dpc-app .dpc-quiz-section .dpc-section__head p{
        font-size:15px!important;
        text-align:center!important;
        line-height:1.45!important;
    }
    .dpc-app .dpc-quiz-card{
        padding:16px 14px 18px!important;
        border-radius:24px!important;
    }
    .dpc-app .dpc-quiz-progress{
        grid-template-columns:1fr!important;
        gap:8px!important;
        margin-bottom:18px!important;
        text-align:center!important;
    }
    .dpc-app .dpc-quiz-progress span{
        font-size:19px!important;
    }
    .dpc-app .dpc-quiz-progress em{
        height:13px!important;
    }
    .dpc-app .dpc-quiz-emoji{
        width:72px!important;
        height:72px!important;
        font-size:38px!important;
    }
    .dpc-app .dpc-quiz-question h4{
        font-size:26px!important;
        line-height:1.12!important;
        margin:8px auto 18px!important;
    }
    .dpc-app .dpc-quiz-options{
        grid-template-columns:1fr!important;
        gap:10px!important;
    }
    .dpc-app .dpc-quiz-options button{
        min-height:58px!important;
        padding:13px 14px 13px 60px!important;
        border-radius:16px!important;
        font-size:15px!important;
    }
    .dpc-app .dpc-quiz-options button:before{
        left:14px!important;
        width:36px!important;
        height:36px!important;
        font-size:20px!important;
    }
    .dpc-app .dpc-quiz-reset{
        width:100%!important;
        min-width:0!important;
        margin-top:16px!important;
    }
}


/* ===== v2.8.3 quiz header cleanup ===== */
.dpc-app .dpc-quiz-section .dpc-kicker{
    display:none!important;
}
.dpc-app .dpc-quiz-section .dpc-section__head{
    grid-template-columns:minmax(0,760px) 1fr!important;
    gap:0!important;
    align-items:start!important;
}
.dpc-app .dpc-quiz-section .dpc-section__head:before{
    display:none!important;
    content:none!important;
}
.dpc-app .dpc-quiz-section .dpc-section__head > div{
    grid-column:1!important;
}
.dpc-app .dpc-quiz-section .dpc-section__head h3{
    margin:0 0 14px!important;
}
.dpc-app .dpc-quiz-section .dpc-section__head p{
    margin:0!important;
}
.dpc-app .dpc-quiz-progress span{
    font-size:20px!important;
    line-height:1!important;
    white-space:nowrap!important;
}
@media (max-width:720px){
    .dpc-app .dpc-quiz-section .dpc-section__head{
        grid-template-columns:1fr!important;
        justify-items:start!important;
        text-align:left!important;
        gap:0!important;
    }
    .dpc-app .dpc-quiz-section .dpc-section__head > div{
        width:100%!important;
    }
    .dpc-app .dpc-quiz-section .dpc-section__head h3{
        text-align:left!important;
        font-size:34px!important;
        margin:0 0 10px!important;
    }
    .dpc-app .dpc-quiz-section .dpc-section__head p{
        text-align:left!important;
    }
    .dpc-app .dpc-quiz-progress span{
        font-size:15px!important;
        letter-spacing:0!important;
        white-space:nowrap!important;
    }
}


/* ===== v2.8.4 nutrition redesign ===== */
.dpc-nutrition-section{
    background:#fdfaf4;
    border:1px solid #ecdcbf;
    box-shadow:none;
}
.dpc-nutrition-section .dpc-section__head--nutrition{
    display:grid;
    grid-template-columns:minmax(0,1.18fr) minmax(290px,.82fr);
    align-items:end;
    gap:20px;
    margin-bottom:18px;
    padding-bottom:0;
    border-bottom:0;
}
.dpc-nutrition-section .dpc-kicker,
.dpc-nutrition-section .dpc-card-label{display:none!important;}
.dpc-nutrition-section .dpc-section__head--nutrition h3{
    margin:0 0 14px;
    font-size:66px;
    line-height:.93;
    letter-spacing:-.04em;
    color:#102c18;
    max-width:760px;
}
.dpc-nutrition-section .dpc-section__head--nutrition p{
    margin:0;
    max-width:760px;
    font-size:18px;
    line-height:1.58;
    color:#6d6b63;
}
.dpc-nutrition-section .dpc-section-dog--nutrition{
    justify-self:end;
    width:100%;
    max-width:470px;
    filter:none;
}
.dpc-nutrition-layout{
    display:grid;
    grid-template-columns:minmax(0,.98fr) minmax(0,1fr);
    gap:18px;
    align-items:stretch;
}
.dpc-nutrition-form,
.dpc-food-panel{
    height:100%;
    display:flex;
    flex-direction:column;
    justify-content:flex-start;
    padding:20px 20px 18px;
    border-radius:28px;
    background:rgba(255,255,255,.9);
    border:1px solid #ebddca;
    box-shadow:none;
}
.dpc-field-grid--nutrition{
    gap:14px;
}
.dpc-nutrition-form .dpc-field span{
    font-size:15px;
    font-weight:600;
    color:#263126;
}
.dpc-nutrition-form .dpc-field input,
.dpc-nutrition-form .dpc-field select{
    min-height:56px;
    border-radius:15px;
    border:1px solid #e2d7c6;
    background:#fffdf9;
}
.dpc-nutrition-submit{
    margin-top:20px!important;
    min-height:58px;
    position:relative;
    z-index:1;
}
.dpc-today-food{
    margin-top:20px;
    padding:18px 22px 16px;
    border-radius:22px;
}
.dpc-today-food span:first-child,
.dpc-today-food span:last-child{
    text-align:center;
    font-size:15px;
}
.dpc-today-food strong{
    text-align:center;
    font-size:64px;
    line-height:.95;
}
.dpc-food-grid{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:14px;
    flex:1;
}
.dpc-food-grid article{
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:flex-start;
    text-align:center;
    padding:18px 18px 14px;
    border-radius:18px;
    border:1px solid #e9ddcc;
    background:#fffdfa;
    min-height:0;
}
.dpc-food-grid__thumb{
    display:flex;
    align-items:center;
    justify-content:center;
    width:138px;
    height:108px;
    margin:0 auto 10px;
}
.dpc-food-grid__thumb img{
    display:block;
    width:118px;
    height:104px;
    object-fit:contain;
}
.dpc-food-grid article > span[aria-hidden='true']{display:none!important;}
.dpc-food-grid strong{
    display:block;
    margin:0 0 6px;
    font-size:23px;
    line-height:1.05;
    color:#1c2d19;
}
.dpc-food-grid small{
    font-size:14px;
    line-height:1.45;
    color:#73736a;
}
@media (max-width:1080px){
    .dpc-nutrition-section .dpc-section__head--nutrition{grid-template-columns:1fr;}
    .dpc-nutrition-section .dpc-section-dog--nutrition{justify-self:center; max-width:420px;}
    .dpc-nutrition-section .dpc-section__head--nutrition h3{font-size:54px;}
    .dpc-nutrition-layout{grid-template-columns:1fr;}
}
@media (max-width:720px){
    .dpc-nutrition-section .dpc-section__head--nutrition{gap:12px; margin-bottom:14px;}
    .dpc-nutrition-section .dpc-section__head--nutrition h3{font-size:38px; line-height:.98;}
    .dpc-nutrition-section .dpc-section__head--nutrition p{font-size:15px; line-height:1.5;}
    .dpc-nutrition-form, .dpc-food-panel{padding:16px; border-radius:22px;}
    .dpc-food-grid{gap:12px;}
    .dpc-food-grid article{padding:14px 12px;}
    .dpc-food-grid__thumb{width:104px; height:82px; margin-bottom:8px;}
    .dpc-food-grid__thumb img{width:90px; height:78px;}
    .dpc-food-grid strong{font-size:18px;}
    .dpc-food-grid small{font-size:12px; line-height:1.35;}
    .dpc-nutrition-submit{margin-top:16px!important; min-height:54px;}
    .dpc-today-food strong{font-size:42px;}
}


/* ===== v2.8.5 nutrition background + thumbs correction ===== */
.dpc-nutrition-section{
    background:#fdfaf4 url("./decor/nutrition-bg.webp") no-repeat center top !important;
    background-size:cover !important;
    border:1px solid #ecdcbf;
    box-shadow:none;
    overflow:hidden;
}
.dpc-nutrition-section .dpc-section__head--nutrition{
    display:block !important;
    min-height:188px;
    margin-bottom:18px;
    padding:0 0 0;
    border-bottom:0;
}
.dpc-nutrition-section .dpc-section__head--nutrition > div{
    max-width:760px;
    padding-right:430px;
}
.dpc-nutrition-section .dpc-section-dog--nutrition{display:none !important;}
.dpc-nutrition-section .dpc-section__head--nutrition h3{
    margin:0 0 14px;
    font-size:66px;
    line-height:.93;
    letter-spacing:-.04em;
    color:#102c18;
}
.dpc-nutrition-section .dpc-section__head--nutrition p{
    margin:0;
    max-width:760px;
    font-size:18px;
    line-height:1.58;
    color:#6d6b63;
}
.dpc-nutrition-submit{
    margin-top:24px !important;
}
.dpc-food-grid article{
    min-height:216px;
}
.dpc-food-grid__thumb{
    width:160px;
    height:112px;
    margin:0 auto 10px;
}
.dpc-food-grid__thumb img{
    display:block;
    width:132px;
    height:100px;
    object-fit:contain;
    object-position:center center;
    margin:0 auto;
}
@media (max-width:1080px){
    .dpc-nutrition-section{background-position:center top !important;}
    .dpc-nutrition-section .dpc-section__head--nutrition{min-height:210px;}
    .dpc-nutrition-section .dpc-section__head--nutrition > div{padding-right:0; max-width:620px;}
    .dpc-nutrition-section .dpc-section__head--nutrition h3{font-size:54px;}
}
@media (max-width:720px){
    .dpc-nutrition-section{background-position:72% top !important; background-size:cover !important;}
    .dpc-nutrition-section .dpc-section__head--nutrition{min-height:148px; margin-bottom:12px;}
    .dpc-nutrition-section .dpc-section__head--nutrition > div{max-width:none; padding-right:0;}
    .dpc-nutrition-section .dpc-section__head--nutrition h3{font-size:38px; line-height:.98; max-width:260px;}
    .dpc-nutrition-section .dpc-section__head--nutrition p{font-size:15px; line-height:1.5; max-width:270px;}
    .dpc-food-grid article{min-height:190px;}
    .dpc-food-grid__thumb{width:112px; height:82px; margin-bottom:8px;}
    .dpc-food-grid__thumb img{width:94px; height:74px;}
    .dpc-nutrition-submit{margin-top:18px !important;}
}


/* ===== v2.8.6 nutrition final background + thumb placement ===== */
.dpc-app .dpc-nutrition-section{
    background-color:#fdfaf4 !important;
    background-image:url("./decor/nutrition-bg.webp") !important;
    background-repeat:no-repeat !important;
    background-position:center top !important;
    background-size:100% auto !important;
    border:1px solid #ecdcbf !important;
    box-shadow:none !important;
    overflow:hidden !important;
}
.dpc-app .dpc-nutrition-section .dpc-section__head--nutrition{
    display:block !important;
    min-height:178px !important;
    margin-bottom:18px !important;
    padding:0 !important;
    border-bottom:0 !important;
}
.dpc-app .dpc-nutrition-section .dpc-section__head--nutrition > div{
    max-width:760px !important;
    padding-right:430px !important;
}
.dpc-app .dpc-nutrition-section .dpc-section-dog--nutrition,
.dpc-app .dpc-section-dog--nutrition{
    display:none !important;
    visibility:hidden !important;
    width:0 !important;
    height:0 !important;
    max-width:0 !important;
    max-height:0 !important;
    opacity:0 !important;
    pointer-events:none !important;
}
.dpc-app .dpc-nutrition-section .dpc-kicker,
.dpc-app .dpc-nutrition-section .dpc-card-label{display:none !important;}
.dpc-app .dpc-nutrition-section .dpc-section__head--nutrition h3{
    margin:0 0 14px !important;
    font-size:66px !important;
    line-height:.93 !important;
    letter-spacing:-.04em !important;
    color:#102c18 !important;
}
.dpc-app .dpc-nutrition-section .dpc-section__head--nutrition p{
    margin:0 !important;
    max-width:760px !important;
    font-size:18px !important;
    line-height:1.58 !important;
    color:#6d6b63 !important;
}
.dpc-app .dpc-nutrition-layout{
    display:grid !important;
    grid-template-columns:minmax(0,.98fr) minmax(0,1fr) !important;
    gap:18px !important;
    align-items:stretch !important;
}
.dpc-app .dpc-nutrition-form,
.dpc-app .dpc-food-panel{
    height:100% !important;
    display:flex !important;
    flex-direction:column !important;
    justify-content:flex-start !important;
    padding:20px 20px 18px !important;
    border-radius:28px !important;
    background:rgba(255,255,255,.9) !important;
    border:1px solid #ebddca !important;
    box-shadow:none !important;
}
.dpc-app .dpc-nutrition-submit{
    margin-top:24px !important;
    min-height:58px !important;
    position:relative !important;
    z-index:1 !important;
}
.dpc-app .dpc-food-grid{
    display:grid !important;
    grid-template-columns:repeat(2,minmax(0,1fr)) !important;
    gap:14px !important;
    flex:1 !important;
    margin-top:0 !important;
}
.dpc-app .dpc-food-grid article{
    display:flex !important;
    flex-direction:column !important;
    align-items:center !important;
    justify-content:flex-start !important;
    text-align:center !important;
    padding:18px 18px 14px !important;
    min-height:216px !important;
    border-radius:18px !important;
    border:1px solid #e9ddcc !important;
    background:#fffdfa !important;
}
.dpc-app .dpc-food-grid__thumb{
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    width:160px !important;
    height:112px !important;
    margin:0 auto 10px !important;
    padding:0 !important;
    border:none !important;
    background:transparent !important;
    box-shadow:none !important;
    border-radius:0 !important;
    overflow:visible !important;
}
.dpc-app .dpc-food-grid__thumb img{
    display:block !important;
    width:auto !important;
    height:auto !important;
    max-width:132px !important;
    max-height:100px !important;
    object-fit:contain !important;
    object-position:center center !important;
    margin:0 auto !important;
    border:none !important;
    background:none !important;
    box-shadow:none !important;
}
.dpc-app .dpc-food-grid strong{
    display:block !important;
    margin:0 0 6px !important;
    font-size:23px !important;
    line-height:1.05 !important;
    color:#1c2d19 !important;
}
.dpc-app .dpc-food-grid small{
    font-size:14px !important;
    line-height:1.45 !important;
    color:#73736a !important;
}
@media (max-width:1080px){
    .dpc-app .dpc-nutrition-section{background-size:100% auto !important;background-position:center top !important;}
    .dpc-app .dpc-nutrition-section .dpc-section__head--nutrition{min-height:198px !important;}
    .dpc-app .dpc-nutrition-section .dpc-section__head--nutrition > div{padding-right:0 !important; max-width:620px !important;}
    .dpc-app .dpc-nutrition-section .dpc-section__head--nutrition h3{font-size:54px !important;}
    .dpc-app .dpc-nutrition-layout{grid-template-columns:1fr !important;}
}
@media (max-width:720px){
    .dpc-app .dpc-nutrition-section{background-position:74% top !important; background-size:cover !important;}
    .dpc-app .dpc-nutrition-section .dpc-section__head--nutrition{min-height:148px !important; margin-bottom:12px !important;}
    .dpc-app .dpc-nutrition-section .dpc-section__head--nutrition > div{max-width:none !important; padding-right:0 !important;}
    .dpc-app .dpc-nutrition-section .dpc-section__head--nutrition h3{font-size:38px !important; line-height:.98 !important; max-width:260px !important;}
    .dpc-app .dpc-nutrition-section .dpc-section__head--nutrition p{font-size:15px !important; line-height:1.5 !important; max-width:270px !important;}
    .dpc-app .dpc-food-grid article{min-height:190px !important; padding:14px 12px !important;}
    .dpc-app .dpc-food-grid__thumb{width:112px !important; height:82px !important; margin-bottom:8px !important;}
    .dpc-app .dpc-food-grid__thumb img{max-width:94px !important; max-height:74px !important;}
    .dpc-app .dpc-food-grid strong{font-size:18px !important;}
    .dpc-app .dpc-food-grid small{font-size:12px !important; line-height:1.35 !important;}
    .dpc-app .dpc-nutrition-submit{margin-top:18px !important; min-height:54px !important;}
}


/* ===== v2.8.7 nutrition header width polish ===== */
.dpc-app .dpc-nutrition-section .dpc-section__head--nutrition{
    display:flex !important;
    align-items:flex-start !important;
    justify-content:flex-start !important;
    min-height:190px !important;
}
.dpc-app .dpc-nutrition-section .dpc-section__head--nutrition > div{
    width:min(620px, calc(100% - 390px)) !important;
    max-width:620px !important;
    padding-right:0 !important;
}
.dpc-app .dpc-nutrition-section .dpc-section__head--nutrition h3{
    max-width:560px !important;
    font-size:58px !important;
    line-height:0.96 !important;
    letter-spacing:-0.035em !important;
    text-wrap:balance !important;
}
.dpc-app .dpc-nutrition-section .dpc-section__head--nutrition p{
    max-width:560px !important;
    font-size:17px !important;
    line-height:1.5 !important;
}
@media (max-width:1200px){
    .dpc-app .dpc-nutrition-section .dpc-section__head--nutrition > div{
        width:min(560px, calc(100% - 340px)) !important;
        max-width:560px !important;
    }
    .dpc-app .dpc-nutrition-section .dpc-section__head--nutrition h3{
        max-width:500px !important;
        font-size:52px !important;
    }
    .dpc-app .dpc-nutrition-section .dpc-section__head--nutrition p{
        max-width:500px !important;
    }
}
@media (max-width:1080px){
    .dpc-app .dpc-nutrition-section .dpc-section__head--nutrition{
        display:block !important;
        min-height:198px !important;
    }
    .dpc-app .dpc-nutrition-section .dpc-section__head--nutrition > div{
        width:auto !important;
        max-width:620px !important;
    }
    .dpc-app .dpc-nutrition-section .dpc-section__head--nutrition h3{
        max-width:620px !important;
        font-size:50px !important;
    }
    .dpc-app .dpc-nutrition-section .dpc-section__head--nutrition p{
        max-width:620px !important;
        font-size:17px !important;
    }
}
@media (max-width:720px){
    .dpc-app .dpc-nutrition-section .dpc-section__head--nutrition h3{
        font-size:38px !important;
        max-width:260px !important;
    }
    .dpc-app .dpc-nutrition-section .dpc-section__head--nutrition p{
        max-width:270px !important;
        font-size:15px !important;
    }
}


/* ===== v2.8.8 nutrition calculator logic + feeding table redesign ===== */
.dpc-app .dpc-table-wrap{
    margin-top:24px !important;
    padding:0 !important;
    border:0 !important;
    border-radius:0 !important;
    background:transparent !important;
    box-shadow:none !important;
    overflow:visible !important;
}
.dpc-app .dpc-food-table{
    width:100% !important;
    border-collapse:separate !important;
    border-spacing:0 !important;
    table-layout:fixed !important;
    background:rgba(255,250,243,.95) !important;
    border:1px solid #dcbf86 !important;
    border-radius:30px !important;
    overflow:hidden !important;
}
.dpc-app .dpc-food-table thead th{
    padding:14px 18px !important;
    background:linear-gradient(180deg,#0e5f42 0%, #0a4c35 100%) !important;
    color:#fff6da !important;
    border-right:1px solid rgba(223,188,107,.7) !important;
    border-bottom:2px solid #d7b062 !important;
    font-size:14px !important;
    font-weight:800 !important;
    letter-spacing:.02em !important;
    text-transform:uppercase !important;
    vertical-align:middle !important;
}
.dpc-app .dpc-food-table thead th:first-child{border-top-left-radius:28px !important;}
.dpc-app .dpc-food-table thead th:last-child{border-right:0 !important;border-top-right-radius:28px !important;}
.dpc-app .dpc-food-table__head{display:flex !important;align-items:center !important;gap:12px !important;}
.dpc-app .dpc-food-table__head-icon{
    flex:0 0 auto !important;
    display:grid !important;
    place-items:center !important;
    width:42px !important;
    height:42px !important;
    border-radius:50% !important;
    border:2px solid #d8ae5d !important;
    background:radial-gradient(circle at 35% 35%, #f3d38f 0%, #bb8430 100%) !important;
    font-size:21px !important;
    box-shadow:inset 0 1px 0 rgba(255,255,255,.55) !important;
}
.dpc-app .dpc-food-table tbody td{
    padding:18px 18px !important;
    background:rgba(255,250,242,.96) !important;
    border-right:1px solid #e2c78e !important;
    border-bottom:1px solid #ead7ac !important;
    font-size:17px !important;
    line-height:1.35 !important;
    color:#35332d !important;
    vertical-align:middle !important;
}
.dpc-app .dpc-food-table tbody tr:nth-child(even) td{background:#fbf4e8 !important;}
.dpc-app .dpc-food-table tbody tr.is-active td{background:#fef8ed !important;}
.dpc-app .dpc-food-table tbody td:last-child{border-right:0 !important;font-size:17px !important;color:#3e4038 !important;}
.dpc-app .dpc-food-table tbody tr:last-child td:first-child{border-bottom-left-radius:28px !important;}
.dpc-app .dpc-food-table tbody tr:last-child td:last-child{border-bottom-right-radius:28px !important;}
.dpc-app .dpc-food-week-pill{
    display:inline-flex !important;
    align-items:center !important;
    gap:12px !important;
    min-width:176px !important;
    padding:12px 22px !important;
    border-radius:999px !important;
    background:linear-gradient(180deg,#0d5e41 0%, #084731 100%) !important;
    border:2px solid #d6ab54 !important;
    color:#fff6d9 !important;
    font-size:18px !important;
    line-height:1 !important;
    font-weight:800 !important;
    box-shadow:0 10px 20px rgba(20,57,40,.12), inset 0 1px 0 rgba(255,255,255,.12) !important;
}
.dpc-app .dpc-food-week-pill__icon{
    display:grid !important;
    place-items:center !important;
    width:28px !important;
    height:28px !important;
    border-radius:50% !important;
    background:rgba(255,224,160,.16) !important;
    color:#ffd47a !important;
    font-size:16px !important;
    line-height:1 !important;
}
.dpc-app .dpc-food-table__metric{
    display:block !important;
    font-size:18px !important;
    line-height:1.25 !important;
    font-weight:700 !important;
    color:#302d27 !important;
}
.dpc-app .dpc-food-note-box{
    display:grid !important;
    grid-template-columns:42px minmax(0,1fr) !important;
    align-items:flex-start !important;
    gap:14px !important;
}
.dpc-app .dpc-food-note-box__icon{
    display:grid !important;
    place-items:center !important;
    width:42px !important;
    height:42px !important;
    border-radius:14px !important;
    background:linear-gradient(180deg,#fff6dd 0%, #f4e0af 100%) !important;
    font-size:22px !important;
    box-shadow:inset 0 0 0 1px #e3c88e !important;
}
.dpc-app .dpc-food-note-box__text{display:block !important;font-size:16px !important;line-height:1.45 !important;color:#45453f !important;}
.dpc-app .dpc-today-food{scroll-margin-top:24px !important;}
@media (max-width:980px){
    .dpc-app .dpc-food-table{min-width:980px !important;}
}
@media (max-width:720px){
    .dpc-app .dpc-food-table tbody tr{padding:16px !important;border-radius:20px !important;background:#fffdf8 !important;border:1px solid #ead7ac !important;}
    .dpc-app .dpc-food-table tbody td{padding:10px 0 !important;background:transparent !important;border-right:0 !important;border-bottom:1px solid #efe0bd !important;}
    .dpc-app .dpc-food-table tbody tr:nth-child(even) td,
    .dpc-app .dpc-food-table tbody tr.is-active td{background:transparent !important;}
    .dpc-app .dpc-food-table tbody td:first-child{padding-top:0 !important;}
    .dpc-app .dpc-food-table tbody td:last-child{padding-bottom:0 !important;border-bottom:0 !important;}
    .dpc-app .dpc-food-table tbody td:before{font-size:11px !important;letter-spacing:.08em !important;color:#7e6a42 !important;}
    .dpc-app .dpc-food-week-pill{min-width:0 !important;width:100% !important;justify-content:center !important;font-size:17px !important;padding:11px 16px !important;}
    .dpc-app .dpc-food-table__metric{font-size:16px !important;text-align:left !important;}
    .dpc-app .dpc-food-note-box{grid-template-columns:36px minmax(0,1fr) !important;gap:10px !important;}
    .dpc-app .dpc-food-note-box__icon{width:36px !important;height:36px !important;font-size:18px !important;border-radius:12px !important;}
    .dpc-app .dpc-food-note-box__text{font-size:15px !important;}
}

/* v2.8.9 — info section redesign */
.dpc-app .dpc-info-section{
    margin-top:24px;
    padding:28px;
    border:0 !important;
    border-radius:34px;
    background:#fffdf8 url("decor/info-section-bg.webp") center top/cover no-repeat !important;
    box-shadow:none !important;
}
.dpc-app .dpc-section__head--info{
    display:grid;
    gap:16px;
    margin-bottom:26px;
    max-width:760px;
}
.dpc-app .dpc-section__head--info h3{
    margin:0;
    max-width:760px;
    font-size:78px !important;
    line-height:.92 !important;
    letter-spacing:-.055em;
    color:#113f2d;
}
.dpc-app .dpc-info-divider,
.dpc-app .dpc-info-card__divider{
    display:flex;
    align-items:center;
    gap:16px;
    color:#d1aa55;
}
.dpc-app .dpc-info-divider span,
.dpc-app .dpc-info-card__divider span{
    display:block;
    height:2px;
    border-radius:999px;
    background:linear-gradient(90deg, rgba(213,172,89,.95), rgba(213,172,89,.45));
}
.dpc-app .dpc-info-divider span{width:130px;}
.dpc-app .dpc-info-divider i,
.dpc-app .dpc-info-card__divider i{font-style:normal;font-size:24px;line-height:1;}
.dpc-app .dpc-copy-grid--info{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:34px;
    margin-top:0;
}
.dpc-app .dpc-info-card{
    position:relative;
    min-height:430px;
    padding:28px 34px 34px;
    border-radius:30px;
    border:2px solid rgba(227,191,118,.72);
    background:rgba(255,255,255,.92);
    box-shadow:none;
    display:flex;
    flex-direction:column;
    align-items:center;
    text-align:left;
}
.dpc-app .dpc-info-card:before,
.dpc-app .dpc-info-card:after{
    content:"";
    position:absolute;
    opacity:.28;
    pointer-events:none;
}
.dpc-app .dpc-info-card:before{
    right:18px;
    bottom:16px;
    width:78px;
    height:78px;
    background:radial-gradient(circle at 30% 30%, rgba(255,217,164,.8), rgba(255,217,164,0) 65%);
}
.dpc-app .dpc-info-card__icon{
    width:96px;
    height:96px;
    margin:0 auto 18px;
    border-radius:50%;
    display:grid;
    place-items:center;
    font-size:42px;
    color:#e9c26b;
    background:radial-gradient(circle at 32% 28%, #1a6d54 0%, #0f493a 70%);
    border:5px solid #e2bb63;
    box-shadow:0 8px 18px rgba(125,88,22,.18), inset 0 2px 0 rgba(255,255,255,.18);
}
.dpc-app .dpc-info-card h4{
    margin:0;
    font-size:33px;
    line-height:1.06;
    letter-spacing:-.03em;
    color:#153f2f;
    text-align:center;
}
.dpc-app .dpc-info-card__divider{
    justify-content:center;
    margin:16px 0 18px;
}
.dpc-app .dpc-info-card__divider span{width:96px;}
.dpc-app .dpc-info-card p{
    margin:0;
    font-size:18px;
    line-height:1.55;
    color:#4a4d48;
}
.dpc-app .dpc-info-card__bottom{
    margin-top:auto;
    padding-top:18px;
    font-size:22px;
    line-height:1;
    color:#d6a94b;
}
.dpc-app .dpc-medical-note{
    margin:28px 0 0;
    min-height:0;
    padding:26px 28px;
    border-radius:24px;
    border:2px solid rgba(227,191,118,.72);
    background:rgba(255,255,255,.92);
    display:grid;
    grid-template-columns:150px 1fr;
    align-items:center;
    gap:22px;
    color:#4d4b46;
    font-size:19px;
    line-height:1.55;
    box-shadow:none;
}
.dpc-app .dpc-medical-note:before{display:none !important;}
.dpc-app .dpc-medical-note__badge{
    width:112px;
    height:112px;
    border-radius:50%;
    display:grid;
    place-items:center;
    font-size:58px;
    color:#fff8ed;
    background:radial-gradient(circle at 35% 35%, #f0c56f 0%, #bf7723 70%);
    border:6px solid #f4dfaa;
    box-shadow:0 10px 18px rgba(175,122,28,.18);
    justify-self:start;
}
.dpc-app .dpc-medical-note__copy strong{
    color:#b67b22;
    font-size:26px;
    margin-right:6px;
}
@media (max-width:1180px){
    .dpc-app .dpc-section__head--info h3{font-size:62px !important;max-width:640px;}
    .dpc-app .dpc-copy-grid--info{grid-template-columns:1fr;gap:18px;}
    .dpc-app .dpc-info-card{min-height:0;}
    .dpc-app .dpc-medical-note{grid-template-columns:110px 1fr;}
    .dpc-app .dpc-medical-note__badge{width:84px;height:84px;font-size:44px;}
}
@media (max-width:720px){
    .dpc-app .dpc-info-section{padding:18px;background-position:center top;}
    .dpc-app .dpc-section__head--info{gap:12px;margin-bottom:18px;}
    .dpc-app .dpc-section__head--info h3{font-size:42px !important;max-width:360px;line-height:.96 !important;}
    .dpc-app .dpc-info-divider{gap:10px;}
    .dpc-app .dpc-info-divider span{width:72px;height:2px;}
    .dpc-app .dpc-info-divider i{font-size:18px;}
    .dpc-app .dpc-copy-grid--info{gap:14px;}
    .dpc-app .dpc-info-card{padding:20px 18px 20px;border-radius:24px;}
    .dpc-app .dpc-info-card__icon{width:78px;height:78px;font-size:34px;margin-bottom:14px;}
    .dpc-app .dpc-info-card h4{font-size:23px;}
    .dpc-app .dpc-info-card__divider{margin:12px 0 14px;gap:10px;}
    .dpc-app .dpc-info-card__divider span{width:68px;}
    .dpc-app .dpc-info-card p{font-size:16px;line-height:1.5;}
    .dpc-app .dpc-medical-note{grid-template-columns:1fr;gap:14px;padding:18px;border-radius:22px;font-size:16px;}
    .dpc-app .dpc-medical-note__badge{justify-self:center;}
    .dpc-app .dpc-medical-note__copy strong{display:inline;font-size:22px;}
}

/* v2.8.10 — jump navigation cards: clear button hover/active states */
.dpc-app .dpc-hero--landing .dpc-jump-card{
    cursor:pointer !important;
    position:relative !important;
    isolation:isolate !important;
    overflow:hidden !important;
    transform:translateZ(0) !important;
    transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease, filter .22s ease !important;
}
.dpc-app .dpc-hero--landing .dpc-jump-card:before{
    content:"";
    position:absolute;
    inset:-2px;
    z-index:-1;
    border-radius:inherit;
    background:linear-gradient(135deg, rgba(255,255,255,.72), rgba(238,187,91,.35), rgba(42,123,72,.18));
    opacity:0;
    transition:opacity .22s ease;
}
.dpc-app .dpc-hero--landing .dpc-jump-card:after{
    content:"";
    position:absolute;
    top:-40%;
    left:-80%;
    width:52%;
    height:180%;
    background:linear-gradient(90deg, transparent, rgba(255,255,255,.72), transparent);
    transform:rotate(18deg);
    opacity:0;
    transition:left .45s ease, opacity .22s ease;
    pointer-events:none;
}
.dpc-app .dpc-hero--landing .dpc-jump-card:hover,
.dpc-app .dpc-hero--landing .dpc-jump-card:focus-visible{
    transform:translateY(-7px) scale(1.035) !important;
    border-color:#d8ae55 !important;
    box-shadow:0 18px 34px rgba(35,58,35,.18), 0 0 0 3px rgba(236,192,93,.25) !important;
    filter:saturate(1.08) brightness(1.02) !important;
    outline:none !important;
}
.dpc-app .dpc-hero--landing .dpc-jump-card:hover:before,
.dpc-app .dpc-hero--landing .dpc-jump-card:focus-visible:before{
    opacity:1;
}
.dpc-app .dpc-hero--landing .dpc-jump-card:hover:after,
.dpc-app .dpc-hero--landing .dpc-jump-card:focus-visible:after{
    left:128%;
    opacity:1;
}
.dpc-app .dpc-hero--landing .dpc-jump-card:hover .dpc-jump-card__icon,
.dpc-app .dpc-hero--landing .dpc-jump-card:focus-visible .dpc-jump-card__icon{
    transform:scale(1.12) rotate(-4deg) !important;
    box-shadow:0 12px 24px rgba(36,61,37,.18), 0 0 0 4px rgba(255,255,255,.55) !important;
}
.dpc-app .dpc-hero--landing .dpc-jump-card:hover em,
.dpc-app .dpc-hero--landing .dpc-jump-card:focus-visible em{
    transform:translateX(4px) scale(1.08) !important;
    background:#ffffff !important;
    color:#0d5137 !important;
}
.dpc-app .dpc-hero--landing .dpc-jump-card:active{
    transform:translateY(-2px) scale(.99) !important;
    box-shadow:0 8px 18px rgba(35,58,35,.14) !important;
}
.dpc-app .dpc-hero--landing .dpc-jump-card__icon,
.dpc-app .dpc-hero--landing .dpc-jump-card em{
    transition:transform .22s ease, box-shadow .22s ease, background .22s ease, color .22s ease !important;
}
@media (hover:none){
    .dpc-app .dpc-hero--landing .dpc-jump-card:active{
        transform:scale(.975) !important;
        filter:saturate(1.08) brightness(1.02) !important;
        box-shadow:0 10px 20px rgba(35,58,35,.16), 0 0 0 3px rgba(236,192,93,.22) !important;
    }
}
@media (prefers-reduced-motion: reduce){
    .dpc-app .dpc-hero--landing .dpc-jump-card,
    .dpc-app .dpc-hero--landing .dpc-jump-card:before,
    .dpc-app .dpc-hero--landing .dpc-jump-card:after,
    .dpc-app .dpc-hero--landing .dpc-jump-card__icon,
    .dpc-app .dpc-hero--landing .dpc-jump-card em{
        transition:none !important;
    }
}
