/*
 * Blue Sea 2026 — Theme stylesheet
 * Auto-generated from static demo (vi/*.html) via extract-static-css.py
 * Brand DNA tokens are defined in theme.json — referenced via var(--wp--preset--color--*).
 */

/* Reset + base box-sizing */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-tap-highlight-color:transparent;overflow-x:hidden;}
body{overflow-x:hidden;width:100%;}
img{max-width:100%;height:auto;display:block;}


/* Token aliases — static demo uses --cream/--sage/etc. Map to theme.json presets so both work. */
:root{
  --cream:  var(--wp--preset--color--cream);
  --linen:  var(--wp--preset--color--linen);
  --sage:   var(--wp--preset--color--sage);
  --forest: var(--wp--preset--color--forest);
  --pine:   var(--wp--preset--color--pine);
  --anchor: var(--wp--preset--color--anchor);
  --sky:    var(--wp--preset--color--sky);
  --sun:    var(--wp--preset--color--sun);
  --max-w: 1200px;
  --pad-x: 5%;
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
body{font-family:'Montserrat',sans-serif;font-weight:400;font-size:15px;line-height:1.65;color:var(--pine);background:var(--cream);overflow-x:hidden;width:100%;}
img{max-width:100%;height:auto;display:block;}
h1,h2,h3,h4{font-family:'Fraunces',serif;}
h1{font-weight:300;font-style:italic;font-size:clamp(32px,6.4vw,60px);line-height:1.02;letter-spacing:-0.02em;color:var(--anchor);}
h2{font-weight:500;font-size:clamp(24px,4.6vw,40px);line-height:1.08;color:var(--anchor);}
h3{font-weight:500;font-size:clamp(17px,2.4vw,22px);line-height:1.25;color:var(--pine);}
h4{font-weight:400;font-style:italic;font-size:clamp(16px,2vw,20px);line-height:1.4;color:var(--forest);}
p{max-width:65ch;}
a{color:var(--anchor);text-decoration:none;}
section{padding:72px 0;}
.eyebrow{font-family:'Montserrat';font-weight:600;font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--forest);opacity:.85;display:block;margin-bottom:10px;}
.section-divider{width:40px;height:2px;background:var(--sage);margin-bottom:18px;}
@keyframes fadeUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.1)}}
.fade-up{opacity:0;transform:translateY(28px);transition:opacity .7s cubic-bezier(.4,0,.2,1),transform .7s cubic-bezier(.4,0,.2,1);}
.fade-up.visible{opacity:1;transform:translateY(0);}
.fade-up.visible .stagger-1{animation:fadeUp .6s .1s both}
.fade-up.visible .stagger-2{animation:fadeUp .6s .2s both}
.fade-up.visible .stagger-3{animation:fadeUp .6s .3s both}
.fade-up.visible .stagger-4{animation:fadeUp .6s .4s both}
header{position:sticky;top:0;z-index:200;background:rgba(250,245,234,.96);backdrop-filter:blur(14px);padding:10px 0;}
/* Border only on the inner site-header; the FSE template-part also renders a
   <header> wrapper, so a bare `header{}` border would draw a double line. */
