
/* ============ DESIGN TOKENS ============ */
:root{
  --green-darkest:#0f3d1a;   /* top bar + footer */
  --green-dark:#14471f;
  --green:#1c6b32;           /* brand green */
  --green-btn:#1f7a34;       /* primary buttons */
  --green-btn-hover:#176228;
  --green-soft:#eef5ec;      /* light section bg */
  --gold:#a87d3f;            /* script accent */
  --zalo:#0068ff;
  --ink:#2b2f2b;
  --muted:#6f756e;
  --line:#e3e8e0;
  --white:#fff;
  --radius:10px;
  --shadow:0 6px 22px rgba(20,60,30,.08);
  --shadow-hover:0 12px 30px rgba(20,60,30,.16);
  --max:1240px;
  --bonsai:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 120 110'%3E%3Cg fill='none'%3E%3Cpath d='M58 60c-2-12-8-18-18-22' stroke='%237a5a32' stroke-width='4' stroke-linecap='round'/%3E%3Cpath d='M60 72V40' stroke='%237a5a32' stroke-width='6' stroke-linecap='round'/%3E%3Cpath d='M62 56c3-9 9-13 17-15' stroke='%237a5a32' stroke-width='4' stroke-linecap='round'/%3E%3Ccircle cx='34' cy='34' r='15' fill='%23499a4e'/%3E%3Ccircle cx='60' cy='24' r='17' fill='%235aab5b'/%3E%3Ccircle cx='86' cy='34' r='15' fill='%23499a4e'/%3E%3Ccircle cx='48' cy='44' r='12' fill='%2367b96a'/%3E%3Ccircle cx='74' cy='44' r='12' fill='%2367b96a'/%3E%3Cpath d='M40 74h40l8 16H32z' fill='%23355f8a'/%3E%3Crect x='30' y='72' width='60' height='6' rx='3' fill='%232a4d70'/%3E%3C/g%3E%3C/svg%3E");
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Be Vietnam Pro',system-ui,sans-serif;
  color:var(--ink);
  background:var(--white);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
ul{list-style:none}
.wrap{max-width:var(--max);margin:0 auto;padding:0 20px}
.serif{font-family:'Playfair Display',serif}

/* image placeholder (swap background-image with real photos later) */
.ph{
  background-color:#dfeadd;
  background-image:linear-gradient(135deg,#e9f2e6,#d6e6d3);
  position:relative;overflow:hidden;
}
.ph::after{
  content:"";position:absolute;inset:0;
  background:var(--bonsai) center/46% no-repeat;
  opacity:.85;
}

/* ============ TOP BAR ============ */
.topbar{background:var(--green-darkest);color:#dfe9df;font-size:13px}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;height:38px}
.topbar a{color:#dfe9df;transition:color .2s}
.topbar a:hover{color:#fff}
.topbar nav{display:flex;align-items:center;gap:22px}
.topbar .hot{color:#fff;font-weight:600}
.topbar .hot b{color:#ffd45e}

/* ============ HEADER ============ */
.header{background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50}
.header .wrap{display:flex;align-items:center;gap:26px;height:86px}
.logo{display:flex;align-items:center;gap:12px;flex-shrink:0}
.logo .mark{width:54px;height:54px;flex-shrink:0;background:var(--bonsai) center/contain no-repeat}
.logo .txt b{display:block;font-family:'Playfair Display',serif;font-weight:800;font-size:26px;color:var(--green);letter-spacing:1px;line-height:1}
.logo .txt span{display:block;font-size:11px;letter-spacing:2.5px;color:#6f8c6f;font-weight:600;margin-top:3px}

.mainnav{display:flex;align-items:center;gap:6px;margin-left:8px}
.mainnav>li{position:relative}
.mainnav>li>a{
  display:flex;align-items:center;gap:5px;padding:12px 13px;font-weight:600;font-size:14.5px;
  color:#3a423a;border-radius:6px;transition:color .2s;white-space:nowrap;
}
.mainnav>li>a:hover,.mainnav>li.active>a{color:var(--green)}
.mainnav>li.active>a{position:relative}
.mainnav>li.active>a::after{content:"";position:absolute;left:13px;right:13px;bottom:2px;height:2.5px;background:var(--green);border-radius:2px}
.caret{font-size:9px;opacity:.7}
.dropdown{
  position:absolute;top:100%;left:0;min-width:210px;background:#fff;
  border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow);
  padding:8px;opacity:0;visibility:hidden;transform:translateY(8px);transition:.18s;z-index:60;
}
.mainnav>li:hover .dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown a{display:block;padding:9px 12px;border-radius:6px;font-size:14px;color:#4a524a}
.dropdown a:hover{background:var(--green-soft);color:var(--green)}

.head-tools{display:flex;align-items:center;gap:16px;margin-left:auto}
.search{display:flex;align-items:center;border:1.5px solid var(--line);border-radius:24px;padding:8px 8px 8px 16px;width:230px}
.search input{border:none;outline:none;font-family:inherit;font-size:13.5px;width:100%;background:transparent}
.search button{border:none;background:none;cursor:pointer;color:#8a948a;font-size:15px;padding:0 4px}
.cart{position:relative;font-size:22px;color:#3a423a;cursor:pointer}
.cart .badge{position:absolute;top:-7px;right:-9px;background:var(--green-btn);color:#fff;font-size:10px;font-weight:700;width:17px;height:17px;border-radius:50%;display:grid;place-items:center}
.burger{display:none;font-size:24px;background:none;border:none;cursor:pointer;color:var(--green)}

/* ============ HERO ============ */
.hero{position:relative;overflow:hidden;background:#0c2c14}
.slides{position:relative;height:540px}
.slide{position:absolute;inset:0;opacity:0;transition:opacity .8s ease;display:grid;place-items:center}
.slide.on{opacity:1}
.slide-bg{position:absolute;inset:0;background-position:center;background-size:cover}
.slide-bg.s1{background-image:linear-gradient(120deg,rgba(15,40,20,.55),rgba(20,60,30,.25)),var(--bonsai),linear-gradient(135deg,#cfe3c7,#a9cda1)}
.slide-bg.s2{background-image:linear-gradient(120deg,rgba(15,40,20,.6),rgba(20,60,30,.3)),linear-gradient(135deg,#bcd6b3,#8fbe87)}
.slide-bg.s3{background-image:linear-gradient(120deg,rgba(15,40,20,.55),rgba(20,60,30,.25)),linear-gradient(135deg,#d3e6cb,#a3c99a)}
.slide-bg{background-repeat:no-repeat;background-position:center;background-size:cover, 30%, cover}
.hero-inner{position:relative;text-align:center;color:#fff;max-width:760px;padding:0 20px;text-shadow:0 2px 14px rgba(0,0,0,.35)}
.hero-inner h1{font-family:'Playfair Display',serif;font-weight:800;font-size:64px;letter-spacing:4px;line-height:1;color:#1f5e2c;text-shadow:0 2px 10px rgba(255,255,255,.4)}
.hero-inner h2{font-family:'Playfair Display',serif;font-weight:600;font-size:30px;letter-spacing:6px;margin-top:8px;color:#2d4d2f;text-shadow:0 2px 8px rgba(255,255,255,.4)}
.hero-inner .script{font-family:'Playfair Display',serif;font-style:italic;font-weight:600;font-size:26px;color:var(--gold);margin-top:14px;text-shadow:0 2px 8px rgba(255,255,255,.3)}

.hero-feats{display:flex;justify-content:center;gap:34px;margin:30px 0 28px;flex-wrap:wrap}
.hfeat{display:flex;flex-direction:column;align-items:center;gap:6px;color:#234d27;max-width:150px;text-shadow:none}
.hfeat .ic{width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,.85);display:grid;place-items:center;font-size:20px;color:var(--green)}
.hfeat-t{font-weight:700;font-size:14px;color:#1f5e2c}
.hfeat-s{font-size:11.5px;color:#3d5d3f;line-height:1.3}

.hero-cta{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:inherit;font-weight:600;font-size:15px;padding:14px 30px;border-radius:6px;cursor:pointer;border:2px solid transparent;transition:.2s;letter-spacing:.5px}
.btn-primary{background:var(--green-btn);color:#fff}
.btn-primary:hover{background:var(--green-btn-hover)}
.btn-ghost{background:transparent;color:#1f5e2c;border-color:#1f5e2c}
.btn-ghost:hover{background:#1f5e2c;color:#fff}

.hero-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:5;width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,.85);border:none;cursor:pointer;font-size:20px;color:#2d4d2f;display:grid;place-items:center;transition:.2s}
.hero-arrow:hover{background:#fff}
.hero-arrow.prev{left:20px}.hero-arrow.next{right:20px}
.hero-dots{position:absolute;bottom:22px;left:50%;transform:translateX(-50%);display:flex;gap:9px;z-index:5}
.hero-dots span{width:11px;height:11px;border-radius:50%;background:rgba(255,255,255,.55);cursor:pointer;transition:.2s}
.hero-dots span.on{background:var(--green-btn);transform:scale(1.1)}

/* ============ SECTION TITLES ============ */
.sec{padding:54px 0}
.sec-soft{background:var(--green-soft)}
.sec-title{text-align:center;font-family:'Playfair Display',serif;font-weight:700;font-size:30px;color:var(--green);margin-bottom:34px;display:flex;align-items:center;justify-content:center;gap:14px}
.sec-title::before,.sec-title::after{content:"🌿";font-size:18px;filter:saturate(.7)}

/* ============ CATEGORY STRIP ============ */
.catbar{padding:36px 0}
.cat-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:16px}
.cat{text-align:center}
.cat .thumb{aspect-ratio:1;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);transition:.22s}
.cat:hover .thumb{transform:translateY(-5px);box-shadow:var(--shadow-hover);border-color:#bcd6b3}
.cat p{margin-top:10px;font-style:italic;font-weight:500;font-size:14px;color:#3a4a3a}

/* ============ PRODUCTS ============ */
.prod-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:18px}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:.22s;display:flex;flex-direction:column}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-hover)}
.card .pic{aspect-ratio:1}
.card .body{padding:14px 12px 16px;text-align:center;display:flex;flex-direction:column;gap:8px;flex:1}
.card h3{font-size:15px;font-weight:600;color:#2d362d}
.card .price{color:var(--green);font-weight:700;font-size:16px}
.card .acts{display:flex;gap:8px;margin-top:auto}
.btn-sm{flex:1;font-size:13px;font-weight:600;padding:8px 6px;border-radius:6px;cursor:pointer;border:1.5px solid var(--green-btn);background:#fff;color:var(--green);transition:.2s;display:inline-flex;align-items:center;justify-content:center;gap:5px;font-family:inherit}
.btn-sm:hover{background:var(--green-soft)}
.btn-zalo{background:var(--zalo);color:#fff;border-color:var(--zalo)}
.btn-zalo:hover{background:#0056d6}

/* ============ ABOUT ============ */
.about-grid{display:grid;grid-template-columns:1fr 1fr 0.7fr;gap:28px;align-items:start}
.about-video{position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:4/3;box-shadow:var(--shadow);cursor:pointer}
.play{position:absolute;inset:0;margin:auto;width:62px;height:62px;border-radius:50%;background:rgba(255,255,255,.9);display:grid;place-items:center;font-size:22px;color:var(--green);transition:.2s}
.about-video:hover .play{transform:scale(1.08);background:#fff}
.about-text h2{font-family:'Playfair Display',serif;font-weight:700;font-size:26px;color:var(--green);line-height:1.25;margin-bottom:16px}
.about-text p{color:var(--muted);font-size:14.5px;margin-bottom:18px}
.about-list{display:grid;grid-template-columns:1fr 1fr;gap:12px 18px;margin-bottom:22px}
.about-list li{display:flex;align-items:flex-start;gap:9px;font-size:14px;color:#3a463a}
.about-list .chk{color:var(--green-btn);font-weight:700;flex-shrink:0}
.about-photos{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.about-photos .big{grid-column:1/3;aspect-ratio:16/8;border-radius:8px}
.about-photos .sm{aspect-ratio:1;border-radius:8px}

/* ============ COLLECTION ============ */
.coll-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
.coll{aspect-ratio:4/3;border-radius:var(--radius);box-shadow:var(--shadow);transition:.22s;cursor:pointer}
.coll:hover{transform:translateY(-5px);box-shadow:var(--shadow-hover)}

/* ============ NEWS ============ */
.news-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;margin-bottom:30px}
.post{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:.22s;display:flex;flex-direction:column}
.post:hover{transform:translateY(-5px);box-shadow:var(--shadow-hover)}
.post .pic{aspect-ratio:16/10}
.post .body{padding:14px 14px 18px}
.post .date{font-size:12px;color:#9aa49a;margin-bottom:6px}
.post h3{font-size:15px;font-weight:600;color:#2d362d;line-height:1.35;margin-bottom:8px}
.post p{font-size:13px;color:var(--muted);line-height:1.5}
.center{text-align:center}

/* ============ FOOTER ============ */
.footer{background:var(--green-dark);color:#cfe0cf;padding:50px 0 0;font-size:14px}
.foot-grid{display:grid;grid-template-columns:1.3fr 1fr .8fr 1.1fr;gap:34px;padding-bottom:40px}
.foot-logo{display:flex;align-items:center;gap:11px;margin-bottom:16px}
.foot-logo .mark{width:46px;height:46px;background:var(--bonsai) center/contain no-repeat;filter:brightness(1.4)}
.foot-logo b{font-family:'Playfair Display',serif;font-weight:800;font-size:22px;color:#fff;letter-spacing:1px;display:block;line-height:1}
.foot-logo span{font-size:10px;letter-spacing:2px;color:#a9c4a9;font-weight:600}
.footer p.desc{color:#a9c4a9;line-height:1.7;margin-bottom:18px}
.foot-social{display:flex;gap:10px}
.foot-social a{width:34px;height:34px;border-radius:7px;display:grid;place-items:center;font-size:15px;background:rgba(255,255,255,.1);color:#fff;transition:.2s}
.foot-social a:hover{background:var(--green-btn)}
.footer h4{color:#fff;font-size:16px;font-weight:700;margin-bottom:16px;letter-spacing:.5px}
.foot-grid ul li{margin-bottom:10px;color:#bcd2bc}
.foot-grid ul li a{transition:.2s}
.foot-grid ul li a:hover,.foot-contact li:hover{color:#fff}
.foot-contact li{display:flex;gap:9px;align-items:flex-start;margin-bottom:12px;color:#bcd2bc}
.foot-contact .ic{color:#8fd49a;flex-shrink:0}
.fanpage{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:10px;padding:14px}
.fan-head{display:flex;gap:11px;align-items:center;margin-bottom:12px}
.fan-head .av{width:46px;height:46px;border-radius:8px;background:#fff var(--bonsai) center/70% no-repeat}
.fan-head b{color:#fff;font-size:14px;display:block}
.fan-head span{font-size:12px;color:#a9c4a9}
.fan-btn{display:inline-flex;align-items:center;gap:7px;background:#1877f2;color:#fff;font-size:13px;font-weight:600;padding:8px 14px;border-radius:6px}
.foot-bottom{border-top:1px solid rgba(255,255,255,.13);padding:16px 0;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;color:#9bb59b;font-size:13px}
.foot-bottom nav{display:flex;gap:18px}
.foot-bottom nav a:hover{color:#fff}

/* ============ FLOATING BUTTONS ============ */
.floats{position:fixed;right:18px;bottom:24px;z-index:80;display:flex;flex-direction:column;gap:12px}
.fbtn{width:52px;height:52px;border-radius:50%;display:grid;place-items:center;cursor:pointer;border:none;color:#fff;box-shadow:0 6px 18px rgba(0,0,0,.22);transition:.2s;font-size:20px;position:relative}
.fbtn:hover{transform:scale(1.08)}
.fbtn.call{background:var(--green-btn)}
.fbtn.call::after{content:"";position:absolute;inset:-4px;border-radius:50%;border:2px solid var(--green-btn);opacity:.6;animation:ring 1.6s infinite}
.fbtn.call .lbl{position:absolute;top:-8px;font-size:8px;background:#fff;color:var(--green);padding:1px 6px;border-radius:10px;font-weight:700;white-space:nowrap}
.fbtn.zalo{background:var(--zalo);font-weight:700;font-size:13px}
.fbtn.up{background:var(--green-btn)}
@keyframes ring{0%{transform:scale(1);opacity:.6}100%{transform:scale(1.5);opacity:0}}

/* ============ RESPONSIVE ============ */
@media(max-width:1080px){
  .cat-grid{grid-template-columns:repeat(4,1fr)}
  .prod-grid{grid-template-columns:repeat(3,1fr)}
  .coll-grid{grid-template-columns:repeat(3,1fr)}
  .news-grid{grid-template-columns:repeat(3,1fr)}
  .about-grid{grid-template-columns:1fr 1fr;}
  .about-photos{grid-column:1/3}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:760px){
  .topbar{display:none}
  .header .wrap{height:68px;gap:14px}
  .search{display:none}
  .burger{display:block;order:3}
  .mainnav{display:none;position:absolute;top:68px;left:0;right:0;background:#fff;flex-direction:column;align-items:stretch;border-bottom:1px solid var(--line);box-shadow:var(--shadow);padding:8px}
  .mainnav.open{display:flex}
  .mainnav>li>a{padding:13px}
  .dropdown{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:none;border-left:2px solid var(--green-soft);margin-left:14px;display:none}
  .mainnav>li:hover .dropdown,.mainnav>li.open-sub .dropdown{display:block}
  .head-tools{margin-left:auto;gap:14px}
  .logo .txt b{font-size:21px}
  .slides{height:auto;min-height:520px}
  .slide{position:relative;display:none;padding:48px 0}
  .slide.on{display:grid}
  .hero-inner h1{font-size:42px}
  .hero-inner h2{font-size:22px;letter-spacing:3px}
  .hero-inner .script{font-size:20px}
  .hero-arrow{display:none}
  .cat-grid{grid-template-columns:repeat(3,1fr)}
  .prod-grid,.coll-grid,.news-grid{grid-template-columns:1fr 1fr}
  .about-grid{grid-template-columns:1fr}
  .about-photos{grid-column:auto}
  .foot-grid{grid-template-columns:1fr}
  .sec-title{font-size:24px}
}
@media(max-width:440px){
  .cat-grid{grid-template-columns:repeat(2,1fr)}
  .prod-grid,.coll-grid,.news-grid{grid-template-columns:1fr}
}
/* WordPress menu compatibility */
.mainnav .sub-menu{
  position:absolute;top:100%;left:0;min-width:210px;background:#fff;
  border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow);
  padding:8px;opacity:0;visibility:hidden;transform:translateY(8px);transition:.18s;z-index:60;
}
.mainnav>li:hover>.sub-menu{opacity:1;visibility:visible;transform:translateY(0)}
.mainnav .sub-menu a{display:block;padding:9px 12px;border-radius:6px;font-size:14px;color:#4a524a}
.mainnav .sub-menu a:hover{background:var(--green-soft);color:var(--green)}
.mainnav .menu-item-has-children>a::after{content:'▼';font-size:9px;opacity:.7;margin-left:5px}
.footer .menu{list-style:none;margin:0;padding:0}
.footer .menu li{margin-bottom:10px;color:#bcd2bc}
.footer .menu a::before{content:'› ';}
.post-full .entry-content{max-width:900px;margin:0 auto;color:var(--ink)}
@media(max-width:760px){
  .mainnav .sub-menu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:none;border-left:2px solid var(--green-soft);margin-left:14px;display:none}
  .mainnav>li.open-sub>.sub-menu{display:block}
}

/* ===== FULL WORDPRESS THEME EXTENSIONS ===== */
.site-logo-img{max-height:62px;width:auto;object-fit:contain;display:block}.footer-logo-img{max-height:58px}.mainnav .menu-item-has-children{position:relative}.mainnav .sub-menu{position:absolute;top:100%;left:0;min-width:220px;background:#fff;border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow);padding:8px;opacity:0;visibility:hidden;transform:translateY(8px);transition:.18s;z-index:60}.mainnav .menu-item-has-children:hover>.sub-menu{opacity:1;visibility:visible;transform:translateY(0)}.mainnav .sub-menu a{display:block;padding:9px 12px;border-radius:6px;font-size:14px;color:#4a524a}.mainnav .sub-menu a:hover{background:var(--green-soft);color:var(--green)}.screen-reader-text{position:absolute!important;clip:rect(1px,1px,1px,1px);width:1px;height:1px;overflow:hidden}.ts-page-hero{min-height:260px;background-size:cover;background-position:center;display:flex;align-items:center;color:#fff;text-align:center}.ts-page-hero .wrap{padding-top:55px;padding-bottom:55px}.ts-page-hero h1{font-family:'Playfair Display',serif;font-size:46px;line-height:1.15;margin-bottom:10px;color:#fff;text-shadow:0 2px 12px rgba(0,0,0,.25)}.ts-page-hero p{font-size:17px;max-width:760px;margin:0 auto;color:#eef6ee}.ts-content-wrap{max-width:920px}.entry-content{font-size:16px;color:#364036}.entry-content h2,.entry-content h3,.entry-content h4{font-family:'Playfair Display',serif;color:var(--green);line-height:1.25;margin:28px 0 14px}.entry-content p,.entry-content ul,.entry-content ol{margin-bottom:16px}.entry-content ul{list-style:disc;padding-left:22px}.entry-content ol{list-style:decimal;padding-left:22px}.entry-content a{color:var(--green);font-weight:600}.entry-content img{border-radius:10px;box-shadow:var(--shadow);height:auto}.ts-archive-grid{grid-template-columns:repeat(3,1fr)}.navigation.pagination{margin-top:30px;text-align:center}.nav-links{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}.page-numbers{display:inline-flex;min-width:38px;height:38px;align-items:center;justify-content:center;border:1px solid var(--line);border-radius:6px;background:#fff;color:var(--green);font-weight:600}.page-numbers.current,.page-numbers:hover{background:var(--green);color:#fff}.ts-term-filter{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:26px;justify-content:center}.ts-term-filter a{padding:9px 16px;border:1px solid var(--line);border-radius:99px;background:#fff;color:var(--green);font-weight:600;font-size:14px}.ts-term-filter a:hover{background:var(--green);color:#fff}.ts-product-card .pic{display:block;background-size:cover!important;background-position:center!important}.price del{color:#999;font-size:13px;margin-right:5px}.price strong{color:var(--green)}.product-single-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:34px;align-items:start}.product-gallery,.product-summary{background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);padding:18px}.product-main-img{display:block;aspect-ratio:1;border-radius:10px;background-size:cover;background-position:center;border:1px solid var(--line)}.product-thumbs{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin-top:12px}.product-thumbs a{aspect-ratio:1;border-radius:7px;border:1px solid var(--line);background-size:cover;background-position:center}.product-summary h2{font-family:'Playfair Display',serif;font-size:32px;color:var(--green);line-height:1.2;margin-bottom:12px}.single-price{font-size:24px;color:var(--green);font-weight:700;margin:12px 0}.single-price del{color:#999;font-size:17px;margin-right:10px}.product-meta{background:var(--green-soft);border-radius:10px;padding:14px 18px;margin:16px 0}.product-meta li{margin:7px 0}.product-cta{justify-content:flex-start;margin:18px 0}.spec-table{width:100%;border-collapse:collapse;margin-top:18px}.spec-table th,.spec-table td{border:1px solid var(--line);padding:10px;text-align:left}.spec-table th{width:35%;background:var(--green-soft);color:var(--green)}.product-content{margin-top:36px}.related-products{margin-top:42px}.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px}.contact-box{background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);padding:24px}.contact-box h2{font-family:'Playfair Display',serif;color:var(--green);margin-bottom:16px}.contact-list li{color:#364036}.map-box{margin-top:28px}.map-box iframe{width:100%;min-height:360px;border:0;border-radius:12px}.wpcf7 input,.wpcf7 textarea,.contact-box input,.contact-box textarea{width:100%;border:1px solid var(--line);border-radius:8px;padding:12px 14px;font-family:inherit;margin-bottom:12px}.wpcf7-submit,.contact-box button[type=submit],.contact-box input[type=submit]{background:var(--green-btn);color:#fff;border:none;border-radius:7px;padding:12px 20px;font-weight:700;cursor:pointer;width:auto}.ts-product-hero{min-height:210px;background:var(--green-dark)}
@media(max-width:900px){.ts-archive-grid{grid-template-columns:repeat(2,1fr)}.product-single-grid,.contact-grid{grid-template-columns:1fr}.ts-page-hero h1{font-size:34px}.mainnav .sub-menu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:none;display:none}.mainnav .menu-item-has-children:hover>.sub-menu{display:block}.site-logo-img{max-height:48px}}
@media(max-width:520px){.ts-archive-grid{grid-template-columns:1fr}.product-thumbs{grid-template-columns:repeat(4,1fr)}.product-summary h2{font-size:25px}.ts-page-hero h1{font-size:29px}}

/* ===== v2.3: category images + clean product images + lightbox ===== */
.ts-product-card .pic.has-img::after,
.product-main-img::after,
.product-thumbs a::after,
.coll::after,
.about-photos a::after{display:none!important;content:none!important}
.ts-product-card .pic.has-img{background-color:#eef5ec;border:0}
.ts-term-filter .ts-term-pill{display:inline-flex;align-items:center;gap:8px;padding:7px 14px 7px 8px}
.ts-term-filter .ts-term-pill span{width:34px;height:34px;border-radius:50%;background-size:cover;background-position:center;display:inline-block;flex:0 0 34px;border:1px solid rgba(20,60,30,.12)}
.about-photos a{display:block;border-radius:8px;background-size:cover;background-position:center;box-shadow:var(--shadow)}
.ts-lightbox{position:fixed;inset:0;z-index:99999;background:rgba(5,18,9,.92);display:none;align-items:center;justify-content:center;padding:24px;touch-action:none}
.ts-lightbox.on{display:flex}
.ts-lightbox-stage{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center;overflow:hidden}
.ts-lightbox-img{max-width:92vw;max-height:88vh;object-fit:contain;border-radius:8px;box-shadow:0 18px 60px rgba(0,0,0,.5);transition:transform .18s ease;cursor:zoom-in;user-select:none;-webkit-user-drag:none}
.ts-lightbox.zoomed .ts-lightbox-img{transform:scale(1.8);cursor:zoom-out}
.ts-lightbox-btn{position:absolute;z-index:2;border:none;background:rgba(255,255,255,.92);color:#0f3d1a;width:46px;height:46px;border-radius:50%;display:grid;place-items:center;font-size:28px;line-height:1;cursor:pointer;box-shadow:0 8px 24px rgba(0,0,0,.22)}
.ts-lightbox-close{top:18px;right:20px;font-size:30px}.ts-lightbox-prev{left:22px;top:50%;transform:translateY(-50%)}.ts-lightbox-next{right:22px;top:50%;transform:translateY(-50%)}.ts-lightbox-zoom{right:82px;top:18px;font-size:18px;font-weight:700}.ts-lightbox-count{position:absolute;left:24px;bottom:20px;color:#fff;background:rgba(0,0,0,.35);padding:6px 12px;border-radius:20px;font-size:14px}.ts-lightbox-help{position:absolute;right:24px;bottom:20px;color:rgba(255,255,255,.78);font-size:13px;background:rgba(0,0,0,.28);padding:6px 12px;border-radius:20px}
@media(max-width:760px){.ts-lightbox{padding:12px}.ts-lightbox-img{max-width:96vw;max-height:82vh}.ts-lightbox-btn{width:42px;height:42px}.ts-lightbox-prev{left:10px}.ts-lightbox-next{right:10px}.ts-lightbox-close{top:12px;right:12px}.ts-lightbox-zoom{top:12px;right:62px}.ts-lightbox-help{display:none}.ts-lightbox-count{left:14px;bottom:14px}}

/* v2.4: remove all tree placeholder icons from image areas */
.ph::after{display:none!important;content:none!important;background:none!important}
.ph,.no-img{background-color:#eef5ec!important;background-image:linear-gradient(135deg,#eef5ec,#dfeadd)!important}
.has-img::after,.pic[style]::after,.thumb[style]::after,.about-video[style]::after,.post .pic[style]::after{display:none!important;content:none!important}
.logo .mark,.foot-logo .mark,.fan-head .av{background-image:none!important;background:transparent!important}
.logo .mark:empty,.foot-logo .mark:empty{display:none!important}
.fan-head .av:empty{display:none!important}
.ts-empty{grid-column:1/-1;text-align:center;background:#fff;border:1px dashed var(--line);border-radius:12px;padding:24px;color:var(--muted)}
.about-video{display:block;background-size:cover;background-position:center;text-decoration:none}
.about-video.no-img{min-height:320px;background:linear-gradient(135deg,#eef5ec,#dfeadd)}
.ts-video-modal{position:fixed;inset:0;background:rgba(0,0,0,.86);z-index:99999;display:none;align-items:center;justify-content:center;padding:24px}
.ts-video-modal.on{display:flex}
.ts-video-frame{position:relative;width:min(1100px,94vw);aspect-ratio:16/9;background:#000;border-radius:12px;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.35)}
.ts-video-frame iframe,.ts-video-frame video{width:100%;height:100%;border:0;display:block;background:#000}
.ts-video-close{position:absolute;top:18px;right:20px;width:42px;height:42px;border-radius:50%;border:0;background:#fff;color:#111;font-size:28px;line-height:42px;cursor:pointer;z-index:2}
@media(max-width:760px){.about-video.no-img{min-height:230px}.ts-video-modal{padding:12px}.ts-video-close{top:10px;right:10px}}

/* ===== v2.5: even category grid, cleaner icons, breadcrumb ===== */
.catbar .wrap{max-width:1240px}
.cat-grid{
  display:grid!important;
  grid-template-columns:repeat(auto-fit,minmax(170px,1fr))!important;
  gap:22px!important;
  align-items:start!important;
  justify-content:stretch!important;
}
.cat{display:block;width:100%;text-align:center}
.cat .thumb{width:100%;aspect-ratio:16/10!important;border-radius:12px;background-size:cover!important;background-position:center!important;overflow:hidden}
.cat p{font-size:16px;line-height:1.35;min-height:44px;display:flex;align-items:center;justify-content:center;text-align:center}
@media(min-width:981px){.cat-grid:has(.cat:nth-child(5):last-child){grid-template-columns:repeat(5,1fr)!important}}
@media(max-width:980px){.cat-grid{grid-template-columns:repeat(3,1fr)!important}}
@media(max-width:560px){.cat-grid{grid-template-columns:repeat(2,1fr)!important;gap:14px!important}.cat p{font-size:14px;min-height:auto}}

.hfeat .ic{background:rgba(255,255,255,.92)!important;border:1px solid rgba(31,122,52,.22);box-shadow:0 6px 18px rgba(20,60,30,.08)}
.hfeat .ic svg{width:25px;height:25px;display:block;fill:none;stroke:currentColor;stroke-width:3;stroke-linecap:round;stroke-linejoin:round}
.sec-title::before,.sec-title::after{content:""!important;width:22px;height:22px;background:no-repeat center/contain url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64' fill='none' stroke='%231c6b32' stroke-width='5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M50 12C29 14 16 25 14 46c17 1 32-10 36-34Z'/%3E%3Cpath d='M14 46c12-10 22-18 36-34'/%3E%3C/svg%3E")!important;filter:none!important;display:inline-block}
.play{width:78px!important;height:78px!important;background:rgba(255,255,255,.94)!important;color:#1f7a34!important;box-shadow:0 12px 34px rgba(0,0,0,.22)!important;border:1px solid rgba(255,255,255,.5)}
.play svg{width:78px;height:78px;display:block;fill:currentColor;stroke:none}.play svg path{fill:#1f7a34}.play svg circle{fill:#fff}
.about-video::before{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(0,0,0,.18),rgba(0,0,0,.02));pointer-events:none}.about-video .play{z-index:2}.about-video:hover .play{transform:translateZ(0) scale(1.06)!important}

.ts-breadcrumb{background:#fff;border-bottom:1px solid var(--line);font-size:13px;color:#748074}
.ts-breadcrumb .wrap{padding-top:10px;padding-bottom:10px}
.ts-breadcrumb ol{display:flex;align-items:center;gap:8px;list-style:none;margin:0;padding:0;white-space:nowrap;overflow:auto;-webkit-overflow-scrolling:touch}
.ts-breadcrumb li{display:flex;align-items:center;gap:8px;flex:0 0 auto}.ts-breadcrumb li+li::before{content:"/";color:#a4afa4}.ts-breadcrumb a{color:var(--green);font-weight:600}.ts-breadcrumb span{color:#5d685d}.ts-breadcrumb a:hover{text-decoration:underline}

.no-img,.ph{background-image:linear-gradient(135deg,#f6faf4,#e9f2e6)!important}.no-img::before,.ph::before{display:none!important;content:none!important}

/* v2.6 - category import layout */
.catbar .wrap{max-width:1240px;}
.cat-grid{width:100%;grid-template-columns:repeat(8,minmax(0,1fr))!important;justify-content:stretch!important;}
.cat .thumb.has-img{background-size:contain!important;background-repeat:no-repeat!important;background-position:center!important;background-color:#fff!important;}
.cat .thumb{aspect-ratio:1.45/1;}
@media(max-width:1180px){.cat-grid{grid-template-columns:repeat(4,minmax(0,1fr))!important;}}
@media(max-width:680px){.cat-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important;}}

/* ===== Footer v2 - premium dark green layout ===== */
.footer-v2{position:relative;background:#003018;color:#d9ead9;padding:68px 0 0;font-size:15px;overflow:hidden;background-image:radial-gradient(circle at 18% 0,rgba(166,198,118,.12),transparent 34%),linear-gradient(135deg,#013e20 0%,#002713 70%)}
.footer-v2::before,.footer-v2::after{content:"";position:absolute;width:330px;height:330px;background:radial-gradient(circle,rgba(255,255,255,.05),transparent 58%);opacity:.45;pointer-events:none}.footer-v2::before{left:-120px;top:20px}.footer-v2::after{right:-80px;bottom:10px}.footer-ornament{position:absolute;top:0;left:0;right:0;height:26px;display:flex;align-items:flex-start;justify-content:center}.footer-ornament::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(199,183,103,.8),transparent)}.footer-ornament span{width:18px;height:18px;margin-top:-1px;border-left:1px solid rgba(199,183,103,.85);border-bottom:1px solid rgba(199,183,103,.85);transform:rotate(-45deg);background:#003018}
.footer-wrap{position:relative;z-index:1}.foot-grid-v2{display:grid;grid-template-columns:1.25fr 1.22fr .72fr 1.25fr;gap:62px;align-items:start;padding-bottom:46px}.footer-v2 h4{font-size:18px;line-height:1.2;margin:0 0 28px;color:#fff;font-weight:800;letter-spacing:1px;position:relative}.footer-v2 h4::after{content:"";display:block;width:38px;height:2px;background:#9abb65;margin-top:13px;border-radius:2px}.foot-logo-v2{display:flex;align-items:center;gap:18px;margin-bottom:22px;color:#fff}.footer-bonsai-logo{width:86px;height:70px;color:#f3f7ea;display:block;flex:0 0 auto}.footer-bonsai-logo svg{width:100%;height:100%;display:block}.foot-logo-v2 .footer-logo-img{max-height:90px;max-width:260px;object-fit:contain}.foot-logo-text b{font-family:'Be Vietnam Pro',system-ui,sans-serif;font-size:35px;line-height:1;font-weight:800;letter-spacing:2px;color:#fff;display:block}.foot-logo-text span{display:block;margin-top:9px;color:#cfe3b6;font-size:15px;font-weight:700;letter-spacing:2px}.footer-v2 p.desc{font-size:16px;line-height:1.82;color:#dceadb;max-width:420px;margin:0 0 26px}.foot-social-v2{display:flex;gap:18px;align-items:center}.foot-social-v2 a{width:52px;height:52px;border-radius:8px;display:grid;place-items:center;border:1px solid rgba(171,206,112,.55);background:rgba(255,255,255,.055);box-shadow:0 8px 20px rgba(0,0,0,.16);transition:.22s;color:#fff}.foot-social-v2 a svg{width:28px;height:28px;display:block}.foot-social-v2 .social-fb{background:linear-gradient(180deg,#2684ff,#075bc5)}.foot-social-v2 .social-yt{background:linear-gradient(180deg,#ff3333,#c90000)}.foot-social-v2 .social-tt{background:#050505}.foot-social-v2 .social-zalo{color:#1788ff;background:#fff}.foot-social-v2 a:hover{transform:translateY(-4px);box-shadow:0 12px 26px rgba(0,0,0,.24)}.foot-contact-v2{margin:0;padding:0;list-style:none}.foot-contact-v2 li{display:grid;grid-template-columns:32px 1fr;gap:14px;align-items:start;margin-bottom:18px;color:#e3eee1;font-size:16px;line-height:1.55}.foot-contact-v2 .ic{width:26px;height:26px;color:#a9cf70;display:block;margin-top:1px}.foot-contact-v2 .ic svg{width:100%;height:100%;display:block}.foot-contact-v2 strong{color:#fff;font-weight:800}.footer-v2 .menu{list-style:none;margin:0;padding:0}.footer-v2 .menu li{margin-bottom:16px;color:#e3eee1;font-size:16px}.footer-v2 .menu a{position:relative;display:inline-flex;align-items:center;gap:9px;color:#e3eee1;transition:.2s}.footer-v2 .menu a::before{content:"";width:12px;height:12px;flex:0 0 12px;background:currentColor;clip-path:polygon(0 0,100% 50%,0 100%,30% 50%)}.footer-v2 .menu a:hover{color:#a9cf70;transform:translateX(4px)}.fanpage-v2{display:grid;grid-template-columns:130px 1fr;gap:20px;background:#fff;border-radius:10px;padding:24px;box-shadow:0 14px 34px rgba(0,0,0,.18);color:#1f2b20;min-height:150px;align-items:center}.fan-avatar{height:112px;border:1px solid #e6e9e2;border-radius:7px;display:grid;place-items:center;color:#0d5129;background:#fff}.fan-avatar svg{width:82px;height:70px}.fan-avatar img{max-width:100%;max-height:100%;object-fit:contain}.fan-info b{display:block;color:#15251a;font-size:17px;line-height:1.32;margin-bottom:9px}.fan-info span{display:block;color:#546154;font-size:15px;margin-bottom:18px}.fan-btn-v2{display:inline-flex;align-items:center;gap:10px;background:#f7f8f7;border:1px solid #d9ded8;border-radius:7px;color:#243024;font-weight:800;padding:10px 18px;line-height:1;transition:.2s}.fan-btn-v2 svg{width:21px;height:21px;color:#1877f2}.fan-btn-v2:hover{background:#edf4ff;border-color:#c8dcff}.foot-bottom-v2{border-top:1px solid rgba(154,187,101,.28);padding:24px 0;display:flex;justify-content:space-between;align-items:center;gap:18px;color:#d8e5d6;font-size:15px}.foot-policy-nav{display:flex;gap:0;align-items:center;flex-wrap:wrap}.foot-policy-nav a{color:#d8e5d6;padding:0 18px;border-right:1px solid rgba(216,229,214,.45);line-height:1}.foot-policy-nav a:first-child{padding-left:0}.foot-policy-nav a:last-child{border-right:0;padding-right:0}.foot-policy-nav a:hover{color:#fff}
@media(max-width:1180px){.foot-grid-v2{grid-template-columns:1fr 1fr;gap:42px}.fanpage-v2{max-width:560px}}
@media(max-width:760px){.footer-v2{padding-top:48px}.foot-grid-v2{grid-template-columns:1fr;gap:34px}.foot-logo-v2{align-items:flex-start}.foot-logo-text b{font-size:28px}.footer-bonsai-logo{width:68px;height:58px}.foot-social-v2 a{width:46px;height:46px}.fanpage-v2{grid-template-columns:94px 1fr;padding:16px}.fan-avatar{height:88px}.fan-avatar svg{width:64px;height:58px}.foot-bottom-v2{align-items:flex-start;flex-direction:column}.foot-policy-nav a{padding:0 10px 0 0;margin-right:10px}.footer-v2 h4{margin-bottom:20px}}
@media(max-width:430px){.fanpage-v2{grid-template-columns:1fr}.fan-avatar{max-width:130px}.foot-contact-v2 li{grid-template-columns:28px 1fr}.foot-logo-v2{gap:12px}.foot-logo-text b{font-size:24px}.foot-logo-text span{font-size:12px}}

/* ===== Footer v2.8: cân lại cỡ chữ đồng bộ với toàn site ===== */
.footer-v2{
  padding-top:54px;
  font-size:13.5px;
}
.foot-grid-v2{
  grid-template-columns:1.18fr 1.12fr .72fr 1.22fr;
  gap:46px;
  padding-bottom:34px;
}
.footer-v2 h4{
  font-size:14.5px;
  margin-bottom:19px;
  letter-spacing:.7px;
  font-weight:800;
}
.footer-v2 h4::after{
  width:30px;
  height:1.5px;
  margin-top:9px;
}
.foot-logo-v2{
  gap:13px;
  margin-bottom:15px;
}
.footer-bonsai-logo{
  width:64px;
  height:54px;
}
.foot-logo-v2 .footer-logo-img{
  max-height:66px;
  max-width:220px;
}
.foot-logo-text b{
  font-size:28px;
  letter-spacing:1.4px;
}
.foot-logo-text span{
  margin-top:6px;
  font-size:12px;
  letter-spacing:1.45px;
}
.footer-v2 p.desc{
  font-size:13.5px;
  line-height:1.72;
  max-width:360px;
  margin-bottom:18px;
}
.foot-social-v2{
  gap:12px;
}
.foot-social-v2 a{
  width:40px;
  height:40px;
  border-radius:7px;
}
.foot-social-v2 a svg{
  width:22px;
  height:22px;
}
.foot-contact-v2 li{
  grid-template-columns:24px 1fr;
  gap:10px;
  margin-bottom:12px;
  font-size:13.5px;
  line-height:1.55;
}
.foot-contact-v2 .ic{
  width:20px;
  height:20px;
  margin-top:1px;
}
.foot-contact-v2 strong{
  font-weight:700;
}
.footer-v2 .menu li{
  margin-bottom:11px;
  font-size:13.5px;
  line-height:1.45;
}
.footer-v2 .menu a{
  gap:7px;
}
.footer-v2 .menu a::before{
  width:9px;
  height:9px;
  flex-basis:9px;
}
.fanpage-v2{
  grid-template-columns:96px 1fr;
  gap:15px;
  padding:17px;
  min-height:118px;
  border-radius:9px;
}
.fan-avatar{
  height:82px;
  border-radius:6px;
}
.fan-avatar svg{
  width:60px;
  height:54px;
}
.fan-info b{
  font-size:13.8px;
  line-height:1.3;
  margin-bottom:6px;
}
.fan-info span{
  font-size:12.5px;
  margin-bottom:11px;
}
.fan-btn-v2{
  gap:7px;
  padding:8px 12px;
  border-radius:6px;
  font-size:13px;
  font-weight:700;
}
.fan-btn-v2 svg{
  width:17px;
  height:17px;
}
.foot-bottom-v2{
  padding:16px 0;
  font-size:13px;
}
.foot-policy-nav a{
  padding:0 13px;
}
@media(max-width:1180px){
  .foot-grid-v2{grid-template-columns:1fr 1fr;gap:34px}
}
@media(max-width:760px){
  .footer-v2{padding-top:42px;font-size:13px}
  .foot-grid-v2{gap:28px;padding-bottom:28px}
  .footer-v2 h4{font-size:14px;margin-bottom:16px}
  .foot-logo-text b{font-size:24px}
  .foot-logo-text span{font-size:11.5px}
  .footer-bonsai-logo{width:58px;height:50px}
  .footer-v2 p.desc,.foot-contact-v2 li,.footer-v2 .menu li{font-size:13px}
  .foot-social-v2 a{width:38px;height:38px}
  .fanpage-v2{grid-template-columns:82px 1fr;padding:14px}
  .fan-avatar{height:74px}
  .fan-avatar svg{width:54px;height:48px}
  .foot-bottom-v2{font-size:12.5px}
}
@media(max-width:430px){
  .fanpage-v2{grid-template-columns:1fr}
  .fan-avatar{max-width:108px;height:76px}
  .foot-logo-v2{gap:10px}
  .foot-logo-text b{font-size:22px}
}
