/* ═══════════════════════════════════════════════════════
   PeptidLab GmbH — styles.css
   Hospital sterile. German precision. Zero decoration.
   ═══════════════════════════════════════════════════════ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --white:#ffffff;
  --bg:#fafafa;
  --g50:#f7f7f7;
  --g100:#f0f0f0;
  --g150:#e8e8e8;
  --g200:#e0e0e0;
  --g300:#c4c4c4;
  --g400:#a0a0a0;
  --g500:#787878;
  --g600:#555555;
  --g700:#333333;
  --g800:#1a1a1a;
  --g900:#0d0d0d;

  --blue:#1a65a3;
  --blue-light:#e8f0f8;
  --blue-dark:#0f4a7a;
  --green:#2d7a4f;
  --green-light:#eaf5ef;
  --red:#b42a2a;
  --red-light:#fceaea;

  --font:'Hanken Grotesk',system-ui,-apple-system,BlinkMacSystemFont,sans-serif;
  --mono:'IBM Plex Mono','SF Mono',monospace;

  --max:1180px;
  --radius:3px;
}

html{scroll-behavior:smooth;font-size:14px}
body{
  font-family:var(--font);
  background:var(--white);
  color:var(--g800);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
a{color:var(--blue);text-decoration:none}
a:hover{text-decoration:underline}
button,input,select,textarea{font-family:var(--font);font-size:14px;color:var(--g800)}
img{display:block;max-width:100%;height:auto}


/* ══════════════════════════════════════════
   TOPBAR
   ══════════════════════════════════════════ */
.topbar{
  background:var(--g800);
  color:var(--g400);
  font-size:11px;
  padding:5px 0;
  letter-spacing:.2px;
}
.topbar-inner{
  max-width:var(--max);
  margin:0 auto;
  padding:0 24px;
  display:flex;
  justify-content:space-between;
  align-items:center;
}
.topbar a{color:var(--g300);font-size:11px}
.topbar a:hover{color:var(--white);text-decoration:none}
.topbar-links{display:flex;gap:16px}


/* ══════════════════════════════════════════
   HEADER
   ══════════════════════════════════════════ */
.header{
  background:var(--white);
  border-bottom:1px solid var(--g150);
  position:sticky;
  top:0;
  z-index:100;
}
.header-inner{
  max-width:var(--max);
  margin:0 auto;
  padding:0 24px;
  display:flex;
  align-items:center;
  height:64px;
  gap:28px;
}

/* Logo */
.logo{
  display:flex;
  align-items:center;
  gap:10px;
  text-decoration:none;
  color:var(--g800);
  flex-shrink:0;
}
.logo:hover{text-decoration:none}
.logo-mark{
  width:34px;height:34px;
  border:2px solid var(--g800);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--mono);font-size:13px;font-weight:700;
  letter-spacing:-1px;
}
.logo-text-wrap{line-height:1.15}
.logo-name{font-size:17px;font-weight:700;letter-spacing:-.3px}
.logo-name span{font-weight:400;color:var(--g500)}
.logo-tagline{font-size:9px;color:var(--g400);letter-spacing:1.8px;text-transform:uppercase}

/* Nav */
.main-nav{display:flex;gap:1px;flex:1}
.main-nav a{
  padding:8px 14px;
  font-size:13px;
  color:var(--g600);
  font-weight:500;
  border-radius:var(--radius);
  text-decoration:none;
  transition:all .08s;
}
.main-nav a:hover{background:var(--g50);color:var(--g800);text-decoration:none}
.main-nav a.active{color:var(--g800);font-weight:600;background:var(--g50)}

/* Header actions */
.header-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}
.hdr-btn{
  height:36px;
  padding:0 14px;
  border:1px solid var(--g200);
  background:var(--white);
  border-radius:var(--radius);
  font-size:12px;font-weight:500;
  cursor:pointer;
  display:flex;align-items:center;gap:6px;
  color:var(--g600);
  transition:all .08s;
  position:relative;
}
.hdr-btn:hover{border-color:var(--g400);color:var(--g800)}
.hdr-btn svg{width:16px;height:16px}
.hdr-btn .badge{
  position:absolute;top:-5px;right:-5px;
  background:var(--blue);color:var(--white);
  font-size:9px;font-weight:700;
  width:16px;height:16px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
}
.hdr-cta{
  height:36px;
  padding:0 18px;
  background:var(--g800);
  color:var(--white);
  border:none;
  border-radius:var(--radius);
  font-size:12px;font-weight:600;
  cursor:pointer;
  display:flex;align-items:center;gap:6px;
  transition:all .08s;
}
.hdr-cta:hover{background:var(--blue)}
.hdr-cta svg{width:15px;height:15px}