.site-header{border-bottom:1px solid rgba(183,194,166,.4);}
header.wp-block-template-part{border-bottom:none;background:none;backdrop-filter:none;padding:0;}
.nav-inner{display:flex;align-items:center;justify-content:space-between;}
.logo-img{height:38px;}
.nav-links{display:flex;gap:24px;align-items:center;}
.nav-links>li{list-style:none;position:relative;}
.nav-links a,.nav-links .nav-trigger{font-family:'Montserrat';font-weight:500;font-size:13px;color:var(--pine);transition:color .2s;cursor:pointer;background:none;border:none;display:inline-flex;align-items:center;gap:5px;padding:6px 0;}
.nav-links a:hover,.nav-links .nav-trigger:hover{color:var(--anchor);}
.nav-trigger::after{content:"";width:7px;height:7px;border-right:1.5px solid currentColor;border-bottom:1.5px solid currentColor;transform:rotate(45deg) translate(-2px,-2px);transition:transform .25s;}
.nav-item.open .nav-trigger::after{transform:rotate(-135deg) translate(-2px,-2px);}
.dropdown{position:absolute;top:100%;left:-14px;min-width:220px;background:var(--cream);border:1px solid rgba(183,194,166,.4);border-radius:10px;padding:10px 0;box-shadow:0 16px 40px rgba(63,79,54,.14);opacity:0;visibility:hidden;transform:translateY(8px);transition:all .25s;pointer-events:none;}
.nav-item:hover .dropdown,.nav-item.open .dropdown{opacity:1;visibility:visible;transform:translateY(0);pointer-events:auto;}
.dropdown a{display:block;padding:9px 18px;font-size:13px;font-weight:400;color:var(--pine);}
.dropdown a:hover{background:var(--linen);color:var(--anchor);}
.btn-nav{background:var(--anchor);color:var(--cream)!important;padding:9px 18px;border-radius:6px;font-weight:600;font-size:12px;transition:background .2s,transform .15s;}
.btn-nav:hover{background:var(--pine);transform:scale(1.02);}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px;}
.hamburger span{display:block;width:22px;height:2px;background:var(--pine);border-radius:2px;transition:all .3s;}
.hamburger.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px);}
.hamburger.active span:nth-child(2){opacity:0;}
.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px);}
.page-hero{padding:clamp(56px,8vw,112px) 0 clamp(40px,5vw,72px);background:var(--linen);}
.page-hero .eyebrow{margin-bottom:14px;}
.page-hero h1{max-width:18ch;margin-bottom:18px;}
.page-hero h1 em{font-style:italic;color:var(--forest);}
.page-hero p.lead{max-width:54ch;font-size:16px;color:var(--pine);}
.breadcrumb{font-size:12px;color:var(--pine);opacity:.7;margin-bottom:18px;}
.breadcrumb a{color:var(--pine);}
.breadcrumb a:hover{color:var(--anchor);}
.breadcrumb span{margin:0 6px;}
.story-section{background:var(--cream);}
.story-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start;margin-top:32px;}
.story-text p{font-size:15px;margin-bottom:16px;color:var(--pine);}
.story-text p:first-of-type{font-family:'Fraunces';font-size:20px;font-style:italic;color:var(--forest);line-height:1.5;}
.story-img{border-radius:16px;overflow:hidden;box-shadow:0 20px 48px rgba(63,79,54,.14);}
.story-img img{width:100%;aspect-ratio:4/3;object-fit:cover;filter:saturate(.85);}
.timeline{margin-top:48px;position:relative;padding-left:32px;}
.timeline::before{content:"";position:absolute;left:9px;top:8px;bottom:8px;width:2px;background:var(--sage);}
.timeline-item{position:relative;margin-bottom:24px;}
.timeline-item::before{content:"";position:absolute;left:-30px;top:6px;width:14px;height:14px;border-radius:50%;background:var(--cream);border:3px solid var(--sun);}
.timeline-year{font-family:'Fraunces';font-style:italic;font-size:22px;color:var(--anchor);margin-bottom:4px;}
.timeline-item p{font-size:14px;color:var(--pine);opacity:.85;}
.values-section{background:var(--linen);}
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:36px;}
.value-card{background:var(--cream);border-radius:14px;padding:32px 26px;border-top:3px solid var(--sage);transition:transform .4s,box-shadow .4s;}
.value-card:hover{transform:translateY(-4px);box-shadow:0 16px 36px rgba(63,79,54,.14);border-top-color:var(--sun);}
.value-icon{width:36px;height:36px;color:var(--forest);margin-bottom:16px;}
.value-card h3{color:var(--anchor);margin-bottom:10px;}
.value-card p{font-size:13.5px;color:var(--pine);opacity:.88;line-height:1.65;}
.factory-section{background:var(--pine);color:var(--cream);}
.factory-section .eyebrow{color:var(--sage);}
.factory-section h2{color:var(--cream);}
.factory-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;margin-top:32px;}
.factory-img{border-radius:16px;overflow:hidden;box-shadow:0 24px 56px rgba(0,0,0,.3);}
.factory-img img{width:100%;aspect-ratio:4/3;object-fit:cover;filter:saturate(.8) brightness(.95);}
.factory-text p{color:rgba(250,245,234,.82);font-size:15px;margin-bottom:14px;}
.factory-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:28px;}
.factory-stat .num{font-family:'Fraunces';font-style:italic;font-weight:500;font-size:38px;color:var(--sun);line-height:1;}
.factory-stat .label{font-size:12px;color:rgba(250,245,234,.7);margin-top:6px;letter-spacing:.04em;}
.certs-section{background:var(--cream);}
.certs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:36px;}
.cert-card{background:var(--linen);border-radius:14px;padding:28px 22px;text-align:center;transition:transform .4s,box-shadow .4s;}
.cert-card:hover{transform:translateY(-4px);box-shadow:0 16px 40px rgba(63,79,54,.14);}
.cert-card img{width:120px;height:auto;margin:0 auto 18px;aspect-ratio:3/4;object-fit:contain;}
.cert-card h3{color:var(--anchor);font-size:18px;margin-bottom:6px;}
.cert-card p{font-size:13px;color:var(--pine);opacity:.78;margin:0 auto;max-width:24ch;}
.cta-final{background:var(--anchor);color:var(--cream);text-align:center;position:relative;overflow:hidden;}
.cta-final::before{content:"";position:absolute;inset:0;background-image:repeating-linear-gradient(-45deg,transparent,transparent 10px,rgba(250,245,234,.04) 10px,rgba(250,245,234,.04) 11px);}
.cta-final>div{position:relative;z-index:1;}
.cta-final .eyebrow{color:var(--sage);opacity:1;}
.cta-final h2{color:var(--cream);max-width:22ch;margin:0 auto 14px;}
.cta-final p{color:rgba(250,245,234,.8);max-width:50ch;margin:0 auto 28px;font-size:15px;}
.cta-final-btns{display:flex;justify-content:center;gap:14px;flex-wrap:wrap;}
.btn-sun{background:var(--sun);color:var(--pine);padding:14px 30px;border-radius:8px;font-family:'Montserrat';font-weight:700;font-size:15px;display:inline-flex;align-items:center;gap:8px;cursor:pointer;border:none;transition:all .2s;text-decoration:none;}
.btn-sun:hover{transform:scale(1.04);box-shadow:0 6px 22px rgba(232,197,71,.4);}
.btn-ghost{background:transparent;color:var(--cream);padding:13px 28px;border-radius:8px;border:1.5px solid rgba(250,245,234,.4);font-family:'Montserrat';font-weight:600;font-size:15px;text-decoration:none;transition:all .2s;}
.btn-ghost:hover{background:rgba(250,245,234,.1);border-color:var(--cream);}
footer{background:var(--pine);color:rgba(250,245,234,.85);padding:64px 0 28px;font-size:14px;}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.4fr;gap:38px;}
.footer-brand img{height:38px;opacity:.92;margin-bottom:14px;}
.footer-brand p{font-size:13px;line-height:1.75;color:rgba(250,245,234,.75);max-width:32ch;}
.footer-col h4{font-family:'Montserrat';font-style:normal;font-weight:600;font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--sage);margin-bottom:14px;}
.footer-col a{display:block;font-size:13px;color:rgba(250,245,234,.75);margin-bottom:8px;transition:color .2s;}
.footer-col a:hover{color:var(--cream);}
.footer-col p{font-size:13px;color:rgba(250,245,234,.75);margin-bottom:8px;line-height:1.6;}
.newsletter-form{display:flex;gap:6px;margin-top:10px;}
.newsletter-form input{flex:1;background:rgba(250,245,234,.08);border:1px solid rgba(250,245,234,.2);color:var(--cream);font-size:13px;padding:10px 12px;border-radius:6px;font-family:'Montserrat';}
.newsletter-form input::placeholder{color:rgba(250,245,234,.4);}
.newsletter-form input:focus{outline:none;border-color:var(--sun);}
.newsletter-form button{background:var(--sun);color:var(--pine);border:none;border-radius:6px;padding:0 16px;font-family:'Montserrat';font-weight:600;font-size:13px;cursor:pointer;transition:transform .2s;}
.newsletter-form button:hover{transform:scale(1.04);}
.newsletter-msg{font-size:12px;color:var(--sun);margin-top:8px;opacity:0;transition:opacity .3s;min-height:16px;}
.newsletter-msg.show{opacity:1;}
.footer-bottom{margin-top:42px;padding-top:22px;border-top:1px solid rgba(183,194,166,.22);text-align:center;font-size:12px;color:rgba(250,245,234,.5);}
.footer-thanks{text-align:center;margin-top:36px;font-family:'Fraunces';font-style:italic;font-size:clamp(18px,2.6vw,22px);color:rgba(250,245,234,.6);}
.floating-btns{position:fixed;bottom:20px;right:16px;z-index:300;display:flex;flex-direction:column;gap:10px;align-items:flex-end;}
.float-btn{display:flex;align-items:center;gap:8px;padding:11px 16px;border-radius:50px;font-family:'Montserrat';font-weight:700;font-size:13px;cursor:pointer;border:none;box-shadow:0 6px 24px rgba(0,0,0,.22);transition:transform .2s,box-shadow .2s;text-decoration:none;animation:pulse 2.2s ease-in-out infinite;}
.float-btn:hover{transform:scale(1.06);box-shadow:0 8px 32px rgba(0,0,0,.3);}
.float-btn-phone{background:var(--anchor);color:var(--cream);}
.float-btn-zalo{background:#0068FF;color:var(--cream);animation-delay:1.1s;}
.float-btn svg{width:18px;height:18px;fill:currentColor;flex-shrink:0;}
.float-btn-label{white-space:nowrap;}
@media(max-width:900px){ section{padding:56px 0;} .story-grid,.factory-grid{grid-template-columns:1fr;gap:28px;} .values-grid{grid-template-columns:1fr;} .certs-grid{grid-template-columns:1fr;} .factory-stats{grid-template-columns:repeat(2,1fr);} .footer-grid{grid-template-columns:1fr 1fr;gap:28px;} }
@media(max-width:640px){ body{font-size:14px;} section{padding:44px 0;} .nav-links{display:none;position:fixed;top:62px;left:0;right:0;background:var(--cream);flex-direction:column;padding:14px 5%;align-items:stretch;gap:0;border-bottom:1px solid var(--sage);box-shadow:0 8px 24px rgba(63,79,54,.1);z-index:199;max-height:calc(100vh - 62px);overflow-y:auto;} .nav-links.open{display:flex;} .nav-links>li{width:100%;} .nav-links a,.nav-links .nav-trigger{padding:14px 0;width:100%;border-bottom:1px solid rgba(183,194,166,.22);font-size:14px;} .nav-trigger{justify-content:space-between;} .dropdown{position:static;opacity:1;visibility:visible;transform:none;pointer-events:auto;background:transparent;border:none;padding:0;box-shadow:none;display:none;min-width:auto;} .nav-item.open .dropdown{display:block;} .dropdown a{padding:10px 0 10px 14px;font-size:13px;border-bottom:1px solid rgba(183,194,166,.15);color:var(--forest);} .nav-links .btn-nav{margin-top:10px;text-align:center;border-bottom:none;border-radius:6px;} .hamburger{display:flex;} .float-btn-label{display:none;} .float-btn{padding:12px;border-radius:50%;} .footer-grid{grid-template-columns:1fr;gap:24px;} .newsletter-form{flex-direction:column;} .newsletter-form button{padding:11px;} .cta-final-btns{flex-direction:column;align-items:stretch;} .factory-stats{grid-template-columns:1fr 1fr;} }
.floating-btn-left{position:fixed;bottom:20px;left:16px;z-index:300;}
.float-btn-left{display:flex;align-items:center;gap:8px;padding:11px 16px;border-radius:50px;font-family:'Montserrat';font-weight:700;font-size:13px;cursor:pointer;border:none;box-shadow:0 6px 24px rgba(0,0,0,.22);background:var(--forest);color:var(--cream);transition:transform .2s,box-shadow .2s;text-decoration:none;}
.float-btn-left:hover{transform:scale(1.06);}
.float-btn-left svg{width:18px;height:18px;fill:currentColor;}
.float-btn-whatsapp{background:#25D366;color:var(--cream);}
.float-btn-wechat{background:#07C160;color:var(--cream);animation-delay:.5s;}
.bs-modal{display:none;position:fixed;inset:0;z-index:1100;background:rgba(10,16,10,.88);align-items:center;justify-content:center;animation:fadeIn .2s ease;padding:20px;}
.bs-modal.open{display:flex;}
.bs-modal-box{background:var(--cream);border-radius:16px;max-width:380px;width:100%;padding:28px 26px;position:relative;box-shadow:0 24px 80px rgba(0,0,0,.4);}
.bs-modal-close{position:absolute;top:10px;right:12px;background:transparent;border:none;cursor:pointer;width:32px;height:32px;border-radius:50%;color:var(--pine);font-size:20px;display:flex;align-items:center;justify-content:center;transition:background .2s;}
.bs-modal-close:hover{background:var(--linen);}
.bs-modal-box h3{font-family:'Fraunces';font-weight:500;font-size:22px;color:var(--anchor);margin-bottom:6px;}
.bs-modal-box p.intro{font-size:13.5px;color:var(--pine);opacity:.85;margin-bottom:18px;}
.bs-modal-box form{display:flex;flex-direction:column;gap:12px;}
.bs-modal-box label{font-size:11px;font-weight:600;color:var(--pine);letter-spacing:.06em;text-transform:uppercase;display:block;margin-bottom:4px;}
.bs-modal-box input,.bs-modal-box textarea{background:var(--linen);border:1px solid rgba(91,114,80,.2);color:var(--pine);font-size:14px;padding:11px 13px;border-radius:8px;width:100%;box-sizing:border-box;font-family:'Montserrat';transition:border-color .2s;}
.bs-modal-box textarea{resize:vertical;min-height:64px;}
.bs-modal-box input:focus,.bs-modal-box textarea:focus{outline:none;border-color:var(--forest);}
.bs-modal-box .btn-submit{background:var(--anchor);color:var(--cream);padding:12px;border:none;border-radius:8px;font-family:'Montserrat';font-weight:600;font-size:14px;cursor:pointer;transition:all .2s;margin-top:4px;}
.bs-modal-box .btn-submit:hover{background:var(--pine);}
.bs-modal-box .btn-submit:disabled{opacity:.6;cursor:wait;}
.bs-modal-msg{font-size:13px;margin-top:8px;min-height:18px;color:var(--forest);text-align:center;}
.wechat-qr{width:200px;height:200px;margin:0 auto 16px;border-radius:12px;background:var(--linen);display:flex;align-items:center;justify-content:center;padding:10px;}
.wechat-qr img{width:100%;height:100%;object-fit:contain;}
.wechat-id{background:var(--linen);border-radius:8px;padding:10px 14px;display:flex;align-items:center;justify-content:space-between;gap:10px;font-family:'Montserrat';font-size:13px;color:var(--pine);margin-bottom:12px;}
.wechat-id strong{font-weight:600;color:var(--anchor);}
.wechat-copy{background:var(--anchor);color:var(--cream);border:none;padding:6px 12px;border-radius:6px;font-family:'Montserrat';font-weight:600;font-size:11px;cursor:pointer;transition:background .2s;}
.wechat-copy:hover{background:var(--pine);}
.wechat-copy.copied{background:var(--forest);}
.wechat-hint{font-size:12px;color:var(--pine);opacity:.7;text-align:center;line-height:1.5;}
@media(max-width:640px){.floating-btn-left{bottom:20px;left:12px;}.float-btn-left{padding:12px;border-radius:50%;}.float-btn-left .float-btn-label{display:none;}.bs-modal-box{padding:22px 18px;}}
.factory-slider{position:relative;border-radius:16px;overflow:hidden;margin-top:36px;box-shadow:0 24px 56px rgba(63,79,54,.16);background:var(--linen);}
.factory-frames{position:relative;aspect-ratio:16/9;}
.factory-frame{position:absolute;inset:0;opacity:0;transition:opacity 600ms ease;cursor:zoom-in;}
.factory-frame.active{opacity:1;z-index:2;}
.factory-frame img{width:100%;height:100%;object-fit:cover;filter:saturate(.85);}
.factory-frame-caption{position:absolute;bottom:0;left:0;right:0;padding:24px 28px;background:linear-gradient(transparent,rgba(15,24,12,.78));color:var(--cream);font-family:'Fraunces';font-style:italic;font-size:clamp(15px,2.2vw,22px);pointer-events:none;z-index:3;}
.factory-dots{position:absolute;bottom:14px;right:24px;display:flex;gap:8px;z-index:4;}
.factory-dot{width:9px;height:9px;border-radius:50%;background:rgba(250,245,234,.35);border:none;cursor:pointer;transition:all .3s;padding:0;}
.factory-dot.active{background:var(--sun);transform:scale(1.3);}
.factory-arrow{position:absolute;top:50%;transform:translateY(-50%);background:rgba(15,24,12,.4);border:none;color:var(--cream);width:42px;height:42px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:18px;z-index:5;opacity:0;transition:opacity .3s,background .2s;}
.factory-slider:hover .factory-arrow{opacity:1;}
.factory-arrow:hover{background:rgba(15,24,12,.65);}
.factory-arrow.prev{left:14px;}
.factory-arrow.next{right:14px;}
@media(prefers-reduced-motion:reduce){.factory-frame{transition:none;}}
@media(max-width:640px){.factory-arrow{opacity:.6;width:36px;height:36px;}.factory-dots{right:16px;bottom:12px;}.factory-frame-caption{padding:18px 20px;font-size:14px;}}
.lang-switcher{display:flex;gap:8px;align-items:center;font-family:'Montserrat';font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;margin-right:4px;}
.lang-switcher a{color:var(--pine);opacity:.55;padding:5px 8px;transition:opacity .2s,color .2s;}
.lang-switcher a:hover{opacity:1;color:var(--anchor);}
.lang-switcher a.active{opacity:1;color:var(--anchor);border-bottom:2px solid var(--sun);}
.lang-switcher .sep{color:var(--sage);opacity:.6;}
@media(max-width:640px){.lang-switcher{justify-content:flex-start;padding:14px 0;border-bottom:1px solid rgba(183,194,166,.22);width:100%;}}
section{padding:64px 0;}
.page-hero h1{max-width:20ch;margin-bottom:14px;}
.listing-section{background:var(--cream);}
.listing-grid{display:grid;grid-template-columns:1fr 280px;gap:48px;align-items:start;}
.posts-list{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;}
.post-card{background:var(--linen);border-radius:14px;overflow:hidden;cursor:pointer;transition:transform .3s,box-shadow .3s;display:block;color:var(--pine);}
.post-card:hover{transform:translateY(-4px);box-shadow:0 16px 36px rgba(63,79,54,.14);}
.post-card img{width:100%;aspect-ratio:16/10;object-fit:cover;filter:saturate(.85);transition:transform .5s ease;}
.post-card:hover img{transform:scale(1.03);}
.post-card-body{padding:20px 18px;}
.post-tag{font-size:10px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--forest);opacity:.85;}
.post-card h3{font-size:17px;line-height:1.3;margin:8px 0 8px;color:var(--anchor);}
.post-card p{font-size:13px;color:var(--pine);opacity:.85;line-height:1.55;}
.post-meta{font-size:11px;color:var(--pine);opacity:.6;margin-top:12px;display:flex;gap:10px;}
.post-meta span::before{content:"·";margin-right:6px;color:var(--sage);}
.post-meta span:first-child::before{content:"";margin:0;}
.sidebar{position:sticky;top:80px;display:flex;flex-direction:column;gap:24px;}
.side-card{background:var(--linen);border-radius:14px;padding:22px 20px;}
.side-card h4{font-family:'Montserrat';font-weight:600;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--forest);margin-bottom:14px;font-style:normal;}
.side-card ul{list-style:none;}
.side-card ul li{margin-bottom:10px;}
.side-card ul li a{font-size:13.5px;color:var(--pine);display:flex;justify-content:space-between;gap:8px;transition:color .2s;}
.side-card ul li a:hover{color:var(--anchor);}
.side-card .count{color:var(--pine);opacity:.5;font-size:12px;}
.recent-post{display:flex;gap:10px;margin-bottom:14px;padding-bottom:14px;border-bottom:1px solid rgba(91,114,80,.12);}
.recent-post:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none;}
.recent-post img{width:60px;height:60px;border-radius:8px;object-fit:cover;filter:saturate(.85);flex-shrink:0;}
.recent-post-body h5{font-family:'Fraunces';font-size:13px;font-weight:500;color:var(--anchor);line-height:1.3;margin-bottom:4px;}
.recent-post-body span{font-size:10.5px;color:var(--pine);opacity:.6;}
.tag-cloud{display:flex;flex-wrap:wrap;gap:6px;}
.tag-cloud a{background:var(--cream);color:var(--pine);font-size:11px;font-weight:500;padding:6px 12px;border-radius:50px;transition:all .2s;}
.tag-cloud a:hover{background:var(--forest);color:var(--cream);}
.pagination{display:flex;justify-content:center;gap:8px;margin-top:42px;}
.page-btn{width:42px;height:42px;border-radius:50%;background:transparent;border:1px solid rgba(91,114,80,.25);color:var(--pine);font-family:'Montserrat';font-weight:600;font-size:13px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;}
.page-btn.active{background:var(--anchor);color:var(--cream);border-color:var(--anchor);}
.page-btn:hover:not(.active){border-color:var(--forest);color:var(--anchor);}
.page-btn.disabled{opacity:.4;cursor:not-allowed;}
.cta-banner{background:var(--pine);color:var(--cream);text-align:center;padding:56px 0;}
.cta-banner h2{color:var(--cream);max-width:24ch;margin:0 auto 14px;}
.cta-banner p{color:rgba(250,245,234,.8);max-width:50ch;margin:0 auto 24px;font-size:15px;}
.btn-sun:hover{transform:scale(1.04);}
.newsletter-form button{background:var(--sun);color:var(--pine);border:none;border-radius:6px;padding:0 16px;font-family:'Montserrat';font-weight:600;font-size:13px;cursor:pointer;}
.float-btn:hover{transform:scale(1.06);}
.float-btn svg{width:18px;height:18px;fill:currentColor;}
@media(max-width:900px){ section{padding:48px 0;} .listing-grid{grid-template-columns:1fr;gap:36px;} .sidebar{position:static;} .posts-list{grid-template-columns:repeat(2,1fr);} .footer-grid{grid-template-columns:1fr 1fr;gap:28px;} }
@media(max-width:640px){ body{font-size:14px;} section{padding:40px 0;} .nav-links{display:none;position:fixed;top:62px;left:0;right:0;background:var(--cream);flex-direction:column;padding:14px 5%;align-items:stretch;gap:0;border-bottom:1px solid var(--sage);box-shadow:0 8px 24px rgba(63,79,54,.1);z-index:199;max-height:calc(100vh - 62px);overflow-y:auto;} .nav-links.open{display:flex;} .nav-links>li{width:100%;} .nav-links a,.nav-links .nav-trigger{padding:14px 0;width:100%;border-bottom:1px solid rgba(183,194,166,.22);font-size:14px;} .nav-trigger{justify-content:space-between;} .dropdown{position:static;opacity:1;visibility:visible;transform:none;pointer-events:auto;background:transparent;border:none;padding:0;box-shadow:none;display:none;min-width:auto;} .nav-item.open .dropdown{display:block;} .dropdown a{padding:10px 0 10px 14px;font-size:13px;border-bottom:1px solid rgba(183,194,166,.15);color:var(--forest);} .nav-links .btn-nav{margin-top:10px;text-align:center;border-bottom:none;border-radius:6px;} .hamburger{display:flex;} .float-btn-label{display:none;} .float-btn{padding:12px;border-radius:50%;} .posts-list{grid-template-columns:1fr;} .footer-grid{grid-template-columns:1fr;gap:24px;} .newsletter-form{flex-direction:column;} .newsletter-form button{padding:11px;} }
.contact-section{background:var(--cream);}
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;margin-top:32px;align-items:start;}
.contact-form-box{background:var(--linen);border-radius:16px;padding:36px 32px;}
.contact-form-box h3{font-size:22px;margin-bottom:8px;color:var(--anchor);}
.contact-form-box p.intro{font-size:14px;color:var(--pine);opacity:.8;margin-bottom:22px;max-width:48ch;}
.contact-form-box form{display:flex;flex-direction:column;gap:14px;}
.contact-form-box label{font-size:12px;font-weight:600;color:var(--pine);letter-spacing:.04em;text-transform:uppercase;display:block;margin-bottom:5px;}
.contact-form-box input,.contact-form-box select,.contact-form-box textarea{background:var(--cream);border:1px solid rgba(91,114,80,.25);color:var(--pine);font-size:14px;padding:11px 14px;border-radius:8px;width:100%;font-family:'Montserrat';transition:border-color .2s;}
.contact-form-box input:focus,.contact-form-box select:focus,.contact-form-box textarea:focus{outline:none;border-color:var(--forest);}
.contact-form-box textarea{min-height:100px;resize:vertical;line-height:1.55;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.btn-submit{background:var(--anchor);color:var(--cream);padding:13px;border:none;border-radius:8px;font-family:'Montserrat';font-weight:600;font-size:14px;cursor:pointer;transition:all .2s;margin-top:6px;}
.btn-submit:hover{background:var(--pine);transform:scale(1.02);box-shadow:0 6px 20px rgba(14,61,112,.25);}
.btn-submit:disabled{opacity:.6;cursor:wait;}
.form-msg{font-size:13px;margin-top:10px;min-height:18px;color:var(--forest);}
.contact-info-box{padding:8px 0;}
.contact-info-box h3{font-size:22px;margin-bottom:18px;color:var(--anchor);}
.info-item{margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid rgba(91,114,80,.15);}
.info-item:last-of-type{border-bottom:none;}
.info-item h4{font-family:'Montserrat';font-weight:600;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--forest);margin-bottom:8px;font-style:normal;}
.info-item p,.info-item a{font-size:14px;color:var(--pine);display:block;margin-bottom:4px;line-height:1.55;}
.info-item a:hover{color:var(--anchor);}
.info-quick{display:flex;gap:10px;margin-top:10px;flex-wrap:wrap;}
.btn-call{display:inline-flex;align-items:center;gap:7px;background:var(--sun);color:var(--pine);padding:11px 18px;border-radius:8px;font-family:'Montserrat';font-weight:700;font-size:13px;text-decoration:none;transition:transform .2s;}
.btn-call:hover{transform:scale(1.04);}
.btn-call svg{width:16px;height:16px;fill:currentColor;}
.btn-zalo{background:#0068FF;color:var(--cream);}
.maps-section{background:var(--linen);padding:64px 0;}
.maps-tabs{display:flex;gap:10px;margin-top:24px;margin-bottom:18px;flex-wrap:wrap;}
.maps-tab{padding:10px 22px;background:var(--cream);border:1px solid rgba(91,114,80,.2);color:var(--pine);font-family:'Montserrat';font-weight:500;font-size:13px;border-radius:50px;cursor:pointer;transition:all .2s;}
.maps-tab.active{background:var(--anchor);color:var(--cream);border-color:var(--anchor);}
.maps-tab:hover:not(.active){background:var(--sage);}
.maps-frame{border-radius:16px;overflow:hidden;box-shadow:0 16px 44px rgba(63,79,54,.14);background:var(--sage);}
.maps-frame iframe{width:100%;height:420px;border:0;display:block;}
@media(max-width:900px){ section{padding:56px 0;} .contact-grid{grid-template-columns:1fr;gap:32px;} .footer-grid{grid-template-columns:1fr 1fr;gap:28px;} }
@media(max-width:640px){ body{font-size:14px;} section{padding:44px 0;} .nav-links{display:none;position:fixed;top:62px;left:0;right:0;background:var(--cream);flex-direction:column;padding:14px 5%;align-items:stretch;gap:0;border-bottom:1px solid var(--sage);box-shadow:0 8px 24px rgba(63,79,54,.1);z-index:199;max-height:calc(100vh - 62px);overflow-y:auto;} .nav-links.open{display:flex;} .nav-links>li{width:100%;} .nav-links a,.nav-links .nav-trigger{padding:14px 0;width:100%;border-bottom:1px solid rgba(183,194,166,.22);font-size:14px;} .nav-trigger{justify-content:space-between;} .dropdown{position:static;opacity:1;visibility:visible;transform:none;pointer-events:auto;background:transparent;border:none;padding:0;box-shadow:none;display:none;min-width:auto;} .nav-item.open .dropdown{display:block;} .dropdown a{padding:10px 0 10px 14px;font-size:13px;border-bottom:1px solid rgba(183,194,166,.15);color:var(--forest);} .nav-links .btn-nav{margin-top:10px;text-align:center;border-bottom:none;border-radius:6px;} .hamburger{display:flex;} .float-btn-label{display:none;} .float-btn{padding:12px;border-radius:50%;} .form-row{grid-template-columns:1fr;} .contact-form-box{padding:28px 22px;} .maps-frame iframe{height:320px;} .footer-grid{grid-template-columns:1fr;gap:24px;} .newsletter-form{flex-direction:column;} .newsletter-form button{padding:11px;} }
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes floatY{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.hero-section{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;min-height:auto;padding:clamp(48px,7vw,96px) 0 clamp(40px,5vw,64px);}
.hero-text .eyebrow{margin-bottom:14px;}
.hero-text h1{margin-bottom:20px;}
.hero-text h1 em{font-style:italic;color:var(--forest);}
.hero-text>p{font-size:16px;margin-bottom:28px;color:var(--pine);}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:36px;}
.btn-primary{display:inline-block;background:var(--anchor);color:var(--cream);padding:14px 28px;border-radius:6px;font-family:'Montserrat';font-weight:600;font-size:14px;transition:all .2s;cursor:pointer;border:none;}
.btn-primary:hover{background:var(--pine);transform:scale(1.03);box-shadow:0 6px 20px rgba(14,61,112,.22);}
.btn-secondary{display:inline-block;border:1.5px solid var(--pine);color:var(--pine);padding:13px 26px;border-radius:6px;font-family:'Montserrat';font-weight:600;font-size:14px;transition:all .2s;cursor:pointer;background:transparent;}
.btn-secondary:hover{background:var(--pine);color:var(--cream);transform:scale(1.03);}
.hero-meta{display:flex;gap:28px;flex-wrap:wrap;}
.hero-meta>div{flex:0 0 auto;}
.meta-num{font-family:'Fraunces';font-weight:500;font-size:30px;color:var(--anchor);line-height:1;}
.meta-label{font-size:11px;color:var(--pine);opacity:.7;margin-top:4px;letter-spacing:.04em;}
.hero-image-wrap{border-radius:18px;overflow:hidden;aspect-ratio:4/5;animation:floatY 5.5s ease-in-out infinite;box-shadow:0 24px 60px rgba(63,79,54,.16);}
.hero-image-wrap img{width:100%;height:100%;object-fit:cover;filter:saturate(.85);}
.cats-section{background:var(--linen);}
.services-section{background:var(--cream);}
.why-section{background:var(--pine);color:var(--cream);}
.why-section .eyebrow{color:var(--sage);}
.why-section h2{color:var(--cream);}
.blog-section{background:var(--cream);}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:36px;}
.blog-card{background:var(--linen);border-radius:14px;overflow:hidden;cursor:pointer;transition:transform .4s,box-shadow .4s;display:block;color:var(--pine);}
.blog-card:hover{transform:translateY(-6px);box-shadow:0 16px 40px rgba(63,79,54,.14);}
.blog-card img{width:100%;aspect-ratio:16/10;object-fit:cover;filter:saturate(.85);transition:transform .5s ease;}
.blog-card:hover img{transform:scale(1.04);}
.blog-card-body{padding:20px 18px;}
.blog-tag{font-family:'Montserrat';font-weight:600;font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--forest);opacity:.85;}
.blog-card h3{font-size:17px;margin:8px 0 8px;color:var(--anchor);line-height:1.3;}
.blog-card p{font-size:13px;color:var(--pine);opacity:.85;}
.blog-meta{font-size:11px;color:var(--pine);opacity:.6;margin-top:12px;}
.partners-section{background:var(--linen);text-align:center;}
.partners-section p.lead{max-width:54ch;margin:0 auto 30px;color:var(--pine);font-size:14px;}
.partners-grid{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:48px;margin-top:18px;}
.partner-logo{height:46px;width:auto;filter:grayscale(1) opacity(.65);transition:filter .3s;}
.partner-logo:hover{filter:grayscale(0) opacity(1);}
@media(max-width:900px){ section{padding:56px 0;} .hero-section{grid-template-columns:1fr;gap:28px;min-height:auto;padding:44px 0 32px;} .hero-image-wrap{order:-1;max-height:320px;aspect-ratio:16/10;} .blog-grid{grid-template-columns:1fr;} .footer-grid{grid-template-columns:1fr 1fr;gap:28px;} .partner-logo{height:36px;} .partners-grid{gap:32px;} }
@media(max-width:640px){ :root{--pad-x:5%;} body{font-size:14px;} section{padding:44px 0;} .nav-links{display:none;position:fixed;top:62px;left:0;right:0;background:var(--cream);flex-direction:column;padding:14px 5%;align-items:stretch;gap:0;border-bottom:1px solid var(--sage);box-shadow:0 8px 24px rgba(63,79,54,.1);z-index:199;max-height:calc(100vh - 62px);overflow-y:auto;} .nav-links.open{display:flex;} .nav-links>li{width:100%;} .nav-links a,.nav-links .nav-trigger{padding:14px 0;width:100%;border-bottom:1px solid rgba(183,194,166,.22);font-size:14px;} .nav-trigger{justify-content:space-between;} .dropdown{position:static;opacity:1;visibility:visible;transform:none;pointer-events:auto;background:transparent;border:none;padding:0;box-shadow:none;display:none;min-width:auto;} .nav-item.open .dropdown{display:block;} .dropdown a{padding:10px 0 10px 14px;font-size:13px;border-bottom:1px solid rgba(183,194,166,.15);color:var(--forest);} .nav-links .btn-nav{margin-top:10px;text-align:center;border-bottom:none;border-radius:6px;} .hamburger{display:flex;} .hero-text h1{font-size:clamp(28px,8vw,42px);} .hero-cta{flex-direction:column;} .hero-cta a,.hero-cta button{width:100%;text-align:center;} .hero-meta{gap:18px;} .meta-num{font-size:26px;} .cats-grid{grid-template-columns:1fr;} .services-grid{grid-template-columns:1fr;} .float-btn-label{display:none;} .float-btn{padding:12px;border-radius:50%;} .footer-grid{grid-template-columns:1fr;gap:24px;} .newsletter-form{flex-direction:column;} .newsletter-form button{padding:11px;} .cta-final-btns{flex-direction:column;align-items:stretch;} }
h1,h2,h3,h4{font-family:'Fraunces',serif;color:var(--anchor);}
h1{font-weight:300;font-style:italic;font-size:clamp(30px,5.6vw,52px);line-height:1.05;letter-spacing:-0.015em;}
h2{font-weight:500;font-size:clamp(22px,3.4vw,30px);line-height:1.15;margin:38px 0 14px;scroll-margin-top:80px;}
h3{font-weight:500;font-size:clamp(17px,2.4vw,22px);margin:28px 0 10px;color:var(--pine);}
p{max-width:none;margin-bottom:16px;}
section{padding:56px 0;}
.post-header{padding:clamp(56px,8vw,96px) 0 32px;background:var(--linen);}
.post-header .container{max-width:820px;}
.post-tag{display:inline-block;font-family:'Montserrat';font-weight:600;font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--forest);background:var(--cream);padding:5px 12px;border-radius:50px;margin-bottom:14px;}
.post-meta-row{display:flex;gap:18px;flex-wrap:wrap;font-size:13px;color:var(--pine);opacity:.75;margin-top:18px;}
.post-meta-row span::before{content:"·";margin-right:6px;color:var(--sage);}
.post-meta-row span:first-child::before{content:"";margin:0;}
.post-feature-img{margin-top:36px;border-radius:16px;overflow:hidden;box-shadow:0 24px 56px rgba(63,79,54,.16);}
.post-feature-img img{width:100%;aspect-ratio:16/9;object-fit:cover;filter:saturate(.85);}
.post-section{background:var(--cream);}
.post-layout{display:grid;grid-template-columns:1fr 240px;gap:60px;align-items:start;}
.post-body{font-size:16px;line-height:1.85;color:var(--pine);max-width:65ch;}
.post-body .lead{font-family:'Fraunces';font-style:italic;font-size:22px;line-height:1.5;color:var(--forest);margin-bottom:32px;}
.post-body p{margin-bottom:18px;}
.post-body blockquote{margin:28px 0;padding:18px 24px;border-left:3px solid var(--sun);background:var(--linen);font-family:'Fraunces';font-style:italic;font-size:18px;color:var(--pine);line-height:1.55;}
.post-body ul,.post-body ol{margin:18px 0 22px 24px;}
.post-body li{margin-bottom:8px;}
.post-body strong{color:var(--anchor);}
.post-share{display:flex;gap:10px;margin-top:48px;padding-top:24px;border-top:1px solid rgba(91,114,80,.18);}
.share-btn{padding:9px 16px;border-radius:50px;background:var(--linen);color:var(--pine);font-size:12px;font-weight:600;letter-spacing:.04em;transition:all .2s;border:none;cursor:pointer;}
.share-btn:hover{background:var(--anchor);color:var(--cream);}
.toc{position:sticky;top:80px;padding:22px 20px;background:var(--linen);border-radius:14px;border-left:3px solid var(--sage);}
.toc h4{font-family:'Montserrat';font-weight:600;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--forest);margin-bottom:14px;font-style:normal;}
.toc ul{list-style:none;}
.toc li{margin-bottom:8px;}
.toc a{display:block;font-size:13px;color:var(--pine);padding:5px 0;border-left:2px solid transparent;padding-left:10px;margin-left:-12px;transition:all .2s;line-height:1.45;}
.toc a:hover{color:var(--anchor);}
.toc a.active{color:var(--anchor);border-left-color:var(--sun);font-weight:500;}
.related-section{background:var(--linen);}
.related-section h2{margin:0 0 30px;}
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.related-card{background:var(--cream);border-radius:12px;overflow:hidden;cursor:pointer;transition:transform .3s,box-shadow .3s;display:block;color:var(--pine);}
.related-card:hover{transform:translateY(-4px);box-shadow:0 14px 32px rgba(63,79,54,.14);}
.related-card img{width:100%;aspect-ratio:16/10;object-fit:cover;filter:saturate(.85);}
.related-card-body{padding:18px 18px 22px;}
.related-card h3{font-size:16px;line-height:1.3;margin-bottom:6px;color:var(--anchor);}
.related-card p{font-size:12.5px;color:var(--pine);opacity:.78;}
.btn-sun{background:var(--sun);color:var(--pine);padding:14px 30px;border-radius:8px;font-family:'Montserrat';font-weight:700;font-size:15px;display:inline-flex;align-items:center;gap:8px;text-decoration:none;transition:all .2s;}
@media(max-width:900px){ section{padding:44px 0;} .post-layout{grid-template-columns:1fr;gap:32px;} .toc{position:static;} .related-grid{grid-template-columns:repeat(2,1fr);} .footer-grid{grid-template-columns:1fr 1fr;gap:28px;} }
@media(max-width:640px){ body{font-size:14px;} .nav-links{display:none;position:fixed;top:62px;left:0;right:0;background:var(--cream);flex-direction:column;padding:14px 5%;align-items:stretch;gap:0;border-bottom:1px solid var(--sage);box-shadow:0 8px 24px rgba(63,79,54,.1);z-index:199;max-height:calc(100vh - 62px);overflow-y:auto;} .nav-links.open{display:flex;} .nav-links>li{width:100%;} .nav-links a,.nav-links .nav-trigger{padding:14px 0;width:100%;border-bottom:1px solid rgba(183,194,166,.22);font-size:14px;} .nav-trigger{justify-content:space-between;} .dropdown{position:static;opacity:1;visibility:visible;transform:none;pointer-events:auto;background:transparent;border:none;padding:0;box-shadow:none;display:none;min-width:auto;} .nav-item.open .dropdown{display:block;} .dropdown a{padding:10px 0 10px 14px;font-size:13px;border-bottom:1px solid rgba(183,194,166,.15);color:var(--forest);} .nav-links .btn-nav{margin-top:10px;text-align:center;border-bottom:none;border-radius:6px;} .hamburger{display:flex;} .float-btn-label{display:none;} .float-btn{padding:12px;border-radius:50%;} .post-body{font-size:15px;} .related-grid{grid-template-columns:1fr;} .footer-grid{grid-template-columns:1fr;gap:24px;} .newsletter-form{flex-direction:column;} .newsletter-form button{padding:11px;} }
h1{font-weight:500;font-style:normal;font-size:clamp(28px,4.4vw,42px);line-height:1.1;color:var(--anchor);}
h2{font-weight:500;font-size:clamp(22px,3.6vw,32px);line-height:1.12;color:var(--anchor);}
h3{font-weight:500;font-size:clamp(16px,2.2vw,20px);line-height:1.3;color:var(--pine);}
.breadcrumb-bar{background:var(--linen);padding:18px 0;}
.breadcrumb{font-size:12px;color:var(--pine);opacity:.8;}
.breadcrumb span.sep{margin:0 6px;color:var(--sage);}
.breadcrumb .current{color:var(--anchor);font-weight:500;}
.product-section{padding:48px 0;}
.product-main{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:start;}
.product-gallery{position:sticky;top:80px;}
.gallery-main{border-radius:16px;overflow:hidden;background:var(--linen);aspect-ratio:1/1;cursor:zoom-in;box-shadow:0 16px 40px rgba(63,79,54,.12);}
.gallery-main img{width:100%;height:100%;object-fit:cover;filter:saturate(.85);transition:transform .5s ease;}
.gallery-main:hover img{transform:scale(1.03);}
.gallery-thumbs{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:12px;}
.gallery-thumb{border-radius:10px;overflow:hidden;cursor:pointer;border:2px solid transparent;transition:border-color .2s;aspect-ratio:1/1;background:var(--linen);}
.gallery-thumb.active{border-color:var(--anchor);}
.gallery-thumb img{width:100%;height:100%;object-fit:cover;filter:saturate(.85);}
.product-info .eyebrow{margin-bottom:12px;}
.product-info h1{margin-bottom:16px;}
.product-summary{font-size:15px;color:var(--pine);margin-bottom:24px;line-height:1.7;max-width:48ch;}
.spec-table{width:100%;border-collapse:collapse;margin-bottom:28px;background:var(--linen);border-radius:12px;overflow:hidden;}
.spec-table th,.spec-table td{padding:12px 16px;text-align:left;font-size:13.5px;border-bottom:1px solid rgba(91,114,80,.12);}
.spec-table th{color:var(--forest);font-weight:600;width:38%;letter-spacing:.04em;}
.spec-table td{color:var(--pine);}
.spec-table tr:last-child th,.spec-table tr:last-child td{border-bottom:none;}
.product-cta{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:24px;}
.btn-primary{display:inline-flex;align-items:center;gap:8px;background:var(--anchor);color:var(--cream);padding:14px 26px;border-radius:8px;font-family:'Montserrat';font-weight:600;font-size:14px;transition:all .2s;cursor:pointer;border:none;text-decoration:none;}
.btn-primary:hover{background:var(--pine);transform:scale(1.02);box-shadow:0 6px 22px rgba(14,61,112,.25);}
.btn-secondary{display:inline-flex;align-items:center;gap:8px;border:1.5px solid var(--pine);color:var(--pine);padding:13px 24px;border-radius:8px;font-family:'Montserrat';font-weight:600;font-size:14px;background:transparent;text-decoration:none;transition:all .2s;}
.btn-secondary:hover{background:var(--pine);color:var(--cream);}
.product-trust{display:flex;gap:18px;flex-wrap:wrap;font-size:12px;color:var(--forest);opacity:.85;}
.product-trust span::before{content:"✓ ";color:var(--sun);font-weight:700;}
.tabs-section{background:var(--linen);}
.tabs-nav{display:flex;gap:6px;border-bottom:1px solid rgba(91,114,80,.18);margin-bottom:28px;overflow-x:auto;}
.tab-btn{background:transparent;border:none;padding:14px 22px;color:var(--pine);font-family:'Montserrat';font-weight:600;font-size:13px;letter-spacing:.04em;cursor:pointer;border-bottom:2px solid transparent;transition:all .2s;white-space:nowrap;}
.tab-btn.active{color:var(--anchor);border-bottom-color:var(--sun);}
.tab-btn:hover:not(.active){color:var(--forest);}
.tab-panel{display:none;}
.tab-panel.active{display:block;}
.tab-panel h3{margin-bottom:14px;color:var(--anchor);}
.tab-panel p{font-size:14.5px;color:var(--pine);margin-bottom:14px;line-height:1.7;}
.tab-panel ul{margin:12px 0 16px 22px;color:var(--pine);}
.tab-panel ul li{margin-bottom:6px;font-size:14.5px;line-height:1.65;}
.faq-item{border-bottom:1px solid rgba(91,114,80,.15);padding:16px 0;}
.faq-item:last-child{border-bottom:none;}
.faq-q{font-family:'Fraunces';font-style:italic;font-size:17px;color:var(--anchor);margin-bottom:6px;}
.faq-a{font-size:14px;color:var(--pine);opacity:.88;}
.related-section{background:var(--cream);}
.related-section h2{margin-bottom:30px;}
.related-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
.related-card{background:var(--linen);border-radius:12px;overflow:hidden;cursor:pointer;transition:transform .3s,box-shadow .3s;display:block;color:var(--pine);}
.related-card img{width:100%;aspect-ratio:1/1;object-fit:cover;filter:saturate(.85);}
.related-card-body{padding:14px 16px;}
.related-card h3{font-size:15px;margin-bottom:4px;color:var(--anchor);}
.related-card p{font-size:12px;color:var(--pine);opacity:.78;}
.lightbox{display:none;position:fixed;inset:0;z-index:1100;background:rgba(10,16,10,.94);align-items:center;justify-content:center;animation:fadeIn .2s ease;}
.lightbox.open{display:flex;}
.lightbox img{max-width:94vw;max-height:92vh;object-fit:contain;border-radius:6px;}
.lightbox-close{position:fixed;top:18px;right:22px;background:rgba(250,245,234,.15);border:none;color:rgba(250,245,234,.9);font-size:24px;width:42px;height:42px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s;}
.lightbox-close:hover{background:rgba(250,245,234,.3);color:var(--cream);}
@media(max-width:900px){ section{padding:40px 0;} .product-main{grid-template-columns:1fr;gap:32px;} .product-gallery{position:static;} .related-grid{grid-template-columns:repeat(2,1fr);} .footer-grid{grid-template-columns:1fr 1fr;gap:28px;} }
@media(max-width:640px){ body{font-size:14px;} .nav-links{display:none;position:fixed;top:62px;left:0;right:0;background:var(--cream);flex-direction:column;padding:14px 5%;align-items:stretch;gap:0;border-bottom:1px solid var(--sage);box-shadow:0 8px 24px rgba(63,79,54,.1);z-index:199;max-height:calc(100vh - 62px);overflow-y:auto;} .nav-links.open{display:flex;} .nav-links>li{width:100%;} .nav-links a,.nav-links .nav-trigger{padding:14px 0;width:100%;border-bottom:1px solid rgba(183,194,166,.22);font-size:14px;} .nav-trigger{justify-content:space-between;} .dropdown{position:static;opacity:1;visibility:visible;transform:none;pointer-events:auto;background:transparent;border:none;padding:0;box-shadow:none;display:none;min-width:auto;} .nav-item.open .dropdown{display:block;} .dropdown a{padding:10px 0 10px 14px;font-size:13px;border-bottom:1px solid rgba(183,194,166,.15);color:var(--forest);} .nav-links .btn-nav{margin-top:10px;text-align:center;border-bottom:none;border-radius:6px;} .hamburger{display:flex;} .float-btn-label{display:none;} .float-btn{padding:12px;border-radius:50%;} .product-cta{flex-direction:column;} .product-cta a{width:100%;justify-content:center;} .gallery-thumbs{grid-template-columns:repeat(4,1fr);} .related-grid{grid-template-columns:1fr 1fr;} .footer-grid{grid-template-columns:1fr;gap:24px;} }
.page-hero h1{max-width:20ch;margin-bottom:18px;}
.svc-overview{background:var(--cream);}
.svc-cards-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:36px;}
.svc-card{background:var(--linen);border-radius:14px;padding:28px 22px;border-top:3px solid var(--sage);transition:transform .4s,box-shadow .4s,border-top-color .3s;cursor:pointer;text-decoration:none;color:var(--pine);display:block;}
.svc-card:hover{transform:translateY(-6px);box-shadow:0 18px 40px rgba(63,79,54,.14);border-top-color:var(--sun);}
.svc-card .svg-icon{width:36px;height:36px;color:var(--forest);margin-bottom:14px;}
.svc-card h3{font-size:18px;margin-bottom:8px;color:var(--anchor);}
.svc-card p{font-size:13px;color:var(--pine);opacity:.85;line-height:1.55;margin-bottom:14px;}
.svc-link{font-family:'Montserrat';font-weight:600;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--forest);display:inline-flex;align-items:center;gap:6px;}
.svc-link::after{content:"↓";transition:transform .25s;}
.svc-card:hover .svc-link::after{transform:translateY(2px);}
.svc-detail{padding:80px 0;scroll-margin-top:80px;}
.svc-detail:nth-child(odd){background:var(--linen);}
.svc-detail:nth-child(even){background:var(--cream);}
.svc-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;}
.svc-detail-text .num{font-family:'Fraunces';font-style:italic;font-weight:500;font-size:48px;color:var(--sun);line-height:1;margin-bottom:10px;}
.svc-detail-text h2{margin-bottom:14px;}
.svc-detail-text p{font-size:15px;color:var(--pine);margin-bottom:14px;line-height:1.7;max-width:48ch;}
.svc-detail-text ul{margin:18px 0 24px 22px;color:var(--pine);}
.svc-detail-text ul li{margin-bottom:8px;font-size:14px;line-height:1.6;}
.svc-detail-text ul li strong{color:var(--anchor);}
.svc-detail-img{border-radius:16px;overflow:hidden;box-shadow:0 20px 48px rgba(63,79,54,.16);}
.svc-detail-img img{width:100%;aspect-ratio:4/3;object-fit:cover;filter:saturate(.85);transition:transform .6s ease;}
.svc-detail-img:hover img{transform:scale(1.03);}
.svc-detail.reverse .svc-detail-grid{direction:rtl;}
.svc-detail.reverse .svc-detail-grid>*{direction:ltr;}
.cta-banner{background:var(--pine);color:var(--cream);text-align:center;padding:64px 0;}
.cta-banner h2{color:var(--cream);max-width:22ch;margin:0 auto 14px;}
.cta-banner p{color:rgba(250,245,234,.8);max-width:50ch;margin:0 auto 28px;font-size:15px;}
.cta-banner-btns{display:flex;justify-content:center;gap:14px;flex-wrap:wrap;}
footer{background:var(--pine);color:rgba(250,245,234,.85);padding:64px 0 28px;font-size:14px;border-top:1px solid rgba(183,194,166,.18);}
@media(max-width:900px){ section{padding:56px 0;} .svc-cards-grid{grid-template-columns:repeat(2,1fr);} .svc-detail{padding:60px 0;} .svc-detail-grid{grid-template-columns:1fr;gap:28px;} .svc-detail.reverse .svc-detail-grid{direction:ltr;} .footer-grid{grid-template-columns:1fr 1fr;gap:28px;} }
@media(max-width:640px){ body{font-size:14px;} section{padding:44px 0;} .nav-links{display:none;position:fixed;top:62px;left:0;right:0;background:var(--cream);flex-direction:column;padding:14px 5%;align-items:stretch;gap:0;border-bottom:1px solid var(--sage);box-shadow:0 8px 24px rgba(63,79,54,.1);z-index:199;max-height:calc(100vh - 62px);overflow-y:auto;} .nav-links.open{display:flex;} .nav-links>li{width:100%;} .nav-links a,.nav-links .nav-trigger{padding:14px 0;width:100%;border-bottom:1px solid rgba(183,194,166,.22);font-size:14px;} .nav-trigger{justify-content:space-between;} .dropdown{position:static;opacity:1;visibility:visible;transform:none;pointer-events:auto;background:transparent;border:none;padding:0;box-shadow:none;display:none;min-width:auto;} .nav-item.open .dropdown{display:block;} .dropdown a{padding:10px 0 10px 14px;font-size:13px;border-bottom:1px solid rgba(183,194,166,.15);color:var(--forest);} .nav-links .btn-nav{margin-top:10px;text-align:center;border-bottom:none;border-radius:6px;} .hamburger{display:flex;} .float-btn-label{display:none;} .float-btn{padding:12px;border-radius:50%;} .svc-cards-grid{grid-template-columns:1fr;} .footer-grid{grid-template-columns:1fr;gap:24px;} .newsletter-form{flex-direction:column;} .newsletter-form button{padding:11px;} .cta-banner-btns{flex-direction:column;align-items:stretch;} }
.page-hero{padding:clamp(56px,8vw,112px) 0 clamp(32px,4vw,56px);background:var(--linen);}
.page-hero h1{max-width:18ch;margin-bottom:14px;}
.products-section{background:var(--cream);}
.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:22px;margin-top:36px;}
.product-card{background:var(--linen);border-radius:14px;overflow:hidden;cursor:pointer;transition:transform .4s cubic-bezier(.4,0,.2,1),box-shadow .4s;display:block;color:var(--pine);}
.product-card:hover{transform:translateY(-6px);box-shadow:0 20px 44px rgba(63,79,54,.16);}
.product-card img{width:100%;aspect-ratio:4/3;object-fit:cover;filter:saturate(.85);transition:transform .5s ease;}
.product-card:hover img{transform:scale(1.05);}
.product-card-body{padding:22px 20px;}
.product-tag{font-size:10px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--forest);opacity:.85;}
.product-card h3{margin:8px 0 6px;color:var(--anchor);font-size:18px;}
.product-card p{font-size:13px;color:var(--pine);opacity:.85;margin-bottom:14px;line-height:1.55;}
.product-spec{font-size:12px;color:var(--pine);opacity:.7;display:flex;gap:14px;flex-wrap:wrap;}
.product-spec span::before{content:"·";margin-right:6px;color:var(--sage);}
.product-spec span:first-child::before{content:"";margin:0;}
.pagination{display:flex;justify-content:center;gap:8px;margin-top:48px;}
.other-cats-section{background:var(--linen);}
.other-cats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;margin-top:28px;}
.other-cat-card{background:var(--cream);border-radius:14px;overflow:hidden;cursor:pointer;transition:transform .3s,box-shadow .3s;display:block;color:var(--pine);}
.other-cat-card:hover{transform:translateY(-4px);box-shadow:0 14px 32px rgba(63,79,54,.14);}
.other-cat-card img{width:100%;aspect-ratio:16/10;object-fit:cover;filter:saturate(.85);}
.other-cat-card-body{padding:18px 20px;}
.other-cat-card h3{font-size:17px;margin-bottom:4px;color:var(--anchor);}
.other-cat-card p{font-size:12.5px;color:var(--pine);opacity:.78;}
.footer-col a{display:block;font-size:13px;color:rgba(250,245,234,.75);margin-bottom:8px;}
@media(max-width:900px){section{padding:48px 0;}.footer-grid{grid-template-columns:1fr 1fr;gap:28px;}}
@media(max-width:640px){body{font-size:14px;}section{padding:40px 0;}.nav-links{display:none;position:fixed;top:62px;left:0;right:0;background:var(--cream);flex-direction:column;padding:14px 5%;align-items:stretch;gap:0;border-bottom:1px solid var(--sage);box-shadow:0 8px 24px rgba(63,79,54,.1);z-index:199;max-height:calc(100vh - 62px);overflow-y:auto;}.nav-links.open{display:flex;}.nav-links>li{width:100%;}.nav-links a,.nav-links .nav-trigger{padding:14px 0;width:100%;border-bottom:1px solid rgba(183,194,166,.22);font-size:14px;}.nav-trigger{justify-content:space-between;}.dropdown{position:static;opacity:1;visibility:visible;transform:none;pointer-events:auto;background:transparent;border:none;padding:0;box-shadow:none;display:none;min-width:auto;}.nav-item.open .dropdown{display:block;}.dropdown a{padding:10px 0 10px 14px;font-size:13px;border-bottom:1px solid rgba(183,194,166,.15);color:var(--forest);}.nav-links .btn-nav{margin-top:10px;text-align:center;border-bottom:none;border-radius:6px;}.hamburger{display:flex;}.float-btn-label{display:none;}.float-btn{padding:12px;border-radius:50%;}.footer-grid{grid-template-columns:1fr;gap:24px;}.newsletter-form{flex-direction:column;}.newsletter-form button{padding:11px;}}
.cats-section{background:var(--cream);}
.cats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px;margin-top:36px;}
.cat-card{background:var(--linen);border-radius:16px;overflow:hidden;cursor:pointer;transition:transform .4s cubic-bezier(.4,0,.2,1),box-shadow .4s;display:block;color:var(--pine);text-decoration:none;}
.cat-card:hover{transform:translateY(-6px);box-shadow:0 22px 48px rgba(63,79,54,.18);}
.cat-card-img{width:100%;aspect-ratio:4/3;object-fit:cover;filter:saturate(.85);transition:transform .5s ease;}
.cat-card:hover .cat-card-img{transform:scale(1.04);}
.cat-card-body{padding:26px 24px;}
.cat-card-meta{font-family:'Montserrat';font-weight:600;font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--forest);opacity:.85;margin-bottom:8px;}
.cat-card h3{font-size:22px;margin-bottom:10px;color:var(--anchor);}
.cat-card p{font-size:14px;color:var(--pine);opacity:.85;line-height:1.6;margin-bottom:18px;}
.cat-card-features{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px;}
.cat-card-feat{font-size:11px;padding:5px 11px;background:var(--cream);color:var(--forest);border-radius:50px;}
.cat-card-cta{font-family:'Montserrat';font-weight:600;font-size:13px;letter-spacing:.08em;color:var(--anchor);display:inline-flex;align-items:center;gap:8px;}
.cat-card-cta::after{content:"→";transition:transform .25s;}
.cat-card:hover .cat-card-cta::after{transform:translateX(4px);}
.approach-section{background:var(--linen);}
.approach-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:28px;}
.approach-card{padding:24px 22px;border-left:3px solid var(--sage);background:var(--cream);border-radius:0 12px 12px 0;}
.approach-card h3{font-size:18px;margin-bottom:8px;color:var(--anchor);}
.approach-card p{font-size:13.5px;color:var(--pine);opacity:.85;line-height:1.6;}
@media(max-width:900px){ section{padding:56px 0;} .cats-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px;} .approach-grid{grid-template-columns:1fr;} .footer-grid{grid-template-columns:1fr 1fr;gap:28px;} }
@media(max-width:640px){ body{font-size:14px;} section{padding:44px 0;} .nav-links{display:none;position:fixed;top:62px;left:0;right:0;background:var(--cream);flex-direction:column;padding:14px 5%;align-items:stretch;gap:0;border-bottom:1px solid var(--sage);box-shadow:0 8px 24px rgba(63,79,54,.1);z-index:199;max-height:calc(100vh - 62px);overflow-y:auto;} .nav-links.open{display:flex;} .nav-links>li{width:100%;} .nav-links a,.nav-links .nav-trigger{padding:14px 0;width:100%;border-bottom:1px solid rgba(183,194,166,.22);font-size:14px;} .nav-trigger{justify-content:space-between;} .dropdown{position:static;opacity:1;visibility:visible;transform:none;pointer-events:auto;background:transparent;border:none;padding:0;box-shadow:none;display:none;min-width:auto;} .nav-item.open .dropdown{display:block;} .dropdown a{padding:10px 0 10px 14px;font-size:13px;border-bottom:1px solid rgba(183,194,166,.15);color:var(--forest);} .nav-links .btn-nav{margin-top:10px;text-align:center;border-bottom:none;border-radius:6px;} .hamburger{display:flex;} .float-btn-label{display:none;} .float-btn{padding:12px;border-radius:50%;} .cats-grid{grid-template-columns:1fr;} .footer-grid{grid-template-columns:1fr;gap:24px;} .newsletter-form{flex-direction:column;} .newsletter-form button{padding:11px;} .cta-banner-btns{flex-direction:column;align-items:stretch;} }

