:root{font-family:Inter,PingFang SC,Microsoft YaHei,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#19201d;background:#f5f1e8;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}button,input{font:inherit}button{cursor:pointer}.app-shell{min-height:100vh;padding:32px;background:radial-gradient(circle at 12% 18%,rgba(210,95,63,.18),transparent 26%),linear-gradient(135deg,#f7f2e8,#e8f1e1 48%,#edf0f4)}.hero{display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,460px);gap:24px;align-items:end;max-width:1160px;margin:0 auto 24px;padding:34px;color:#f9f6ed;background:linear-gradient(120deg,#141e1be6,#2c4334c7),url("data:image/svg+xml,%3Csvg width='900' height='420' viewBox='0 0 900 420' xmlns='http://www.w3.org/2000/svg'%3E%3Crect width='900' height='420' fill='%23314631'/%3E%3Cpath d='M0 300L80 260L170 310L260 215L355 250L455 150L555 215L640 115L760 180L900 85V420H0Z' fill='%23598a4f'/%3E%3Cpath d='M0 338L105 292L220 335L338 254L450 298L560 220L690 285L795 210L900 250V420H0Z' fill='%2383a65f'/%3E%3Ccircle cx='728' cy='86' r='42' fill='%23d7a13e'/%3E%3Cpath d='M102 138h60v32h-60zM640 282h72v38h-72zM340 176h48v48h-48z' fill='%23d25f3f' opacity='.85'/%3E%3C/svg%3E");background-size:cover;background-position:center;border-radius:8px;box-shadow:0 22px 60px #222d252e}.eyebrow{margin:0 0 12px;color:#f1c66a;font-size:13px;font-weight:700;letter-spacing:0;text-transform:uppercase}h1,h2,p{margin-top:0}h1{margin-bottom:16px;font-size:clamp(36px,6vw,68px);line-height:1;letter-spacing:0}.intro{max-width:580px;margin-bottom:0;color:#f9f6edd1;font-size:18px;line-height:1.8}.search-panel{display:grid;gap:14px;padding:18px;color:#18201c;background:#fffcf4f0;border:1px solid rgba(255,255,255,.32);border-radius:8px}.search-label{font-size:14px;font-weight:700}.search-row input{width:100%;min-height:48px;padding:0 14px;color:#18201c;background:#fff;border:1px solid #d6d2c7;border-radius:8px;outline:none}.search-row input:focus{border-color:#4f9d69;box-shadow:0 0 0 3px #4f9d692e}.category-list{display:flex;flex-wrap:wrap;gap:8px}.category-list button,.link-list button{min-height:36px;border:0;border-radius:8px;transition:transform .16s ease,background .16s ease,color .16s ease}.category-list button{padding:0 12px;color:#526057;background:#ece7dc}.category-list button.active{color:#fffaf0;background:#26382e}.category-list button:hover,.link-list button:hover{transform:translateY(-1px)}.content-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px;max-width:1160px;margin:0 auto}.game-card{display:flex;flex-direction:column;min-height:390px;padding:20px;background:#fffcf4eb;border:1px solid rgba(77,82,70,.12);border-radius:8px;box-shadow:0 16px 36px #41483d1a}.card-top{display:grid;grid-template-columns:58px minmax(0,1fr);gap:14px;align-items:center}.game-mark{display:grid;width:58px;height:58px;place-items:center;color:#fff;background:linear-gradient(145deg,rgba(255,255,255,.18),transparent),var(--mark-color);border-radius:8px;font-size:28px;font-weight:800}.card-top h2{margin-bottom:7px;font-size:22px;line-height:1.2}.card-top p{margin-bottom:0;color:#667067;font-size:14px;line-height:1.5}.tag-row,.spot-list{display:flex;flex-wrap:wrap;gap:8px}.tag-row{margin:18px 0 16px}.tag-row span{padding:5px 9px;color:#385243;background:#e4eddf;border-radius:999px;font-size:12px;font-weight:700}.spot-list{align-content:flex-start;min-height:106px;padding:14px;background:#f5f0e6;border:1px solid #e1dacd;border-radius:8px}.spot-list span{padding:7px 10px;color:#5b5144;background:#fffaf0;border-radius:8px;font-size:13px}.link-list{display:grid;gap:10px;margin-top:auto;padding-top:18px}.link-list button{width:100%;padding:0 12px;color:#fffaf0;background:#26382e}.empty-state{grid-column:1 / -1;padding:40px;text-align:center;color:#526057;background:#fffcf4db;border-radius:8px}@media(max-width:1040px){.content-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:760px){.app-shell{padding:14px}.hero{grid-template-columns:1fr;padding:22px}.intro{font-size:16px;line-height:1.7}.content-grid{grid-template-columns:1fr}.game-card{min-height:0}}
