:root{--bg:#fbf8f3;--card:#fffdf8;--text:#2d2a26;--muted:#7c7368;--soft:#efe1cf;--accent:#b56a35;--border:rgba(45,42,38,.12)}
*{box-sizing:border-box}
body{margin:0;font-family:Arial,Helvetica,sans-serif;color:var(--text);background:radial-gradient(circle at 50% 0%,rgba(181,106,53,.12),transparent 34%),var(--bg)}
.wrap{max-width:760px;margin:0 auto;padding:14px 12px 30px}
.card{background:var(--card);border:1px solid var(--border);border-radius:26px;overflow:hidden;box-shadow:0 14px 42px rgba(45,42,38,.08)}
.photo{width:100%;aspect-ratio:4/3;object-fit:cover;background:#eadfce;display:block}
.content{padding:20px}.eyebrow{font-size:13px;color:var(--muted);margin-bottom:6px}
h1{font-size:34px;line-height:1.04;margin:0 0 8px}
.pill{display:inline-flex;background:#f4eadc;border:1px solid var(--border);border-radius:999px;padding:8px 12px;font-weight:700;margin:6px 0 12px}.lead{font-size:17px;line-height:1.42;margin:8px 0 18px;color:#3b352f;white-space:pre-wrap}.human-block{font-size:16px;line-height:1.45;color:#3b352f;white-space:pre-wrap;margin:0 0 10px}
.grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.item{background:#fff7ec;border:1px solid var(--border);border-radius:16px;padding:12px}
.label{font-size:12px;color:var(--muted);margin-bottom:4px}.value{font-weight:700}
.section{margin-top:16px;padding-top:16px;border-top:1px solid var(--border)}
.section h2{font-size:20px;margin:0 0 10px}.text{white-space:pre-wrap;line-height:1.45}
.needs{display:grid;gap:8px}.need{background:#fff7ec;border:1px solid var(--border);border-radius:14px;padding:12px}
.need a{color:var(--accent);font-weight:700;text-decoration:none}
.support-box{background:linear-gradient(135deg,#fff7ec,#f6e5d2);border:1px solid rgba(181,106,53,.22);border-radius:18px;padding:14px;display:grid;gap:10px}
.support-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.support-title{font-weight:800;font-size:17px}.support-note{color:var(--muted);font-size:14px;line-height:1.35;margin-top:3px}
.support-button{display:inline-flex;align-items:center;justify-content:center;text-decoration:none;background:var(--accent);color:white;border-radius:999px;padding:11px 15px;font-weight:800;white-space:nowrap}
.support-donate{display:grid;gap:10px}
.support-amounts{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}
.support-amount{border:1px solid var(--border);background:#fff;border-radius:14px;padding:10px 8px;font-size:15px;font-weight:800;color:var(--accent);cursor:pointer}
.support-amount.active{border-color:var(--accent);box-shadow:0 0 0 3px rgba(181,106,53,.14)}
.support-custom{width:100%;border:1px solid var(--border);border-radius:14px;padding:12px 14px;font-size:16px;background:#fff;color:var(--text)}
.support-pay{width:100%;border:0;border-radius:16px;padding:14px 16px;background:var(--accent);color:#fff;font-size:16px;font-weight:900;cursor:pointer;box-shadow:0 12px 24px rgba(181,106,53,.22)}
.support-pay:disabled{opacity:.7;cursor:wait}
.support-notice{display:none;font-size:13px;line-height:1.4;padding:10px 12px;border-radius:12px}
.support-notice.error{display:block;background:#fff0f0;color:#9b1c1c}
.support-stats{display:flex;flex-wrap:wrap;gap:8px}.support-stat{background:rgba(255,255,255,.72);border:1px solid var(--border);border-radius:999px;padding:7px 10px;font-size:13px;font-weight:700}
.donation-list{display:grid;gap:7px}.donation-item{background:rgba(255,255,255,.72);border:1px solid var(--border);border-radius:14px;padding:10px}.donation-meta{font-size:12px;color:var(--muted);margin-top:3px}
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.gallery img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:14px;cursor:pointer;transition:transform .15s ease}
.gallery img:active{transform:scale(.98)}
.related-cats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}
.related-cat{display:block;text-decoration:none;color:inherit;background:#fff7ec;border:1px solid var(--border);border-radius:16px;overflow:hidden}
.related-cat img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block;background:#eadfce}
.related-cat-body{padding:10px}.related-cat-name{font-weight:800;margin-bottom:4px}.related-cat-caption{font-size:13px;line-height:1.35;color:var(--muted);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
@media(max-width:620px){.related-cats{grid-template-columns:repeat(2,minmax(0,1fr))}}
.video-playlist{display:grid;gap:10px}
.video-player{background:#111;border-radius:18px;overflow:hidden;border:1px solid var(--border)}
.video-player video{width:100%;max-height:70vh;background:#111;display:block}
.video-list{display:grid;gap:8px}
.video-item{width:100%;text-align:left;border:1px solid var(--border);background:#fff7ec;border-radius:14px;padding:8px;color:var(--text);font:inherit;cursor:pointer;display:grid;grid-template-columns:74px 1fr;gap:10px;align-items:center}
.video-item.active{background:#f4eadc;border-color:rgba(181,106,53,.45)}
.video-thumb{width:74px;aspect-ratio:4/3;object-fit:cover;border-radius:10px;background:#eadfce;display:block}
.video-copy{min-width:0}
.video-title{font-weight:700}
.video-note{font-size:12px;color:var(--muted);margin-top:3px}
.cafe-visit-box{background:linear-gradient(135deg,#fff7ec,#f6e5d2);border:1px solid rgba(181,106,53,.22);border-radius:18px;padding:16px;display:grid;gap:10px}
.cafe-visit-kicker{font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-weight:700}
.cafe-visit-text{line-height:1.5;color:#3b352f}
.cafe-visit-place{font-weight:700}
.cafe-visit-actions{display:flex;flex-wrap:wrap;gap:10px}
.cafe-visit-button,.cafe-visit-link{display:inline-flex;align-items:center;justify-content:center;text-decoration:none;border-radius:999px;padding:11px 15px;font-weight:800}
.cafe-visit-button{background:var(--accent);color:#fff}
.cafe-visit-link{background:rgba(255,255,255,.72);color:var(--accent);border:1px solid var(--border)}
.lightbox{position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,.86);display:none;align-items:center;justify-content:center;padding:18px}
.lightbox.open{display:flex}
.lightbox img{max-width:100%;max-height:88vh;border-radius:18px;box-shadow:0 20px 70px rgba(0,0,0,.35);object-fit:contain;background:#111}
.lightbox-close,.lightbox-nav{position:fixed;border:0;border-radius:999px;background:rgba(255,255,255,.92);color:#2d2a26;box-shadow:0 8px 28px rgba(0,0,0,.22);cursor:pointer}
.lightbox-close{top:12px;right:12px;width:44px;height:44px;font-size:28px;line-height:44px}
.lightbox-nav{top:50%;transform:translateY(-50%);width:48px;height:48px;font-size:34px;line-height:48px}
.lightbox-prev{left:12px}.lightbox-next{right:12px}
.lightbox-nav[hidden],.lightbox-count[hidden]{display:none}
.lightbox-count{position:fixed;left:50%;bottom:14px;transform:translateX(-50%);padding:7px 11px;border-radius:999px;background:rgba(255,255,255,.9);color:#2d2a26;font-size:13px;font-weight:700}
.box{padding:26px;background:var(--card);border:1px solid var(--border);border-radius:22px;text-align:center}
@media(max-width:520px){h1{font-size:30px}.grid{grid-template-columns:1fr}.content{padding:16px}.support-head{flex-direction:column}.support-amounts{grid-template-columns:repeat(2,minmax(0,1fr))}.lightbox{padding:10px}.lightbox-nav{width:42px;height:42px;font-size:30px;line-height:42px}.lightbox-prev{left:8px}.lightbox-next{right:8px}}