/* ── Catalog mode: quote button + Woo chrome cleanup ─────────── */
.btn-quote,
.btn-quote.button,
a.btn-quote,
button.btn-quote {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--anchor);
  color: var(--cream);
  padding: 13px 26px;
  border: none;
  border-radius: 6px;
  font-family: 'Montserrat', sans-serif;
  font-weight: 600;
  font-size: 14px;
  text-decoration: none;
  transition: all 0.2s ease;
  cursor: pointer;
}
.btn-quote:hover,
.btn-quote.button:hover {
  background: var(--pine);
  transform: scale(1.02);
  box-shadow: 0 6px 22px rgba(14, 61, 112, 0.22);
  color: var(--cream);
}

.single-product-quote-cta { margin-top: 24px; }

/* Woo product card layout (uses [products] shortcode) */
.woocommerce ul.products,
.woocommerce-page ul.products {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 22px;
  list-style: none;
  padding: 0;
  margin: 0;
}
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
  background: var(--linen);
  border-radius: 14px;
  overflow: hidden;
  width: auto !important;
  margin: 0 !important;
  padding: 0 !important;
  float: none !important;
  clear: none !important;
  transition: transform 0.4s, box-shadow 0.4s;
}
.woocommerce ul.products li.product:hover {
  transform: translateY(-6px);
  box-shadow: 0 20px 44px rgba(63,79,54,.16);
}
.woocommerce ul.products li.product a img {
  width: 100%;
  aspect-ratio: 4/3;
  object-fit: cover;
  filter: saturate(.85);
  margin: 0 !important;
}
.woocommerce ul.products li.product .woocommerce-loop-product__title {
  padding: 18px 20px 6px !important;
  font-family: 'Fraunces', serif;
  font-size: 18px !important;
  color: var(--anchor) !important;
  font-weight: 500 !important;
}
.woocommerce ul.products li.product .btn-quote {
  margin: 0 20px 22px;
}