/* ══════════════════════════════════════════
   DISCLAIMER BAR
   ══════════════════════════════════════════ */
.disclaimer-bar{
  background:var(--g50);
  border-bottom:1px solid var(--g150);
  padding:7px 0;
  text-align:center;
  font-size:11px;
  color:var(--g500);
}
.disclaimer-bar strong{color:var(--g700);font-weight:600}


/* ══════════════════════════════════════════
   HERO / LANDING
   ══════════════════════════════════════════ */
.hero{
  background:var(--g50);
  border-bottom:1px solid var(--g150);
  padding:60px 0;
}
.hero-inner{
  max-width:var(--max);
  margin:0 auto;
  padding:0 24px;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:60px;
  align-items:center;
}
.hero-content h1{
  font-size:36px;
  font-weight:800;
  line-height:1.1;
  letter-spacing:-.8px;
  color:var(--g900);
  margin-bottom:16px;
}
.hero-content p{
  font-size:15px;
  color:var(--g500);
  line-height:1.6;
  margin-bottom:24px;
  max-width:440px;
}
.hero-btns{display:flex;gap:10px}
.btn-primary{
  padding:12px 28px;
  background:var(--g800);
  color:var(--white);
  border:none;
  border-radius:var(--radius);
  font-size:14px;font-weight:600;
  cursor:pointer;
  transition:all .08s;
}
.btn-primary:hover{background:var(--blue)}
.btn-secondary{
  padding:12px 28px;
  background:var(--white);
  color:var(--g700);
  border:1px solid var(--g200);
  border-radius:var(--radius);
  font-size:14px;font-weight:600;
  cursor:pointer;
  transition:all .08s;
}
.btn-secondary:hover{border-color:var(--g400)}

.hero-image{
  display:flex;
  justify-content:center;
  align-items:center;
}
.hero-image img{
  max-height:400px;
  width:auto;
  filter:drop-shadow(0 8px 24px rgba(0,0,0,.06));
}


/* ══════════════════════════════════════════
   METRICS STRIP
   ══════════════════════════════════════════ */
.metrics{
  border-bottom:1px solid var(--g150);
  background:var(--white);
}
.metrics-inner{
  max-width:var(--max);
  margin:0 auto;
  padding:0 24px;
  display:grid;
  grid-template-columns:repeat(4,1fr);
}
.metric{
  padding:24px 0;
  text-align:center;
  border-right:1px solid var(--g150);
}
.metric:last-child{border-right:none}
.metric-value{
  font-size:28px;
  font-weight:800;
  color:var(--g800);
  letter-spacing:-1px;
}
.metric-label{
  font-size:11px;
  color:var(--g400);
  text-transform:uppercase;
  letter-spacing:1px;
  margin-top:2px;
}


/* ══════════════════════════════════════════
   FEATURED PRODUCTS SECTION
   ══════════════════════════════════════════ */
.section{
  padding:48px 0;
}
.section-inner{
  max-width:var(--max);
  margin:0 auto;
  padding:0 24px;
}
.section-header{
  display:flex;
  justify-content:space-between;
  align-items:baseline;
  margin-bottom:20px;
}
.section-title{
  font-size:20px;
  font-weight:700;
  letter-spacing:-.3px;
}
.section-link{
  font-size:12px;
  color:var(--blue);
  font-weight:500;
}


/* ══════════════════════════════════════════
   PRODUCT GRID
   ══════════════════════════════════════════ */
.product-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:1px;
  background:var(--g150);
  border:1px solid var(--g150);
  border-radius:var(--radius);
  overflow:hidden;
}
.product-grid.three-col{grid-template-columns:repeat(3,1fr)}

