/* =============================================================
   Mensaje Enviado — HOJA DE ESTILOS DE PRODUCCIÓN
   - Sin la maqueta de demo (sin .shell-top/.device/.notch/.scroller/.stage).
   - Responsive con media queries (breakpoint ~760px).
   - Fondo de página claro (--canvas).
   Renombra a mensaje-enviado.css al subirla a /site/templates/styles/.
   ============================================================= */
/* ============================================================
   Mensaje Enviado — propuesta de sitio (mobile-first)
   Layout responde al ANCHO DEL CONTENEDOR (container queries),
   así el marco de teléfono muestra el diseño móvil real.
   ============================================================ */
:root{
  --teal:#0E9E89; --teal-600:#0B8576; --teal-700:#0A6E60; --teal-ink:#07332D;
  --teal-tint:#E6F4F1; --teal-tint2:#D2EBE6;
  --ink:#15211F; --muted:#5C6B68; --faint:#8A9794;
  --line:#E6ECEA; --line2:#F0F3F2; --surface:#fff; --canvas:#F4F7F6;
  --amber:#C77D12; --amber-tint:#F9EED7;
  --green:#1B8F4D; --green-tint:#DCF1E4; --wa:#21A957;
  --r:14px; --r-lg:22px; --r-xl:28px;
  --sh-sm:0 1px 2px rgba(16,40,36,.05);
  --sh:0 2px 4px rgba(16,40,36,.04), 0 10px 30px -14px rgba(16,40,36,.18);
  --sh-up:0 -6px 24px -10px rgba(16,40,36,.16);
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:'Plus Jakarta Sans',system-ui,-apple-system,sans-serif;
  background:var(--canvas); color:var(--ink); -webkit-font-smoothing:antialiased;
  line-height:1.5; font-feature-settings:"ss01";
}
img{display:block;max-width:100%}
button{font-family:inherit;cursor:pointer;border:0;background:none;color:inherit}
a{color:inherit;text-decoration:none}
.mono{font-family:'JetBrains Mono',ui-monospace,monospace}

/* ============================================================
   Wrapper de la app (en PRODUCCIÓN no existe el marco de teléfono).
   Si tu template no usa .app, estos estilos quedan inertes.
   ============================================================ */
.app{background:var(--canvas)}


