/* DaVinci Products — based on DaVinci Services design system */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Outfit',sans-serif;color:#2a2d2e;background:#fff;line-height:1.7;font-size:16px;overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{cursor:pointer;font:inherit;border:none;background:none}

:root{
  --primary:#224b60;
  --primary-light:#2d6380;
  --dark:#151818;
  --cream:#f6e8dc;
  --gold:#d68434;
  --green:#0c8542;
  --green-light:#edf7f0;
  --grey:#7e8c91;
  --grey-light:#c8cfd2;
  --white:#ffffff;
  --bg-section:#f7f8f9;
  --max-w:1200px;
  --header-h:72px;
  --radius:6px;
  --shadow:0 2px 20px rgba(0,0,0,.06);
  --transition:.3s cubic-bezier(.4,0,.2,1);
}

/* Typography */
h1,h2,h3{font-family:'Outfit',sans-serif;color:var(--dark);line-height:1.25;font-weight:700}
h1{font-size:clamp(2.2rem,5vw,3.6rem);letter-spacing:-.02em}
h2{font-size:clamp(1.6rem,3.5vw,2.4rem);letter-spacing:-.01em}
h3{font-size:clamp(1rem,2vw,1.3rem)}

/* Layout */
.container{max-width:var(--max-w);margin:0 auto;padding:0 24px}
section{padding:72px 0}
.alt-bg{background:var(--bg-section)}
.text-center{text-align:center}
.section-label{display:inline-block;font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--green);margin-bottom:12px}
.section-title{margin-bottom:16px}
.section-desc{color:var(--grey);max-width:640px;margin:0 auto 40px;font-size:1.05rem}

