@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;1,300;1,400;1,500;1,600&family=Cormorant:ital,wght@1,300;1,400&display=swap');

/* ━━ DESIGN TOKENS ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
:root {
  --ink:    #1A1812;   /* Warm near-black — NOT cold black */
  --ink2:   #2C2820;
  --cream:  #F5F2EC;   /* Primary light */
  --paper:  #FAF8F4;
  --warm:   #EDE8DF;
  --gold:   #B8A882;   /* Secondary accent */
  --red:    #CC0000;   /* Miele red — used sparingly */
  --red2:   #990000;
  --stone:  #6B6560;
  --border: #3A3630;
  --border-light: #E0DCD4;
  --ease:   cubic-bezier(.16,1,.3,1);
}

/* ━━ BASE ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.ml *{box-sizing:border-box;margin:0;padding:0;}
.ml {
  font-family:'Helvetica Neue',Helvetica,Arial,sans-serif;
  font-weight:300;font-size:16px;
  color:var(--cream);background:var(--ink);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
.ml a{text-decoration:none;color:inherit;}
.ml-wrap{max-width:1440px;margin:0 auto;padding:0 72px;}

/* ━━ TINY HELPERS ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.ml-label {
  font-size:10px;letter-spacing:4px;text-transform:uppercase;
  font-weight:400;color:var(--gold);
  display:flex;align-items:center;gap:16px;
}
.ml-label::before{
  content:'';display:block;width:32px;height:1px;
  background:var(--red);flex-shrink:0;
}
.ml-h2 {
  font-family:'Cormorant Garamond',Georgia,serif;
  font-size:clamp(36px,4vw,62px);font-weight:400;
  font-style:italic;line-height:1.05;letter-spacing:-.5px;
  color:var(--cream);
}
.ml-h2 em{font-style:normal;color:var(--red);}
.ml-h2-dark{color:var(--ink);}
.ml-p{
  font-size:15px;font-weight:300;line-height:1.8;
  color:rgba(245,242,236,.55);
}
.ml-p-dark{color:var(--stone);}

/* ━━ 1. HEADER BAR ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.ml-header{
  position:absolute;top:0;left:0;right:0;z-index:10;
  padding:32px 72px;
  display:flex;align-items:center;justify-content:space-between;
}
.ml-header::after{
  content:'';position:absolute;bottom:0;left:72px;right:72px;
  height:1px;background:rgba(245,242,236,.08);
}
.ml-logo-img{
  height:38px;width:auto;
  filter:brightness(0) invert(1);
  opacity:.85;
}
.ml-logo-fallback{
  font-family:'Cormorant Garamond',Georgia,serif;
  font-size:38px;font-weight:400;font-style:italic;
  color:var(--cream);letter-spacing:-.5px;line-height:1;
}
.ml-logo-tagline{
  font-size:8px;letter-spacing:4px;text-transform:uppercase;
  color:var(--gold);font-weight:400;margin-top:3px;
  font-family:'Helvetica Neue',sans-serif;
}
.ml-nav{display:flex;align-items:center;gap:48px;}
.ml-nav-link{
  font-size:11px;letter-spacing:2.5px;text-transform:uppercase;
  color:rgba(245,242,236,.4);font-weight:400;
  transition:color .3s;
}
.ml-nav-link:hover{color:var(--cream);}

/* ━━ 2. HERO — Full viewport, cinematic ━━━━━━━━━━━━━━━ */
.ml-hero{
  position:relative;
  min-height:100vh;
  background:var(--ink);
  display:flex;flex-direction:column;
  overflow:hidden;
}
/* Subtle warm gradient */
.ml-hero::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse 70% 60% at 65% 50%, rgba(184,168,130,.04) 0%,transparent 65%),
    radial-gradient(ellipse 50% 80% at 10% 90%, rgba(204,0,0,.03) 0%,transparent 60%);
  pointer-events:none;
}
/* Vertical gold line — editorial accent */
.ml-hero-line{
  position:absolute;left:72px;top:0;bottom:0;
  width:1px;background:linear-gradient(to bottom,transparent,var(--gold) 20%,var(--gold) 80%,transparent);
  opacity:.2;
}

/* Hero inner */
.ml-hero-inner{
  flex:1;display:grid;grid-template-columns:1fr 1fr;
  align-items:center;padding:160px 72px 80px;
  position:relative;z-index:2;gap:80px;
}