/* ---------- Top bar (mobile) ---------- */
.topbar{
  position:sticky;top:0;z-index:40;display:flex;align-items:center;justify-content:space-between;
  gap:10px;padding:14px 16px;background:rgba(255,255,255,.9);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);min-height:60px;
}
.brand{display:flex;align-items:center;gap:9px;font-weight:800;letter-spacing:-.02em;font-size:18px}
.brand .ico{width:30px;height:30px;flex:none;background:var(--teal);border-radius:9px;display:grid;place-items:center;color:#fff}
.brand .ico svg{width:18px;height:18px}
.brand .m{color:var(--ink)} .brand .e{color:var(--teal)}
.icobtn{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;color:var(--ink);background:var(--canvas)}
.icobtn svg{width:21px;height:21px}
.nav-desk{display:none}
.pill-donante{display:inline-flex;align-items:center;font-weight:700;font-size:13.5px;color:var(--teal-700);background:var(--teal-tint);padding:9px 15px;border-radius:999px}

/* ---------- Buttons ---------- */
.btn{font-weight:700;font-size:15px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;gap:9px;padding:14px 20px;letter-spacing:-.01em;line-height:1;transition:filter .12s,transform .12s,background .12s;white-space:nowrap}
.btn:active{transform:translateY(1px)}
.btn svg{width:18px;height:18px;flex:none}
.btn-primary{background:var(--teal);color:#fff}
.btn-primary:hover{filter:brightness(1.06)}
.btn-wa{background:var(--wa);color:#fff}
.btn-ghost{background:#fff;color:var(--ink);box-shadow:inset 0 0 0 1.5px var(--line)}
.btn-ghost:hover{box-shadow:inset 0 0 0 1.5px var(--teal);color:var(--teal-700)}
.btn-soft{background:var(--teal-tint);color:var(--teal-700)}
.btn-block{width:100%}
.btn-lg{padding:16px 22px;font-size:16px}

/* ---------- Badges ---------- */
.badge{font-size:11px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;padding:6px 11px;border-radius:999px;display:inline-flex;align-items:center;gap:6px}
.badge .d{width:7px;height:7px;border-radius:50%}
.b-ini{background:var(--amber-tint);color:var(--amber)}
.b-proc{background:var(--teal-tint);color:var(--teal-700)}
.b-fin{background:var(--green-tint);color:var(--green)}
.badge.solid.b-ini{background:var(--amber);color:#fff}
.badge.solid.b-proc{background:var(--teal);color:#fff}
.badge.solid.b-fin{background:var(--green);color:#fff}

/* ---------- Photo placeholder ---------- */
.ph{position:relative;background:
   repeating-linear-gradient(135deg,#dce7e4 0 10px,#e7efed 10px 20px);
   display:grid;place-items:center;color:#7d918c;overflow:hidden}
.ph::after{content:attr(data-l);font-family:'JetBrains Mono',monospace;font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:#83968f;padding:4px 9px;background:rgba(255,255,255,.7);border-radius:6px}
.ph.dark{background:repeating-linear-gradient(135deg,#16302b 0 10px,#1c3a34 10px 20px);color:#6fae a3}
.ph.dark::after{background:rgba(255,255,255,.12);color:#bfe0d9}

/* ============================================================
   HERO (home)
   ============================================================ */
.hero{background:
   radial-gradient(120% 90% at 90% -10%,#13b39b 0%,transparent 55%),
   linear-gradient(160deg,#0E9E89,#0A6E60 90%);
   color:#fff;padding:40px 20px 44px;text-align:center;position:relative;overflow:hidden}
.hero::after{content:"";position:absolute;right:-8%;bottom:-22%;width:230px;height:230px;opacity:.10;
   background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'><path d='M2.5 12 L7 16.5 L14.5 6.5'/><path d='M8.5 12 L13 16.5 L20.5 6.5'/></svg>") center/contain no-repeat}
.hero h1{font-size:30px;font-weight:800;letter-spacing:-.03em;line-height:1.08;position:relative}
.hero p{margin:14px auto 0;color:#d6efe9;font-size:15px;max-width:32ch;position:relative}
.hero .btn{margin-top:24px;position:relative}
.hero .stat{display:flex;justify-content:center;gap:26px;margin-top:30px;position:relative}
.hero .stat .n{font-size:24px;font-weight:800;letter-spacing:-.02em}
.hero .stat .t{font-size:11.5px;color:#bfe0d9;letter-spacing:.02em}

/* ---------- Section ---------- */
.sec{padding:26px 16px}
.sec-h{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}
.sec-h h2{font-size:22px;font-weight:800;letter-spacing:-.025em}
.sec-h .see{font-size:13.5px;font-weight:700;color:var(--teal-700)}

/* ---------- Filter chips ---------- */
.chips{display:flex;gap:9px;overflow-x:auto;padding:2px 16px 4px;margin:0 -16px;scrollbar-width:none}
.chips::-webkit-scrollbar{display:none}
.chip{flex:none;white-space:nowrap;font-size:13.5px;font-weight:700;padding:9px 16px;border-radius:999px;background:#fff;color:var(--muted);box-shadow:inset 0 0 0 1.5px var(--line)}
.chip.on{background:var(--ink);color:#fff;box-shadow:none}

/* ---------- Case cards ---------- */
.cases{display:grid;gap:16px;margin-top:16px}
.ccard{background:#fff;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh);position:relative;display:block}
.ccard .media{aspect-ratio:16/11;position:relative}
.ccard .media .badge{position:absolute;top:12px;left:12px;z-index:2;box-shadow:0 4px 12px rgba(0,0,0,.18)}
.ccard .media .grad{position:absolute;inset:0;background:linear-gradient(to top,rgba(7,30,26,.86) 0%,rgba(7,30,26,.25) 45%,transparent 70%)}
.ccard .body{padding:15px 16px 17px}
.ccard h3{font-size:17px;font-weight:800;letter-spacing:-.02em;line-height:1.2}
.ccard p{margin-top:6px;font-size:13.5px;color:var(--muted);line-height:1.45;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.ccard .meta{display:flex;align-items:center;gap:7px;margin-top:11px;font-size:12.5px;color:var(--faint);font-weight:600}
.ccard .prog{margin-top:13px}
.ccard .bar{height:7px;border-radius:999px;background:var(--line);overflow:hidden}
.ccard .bar i{display:block;height:100%;border-radius:999px;background:var(--teal)}
.ccard .prog .row{display:flex;justify-content:space-between;font-size:12px;margin-top:7px;font-weight:700;color:var(--muted)}
.ccard .go{margin-top:13px;font-size:14px;font-weight:800;color:var(--teal-700);display:inline-flex;align-items:center;gap:6px}
.ccard .go svg{width:15px;height:15px;transition:transform .15s}
.ccard:hover .go svg{transform:translateX(3px)}

/* ============================================================
   CASE DETAIL
   ============================================================ */
.case-hero{position:relative;aspect-ratio:1/1;max-height:62cqh}
.case-hero .grad{position:absolute;inset:0;background:linear-gradient(to top,rgba(7,30,26,.92) 0%,rgba(7,30,26,.15) 55%,rgba(7,30,26,.25) 100%)}
.case-hero .cap{position:absolute;left:0;right:0;bottom:0;padding:18px 18px 20px;color:#fff}
.case-hero h1{font-size:23px;font-weight:800;letter-spacing:-.02em;line-height:1.16;margin-top:11px;text-wrap:balance}
.case-hero .sub{margin-top:8px;font-size:13.5px;color:#d9eae6;line-height:1.45;max-width:40ch}
.case-back{position:absolute;top:14px;left:14px;z-index:5;width:42px;height:42px;border-radius:50%;background:rgba(7,30,26,.5);backdrop-filter:blur(6px);display:grid;place-items:center;color:#fff}
.case-back svg{width:21px;height:21px}
.case-share{position:absolute;top:14px;right:14px;z-index:5;width:42px;height:42px;border-radius:50%;background:rgba(7,30,26,.5);backdrop-filter:blur(6px);display:grid;place-items:center;color:#fff}
.case-share svg{width:19px;height:19px}

/* story / estados */
.case-hero.story{aspect-ratio:10/15;max-height:none}
.story-bars{position:absolute;top:10px;left:12px;right:12px;z-index:6;display:flex;gap:5px}
.story-bars .sbar{flex:1;height:3px;border-radius:2px;background:rgba(255,255,255,.4);overflow:hidden}
.story-bars .sbar i{display:block;height:100%;width:0;background:#fff;border-radius:2px}
.story-bars .sbar.done i{width:100%}
@keyframes storyfill{from{width:0}to{width:100%}}
.story-tap{position:absolute;top:46px;bottom:120px;width:42%;z-index:3;cursor:pointer}
.story-tap.prev{left:0}
.story-tap.next{right:0}
.case-hero.story .case-back,.case-hero.story .case-share{top:26px}

/* supporters row */
.supporters{display:flex;align-items:center;gap:11px;padding:13px 18px;background:#fff;border-bottom:1px solid var(--line);flex-wrap:wrap}
.supporters .lab{font-size:13px;color:var(--muted);font-weight:600}
.av-stack{display:flex;align-items:center}
.av-stack .a{width:32px;height:32px;border-radius:50%;border:2.5px solid #fff;margin-left:-9px;display:grid;place-items:center;color:#fff;font-weight:700;font-size:12px;box-shadow:0 1px 3px rgba(7,30,26,.18)}
.av-stack .a:first-child{margin-left:0}
.supporters .more{font-size:13px;font-weight:700;color:var(--teal-700)}

/* contribuciones */
.contribs{display:grid;gap:12px}
.contrib{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:15px 16px}
.contrib .ct-top{display:flex;align-items:center;gap:12px}
.contrib .cav{width:44px;height:44px;border-radius:50%;flex:none;display:grid;place-items:center;color:#fff;font-weight:800;font-size:16px}
.contrib .nm{font-weight:700;font-size:15px}
.contrib .ty{font-size:12.5px;color:var(--faint);margin-top:1px}
.contrib .ct-top .badge{margin-left:auto;flex:none}
.contrib .gift{display:flex;align-items:center;gap:9px;margin-top:12px;font-size:14.5px;color:#2b3a37;font-weight:600}
.contrib .gift svg{width:20px;height:20px;color:var(--amber);flex:none}

/* progress band */
.pband{background:#fff;padding:18px 18px;border-bottom:1px solid var(--line)}
.pband .top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:9px}
.pband .top .a{font-size:15px;font-weight:800}
.pband .top .b{font-size:13px;font-weight:700;color:var(--teal-700)}
.pband .bar{height:10px;border-radius:999px;background:var(--line);overflow:hidden}
.pband .bar i{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--teal),#13b39b)}
.pband .legend{display:flex;justify-content:space-between;margin-top:8px;font-size:12px;color:var(--faint);font-weight:600}

/* location */
.loc{display:flex;align-items:center;gap:9px;padding:14px 18px;background:#fff;font-size:13.5px;color:var(--muted);border-bottom:1px solid var(--line)}
.loc svg{width:18px;height:18px;color:var(--teal);flex:none}
.loc .map{margin-left:auto;font-weight:700;color:var(--teal-700);white-space:nowrap}

/* body text block */
.block{padding:20px 18px;background:#fff}
.block p{font-size:15px;color:#2b3a37;line-height:1.62}
.block h2{font-size:18px;font-weight:800;letter-spacing:-.02em;margin-bottom:14px}
.divider{height:9px;background:var(--canvas)}

/* beneficiaries */
.bens{display:grid;gap:11px}
.ben{display:flex;align-items:center;gap:13px;padding:13px;border:1px solid var(--line);border-radius:var(--r);background:#fff}
.ben .av{width:46px;height:46px;border-radius:50%;flex:none;display:grid;place-items:center;font-weight:800;color:#fff;font-size:17px;background:var(--teal)}
.ben .av.a2{background:#0A6E60}.ben .av.a3{background:#13b39b}
.ben .nm{font-weight:700;font-size:15px}
.ben .rl{font-size:12.5px;color:var(--faint);margin-top:2px}

/* ---------- Tabs (segmented, scrollable) ---------- */
.tabs-wrap{position:sticky;top:60px;z-index:30;background:var(--canvas);padding-top:6px}
.tabs{display:flex;gap:7px;overflow-x:auto;padding:8px 16px;scrollbar-width:none}
.tabs::-webkit-scrollbar{display:none}
.tab{flex:none;font-size:14px;font-weight:700;color:var(--muted);padding:10px 16px;border-radius:999px;background:#fff;box-shadow:inset 0 0 0 1.5px var(--line);transition:.12s}
.tab.on{background:var(--teal);color:#fff;box-shadow:none}
.tabpane{display:none;padding:18px 16px 24px}
.tabpane.on{display:block;animation:fade .25s ease}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* needs list */
.needs{display:grid;gap:11px}
.need{display:flex;gap:13px;align-items:flex-start;padding:15px;background:#fff;border:1px solid var(--line);border-radius:var(--r)}
.need .ck{width:24px;height:24px;border-radius:50%;flex:none;border:2px solid var(--line);display:grid;place-items:center;margin-top:1px;color:#fff;transition:.15s}
.need.done .ck{background:var(--teal);border-color:var(--teal)}
.need .ck svg{width:14px;height:14px;opacity:0}
.need.done .ck svg{opacity:1}
.need .nm{font-weight:700;font-size:15px}
.need.done .nm{color:var(--muted)}
.need .ds{font-size:13px;color:var(--muted);margin-top:3px;line-height:1.4}
.need .tag{margin-left:auto;flex:none}

/* transparency — cards on mobile */
.tsum{display:grid;grid-template-columns:1fr 1fr;gap:11px;margin-bottom:16px}
.tsum .c{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:15px}
.tsum .c.saldo{grid-column:1/-1;background:var(--teal-ink);border-color:var(--teal-ink);color:#fff}
.tsum .lab{font-size:11.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--faint)}
.tsum .c.saldo .lab{color:#9fd9cf}
.tsum .val{font-size:24px;font-weight:800;letter-spacing:-.02em;margin-top:5px}
.tsum .c.ing .val{color:var(--green)}
.tsum .c.egr .val{color:#C0392B}
.tx{display:grid;gap:9px}
.txrow{display:flex;align-items:center;gap:12px;padding:13px 14px;background:#fff;border:1px solid var(--line);border-radius:var(--r)}
.txrow .ti{width:38px;height:38px;border-radius:11px;flex:none;display:grid;place-items:center}
.txrow .ti.in{background:var(--green-tint);color:var(--green)}
.txrow .ti.out{background:#FBE6E3;color:#C0392B}
.txrow .ti svg{width:18px;height:18px}
.txrow .cc{flex:1;min-width:0}
.txrow .cc .c1{font-weight:700;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.txrow .cc .c2{font-size:12px;color:var(--faint);margin-top:2px}
.txrow .amt{font-weight:800;font-size:15px;letter-spacing:-.01em;white-space:nowrap}
.txrow .amt.in{color:var(--green)}.txrow .amt.out{color:#C0392B}
.txrow .vbtn{font-size:12px;font-weight:700;color:var(--teal-700);margin-left:4px}

/* evidence */
.evs{display:grid;gap:14px}
.ev{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:16px}
.ev h3{font-size:16px;font-weight:800;letter-spacing:-.01em}
.ev p{font-size:13px;color:var(--muted);margin-top:3px}
.ev .thumbs{display:grid;grid-template-columns:repeat(4,1fr);gap:7px;margin-top:13px}
.ev .thumbs .ph{aspect-ratio:1;border-radius:10px}

/* gallery */
.gal{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
.gal .ph{aspect-ratio:1;border-radius:12px}

/* timeline (avance) */
.tl{position:relative;padding-left:30px}
.tl::before{content:"";position:absolute;left:9px;top:6px;bottom:6px;width:2px;background:var(--line)}
.tlitem{position:relative;padding-bottom:20px}
.tlitem::before{content:"";position:absolute;left:-30px;top:3px;width:20px;height:20px;border-radius:50%;background:#fff;border:3px solid var(--teal);box-shadow:0 0 0 4px var(--canvas)}
.tlitem.done::before{background:var(--teal)}
.tlitem .dt{font-size:12px;font-weight:700;color:var(--teal-700);letter-spacing:.02em}
.tlitem .ti{font-weight:700;font-size:15px;margin-top:3px}
.tlitem .tx2{font-size:13px;color:var(--muted);margin-top:3px;line-height:1.5}

/* ---------- sticky action bar (case, mobile) ---------- */
.actionbar{position:sticky;bottom:0;z-index:35;background:rgba(255,255,255,.94);backdrop-filter:blur(10px);
  border-top:1px solid var(--line);box-shadow:var(--sh-up);padding:12px 14px;display:flex;gap:10px;align-items:stretch}
.actionbar .btn-wa{flex:1}
.actionbar .ib{width:52px;border-radius:16px;background:var(--canvas);display:grid;place-items:center;color:var(--ink);flex:none}
.actionbar .ib svg{width:22px;height:22px}
.actionbar .ib:hover{background:var(--teal-tint);color:var(--teal-700)}

/* ---------- bottom nav (mobile) ---------- */
.botnav{position:sticky;bottom:0;z-index:35;display:flex;background:rgba(255,255,255,.96);backdrop-filter:blur(10px);border-top:1px solid var(--line);padding:8px 6px 10px}
.botnav a{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;font-size:11px;font-weight:700;color:var(--faint);padding:5px 0}
.botnav a svg{width:23px;height:23px}
.botnav a.on{color:var(--teal-700)}

/* ---------- login ---------- */
.auth{padding:24px 18px 40px}
.authcard{background:#fff;border-radius:var(--r-xl);box-shadow:var(--sh);padding:26px 22px;border:1px solid var(--line)}
.authcard h1{font-size:24px;font-weight:800;letter-spacing:-.02em}
.authcard .lead{font-size:14px;color:var(--muted);margin-top:6px}
.authcard .lead a{color:var(--teal-700);font-weight:700}
.field{margin-top:18px}
.field label{display:block;font-size:13.5px;font-weight:700;margin-bottom:7px}
.field input{width:100%;font-family:inherit;font-size:15px;padding:14px 15px;border-radius:13px;border:1.5px solid var(--line);background:var(--canvas);color:var(--ink);transition:.15s}
.field input:focus{outline:0;border-color:var(--teal);background:#fff;box-shadow:0 0 0 4px var(--teal-tint)}
.field input::placeholder{color:var(--faint)}
.authsep{display:flex;align-items:center;gap:12px;margin:24px 0 4px;color:var(--faint);font-size:12.5px;font-weight:600}
.authsep::before,.authsep::after{content:"";height:1px;background:var(--line);flex:1}
.subcard{margin-top:16px;background:var(--teal-tint);border-radius:var(--r);padding:16px}
.subcard h3{font-size:14.5px;font-weight:800;color:var(--teal-700)}
.subcard p{font-size:13px;color:#33514c;margin-top:4px;line-height:1.5}

/* ---------- contact + footer ---------- */
.contact{background:var(--canvas);text-align:center;padding:34px 20px}
.contact h2{font-size:20px;font-weight:800;letter-spacing:-.02em}
.contact p{font-size:14px;color:var(--muted);margin:8px auto 18px;max-width:36ch}
.footer{background:var(--teal-ink);color:#bfe0d9;text-align:center;padding:30px 20px}
.footer .brand{justify-content:center;margin-bottom:12px}
.footer .brand .m,.footer .brand .e{color:#fff}
.footer p{font-size:12.5px;color:#7fb4ab;line-height:1.6}

/* ============================================================
   DESKTOP ADAPTATION  (container ≥ 760px)
   ============================================================ */
@media (min-width:760px){
  .topbar{padding:18px 40px;min-height:74px}
  .nav-desk{display:flex;align-items:center;gap:30px;font-size:15px;font-weight:600;color:var(--muted)}
  .nav-desk a:hover{color:var(--ink)}
  .nav-desk a.on{color:var(--ink);font-weight:700}
  .menu-btn{display:none}
  .brand{font-size:21px}.brand .ico{width:34px;height:34px}.brand .ico svg{width:20px;height:20px}

  .hero{padding:78px 40px 84px}
  .hero h1{font-size:54px;max-width:none}
  .hero p{font-size:18px;max-width:60ch}
  .hero .stat{gap:54px;margin-top:40px}
  .hero .stat .n{font-size:34px}

  .sec{max-width:1120px;margin:0 auto;padding:46px 40px}
  .sec-h h2{font-size:30px}
  .chips{margin:0;padding:0;overflow:visible;flex-wrap:wrap}
  .cases{grid-template-columns:repeat(3,1fr);gap:24px;margin-top:24px}
  .ccard .media{aspect-ratio:4/3}

  /* case detail desktop: two columns */
  .case-wrap{max-width:1120px;margin:0 auto;display:grid;grid-template-columns:1.55fr 1fr;gap:30px;padding:30px 40px;align-items:start}
  .case-main{min-width:0}
  .case-side{position:sticky;top:96px;display:flex;flex-direction:column;gap:16px}
  .case-hero{border-radius:var(--r-xl);overflow:hidden;aspect-ratio:16/11;max-height:none}
  .case-hero.story{aspect-ratio:3/2;max-height:480px}
  .case-hero h1{font-size:30px}
  .pband,.loc,.supporters{border-radius:var(--r-lg);border:1px solid var(--line);margin-top:0}
  .loc{border-bottom:1px solid var(--line)}
  .contribs{grid-template-columns:1fr 1fr}
  .block{border-radius:var(--r-lg);border:1px solid var(--line)}
  .divider{display:none}
  .bens{grid-template-columns:1fr 1fr}
  .tabs-wrap{position:static;background:transparent;padding:0}
  .tabs{padding:0 0 4px;flex-wrap:wrap}
  .tabpane{padding:20px 0 0}
  .gal{grid-template-columns:repeat(4,1fr)}
  .ev .thumbs{grid-template-columns:repeat(6,1fr)}
  .tsum{grid-template-columns:1fr 1fr 1fr}
  .tsum .c.saldo{grid-column:auto}
  .stack-side{display:flex;flex-direction:column;gap:14px}

  /* desktop side action card replaces sticky bar */
  .actionbar{display:none}
  .side-actions{display:flex;flex-direction:column;gap:10px;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:18px;box-shadow:var(--sh)}
  .side-actions .btn{width:100%}

  .botnav{display:none}
  .auth{max-width:460px;margin:0 auto;padding:50px 20px 70px}
  .contact{padding:54px 20px}
  .footer{padding:44px 20px}
}
@media (max-width:759.9px){
  .case-side .side-actions{display:none}
}