/* Buttons — same as services */
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 36px;border-radius:var(--radius);font-weight:600;font-size:.95rem;transition:all var(--transition);cursor:pointer}
.btn-primary{background:var(--primary);color:var(--white);border:none}
.btn-primary:hover{background:var(--primary-light);transform:translateY(-2px);box-shadow:0 6px 24px rgba(34,75,96,.25);color:#fff}
.btn-green{background:var(--green);color:var(--white);border:none}
.btn-green:hover{background:#0a7038;transform:translateY(-2px);color:#fff}
.btn-outline{border:2px solid var(--primary);color:var(--primary);background:transparent}
.btn-outline:hover{background:var(--primary);color:var(--white)}
.btn-white{border:2px solid rgba(255,255,255,.4);color:#fff;background:transparent}
.btn-white:hover{background:#fff;color:var(--primary)}

/* Header — same as services */
.site-header{position:fixed;top:0;left:0;right:0;height:var(--header-h);background:rgba(255,255,255,.92);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid rgba(0,0,0,.06);z-index:1000;transition:transform .4s ease}
.site-header.hidden{transform:translateY(-100%)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:var(--header-h);max-width:var(--max-w);margin:0 auto;padding:0 24px}
.header-logo{display:flex;align-items:center;gap:10px}
.header-logo img{height:44px;width:auto}
.header-logo span{font-size:1.2rem;font-weight:700;color:var(--primary);white-space:nowrap}
.header-logo .logo-gold{color:var(--gold)}
.header-logo .logo-green{color:var(--green)}
.main-nav{display:flex;align-items:center;gap:32px}
.main-nav a{font-size:.9rem;font-weight:500;color:var(--dark);position:relative;padding:4px 0;transition:color var(--transition)}
.main-nav a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--green);transition:width var(--transition)}
.main-nav a:hover,.main-nav a.active{color:var(--green)}
.main-nav a:hover::after,.main-nav a.active::after{width:100%}
.nav-cta{background:var(--green)!important;color:#fff!important;padding:10px 24px!important;border-radius:var(--radius)!important;font-weight:600!important}
.nav-cta::after{display:none!important}
.nav-cta:hover{background:#0a7038!important}
.nav-toggle{display:none;flex-direction:column;gap:5px;padding:6px}
.nav-toggle span{display:block;width:22px;height:2px;background:var(--dark);border-radius:2px;transition:var(--transition)}
.nav-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);opacity:0;pointer-events:none;transition:opacity .3s;z-index:998}
.nav-overlay.show{opacity:1;pointer-events:auto}

/* Hero */
.hero{padding:calc(var(--header-h) + 48px) 0 56px;background:linear-gradient(160deg,var(--cream) 0%,#fff 40%,var(--bg-section) 100%);text-align:center;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;top:-20%;right:-10%;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(12,133,66,.06),transparent 70%);pointer-events:none}
.hero-logo{width:300px;margin:0 auto 28px;animation:float 6s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}
.hero h1 span{color:var(--green)}
.hero p{color:var(--grey);font-size:1.1rem;margin:16px auto 24px;max-width:560px}
.hero-badges{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-bottom:28px}
.hero-badge{display:inline-flex;align-items:center;gap:6px;font-size:.75rem;font-weight:500;padding:6px 14px;border-radius:99px;background:var(--green-light);border:1px solid rgba(12,133,66,.15);color:var(--green)}

/* Values bar */
.values-bar{background:var(--primary);padding:36px 0;color:#fff}
.values-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;text-align:center}
.value-item{display:flex;flex-direction:column;align-items:center;gap:6px}
.value-icon{width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center}
.value-icon svg{width:20px;height:20px;stroke:#fff;fill:none;stroke-width:2}
.value-label{font-size:.85rem;font-weight:500}
.value-sub{font-size:.7rem;opacity:.6}

/* Filter bar */
.filter-section{padding:14px 0;position:sticky;top:var(--header-h);background:rgba(255,255,255,.95);backdrop-filter:blur(10px);z-index:50;border-bottom:1px solid rgba(0,0,0,.06);transition:transform .3s ease,opacity .3s ease}
.filter-section.hidden{transform:translateY(-100%);opacity:0;pointer-events:none}
.filter-inner{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:center}
.filter-pills{display:flex;gap:5px;flex-wrap:wrap;justify-content:center}
.filter-pill{font-size:.75rem;padding:5px 14px;border-radius:var(--radius);border:1px solid var(--grey-light);background:#fff;color:var(--grey);cursor:pointer;font-family:inherit;font-weight:500;transition:all var(--transition)}
.filter-pill:hover,.filter-pill.active{border-color:var(--green);color:var(--green);background:var(--green-light)}
.filter-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:center;width:100%}
.filter-count{font-size:.68rem;color:var(--grey);white-space:nowrap}
.search-wrap{position:relative}
.search-input{padding:7px 14px 7px 32px;border:1px solid var(--grey-light);border-radius:var(--radius);font-size:.82rem;font-family:inherit;outline:none;width:200px;transition:border-color var(--transition)}
.search-input:focus{border-color:var(--green)}
.search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);width:15px;height:15px;stroke:var(--grey);fill:none;stroke-width:2}
.budget-wrap{display:flex;align-items:center;gap:8px}
.budget-label{font-size:.68rem;color:var(--grey);white-space:nowrap}
.budget-slider{-webkit-appearance:none;appearance:none;width:120px;height:4px;border-radius:2px;background:var(--grey-light);outline:none;transition:all var(--transition)}
.budget-slider::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:var(--green);cursor:pointer;border:2px solid #fff;box-shadow:0 1px 4px rgba(0,0,0,.15)}
.budget-slider::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--green);cursor:pointer;border:2px solid #fff}
.budget-val{font-size:.7rem;font-weight:600;color:var(--green);font-family:'DM Mono',monospace;min-width:32px}

/* Design filter */
.design-section{padding:6px 0 0}
.design-label{font-size:.68rem;font-weight:600;color:var(--grey);margin-bottom:6px;text-align:center}
.design-row{display:flex;gap:5px;flex-wrap:wrap;justify-content:center}
.design-pill{font-size:.72rem;padding:5px 12px;border-radius:var(--radius);border:1px solid var(--grey-light);background:#fff;color:var(--grey);cursor:pointer;font-family:inherit;font-weight:500;transition:all var(--transition);display:inline-flex;align-items:center;gap:4px}
.design-pill:hover,.design-pill.active{border-color:var(--green);color:var(--green);background:var(--green-light)}
.design-count{font-size:.6rem;opacity:.5;font-family:'DM Mono',monospace}

/* Favourites */
.fav-section{padding:48px 0;background:linear-gradient(135deg,var(--cream) 0%,#fff 100%)}
.fav-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.fav-card{position:relative;background:#fff;border:2px solid var(--green);border-radius:var(--radius);overflow:hidden;transition:all var(--transition);color:inherit;display:flex;flex-direction:column}
.fav-card:hover{transform:translateY(-6px);box-shadow:0 8px 32px rgba(12,133,66,.12)}
.fav-badge{position:absolute;top:12px;left:12px;background:var(--green);color:#fff;font-size:.7rem;font-weight:700;padding:4px 12px;border-radius:var(--radius);z-index:2;letter-spacing:.03em}
.fav-img{aspect-ratio:1;overflow:hidden;background:var(--bg-section)}
.fav-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.fav-card:hover .fav-img img{transform:scale(1.05)}
.fav-body{padding:18px;flex:1;display:flex;flex-direction:column}
.fav-cat{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--green);margin-bottom:4px}
.fav-name{font-size:.95rem;font-weight:600;line-height:1.3;margin-bottom:10px}
.fav-price{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.fav-price-old{font-size:.85rem;color:var(--grey);text-decoration:line-through}
.fav-price-new{font-size:1.1rem;font-weight:700;color:var(--green)}
.fav-link{font-size:.75rem;font-weight:600;color:var(--green);margin-top:auto}

/* Product grid */
.products-section{padding:40px 0 80px}
.product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:24px}
.product-card{background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:var(--radius);overflow:hidden;transition:all var(--transition);display:flex;flex-direction:column;color:inherit}
.product-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--green)}
.product-card-img{aspect-ratio:1;overflow:hidden;background:var(--bg-section)}
.product-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.product-card:hover .product-card-img img{transform:scale(1.05)}
.product-card-body{padding:18px;flex:1;display:flex;flex-direction:column}
.product-cat{font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--green);margin-bottom:4px}
.product-name{font-size:.92rem;font-weight:600;line-height:1.35;margin-bottom:auto}
.product-foot{display:flex;align-items:center;justify-content:space-between;padding-top:14px;margin-top:14px;border-top:1px solid rgba(0,0,0,.06)}
.product-price{font-size:1.05rem;font-weight:700;color:var(--primary)}
.product-link{font-size:.75rem;font-weight:600;color:var(--green);display:flex;align-items:center;gap:4px;transition:gap var(--transition)}
.product-card:hover .product-link{gap:8px}
.no-results{text-align:center;padding:60px 20px;color:var(--grey)}

/* About section */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.about-visual{background:var(--bg-section);border-radius:var(--radius);padding:48px;display:flex;align-items:center;justify-content:center;min-height:320px}
.about-visual img{max-width:240px}
.eco-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:20px}
.eco-tag{font-size:.78rem;padding:6px 14px;border-radius:var(--radius);background:var(--green-light);color:var(--green);font-weight:500;border:1px solid rgba(12,133,66,.15)}

/* CTA */
.cta-section{background:var(--primary);padding:72px 0;color:#fff;text-align:center;position:relative;overflow:hidden}
.cta-section::after{content:'';position:absolute;bottom:-60px;right:-60px;width:200px;height:200px;border-radius:50%;background:rgba(12,133,66,.12)}
.cta-section h2{color:#fff;margin-bottom:12px}
.cta-section p{color:rgba(255,255,255,.7);max-width:500px;margin:0 auto 28px;font-size:1.05rem}
.cta-buttons{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* Footer — same as services */
.site-footer{background:var(--dark);color:rgba(255,255,255,.6);padding:48px 0 24px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;margin-bottom:32px}
.footer-brand img{width:180px;margin-bottom:12px}
.footer-brand p{font-size:.88rem;max-width:280px;line-height:1.6}
.footer-col h4{color:#fff;font-size:.85rem;font-weight:600;margin-bottom:12px}
.footer-col a{display:block;color:rgba(255,255,255,.5);font-size:.85rem;margin-bottom:8px;transition:color var(--transition)}
.footer-col a:hover{color:var(--green)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:20px;display:flex;justify-content:space-between;align-items:center;font-size:.78rem;flex-wrap:wrap;gap:8px}

/* Animations */
.fade-up{opacity:0;transform:translateY(30px);transition:opacity .7s ease,transform .7s ease}
.fade-up.visible{opacity:1;transform:translateY(0)}

/* Responsive */
@media(max-width:900px){
  .about-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:24px}
  .values-grid{grid-template-columns:repeat(2,1fr)}
  .hero-logo{width:200px}
  .fav-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  .nav-toggle{display:flex}
  .main-nav{position:fixed;top:0;right:-280px;width:280px;height:100vh;background:#fff;flex-direction:column;padding:80px 32px 32px;gap:0;box-shadow:-8px 0 32px rgba(0,0,0,.1);transition:right .3s ease;z-index:999}
  .main-nav.open{right:0}
  .main-nav a{padding:14px 0;border-bottom:1px solid var(--bg-section);width:100%;font-size:1rem}
  .nav-cta{margin-top:16px;text-align:center;justify-content:center}
  section{padding:48px 0}
  .product-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:14px}
  .product-card-body{padding:14px}
  .product-name{font-size:.82rem}
}
@media(max-width:480px){
  .header-logo span{font-size:.95rem}
  .header-logo img{height:36px}
  .values-grid{grid-template-columns:1fr 1fr;gap:12px}
  .search-input{width:100%}
  .filter-pills{gap:4px}
  .filter-pill{font-size:.68rem;padding:4px 10px}
  .filter-meta{gap:8px}
  .budget-slider{width:100px}
  .design-pill{font-size:.65rem;padding:4px 8px}
  .product-grid{grid-template-columns:repeat(2,1fr);gap:10px}
  .product-card-body{padding:10px}
  .fav-grid{grid-template-columns:1fr}
}