/* Left text */
.ml-hero-text{}
.ml-hero-label{margin-bottom:32px;}
.ml-hero-headline{
  font-family:'Cormorant Garamond',Georgia,serif;
  font-size:clamp(52px,5.5vw,88px);
  font-weight:300;font-style:italic;
  line-height:.95;letter-spacing:-2px;
  color:var(--cream);
  margin-bottom:32px;
}
.ml-hero-headline strong{
  font-weight:500;font-style:normal;
  display:block;font-size:.55em;
  letter-spacing:4px;text-transform:uppercase;
  color:var(--gold);font-family:'Helvetica Neue',sans-serif;
  margin-bottom:16px;
}
.ml-hero-headline em{color:transparent;-webkit-text-stroke:1px rgba(245,242,236,.3);}
.ml-hero-desc{
  font-size:15px;font-weight:300;line-height:1.8;
  color:rgba(245,242,236,.5);max-width:380px;
  margin-bottom:48px;
}
.ml-cta-primary{
  display:inline-flex;align-items:center;gap:16px;
  background:var(--red);color:#fff;
  font-size:10px;letter-spacing:3px;text-transform:uppercase;
  font-weight:400;padding:16px 36px;
  transition:background .3s;cursor:pointer;border:none;
  font-family:'Helvetica Neue',sans-serif;
}
.ml-cta-primary:hover{background:var(--red2);}
.ml-cta-ghost{
  display:inline-flex;align-items:center;gap:16px;
  border:1px solid rgba(245,242,236,.18);color:rgba(245,242,236,.55);
  font-size:10px;letter-spacing:3px;text-transform:uppercase;
  font-weight:400;padding:15px 36px;margin-left:16px;
  transition:all .3s;cursor:pointer;background:none;
  font-family:'Helvetica Neue',sans-serif;
}
.ml-cta-ghost:hover{border-color:rgba(245,242,236,.4);color:var(--cream);}

/* Hero right — product visual */
.ml-hero-visual{
  display:flex;align-items:center;justify-content:center;
  position:relative;
}
.ml-hero-product{
  position:relative;
  filter:drop-shadow(0 40px 80px rgba(0,0,0,.5));
}
.ml-hero-badge{
  position:absolute;top:-24px;right:-24px;
  background:var(--red);color:#fff;
  font-size:8px;letter-spacing:2.5px;text-transform:uppercase;
  padding:8px 16px;font-family:'Helvetica Neue',sans-serif;font-weight:400;
}

/* Stats strip at bottom of hero */
.ml-hero-stats{
  padding:0 72px 48px;
  display:grid;grid-template-columns:repeat(4,1fr);
  border-top:1px solid rgba(245,242,236,.06);
  padding-top:32px;
  position:relative;z-index:2;
}
.ml-hero-stat{
  padding:0 40px;border-right:1px solid rgba(245,242,236,.06);
}
.ml-hero-stat:first-child{padding-left:0;}
.ml-hero-stat:last-child{border-right:none;}
.ml-stat-num{
  font-family:'Cormorant Garamond',Georgia,serif;
  font-size:44px;font-weight:300;font-style:italic;
  color:var(--cream);line-height:1;letter-spacing:-1px;margin-bottom:6px;
}
.ml-stat-num sup{font-size:.5em;vertical-align:super;color:var(--red);}
.ml-stat-lbl{
  font-size:9px;letter-spacing:3px;text-transform:uppercase;
  color:var(--gold);font-weight:400;opacity:.7;
}
/* ━━ 3. PHILOSOPHY — Cream section ━━━━━━━━━━━━━━━━━━━━ */
.ml-philosophy{
  background:var(--cream);padding:120px 0;
  position:relative;overflow:hidden;
}
.ml-philosophy::before{
  content:'"';
  position:absolute;top:-60px;left:40px;
  font-family:'Cormorant Garamond',Georgia,serif;
  font-size:400px;font-weight:300;font-style:italic;
  color:transparent;-webkit-text-stroke:1px rgba(26,24,18,.04);
  line-height:1;pointer-events:none;
}
.ml-philosophy-grid{
  display:grid;grid-template-columns:200px 1fr;gap:80px;align-items:center;
}
.ml-philosophy-side{
  display:flex;flex-direction:column;align-items:flex-start;gap:20px;
}
.ml-philosophy-year{
  font-family:'Cormorant Garamond',Georgia,serif;
  font-size:80px;font-weight:300;color:var(--border-light);
  line-height:1;font-style:italic;letter-spacing:-2px;
}
.ml-philosophy-vline{
  width:1px;height:60px;background:var(--red);
}
.ml-philosophy-quote{
  font-family:'Cormorant Garamond',Georgia,serif;
  font-size:clamp(28px,3.5vw,50px);
  font-weight:300;font-style:italic;
  color:var(--ink);line-height:1.2;letter-spacing:-.3px;
}
.ml-philosophy-quote strong{font-weight:600;color:var(--red);}
.ml-philosophy-body{
  font-size:15px;font-weight:300;
  color:var(--stone);line-height:1.85;
  margin-top:28px;max-width:580px;
  font-family:'Helvetica Neue',sans-serif;
}