.product-card{
  background:var(--white);
  padding:20px;
  cursor:pointer;
  transition:background .06s;
  display:flex;
  flex-direction:column;
}
.product-card:hover{background:var(--g50)}

.product-img{
  width:100%;
  aspect-ratio:1;
  background:var(--g50);
  border:1px solid var(--g150);
  border-radius:var(--radius);
  margin-bottom:14px;
  overflow:hidden;
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
}
.product-img img{
  width:70%;
  height:70%;
  object-fit:contain;
}
/* Placeholder when no image */
.product-img .placeholder{
  display:flex;flex-direction:column;
  align-items:center;gap:4px;
  color:var(--g300);
}
.product-img .placeholder svg{width:32px;height:32px;opacity:.4}
.product-img .placeholder span{font-size:9px;font-family:var(--mono);letter-spacing:.5px}

.product-img .purity-badge{
  position:absolute;top:8px;left:8px;
  font-family:var(--mono);font-size:9px;
  color:var(--g600);
  background:var(--white);
  padding:2px 6px;
  border:1px solid var(--g200);
  border-radius:2px;
}

.product-sku{
  font-family:var(--mono);font-size:10px;
  color:var(--g400);margin-bottom:3px;
}
.product-name{
  font-size:15px;font-weight:600;
  line-height:1.2;margin-bottom:2px;
}
.product-cat{
  font-size:11px;color:var(--g500);margin-bottom:6px;
}
.product-desc{
  font-size:12px;color:var(--g500);
  line-height:1.4;margin-bottom:auto;
  display:-webkit-box;-webkit-line-clamp:2;
  -webkit-box-orient:vertical;overflow:hidden;
}
.product-bottom{
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  margin-top:14px;
  padding-top:12px;
  border-top:1px solid var(--g100);
}
.product-price{
  font-family:var(--mono);
  font-size:16px;font-weight:600;
}
.product-price small{
  font-size:10px;color:var(--g400);
  font-weight:400;display:block;
}
.product-add{
  background:var(--g800);
  color:var(--white);
  border:none;
  padding:7px 14px;
  border-radius:var(--radius);
  font-size:11px;font-weight:600;
  cursor:pointer;
  transition:all .08s;
}
.product-add:hover{background:var(--blue)}
.product-add.added{background:var(--green)}
.product-stock{
  font-size:10px;color:var(--green);margin-top:4px;
}


/* ══════════════════════════════════════════
   CATALOG LAYOUT (sidebar + grid)
   ══════════════════════════════════════════ */
.catalog-layout{
  display:grid;
  grid-template-columns:200px 1fr;
  gap:24px;
}
.catalog-sidebar{
  position:sticky;top:84px;align-self:start;
}
.sidebar-title{
  font-size:10px;font-weight:700;
  text-transform:uppercase;
  letter-spacing:1px;
  color:var(--g400);
  margin-bottom:8px;
}
.category-list{display:flex;flex-direction:column;gap:1px;margin-bottom:20px}
.category-btn{
  padding:7px 10px;
  font-size:13px;color:var(--g600);
  cursor:pointer;border-radius:var(--radius);
  background:none;border:none;
  text-align:left;font-weight:400;
  transition:all .06s;
  display:flex;justify-content:space-between;
}
.category-btn:hover{background:var(--g50);color:var(--g800)}
.category-btn.active{background:var(--blue-light);color:var(--blue);font-weight:600}
.category-btn .count{font-size:11px;color:var(--g400);font-weight:400}
.category-btn.active .count{color:var(--blue)}

.sidebar-info{
  background:var(--g50);
  border:1px solid var(--g150);
  border-radius:var(--radius);
  padding:12px;
  font-size:11px;
  color:var(--g500);
  line-height:1.5;
}


/* ══════════════════════════════════════════
   VOLUME DISCOUNTS
   ══════════════════════════════════════════ */
.volume-section{
  background:var(--g50);
  border-top:1px solid var(--g150);
  border-bottom:1px solid var(--g150);
  padding:40px 0;
}
.volume-inner{
  max-width:var(--max);
  margin:0 auto;
  padding:0 24px;
}
.volume-title{font-size:16px;font-weight:700;margin-bottom:12px}
.volume-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1px;
  background:var(--g150);
  border:1px solid var(--g150);
  border-radius:var(--radius);
  overflow:hidden;
}
.volume-tier{
  background:var(--white);
  padding:20px;
  text-align:center;
}
.volume-pct{
  font-family:var(--mono);
  font-size:28px;font-weight:700;
  color:var(--g800);
}
.volume-threshold{
  font-size:11px;color:var(--g400);margin-top:4px;
}


