:root{
  --green:#155923;
  --green-soft:#eff8f0;
  --green-soft-2:#f7fbf7;
  --green-grad-1:#1a722b;
  --green-grad-2:#0f4d1c;
  --text:#111827;
  --text-soft:#475467;
  --muted:#667085;
  --line:rgba(21,89,35,.12);
  --bg:#f7faf7;
  --card:#ffffff;
  --shadow:0 16px 40px rgba(16,24,40,.08);
  --shadow-soft:0 8px 24px rgba(16,24,40,.06);
  --yellow:#f5b300;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;-webkit-font-smoothing:antialiased;scroll-behavior:smooth}
a{text-decoration:none;color:inherit}
button{font:inherit}
img{display:block;max-width:100%}
.page{width:min(100%,560px);margin:0 auto;min-height:100vh;background:#fff;box-shadow:0 0 0 1px rgba(17,24,39,.03)}
.topbar{position:sticky;top:0;z-index:40;display:flex;align-items:center;justify-content:space-between;gap:14px;padding:16px 18px 13px;background:rgba(255,255,255,.96);backdrop-filter:blur(18px);border-bottom:1px solid rgba(17,24,39,.05)}
.brand{display:flex;align-items:center;min-width:0;gap:10px}
.brand-mark{height:34px;width:56px;object-fit:contain;object-position:center}
.brand-name{font-size:23px;letter-spacing:.34em;font-weight:800;color:var(--green);line-height:1}
.category-pill{display:inline-flex;align-items:center;gap:8px;white-space:nowrap;padding:12px 16px;border-radius:999px;border:1px solid rgba(21,89,35,.18);background:#fff;color:var(--green);font-size:13px;font-weight:800;box-shadow:0 10px 28px rgba(21,89,35,.08)}
.category-pill img{width:17px;height:17px;flex:0 0 auto}
.hero{position:relative;aspect-ratio:1.42/1;overflow:hidden;background:#edf2f7}
.hero-img{width:100%;height:100%;object-fit:cover;transition:opacity .25s ease}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.01) 0%,rgba(0,0,0,.04) 100%);pointer-events:none}
.hero-note{position:absolute;right:16px;bottom:18px;max-width:250px;display:flex;align-items:center;gap:10px;padding:14px 16px;border-radius:20px;background:rgba(255,255,255,.96);border:1px solid rgba(21,89,35,.08);box-shadow:0 18px 36px rgba(16,24,40,.16);z-index:3}
.hero-note-icon{width:42px;height:42px;display:grid;place-items:center;border-radius:14px;background:var(--green-soft);color:var(--green);flex:0 0 auto}
.hero-note-icon img{width:24px;height:24px}
.hero-note-text{font-size:14px;line-height:19px;font-weight:800;color:#23323f}
.discount-badge{position:absolute;left:16px;top:16px;z-index:4;display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border-radius:999px;background:linear-gradient(135deg,var(--green-grad-1),var(--green-grad-2));color:#fff;font-size:12px;font-weight:900;box-shadow:0 12px 26px rgba(21,89,35,.25)}
.content{position:relative;margin-top:-24px;background:#fff;border-radius:28px 28px 0 0;padding:22px 18px 28px;box-shadow:0 -12px 30px rgba(17,24,39,.06)}
.title{margin:0;font-size:34px;line-height:1.06;letter-spacing:-.04em;color:#0f172a;font-weight:900}
.rating-row{display:flex;align-items:center;gap:12px;margin-top:14px;color:#344054;font-size:14px}
.stars{display:inline-flex;align-items:center;gap:2px;color:var(--yellow)}
.stars svg{width:18px;height:18px;fill:currentColor}
.location-row{display:flex;align-items:flex-start;gap:10px;margin-top:14px;color:#475467;font-size:15px;line-height:22px}
.location-row img{width:19px;height:19px;flex:0 0 auto;margin-top:1px}
.price{margin-top:16px;color:var(--green);font-size:30px;line-height:1.08;font-weight:900;letter-spacing:-.04em}
.description{margin:16px 0 0;color:#344054;font-size:15px;line-height:24px}
.timer-card{margin-top:14px;padding:12px 14px;border-radius:18px;border:1px solid var(--line);background:linear-gradient(135deg,#f2fbf3,#fff);display:flex;align-items:center;justify-content:space-between;gap:12px}
.timer-label{font-size:12px;line-height:16px;font-weight:800;color:var(--muted)}
.timer-value{font-size:15px;line-height:20px;font-weight:900;color:var(--green);font-variant-numeric:tabular-nums}
.spec-card{margin-top:22px;border:1px solid var(--line);border-radius:22px;overflow:hidden;background:#fff;box-shadow:var(--shadow-soft);display:grid;grid-template-columns:repeat(4,1fr)}
.spec-item{padding:14px 8px 13px;border-right:1px solid rgba(17,24,39,.08);text-align:center;min-width:0}
.spec-item:last-child{border-right:0}
.spec-icon{width:24px;height:24px;margin:0 auto 8px}
.spec-icon img{width:100%;height:100%;object-fit:contain}
.spec-value{display:block;font-size:16px;line-height:1.08;font-weight:850;color:#101828}
.spec-label{display:block;margin-top:5px;font-size:10.8px;line-height:14px;color:var(--muted)}
.calc-note{margin:10px 0 0;text-align:center;color:var(--muted);font-size:12px;line-height:18px}
.thumb-strip{display:flex;gap:12px;overflow-x:auto;padding:16px 2px 0;scrollbar-width:none;-ms-overflow-style:none}
.thumb-strip::-webkit-scrollbar{display:none}
.thumb-btn{position:relative;width:88px;height:88px;flex:0 0 auto;padding:0;border:0;background:#eef2f6;border-radius:16px;overflow:hidden;box-shadow:none;cursor:pointer}
.thumb-btn img{width:100%;height:100%;object-fit:cover}
.thumb-btn.is-active{outline:2px solid var(--green);outline-offset:0}
.thumb-more{position:absolute;inset:0;display:grid;place-items:center;background:rgba(15,23,42,.38);color:#fff;font-size:22px;font-weight:900}
.why-card{margin-top:24px;padding:20px;border-radius:24px;border:1px solid rgba(21,89,35,.08);background:linear-gradient(135deg,#f6fff7,#fff);box-shadow:var(--shadow-soft)}
.why-title{margin:0 0 14px;font-size:20px;line-height:1.2;letter-spacing:-.03em;font-weight:900;color:#101828}
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.why-item{min-width:0}
.why-icon{width:40px;height:40px;display:grid;place-items:center;border-radius:999px;background:#eaf6eb}
.why-icon img{width:21px;height:21px;object-fit:contain}
.why-item strong{display:block;margin-top:8px;font-size:12.2px;line-height:15px;color:#101828}
.why-item span{display:block;margin-top:4px;font-size:10.8px;line-height:15px;color:var(--muted)}
.actions{margin-top:22px;display:grid;gap:12px}
.primary-btn,.wa-btn{display:flex;align-items:center;justify-content:center;gap:12px;min-height:58px;padding:14px 18px;border-radius:16px;font-size:16px;font-weight:900;text-align:center}
.primary-btn{background:linear-gradient(135deg,var(--green-grad-1),var(--green-grad-2));color:#fff;box-shadow:0 16px 32px rgba(21,89,35,.24)}
.primary-btn img{width:28px;height:28px;flex:0 0 auto}
.wa-btn{background:#fff;color:#1c9c46;border:1px solid rgba(28,156,70,.3)}
.wa-btn .wa-icon{font-size:21px;line-height:1}
.hint{margin:2px 6px 0;text-align:center;color:var(--muted);font-size:12px;line-height:18px}
.footer{display:flex;align-items:center;gap:16px;padding:20px 18px 24px;border-top:1px solid rgba(17,24,39,.07);margin-top:24px;color:#475467;font-size:13px;line-height:19px}
.footer-brand{display:flex;align-items:center;gap:9px;flex:0 0 auto}
.footer-mark{width:52px;height:34px;object-fit:contain}
.footer-brand-name{font-size:22px;letter-spacing:.32em;font-weight:800;color:var(--green);line-height:1}
.home-wrap{padding:28px 18px 24px}
.home-card{border:1px solid var(--line);border-radius:26px;padding:24px 18px;background:radial-gradient(circle at top right,rgba(21,89,35,.14),transparent 42%),#fff;box-shadow:var(--shadow)}
.home-card h1{margin:0;font-size:30px;line-height:1.08;letter-spacing:-.04em;color:#0f172a}
.home-card p{margin:12px 0 0;color:var(--muted);line-height:24px}
.home-eyebrow{margin:0 0 8px;color:var(--green);font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.08em}
.home-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;padding:18px}
.home-type{border:1px solid var(--line);border-radius:20px;padding:16px;background:#fff;box-shadow:var(--shadow-soft)}
.home-type-icon{width:36px;height:36px;border-radius:12px;background:#eaf6eb;color:var(--green);display:grid;place-items:center;font-size:18px;font-weight:900}
.home-type h2{margin:10px 0 6px;font-size:15px;line-height:1.2}
.home-type p{margin:0;color:var(--muted);font-size:12px;line-height:18px}
.empty-card{padding:40px 18px;text-align:center;color:var(--muted)}
@media (max-width:520px){
  .page{width:100%}
  .topbar{padding:16px 16px 14px}
  .brand-mark{height:31px;width:52px}
  .brand-name{font-size:21px;letter-spacing:.3em}
  .category-pill{padding:11px 14px;font-size:13px}
  .hero{aspect-ratio:1.15/1}
  .hero-note{right:14px;bottom:14px;max-width:235px;padding:12px 14px}
  .hero-note-icon{width:38px;height:38px}
  .hero-note-text{font-size:13px;line-height:18px}
  .content{padding:20px 16px 26px}
  .title{font-size:30px}
  .price{font-size:28px}
  .spec-card{grid-template-columns:repeat(4,1fr)}
  .spec-item{padding:12px 6px 12px}
  .spec-icon{width:22px;height:22px;margin-bottom:7px}
  .spec-value{font-size:15px}
  .spec-label{font-size:10.2px;line-height:13px}
  .thumb-btn{width:82px;height:82px}
  .why-grid{grid-template-columns:repeat(3,1fr);gap:12px}
  .why-item strong{font-size:13px}
  .primary-btn,.wa-btn{font-size:15px;min-height:56px}
}
@media (max-width:390px){
  .brand-mark{width:48px;height:29px}
  .brand-name{font-size:19px;letter-spacing:.28em}
  .category-pill{padding:10px 13px;font-size:12px}
  .hero-note{max-width:220px}
  .content{padding-left:14px;padding-right:14px}
  .title{font-size:28px}
  .price{font-size:26px}
  .description{font-size:14px;line-height:22px}
  .spec-item{padding-left:6px;padding-right:6px}
  .thumb-btn{width:78px;height:78px;border-radius:14px}
}