/* ━━ 4. CATEGORIES — Warm paper, horizontal scroll ━━━━ */
.ml-cats{background:var(--paper);padding:100px 0;}
.ml-sect-head{
  display:flex;align-items:flex-end;justify-content:space-between;
  margin-bottom:52px;
}
.ml-all-link{
  font-size:10px;letter-spacing:3px;text-transform:uppercase;
  color:var(--stone);border-bottom:1px solid var(--border-light);
  padding-bottom:2px;transition:all .3s;font-weight:400;
  font-family:'Helvetica Neue',sans-serif;
}
.ml-all-link:hover{color:var(--ink);border-color:var(--ink);}

.ml-cat-group-lbl{
  font-size:9px;letter-spacing:4px;text-transform:uppercase;
  color:rgba(107,101,96,.6);font-family:'Helvetica Neue',sans-serif;font-weight:400;
  margin:40px 0 20px;display:flex;align-items:center;gap:16px;
}
.ml-cat-group-lbl:first-of-type{margin-top:0;}
.ml-cat-group-lbl::after{content:'';flex:1;height:1px;background:var(--border-light);}

.ml-cat-scroll{overflow-x:auto;scrollbar-width:none;margin:0 -4px;padding:4px;}
.ml-cat-scroll::-webkit-scrollbar{display:none;}
.ml-cat-row{display:flex;gap:20px;min-width:max-content;}