/* ══════════════════════════════════════════
   CERTIFICATIONS STRIP
   ══════════════════════════════════════════ */
.certs{
  border-bottom:1px solid var(--g150);
  padding:20px 0;
}
.certs-inner{
  max-width:var(--max);
  margin:0 auto;
  padding:0 24px;
  display:flex;
  justify-content:center;
  gap:40px;
}
.cert{
  display:flex;align-items:center;
  gap:8px;
  font-size:12px;color:var(--g500);font-weight:500;
}
.cert-icon{
  width:32px;height:32px;
  background:var(--g100);
  border-radius:var(--radius);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--mono);font-size:10px;font-weight:700;color:var(--g500);
}


/* ══════════════════════════════════════════
   FOOTER
   ══════════════════════════════════════════ */
.footer{
  background:var(--g50);
  border-top:1px solid var(--g150);
  padding:40px 0 20px;
}
.footer-inner{
  max-width:var(--max);
  margin:0 auto;
  padding:0 24px;
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1fr;
  gap:32px;
}
.footer h4{
  font-size:10px;font-weight:700;
  text-transform:uppercase;letter-spacing:1px;
  color:var(--g500);margin-bottom:10px;
}
.footer p{font-size:12px;color:var(--g500);line-height:1.6;margin-bottom:3px}
.footer a{font-size:12px;color:var(--g500);display:block;margin-bottom:3px;text-decoration:none}
.footer a:hover{color:var(--g800)}

.footer-logo{
  display:flex;align-items:center;gap:8px;margin-bottom:12px;
}
.footer-logo .mark{
  width:24px;height:24px;
  border:2px solid var(--g400);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--mono);font-size:9px;font-weight:700;color:var(--g500);
}
.footer-logo span{font-weight:700;font-size:14px;color:var(--g600)}

.footer-bottom{
  max-width:var(--max);
  margin:24px auto 0;
  padding:16px 24px 0;
  border-top:1px solid var(--g200);
  display:flex;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:8px;
}
.footer-bottom p{font-size:10px;color:var(--g400)}

.footer-legal{
  max-width:var(--max);
  margin:12px auto 0;
  padding:0 24px;
}
.footer-legal p{
  font-size:9px;color:var(--g400);
  line-height:1.5;
  background:var(--white);
  border:1px solid var(--g150);
  border-radius:var(--radius);
  padding:10px 12px;
}


/* ══════════════════════════════════════════
   RESPONSIVE
   ══════════════════════════════════════════ */
@media(max-width:960px){
  .hero-inner{grid-template-columns:1fr;gap:32px;text-align:center}
  .hero-content p{margin-left:auto;margin-right:auto}
  .hero-btns{justify-content:center}
  .hero-image img{max-height:280px}
  .product-grid{grid-template-columns:repeat(2,1fr)}
  .catalog-layout{grid-template-columns:1fr}
  .catalog-sidebar{position:static;display:flex;gap:4px;overflow-x:auto;padding-bottom:4px}
  .sidebar-title{display:none}
  .sidebar-info{display:none}
  .category-list{flex-direction:row;gap:4px;margin-bottom:0}
  .category-btn{white-space:nowrap;padding:6px 12px;border:1px solid var(--g200);border-radius:var(--radius);font-size:12px}
  .category-btn .count{display:none}
  .footer-inner{grid-template-columns:1fr 1fr}
  .metrics-inner{grid-template-columns:repeat(2,1fr)}
  .main-nav{display:none}
  .certs-inner{gap:20px;flex-wrap:wrap;justify-content:center}
}
@media(max-width:600px){
  .product-grid{grid-template-columns:1fr}
  .hero h1{font-size:26px}
  .footer-inner{grid-template-columns:1fr}
  .volume-grid{grid-template-columns:1fr}
  .hdr-btn span{display:none}
}
