/* ====================================================================
   0) ROUTINE HEADER — premium minimal masthead (no breadcrumb)
   --------------------------------------------------------------------
   • narrower content (~780px)
   • softer italic (lower contrast)
   • subtle warm radial fade δεξιά (skin-tone glow, όχι flat)
   • καθαρίζει το default "Skinya · Maison" stamp στην πάνω-δεξιά γωνία
   ==================================================================== */
/* editorial split — copy left, image right */
.routine-header{
  max-width:none;border-bottom:none;
  padding:0;
  background:var(--ivory);
  overflow:hidden;position:relative;
  display:grid;
  grid-template-columns:0.78fr 1.22fr;
  min-height:560px;
  align-items:stretch;
}
/* right-side photo */
.routine-header::before{
  content:'';
  grid-column:2;grid-row:1;
  background:url("../assets/routine-header-bg.png") center/cover no-repeat;
  position:relative;
}
/* soft fade band on the seam, ivory bleeds into the photo */
.routine-header::after{
  content:'';
  grid-column:2;grid-row:1;
  align-self:stretch;justify-self:start;
  width:200px;height:100%;
  background:linear-gradient(90deg,
    var(--ivory) 0%,
    rgba(255,247,237,0.65) 40%,
    rgba(255,247,237,0.15) 80%,
    transparent 100%);
  pointer-events:none;z-index:2;
}
.routine-header .page-header-content{
  grid-column:1;grid-row:1;
  align-self:center;
  max-width:none;margin:0;padding:5.5rem 2rem 5.5rem 9rem;
  display:flex;flex-direction:column;align-items:flex-start;text-align:left;
}
.routine-header .eyebrow{
  margin-bottom:1.5rem;color:var(--gold-leaf);
  font-size:.7rem;letter-spacing:.5em;
}
.routine-header h1{
  font-family:'Cormorant Garamond',serif;font-weight:500;
  font-size:clamp(2.4rem,4.6vw,4rem);
  line-height:1.06;letter-spacing:-.02em;
  color:var(--aubergine);margin:0 0 1.6rem;max-width:520px;
}
.routine-header h1 em{
  font-weight:400;font-style:italic;
  background:linear-gradient(135deg,var(--plum-deep) 0%,var(--gold-leaf) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  padding-right:.05em;
}
.routine-header p{
  font-family:'Cormorant Garamond',serif;font-style:italic;
  font-size:1.15rem;line-height:1.75;letter-spacing:.005em;
  color:var(--aubergine);opacity:.72;
  max-width:480px;margin:0;text-align:left;
}

/* mobile / tablet — stack: photo on top, copy below */
@media (max-width: 900px){
  .routine-header{
    grid-template-columns:1fr;
    grid-template-rows:280px auto;
    min-height:0;
  }
  .routine-header::before{grid-column:1;grid-row:1}
  .routine-header::after{
    grid-column:1;grid-row:1;
    width:100%;height:120px;align-self:end;
    background:linear-gradient(180deg,
      transparent 0%,
      rgba(255,247,237,0.6) 60%,
      var(--ivory) 100%);
  }
  .routine-header .page-header-content{
    grid-column:1;grid-row:2;
    align-items:center;text-align:center;
    padding:3rem 1.5rem 4rem;
  }
  .routine-header h1{max-width:none}
  .routine-header p{max-width:none;text-align:center;margin:0 auto}
}


/* ====================================================================
   RITUAL.CSS — Στυλ της σελίδας Ritual (K-Beauty routine)
   --------------------------------------------------------------------
   Δομή σε parts (αντιστοιχούν στα sections του HTML):
     1) .ritual-intro     — intro με κείμενο + video frame (3 stats)
     2) .routine-section  — Morning / Night routine container
        2a) .routine-step — μία κάρτα ενός βήματος (num + body + pick)
     3) .routine-weekly   — weekly add-ons (3 cards)
     4) .routine-tips     — golden rules grid
     5) .quote-section    — closing quote (σκούρο background)
   ==================================================================== */


/* ====================================================================
   1) RITUAL INTRO — text column + video frame
   ==================================================================== */
.ritual-intro{background:linear-gradient(180deg,var(--ivory) 0%,var(--lavender-mist) 100%)}
.ritual-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:5rem;align-items:center;max-width:1400px;margin:0 auto}
.ritual-text h2{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:clamp(2.5rem,4vw,3.5rem);line-height:1.05;color:var(--aubergine);margin:1.5rem 0}
.ritual-text h2 em{font-style:italic;color:var(--plum-deep)}
.ritual-text p{font-family:'Cormorant Garamond',serif;font-size:1.2rem;font-style:italic;color:var(--plum-deep);margin-bottom:2rem;line-height:1.6}
.ritual-text p em{font-style:italic;color:var(--aubergine);font-weight:500}
/* Flow chain (Toner → Serum → Moisturizer → SPF) — LAYERED STACK
   Τα chips επικαλύπτονται διαγώνια για να δείξουν την πορεία της ρουτίνας.
   Κάθε επόμενο chip κάθεται πιο πάνω (μεγαλύτερο z-index), με slight rotation
   και vertical stagger. Σε hover, το chip "πετάγεται" μπροστά. */
.routine-flow{
  display:flex;align-items:stretch;gap:0;
  margin:1.5rem 0 2.2rem;padding:0;
  border-radius:6px;overflow:hidden;
  /* ΕΝΑ continuous gradient αριστερά → δεξιά: άσπρο → μπεζ → απαλό → πορτοκαλί */
  background:linear-gradient(90deg,
    var(--ivory) 0%,
    var(--lilac-cream) 33%,
    var(--gold-soft) 66%,
    var(--gold-leaf) 100%);
  box-shadow:0 14px 30px -12px rgba(192,133,122,0.35),0 4px 10px rgba(61,42,30,0.08);
}
.flow-chip{
  flex:1;display:inline-flex;align-items:center;justify-content:center;
  padding:1.7rem 1.2rem;
  background:transparent;border:none;
  font-family:'Inter',sans-serif;font-weight:600;
  font-size:.95rem;letter-spacing:.26em;text-transform:uppercase;
  position:relative;cursor:default;
  transition:transform .3s ease;
}
/* text color βάση position στο gradient — σκούρο στα ανοιχτά, λευκό στο πορτοκαλί */
.flow-chip:nth-of-type(1){color:var(--aubergine)}
.flow-chip:nth-of-type(2){color:var(--aubergine)}
.flow-chip:nth-of-type(3){color:var(--aubergine)}
.flow-chip:nth-of-type(4){color:var(--ivory);font-weight:700}
/* subtle dividers ανάμεσα στα chips */
.flow-chip:not(:last-child)::after{
  content:'';position:absolute;right:0;top:30%;bottom:30%;width:1px;
  background:rgba(61,42,30,0.12);
}
.flow-chip:hover{transform:translateY(-2px)}
.flow-chip--key{font-weight:700}
/* Κρύβουμε τα arrows — το overlap δείχνει τη ροή */
.flow-arrow{display:none}

/* Beginner callout (4 essentials) */
.routine-beginner{
  display:block;
  margin:1.8rem 0 2rem;
  padding:1.4rem 1.6rem;
  background:linear-gradient(135deg,var(--champagne) 0%,var(--lilac-cream) 100%);
  border-left:3px solid var(--gold-leaf);
  border-radius:2px;
}
.beginner-tag{
  display:block;
  font-size:.62rem;letter-spacing:.35em;text-transform:uppercase;
  color:var(--plum-deep);font-weight:500;margin-bottom:.5rem;
}
.beginner-flow{
  display:block;
  font-family:'Cormorant Garamond',serif;font-weight:500;
  font-size:1.25rem;color:var(--aubergine);
  letter-spacing:.01em;line-height:1.3;margin-bottom:.4rem;
}
.beginner-sub{
  display:block;
  font-family:'Cormorant Garamond',serif;font-style:italic;
  font-size:.95rem;color:var(--plum-deep);opacity:.85;line-height:1.4;
}

.ritual-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:3rem;padding-top:3rem;border-top:1px solid rgba(156,132,114,0.15)}
.stat strong{display:block;font-family:'Cormorant Garamond',serif;font-style:italic;font-size:2rem;color:var(--aubergine);font-weight:400;line-height:1}
.stat small{font-size:.65rem;letter-spacing:.25em;text-transform:uppercase;color:var(--plum-deep);margin-top:.6rem;display:block;line-height:1.3}

/* Video frame (μεγάλο πλαίσιο με play button) */
.video-frame{position:relative;height:600px;background:linear-gradient(135deg,var(--lavender-dust),var(--mauve-soft));overflow:hidden;border-radius:2px;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 40px 80px -20px var(--shadow-soft)}
.video-frame::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 30% 30%,rgba(255,255,255,0.3) 0%,transparent 50%),radial-gradient(circle at 70% 70%,rgba(156,132,114,0.3) 0%,transparent 50%)}
.video-frame::after{content:'';position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.7'/%3E%3CfeColorMatrix values='0 0 0 0 0.4 0 0 0 0 0.3 0 0 0 0 0.5 0 0 0 0.15 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");opacity:.4}
.play-btn{width:100px;height:100px;border:1.5px solid var(--ivory);background:rgba(253,251,246,0.15);backdrop-filter:blur(10px);border-radius:50%;display:flex;align-items:center;justify-content:center;z-index:2;position:relative;cursor:pointer;transition:all .4s;animation:pulse 2.5s ease-in-out infinite}
.play-btn:hover{background:var(--ivory);transform:scale(1.1)}
.play-btn svg{width:30px;height:30px;fill:var(--ivory);margin-left:5px;transition:fill .3s}
.play-btn:hover svg{fill:var(--aubergine)}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(253,251,246,0.4)}50%{box-shadow:0 0 0 30px rgba(253,251,246,0)}}
.video-caption{position:absolute;bottom:2rem;left:2rem;color:var(--ivory);z-index:2}
.video-caption .eyebrow{color:var(--ivory);margin-bottom:.5rem}
.video-caption .eyebrow::before{background:var(--ivory)}
.video-caption strong{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.5rem;font-weight:400}


/* ====================================================================
   2) ROUTINE SECTION — Morning / Night (shared layout, διαφορετικά bg)
   ==================================================================== */
.routine-section{padding:7rem 3rem;position:relative}
.routine-section--morning{background:linear-gradient(180deg,var(--ivory) 0%,var(--champagne) 100%)}
.routine-section--night{
  background:linear-gradient(180deg,
    var(--champagne) 0,
    var(--champagne) 24px,
    #c69a82 260px,
    #dcb89e 25%,
    #ead0b8 45%,
    #f3e0cc 65%,
    #f9ecdb 85%,
    var(--champagne) 100%);
  color:var(--ivory);
  padding-top:15rem;
}

/* Night: αντιστροφή χρωμάτων στο section-head + steps */
.routine-section--night .section-head h2{color:var(--ivory)}
.routine-section--night .section-head h2 em{color:var(--gold-soft)}
.routine-section--night .section-head .eyebrow{color:var(--gold-soft)}
.routine-section--night .section-head .eyebrow::before,
.routine-section--night .section-head .eyebrow::after{background:var(--gold-soft)}
.routine-section--night .section-head p{color:var(--lilac-cream);opacity:.85}
.routine-section--night .section-head p em{color:var(--gold-soft);font-weight:500;opacity:1}

/* 2a) Steps grid (2 columns desktop) */
.routine-steps{
  display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;
  max-width:1200px;margin:0 auto;
}

/* 2b) One step card — ζωντανό warm gradient + golden glow accent */
.routine-step{
  display:grid;grid-template-columns:72px 1fr;gap:1.4rem;
  padding:1.8rem;
  background:
    radial-gradient(120% 80% at 0% 0%, rgba(236,199,189,0.18) 0%, transparent 55%),
    linear-gradient(180deg,#fffaf3 0%,var(--ivory) 100%);
  border:1px solid rgba(192,133,122,0.16);
  border-radius:8px;
  position:relative;overflow:hidden;
  transition:transform .35s cubic-bezier(.2,.7,.2,1), box-shadow .35s ease, border-color .3s ease;
}
/* λεπτή πορτοκαλί λωρίδα αριστερά — animated on hover */
.routine-step::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:3px;
  background:linear-gradient(180deg,var(--gold-leaf),var(--plum-deep));
  opacity:.55;transition:opacity .35s ease, width .35s ease;
}
/* sparkle/glow στην γωνία */
.routine-step::after{
  content:'';position:absolute;top:-40px;right:-40px;width:140px;height:140px;
  background:radial-gradient(circle,rgba(236,199,189,0.45) 0%,transparent 65%);
  pointer-events:none;opacity:0;transition:opacity .4s ease;
}
.routine-step:hover{
  transform:translateY(-5px);
  box-shadow:0 30px 50px -20px rgba(192,133,122,0.3),0 10px 20px -10px rgba(61,42,30,0.12);
  border-color:rgba(192,133,122,0.35);
}
.routine-step:hover::before{width:5px;opacity:1}
.routine-step:hover::after{opacity:1}