/* Hide Woo native chrome */
.woocommerce .woocommerce-result-count,
.woocommerce-page .woocommerce-result-count,
.woocommerce .woocommerce-ordering,
.woocommerce-page .woocommerce-ordering,
.woocommerce .price,
.woocommerce-Price-amount,
.woocommerce-loop-product__price {
  display: none !important;
}

/* ── Polish round 2: logo + nav + hero overflow ───────── */

/* 1) Logo — keep square ratio (source is 361×376) */
.logo-img,
.site-header img.logo-img,
header img.logo-img,
.wp-block-site-logo img {
  width: 44px !important;
  height: 44px !important;
  object-fit: contain;
  display: block;
}

/* 2) Header navigation — prevent 2-line wrap, breathing room */
:root { --max-w: 1280px; }
.site-header > .container,
.site-header .nav-inner {
  max-width: var(--bs-container-max, 1140px);
  margin: 0 auto;
  padding-left: var(--bs-container-px, clamp(20px, 4vw, 40px));
  padding-right: var(--bs-container-px, clamp(20px, 4vw, 40px));
}
.nav-inner {
  flex-wrap: nowrap;
  gap: 18px;
}
.nav-links {
  flex-wrap: nowrap;
  gap: 18px;
}
.nav-links > li {
  white-space: nowrap;
  flex-shrink: 0;
}
.nav-links a,
.nav-links .nav-trigger {
  font-size: 13px;
  padding: 6px 0;
  white-space: nowrap;
}
.lang-switcher { gap: 4px !important; margin: 0 4px; }
.lang-switcher a { padding: 4px 6px !important; font-size: 11px !important; }

