/* ============================================================
   EUROPEAN NATURAL BEAUTY MARKET — redesign concept
   Museum-editorial system
   ============================================================ */

:root{
  --paper:   #FAFAF8;
  --paper-2: #F1F1EC;
  --ink:     #141413;
  --ink-2:   #595955;
  --ink-3:   #8A8A84;
  --line:    #D3D3D3;
  --line-2:  #E4E4DF;
  --yellow:  #E2E423;
  --yellow-2:#EBED5A;

  --serif: "Cormorant Garamond", Georgia, serif;
  --grot:  "Helvetica Neue", Helvetica, "Arimo", Arial, sans-serif;

  --maxw: 1360px;
  --pad: 48px;
  --ease: cubic-bezier(.22,.61,.36,1);
}

*{ box-sizing: border-box; }
html{ -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; scroll-behavior: smooth; }
body{
  margin:0;
  background: var(--paper);
  color: var(--ink);
  font-family: var(--grot);
  font-size: 17px;
  line-height: 1.55;
  letter-spacing: -0.005em;
  overflow-x: hidden;
}
::selection{ background: var(--yellow); color: var(--ink); }
img{ display:block; max-width:100%; }
a{ color: inherit; text-decoration: none; }
button{ font-family: inherit; cursor: pointer; }

/* ---------- layout ---------- */
.wrap{ max-width: var(--maxw); margin: 0 auto; padding-inline: var(--pad); }
.section{ padding-block: clamp(64px, 9vw, 140px); }
.section--tight{ padding-block: clamp(48px, 6vw, 96px); }
.rule{ height:1px; background: var(--line); border:0; margin:0; }
.rule--ink{ background: var(--ink); height:1.5px; }

/* ---------- type ---------- */
.eyebrow{
  font-size: 11.5px; font-weight: 600; letter-spacing: .22em; text-transform: uppercase;
  color: var(--ink); display:flex; align-items:center; gap: 14px;
}
.eyebrow .idx{ color: var(--ink-3); font-variant-numeric: tabular-nums; }
.eyebrow--muted{ color: var(--ink-2); }

.display{
  font-family: var(--grot);
  font-weight: 600;
  line-height: .92;
  letter-spacing: -0.03em;
  margin: 0;
  text-wrap: balance;
}
.h-xl{ font-size: clamp(48px, 8.5vw, 132px); }
.h-lg{ font-size: clamp(36px, 5.4vw, 78px); }
.h-md{ font-size: clamp(28px, 3.4vw, 50px); }
.h-sm{ font-size: clamp(22px, 2.2vw, 32px); }

.serif{ font-family: var(--serif); font-weight: 400; letter-spacing: 0; }
.serif-quote{
  font-family: var(--serif);
  font-weight: 300;
  font-size: clamp(30px, 4.6vw, 66px);
  line-height: 1.08;
  letter-spacing: -0.01em;
  text-wrap: balance;
}
.serif-quote em{ font-style: italic; }

.lead{ font-size: clamp(18px, 1.5vw, 22px); line-height: 1.5; color: var(--ink-2); max-width: 60ch; }
.body{ color: var(--ink-2); }
.body p{ margin: 0 0 1.1em; max-width: 56ch; }
.tnum{ font-variant-numeric: tabular-nums; }

/* headline font tweak */
body[data-headfont="serif"] .display{ font-family: var(--serif); font-weight: 500; letter-spacing: -0.015em; line-height: .96; }
body[data-headfont="serif"] .h-xl{ font-weight: 500; }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap: 12px;
  font-family: var(--grot); font-size: 14px; font-weight: 600; letter-spacing: .02em;
  padding: 15px 26px; border: 1.5px solid var(--ink); background: var(--ink); color: var(--paper);
  border-radius: 0; transition: all .25s var(--ease); white-space: nowrap;
}
.btn .arr{ transition: transform .3s var(--ease); }
.btn:hover .arr{ transform: translateX(5px); }
.btn:hover{ background: transparent; color: var(--ink); }
.btn--yellow{ background: var(--yellow); border-color: var(--yellow); color: var(--ink); }
.btn--yellow:hover{ background: transparent; border-color: var(--ink); color: var(--ink); }
.btn--ghost{ background: transparent; color: var(--ink); }
.btn--ghost:hover{ background: var(--ink); color: var(--paper); }
.btn--light{ background: var(--paper); border-color: var(--paper); color: var(--ink); }
.btn--light:hover{ background: transparent; color: var(--paper); border-color: var(--paper); }
.btn--block{ width:100%; justify-content: space-between; }

.link-arrow{
  display:inline-flex; align-items:center; gap:10px; font-weight:600; font-size:14px;
  letter-spacing:.02em; padding-bottom:3px; border-bottom:1.5px solid var(--ink);
  transition: gap .25s var(--ease);
}
.link-arrow:hover{ gap: 16px; }

