
:root{
    --ink:#15221b;
    --muted:#68736c;
    --line:#d8ddd8;
    --paper:#f7f8f6;
    --soft:#edf3ef;
    --brand:#1f4d3a;
    --brand-light:#2f6b52;
    --brand-deep:#173629;
    --white:#ffffff;
    --dark:#173629;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
    margin:0;
    font-family:Inter,Arial,sans-serif;
    color:var(--ink);
    background:var(--paper);
    font-size:14px;
}
a{text-decoration:none;color:inherit}
img{display:block;width:100%;object-fit:cover}
.topbar {
    background: #173629;
    color: #fff;
    text-align: center;
    padding: 8px 20px;
    font-size: 12px;
    white-space: nowrap;
    letter-spacing: .2px;
    overflow: hidden;
    text-overflow: ellipsis;
}
.header{
    position:sticky;
    top:0;
    z-index:50;
    background:rgba(250,248,243,.94);
    backdrop-filter:blur(12px);
    border-bottom:1px solid var(--line);
}
.nav{
    max-width:1260px;
    margin:auto;
    height:64px;
    padding:0 24px;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:24px;
}
.logo{
    font-family:"Playfair Display",serif;
    font-size:23px;
    font-weight:500;
    letter-spacing:.25px;
}
.logo span{color:var(--brand)}
.menu{
    display:flex;
    gap:24px;
    align-items:center;
    font-size:13px;
    font-weight:500;
    text-transform:none;
    letter-spacing:.25px;
}
a.logo img {
    height: 39px;
}
.menu a{padding:24px 0;border-bottom:2px solid transparent;font-weight: 400;}
.menu a:hover{border-color:var(--brand)}
.nav-actions{display:flex;gap:10px;align-items:center}
.icon-btn{
    width:36px;
    height:36px;
    border:1px solid var(--line);
    background:#fff;
    display:grid;
    place-items:center;
    font-size:15px;
}
.mobile-toggle{display:none}
.container{
    max-width:1260px;
    margin:auto;
    padding:0 24px;
}
.btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:44px;
    padding:0 20px;
    border:1px solid var(--brand);
    background:var(--brand);
    color:#fff;
    font-weight:500;
    font-size:13px;
    text-transform:none;
    letter-spacing:.25px;
}
.btn:hover{background:#2f6b52}
.btn.outline{background:transparent;color:var(--dark)}
.btn.outline:hover{background:var(--brand);color:#fff}
.kicker{
    font-size:11px;
    font-weight:500;
    text-transform:none;
    color:var(--brand);
}
.section{padding:20px 0}
.section-head{
    display:flex;
    justify-content:space-between;
    align-items:flex-end;
    gap:28px;
    margin-bottom:26px;
}
.section-head h2{
    font-family:"Playfair Display",serif;
    font-size:32px;
    line-height:1.05;
    margin:6px 0 0;
}
.section-head p{
    margin:0;
    color:var(--muted);
    max-width:520px;
    line-height:1.55;
}
.grid-4{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:18px;
}
.product-card{
    background:#fff;
    border:1px solid var(--line);
    transition:.2s;
}
.product-card:hover{
    transform:translateY(-3px);
    box-shadow:0 16px 34px rgba(0,0,0,.08);
}
.product-media{
    position:relative;
    aspect-ratio:6/9;
    background:#eee;
}
.badge{
    position:absolute;
    top:10px;
    left:10px;
    background:#fff;
    border:1px solid var(--line);
    padding:6px 9px;
    font-size:10px;
    font-weight:500;
    text-transform:none;
    letter-spacing:.25px;
}
.wish {
    position: absolute;
    top: 10px;
    right: 10px;
    width: 32px;
    height: 32px;
    border: 1px solid #d8ddd800;
    background: #ffffff00;
    font-size: 16px;
}
.product-info{padding:13px}
.product-info h3{
    margin:0 0 7px;
    font-size:14px;
    line-height:1.35;
}
.price{
    display:flex;
    gap:8px;
    align-items:center;
    font-weight:500;
    font-size:13px;
}
.price del{color:#aaa;font-weight:500}
.swatches{display:flex;gap:6px;margin-top:10px}
.swatch{
    width:14px;
    height:14px;
    border:1px solid #ccc;
}
.breadcrumb{
    padding:18px 0;
    color:var(--muted);
    font-size:13px;
}
.page-title{
    padding:28px 0 22px;
    border-bottom:1px solid var(--line);
    margin-bottom:26px;
}
.page-title h1{
    font-family:"Playfair Display",serif;
    font-size:40px;
    line-height:1.02;
    margin:0 0 10px;
}
.page-title p{
    color:var(--muted);
    max-width:720px;
    line-height:1.6;
    margin:0;
}
.footer{
    background:#173629;
    color:#fff;
}
.footer-grid {
    display: grid;
    grid-template-columns: .6fr 1fr;
    gap: 66px;
    padding: 50px 24px 20px 24px;
}
.fotter_shop {
    display: grid;
    grid-template-columns: 1.2fr 1fr 1.6fr;
    margin-top: 55px;
    gap: 20px;
}
.footer h4{margin:0 0 13px;font-size:13px;text-transform:none;letter-spacing:.8px}
.footer p,.footer a{
    color:#cfcfcf;
    line-height:1.75;
    font-size:13px;
}.ftshop_items p.shop_cat {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px 0px;
}
.newsletter {
    display: flex;
    border: 1px solid #ffffff7a;
    margin-top: 16px;
    height: 45px;
}
.newsletter input{
    flex:1;
    border:0;
    outline:0;
    background:transparent;
    color:#fff;
    padding:0 12px;
}
.newsletter button{
    border:0;
    padding:0 16px;
    font-weight:500;
}
.copyright {
    border-top: 1px solid #ffffff0d;
    padding: 16px 24px;
    text-align: center;
    color: #fffcfc80;
    font-size: 10px;
}
@media(max-width:980px){
    .menu{display:none}
    .mobile-toggle{display:grid}
    .grid-4{grid-template-columns:repeat(2,1fr)}
    .footer-grid{grid-template-columns: 0.5fr 1fr;}
    .section-head p{margin-top:8px;display: none;}
    .fotter_shop {
        display: grid;
        grid-template-columns: 1fr 1fr 1fr 1fr;
        gap: 15px;
        margin-top: 55px;
    }
}
@media(max-width:620px){
    body{font-size:13px}
    .nav{height:58px;padding:0 14px}
    .logo{height: 30px;}
    .hide-sm{display:none}
    .container{padding:0 14px}
    .section{padding: 20px 0 5px 0;}
    .section-head h2,.page-title h1{font-size:20px}
    .grid-4{gap:10px}
    .product-info{padding:10px}
    .footer-grid{grid-template-columns:1fr;padding-top: 0px;margin-bottom: 17px;gap: 10px;}
    .benefits {
        grid-template-columns: repeat(2,1fr);
    }
    .product-info h3 {
        font-size: 12.8px;
    }
    .category-content h3 {
        font-size: 18px !important;
    }
    .category-head {
        margin-bottom: 15px;
    }
    .collection-feature-grid {
        gap: 8px;
    }
    .fotter_shop {
        grid-template-columns: 1fr 1fr !important;
        display: grid;
        gap: 5px;
        margin-top: 10px;
    }
    .ftshop_items p.shop_cat {
        display: grid;
        grid-template-columns: 1fr;
        gap: 3px 0px;
    }
    .nhan_thong_bao{
        grid-column: 1 / -1;
    }
}


/* Green premium refinement */
.topbar{background:var(--brand-deep)}
.header{background:rgba(247,248,246,.95)}
.logo span,.kicker{color:var(--brand)}
.btn{background:var(--brand);border-color:var(--brand);font-weight:500}
.btn:hover{background:var(--brand-light);border-color:var(--brand-light)}
.btn.outline{color:var(--brand);border-color:var(--brand)}
.btn.outline:hover{background:var(--brand);color:#fff}
.footer{background:var(--brand-deep)}
.menu a:hover{border-color:var(--brand)}
.product-card:hover{box-shadow:0 14px 30px rgba(23,54,41,.10)}
.badge{color:var(--brand);font-weight:500}
.product-info h3{font-weight:500}
.price{font-weight:500}

.logo.foter_lg img {
    height: 100%;
    width: auto;
}.logo.foter_lg {
    height: 39px;
}
.grid-5 {
    display: grid;
    grid-template-columns: repeat(5,1fr);
    gap: 18px;
}@media (max-width: 620px) {
    a.logo img {
        height: 30px;
        margin-top: 2px;
    }
}