@media(max-width: 1100px) {
  .nav-links { gap: 14px; }
  .nav-links a, .nav-links .nav-trigger { font-size: 12.5px; }
  .lang-switcher a { font-size: 10.5px !important; padding: 3px 5px !important; }
}
@media(max-width: 980px) {
  .nav-links a, .nav-links .nav-trigger { font-size: 12px; }
  .nav-links { gap: 12px; }
  .btn-nav { padding: 8px 14px !important; font-size: 11.5px !important; }
}

/* 3) Hero section — center + container padding (fixes edge overflow)
   Updated R5: align legacy is-layout-constrained sections to 1140 match --bs-container-max.
   Sections that need full-bleed bg should use .bs-section (no max-width) + .bs-container inside. */
.wp-block-group.is-layout-constrained:not(.bs-section) {
  padding-left: var(--pad-x, 5%);
  padding-right: var(--pad-x, 5%);
  margin-left: auto;
  margin-right: auto;
  max-width: 1140px;
  box-sizing: border-box;
}
.wp-block-group.is-layout-constrained > .wp-block-columns,
.wp-block-group.is-layout-constrained > .wp-block-html {
  max-width: 100%;
}
/* But un-pad the outer pattern wrappers that have their own .container inside */
.wp-block-group:has(> .container) {
  padding-left: 0;
  padding-right: 0;
}
/* Re-allow full-bleed backgrounds for sections that should color edge-to-edge */
.wp-block-group.has-background.is-layout-constrained {
  /* Already padded, keep */
}