/* Night styling για steps — glass με μοβ-χρυσό glow */
.routine-section--night .routine-step{
  background:
    radial-gradient(120% 80% at 0% 0%, rgba(217,162,136,0.16) 0%, transparent 55%),
    linear-gradient(180deg,rgba(253,251,246,0.06) 0%,rgba(253,251,246,0.03) 100%);
  border:1px solid rgba(212,173,138,0.22);
  backdrop-filter:blur(8px);
}
.routine-section--night .routine-step::before{
  background:linear-gradient(180deg,var(--gold-soft),var(--mauve-soft));
}
.routine-section--night .routine-step::after{
  background:radial-gradient(circle,rgba(217,162,136,0.35) 0%,transparent 65%);
}
.routine-section--night .routine-step:hover{
  background:
    radial-gradient(120% 80% at 0% 0%, rgba(217,162,136,0.25) 0%, transparent 55%),
    linear-gradient(180deg,rgba(253,251,246,0.1) 0%,rgba(253,251,246,0.05) 100%);
  border-color:rgba(217,162,136,0.45);
  box-shadow:0 30px 50px -20px rgba(0,0,0,0.4);
}

/* "KEY" step — highlight (π.χ. SPF στο πρωί, ρετινόλη στο βράδυ) */
.routine-step--key{
  border-color:var(--gold-leaf);
  box-shadow:0 0 0 1px var(--gold-leaf) inset, 0 14px 30px -16px rgba(192,133,122,0.4);
}
.routine-step--key::before{opacity:1;width:5px}
.routine-section--night .routine-step--key{
  border-color:var(--gold-soft);
  box-shadow:0 0 0 1px rgba(217,162,136,0.4) inset, 0 14px 30px -16px rgba(0,0,0,0.45);
}

/* Step number badge — μεγαλύτερο, πιο vibrant με halo */
.routine-step .step-num{
  width:72px;height:72px;
  background:linear-gradient(135deg,var(--rose-warm) 0%,var(--gold-leaf) 50%,var(--plum-deep) 100%);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:500;
  font-size:1.55rem;color:var(--ivory);
  flex-shrink:0;
  box-shadow:
    0 8px 22px -6px rgba(192,133,122,0.55),
    inset 0 1px 0 rgba(255,255,255,0.3);
  position:relative;z-index:1;
  transition:transform .4s cubic-bezier(.2,.7,.2,1);
}
.routine-step .step-num::before{
  content:'';position:absolute;inset:-6px;border-radius:50%;
  background:linear-gradient(135deg,rgba(236,199,189,0.35),rgba(192,133,122,0.25));
  filter:blur(8px);z-index:-1;opacity:.7;
  transition:opacity .35s ease;
}
.routine-step:hover .step-num{transform:scale(1.08) rotate(-4deg)}
.routine-step:hover .step-num::before{opacity:1}
.routine-section--night .routine-step .step-num{
  background:linear-gradient(135deg,var(--gold-soft) 0%,var(--mauve-soft) 60%,var(--plum-deep) 100%);
  color:var(--ivory);
  box-shadow:
    0 8px 22px -6px rgba(217,162,136,0.5),
    inset 0 1px 0 rgba(255,255,255,0.25);
}
.routine-section--night .routine-step .step-num::before{
  background:linear-gradient(135deg,rgba(217,162,136,0.4),rgba(122,90,140,0.35));
}

/* Step body (text column) */
.step-body{display:flex;flex-direction:column;gap:.5rem}
.step-tag{
  font-size:.62rem;letter-spacing:.3em;text-transform:uppercase;
  color:var(--gold-leaf);font-weight:500;
}
.routine-section--night .step-tag{color:var(--gold-soft)}
.step-body h3{
  font-family:'Cormorant Garamond',serif;font-weight:500;
  font-size:1.4rem;line-height:1.2;
  color:var(--aubergine);margin:.2rem 0 .4rem;
}
.routine-section--night .step-body h3{color:var(--ivory)}
.step-body > p{
  font-family:'Cormorant Garamond',serif;
  font-size:1rem;line-height:1.5;
  color:var(--aubergine);opacity:.82;margin-bottom:.8rem;
}
.routine-section--night .step-body > p{color:var(--lilac-cream);opacity:.78}
.step-body p em{font-style:italic;color:var(--plum-deep);font-weight:500;opacity:1}
.routine-section--night .step-body p em{color:var(--gold-soft);font-style:italic}

/* Product pick chip — HERO photo αριστερά (μεγάλη), info + CTA δεξιά */
.step-pick{
  margin-top:auto;
  padding:1rem;
  background:linear-gradient(135deg,rgba(245,237,226,0.85) 0%,rgba(236,199,189,0.25) 100%);
  border-left:3px solid var(--gold-leaf);
  border-radius:0 8px 8px 0;
  display:flex;align-items:stretch;gap:1.1rem;
  position:relative;overflow:hidden;
  transition:background .35s ease;
}
.routine-step:hover .step-pick{
  background:linear-gradient(135deg,rgba(245,237,226,1) 0%,rgba(236,199,189,0.4) 100%);
}
.routine-section--night .step-pick{
  background:linear-gradient(135deg,rgba(253,251,246,0.08) 0%,rgba(217,162,136,0.15) 100%);
  border-left-color:var(--gold-soft);
}
.routine-section--night .routine-step:hover .step-pick{
  background:linear-gradient(135deg,rgba(253,251,246,0.12) 0%,rgba(217,162,136,0.22) 100%);
}

/* Pick info col — flex column με CTA στο κάτω μέρος */
.pick-info{display:flex;flex-direction:column;gap:.2rem;min-width:0;flex:1;justify-content:center}

/* Pick CTA — κουμπί που καλεί σε αγορά */
.pick-cta{
  margin-top:.6rem;align-self:flex-start;
  font-family:'Inter',sans-serif;font-size:.62rem;letter-spacing:.28em;
  text-transform:uppercase;font-weight:600;
  padding:.6rem 1.1rem;
  background:linear-gradient(135deg,var(--rose-warm) 0%,var(--plum-deep) 100%);
  color:var(--ivory);
  border:none;border-radius:20px;
  box-shadow:0 4px 12px -4px rgba(192,133,122,0.5);
  cursor:pointer;
  transition:transform .3s ease, box-shadow .3s ease, filter .3s ease;
}
.pick-cta:hover{
  transform:translateY(-2px);
  box-shadow:0 10px 22px -6px rgba(192,133,122,0.7);
  filter:brightness(1.08);
}
.routine-section--night .pick-cta{
  background:linear-gradient(135deg,var(--gold-soft) 0%,var(--mauve-soft) 100%);
  color:var(--aubergine);
  box-shadow:0 4px 12px -4px rgba(217,162,136,0.45);
}

/* Thumb — ΜΕΓΑΛΗ photo που τραβάει το μάτι (almost 2x previous) */
.pick-thumb{
  flex-shrink:0;width:140px;height:140px;
  background:linear-gradient(135deg,#fffaf3 0%,var(--ivory) 100%);
  border:1px solid rgba(192,133,122,0.28);
  border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;position:relative;
  box-shadow:
    0 12px 22px -10px rgba(192,133,122,0.4),
    inset 0 1px 0 rgba(255,255,255,0.7);
  transition:transform .45s cubic-bezier(.2,.7,.2,1), box-shadow .35s ease;
}
.pick-thumb::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle at 30% 25%, rgba(255,255,255,0.55) 0%, transparent 55%);
  pointer-events:none;z-index:1;
}
.pick-thumb img{
  max-width:90%;max-height:90%;width:auto;height:auto;
  object-fit:contain;mix-blend-mode:multiply;
  filter:drop-shadow(0 10px 16px rgba(61,42,30,0.22));
  transition:transform .5s cubic-bezier(.2,.7,.2,1);
  position:relative;z-index:0;
}
.pick-initial{font-size:3rem !important}
.routine-step:hover .pick-thumb{
  transform:scale(1.04) rotate(-2deg);
  box-shadow:
    0 22px 36px -12px rgba(192,133,122,0.5),
    inset 0 1px 0 rgba(255,255,255,0.8);
}
.routine-step:hover .pick-thumb img{transform:scale(1.1)}
.pick-initial{
  font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:400;
  color:var(--gold-leaf);opacity:.75;line-height:1;
}
.routine-section--night .pick-thumb{
  background:linear-gradient(135deg,rgba(253,251,246,0.08) 0%,rgba(253,251,246,0.04) 100%);
  border-color:rgba(217,162,136,0.3);
}
.routine-section--night .pick-initial{color:var(--gold-soft);opacity:.7}

.pick-brand{
  font-size:.6rem;letter-spacing:.3em;text-transform:uppercase;
  color:var(--plum-deep);font-weight:500;
}
.routine-section--night .pick-brand{color:var(--gold-soft)}
.step-pick strong{
  font-family:'Cormorant Garamond',serif;font-weight:500;
  font-size:1.05rem;line-height:1.2;color:var(--aubergine);
  margin:.1rem 0;
}
.routine-section--night .step-pick strong{color:var(--ivory)}
.step-pick small{
  font-family:'Cormorant Garamond',serif;font-style:italic;
  font-size:.88rem;color:var(--plum-deep);opacity:.85;
}
.routine-section--night .step-pick small{color:var(--lilac-cream);opacity:.75}


/* ====================================================================
   3) ROUTINE WEEKLY — extras (1-2x εβδομάδα)
   ==================================================================== */
.routine-weekly{
  padding:7rem 3rem;
  background:
    radial-gradient(60% 50% at 20% 20%, rgba(236,199,189,0.22) 0%, transparent 60%),
    radial-gradient(50% 60% at 90% 80%, rgba(192,133,122,0.14) 0%, transparent 60%),
    var(--lavender-mist);
}
.weekly-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;
  max-width:1200px;margin:0 auto;
}
.weekly-card{
  background:
    radial-gradient(120% 70% at 100% 0%, rgba(236,199,189,0.2) 0%, transparent 55%),
    linear-gradient(180deg,#fffaf3 0%,var(--ivory) 100%);
  padding:0 0 2rem;
  border:1px solid rgba(192,133,122,0.18);
  border-radius:10px;
  display:flex;flex-direction:column;gap:.8rem;
  position:relative;overflow:hidden;
  transition:transform .4s cubic-bezier(.2,.7,.2,1), box-shadow .35s ease, border-color .3s ease;
}
/* HERO photo banner στην κορυφή — πολύ μεγάλη εικόνα για να καλεί σε αγορά */
.weekly-card .weekly-hero{
  width:100%;height:260px;
  background:
    radial-gradient(60% 80% at 50% 40%, rgba(255,250,243,0.95) 0%, rgba(245,237,226,0.7) 100%);
  position:relative;overflow:hidden;
  display:flex;align-items:center;justify-content:center;
  border-bottom:1px solid rgba(192,133,122,0.12);
}
.weekly-card .weekly-hero::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(circle at 25% 20%, rgba(236,199,189,0.35) 0%, transparent 55%),
    radial-gradient(circle at 80% 80%, rgba(192,133,122,0.12) 0%, transparent 50%);
  pointer-events:none;
}
.weekly-card .weekly-hero img{
  max-width:72%;max-height:88%;
  object-fit:contain;mix-blend-mode:multiply;
  filter:drop-shadow(0 16px 24px rgba(61,42,30,0.28));
  transition:transform .6s cubic-bezier(.2,.7,.2,1);
  position:relative;z-index:1;
}
.weekly-card:hover .weekly-hero img{transform:scale(1.1) rotate(-2deg)}
.weekly-card > *:not(.weekly-hero):not(.weekly-tag){padding-left:2rem;padding-right:2rem}
.weekly-card .weekly-tag{margin:1.4rem 2rem 0}
/* Color-coded top accent bar — κάθε κάρτα έχει το δικό της accent */
.weekly-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--gold-leaf),var(--plum-deep));
  opacity:.75;transition:opacity .35s ease, height .35s ease;
}
.weekly-card::after{
  content:'';position:absolute;top:-60px;right:-60px;width:180px;height:180px;
  background:radial-gradient(circle,rgba(236,199,189,0.4) 0%,transparent 65%);
  pointer-events:none;opacity:0;transition:opacity .45s ease;
}
.weekly-card:nth-child(1)::before{background:linear-gradient(90deg,var(--mauve-soft),var(--plum-deep))}
.weekly-card:nth-child(2)::before{background:linear-gradient(90deg,var(--rose-warm),var(--gold-leaf))}
.weekly-card:nth-child(3)::before{background:linear-gradient(90deg,var(--gold-soft),var(--gold-leaf))}

