:root{color:#261f18;background:#f4ead8;font-family:Avenir Next,Trebuchet MS,sans-serif;--ink: #261f18;--paper: #fff8ec;--accent: #ef6f39;--good: #1f9d69;--bad: #e34b4b;--line: rgba(38, 31, 24, .14)}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:radial-gradient(circle at 20% 0%,#ffe4a8 0,transparent 34%),linear-gradient(145deg,#f7ecd6,#dff0db)}button,input{font:inherit}button{border:0;cursor:pointer}.app-shell{width:min(100%,520px);min-height:100vh;margin:0 auto;padding:18px}.topbar{display:flex;justify-content:flex-start;align-items:center;margin-bottom:22px}.brand,.ghost{background:#fff8ecb8;color:var(--ink);border:1px solid var(--line);border-radius:999px;padding:10px 14px;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.brand{font-weight:900;letter-spacing:-.04em}.hero{padding:10px 0 34px}.eyebrow{color:#87543a;text-transform:uppercase;letter-spacing:.14em;font-size:12px;font-weight:800}.hero h1{font-size:clamp(42px,12vw,68px);line-height:.88;letter-spacing:-.08em;margin:0 0 28px}.search-box{display:grid;gap:12px}.search-box input{width:100%;padding:18px 20px;border-radius:24px;border:1px solid var(--line);background:var(--paper);box-shadow:0 20px 60px #4a32141f;outline:none}.search-box button,.empty-state button{padding:16px 20px;border-radius:24px;color:#fff;background:var(--ink);font-weight:900}.browse-button{width:100%;margin-top:12px;padding:16px 20px;border-radius:24px;color:var(--ink);background:#fff8ecc7;border:1px solid var(--line);font-weight:900;box-shadow:0 14px 38px #4a32141a}.liked-cta{width:100%;margin-top:12px;padding:16px 20px;border-radius:24px;color:var(--ink);background:#fff8ecc7;border:1px solid var(--line);font-weight:950;box-shadow:0 14px 38px #4a32141a}.hint{color:#261f18a8;line-height:1.5}.error-message{color:#9d2f25;background:#e34b4b1a;border:1px solid rgba(227,75,75,.22);border-radius:18px;padding:12px 14px;line-height:1.4}.deck{position:relative;min-height:74vh;display:grid;place-items:center}.deck-head{width:100%;align-self:end;margin-bottom:10px;text-align:center}.deck-head h1{margin:0;font-size:24px;letter-spacing:-.05em}.deck-head p{margin:6px 0 0;color:#261f189e;line-height:1.35}.swipe-layer{width:100%;touch-action:pan-y}.meme-card{background:#fff8ecdb;border:1px solid rgba(38,31,24,.12);border-radius:34px;padding:12px;box-shadow:0 28px 80px #4a321438;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.image-frame{border-radius:26px;overflow:hidden;background:#191613;aspect-ratio:1 / 1;display:grid;place-items:center}.image-frame img{width:100%;height:100%;object-fit:contain;-webkit-user-select:none;user-select:none}.card-copy{padding:12px 8px 4px}.card-copy h2{margin:0;font-size:22px;line-height:1.05;letter-spacing:-.04em}.card-copy p{margin:8px 0 0;color:#261f18b3;line-height:1.35;max-height:58px;overflow:hidden}.primary-actions{display:flex;justify-content:center;gap:14px;padding:12px 0}.round{width:58px;height:58px;border-radius:999px;font-size:28px;font-weight:900;color:#fff;box-shadow:0 12px 24px #261f182e}.nope{background:var(--bad)}.like{background:var(--good)}.undo{background:#2f2a24;font-size:24px}.secondary-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}.secondary-actions button{padding:12px 10px;border-radius:18px;background:#f0dfc3;color:var(--ink);font-weight:800}.deck-count{margin-top:12px;color:#261f1894;font-size:13px}.list-page,.shared-page{padding-bottom:32px}.page-head{display:flex;align-items:center;justify-content:space-between}.page-head h1{letter-spacing:-.06em;font-size:36px;margin:0 0 14px}.meme-grid{display:grid;gap:18px}.meme-grid .meme-card{box-shadow:0 16px 44px #4a321424}.favorites-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.favorite-tile{min-width:0}.favorite-tile.is-open{grid-column:1 / -1;background:#fff8ecd1;border:1px solid var(--line);border-radius:24px;padding:8px;box-shadow:0 16px 42px #4a321421}.favorite-image-button{width:100%;aspect-ratio:1 / 1;padding:0;border-radius:16px;overflow:hidden;background:#191613;display:block}.favorite-image-button img{width:100%;height:100%;object-fit:cover;display:block}.favorite-tile.is-open .favorite-image-button{border-radius:18px}.favorite-tile.is-open .favorite-image-button img{object-fit:contain}.favorite-details{padding:10px 6px 4px}.favorite-details h2{margin:0;font-size:20px;line-height:1.08;letter-spacing:-.04em}.favorite-details p{margin:8px 0 0;color:#261f18b3;line-height:1.35}.favorite-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:10px}.favorite-actions button{padding:11px 10px;border-radius:15px;background:#f0dfc3;color:var(--ink);font-weight:850}.empty-state,.loading{min-height:70vh;display:grid;place-content:center;text-align:center;gap:12px}.tag-discovery{margin-top:34px}.section-label h2{margin:4px 0 14px;font-size:28px;letter-spacing:-.06em}.tag-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.tag-card{min-height:96px;text-align:left;border-radius:24px;padding:12px;color:var(--ink);background:#fff8ecc7;border:1px solid var(--line);box-shadow:0 12px 30px #4a32141a;display:grid;grid-template-columns:54px 1fr;align-items:center;gap:10px}.tag-icon-frame{width:54px;height:54px;border-radius:17px;overflow:hidden;background:#191613;border:1px solid rgba(38,31,24,.12);display:grid;place-items:center}.tag-icon-frame img{width:100%;height:100%;object-fit:cover;display:block}.tag-title{font-weight:900;letter-spacing:-.03em}@media(min-width:760px){.app-shell{width:min(100%,920px)}.hero{max-width:720px}.search-box{grid-template-columns:1fr 150px}.deck{width:480px;margin:0 auto}.meme-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.favorites-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}
