:root{--green:#16a34a;--green-dark:#15803d;--green-light:#dcfce7;--orange:#f97316;--cafe:#db2777;--ink:#0f172a;--ink-soft:#475569;--cloud:#f8fafc;--line:#e2e8f0;--white:#fff;--radius:18px;--shadow:0 1px 3px rgba(15,23,42,.06),0 8px 24px rgba(15,23,42,.05)}*{box-sizing:border-box}body,html{margin:0;padding:0}body{background:var(--cloud);color:var(--ink);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif,Apple Color Emoji,Segoe UI Emoji;-webkit-font-smoothing:antialiased;line-height:1.5}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}.container{width:100%;max-width:1120px;margin:0 auto;padding:0 20px}.site-header{position:-webkit-sticky;position:sticky;top:0;z-index:20;background:rgba(248,250,252,.85);-webkit-backdrop-filter:saturate(180%) blur(12px);backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid var(--line)}.site-header .bar{justify-content:space-between;height:64px}.logo,.site-header .bar{display:flex;align-items:center}.logo{gap:9px;font-weight:800;font-size:20px;letter-spacing:-.02em}.logo .dot{width:28px;height:28px;border-radius:9px;background:var(--green);display:grid;place-items:center;color:#fff;font-size:17px}.nav{display:flex;gap:22px;align-items:center;font-size:15px;font-weight:600;color:var(--ink-soft)}.nav a:hover{color:var(--ink)}@media (max-width:640px){.nav{display:none}}.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 20px;border-radius:999px;font-weight:700;font-size:15px;border:1px solid transparent;cursor:pointer;transition:transform .06s ease,background .15s ease}.btn:active{transform:scale(.98)}.btn-primary{background:var(--green);color:#fff}.btn-primary:hover{background:var(--green-dark)}.btn-ghost{background:var(--white);color:var(--ink);border-color:var(--line)}.hero{padding:64px 0 36px;text-align:center}.hero h1{font-size:clamp(34px,6vw,56px);line-height:1.05;letter-spacing:-.03em;margin:0 0 16px}.hero h1 .hl{color:var(--green)}.hero p.lead{font-size:clamp(17px,2.4vw,21px);color:var(--ink-soft);max-width:640px;margin:0 auto 28px}.hero .cta{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.section{padding:28px 0}.section h2{font-size:clamp(22px,3vw,28px);letter-spacing:-.02em;margin:0 0 4px}.section .sub{color:var(--ink-soft);margin:0 0 20px}.section-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:18px}.section-head h2{margin:0}.section-head a{color:var(--green);font-weight:700;font-size:15px;white-space:nowrap}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));grid-gap:18px;gap:18px}.card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:transform .12s ease,box-shadow .12s ease;display:flex;flex-direction:column}.card:hover{transform:translateY(-3px);box-shadow:0 2px 6px rgba(15,23,42,.08),0 14px 34px rgba(15,23,42,.1)}.card .thumb{position:relative;aspect-ratio:4/3;background:var(--green-light);display:grid;place-items:center}.card .thumb img{width:100%;height:100%;object-fit:cover}.card .thumb .ph{font-size:40px;opacity:.5}.card .badge{position:absolute;top:10px;left:10px;padding:5px 10px;border-radius:999px;color:#fff;font-size:12px;font-weight:700}.card .body{padding:14px 16px 16px;display:flex;flex-direction:column;gap:6px;flex:1 1}.card .name{font-weight:700;font-size:17px;letter-spacing:-.01em}.card .meta{color:var(--ink-soft);font-size:13.5px}.card .rating{color:#b45309;font-weight:700;font-size:13.5px}.tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}.tag{background:var(--green-light);color:var(--green-dark);font-size:12px;font-weight:600;padding:3px 9px;border-radius:999px}.chips{display:flex;flex-wrap:wrap;gap:10px}.chip{background:var(--white);border:1px solid var(--line);border-radius:999px;padding:10px 16px;font-weight:600;font-size:15px;box-shadow:var(--shadow);transition:border-color .12s ease,color .12s ease}.chip:hover{border-color:var(--green);color:var(--green-dark)}.crumbs{font-size:14px;color:var(--ink-soft);padding:18px 0 0}.crumbs a:hover{color:var(--green-dark)}.crumbs .sep{margin:0 8px;opacity:.5}.detail-hero{aspect-ratio:16/7;max-height:380px;background:var(--green-light);border-radius:var(--radius);overflow:hidden;display:grid;place-items:center;margin-top:14px}.detail-hero img{width:100%;height:100%;object-fit:cover}.detail h1{font-size:clamp(28px,4vw,40px);letter-spacing:-.02em;margin:18px 0 6px}.detail .sub{color:var(--ink-soft);font-size:16px}.detail .facts{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));grid-gap:12px;gap:12px;margin:22px 0}.fact{background:var(--white);border:1px solid var(--line);border-radius:14px;padding:14px 16px}.fact .k{font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-soft);font-weight:700}.fact .v{font-size:16px;font-weight:600;margin-top:2px}.prose{max-width:680px;font-size:17px;color:#1e293b}.app-cta{background:linear-gradient(135deg,var(--green) 0,var(--green-dark) 100%);color:#fff;border-radius:26px;padding:40px 32px;text-align:center;margin:40px 0}.app-cta h2{margin:0 0 10px;font-size:clamp(24px,4vw,34px)}.app-cta p{margin:0 auto 22px;max-width:520px;opacity:.92;font-size:17px}.app-cta .btn-ghost{background:hsla(0,0%,100%,.16);border-color:hsla(0,0%,100%,.3);color:#fff}.site-footer{border-top:1px solid var(--line);margin-top:48px;padding:36px 0;color:var(--ink-soft);font-size:14px}.site-footer .cols{display:flex;flex-wrap:wrap;gap:40px;justify-content:space-between}.site-footer a{display:block;padding:4px 0}.site-footer a:hover{color:var(--ink)}.site-footer .legal{margin-top:24px;font-size:13px;opacity:.8}