.weekly-card:hover{
  transform:translateY(-8px);
  box-shadow:0 40px 60px -20px rgba(192,133,122,0.3),0 12px 24px -12px rgba(61,42,30,0.15);
  border-color:rgba(192,133,122,0.4);
}
.weekly-card:hover::before{height:5px;opacity:1}
.weekly-card:hover::after{opacity:1}

.weekly-tag{
  display:inline-block;align-self:flex-start;
  padding:.45rem 1rem;
  background:linear-gradient(135deg,var(--champagne) 0%,var(--gold-soft) 100%);
  font-size:.62rem;letter-spacing:.25em;text-transform:uppercase;
  color:var(--plum-deep);font-weight:600;
  border-radius:20px;
  box-shadow:0 2px 8px -2px rgba(192,133,122,0.25);
}
.weekly-card:nth-child(1) .weekly-tag{background:linear-gradient(135deg,var(--lavender-dust) 0%,var(--mauve-soft) 100%);color:var(--ivory)}
.weekly-card:nth-child(2) .weekly-tag{background:linear-gradient(135deg,var(--rose-warm) 0%,var(--gold-leaf) 100%);color:var(--ivory)}

.weekly-card h3{
  font-family:'Cormorant Garamond',serif;font-weight:500;
  font-size:1.5rem;line-height:1.2;
  color:var(--aubergine);margin:.3rem 0;
}
.weekly-card > p{
  font-family:'Cormorant Garamond',serif;font-size:1rem;
  color:var(--aubergine);opacity:.82;line-height:1.55;margin-bottom:.5rem;
}
.weekly-card p em{font-style:italic;color:var(--plum-deep);font-weight:500;opacity:1}

.weekly-pick{
  margin:.5rem 2rem 0;
  padding:1.1rem 1.2rem;
  background:linear-gradient(135deg,rgba(245,237,226,0.7) 0%,rgba(236,199,189,0.25) 100%);
  border-left:3px solid var(--gold-leaf);
  border-radius:0 8px 8px 0;
  display:flex;flex-direction:column;gap:.15rem;
  position:relative;
}
.weekly-pick strong{
  font-family:'Cormorant Garamond',serif;font-weight:500;
  font-size:1.15rem;line-height:1.2;color:var(--aubergine);margin:.1rem 0;
}
.weekly-pick small{
  font-family:'Cormorant Garamond',serif;font-style:italic;
  font-size:.92rem;color:var(--plum-deep);opacity:.85;
}
.weekly-pick .pick-cta{
  margin-top:.9rem;align-self:flex-start;
  font-family:'Inter',sans-serif;font-size:.65rem;letter-spacing:.3em;
  text-transform:uppercase;font-weight:600;
  padding:.7rem 1.4rem;
  background:linear-gradient(135deg,var(--rose-warm) 0%,var(--plum-deep) 100%);
  color:var(--ivory);
  border:none;border-radius:24px;
  box-shadow:0 6px 16px -6px rgba(192,133,122,0.55);
  cursor:pointer;
  transition:transform .3s ease, box-shadow .3s ease;
}
.weekly-pick .pick-cta:hover{
  transform:translateY(-2px);
  box-shadow:0 10px 22px -6px rgba(192,133,122,0.7);
}


/* ====================================================================
   4) ROUTINE TIPS — golden rules grid
   ==================================================================== */
/* ====================================================================
   GOLDEN RULES — split editorial: notebook photo αριστερά + 5 rule cards δεξιά
   ==================================================================== */
.routine-tips{background:var(--ivory);padding:7rem 3rem}

/* Centered title πάνω από τις 2 στήλες */
.routine-tips-head{text-align:center;margin:0 auto 4rem;max-width:780px}
.routine-tips-head .eyebrow{display:inline-block;margin-bottom:1.2rem;color:var(--plum-deep);font-size:.7rem;letter-spacing:.36em;font-weight:600}
.routine-tips-head h2{font-size:clamp(2.2rem,4vw,3.4rem);margin:0 0 1rem}
.routine-tips-head h2 em{font-style:italic;color:var(--gold-leaf)}

/* 2-col grid: align-items start ώστε photo + rules να ξεκινάνε από ΙΔΙΑ γραμμή πάνω */
.routine-tips-inner{max-width:1400px;margin:0 auto;display:grid;grid-template-columns:1.6fr 1fr;gap:4rem;align-items:start}

/* LEFT — notebook photo */
.routine-tips-photo{margin:0;border-radius:14px;overflow:hidden;box-shadow:0 30px 60px -22px rgba(31,24,19,0.22),0 8px 20px rgba(31,24,19,0.08);position:relative}
.routine-tips-photo img{display:block;width:100%;height:auto;transition:transform 1.4s var(--ease-luxe);filter:saturate(.98)}
@media (hover:hover){.routine-tips-photo:hover img{transform:scale(1.02)}}

/* RIGHT — rule cards stack ξεκινά από το TOP, ίδια γραμμή με photo */
.routine-tips-rules{display:flex;flex-direction:column;gap:.7rem}