/* Hero columns: ensure image col never wider than 45% on desktop */
.wp-block-columns .wp-block-column { box-sizing: border-box; }
.hero-image-wrap { max-width: 100%; }

/* 4) Legacy `.container` wrappers (footer, hero-homepage, etc) — match --bs-container-max */
.site-footer > .container,
.hero-section-wrap .container,
.cats-section .container,
.services-section .container,
.why-section .container,
.partners-section .container,
.factory-section .container,
.cta-final .container {
  max-width: var(--bs-container-max, 1140px);
  margin: 0 auto;
  padding-left: var(--bs-container-px, clamp(20px, 4vw, 40px));
  padding-right: var(--bs-container-px, clamp(20px, 4vw, 40px));
}

/* ── Blog archive — post cards grid ──────────────────── */
.wp-block-query .posts-list,
.wp-block-query .wp-block-post-template {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 24px;
  list-style: none;
  padding: 0;
  margin: 0;
}
.wp-block-query .post-card {
  background: var(--linen);
  border-radius: 14px;
  overflow: hidden;
  transition: transform .35s, box-shadow .35s;
  display: flex !important;
  flex-direction: column;
  height: 100%;
}
.wp-block-query .post-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 16px 40px rgba(63,79,54,.14);
}
.wp-block-query .post-card .wp-block-post-featured-image {
  margin: 0;
}
.wp-block-query .post-card .wp-block-post-featured-image img {
  width: 100%;
  aspect-ratio: 16/10;
  object-fit: cover;
  filter: saturate(.85);
}
.wp-block-query .post-card-body {
  padding: 20px 22px 22px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  flex: 1;
}
.wp-block-query .post-card .post-tag {
  font-family: 'Montserrat', sans-serif;
  font-size: 10.5px;
  font-weight: 600;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--forest);
  opacity: .85;
}
.wp-block-query .post-card .post-tag a {
  color: inherit;
  text-decoration: none;
}
.wp-block-query .post-card h3 {
  font-family: 'Fraunces', serif;
  font-size: 17px !important;
  line-height: 1.3;
  margin: 4px 0 6px;
  color: var(--anchor);
}
.wp-block-query .post-card h3 a { color: inherit; }
.wp-block-query .post-card .wp-block-post-excerpt {
  font-size: 13px;
  color: var(--pine);
  opacity: .85;
  line-height: 1.55;
}
.wp-block-query .post-card .post-meta {
  font-size: 11px;
  color: var(--pine);
  opacity: .6;
  margin-top: auto;
}
.wp-block-query .wp-block-query-pagination {
  margin-top: 42px;
  gap: 8px;
  flex-wrap: wrap;
}
.wp-block-query .wp-block-query-pagination-numbers .page-numbers,
.wp-block-query .wp-block-query-pagination-next,
.wp-block-query .wp-block-query-pagination-previous {
  background: transparent;
  border: 1px solid rgba(91,114,80,.25);
  color: var(--pine);
  font-family: 'Montserrat', sans-serif;
  font-weight: 600;
  font-size: 13px;
  padding: 10px 16px;
  border-radius: 50px;
  text-decoration: none;
  transition: all .2s;
}
.wp-block-query .wp-block-query-pagination-numbers .current {
  background: var(--anchor);
  color: var(--cream);
  border-color: var(--anchor);
}

/* ── Polish round 3: hero breathing room ─────────────── */

/* Reduce site-wide max-width + increase side padding for spacious layout */
:root {
  --max-w: 1140px;
  --pad-x: 6%;
}

@media(min-width: 1280px) {
  :root { --max-w: 1140px; --pad-x: clamp(24px, 6vw, 96px); }
}
@media(min-width: 1600px) {
  :root { --pad-x: clamp(48px, 10vw, 160px); }
}

/* Force hero section to use generous padding regardless of FSE constraint */
.hero-section-wrap {
  padding-left: 0 !important;
  padding-right: 0 !important;
}
.hero-section-wrap > .container.hero-section {
  max-width: var(--max-w);
  margin: 0 auto;
  padding-left: var(--pad-x);
  padding-right: var(--pad-x);
  display: grid;
  grid-template-columns: 1.05fr .95fr;
  gap: clamp(32px, 5vw, 64px);
  align-items: center;
}

/* Page hero (about, shop, contact) — match same generous padding */
.page-hero {
  padding-left: 0 !important;
  padding-right: 0 !important;
}
.page-hero > .wp-block-html,
.page-hero > .wp-block-heading,
.page-hero > .wp-block-paragraph,
.page-hero > p {
  max-width: var(--max-w);
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: var(--pad-x);
  padding-right: var(--pad-x);
  box-sizing: border-box;
}

@media(max-width: 900px) {
  .hero-section-wrap > .container.hero-section {
    grid-template-columns: 1fr;
    gap: 28px;
  }
}

/* ── MEGA MENU + SEARCH OVERLAY ────────────────────────── */

/* Search icon button */
.nav-search-trigger .search-btn {
  background: transparent;
  border: 1px solid transparent;
  color: var(--pine);
  width: 34px;
  height: 34px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all .2s;
  padding: 0;
}
.nav-search-trigger .search-btn:hover {
  background: var(--linen);
  color: var(--anchor);
}