/* ---------- nav ---------- */
.nav{
  position: sticky; top:0; z-index: 50; background: var(--paper);
  border-bottom: 1px solid var(--line);
}
.nav__util{
  font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--ink-2);
  border-bottom: 1px solid var(--line-2);
}
.nav__util .wrap{ display:flex; justify-content: space-between; align-items:center; height: 36px; }
.nav__util .dot{ width:6px; height:6px; background: var(--yellow); border-radius:50%; display:inline-block; }
.nav__bar{ display:flex; align-items:center; justify-content: space-between; height: 74px; }
.nav__logo{ display:flex; align-items:center; gap: 14px; }
.nav__logo img{ height: 30px; width:auto; }
.nav__links{ display:flex; align-items:center; gap: 38px; }
.nav__link{
  font-size: 13.5px; font-weight: 600; letter-spacing: .04em; position: relative; padding: 4px 0;
}
.nav__link::after{
  content:""; position:absolute; left:0; right:100%; bottom:-2px; height:1.5px; background: var(--ink);
  transition: right .3s var(--ease);
}
.nav__link:hover::after, .nav__link[data-active="true"]::after{ right:0; }
.nav__link[data-active="true"]{ }
.nav__cta{ display:flex; align-items:center; gap: 18px; }

/* ---------- footer ---------- */
.footer{ background: var(--ink); color: var(--paper); padding-block: 80px 40px; }
.footer a:hover{ color: var(--yellow); }
.footer__grid{ display:grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 40px; }
.footer__col h4{ font-size: 11px; letter-spacing: .2em; text-transform: uppercase; color: var(--ink-3); margin:0 0 18px; font-weight:600; }
.footer__col ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap: 12px; }
.footer__col a{ font-size: 15px; color: #cfcfca; transition: color .2s; }
.footer__logo{ height: 40px; margin-bottom: 22px; }
.footer__bottom{ display:flex; justify-content: space-between; align-items:center; margin-top: 64px; padding-top: 24px; border-top:1px solid rgba(255,255,255,.16); font-size:12px; color: var(--ink-3); letter-spacing:.03em; }

/* ---------- bits ---------- */
.tag{
  display:inline-flex; align-items:center; gap:8px; font-size: 11px; font-weight:600;
  letter-spacing:.16em; text-transform: uppercase; padding: 7px 12px; border:1px solid var(--line);
  color: var(--ink-2); border-radius: 100px;
}
.tag--yellow{ background: var(--yellow); border-color: var(--yellow); color: var(--ink); }
.index-num{ font-size: 13px; font-weight:600; letter-spacing:.1em; color: var(--ink-3); font-variant-numeric: tabular-nums; }

image-slot{ background: var(--paper-2); }

/* reveal */
.reveal{ opacity:0; transform: translateY(26px); transition: opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce){ .reveal{ opacity:1; transform:none; transition:none; } html{ scroll-behavior:auto; } }

/* rounded-button tweak */
body[data-rounded="true"] .btn{ border-radius: 100px; }
body[data-rounded="true"] input,
body[data-rounded="true"] select,
body[data-rounded="true"] textarea{ border-radius: 12px; }

/* ---------- responsive ---------- */
@media (max-width: 1000px){
  .hero-grid{ grid-template-columns: 1fr !important; }
  .hero-side{ padding-bottom: 0 !important; }
  .sel-grid, .reg-hero, .reg-grid{ grid-template-columns: 1fr !important; }
  .faq-grid{ grid-template-columns: 1fr !important; gap: 28px !important; }
}
@media (max-width: 900px){
  :root{ --pad: 22px; }
  body{ font-size: 16px; }
  .nav__links{ display:none; }
  .footer__grid{ grid-template-columns: 1fr 1fr; gap: 32px; }
  .man-grid{ grid-template-columns: 1fr !important; gap: 24px !important; }
  .why-grid{ grid-template-columns: 1fr !important; }
  .why-grid > div{ border-left: none !important; padding-left: 0 !important; border-top: 1px solid var(--line); padding-top: 28px !important; }
  .facts-grid{ grid-template-columns: 1fr 1fr !important; }
  .facts-grid > div:nth-child(3){ border-left: none !important; padding-left: 0 !important; }
  .aud-grid{ grid-template-columns: 1fr !important; }
  .ben-grid{ grid-template-columns: 1fr !important; }
  .ben-grid > div{ border-left: none !important; padding-left: 0 !important; border-top: 1px solid var(--line) !important; }
  .price-grid{ grid-template-columns: 1fr !important; }
  .who-grid{ grid-template-columns: 1fr !important; }
  .who-grid > div{ border-left: none !important; padding-left: 0 !important; }
  .man-grid .body > div[style]{ grid-template-columns: 1fr !important; }
}
@media (max-width: 760px){
  .form-row{ grid-template-columns: 1fr !important; }
  .agenda-row{ grid-template-columns: 64px 1fr !important; }
  .agenda-row > .tag{ display:none; }
  .mosaic{ grid-template-columns: 1fr 1fr !important; grid-auto-rows: 150px !important; }
  .mosaic__fig{ grid-column: auto !important; grid-row: auto !important; }
  .mosaic__fig:first-child{ grid-column: 1 / 3 !important; grid-row: span 2 !important; }
}
@media (max-width: 600px){
  .nav__util .wrap .hide-sm{ display:none; }
  .footer__grid{ grid-template-columns: 1fr; }
  .facts-grid{ grid-template-columns: 1fr !important; }
  .facts-grid > div{ border-left: none !important; padding-left: 0 !important; border-top: 1px solid var(--line); }
}