.ml-cat-tile{
  display:flex;flex-direction:column;width:190px;flex-shrink:0;
  text-decoration:none;cursor:pointer;
}
.ml-cat-tile-box{
  width:190px;height:190px;
  background:var(--warm);
  display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;
  transition:background .35s var(--ease);
  border:1px solid rgba(0,0,0,.04);
}
.ml-cat-tile:hover .ml-cat-tile-box{background:#E5E0D8;}
/* Top accent on hover */
.ml-cat-tile-box::before{
  content:'';position:absolute;top:0;left:0;right:0;
  height:2px;background:var(--red);
  transform:scaleX(0);transform-origin:left;
  transition:transform .35s var(--ease);
}
.ml-cat-tile:hover .ml-cat-tile-box::before{transform:scaleX(1);}

.ml-cat-tile-img{
  width:75%;height:75%;object-fit:contain;
  transition:transform .45s var(--ease);
  filter:drop-shadow(0 6px 16px rgba(0,0,0,.1));
}
.ml-cat-tile:hover .ml-cat-tile-img{transform:scale(1.08) translateY(-4px);}

/* SVG fallback */
.ml-cat-svg{
  width:72px;height:72px;
  transition:transform .45s var(--ease);
}
.ml-cat-tile:hover .ml-cat-svg{transform:scale(1.08) translateY(-4px);}
.ml-cat-svg svg{
  width:72px;height:72px;fill:none;
  stroke:rgba(26,24,18,.3);stroke-width:1.5;
  stroke-linecap:round;stroke-linejoin:round;
  transition:stroke .3s;
}
.ml-cat-tile:hover .ml-cat-svg svg{stroke:var(--red);}

.ml-cat-tile-name{
  font-size:13px;font-weight:300;color:var(--ink);
  margin-top:12px;letter-spacing:.2px;transition:color .2s;
  font-family:'Helvetica Neue',sans-serif;
}
.ml-cat-tile:hover .ml-cat-tile-name{color:var(--red);}
.ml-cat-tile-meta{
  font-size:11px;font-weight:300;color:var(--stone);margin-top:3px;
  font-family:'Helvetica Neue',sans-serif;opacity:.65;
}

/* ━━ 5. TECHNOLOGY — Dark, editorial ━━━━━━━━━━━━━━━━━━ */
.ml-tech{background:var(--ink2);padding:100px 0;}
.ml-tech-grid{
  display:grid;grid-template-columns:2.2fr 1fr 1fr 1fr;
  gap:1px;background:rgba(245,242,236,.06);
  margin-top:52px;
}
.ml-tech-card{
  background:var(--ink2);padding:44px 36px;
  display:flex;flex-direction:column;
  border-bottom:2px solid transparent;
  transition:all .3s var(--ease);
}
.ml-tech-card:hover{
  background:rgba(245,242,236,.025);
  border-bottom-color:var(--red);
}
.ml-tech-featured{padding:52px 44px;}
.ml-tech-n{
  font-family:'Cormorant Garamond',Georgia,serif;
  font-size:56px;font-weight:300;font-style:italic;
  color:rgba(245,242,236,.06);line-height:1;
  margin-bottom:20px;transition:color .3s;
}
.ml-tech-featured .ml-tech-n{font-size:72px;}
.ml-tech-card:hover .ml-tech-n{color:rgba(204,0,0,.12);}
.ml-tech-name{
  font-family:'Cormorant Garamond',Georgia,serif;
  font-size:22px;font-weight:400;font-style:italic;
  color:var(--cream);margin-bottom:12px;
}
.ml-tech-featured .ml-tech-name{font-size:32px;}
.ml-tech-desc{
  font-size:13px;font-weight:300;line-height:1.75;
  color:rgba(245,242,236,.38);flex:1;
  font-family:'Helvetica Neue',sans-serif;
}
.ml-tech-prod{
  font-size:9px;letter-spacing:3px;text-transform:uppercase;
  color:rgba(245,242,236,.2);margin-top:24px;
  font-family:'Helvetica Neue',sans-serif;
  padding-top:16px;border-top:1px solid rgba(245,242,236,.06);
}

/* ━━ 6. PRODUCTS — Dark grid ━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.ml-products{background:var(--ink);padding:100px 0;}
.ml-prod-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:1px;background:rgba(245,242,236,.05);
  margin-top:52px;
}
.ml-prod-card{
  background:var(--ink);display:flex;flex-direction:column;
  text-decoration:none;border-top:1px solid transparent;
  transition:all .3s;
}
.ml-prod-card:hover{background:rgba(245,242,236,.02);border-top-color:var(--red);}
.ml-prod-img-wrap{
  height:260px;background:var(--ink2);
  display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;
}
.ml-prod-img-wrap img{
  width:80%;height:80%;object-fit:contain;
  transition:transform .5s var(--ease);
  filter:drop-shadow(0 8px 24px rgba(0,0,0,.4));
}
.ml-prod-card:hover .ml-prod-img-wrap img{transform:scale(1.05) translateY(-4px);}
.ml-prod-tag{
  position:absolute;top:0;left:0;
  background:var(--red);color:#fff;
  font-size:8px;letter-spacing:2px;font-weight:400;
  text-transform:uppercase;padding:5px 12px;
  font-family:'Helvetica Neue',sans-serif;
}
.ml-prod-body{
  padding:20px 22px 24px;flex:1;display:flex;flex-direction:column;
  border-top:1px solid rgba(245,242,236,.05);
}
.ml-prod-name{
  font-size:14px;font-weight:300;color:rgba(245,242,236,.75);
  line-height:1.4;margin-bottom:auto;
  font-family:'Helvetica Neue',sans-serif;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.ml-prod-foot{
  display:flex;align-items:center;justify-content:space-between;
  margin-top:16px;padding-top:14px;border-top:1px solid rgba(245,242,236,.06);
}
.ml-prod-price{
  font-family:'Cormorant Garamond',Georgia,serif;
  font-size:20px;font-weight:300;color:var(--cream);
}
.ml-prod-arrow{
  width:30px;height:30px;background:var(--red);
  display:flex;align-items:center;justify-content:center;
  transition:background .2s;
}
.ml-prod-card:hover .ml-prod-arrow{background:var(--red2);}
.ml-prod-arrow svg{width:11px;height:11px;stroke:#fff;stroke-width:2;}

/* ━━ 7. MANIFESTO — Cream, typographic ━━━━━━━━━━━━━━━━ */
.ml-manifesto{
  background:var(--cream);padding:140px 0;text-align:center;
  position:relative;overflow:hidden;
}
.ml-manifesto::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--red) 30%,var(--red) 70%,transparent);
}
.ml-manifesto-kicker{
  font-size:9px;letter-spacing:5px;text-transform:uppercase;
  color:var(--stone);font-family:'Helvetica Neue',sans-serif;margin-bottom:32px;
}
.ml-manifesto-main{
  font-family:'Cormorant Garamond',Georgia,serif;
  font-size:clamp(52px,7vw,108px);font-weight:300;font-style:italic;
  color:var(--ink);line-height:.95;letter-spacing:-3px;
  margin-bottom:48px;
}
.ml-manifesto-main em{color:var(--red);}
.ml-manifesto-sub{
  font-size:14px;font-weight:300;color:var(--stone);letter-spacing:.3px;
  font-family:'Helvetica Neue',sans-serif;margin-bottom:64px;
}
.ml-manifesto-nums{
  display:inline-flex;border:1px solid var(--border-light);
}
.ml-manifesto-num{
  padding:28px 56px;border-right:1px solid var(--border-light);
  text-align:center;
}
.ml-manifesto-num:last-child{border-right:none;}
.ml-manifesto-num-val{
  font-family:'Cormorant Garamond',Georgia,serif;
  font-size:38px;font-weight:300;font-style:italic;
  color:var(--ink);line-height:1;margin-bottom:6px;
}
.ml-manifesto-num-lbl{
  font-size:9px;letter-spacing:3px;text-transform:uppercase;
  color:var(--stone);font-family:'Helvetica Neue',sans-serif;
}