/* Search overlay — full viewport */
.search-overlay {
  position: fixed;
  inset: 0;
  background: rgba(15, 24, 12, .94);
  z-index: 1200;
  display: none;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  padding: 24px;
  animation: fadeIn .25s ease;
}
.search-overlay.open { display: flex; }
.search-overlay-close {
  position: absolute;
  top: 22px;
  right: 26px;
  background: rgba(250,245,234,.15);
  border: none;
  color: rgba(250,245,234,.9);
  font-size: 26px;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  cursor: pointer;
  transition: background .2s;
  line-height: 1;
}
.search-overlay-close:hover {
  background: rgba(250,245,234,.3);
  color: var(--cream);
}
.search-form {
  display: flex;
  align-items: center;
  gap: 0;
  width: 100%;
  max-width: 720px;
  background: var(--cream);
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 30px 80px rgba(0,0,0,.4);
}
.search-form input[type="search"] {
  flex: 1;
  border: none;
  outline: none;
  padding: 22px 26px;
  font-family: 'Fraunces', serif;
  font-size: clamp(18px, 2.4vw, 26px);
  font-weight: 400;
  font-style: italic;
  color: var(--pine);
  background: transparent;
  width: 100%;
}
.search-form input::placeholder {
  color: var(--pine);
  opacity: .4;
  font-style: italic;
}
.search-submit {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border: none;
  background: var(--anchor);
  color: var(--cream);
  padding: 0 32px;
  height: 100%;
  font-family: 'Montserrat', sans-serif;
  font-weight: 600;
  font-size: 15px;
  cursor: pointer;
  transition: background .2s;
}
.search-submit:hover { background: var(--pine); }
.search-hint {
  margin-top: 18px;
  font-size: 12px;
  color: rgba(250,245,234,.6);
  letter-spacing: .04em;
}

/* MEGA MENU — full-width below header */
.nav-links > li.nav-mega { position: static; }
.nav-mega .mega-menu {
  position: absolute;
  top: calc(100% + 1px);
  left: 0;
  right: 0;
  background: var(--cream);
  border-top: 1px solid rgba(183,194,166,.4);
  border-bottom: 1px solid rgba(183,194,166,.4);
  box-shadow: 0 24px 56px rgba(63,79,54,.16);
  opacity: 0;
  visibility: hidden;
  transform: translateY(8px);
  transition: opacity .25s ease, visibility .25s, transform .25s ease;
  pointer-events: none;
  padding: 36px 0 40px;
}
.nav-mega.open .mega-menu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  pointer-events: auto;
}
.mega-inner {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 var(--pad-x);
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 40px;
  justify-content: center;
  align-items: start;
}
.mega-menu-news .mega-inner {
  grid-template-columns: 1fr 1.6fr;
}
.mega-col {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.mega-eyebrow {
  font-family: 'Montserrat', sans-serif;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--forest);
  opacity: .85;
}
.mega-col h4 {
  font-family: 'Fraunces', serif;
  font-weight: 500;
  font-style: normal;
  font-size: 22px;
  color: var(--anchor);
  margin: 4px 0 10px;
  letter-spacing: -0.005em;
}
.mega-col a {
  font-family: 'Montserrat', sans-serif;
  font-size: 13.5px;
  font-weight: 400;
  color: var(--pine);
  text-decoration: none;
  padding: 5px 0;
  border-bottom: 1px solid transparent;
  transition: color .2s, border-color .2s, padding-left .2s;
  align-self: flex-start;
}
.mega-col a:hover {
  color: var(--anchor);
  border-bottom-color: var(--sun);
  padding-left: 4px;
}
.mega-feature {
  background: var(--linen);
  border-radius: 14px;
  padding: 22px 22px 24px;
  gap: 8px;
}
.mega-feature img {
  width: 100%;
  aspect-ratio: 16/10;
  object-fit: cover;
  border-radius: 10px;
  filter: saturate(.85);
  margin-bottom: 10px;
}
.mega-feature p {
  font-size: 13px;
  color: var(--pine);
  opacity: .85;
  line-height: 1.55;
  margin: 4px 0 12px;
}
.mega-cta {
  font-family: 'Montserrat', sans-serif;
  font-weight: 600;
  font-size: 13px;
  letter-spacing: .04em;
  color: var(--anchor);
  text-decoration: none;
  border-bottom: 2px solid var(--sun);
  align-self: flex-start;
  padding-bottom: 2px;
}
.mega-feature .mega-cta:hover {
  color: var(--pine);
}

/* Mobile mega menu — collapse into accordion */
@media(max-width: 900px) {
  .nav-mega .mega-menu {
    position: static;
    box-shadow: none;
    border: none;
    padding: 0;
    background: transparent;
    transform: none;
  }
  .mega-inner {
    display: block;
    padding: 14px 0 8px 14px;
  }
  .mega-feature { display: none; }
  .mega-col + .mega-col { margin-top: 14px; }
  .mega-col h4 { font-size: 16px; margin: 6px 0 6px; }
  .mega-col a { font-size: 13px; padding: 6px 0; }
  .nav-search-trigger { order: -1; }
}
@media(max-width: 640px) {
  .nav-mega .mega-menu { display: none; }
  .nav-mega.open .mega-menu { display: block; }
  .search-form input[type="search"] { padding: 18px 20px; font-size: 18px; }
  .search-submit { padding: 0 18px; }
  .search-submit span { display: none; }
}

/* ── FLAG DROPDOWN LANGUAGE SWITCHER ───────────────────── */
.lang-switcher {
  position: relative;
  list-style: none;
}
.lang-current {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: transparent;
  border: 1px solid rgba(91,114,80,.25);
  border-radius: 50px;
  padding: 5px 10px 5px 8px;
  cursor: pointer;
  font-family: 'Montserrat', sans-serif;
  font-size: 12px;
  font-weight: 600;
  color: var(--pine);
  transition: all .2s;
}
.lang-current:hover { border-color: var(--forest); background: var(--linen); }
.lang-current .lang-flag { font-size: 15px; line-height: 1; }
.lang-current .lang-code { letter-spacing: .04em; }
.lang-current .lang-caret {
  width: 6px; height: 6px;
  border-right: 1.5px solid currentColor;
  border-bottom: 1.5px solid currentColor;
  transform: rotate(45deg) translate(-1px,-1px);
  transition: transform .25s;
  margin-left: 2px;
}
.lang-switcher.open .lang-caret { transform: rotate(-135deg) translate(-1px,-1px); }

.lang-dropdown {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  min-width: 170px;
  background: var(--cream);
  border: 1px solid rgba(183,194,166,.4);
  border-radius: 12px;
  padding: 8px;
  box-shadow: 0 16px 40px rgba(63,79,54,.16);
  list-style: none;
  margin: 0;
  opacity: 0;
  visibility: hidden;
  transform: translateY(8px);
  transition: all .22s ease;
  pointer-events: none;
  z-index: 250;
}
.lang-switcher:hover .lang-dropdown,
.lang-switcher.open .lang-dropdown,
.lang-switcher:focus-within .lang-dropdown {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  pointer-events: auto;
}
.lang-dropdown li { width: 100%; }
.lang-dropdown a {
  display: flex !important;
  align-items: center;
  gap: 10px;
  padding: 9px 12px !important;
  border-radius: 8px;
  font-family: 'Montserrat', sans-serif;
  font-size: 13px !important;
  font-weight: 500;
  color: var(--pine) !important;
  text-decoration: none;
  transition: background .18s, color .18s;
  white-space: nowrap;
  border: none !important;
}
.lang-dropdown a:hover { background: var(--linen); color: var(--anchor) !important; }
.lang-dropdown a.active { background: var(--linen); color: var(--anchor) !important; }
.lang-dropdown a.active::after {
  content: "✓";
  margin-left: auto;
  color: var(--sun);
  font-weight: 700;
}
.lang-dropdown .lang-flag { font-size: 17px; line-height: 1; }

/* Language nudge banner (browser auto-detect) */
.lang-nudge {
  position: fixed;
  left: 50%;
  bottom: 24px;
  transform: translateX(-50%) translateY(140%);
  z-index: 400;
  background: var(--anchor);
  color: var(--cream);
  border-radius: 12px;
  padding: 14px 18px;
  display: flex;
  align-items: center;
  gap: 14px;
  box-shadow: 0 16px 48px rgba(14,61,112,.3);
  font-family: 'Montserrat', sans-serif;
  font-size: 13.5px;
  max-width: 92vw;
  transition: transform .4s cubic-bezier(.4,0,.2,1);
}
.lang-nudge.show { transform: translateX(-50%) translateY(0); }
.lang-nudge .lang-nudge-flag { font-size: 20px; }
.lang-nudge a {
  background: var(--sun);
  color: var(--pine);
  padding: 7px 16px;
  border-radius: 50px;
  font-weight: 700;
  font-size: 12.5px;
  text-decoration: none;
  white-space: nowrap;
  transition: transform .2s;
}
.lang-nudge a:hover { transform: scale(1.04); }
.lang-nudge button {
  background: transparent;
  border: none;
  color: rgba(250,245,234,.7);
  font-size: 20px;
  cursor: pointer;
  line-height: 1;
  padding: 0 2px;
}
.lang-nudge button:hover { color: var(--cream); }

@media(max-width: 640px) {
  .lang-dropdown { right: auto; left: 0; }
  .lang-nudge { flex-direction: column; text-align: center; bottom: 16px; }
}

/* ─────────────────────────────────────────────
   Polish R3 — Phase 3
   ───────────────────────────────────────────── */

/* Footer logo — force square to prevent host-cache squashing the prod 200×… file. */
.logo-footer { width: 44px; height: 44px; object-fit: contain; display: inline-block; }

/* 6-card 3×2 cats grid */
.cats-grid-6 { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 22px; margin-top: 36px; }
.cats-grid-6 .cat-card { background: var(--cream); border-radius: 14px; overflow: hidden; display: flex; flex-direction: column; transition: transform .4s cubic-bezier(.4,0,.2,1), box-shadow .4s; color: var(--pine); text-decoration: none; border: 1px solid rgba(183,194,166,.28); }
.cats-grid-6 .cat-card:hover { transform: translateY(-6px); box-shadow: 0 20px 44px rgba(63,79,54,.16); }
.cats-grid-6 .cat-card-img { width: 100%; aspect-ratio: 4/3; object-fit: cover; filter: saturate(.88); display: block; }
.cats-grid-6 .cat-card-body { padding: 20px 22px 22px; }
.cats-grid-6 .cat-card-body h3 { font-family: 'Fraunces', serif; font-weight: 500; font-size: 19px; color: var(--anchor); margin: 0 0 8px; }
.cats-grid-6 .cat-card-body p { font-size: 13px; line-height: 1.55; color: var(--pine); opacity: .85; margin: 0 0 12px; }
.cats-grid-6 .cat-card-cta { font-family: 'Montserrat', sans-serif; font-weight: 600; font-size: 12px; letter-spacing: .04em; color: var(--anchor); border-bottom: 2px solid var(--sun); padding-bottom: 2px; align-self: flex-start; }
.cats-grid-footer { display: flex; justify-content: center; margin-top: 36px; }

/* Services CPT grid (3×2) */
.services-grid-6 { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 22px; margin-top: 36px; }
.services-grid-6 .service-card { background: var(--linen); border-radius: 14px; overflow: hidden; padding: 0; border-top: 3px solid var(--sage); display: flex; flex-direction: column; transition: transform .4s, box-shadow .4s; color: var(--pine); text-decoration: none; }
.services-grid-6 .service-card:hover { transform: translateY(-4px); box-shadow: 0 16px 36px rgba(63,79,54,.12); border-top-color: var(--sun); }
.services-grid-6 .service-card-img { width: 100%; aspect-ratio: 16/10; object-fit: cover; filter: saturate(.88); display: block; }
.services-grid-6 .service-card-body { padding: 22px 22px 24px; }
.services-grid-6 .service-card-body h3 { font-family: 'Fraunces', serif; font-weight: 500; font-size: 19px; color: var(--anchor); margin: 0 0 8px; }
.services-grid-6 .service-card-body p { font-size: 13px; line-height: 1.55; color: var(--pine); opacity: .85; margin: 0 0 12px; }
.services-grid-6 .service-card-cta { font-family: 'Montserrat', sans-serif; font-weight: 600; font-size: 12px; letter-spacing: .04em; color: var(--anchor); border-bottom: 2px solid var(--sun); padding-bottom: 2px; align-self: flex-start; display: inline-block; }
.services-grid-footer { display: flex; justify-content: center; margin-top: 36px; }

/* Anchor outline CTA used by grid footers */
.btn-anchor-outline { font-family: 'Montserrat', sans-serif; font-weight: 600; font-size: 13px; letter-spacing: .04em; color: var(--anchor); padding: 14px 28px; border: 1.5px solid var(--anchor); border-radius: 10px; background: transparent; text-decoration: none; transition: background .2s, color .2s; }
.btn-anchor-outline:hover { background: var(--anchor); color: var(--cream); }