/* RULES LIST — 5 premium luxury boxes */
.rules-list{display:flex;flex-direction:column;gap:.7rem;margin-top:.4rem;counter-reset:rule}
.rule-card{position:relative;display:flex;align-items:flex-start;gap:1.5rem;padding:1.4rem 3.2rem 1.4rem 2rem;background:#fff;border:1px solid rgba(31,24,19,0.05);border-radius:16px;box-shadow:0 1px 2px rgba(31,24,19,0.03),0 8px 20px -12px rgba(31,24,19,0.08);transition:transform .55s var(--ease-luxe),box-shadow .55s var(--ease-luxe),border-color .35s var(--ease-luxe),padding-left .45s var(--ease-luxe);overflow:hidden}
/* Vertical clay accent stripe on the left edge — grows on hover */
.rule-card::before{content:'';position:absolute;top:18%;bottom:18%;left:0;width:2px;background:var(--gold-leaf);opacity:.35;border-radius:0 2px 2px 0;transition:opacity .45s var(--ease-luxe),top .45s var(--ease-luxe),bottom .45s var(--ease-luxe)}
@media (hover:hover){
  .rule-card:hover{transform:translateX(6px);border-color:rgba(192,133,122,0.28);box-shadow:0 2px 4px rgba(31,24,19,0.04),0 18px 36px -16px rgba(31,24,19,0.20);padding-left:2.4rem}
  .rule-card:hover::before{opacity:1;top:0;bottom:0;width:3px}
}

/* Italic Cormorant numeral με circle outline */
.rule-num{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border:1px solid rgba(192,133,122,0.35);border-radius:50%;font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:500;font-size:1.05rem;color:var(--gold-leaf);line-height:1;letter-spacing:.01em;background:rgba(192,133,122,0.04);transition:all .45s var(--ease-luxe)}
@media (hover:hover){.rule-card:hover .rule-num{background:var(--gold-leaf);color:#fff;border-color:var(--gold-leaf);transform:rotate(-6deg)}}

/* Body — title + small caps tag + description */
.rule-body{flex:1;min-width:0}
.rule-body h4{font-family:'Cormorant Garamond',serif;font-weight:500;font-size:1.3rem;line-height:1.15;color:var(--aubergine);margin:0 0 .4rem;letter-spacing:-.008em}
.rule-body p{font-family:'Inter',sans-serif;font-size:.86rem;color:var(--ink-soft);opacity:.78;line-height:1.6;margin:0}

/* ✓ / ✗ badge top-right — distinguishes DO από DON'T */
.rule-mark{position:absolute;top:1.1rem;right:1.3rem;width:28px;height:28px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-family:'Inter',sans-serif;font-size:.88rem;font-weight:700;line-height:1;letter-spacing:0;transition:transform .35s var(--ease-luxe)}
.rule-card[data-type="do"] .rule-mark{background:rgba(192,133,122,0.14);color:var(--gold-leaf);border:1px solid rgba(192,133,122,0.32)}
.rule-card[data-type="dont"] .rule-mark{background:rgba(154,88,79,0.12);color:var(--plum-deep);border:1px solid rgba(154,88,79,0.30)}
/* Subtle accent stripe color per type */
.rule-card[data-type="dont"]::before{background:var(--plum-deep)}
@media (hover:hover){
  .rule-card:hover .rule-mark{transform:scale(1.08)}
  .rule-card[data-type="do"]:hover .rule-mark{background:var(--gold-leaf);color:#fff;border-color:var(--gold-leaf)}
  .rule-card[data-type="dont"]:hover .rule-mark{background:var(--plum-deep);color:#fff;border-color:var(--plum-deep)}
}

/* Responsive: tablet/mobile stack */
@media (max-width:968px){
  .routine-tips{padding:5rem 1.5rem}
  .routine-tips-inner{grid-template-columns:1fr;gap:3rem}
  .routine-tips-photo{max-width:560px;margin:0 auto}
  .routine-tips-rules .section-head{text-align:center}
  .routine-tips-rules .section-head h2,
  .routine-tips-rules .section-head p{text-align:center}
}
@media (max-width:480px){
  .routine-tips{padding:4rem 1.2rem}
  .rule-card{padding:1.1rem 1.4rem 1.1rem 1.6rem;gap:1rem;border-radius:14px}
  .rule-num{width:36px;height:36px;font-size:.95rem}
  .rule-body h4{font-size:1.15rem}
  .rule-body p{font-size:.82rem;line-height:1.55}
}

.tips-grid{
  display:grid;grid-template-columns:repeat(5,1fr);gap:1.5rem;
  max-width:1300px;margin:0 auto;
}
.tip{
  text-align:center;
  padding:2rem 1.2rem;
  border:1px solid rgba(156,132,114,0.12);
  border-radius:2px;
  transition:all .35s ease;
}
.tip:hover{border-color:var(--gold-leaf);transform:translateY(-3px)}
.tip-num{
  display:inline-block;
  font-family:'Cormorant Garamond',serif;font-style:italic;
  font-size:1.1rem;color:var(--gold-leaf);letter-spacing:.2em;
  margin-bottom:.8rem;
}
.tip h4{
  font-family:'Cormorant Garamond',serif;font-weight:500;
  font-size:1.2rem;color:var(--aubergine);
  margin-bottom:.6rem;line-height:1.2;
}
.tip p{
  font-family:'Cormorant Garamond',serif;font-style:italic;
  font-size:.95rem;color:var(--plum-deep);line-height:1.5;
}


/* ====================================================================
   5) QUOTE SECTION — closing
   ==================================================================== */
.quote-section{background:linear-gradient(135deg,var(--plum-deep),var(--aubergine));color:var(--ivory);text-align:center;padding:8rem 3rem;position:relative;overflow:hidden}
.quote-section::before{content:'';position:absolute;width:500px;height:500px;background:radial-gradient(circle,rgba(212,173,138,0.2),transparent 70%);border-radius:50%;top:-200px;right:-100px;filter:blur(60px)}
.quote-content{position:relative;z-index:2;max-width:800px;margin:0 auto}
.quote-content::before{content:'❝';font-family:'Cormorant Garamond',serif;font-size:5rem;color:var(--lavender-dust);display:block;line-height:1;margin-bottom:1rem}
.quote-content blockquote{font-family:'Cormorant Garamond',serif;font-weight:400;font-style:italic;font-size:clamp(1.5rem,3vw,2.4rem);line-height:1.4;margin-bottom:2rem}
.quote-content blockquote em{font-style:italic;color:var(--gold-soft);font-weight:500}
.quote-content cite{font-style:normal;font-size:.8rem;letter-spacing:.3em;text-transform:uppercase;color:var(--lavender-dust)}


/* ====================================================================
   MORNING ROUTINE V2 — Editorial premium shopping experience
   --------------------------------------------------------------------
   Scoped κάτω από .morning-v2 ώστε ΝΑ ΜΗΝ επηρεάσει το night routine.
   • .m-hero            — Step 01 & 02 full-width spotlight (2-col)
   • .m-grid + .m-card  — Steps 03–06 luxury cards (4-col → 2 → 1)
   • .m-essentials      — beginner essentials strip (3 chips)
   • .m-bundle          — closing bundle CTA με -5% badge
   ==================================================================== */

.morning-v2{padding:7rem clamp(1.5rem, 5vw, 5rem)}
.morning-v2 .section-head{margin-bottom:5rem}
.morning-v2 .section-head h2{font-size:clamp(2.4rem,4.6vw,3.6rem);max-width:780px}
.morning-v2 .section-head p{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.2rem;opacity:.78;max-width:620px}

/* ============ HERO STEP (full-width spotlight) ============ */
.m-hero{
  display:grid;grid-template-columns:1fr 1fr;gap:5rem;
  align-items:center;
  max-width:1280px;margin:0 auto 4.5rem;
  position:relative;
}
.m-hero--reverse{direction:rtl}
.m-hero--reverse > *{direction:ltr}

/* HERO visual side */
.m-hero-visual{position:relative;padding:1.2rem}
.m-hero-photo{
  position:relative;width:100%;aspect-ratio:4/5;overflow:hidden;
  background:linear-gradient(160deg,var(--rose-warm),var(--lavender-dust),var(--mauve-soft));
  box-shadow:
    0 1px 2px rgba(31,24,19,0.06),
    0 50px 80px -30px rgba(31,24,19,0.30),
    0 20px 40px -20px rgba(192,133,122,0.20);
  border:8px solid #fff;
  transition:transform .6s var(--ease-luxe);
}
.m-hero-photo:hover{transform:translateY(-4px)}
.m-hero-photo img{width:100%;height:100%;object-fit:cover;display:block}
.m-hero-photo--texture img{filter:saturate(.95) brightness(1.02)}
.m-hero-photo--texture{background:linear-gradient(160deg,var(--champagne),var(--rose-warm))}
.m-hero-photo::after{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse at 30% 20%, rgba(253,251,246,0.18) 0%, transparent 55%);
}

/* SKINYA PICK badge floating κορνίζα */
.m-hero-badge{
  position:absolute;top:1.2rem;left:1.2rem;z-index:3;
  background:rgba(31,24,19,0.85);color:var(--ivory);backdrop-filter:blur(6px);
  padding:.5rem .85rem;font-size:.55rem;
  letter-spacing:.38em;text-transform:uppercase;font-weight:600;
  display:inline-flex;align-items:center;gap:.5rem;
  box-shadow:0 8px 20px -8px rgba(31,24,19,0.4);
}
.m-hero-badge::before{content:'⭐';font-size:.85rem;letter-spacing:0}

/* HERO giant step number — editorial accent behind */
.m-hero-stepmark{
  position:absolute;top:-1.2rem;left:-.6rem;
  font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:300;
  font-size:10rem;line-height:.85;
  color:var(--gold-leaf);opacity:.18;
  pointer-events:none;z-index:0;letter-spacing:-.04em;
}
.m-hero--reverse .m-hero-stepmark{left:auto;right:-.6rem}

/* HERO content side */
.m-hero-content{display:flex;flex-direction:column;gap:1.3rem;max-width:540px}
.m-hero-meta{
  display:flex;align-items:center;gap:.7rem;flex-wrap:wrap;
  font-size:.6rem;letter-spacing:.28em;text-transform:uppercase;
  color:var(--mauve-soft);font-weight:600;margin-bottom:.2rem;
}
.m-step-tag{
  color:var(--plum-deep);background:rgba(192,133,122,0.14);
  padding:.42rem .8rem;letter-spacing:.32em;
  font-family:'Cormorant Garamond',serif;font-style:italic;font-size:.7rem;font-weight:500;
}
.m-step-dot{width:4px;height:4px;border-radius:50%;background:var(--gold-leaf);opacity:.55;flex-shrink:0}
.m-step-time{color:var(--mauve-soft)}
.m-step-best{color:var(--aubergine);opacity:.78;letter-spacing:.18em;font-weight:500}

.m-hero h3{
  font-family:'Cormorant Garamond',serif;font-weight:500;
  font-size:clamp(2rem,3.4vw,3rem);line-height:1.15;letter-spacing:-.018em;
  color:var(--aubergine);margin:0;padding-top:.15rem;
}
.m-hero h3 em{
  font-style:italic;
  background:linear-gradient(135deg,var(--plum-deep),var(--gold-leaf));
  -webkit-background-clip:text;background-clip:text;color:transparent;
  padding-right:.05em;
}
.m-hero-lead{
  font-family:'Cormorant Garamond',serif;font-size:1.18rem;line-height:1.65;
  color:var(--ink-soft);opacity:.88;margin:0;
}

/* RESULT band — bold outcome */
.m-result{
  background:linear-gradient(135deg, rgba(245,224,200,0.65), rgba(232,200,176,0.45));
  border-left:3px solid var(--gold-leaf);
  padding:1.2rem 1.4rem;position:relative;
}
.m-result-mark{
  display:block;font-size:.6rem;letter-spacing:.4em;
  text-transform:uppercase;color:var(--gold-leaf);font-weight:700;
  margin-bottom:.45rem;
}
.m-result strong{
  font-family:'Cormorant Garamond',serif;font-weight:500;font-style:italic;
  font-size:1.18rem;color:var(--aubergine);line-height:1.4;display:block;
}

/* CHIPS — ingredient highlights */
.m-chips{display:flex;flex-wrap:wrap;gap:.5rem}
.m-chip{
  background:#fff;border:1px solid rgba(192,133,122,0.32);
  padding:.42rem .9rem;font-size:.62rem;letter-spacing:.22em;
  text-transform:uppercase;color:var(--plum-deep);font-weight:600;
  border-radius:999px;display:inline-flex;align-items:center;gap:.35rem;
  transition:all .3s var(--ease-luxe);
}
.m-chip:hover{background:var(--rose-warm);border-color:var(--gold-leaf);transform:translateY(-1px)}

/* PRODUCT BLOCK — premium spotlight card */
.m-product{
  margin-top:.4rem;padding:1.4rem 1.5rem;background:#fff;
  border:1px solid rgba(31,24,19,0.06);position:relative;
  box-shadow:0 1px 2px rgba(31,24,19,0.04),0 16px 30px -14px rgba(31,24,19,0.12);
}
.m-product::before{
  content:'';position:absolute;top:0;left:0;width:60px;height:2px;
  background:linear-gradient(90deg,var(--gold-leaf),var(--plum-deep));
}
.m-product-head{
  display:flex;align-items:baseline;justify-content:space-between;
  gap:1rem;margin-bottom:.4rem;
}
.m-product-head small{
  font-size:.55rem;letter-spacing:.4em;text-transform:uppercase;
  color:var(--gold-leaf);font-weight:700;
}
.m-product-brand{
  font-size:.66rem;letter-spacing:.32em;text-transform:uppercase;
  color:var(--mauve-soft);font-weight:600;
}
.m-product-name{
  display:block;font-family:'Cormorant Garamond',serif;font-weight:500;
  font-size:1.4rem;color:var(--aubergine);line-height:1.18;margin-bottom:.7rem;
  letter-spacing:-.005em;
}
.m-why{
  font-size:.88rem;color:var(--ink-soft);line-height:1.6;
  opacity:.88;margin:0 0 1.2rem;
}
.m-why em{
  font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:500;
  color:var(--plum-deep);opacity:1;letter-spacing:.005em;
}

.m-cta-row{display:flex;align-items:center;gap:1.2rem;flex-wrap:wrap}
.m-cta-primary{padding:.95rem 1.7rem;font-size:.65rem}
.m-cta-link{
  background:none;border:none;cursor:pointer;
  font-size:.64rem;letter-spacing:.28em;text-transform:uppercase;font-weight:600;
  color:var(--plum-deep);font-family:'Inter',sans-serif;
  padding:.5rem 0;position:relative;
  transition:color .3s var(--ease-luxe), letter-spacing .3s var(--ease-luxe);
}
.m-cta-link:hover{color:var(--gold-leaf);letter-spacing:.32em}


/* ============ ROUTINE ORDER LEGEND ============ */
/* Editorial flow strip: εξηγεί τη σειρά εφαρμογής (από λεπτή σε πλούσια υφή) */
.morning-order{
  display:flex;align-items:center;justify-content:center;gap:1.4rem;flex-wrap:wrap;
  max-width:1240px;margin:3rem auto 1.5rem;
  padding:1.6rem 2rem;
  background:linear-gradient(135deg, rgba(245,224,200,0.55), rgba(232,200,176,0.40));
  border:1px dashed rgba(192,133,122,0.40);
  position:relative;text-align:center;
}
.m-order-label{font-size:.72rem;letter-spacing:.32em;text-transform:uppercase;color:var(--plum-deep);font-weight:700;position:absolute;left:2rem;top:50%;transform:translateY(-50%)}
.m-order-list{
  display:flex;align-items:center;gap:.4rem;flex-wrap:wrap;
  list-style:none;padding:0;margin:0;
}
.m-order-list li{
  font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:500;
  font-size:1.35rem;color:var(--aubergine);
  display:inline-flex;align-items:center;gap:.7rem;
  counter-increment:morningstep;
}
.m-order-list{counter-reset:morningstep}
.m-order-list li::after{display:none}
/* Βέλος ΠΡΙΝ κάθε item (εκτός του 1ου) → όταν σπάει η σειρά δεν μένει κρεμασμένο στο τέλος */
.m-order-list li:not(:first-child)::before{
  content:'→';color:var(--gold-leaf);opacity:.7;
  margin-right:.1rem;font-size:1.15rem;font-style:normal;display:inline-block;
}
.m-order-rule{
  font-family:'Cormorant Garamond',serif;font-style:italic;
  color:var(--plum-deep);font-size:1.05rem;
  margin-left:auto;margin:0;
}


/* ============ MORNING FAN · interactive card carousel (3D arc) ============ */
/* Vanilla port του card-stack/fan effect. Cards absolute-positioned, transforms
   υπολογίζονται από JS με βάση το offset από το active. Click side cards για να
   αλλάξεις active. Drag-to-swipe + dots + keyboard + prev/next. */
.cf-wrap{
  width:100%;max-width:1240px;margin:2rem auto 0;
  user-select:none;
}
.cf-stage{
  position:relative;
  height:640px;
  perspective:1400px;
  display:flex;align-items:flex-end;justify-content:center;
  outline:none;
}
.cf-stage::before{
  content:'';position:absolute;
  top:8%;left:50%;transform:translateX(-50%);
  width:60%;height:200px;
  background:radial-gradient(ellipse at center, rgba(192,133,122,0.18) 0%, transparent 65%);
  filter:blur(40px);pointer-events:none;
}
.cf-stage::after{
  content:'';position:absolute;
  bottom:-20px;left:50%;transform:translateX(-50%);
  width:70%;height:80px;
  background:radial-gradient(ellipse at center, rgba(31,24,19,0.15) 0%, transparent 70%);
  filter:blur(30px);pointer-events:none;
}
.cf-card{
  position:absolute;bottom:30px;
  width:420px;height:580px;
  background:#fff;
  border:4px solid rgba(31,24,19,0.08);
  border-radius:14px;overflow:hidden;
  box-shadow:0 1px 2px rgba(31,24,19,0.06), 0 28px 60px -16px rgba(31,24,19,0.30);
  transform-style:preserve-3d;
  cursor:pointer;
  will-change:transform,opacity;
  transition:transform .6s cubic-bezier(.32,.72,.2,1),
             opacity .4s ease,
             box-shadow .4s ease;
}
.cf-card.is-active{
  cursor:grab;
  box-shadow:0 2px 4px rgba(31,24,19,0.08), 0 40px 80px -20px rgba(192,133,122,0.35), 0 18px 40px -12px rgba(31,24,19,0.25);
}
.cf-card.is-active:active{cursor:grabbing}
.cf-card--must{border-color:rgba(192,133,122,0.30)}
.cf-photo{
  position:relative;width:100%;height:50%;
  background:linear-gradient(160deg, var(--lavender-mist), var(--champagne));
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
}
.cf-photo img{
  width:100%;height:100%;object-fit:cover;object-position:center;
  pointer-events:none;
}
.cf-photo--texture img{width:100%;height:100%;object-fit:cover;filter:saturate(.95) brightness(1.02)}
.cf-must-badge{
  position:absolute;top:.8rem;left:.8rem;
  background:linear-gradient(135deg,var(--gold-leaf),var(--plum-deep));
  color:#fff;font-size:.52rem;letter-spacing:.32em;text-transform:uppercase;font-weight:700;
  padding:.32rem .6rem;
}
.cf-info{
  padding:1.3rem 1.5rem 1.4rem;
  display:flex;flex-direction:column;gap:.45rem;
  height:50%;
}
.cf-top{display:flex;align-items:baseline;gap:.8rem}
.cf-step{
  font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:300;
  font-size:2.4rem;line-height:.9;color:var(--gold-leaf);
}
.cf-time{
  font-size:.55rem;letter-spacing:.32em;text-transform:uppercase;
  color:var(--mauve-soft);font-weight:600;
}
.cf-name{
  font-family:'Cormorant Garamond',serif;font-weight:500;
  font-size:1.8rem;line-height:1.1;color:var(--aubergine);
  margin:0;letter-spacing:-.005em;
}
.cf-why{
  font-family:'Cormorant Garamond',serif;font-style:italic;
  font-size:.95rem;line-height:1.5;color:var(--ink-soft);
  opacity:.85;margin:0;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;
}
.cf-pick{
  display:flex;flex-direction:column;gap:.1rem;
  margin-top:auto;padding-top:.5rem;
  border-top:1px dashed rgba(31,24,19,0.12);
}
.cf-brand{
  font-size:.55rem;letter-spacing:.32em;text-transform:uppercase;
  color:var(--gold-leaf);font-weight:600;
}
.cf-product{
  font-family:'Cormorant Garamond',serif;font-weight:500;
  font-size:1.05rem;line-height:1.25;color:var(--aubergine);
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.cf-cta{
  margin-top:.7rem;padding:.85rem 1.2rem;
  background:transparent;color:var(--aubergine);
  border:1px solid rgba(31,24,19,0.20);
  font-family:'Inter',sans-serif;font-size:.62rem;font-weight:600;
  letter-spacing:.28em;text-transform:uppercase;cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  position:relative;overflow:hidden;
  transition:all .3s var(--ease-luxe);
}
.cf-cta i{font-style:normal;font-size:.95rem;letter-spacing:0;transition:transform .3s var(--ease-luxe)}
.cf-cta::before{
  content:'';position:absolute;inset:0;z-index:0;
  background:linear-gradient(135deg,var(--gold-leaf),var(--plum-deep));
  transform:scaleX(0);transform-origin:left;
  transition:transform .35s var(--ease-luxe);
}
.cf-cta > *{position:relative;z-index:1}
.cf-cta:hover{color:#fff;border-color:transparent}
.cf-cta:hover::before{transform:scaleX(1)}
.cf-cta:hover i{transform:translateX(3px)}
.cf-controls{
  margin-top:2rem;display:flex;align-items:center;justify-content:center;gap:1.4rem;
}
.cf-nav{
  width:42px;height:42px;border-radius:50%;
  background:#fff;border:1px solid rgba(31,24,19,0.15);
  color:var(--aubergine);font-size:1.15rem;cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center;
  transition:all .3s var(--ease-luxe);
}
.cf-nav:hover{background:var(--gold-leaf);color:#fff;border-color:var(--gold-leaf);transform:translateY(-2px)}
.cf-dots{display:flex;align-items:center;gap:.7rem}
.cf-dot{
  width:8px;height:8px;border-radius:50%;
  background:rgba(31,24,19,0.18);border:none;cursor:pointer;padding:0;
  transition:all .3s var(--ease-luxe);
}
.cf-dot:hover{background:rgba(31,24,19,0.40)}
.cf-dot.is-active{background:var(--gold-leaf);width:24px;border-radius:4px}

/* Night context — dots/nav με light visibility πάνω στο chocolate bg */
.routine-section--night .cf-dot{background:rgba(255,255,255,0.25)}
.routine-section--night .cf-dot:hover{background:rgba(255,255,255,0.50)}
.routine-section--night .cf-dot.is-active{background:var(--gold-leaf)}
.routine-section--night .cf-nav{
  background:rgba(255,255,255,0.08);color:var(--ivory);
  border-color:rgba(245,224,200,0.25);backdrop-filter:blur(4px);
}
.routine-section--night .cf-nav:hover{background:var(--gold-leaf);color:#fff;border-color:var(--gold-leaf)}

/* Night context — order legend (matches chocolate theme) */
.routine-section--night .morning-order{
  background:linear-gradient(135deg, rgba(154,88,79,0.22), rgba(31,24,19,0.35));
  border-color:rgba(245,224,200,0.30);
  backdrop-filter:blur(6px);
}
.routine-section--night .m-order-label{color:var(--gold-soft)}
.routine-section--night .m-order-list li{color:var(--ivory)}
.routine-section--night .m-order-list li:not(:first-child)::before{
  color:var(--gold-soft);opacity:.85;
}
.routine-section--night .m-order-rule{color:var(--lavender-dust);opacity:.85}
.routine-section--night .m-order-rule em{color:var(--gold-soft)}
@media(max-width:900px){
  .cf-stage{height:500px}
  .cf-card{width:320px;height:440px}
  .cf-step{font-size:2rem}
  .cf-name{font-size:1.5rem}
}
@media(max-width:600px){
  .cf-wrap{margin-top:1rem}
  .cf-stage{height:370px}
  .cf-card{width:236px;height:330px;border-width:3px;bottom:20px}
  .cf-name{font-size:1.3rem}
  .cf-step{font-size:1.5rem}
  .cf-why{-webkit-line-clamp:2}
}


/* ============ MORNING ROWS · clean editorial step-rows (no animation, no sticky) ============ */
/* 6 βήματα σε vertical column με wide horizontal rows. Κάθε row έχει:
   photo αριστερά (220px) · content κέντρο · CTA δεξιά. Subtle hover, χωρίς
   3D stack tricks. Premium και άμεσα readable. */
.morning-rows{
  display:flex;flex-direction:column;gap:1.4rem;
  max-width:1240px;margin:1.5rem auto 0;
}
.mrow{
  background:#fff;
  border:1px solid rgba(31,24,19,0.07);
  display:grid;
  grid-template-columns:220px 1fr auto;
  gap:2rem;
  padding:1.6rem;
  align-items:center;
  position:relative;overflow:hidden;
  transition:transform .45s var(--ease-luxe),
             box-shadow .45s var(--ease-luxe),
             border-color .35s var(--ease-luxe);
}
.mrow::before{
  content:'';position:absolute;top:0;left:0;bottom:0;width:3px;
  background:linear-gradient(180deg, var(--gold-leaf), var(--plum-deep));
  transform:scaleY(0);transform-origin:top;
  transition:transform .5s var(--ease-luxe);
}
.mrow:hover{
  transform:translateY(-3px);
  border-color:var(--gold-leaf);
  box-shadow:0 1px 2px rgba(31,24,19,0.06), 0 28px 50px -20px rgba(192,133,122,0.30);
}
.mrow:hover::before{transform:scaleY(1)}
.mrow--must{
  background:linear-gradient(135deg, #fff 0%, rgba(245,224,200,0.50) 100%);
  border-color:rgba(192,133,122,0.35);
}
.mrow-photo{
  position:relative;width:100%;aspect-ratio:4/5;
  background:linear-gradient(160deg, var(--lavender-mist), var(--champagne));
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;border-radius:4px;
}
.mrow-photo img{
  width:78%;height:78%;object-fit:contain;
  filter:drop-shadow(0 12px 18px rgba(31,24,19,0.18));
  transition:transform .55s var(--ease-luxe);
}
.mrow:hover .mrow-photo img{transform:translateY(-3px) scale(1.05)}
.mrow-photo--texture img{filter:saturate(.95) brightness(1.02);width:100%;height:100%;object-fit:cover}
.mrow-must-badge{
  position:absolute;top:.8rem;left:.8rem;
  background:linear-gradient(135deg,var(--gold-leaf),var(--plum-deep));
  color:#fff;font-size:.52rem;letter-spacing:.32em;text-transform:uppercase;font-weight:700;
  padding:.32rem .6rem;
}
.mrow-body{
  display:flex;flex-direction:column;gap:.5rem;min-width:0;
}
.mrow-top{
  display:flex;align-items:baseline;gap:1rem;margin-bottom:.15rem;
}
.mrow-step{
  font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:300;
  font-size:2.4rem;line-height:.9;color:var(--gold-leaf);letter-spacing:-.02em;
}
.mrow-time{
  font-size:.58rem;letter-spacing:.32em;text-transform:uppercase;
  color:var(--mauve-soft);font-weight:600;
}
.mrow-name{
  font-family:'Cormorant Garamond',serif;font-weight:500;
  font-size:1.8rem;line-height:1.1;color:var(--aubergine);
  margin:0;letter-spacing:-.012em;padding-top:.1rem;
}
.mrow-why{
  font-family:'Cormorant Garamond',serif;font-style:italic;
  font-size:1rem;line-height:1.55;color:var(--ink-soft);
  opacity:.88;margin:.3rem 0 .2rem;max-width:540px;
}
.mrow-pick{
  display:flex;align-items:baseline;gap:.7rem;flex-wrap:wrap;
  padding-top:.6rem;border-top:1px dashed rgba(31,24,19,0.12);margin-top:.4rem;
}
.mrow-brand{
  font-size:.6rem;letter-spacing:.32em;text-transform:uppercase;
  color:var(--gold-leaf);font-weight:600;
}
.mrow-product{
  font-family:'Cormorant Garamond',serif;font-weight:500;
  font-size:1.05rem;color:var(--aubergine);
}
.mrow-cta{
  align-self:center;white-space:nowrap;
  padding:1rem 1.5rem;background:transparent;color:var(--aubergine);
  border:1px solid rgba(31,24,19,0.22);
  font-family:'Inter',sans-serif;font-size:.62rem;font-weight:600;
  letter-spacing:.28em;text-transform:uppercase;cursor:pointer;
  display:inline-flex;align-items:center;gap:.6rem;
  position:relative;overflow:hidden;transition:all .35s var(--ease-luxe);
}
.mrow-cta i{font-style:normal;font-size:.95rem;letter-spacing:0;transition:transform .3s var(--ease-luxe)}
.mrow-cta::before{
  content:'';position:absolute;inset:0;z-index:0;
  background:linear-gradient(135deg, var(--gold-leaf), var(--plum-deep));
  transform:scaleX(0);transform-origin:left;
  transition:transform .45s var(--ease-luxe);
}
.mrow-cta > *{position:relative;z-index:1}
.mrow-cta:hover{color:#fff;border-color:transparent}
.mrow-cta:hover::before{transform:scaleX(1)}
.mrow-cta:hover i{transform:translateX(4px)}
@media(max-width:1000px){
  .mrow{grid-template-columns:160px 1fr;gap:1.4rem;padding:1.3rem}
  .mrow-cta{grid-column:2;justify-self:start;align-self:start;margin-top:.6rem}
  .mrow-step{font-size:2.1rem}
  .mrow-name{font-size:1.6rem}
}
@media(max-width:600px){
  .mrow{grid-template-columns:1fr;gap:1rem;padding:1.4rem}
  .mrow-photo{aspect-ratio:4/3;max-height:240px}
  .mrow-cta{justify-self:flex-start;align-self:auto;margin-top:.4rem}
}


/* ============ MORNING FLOW · editorial full-width step rows (legacy fallback) ============ */
/* Όχι "product cards" — editorial rows. Κάθε βήμα είναι ένα ευρύ horizontal
   row με: GIANT italic step number αριστερά · elegant photo · content stack
   στο κέντρο · CTA δεξιά. Διαχωριστικές γραμμές μεταξύ rows αντί για borders. */
.morning-flow{
  display:flex;flex-direction:column;
  max-width:1240px;margin:1.5rem auto 0;
}
.m-flow-card{
  background:transparent;border:none;
  border-bottom:1px solid rgba(31,24,19,0.10);
  padding:2.4rem 1.6rem;
  display:grid;
  grid-template-columns:110px 240px 1fr auto;
  grid-template-rows:auto auto auto;
  gap:.5rem 2rem;
  align-items:start;
  position:relative;overflow:hidden;
  transition:background .45s var(--ease-luxe);
}
.m-flow-card:first-child{border-top:1px solid rgba(31,24,19,0.10)}

/* Hover — warm subtle highlight (NO product-card lift) */
.m-flow-card:hover{
  background:linear-gradient(135deg, rgba(245,224,200,0.40) 0%, rgba(232,200,176,0.18) 100%);
}

/* Editorial flow: step badge column / photo / content / cta */
.m-flow-card > .m-flow-top{
  grid-column:1;grid-row:1 / -1;
  align-self:center;
  flex-direction:column;align-items:flex-start;gap:.5rem;
}
.m-flow-card > .m-flow-photo{
  grid-column:2;grid-row:1 / -1;
  width:100%;align-self:center;margin:0;
  aspect-ratio:4/5;
}
.m-flow-card > .m-flow-name{grid-column:3;grid-row:1;margin:0;align-self:end}
.m-flow-card > .m-flow-pick{
  grid-column:3;grid-row:2;
  flex-direction:row;align-items:baseline;gap:.7rem;
  border-top:none;padding-top:0;margin-top:.1rem;
}
.m-flow-card > .m-flow-why{grid-column:3;grid-row:3;margin-top:.7rem;max-width:540px}
.m-flow-card > .m-flow-cta{
  grid-column:4;grid-row:1 / -1;
  align-self:center;justify-self:end;white-space:nowrap;
  padding:1rem 1.6rem;
  border:1px solid rgba(31,24,19,0.20);
}
.m-flow-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg, transparent 0%, var(--gold-leaf) 50%, transparent 100%);
  transform:scaleX(0);transform-origin:center;
  transition:transform .55s var(--ease-luxe);
}
.m-flow-card:hover{
  transform:translateY(-5px);border-color:var(--gold-leaf);
  box-shadow:0 1px 2px rgba(31,24,19,0.06), 0 30px 50px -20px rgba(192,133,122,0.30);
}
.m-flow-card:hover::before{transform:scaleX(1)}

/* MUST variant — SPF */
.m-flow-card--must{
  background:linear-gradient(180deg, #fff 0%, rgba(245,224,200,0.50) 100%);
  border-color:rgba(192,133,122,0.35);
}

/* Top column: GIANT italic step number + small time/must below it */
.m-flow-top{display:flex;align-items:center;gap:.55rem;flex-wrap:wrap}
.m-flow-step{
  font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:300;
  font-size:4.6rem;line-height:.85;letter-spacing:-.02em;
  color:var(--gold-leaf);background:none;padding:0;
}
.m-flow-time{
  font-size:.58rem;letter-spacing:.32em;text-transform:uppercase;
  color:var(--mauve-soft);font-weight:600;margin-top:.2rem;
}
.m-flow-must{
  margin-top:.2rem;color:#fff;
  background:linear-gradient(135deg, var(--gold-leaf), var(--plum-deep));
  padding:.32rem .65rem;font-size:.52rem;letter-spacing:.32em;
  text-transform:uppercase;font-weight:700;
}

/* Photo — small elegant frame στο left column, full-height */
.m-flow-card > .m-flow-photo{
  grid-column:1;grid-row:1 / -1;
  margin:0;align-self:stretch;
  aspect-ratio:auto;width:100%;
  background:linear-gradient(160deg, var(--lavender-mist), var(--champagne));
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;position:relative;
  border:1px solid rgba(192,133,122,0.18);
}
.m-flow-photo img{
  width:78%;height:78%;object-fit:contain;
  filter:drop-shadow(0 12px 18px rgba(31,24,19,0.18));
  transition:transform .6s var(--ease-luxe);
}
.m-flow-card:hover .m-flow-photo img{transform:translateY(-2px) scale(1.04)}
.m-flow-photo--texture img{filter:saturate(.95) brightness(1.02);width:100%;height:100%;object-fit:cover}

/* Name — μεγαλύτερο editorial title */
.m-flow-name{
  font-family:'Cormorant Garamond',serif;font-weight:500;
  font-size:2rem;line-height:1.12;color:var(--aubergine);
  margin:0;letter-spacing:-.012em;
}

/* Why-paragraph (το routine reasoning) */
.m-flow-why{
  font-family:'Cormorant Garamond',serif;font-style:italic;
  font-size:.92rem;line-height:1.5;color:var(--ink-soft);
  opacity:.88;margin:.2rem 0 .3rem;
}

/* Product pick block (brand + name) — dashed border για editorial διαχωρισμό */
.m-flow-pick{
  display:flex;flex-direction:column;gap:.2rem;
  padding-top:.7rem;border-top:1px dashed rgba(31,24,19,0.12);
  margin-top:auto;
}

/* Brand caps */
.m-flow-brand{
  font-size:.6rem;letter-spacing:.32em;text-transform:uppercase;
  color:var(--gold-leaf);font-weight:600;
}

/* Product name */
.m-flow-product{
  font-family:'Cormorant Garamond',serif;font-weight:500;
  font-size:1.05rem;line-height:1.25;color:var(--aubergine);
}

/* CTA — top dashed border removed (το pick-block το έχει ήδη) */
.m-flow-cta{
  padding:.5rem 0 0;
  background:none;border:none;
  font-family:'Inter',sans-serif;font-size:.62rem;font-weight:600;
  letter-spacing:.28em;text-transform:uppercase;color:var(--plum-deep);
  cursor:pointer;text-align:left;
  display:inline-flex;align-items:center;gap:.5rem;
  transition:gap .3s var(--ease-luxe), color .3s var(--ease-luxe);
}
.m-flow-cta::after{content:'→';font-size:.95rem;letter-spacing:0}
.m-flow-cta:hover{color:var(--gold-leaf);gap:.85rem}

/* Responsive */
@media(max-width:1000px){
  /* CTA πέφτει κάτω από content (όχι far right) */
  .m-flow-card{
    grid-template-columns:90px 200px 1fr;
    padding:2rem 1.2rem;gap:.4rem 1.5rem;
  }
  .m-flow-card > .m-flow-cta{
    grid-column:3;grid-row:4;
    justify-self:start;align-self:start;margin-top:1rem;
  }
  .m-flow-card > .m-flow-why{grid-row:3;max-width:none}
  .m-flow-step{font-size:3.6rem}
  .m-flow-name{font-size:1.7rem}
  .morning-order{padding:1.2rem 1.4rem}
  .m-order-rule{margin-left:0;margin-top:.3rem;width:100%}
}
@media(max-width:700px){
  /* Stack vertical for mobile */
  .m-flow-card{
    grid-template-columns:1fr;
    grid-template-rows:auto auto auto auto auto;
    gap:.7rem;padding:1.8rem 1rem;
  }
  .m-flow-card > .m-flow-top{
    grid-column:1;grid-row:1;
    flex-direction:row;align-items:baseline;gap:1rem;
  }
  .m-flow-step{font-size:2.8rem}
  .m-flow-time{margin-top:0}
  .m-flow-must{margin-top:0}
  .m-flow-card > .m-flow-photo{
    grid-column:1;grid-row:2;width:100%;max-width:300px;align-self:flex-start;
  }
  .m-flow-card > .m-flow-name{grid-column:1;grid-row:3;align-self:auto}
  .m-flow-card > .m-flow-pick{grid-column:1;grid-row:4}
  .m-flow-card > .m-flow-why{grid-column:1;grid-row:5;margin-top:.5rem}
  .m-flow-card > .m-flow-cta{grid-column:1;grid-row:6;justify-self:start;margin-top:.8rem}
  .morning-order{flex-direction:column;align-items:center;gap:.7rem;text-align:center}
  /* Label static (όχι absolute) → δεν πέφτει πάνω στις σειρές· μπαίνει σαν τίτλος πάνω */
  .m-order-label{position:static;transform:none;left:auto;top:auto;order:-1}
  /* Κάθετη σειρά (πάνω→κάτω) — όλα τα βήματα φαίνονται, με βελάκι ↓ ανάμεσα. Ποτέ δεν ξεχειλίζει. */
  .m-order-list{flex-direction:column;flex-wrap:nowrap;align-items:center;gap:.12rem;overflow:visible;max-width:100%}
  .m-order-list li{flex-direction:column;gap:.12rem;font-size:1rem;white-space:nowrap}
  .m-order-list li:not(:first-child)::before{content:'↓';margin:0;font-size:.82rem;opacity:.6}
  .m-order-rule{text-align:center}
}


/* ============ STEPS 03-06 LUXURY CARDS GRID — landscape horizontal cards ============ */
.m-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:1.4rem;
  max-width:1280px;margin:5rem auto 0;
  /* FIXED equal row heights → όλα τα cards ίδιο μέγεθος ανεξάρτητα από το ύψος της εικόνας */
  grid-auto-rows:370px;
}
/* Landscape card: square visual αριστερά · συμπιεσμένο content δεξιά */
.m-card{
  background:#fff;border:1px solid rgba(31,24,19,0.07);
  padding:1.2rem;
  display:grid;
  grid-template-columns:200px 1fr;
  grid-template-rows:auto auto auto auto 1fr auto;
  gap:.3rem 1.3rem;
  position:relative;overflow:hidden;
  height:100%;  /* γέμισε το 300px του grid row */
  transition:transform .45s var(--ease-luxe),
             box-shadow .45s var(--ease-luxe),
             border-color .35s var(--ease-luxe);
}
/* Text safety: clamp result & pick description — h4 αφήνεται ελεύθερο
   ώστε ο serif ascender να μην κόβεται από το overflow:hidden */
.m-card-result{
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;
  padding-bottom:.18em; /* descender safety για italic Cormorant */
}
.m-card-pick p{
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
  padding-bottom:.1em;
}
/* Place children in the right column */
.m-card > .m-card-top,
.m-card > h4,
.m-card > .m-card-result,
.m-card > .m-chips,
.m-card > .m-card-pick,
.m-card > .m-card-cta{grid-column:2}
.m-card > .m-card-top{grid-row:1;margin-bottom:.2rem}
.m-card > h4{grid-row:2}
.m-card > .m-card-result{grid-row:3;margin-top:.15rem}
.m-card > .m-chips{grid-row:4;margin-top:.4rem}
.m-card > .m-card-pick{grid-row:5;align-self:end;margin-top:.5rem}
.m-card > .m-card-cta{grid-row:6;margin-top:.45rem;justify-self:start;min-width:170px}
/* Visual: square block στο left column, stretched vertically */
.m-card > .m-card-visual{
  grid-column:1;grid-row:1 / -1;
  margin:0;aspect-ratio:auto;min-height:0;
  align-self:stretch;width:100%;
}
.m-card > .m-card-visual img{width:74%;height:74%}
/* Compressed typography για landscape feel */
.m-card h4{font-size:1.2rem;line-height:1.32;padding-top:.25rem}
.m-card-result{font-size:.9rem;line-height:1.5}
.m-card-pick{padding-top:.5rem;gap:.1rem}
.m-card-pick strong{font-size:.98rem}
.m-card-pick p{font-size:.74rem;line-height:1.45;margin-top:.18rem}
.m-card-cta{padding:.75rem 1.1rem;font-size:.6rem}
.m-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent 0%,var(--gold-leaf) 50%,transparent 100%);
  transform:scaleX(0);transform-origin:center;
  transition:transform .55s var(--ease-luxe);
}
.m-card:hover{
  transform:translateY(-6px);
  border-color:var(--gold-leaf);
  box-shadow:
    0 1px 2px rgba(31,24,19,0.06),
    0 35px 60px -22px rgba(192,133,122,0.30),
    0 12px 28px -10px rgba(31,24,19,0.12);
}
.m-card:hover::before{transform:scaleX(1)}

.m-card--key{
  background:linear-gradient(180deg,#fff 0%, rgba(245,224,200,0.50) 100%);
  border-color:rgba(192,133,122,0.40);
}
.m-card--key::after{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(circle at 100% 0%, rgba(192,133,122,0.18) 0%, transparent 55%);
}

.m-card-top{
  display:flex;align-items:center;gap:.55rem;
  font-size:.6rem;letter-spacing:.28em;text-transform:uppercase;font-weight:600;
}
.m-card-step{
  background:var(--aubergine);color:var(--ivory);
  padding:.35rem .6rem;letter-spacing:.18em;font-size:.66rem;
  font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:500;
}
.m-card-time{color:var(--mauve-soft);letter-spacing:.18em;font-size:.62rem}
.m-card-must{
  margin-left:auto;color:var(--ivory);
  background:linear-gradient(135deg,var(--plum-deep),var(--gold-leaf));
  padding:.32rem .65rem;letter-spacing:.32em;font-size:.55rem;font-weight:700;
  font-family:'Inter',sans-serif;
}

.m-card-visual{
  position:relative;aspect-ratio:1/1;
  background:linear-gradient(160deg, var(--lavender-mist), var(--champagne));
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;margin:.3rem -1.4rem;
}
.m-card-visual img{
  width:78%;height:78%;object-fit:contain;display:block;
  filter:drop-shadow(0 18px 28px rgba(31,24,19,0.20));
  transition:transform .6s var(--ease-luxe);
}
.m-card:hover .m-card-visual img{transform:translateY(-5px) scale(1.05)}
.m-card-badge{
  position:absolute;top:.85rem;left:.85rem;
  font-size:.54rem;letter-spacing:.26em;text-transform:uppercase;
  color:var(--ivory);background:rgba(31,24,19,0.78);backdrop-filter:blur(6px);
  padding:.42rem .72rem;font-weight:600;
}

.m-card h4{
  font-family:'Cormorant Garamond',serif;font-weight:500;
  font-size:1.4rem;line-height:1.14;color:var(--aubergine);margin:0;
  letter-spacing:-.005em;
}
.m-card h4 em{font-style:italic;color:var(--plum-deep)}
.m-card-result{
  font-family:'Cormorant Garamond',serif;font-style:italic;
  font-size:1rem;line-height:1.5;color:var(--ink-soft);
  opacity:.88;margin:0;
}
.m-chips--sm .m-chip{font-size:.55rem;padding:.32rem .72rem;letter-spacing:.18em}

.m-card-pick{
  padding-top:.85rem;border-top:1px dashed rgba(31,24,19,0.14);
  display:flex;flex-direction:column;gap:.18rem;margin-top:auto;
}
.m-card-pick small{
  font-size:.6rem;letter-spacing:.32em;text-transform:uppercase;
  color:var(--mauve-soft);font-weight:600;
}
.m-card-pick strong{
  font-family:'Cormorant Garamond',serif;font-weight:500;
  font-size:1.05rem;color:var(--aubergine);line-height:1.2;
}
.m-card-pick p{
  font-size:.78rem;color:var(--ink-soft);line-height:1.55;
  opacity:.82;margin:.32rem 0 0;
}
.m-card-pick p em{
  font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:500;
  color:var(--plum-deep);opacity:1;
}

.m-card-cta{
  margin-top:.5rem;padding:.95rem 1rem;background:transparent;
  border:1px solid rgba(31,24,19,0.20);cursor:pointer;
  font-family:'Inter',sans-serif;font-size:.62rem;font-weight:600;
  letter-spacing:.28em;text-transform:uppercase;color:var(--aubergine);
  display:inline-flex;align-items:center;justify-content:space-between;
  transition:all .35s var(--ease-luxe);position:relative;overflow:hidden;
}
.m-card-cta span{position:relative;z-index:1}
.m-card-cta i{
  font-style:normal;font-size:.95rem;letter-spacing:0;
  position:relative;z-index:1;transition:transform .3s var(--ease-luxe);
}
.m-card-cta::before{
  content:'';position:absolute;inset:0;z-index:0;
  background:linear-gradient(135deg,var(--gold-leaf),var(--plum-deep));
  transform:scaleX(0);transform-origin:left;
  transition:transform .45s var(--ease-luxe);
}
.m-card-cta:hover{color:#fff;border-color:transparent}
.m-card-cta:hover::before{transform:scaleX(1)}
.m-card-cta:hover i{transform:translateX(4px)}


/* ============ BEGINNER ESSENTIALS STRIP ============ */
.m-essentials{
  display:grid;grid-template-columns:1fr auto;gap:3rem;align-items:center;
  max-width:1100px;margin:4.5rem auto 0;
  padding:2.4rem 2.8rem;
  background:linear-gradient(135deg, rgba(245,224,200,0.55), rgba(232,200,176,0.40));
  border:1px dashed rgba(192,133,122,0.42);
  position:relative;
}
.m-essentials-content{display:flex;flex-direction:column;gap:.45rem;max-width:540px}
.m-essentials-content .eyebrow{margin-bottom:.2rem}
.m-essentials-content h4{
  font-family:'Cormorant Garamond',serif;font-weight:500;font-size:1.85rem;
  color:var(--aubergine);margin:0;letter-spacing:-.005em;
}
.m-essentials-content h4 em{font-style:italic;color:var(--plum-deep)}
.m-essentials-content p{
  font-size:.94rem;color:var(--ink-soft);line-height:1.6;opacity:.85;margin:.3rem 0 0;
}

.m-essentials-strip{display:flex;align-items:stretch;gap:.7rem}
.m-essential{
  background:#fff;border:1px solid rgba(31,24,19,0.08);
  padding:1rem 1.4rem;display:flex;flex-direction:column;align-items:center;
  gap:.3rem;min-width:90px;text-align:center;
  transition:transform .3s var(--ease-luxe), box-shadow .3s var(--ease-luxe);
}
.m-essential:hover{transform:translateY(-3px);box-shadow:var(--shadow-card)}
.m-essential span{
  font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.2rem;
  color:var(--gold-leaf);font-weight:500;line-height:1;
}
.m-essential strong{
  font-size:.64rem;letter-spacing:.32em;text-transform:uppercase;
  color:var(--aubergine);font-weight:600;
}
.m-essential--mid{
  background:var(--gold-leaf);border-color:var(--gold-leaf);
  box-shadow:0 6px 20px -8px rgba(192,133,122,0.45);
}
.m-essential--mid span{color:#fff;opacity:.85}
.m-essential--mid strong{color:#fff}
.m-essential--must{
  background:var(--aubergine);border-color:var(--aubergine);
  box-shadow:0 6px 20px -8px rgba(31,24,19,0.40);
}
.m-essential--must span{color:var(--gold-soft)}
.m-essential--must strong{color:var(--ivory)}


/* ============ BUNDLE CTA — Shop the full routine ============ */
.m-bundle{
  display:grid;grid-template-columns:.85fr 1.15fr;gap:0;
  max-width:1280px;margin:4rem auto 0;
  background:linear-gradient(135deg,var(--champagne) 0%, var(--rose-warm) 100%);
  color:var(--aubergine);position:relative;overflow:hidden;
  box-shadow:
    0 26px 60px -22px rgba(31,24,19,0.18),
    0 8px 20px -10px rgba(192,133,122,0.20);
}
.m-bundle::before{
  content:'';position:absolute;top:0;left:0;width:80px;height:1px;
  background:var(--gold-leaf);z-index:3;
}

.m-bundle-photo{
  position:relative;min-height:360px;
  background:
    radial-gradient(circle at 30% 30%, rgba(245,224,200,0.20) 0%, transparent 60%),
    linear-gradient(160deg, var(--rose-warm) 0%, var(--mauve-soft) 100%);
  display:flex;align-items:center;justify-content:center;padding:2rem;
  overflow:hidden;
}
.m-bundle-img{
  position:absolute;width:48%;max-width:210px;height:auto;
  object-fit:contain;filter:drop-shadow(0 22px 30px rgba(31,24,19,0.30));
  transition:transform .55s var(--ease-luxe);
}
.m-bundle-img--1{transform:rotate(-12deg) translate(-32%, 10%);z-index:1}
.m-bundle-img--2{transform:rotate(2deg) translate(0%, -8%);z-index:3;width:54%}
.m-bundle-img--3{transform:rotate(14deg) translate(32%, 8%);z-index:2}
.m-bundle:hover .m-bundle-img--1{transform:rotate(-15deg) translate(-36%, 8%)}
.m-bundle:hover .m-bundle-img--3{transform:rotate(17deg) translate(36%, 6%)}

/* ============ MARQUEE VARIANT — infinite horizontal scroll με polaroid tilt ============ */
.m-bundle--marquee .m-bundle-photo{
  padding:0;display:block;min-height:360px;overflow:hidden;
  -webkit-mask-image:linear-gradient(to right, transparent 0%, #000 12%, #000 88%, transparent 100%);
          mask-image:linear-gradient(to right, transparent 0%, #000 12%, #000 88%, transparent 100%);
}
.m-marquee-track{
  display:flex;align-items:center;gap:1rem;
  height:100%;padding:1.5rem 0;
  width:max-content;
  animation:marqueeScroll 36s linear infinite;
  will-change:transform;
}
.m-marquee-img{
  flex-shrink:0;
  width:auto;height:230px;aspect-ratio:3/4;
  object-fit:cover;border-radius:14px;
  background:#fff;
  box-shadow:0 18px 32px -14px rgba(31,24,19,0.32), 0 4px 10px -4px rgba(31,24,19,0.18);
  transition:transform .5s var(--ease-luxe);
}
/* alternate tilt -2deg / +5deg για polaroid feel */
.m-marquee-img:nth-child(odd){transform:rotate(-2deg)}
.m-marquee-img:nth-child(even){transform:rotate(5deg) translateY(-6px)}
.m-marquee-img:hover{transform:scale(1.06) translateY(-4px) rotate(0deg);z-index:5}

@keyframes marqueeScroll{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}

@media(prefers-reduced-motion: reduce){
  .m-marquee-track{animation:none}
}
@media(max-width:900px){
  .m-bundle--marquee .m-bundle-photo{min-height:240px}
  .m-marquee-img{height:170px}
  .m-marquee-track{animation-duration:28s}
}

.m-bundle-body{
  padding:3rem 3.2rem;display:flex;flex-direction:column;gap:1rem;
  position:relative;
}
.m-bundle-badge{
  position:absolute;top:1.6rem;right:1.6rem;
  background:var(--gold-leaf);color:var(--ivory);
  font-size:.95rem;letter-spacing:.18em;font-weight:700;
  padding:.65rem 1rem;font-family:'Cormorant Garamond',serif;font-style:italic;
  box-shadow:0 8px 20px -6px rgba(192,133,122,0.55);
}
.m-bundle-body .eyebrow{color:var(--plum-deep);margin:0}
.m-bundle-body h3{
  font-family:'Cormorant Garamond',serif;font-weight:500;
  font-size:clamp(1.8rem,2.8vw,2.5rem);line-height:1.08;color:var(--aubergine);
  margin:0;letter-spacing:-.012em;
}
.m-bundle-body h3 em{
  font-style:italic;
  background:linear-gradient(135deg,var(--plum-deep),var(--gold-leaf));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.m-bundle-body p{
  font-family:'Cormorant Garamond',serif;font-style:italic;
  font-size:1.05rem;color:var(--mauve-soft);opacity:1;
  line-height:1.6;max-width:480px;margin:0 0 .5rem;
}

.m-bundle-cta-row{
  display:flex;align-items:center;gap:1.4rem;flex-wrap:wrap;margin-top:.5rem;
}
.m-bundle-cta-row .btn-primary{
  background:var(--aubergine);color:var(--ivory);
  box-shadow:0 10px 24px -8px rgba(31,24,19,0.40);
}
.m-bundle-cta-row .btn-primary::after{background:var(--gold-leaf)}
.m-bundle-cta-row .btn-primary:hover{color:var(--ivory)}
.m-bundle-price{display:flex;flex-direction:column;gap:.12rem}
.m-bundle-price small{
  font-size:.58rem;letter-spacing:.32em;text-transform:uppercase;
  color:var(--mauve-soft);opacity:1;font-weight:600;
}
.m-bundle-price s{
  font-size:.95rem;color:var(--mauve-soft);opacity:.65;
  text-decoration:line-through;
}
.m-bundle-price strong{
  font-family:'Cormorant Garamond',serif;font-weight:500;
  font-size:1.7rem;color:var(--plum-deep);
}


/* ============ RESPONSIVE ============ */
@media(max-width:900px){
  .morning-v2{padding:5rem 1.5rem}
  .morning-v2 .section-head{margin-bottom:3rem}
  .m-hero{grid-template-columns:1fr;gap:2.2rem;margin-bottom:3rem}
  .m-hero--reverse{direction:ltr}
  .m-hero-visual{padding:.5rem;max-width:420px;margin:0 auto;width:100%}
  .m-hero-stepmark{font-size:6.5rem;top:-.4rem;left:0}
  .m-hero--reverse .m-hero-stepmark{left:0;right:auto}
  .m-hero-content{max-width:none}
  /* Wide cards → narrower visual column για κρατήσει 2-col layout */
  .m-grid{grid-auto-rows:300px}
  .m-card{grid-template-columns:160px 1fr;gap:.5rem 1.1rem;padding:1.2rem}
  .m-card > .m-card-visual{min-height:0}
  .m-essentials{grid-template-columns:1fr;gap:1.6rem;padding:2rem 1.6rem}
  .m-essentials-strip{justify-content:flex-start;flex-wrap:wrap}
  .m-bundle{grid-template-columns:1fr}
  .m-bundle-photo{min-height:280px}
  .m-bundle-body{padding:2.4rem 1.8rem}
  .m-bundle-badge{top:1rem;right:1rem;font-size:.85rem;padding:.55rem .85rem}
}
/* ============ NIGHT V2 — Refined dark chocolate (clean, no noise) ============ */
/* Background: ζεστό σκούρο σοκολατί gradient με ένα διακριτικό warm spotlight
   από πάνω. Σαφώς διαφορετικό από το velvet wine, χωρίς noise overlay,
   χωρίς πολλά radial pools — clean & elegant. */
.routine-section--night.night-v2{
  background:
    /* Single warm spotlight από πάνω */
    radial-gradient(70% 50% at 50% 0%, rgba(232,200,176,0.18) 0%, transparent 70%),
    /* Side warm pool */
    radial-gradient(45% 55% at 90% 60%, rgba(192,133,122,0.14) 0%, transparent 65%),
    /* Main chocolate gradient */
    linear-gradient(180deg, #4a2e22 0%, #2a1812 55%, #150906 100%);
  color:var(--ivory);
  position:relative;
  padding-top:3rem;
}
.routine-section--night.night-v2::before{display:none}

/* Section head — ivory text + gold-leaf accents (newsletter style) */
.routine-section--night.night-v2 .section-head h2{color:#fff}
.routine-section--night.night-v2 .section-head h2 em{
  color:var(--gold-leaf);font-style:italic;
  background:none;-webkit-text-fill-color:var(--gold-leaf);
}
.routine-section--night.night-v2 .section-head .eyebrow{color:var(--gold-leaf)}
.routine-section--night.night-v2 .section-head p{color:var(--lavender-dust);opacity:.92}
.routine-section--night.night-v2 .section-head p em{color:var(--gold-soft);font-style:italic}

/* HERO — ivory text + gold-leaf em (matches newsletter) */
.routine-section--night .m-hero h3{color:#fff}
.routine-section--night .m-hero h3 em{
  color:var(--gold-leaf);
  background:none;-webkit-text-fill-color:var(--gold-leaf);
}
.routine-section--night .m-hero-lead{color:var(--lavender-dust);opacity:.92}
.routine-section--night .m-step-tag{
  background:rgba(255,255,255,0.96);color:var(--plum-deep);
}
.routine-section--night .m-step-time{color:var(--lavender-dust);opacity:.85}
.routine-section--night .m-step-best{color:var(--gold-soft);opacity:.95}
.routine-section--night .m-step-dot{background:var(--gold-leaf);opacity:.9}
.routine-section--night .m-hero-stepmark{color:var(--gold-leaf);opacity:.18}

/* HERO badge — λευκό με plum text */
.routine-section--night .m-hero-badge{
  background:rgba(255,255,255,0.96);color:var(--plum-deep);
}

/* RESULT band — WHITE bg για υψηλό contrast */
.routine-section--night .m-result{
  background:linear-gradient(135deg, rgba(255,255,255,0.96), rgba(245,224,200,0.90));
  border-left-color:var(--gold-leaf);
  backdrop-filter:blur(4px);
}
.routine-section--night .m-result-mark{color:var(--plum-deep)}
.routine-section--night .m-result strong{color:var(--aubergine)}

/* CHIPS — WHITE bg για contrast πάνω στο terracotta */
.routine-section--night .m-chip{
  background:rgba(255,255,255,0.96);border-color:rgba(154,88,79,0.35);
  color:var(--plum-deep);
}
.routine-section--night .m-chip:hover{
  background:#fff;border-color:var(--plum-deep);color:var(--aubergine);
}

/* PRODUCT block — solid white card */
.routine-section--night .m-product{
  background:#fff;
  border-color:rgba(154,88,79,0.20);
  box-shadow:0 1px 2px rgba(0,0,0,0.06), 0 20px 40px -16px rgba(0,0,0,0.35);
}
.routine-section--night .m-product::before{
  background:linear-gradient(90deg, var(--gold-leaf), var(--plum-deep));
}
.routine-section--night .m-product-head small{color:var(--gold-leaf)}
.routine-section--night .m-product-brand{color:var(--mauve-soft)}
.routine-section--night .m-product-name{color:var(--aubergine)}
.routine-section--night .m-why{color:var(--ink-soft)}
.routine-section--night .m-why em{color:var(--plum-deep)}
.routine-section--night .m-cta-link{color:var(--plum-deep)}
.routine-section--night .m-cta-link:hover{color:var(--gold-leaf)}
/* primary button — keep gold-leaf, ίδια όψη με newsletter button */
.routine-section--night .m-cta-primary{background:var(--gold-leaf);box-shadow:0 8px 20px -8px rgba(154,88,79,0.45)}

/* HERO --key (Retinol MUST) — extra δραματικό με χρυσή κορνίζα */
.m-hero--key .m-hero-photo{
  box-shadow:
    0 1px 2px rgba(0,0,0,0.20),
    0 50px 100px -20px rgba(31,24,19,0.55),
    0 25px 50px -15px rgba(154,88,79,0.40);
  border-color:var(--gold-leaf);
}
.m-hero-badge--must{
  background:var(--gold-leaf) !important;color:#fff !important;
  letter-spacing:.36em;
}

/* CARDS — WHITE με terracotta accents */
.routine-section--night .m-card{
  background:#fff;
  border-color:rgba(154,88,79,0.16);
  box-shadow:0 1px 2px rgba(0,0,0,0.04), 0 18px 36px -16px rgba(31,24,19,0.25);
}
.routine-section--night .m-card:hover{
  background:#fff;
  border-color:var(--gold-leaf);
  box-shadow:
    0 1px 2px rgba(0,0,0,0.08),
    0 35px 60px -22px rgba(154,88,79,0.45),
    0 12px 28px -10px rgba(31,24,19,0.25);
}
.routine-section--night .m-card::before{
  background:linear-gradient(90deg, transparent 0%, var(--gold-leaf) 50%, transparent 100%);
}
.routine-section--night .m-card-step{
  background:var(--aubergine);color:var(--gold-soft);
}
.routine-section--night .m-card-time{color:var(--mauve-soft)}
.routine-section--night .m-card-visual{
  background:linear-gradient(160deg, var(--champagne) 0%, var(--rose-warm) 100%);
}
.routine-section--night .m-card h4{color:var(--aubergine)}
.routine-section--night .m-card h4 em{color:var(--plum-deep)}
.routine-section--night .m-card-result{color:var(--ink-soft);opacity:.88}
.routine-section--night .m-card-pick{border-top-color:rgba(154,88,79,0.18)}
.routine-section--night .m-card-pick small{color:var(--mauve-soft)}
.routine-section--night .m-card-pick strong{color:var(--aubergine)}
.routine-section--night .m-card-pick p{color:var(--ink-soft);opacity:.85}
.routine-section--night .m-card-pick p em{color:var(--plum-deep)}
.routine-section--night .m-card-cta{
  color:var(--aubergine);border-color:rgba(154,88,79,0.30);
}
.routine-section--night .m-card-cta::before{
  background:linear-gradient(135deg, var(--gold-leaf), var(--plum-deep));
}
.routine-section--night .m-card-cta:hover{color:#fff;border-color:transparent}
.routine-section--night .m-card-badge{
  background:rgba(31,24,19,0.85);
}

/* BUNDLE night — βαθύτερο για να ξεχωρίζει από το terracotta section */
.m-bundle--night{
  background:linear-gradient(135deg, #1a1108 0%, var(--aubergine) 60%, #2d1812 100%);
  color:var(--ivory);
}
.m-bundle--night .m-bundle-photo{
  background:
    radial-gradient(circle at 30% 30%, rgba(245,224,200,0.22) 0%, transparent 60%),
    linear-gradient(160deg, var(--plum-deep) 0%, #6a3a26 100%);
}
.m-bundle--night .m-bundle-badge{background:var(--gold-leaf);color:#fff}
/* Text overrides για το dark night bg */
.m-bundle--night .m-bundle-body .eyebrow{color:var(--gold-soft)}
.m-bundle--night .m-bundle-body h3{color:var(--ivory)}
.m-bundle--night .m-bundle-body h3 em{
  background:none;-webkit-text-fill-color:var(--gold-soft);color:var(--gold-soft);
}
.m-bundle--night .m-bundle-body p{color:var(--lavender-dust);opacity:.92}
.m-bundle--night .m-bundle-cta-row .btn-primary{
  background:var(--gold-leaf);color:#fff;
  box-shadow:0 10px 24px -8px rgba(192,133,122,0.55);
}
.m-bundle--night .m-bundle-cta-row .btn-primary::after{background:var(--ivory)}
.m-bundle--night .m-bundle-cta-row .btn-primary:hover{color:var(--aubergine)}
.m-bundle--night .m-bundle-price small{color:var(--lavender-dust);opacity:.7}
.m-bundle--night .m-bundle-price s{color:var(--lavender-dust);opacity:.55}
.m-bundle--night .m-bundle-price strong{color:var(--gold-soft)}


/* ============ WEEKLY V2 — light section, ίδια κάρτα-pattern ============ */
.weekly-v2{padding:7rem clamp(1.5rem, 5vw, 5rem);background:linear-gradient(180deg,var(--champagne) 0%, var(--ivory) 100%)}
.weekly-v2 .section-head{margin-bottom:5rem}
.weekly-v2 .section-head h2{font-size:clamp(2.4rem,4.6vw,3.6rem);max-width:780px}
.weekly-v2 .section-head h2 em{
  font-style:italic;
  background:linear-gradient(135deg,var(--plum-deep),var(--gold-leaf));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.weekly-v2 .section-head p{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.2rem;opacity:.78;max-width:620px}


@media(max-width:700px){
  /* Cards stack 1-col + ξαναγυρνάνε σε vertical layout (visual πάνω) */
  .m-grid{grid-template-columns:1fr;gap:1.2rem;grid-auto-rows:auto}
  .m-card{
    grid-template-columns:1fr;
    grid-template-rows:auto auto auto auto auto auto auto;
    gap:.95rem;padding:1.4rem;height:auto;
  }
  .m-card > .m-card-top{grid-row:1;grid-column:1}
  .m-card > .m-card-visual{
    grid-column:1;grid-row:2;
    aspect-ratio:1/1;min-height:0;margin:.3rem -1.4rem;
  }
  .m-card > h4{grid-row:3;grid-column:1}
  .m-card > .m-card-result{grid-row:4;grid-column:1}
  .m-card > .m-chips{grid-row:5;grid-column:1}
  .m-card > .m-card-pick{grid-row:6;grid-column:1;align-self:auto}
  .m-card > .m-card-cta{grid-row:7;grid-column:1}
}