/* ━━ 8. CTA FINAL ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.ml-cta{background:var(--ink2);padding:120px 0;text-align:center;}
.ml-cta-headline{
  font-family:'Cormorant Garamond',Georgia,serif;
  font-size:clamp(30px,4vw,58px);font-weight:300;font-style:italic;
  color:var(--cream);line-height:1.1;margin-bottom:16px;
}
.ml-cta-headline em{color:var(--red);}
.ml-cta-sub{
  font-size:14px;font-weight:300;color:rgba(245,242,236,.4);
  max-width:480px;margin:0 auto 44px;line-height:1.8;
  font-family:'Helvetica Neue',sans-serif;
}
.ml-cta-row{display:flex;align-items:center;justify-content:center;gap:16px;}
.ml-hotline{
  font-size:12px;font-weight:300;color:rgba(245,242,236,.3);
  font-family:'Helvetica Neue',sans-serif;margin-top:28px;letter-spacing:.3px;
}
.ml-hotline strong{color:var(--red);font-weight:400;}


/* ── Category scroll ── */
.ml-cat-scroll{
  overflow-x:auto;
  overflow-y:visible;
  scrollbar-width:thin;
  scrollbar-color:rgba(26,24,18,.25) rgba(26,24,18,.06);
  padding-bottom:14px;
  padding:8px 4px 14px;
  scroll-behavior:smooth;
}
.ml-cat-scroll::-webkit-scrollbar{height:4px;}
.ml-cat-scroll::-webkit-scrollbar-track{background:rgba(26,24,18,.05);border-radius:2px;}
.ml-cat-scroll::-webkit-scrollbar-thumb{background:rgba(26,24,18,.25);border-radius:2px;}
.ml-cat-scroll::-webkit-scrollbar-thumb:hover{background:rgba(26,24,18,.5);}

/* Outer wrapper with nav arrows */
.ml-cat-scroll-outer{position:relative;}

/* Prev/Next arrow buttons */
.ml-cat-nav{
  position:absolute;top:50%;transform:translateY(-50%);
  width:40px;height:40px;
  background:var(--paper);
  border:1px solid var(--border-light);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;z-index:10;
  transition:all .25s;
  margin-top:-10px;/* compensate scrollbar pb */
}
.ml-cat-nav:hover{background:#fff;border-color:var(--red);color:var(--red);}
.ml-cat-nav svg{width:14px;height:14px;stroke:currentColor;stroke-width:2;}
.ml-cat-nav-prev{left:-20px;}
.ml-cat-nav-next{right:-20px;}
.ml-cat-nav[disabled]{opacity:.25;cursor:default;pointer-events:none;}

/* Fade edge gradient */
.ml-cat-scroll-outer::before,
.ml-cat-scroll-outer::after{
  content:'';position:absolute;top:0;bottom:14px;width:24px;z-index:5;
  pointer-events:none;
}
.ml-cat-scroll-outer::before{
  left:0;
  background:linear-gradient(to right,var(--paper),transparent);
}
.ml-cat-scroll-outer::after{
  right:0;
  background:linear-gradient(to left,var(--paper),transparent);
}