@media(max-width: 900px) {
  .cats-grid-6 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .services-grid-6 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media(max-width: 640px) {
  .cats-grid-6 { grid-template-columns: 1fr; }
  .services-grid-6 { grid-template-columns: 1fr; }
}

/* ─────────────────────────────────────────────
   Polish R3 — Phase 4 — About Us page
   ───────────────────────────────────────────── */

/* About hero */
.about-hero { text-align: left; }
.about-hero h1 { max-width: 880px; }
.about-hero-tagline { font-family: 'Fraunces', serif; font-style: italic; font-weight: 400; font-size: clamp(18px, 2vw, 22px); color: var(--pine); max-width: 720px; margin: 16px 0 24px; line-height: 1.5; }
.about-hero-meta { display: flex; flex-wrap: wrap; gap: 12px; font-family: 'Montserrat', sans-serif; font-size: 12.5px; color: var(--forest); letter-spacing: .03em; opacity: .85; }
.about-hero-meta span { display: inline-block; }

/* About intro */
.about-intro-body { max-width: 820px; margin-top: 24px; }
.about-intro-body p { font-size: 15px; line-height: 1.7; color: var(--pine); margin-bottom: 18px; }
.about-intro-partners { display: flex; flex-wrap: wrap; align-items: center; gap: 18px 24px; margin-top: 36px; padding-top: 24px; border-top: 1px solid rgba(183,194,166,.4); }
.about-intro-partners-label { font-family: 'Montserrat', sans-serif; font-size: 11px; letter-spacing: .28em; text-transform: uppercase; color: var(--forest); opacity: .8; }
.about-intro-partner { font-family: 'Fraunces', serif; font-weight: 500; font-size: 18px; color: var(--anchor); letter-spacing: .04em; }
.about-intro-partner:last-child { font-family: 'Montserrat', sans-serif; font-weight: 400; font-style: italic; font-size: 13px; color: var(--pine); opacity: .75; letter-spacing: 0; }

/* About scale (stats + cert badges) */
.about-scale-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 32px; margin-top: 36px; }
.about-scale-stat { display: flex; flex-direction: column; gap: 8px; padding: 24px 4px; border-top: 2px solid var(--sun); }
.about-scale-num { font-family: 'Fraunces', serif; font-style: italic; font-weight: 500; font-size: clamp(32px, 4vw, 44px); color: var(--anchor); line-height: 1; }
.about-scale-label { font-family: 'Montserrat', sans-serif; font-size: 13px; line-height: 1.55; color: var(--pine); opacity: .85; }
.about-scale-certs { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 32px; }
.about-scale-cert { font-family: 'Montserrat', sans-serif; font-weight: 600; font-size: 12px; letter-spacing: .14em; text-transform: uppercase; color: var(--anchor); background: var(--linen); padding: 10px 18px; border-radius: 999px; border: 1px solid rgba(63,90,127,.18); }

/* About capabilities — now uses .bs-card .bs-card--stat */

/* About process (flow + machine list) */
.about-process-flow { display: flex; flex-wrap: wrap; align-items: center; gap: 8px 10px; margin-top: 32px; padding: 24px; background: var(--cream); border-radius: 14px; }
.about-process-step { font-family: 'Montserrat', sans-serif; font-weight: 600; font-size: 12.5px; color: var(--anchor); background: white; padding: 10px 16px; border-radius: 8px; border: 1px solid rgba(183,194,166,.5); }
.about-process-arrow { color: var(--forest); font-weight: 700; opacity: .55; }
.about-process-machines { margin-top: 36px; }
.about-process-machines h3 { font-family: 'Fraunces', serif; font-weight: 500; font-size: 22px; color: var(--anchor); margin-bottom: 8px; }
.about-process-machines p { font-size: 14px; color: var(--pine); opacity: .85; margin-bottom: 18px; }
.about-process-machine-list { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 10px 18px; list-style: none; padding: 0; margin: 0; }
.about-process-machine-list li { font-family: 'Montserrat', sans-serif; font-size: 13px; color: var(--pine); padding: 10px 14px; background: white; border-radius: 8px; border-left: 3px solid var(--sun); }
.about-process-machine-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 18px; }
.about-process-machine-grid .machine-card { margin: 0; background: white; border-radius: 10px; overflow: hidden; box-shadow: 0 2px 10px rgba(0,0,0,.06); }
.about-process-machine-grid .machine-card img { display: block; width: 100%; height: 150px; object-fit: cover; }
.about-process-machine-grid .machine-card figcaption { font-family: 'Montserrat', sans-serif; font-size: 13px; font-weight: 600; color: var(--pine); padding: 10px 12px; text-align: center; }

/* About QC (2-col list) */
.about-qc-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 36px; margin-top: 32px; }
.about-qc-col h3 { font-family: 'Fraunces', serif; font-weight: 500; font-size: 22px; color: var(--anchor); margin-bottom: 14px; }
.about-qc-list { padding-left: 22px; margin: 0; }
.about-qc-list li { font-family: 'Montserrat', sans-serif; font-size: 14px; line-height: 1.75; color: var(--pine); }
.about-qc-list-bullet { list-style: none; padding-left: 0; }
.about-qc-list-bullet li { position: relative; padding-left: 22px; }
.about-qc-list-bullet li::before { content: ""; position: absolute; left: 0; top: 10px; width: 8px; height: 8px; background: var(--sun); border-radius: 50%; }

/* About export (markets + strengths) */
.about-export-markets { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 30px; }
.about-export-market { font-family: 'Fraunces', serif; font-weight: 500; font-size: 16px; color: var(--anchor); background: white; padding: 14px 24px; border-radius: 999px; border: 1.5px solid var(--anchor); }
.about-export-strengths { margin-top: 40px; }
.about-export-strengths h3 { font-family: 'Fraunces', serif; font-weight: 500; font-size: 22px; color: var(--anchor); margin-bottom: 14px; }
.about-export-strengths ul { padding-left: 22px; margin: 0; }
.about-export-strengths li { font-family: 'Montserrat', sans-serif; font-size: 14px; line-height: 1.75; color: var(--pine); }

/* About why-choose — now uses .bs-card .bs-card--stat .bs-card--stat-muted */

@media(max-width: 900px) {
  .about-scale-grid { grid-template-columns: 1fr; gap: 22px; }
  .about-process-machine-list { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .about-process-machine-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .about-qc-grid { grid-template-columns: 1fr; gap: 28px; }
}
@media(max-width: 640px) {
  .about-process-machine-list { grid-template-columns: 1fr; }
  .about-process-machine-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .about-process-flow { padding: 16px; }
  .about-process-step { font-size: 12px; padding: 8px 12px; }
  .about-export-markets { gap: 8px; }
  .about-export-market { font-size: 14px; padding: 10px 16px; }
}

/* ═════════════════════════════════════════════════════════════════════════
   DESIGN SYSTEM R4 — TOKENS + UTILITIES + UNIFIED CARD PATTERN
   Standardize section spacing, container, 12-col grid, card markup.
   Namespace `--bs-*` + `.bs-*` để không conflict với existing vars/classes.
   ═════════════════════════════════════════════════════════════════════════ */

:root {
  /* Vertical rhythm */
  --bs-section-py:     clamp(56px, 7vw, 96px);
  --bs-section-py-sm:  clamp(40px, 5vw, 64px);
  --bs-section-py-lg:  clamp(72px, 9vw, 120px);

  /* Container */
  --bs-container-max:  1140px;
  --bs-container-px:   clamp(20px, 4vw, 40px);

  /* Section head spacing (eyebrow → h2 → lead → grid) */
  --bs-eyebrow-mb:     14px;
  --bs-h2-mb:          16px;
  --bs-lead-mb:        32px;
  --bs-head-grid-gap:  40px;

  /* Grid gaps */
  --bs-row-gap:        22px;
  --bs-row-gap-tight:  14px;
  --bs-row-gap-loose:  32px;

  /* Card tokens */
  --bs-card-radius:    14px;
  --bs-card-pad:       clamp(20px, 2.5vw, 28px);
  --bs-card-media-ratio: 4 / 3;
}

/* ── Section + Container ────────────────────────────────────────────────── */
.bs-section       { padding-block: var(--bs-section-py); }
.bs-section--sm   { padding-block: var(--bs-section-py-sm); }
.bs-section--lg   { padding-block: var(--bs-section-py-lg); }

.bs-container     {
  max-width: var(--bs-container-max);
  margin-inline: auto;
  padding-inline: var(--bs-container-px);
}

/* ── Section head (eyebrow + h2 + lead) ─────────────────────────────────── */
.bs-section-head                      { margin-bottom: var(--bs-head-grid-gap); }
.bs-section-head .eyebrow             { display: block; margin-bottom: var(--bs-eyebrow-mb); }
.bs-section-head h2                   { margin-bottom: var(--bs-h2-mb); }
.bs-section-head .lead                { margin-bottom: var(--bs-lead-mb); max-width: 720px; font-size: 15px; line-height: 1.7; color: var(--pine); opacity: .9; }
.bs-section-head > *:last-child       { margin-bottom: 0; }

/* ── 12-col row grid ────────────────────────────────────────────────────── */
.bs-row              { display: grid; gap: var(--bs-row-gap); }
.bs-row--cols-2      { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.bs-row--cols-3      { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.bs-row--cols-4      { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.bs-row--cols-6      { grid-template-columns: repeat(6, minmax(0, 1fr)); }
.bs-row--gap-tight   { gap: var(--bs-row-gap-tight); }
.bs-row--gap-loose   { gap: var(--bs-row-gap-loose); }

/* ── Unified card pattern ───────────────────────────────────────────────── */
.bs-card {
  background: var(--cream);
  border-radius: var(--bs-card-radius);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: var(--pine);
  border: 1px solid rgba(183, 194, 166, .28);
  transition: transform .4s cubic-bezier(.4, 0, .2, 1), box-shadow .4s, border-color .4s;
}
.bs-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 20px 44px rgba(63, 79, 54, .16);
  border-color: var(--sage);
}

.bs-card-media {
  width: 100%;
  aspect-ratio: var(--bs-card-media-ratio);
  object-fit: cover;
  display: block;
  filter: saturate(.88);
}

.bs-card-body {
  padding: var(--bs-card-pad);
  display: flex;
  flex-direction: column;
  gap: 8px;
  flex: 1;
}

.bs-card-eyebrow {
  font-family: 'Montserrat', sans-serif;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--forest);
  opacity: .85;
}

.bs-card-title {
  font-family: 'Fraunces', serif;
  font-weight: 500;
  font-size: 19px;
  color: var(--anchor);
  margin: 0;
  line-height: 1.3;
}

.bs-card-text {
  font-size: 13.5px;
  line-height: 1.65;
  color: var(--pine);
  opacity: .85;
  margin: 0;
}

.bs-card-cta {
  font-family: 'Montserrat', sans-serif;
  font-weight: 600;
  font-size: 12px;
  letter-spacing: .04em;
  color: var(--anchor);
  border-bottom: 2px solid var(--sun);
  padding-bottom: 2px;
  align-self: flex-start;
  margin-top: 4px;
  display: inline-block;
}

/* Variant: icon card (SVG icon + heading + text, no media) */
.bs-card--icon {
  background: var(--linen);
  border: none;
  border-top: 3px solid var(--sage);
  border-radius: var(--bs-card-radius);
}
.bs-card--icon:hover { border-top-color: var(--sun); }
.bs-card--icon .bs-card-body  { padding-top: 26px; }
.bs-card--icon .svg-icon      { width: 36px; height: 36px; color: var(--forest); margin-bottom: 8px; }

/* Variant: stat card (large Fraunces number + label + h3 + text) */
.bs-card--stat {
  background: var(--cream);
  border-left: 3px solid var(--sun);
}
.bs-card--stat .bs-card-stat-num {
  font-family: 'Fraunces', serif;
  font-style: italic;
  font-weight: 500;
  font-size: clamp(36px, 4.5vw, 52px);
  color: var(--anchor);
  line-height: 1;
}
.bs-card--stat.bs-card--stat-muted .bs-card-stat-num { opacity: .35; }

/* ── Responsive breakpoints ─────────────────────────────────────────────── */
@media(max-width: 900px) {
  .bs-row--cols-3,
  .bs-row--cols-4,
  .bs-row--cols-6 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media(max-width: 640px) {
  .bs-row--cols-2,
  .bs-row--cols-3,
  .bs-row--cols-4,
  .bs-row--cols-6 { grid-template-columns: 1fr; }
}
