body{
  background:
    radial-gradient(circle at 12% 10%, rgba(193,92,138,.10), transparent 24%),
    radial-gradient(circle at 88% 12%, rgba(164,69,116,.08), transparent 20%),
    linear-gradient(180deg,#f8fafc 0%,#f2f5f8 100%);
}

.hero,
.uv-section,
.cats-wrap,
.brands-wrap,
.cta-banner,
.testimonials-wrap,
.about-wrap,
.saas-wrap,
.contact-wrap,
footer{
  width:min(1420px,calc(100% - 28px));
  margin-left:auto;
  margin-right:auto;
  border-radius:38px;
  overflow:hidden;
}

nav{
  width:100%;
  margin-top:0;
  margin-left:0;
  margin-right:0;
  top:0;
  border-radius:0;
  overflow:visible;
  padding-left:6%;
  padding-right:6%;
  background:
    linear-gradient(180deg,rgba(252,247,249,.98) 0%,rgba(247,239,243,.95) 42%,rgba(238,223,231,.84) 78%,rgba(209,154,180,.16) 100%);
  border-top:none;
  border-left:none;
  border-right:none;
  border-bottom:1px solid rgba(255,255,255,.32);
  box-shadow:0 18px 44px rgba(20,35,45,.08);
}

nav.up{
  box-shadow:0 22px 48px rgba(20,35,45,.10);
}

.hero,
.uv-pharma,
.cats-wrap,
.brands-wrap,
.testimonials-wrap,
.about-wrap,
.contact-wrap{
  background-color:rgba(255,255,255,.74);
  border:1px solid rgba(255,255,255,.58);
  box-shadow:0 28px 70px rgba(20,35,45,.08);
}

.hero{
  margin-top:18px;
  min-height:calc(100vh - 132px);
  grid-template-columns:minmax(0,1fr) minmax(360px,.88fr);
  gap:clamp(32px,4.4vw,72px);
  padding:118px 7% 98px;
}

.uv-section,
.cats-wrap,
.brands-wrap,
.cta-banner,
.testimonials-wrap,
.about-wrap,
.saas-wrap,
.contact-wrap,
footer{
  margin-top:22px;
}

.uv-pharma,
.uv-logiciel,
.brands-wrap,
.cta-banner,
.about-wrap,
.saas-wrap{
  margin-bottom:0!important;
}

.uv-pharma{
  clip-path:none;
  box-shadow:0 28px 70px rgba(20,35,45,.08);
}

.uv-logiciel{
  clip-path:none;
  padding-top:0;
  background:
    radial-gradient(circle at 18% 18%, rgba(84,149,197,.10), transparent 20%),
    linear-gradient(155deg,#08111b 0%,#101b2c 52%,#172233 100%);
  border:1px solid rgba(255,255,255,.08);
  box-shadow:0 32px 78px rgba(5,12,24,.28);
}

.cats-wrap,
.brands-wrap,
.testimonials-wrap,
.about-wrap,
.contact-wrap{
  padding-left:32px;
  padding-right:32px;
}

.cta-banner,
.saas-wrap,
footer{
  border:1px solid rgba(255,255,255,.08);
  box-shadow:0 32px 78px rgba(5,12,24,.22);
}

.hero::before,
.hero::after{
  opacity:.78;
}

.h-main-media,
.c-card.has-image .c-media,
.uv-ccat.has-img{
  background:
    linear-gradient(135deg,rgba(255,255,255,.18),rgba(255,255,255,.04)),
    linear-gradient(120deg,rgba(193,92,138,.16),rgba(164,69,116,.06) 42%,rgba(255,255,255,.08) 100%);
}

.h-main-media::before,
.c-card.has-image .c-media::before,
.uv-ccat.has-img::before{
  content:'';
  position:absolute;
  inset:0;
  z-index:1;
  background:linear-gradient(110deg,rgba(255,255,255,0) 0%,rgba(255,255,255,.28) 42%,rgba(255,255,255,0) 72%);
  transform:translateX(-140%);
  animation:premiumImageSweep 1.8s cubic-bezier(.16,1,.3,1) infinite;
  pointer-events:none;
  opacity:.85;
  transition:opacity .55s ease;
}

.h-main-media img,
.c-card.has-image .c-media img,
.uv-ccat.has-img img{
  opacity:.001;
  transition:
    opacity .78s cubic-bezier(.16,1,.3,1),
    transform .85s cubic-bezier(.16,1,.3,1),
    filter .85s ease;
}

.h-main-media.asset-loaded::before,
.c-card.has-image .c-media.asset-loaded::before,
.uv-ccat.has-img.asset-loaded::before{
  opacity:0;
  animation:none;
}

.h-main-media.asset-loaded img,
.c-card.has-image .c-media.asset-loaded img,
.uv-ccat.has-img.asset-loaded img{
  opacity:1;
}

.hero-content{max-width:604px;padding-right:6px}
.hero-title{
  font-size:clamp(62px,7.2vw,102px);
  line-height:.88;
  letter-spacing:-3.3px;
  text-wrap:balance;
}
.h-p{max-width:34rem;color:rgba(255,255,255,.82)}
.h-signals{gap:12px;max-width:620px}
.h-signal{padding:11px 15px;border-color:rgba(255,255,255,.14);background:rgba(255,255,255,.09)}
.h-kpis{
  max-width:580px;
  background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.04));
  box-shadow:0 22px 54px rgba(8,14,26,.16);
}
.kpi{padding:24px 22px}
.kpi-n{font-size:40px}
.h-panel{max-width:640px}
.h-composition{min-height:626px;padding:42px 30px 18px 42px}
.h-main-card{min-height:586px;border-radius:44px;box-shadow:0 38px 96px rgba(56,18,35,.22)}
.h-main-card::after{inset:14px;border-radius:34px}
.h-main-status{top:92px;right:20px;font-size:7.5px;letter-spacing:2px}
.h-main-panel{
  width:min(250px,calc(100% - 44px));
  padding:16px 16px 17px;
  border-radius:26px;
  background:linear-gradient(180deg,rgba(16,22,33,.18),rgba(16,22,33,.32));
}
.h-main-title{font-size:15px;line-height:1.2;letter-spacing:.15px}
.h-main-link,.h-saas-link{padding:10px 14px;font-size:7.5px;letter-spacing:1.7px}
.h-saas-card{
  width:min(41%,260px);
  right:-4px;
  bottom:18px;
  padding:14px;
  border-radius:28px;
  box-shadow:0 28px 72px rgba(6,20,38,.32);
}
.h-saas-card::before{inset:8px;border-radius:20px}
.h-saas-ui{min-height:194px;padding:13px;border-radius:20px}
.h-saas-title{font-size:18px}
.scroll-mouse{bottom:28px}
.section-live::after{
  opacity:.94;
  transform:translateY(-8px) scale(1.016);
  transition:
    opacity 1.08s cubic-bezier(.16,1,.3,1),
    transform 1.22s cubic-bezier(.16,1,.3,1);
}

@keyframes premiumImageSweep{
  0%{transform:translateX(-140%)}
  100%{transform:translateX(140%)}
}

.uv-section{box-shadow:inset 0 1px 0 rgba(255,255,255,.18)}
.uv-pharma{
  background:
    radial-gradient(circle at 12% 14%, rgba(255,255,255,.82), transparent 26%),
    radial-gradient(circle at 84% 18%, rgba(193,92,138,.13), transparent 22%),
    radial-gradient(circle at 72% 78%, rgba(217,154,185,.16), transparent 18%),
    linear-gradient(135deg,#fff9f6 0%,#f7eee8 38%,#f0e5dc 100%);
}
.uv-text{position:relative;z-index:2}
.uv-pharma .uv-text{
  max-width:620px;
  padding-right:4%;
}
.uv-pharma .uv-text::before{
  content:'';
  position:absolute;
  inset:38px 3% 38px 0;
  border-radius:40px;
  background:
    linear-gradient(180deg,rgba(255,255,255,.56),rgba(255,255,255,.18)),
    radial-gradient(circle at top left,rgba(255,255,255,.46),rgba(255,255,255,0) 34%);
  border:1px solid rgba(255,255,255,.62);
  box-shadow:
    0 28px 72px rgba(94,64,76,.10),
    inset 0 1px 0 rgba(255,255,255,.82);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  pointer-events:none;
  z-index:-1;
}
.uv-pharma .uv-text::after{
  content:'';
  position:absolute;
  left:34px;
  top:54px;
  width:92px;
  height:1px;
  background:linear-gradient(90deg,rgba(164,69,116,.34),rgba(164,69,116,0));
  pointer-events:none;
}
.uv-pharma .uv-visual::before{
  content:'';
  position:absolute;
  inset:38px 36px 34px 22px;
  border-radius:42px;
  background:
    linear-gradient(180deg,rgba(255,255,255,.34),rgba(255,255,255,.08)),
    radial-gradient(circle at 70% 18%,rgba(255,255,255,.32),rgba(255,255,255,0) 24%);
  border:1px solid rgba(255,255,255,.48);
  box-shadow:
    0 30px 80px rgba(94,64,76,.10),
    inset 0 1px 0 rgba(255,255,255,.8);
  pointer-events:none;
}
.uv-pharma .uv-visual::after{
  content:'';
  position:absolute;
  right:48px;
  top:48px;
  width:170px;
  height:170px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(255,255,255,.26),rgba(255,255,255,0) 72%);
  filter:blur(8px);
  pointer-events:none;
}
.uv-pharma .uv-eyebrow,
.uv-pharma .uv-lead,
.uv-pharma .uv-pills,
.uv-pharma .uv-cta{
  opacity:0;
  transform:translateY(18px);
  transition:
    opacity .76s cubic-bezier(.22,1,.36,1),
    transform .98s cubic-bezier(.16,1,.3,1);
}
.uv-pharma.in .uv-eyebrow,
.uv-pharma.in .uv-lead,
.uv-pharma.in .uv-pills,
.uv-pharma.in .uv-cta{
  opacity:1;
  transform:translateY(0);
}
.uv-pharma.in .uv-eyebrow{transition-delay:.06s}
.uv-pharma.in .uv-lead{transition-delay:.24s}
.uv-pharma.in .uv-pills{transition-delay:.36s}
.uv-pharma.in .uv-cta{transition-delay:.5s}
.uv-heading{text-wrap:balance}
.uv-heading-line{
  display:block;
  overflow:hidden;
  padding-bottom:.08em;
  margin-bottom:-.08em;
}
.uv-heading-inner{
  display:block;
  opacity:0;
  filter:blur(10px);
  transform:translateY(118%) skewY(3deg);
  transition:
    opacity .86s cubic-bezier(.22,1,.36,1),
    transform 1.14s cubic-bezier(.16,1,.3,1),
    filter .86s ease;
}
.uv-section.in .uv-heading-inner{
  opacity:1;
  filter:none;
  transform:translateY(0) skewY(0);
}
.uv-section.in .uv-heading-line:nth-child(2) .uv-heading-inner{
  transition-delay:.16s;
}
.uv-pharma .uv-heading{
  position:relative;
  font-size:clamp(60px,6vw,96px);
  letter-spacing:-3.4px;
  line-height:.86;
  margin-bottom:24px;
}
.uv-pharma .uv-lead{
  max-width:31rem;
  font-size:15px;
  line-height:1.92;
  color:rgba(73,48,60,.78);
}
.uv-pharma .uv-pills{
  gap:12px;
  margin:30px 0 38px;
}
.uv-pharma .uv-pill{
  position:relative;
  overflow:hidden;
  padding:10px 16px;
  border-radius:999px;
  background:linear-gradient(180deg,rgba(255,255,255,.62),rgba(255,255,255,.24));
  border:1px solid rgba(164,69,116,.18);
  box-shadow:0 10px 24px rgba(87,37,62,.05), inset 0 1px 0 rgba(255,255,255,.72);
  color:#b15f84;
  font-weight:600;
}
.uv-pharma .uv-pill::before{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(115deg,rgba(255,255,255,0),rgba(255,255,255,.56),rgba(255,255,255,0));
  transform:translateX(-180%);
  opacity:.52;
  transition:transform .8s cubic-bezier(.16,1,.3,1);
}
.uv-pharma .uv-pill:hover::before{
  transform:translateX(180%);
}
.uv-pharma .uv-cta{
  position:relative;
  padding:17px 38px;
  box-shadow:
    0 18px 34px rgba(80,10,35,.18),
    inset 0 1px 0 rgba(255,255,255,.06);
}
.uv-pharma .uv-cta::after{
  content:'';
  position:absolute;
  inset:1px;
  border-radius:inherit;
  border:1px solid rgba(255,255,255,.08);
  pointer-events:none;
}
.uv-pharma .uv-cats-grid{
  position:relative;
  isolation:isolate;
}
.uv-pharma .uv-cats-grid::before{
  content:'';
  position:absolute;
  inset:-16px;
  border-radius:42px;
  background:
    linear-gradient(180deg,rgba(255,255,255,.24),rgba(255,255,255,.08)),
    radial-gradient(circle at 22% 18%,rgba(255,255,255,.34),rgba(255,255,255,0) 26%);
  border:1px solid rgba(255,255,255,.46);
  box-shadow:
    0 26px 72px rgba(94,64,76,.12),
    inset 0 1px 0 rgba(255,255,255,.76);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  z-index:-1;
}
.uv-ccat{
  border-radius:26px;
  box-shadow:
    0 18px 42px rgba(72,34,54,.10),
    inset 0 1px 0 rgba(255,255,255,.16);
}
.uv-pharma .uv-ccat{
  border:1px solid rgba(255,255,255,.22);
  opacity:0;
  transform:translateY(22px) scale(.985);
  transition:
    opacity .74s cubic-bezier(.22,1,.36,1),
    transform .92s cubic-bezier(.16,1,.3,1),
    box-shadow .42s ease,
    border-color .42s ease;
}
.uv-pharma.in .uv-ccat{
  opacity:1;
  transform:translateY(0) scale(1);
}
.uv-pharma.in .uv-ccat:nth-child(1){transition-delay:.08s}
.uv-pharma.in .uv-ccat:nth-child(2){transition-delay:.14s}
.uv-pharma.in .uv-ccat:nth-child(3){transition-delay:.2s}
.uv-pharma.in .uv-ccat:nth-child(4){transition-delay:.26s}
.uv-pharma.in .uv-ccat:nth-child(5){transition-delay:.32s}
.uv-pharma.in .uv-ccat:nth-child(6){transition-delay:.38s}
.uv-ccat.long-name{padding:16px}
.uv-ccat.long-name .uv-ccat-nm{
  font-size:13.5px;
  line-height:1.15;
  max-width:10ch;
}
.uv-ccat:first-child.long-name .uv-ccat-nm{
  font-size:17px;
  max-width:11ch;
}
.uv-pharma .uv-cats-grid{
  grid-template-rows:repeat(3,1fr);
  width:min(94%,540px);
  height:498px;
}
.uv-pharma .uv-ccat:first-child{
  grid-row:span 3;
}
.uv-pharma .uv-ccat:last-child{
  grid-column:span 2;
  border-radius:24px;
  min-height:0;
  padding:18px 18px 20px;
}
.uv-pharma .uv-ccat:last-child .uv-ccat-nm{
  font-size:17px;
  line-height:1.04;
  max-width:16ch;
}
.uv-pharma .uv-ccat.long-name:last-child .uv-ccat-nm{
  font-size:18px;
}
.uv-pharma .uv-ccat::after{
  background:
    linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,0) 22%),
    radial-gradient(circle at var(--spot-x) var(--spot-y),rgba(255,255,255,.26),rgba(255,255,255,.08) 18%,rgba(255,255,255,0) 44%),
    linear-gradient(to top,rgba(30,5,18,.78) 0%,rgba(30,5,18,.32) 44%,rgba(30,5,18,.02) 78%);
}
.uv-pharma .uv-ccat:hover{
  transform:translateY(-8px) scale(1.012);
  box-shadow:
    0 28px 58px rgba(72,34,54,.16),
    inset 0 1px 0 rgba(255,255,255,.22);
  border-color:rgba(255,255,255,.36);
}
.uv-pharma .uv-ccat-nm{
  font-size:13px;
  line-height:1.08;
  letter-spacing:-.02em;
  text-shadow:0 10px 24px rgba(0,0,0,.28);
}
.uv-pharma .uv-text > *:not(.uv-heading){
  position:relative;
  z-index:1;
}
.uv-dash{border-radius:34px;box-shadow:0 34px 84px rgba(4,8,16,.24)}
.uv-dash-card{border-radius:24px}

.cats-grid{gap:20px}
.c-card{min-height:272px;padding:22px;border-radius:32px;box-shadow:0 24px 56px rgba(20,35,45,.08)}
.c-card.has-image .c-card-body{gap:12px;max-width:208px}
.c-card.has-image .c-nm{font-size:clamp(18px,1.9vw,23px);max-width:11ch}
.c-card.long-name .c-card-body{max-width:252px}
.c-card.long-name.has-image .c-nm{
  font-size:clamp(21px,2.15vw,28px);
  line-height:.98;
  max-width:15ch;
  text-wrap:balance;
}
.c-card:hover{box-shadow:0 30px 72px rgba(20,35,45,.12)}
.sec-sub{text-wrap:pretty}

.brand-track{gap:18px}
.brand-card{height:184px;flex:0 0 256px;border-radius:30px}
.brand-media img{transition:transform .5s cubic-bezier(.16,1,.3,1),filter .5s ease}
.brand-card:hover .brand-media img{transform:scale(1.04);filter:saturate(1.02) contrast(1.03)}
.brands-head{margin-bottom:8px}
.brands-title{max-width:720px}

.t-grid{grid-auto-rows:1fr}
.t-card{display:flex;flex-direction:column;min-height:100%}
.t-desc{margin-bottom:auto}
.testimonials-shell{gap:28px}
.t-card,.t-spotlight{box-shadow:0 26px 64px rgba(20,35,45,.10)}

.about-wrap{
  grid-template-columns:minmax(0,1.06fr) minmax(340px,.94fr);
  grid-template-areas:
    "copy visual"
    "manifesto manifesto";
  gap:clamp(38px,5.5vw,84px);
  align-items:start;
  background:
    linear-gradient(180deg,#fcfbf9 0%,#f4f5f6 100%);
}
.about-wrap::before{
  content:'';
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 14% 12%, rgba(231,183,203,.14), transparent 22%),
    radial-gradient(circle at 88% 18%, rgba(20,35,45,.06), transparent 22%),
    linear-gradient(90deg,rgba(255,255,255,.48),rgba(255,255,255,0) 34%);
  pointer-events:none;
  z-index:0;
}
.about-copy-stage,
.about-visual-stage,
.about-manifesto-stage{
  position:relative;
  z-index:1;
}
.about-copy-stage{
  grid-area:copy;
  align-self:start;
  padding-top:8px;
}
.about-tag{
  margin-bottom:18px;
}
.about-title{
  max-width:6.7ch;
  font-size:clamp(76px,7.6vw,124px);
  line-height:.84;
  letter-spacing:-.06em;
}
.about-title-line{
  display:block;
  overflow:hidden;
  padding-bottom:.05em;
  margin-bottom:-.05em;
}
.about-title-line > span{
  display:block;
  opacity:0;
  transform:translateY(102%);
  clip-path:inset(0 0 100% 0);
  transition:
    opacity .88s cubic-bezier(.16,1,.3,1),
    transform 1.14s cubic-bezier(.16,1,.3,1),
    clip-path 1.14s cubic-bezier(.16,1,.3,1);
}
.about-wrap.section-live .about-title-line > span{
  opacity:1;
  transform:none;
  clip-path:inset(0 0 0 0);
}
.about-wrap.section-live .about-title-line:nth-child(2) > span{
  transition-delay:.12s;
}
.a-lead{
  max-width:29ch;
  margin-top:24px;
  font-size:20px;
  line-height:1.84;
  color:#677883;
  opacity:0;
  transform:translateY(16px);
  transition:
    opacity .76s cubic-bezier(.22,1,.36,1) .14s,
    transform .94s cubic-bezier(.16,1,.3,1) .14s;
}
.about-wrap.section-live .a-lead{
  opacity:1;
  transform:none;
}
.a-note{
  width:min(100%,560px);
  margin:34px 0 0;
  min-height:0;
  padding:0 0 0 20px;
  border:none;
  background:none;
  box-shadow:none;
  opacity:0;
  transform:translateY(18px);
  transition:
    opacity .78s cubic-bezier(.22,1,.36,1) .22s,
    transform 1s cubic-bezier(.16,1,.3,1) .22s;
}
.about-wrap.section-live .a-note{
  opacity:1;
  transform:none;
}
.a-note::after{
  content:'';
  position:absolute;
  left:0;
  top:8px;
  bottom:8px;
  width:2px;
  background:linear-gradient(180deg,var(--g),rgba(193,92,138,.18));
  border-radius:999px;
}
.a-note-text{
  max-width:30ch;
  font-size:15px;
  line-height:1.78;
  color:#6c7b84;
}

.about-visual-stage{
  grid-area:visual;
  display:flex;
  align-items:flex-start;
  justify-content:flex-end;
  padding-top:26px;
}
.a-frame,
.a-brand-card,
.about-wrap .w-card,
.a-note,
.a-badge{
  animation:none!important;
}
.a-frame{
  width:min(100%,430px);
  position:relative;
  opacity:0;
  transform:translateY(28px) scale(.988);
  transition:
    opacity .96s cubic-bezier(.16,1,.3,1),
    transform 1.2s cubic-bezier(.16,1,.3,1);
}
.about-wrap.section-live .a-frame{
  opacity:1;
  transform:none;
}
.a-frame::before{
  content:'';
  position:absolute;
  left:18px;
  right:18px;
  top:-16px;
  height:1px;
  background:linear-gradient(90deg,rgba(193,92,138,0),rgba(193,92,138,.4),rgba(193,92,138,0));
}
.a-frame::after{
  content:'';
  position:absolute;
  right:-12px;
  bottom:-12px;
  width:146px;
  height:146px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(231,183,203,.28),rgba(231,183,203,0) 72%);
  filter:blur(18px);
  pointer-events:none;
}
.a-brand-card{
  position:relative;
  width:100%;
  border-radius:26px;
  background:
    linear-gradient(180deg,#fcfaf7 0%,#f1ece7 100%);
  border:1px solid rgba(201,122,158,.14);
  box-shadow:
    0 28px 64px rgba(20,35,45,.09),
    inset 0 1px 0 rgba(255,255,255,.9);
  opacity:0;
  transform:translateY(26px);
  transition:
    opacity .88s cubic-bezier(.16,1,.3,1) .12s,
    transform 1.06s cubic-bezier(.16,1,.3,1) .12s,
    box-shadow .3s ease;
}
.about-wrap.section-live .a-brand-card{
  opacity:1;
  transform:none;
}
.a-brand-card::before{
  content:'';
  position:absolute;
  inset:1px;
  border-radius:24px;
  background:
    linear-gradient(180deg,rgba(255,255,255,.46),rgba(255,255,255,.1));
  pointer-events:none;
}
.a-brand-card::after{
  content:'';
  position:absolute;
  inset:auto 24px 0 24px;
  height:1px;
  background:linear-gradient(90deg,rgba(193,92,138,0),rgba(193,92,138,.18),rgba(193,92,138,0));
}
.a-brand-shell{
  position:relative;
  padding:26px;
  overflow:hidden;
}
.a-brand-shell::before{
  content:'DMPA';
  position:absolute;
  right:20px;
  top:18px;
  font-family:var(--serif);
  font-size:72px;
  line-height:.82;
  letter-spacing:-.08em;
  color:rgba(87,37,62,.045);
  pointer-events:none;
}
.a-brand-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  margin-bottom:28px;
}
.a-city{
  padding:10px 14px;
  font-size:9.5px;
  letter-spacing:2.3px;
  text-transform:uppercase;
  border-radius:999px;
  border:1px solid rgba(87,37,62,.08);
  background:rgba(255,255,255,.5);
  color:#6a4155;
}
.a-meta{
  font-size:10px;
  letter-spacing:2.1px;
  text-transform:uppercase;
  color:#8d7d83;
}
.a-brand-core{
  display:grid;
  grid-template-columns:96px minmax(0,1fr);
  column-gap:22px;
  align-items:start;
}
.a-logo-wrap{
  display:flex;
  align-items:flex-start;
  justify-content:flex-start;
}
.a-logo{
  width:84px;
  padding:10px;
  border-radius:20px;
  background:#fff;
  box-shadow:0 18px 34px rgba(20,35,45,.08);
}
.a-brand-copy-wrap{
  gap:14px;
}
.a-brand-eyebrow{
  font-size:11px;
  letter-spacing:3px;
  text-transform:uppercase;
  color:#7f5a6d;
}
.a-brand-copy{
  max-width:27ch;
  font-size:15px;
  line-height:1.92;
  color:#66747c;
}
.a-badge{
  display:flex;
  align-items:baseline;
  gap:10px;
  padding-left:0;
  border-left:none;
  opacity:0;
  transform:translateY(16px);
  transition:
    opacity .74s cubic-bezier(.22,1,.36,1) .26s,
    transform .92s cubic-bezier(.16,1,.3,1) .26s;
}
.about-wrap.section-live .a-badge{
  opacity:1;
  transform:none;
}
.ab-n{
  font-size:18px;
  line-height:.82;
  color:#3d2330;
}
.ab-l{
  max-width:none;
  font-size:10px;
  letter-spacing:2px;
  color:#76838b;
}

.about-manifesto-stage{
  grid-area:manifesto;
  margin-top:2px;
}
.why-grid{
  margin-top:0!important;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:28px;
}
.about-wrap .w-card{
  min-height:0;
  padding:18px 6px 0 0;
  grid-template-columns:1fr;
  column-gap:0;
  row-gap:12px;
  background:none;
  border:none;
  box-shadow:none;
  opacity:0;
  transform:translateY(20px);
  transition:
    opacity .72s cubic-bezier(.22,1,.36,1),
    transform .98s cubic-bezier(.16,1,.3,1);
}
.about-wrap.section-live .w-card{
  opacity:1;
  transform:none;
}
.about-wrap.section-live .w-card:nth-child(1){transition-delay:.22s}
.about-wrap.section-live .w-card:nth-child(2){transition-delay:.3s}
.about-wrap.section-live .w-card:nth-child(3){transition-delay:.38s}
.about-wrap .w-card::before{
  content:'';
  position:absolute;
  left:0;
  top:0;
  width:42px;
  height:1px;
  background:linear-gradient(90deg,rgba(193,92,138,.6),rgba(193,92,138,0));
}
.about-wrap .w-card:hover{
  transform:translateY(-3px);
}
.about-wrap .w-card .w-title{
  max-width:8ch;
  margin-bottom:0;
  padding-top:18px;
  font-size:30px;
  line-height:.92;
  letter-spacing:-.03em;
}
.about-wrap .w-card .w-desc{
  max-width:22ch;
  margin:0;
  font-size:13.5px;
  line-height:1.86;
  color:#697983;
}

.w-card,.c-row{border-radius:30px}
.c-rows{gap:16px}
.c-row{padding:24px;min-height:108px;box-shadow:0 18px 42px rgba(20,35,45,.08)}
.map-wrap{height:460px;margin-top:56px;border-radius:32px}

.saas-new-layout{gap:56px}
.saas-head{max-width:760px}
.saas-copy{max-width:34rem}
.saas-feat-row{padding:18px 20px;border-radius:18px}
.saas-screen{border-radius:22px;box-shadow:0 36px 90px rgba(0,0,0,.46)}
.saas-screen-body{padding:16px}
.saas-screen-bar-fill{transition:width .92s cubic-bezier(.16,1,.3,1),filter .32s ease}

.cta-banner{padding-top:86px;padding-bottom:86px}
.cta-banner p{
  max-width:600px;
  color:rgba(255,255,255,.62);
}

.sec-h,
.brands-title,
.about-title{
  letter-spacing:-.04em;
}

.testimonials-wrap .sec-sub,
.cats-wrap .sec-sub,
.brands-sub{
  max-width:56ch;
}

.contact-wrap{gap:64px}
footer{
  column-gap:40px;
  margin-bottom:24px;
}

.h-main-card,
.h-saas-card,
.c-card,
.brand-card,
.t-card,
.w-card,
.c-row,
.saas-screen,
.uv-dash{
  position:relative;
  overflow:hidden;
}

.h-main-card::before,
.h-saas-card::before,
.c-card::before,
.brand-card::before,
.t-card::before,
.w-card::before,
.c-row::before,
.saas-screen::before,
.uv-dash::before{
  content:'';
  position:absolute;
  inset:-30% auto auto -38%;
  width:42%;
  height:180%;
  background:linear-gradient(115deg,rgba(255,255,255,0),rgba(255,255,255,.16),rgba(255,255,255,0));
  transform:translateX(-220%) skewX(-18deg);
  opacity:0;
  pointer-events:none;
  transition:transform .7s cubic-bezier(.22,1,.36,1),opacity .28s ease;
  z-index:2;
}

.h-main-card:hover::before,
.h-saas-card:hover::before,
.c-card:hover::before,
.brand-card:hover::before,
.t-card:hover::before,
.w-card:hover::before,
.c-row:hover::before,
.saas-screen:hover::before,
.uv-dash:hover::before{
  transform:translateX(360%) skewX(-18deg);
  opacity:.75;
}

.h-main-card,
.h-saas-card,
.c-card,
.brand-card,
.t-card,
.w-card,
.c-row,
.saas-screen,
.uv-dash,
.wa-cta,
.cta-btn1,
.cta-btn2,
.h-btn1,
.h-btn2,
.uv-cta,
.saas-btn,
.saas-btn-sub{
  transition:
    transform .34s cubic-bezier(.22,1,.36,1),
    box-shadow .34s cubic-bezier(.22,1,.36,1),
    border-color .34s ease,
    background .34s ease;
}

.h-main-card:hover,
.h-saas-card:hover,
.c-card:hover,
.brand-card:hover,
.t-card:hover,
.w-card:hover,
.c-row:hover,
.saas-screen:hover,
.uv-dash:hover{
  transform:translateY(-4px);
}

.wa-cta:hover,
.cta-btn1:hover,
.cta-btn2:hover,
.h-btn1:hover,
.h-btn2:hover,
.uv-cta:hover,
.saas-btn:hover,
.saas-btn-sub:hover{
  transform:translateY(-3px);
}

@media(hover:none),(pointer:coarse){
  .hero,
  .uv-pharma,
  .cats-wrap,
  .brands-wrap,
  .testimonials-wrap,
  .about-wrap,
  .contact-wrap{
    box-shadow:0 18px 42px rgba(20,35,45,.07);
  }

  .h-main-card,
  .h-saas-card,
  .uv-dash,
  .map-wrap,
  .t-card,
  .t-spotlight,
  .c-card,
  .brand-card,
  .w-card,
  .c-row,
  .saas-screen{
    box-shadow:0 16px 36px rgba(20,35,45,.08);
  }

  .h-main-card::before,
  .h-saas-card::before,
  .c-card::before,
  .brand-card::before,
  .t-card::before,
  .w-card::before,
  .c-row::before,
  .saas-screen::before,
  .uv-dash::before{
    display:none;
  }
}

@media(prefers-reduced-motion:reduce){
  nav,
  .hero,
  .uv-section,
  .cats-wrap,
  .brands-wrap,
  .cta-banner,
  .testimonials-wrap,
  .about-wrap,
  .saas-wrap,
  .contact-wrap,
  footer{
    scroll-behavior:auto;
  }

  .h-main-media::before,
  .c-card.has-image .c-media::before,
  .uv-ccat.has-img::before{
    animation:none;
  }

  .uv-heading-inner,
  .uv-pharma .uv-ccat{
    opacity:1;
    filter:none;
    transform:none;
    transition:none;
  }
}

@media(max-width:960px){
  .hero,
  .uv-section,
  .cats-wrap,
  .brands-wrap,
  .cta-banner,
  .testimonials-wrap,
  .about-wrap,
  .saas-wrap,
  .contact-wrap,
  footer{
    width:calc(100% - 20px);
    border-radius:30px;
  }
  nav{
    width:100%;
    border-radius:0;
    padding-left:5%;
    padding-right:5%;
  }
  .hero{padding:96px 6% 76px}
  .uv-pharma .uv-text::before{inset:28px 2% 28px 0;border-radius:34px}
  .uv-pharma .uv-visual::before{inset:28px 22px 28px 16px;border-radius:34px}
  .uv-pharma .uv-visual::after{right:28px;top:36px;width:132px;height:132px}
  .uv-pharma .uv-cats-grid::before{inset:-12px;border-radius:34px}
  .uv-pharma .uv-heading{font-size:clamp(52px,5.6vw,74px)}
  .h-composition{min-height:560px;padding:34px 22px 8px 30px}
  .h-main-card{min-height:520px}
  .h-saas-card{width:min(40%,244px);right:0;bottom:18px}
  .brand-card{flex-basis:224px}
  .map-wrap{height:360px;margin-top:30px}
  .uv-pharma .uv-cats-grid{width:min(100%,520px);height:462px}
  .uv-pharma .uv-ccat:last-child .uv-ccat-nm{font-size:16px}
  .saas-new-layout{gap:36px}
  .about-wrap{
    grid-template-columns:1fr;
    grid-template-areas:
      "copy"
      "visual"
      "manifesto";
    gap:32px;
  }
  .about-visual-stage{
    justify-content:flex-start;
    padding-top:0;
  }
  .a-frame{
    width:min(100%,520px);
    margin:0;
  }
  .about-title{
    max-width:8ch;
    font-size:clamp(58px,7.6vw,84px);
  }
  .a-lead{max-width:34ch}
  .a-note{width:min(100%,760px)}
  .why-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:24px 18px;
  }
  .why-grid .w-card{
    padding:18px 8px 0 0;
  }
  .why-grid .w-card:last-child{grid-column:span 2}
  .about-wrap,.contact-wrap{gap:40px}
  .cats-wrap,
  .brands-wrap,
  .testimonials-wrap,
  .about-wrap,
  .contact-wrap{padding-left:24px;padding-right:24px}
  .c-card.long-name .c-card-body{max-width:220px}
  .c-card.long-name.has-image .c-nm{font-size:clamp(19px,2vw,24px)}
}

@media(max-width:640px){
  .hero,
  .uv-section,
  .cats-wrap,
  .brands-wrap,
  .cta-banner,
  .testimonials-wrap,
  .about-wrap,
  .saas-wrap,
  .contact-wrap,
  footer{
    width:calc(100% - 14px);
    border-radius:24px;
  }
  nav{
    width:100%;
    border-radius:0;
    padding-left:18px;
    padding-right:18px;
  }
  .hero{padding-top:88px}
  .uv-pharma .uv-text::before,
  .uv-pharma .uv-visual::before,
  .uv-pharma .uv-cats-grid::before,
  .uv-pharma .uv-text::after,
  .uv-pharma .uv-visual::after{
    display:none;
  }
  .uv-pharma .uv-heading{font-size:46px;letter-spacing:-1.8px;line-height:.9}
  .uv-pharma .uv-lead{font-size:14px;line-height:1.82}
  .uv-pharma .uv-pill{padding:9px 14px}
  .hero-title{font-size:42px}
  .h-kpis{display:grid;grid-template-columns:1fr}
  .kpi:not(:last-child){border-right:none;border-bottom:1px solid rgba(255,255,255,.1)}
  .h-composition{padding:0}
  .h-main-card{min-height:344px}
  .h-saas-card{width:min(86%,290px);margin:-44px 0 0 auto}
  .brand-card{flex-basis:72vw}
  .map-wrap{height:320px}
  .a-frame{
    width:100%;
  }
  .a-brand-shell{
    padding:20px;
  }
  .a-brand-core{
    grid-template-columns:1fr;
    row-gap:14px;
  }
  .a-brand-head{
    align-items:flex-start;
    flex-direction:column;
  }
  .a-logo{
    width:76px;
    justify-self:start;
  }
  .about-title{
    font-size:44px;
    max-width:8.4ch;
  }
  .a-lead{
    font-size:16px;
    line-height:1.72;
  }
  .a-note{
    min-height:64px;
    border-radius:16px;
  }
  .why-grid{
    grid-template-columns:1fr;
    gap:18px;
  }
  .why-grid .w-card,
  .why-grid .w-card:last-child{
    grid-column:auto;
  }
  .about-wrap .w-card{
    min-height:0;
    padding:20px 0 0;
  }
  .about-wrap .w-card .w-title{
    font-size:24px;
  }
  .uv-pharma .uv-cats-grid{
    grid-template-columns:repeat(2,1fr);
    grid-template-rows:repeat(4,1fr);
    width:min(100%,360px);
    height:460px;
  }
  .uv-pharma .uv-ccat:first-child{
    grid-row:span 2;
  }
  .uv-pharma .uv-ccat:last-child{
    grid-column:span 2;
    padding:16px;
  }
  .uv-pharma .uv-ccat:last-child .uv-ccat-nm{font-size:16px;max-width:15ch}
  .uv-ccat.long-name .uv-ccat-nm{font-size:13px;max-width:11ch}
  .uv-ccat:first-child.long-name .uv-ccat-nm{font-size:15px}
  .c-card.long-name .c-card-body{max-width:210px}
  .c-card.long-name.has-image .c-nm{font-size:20px;max-width:14ch}
  .cta-banner{padding-top:64px;padding-bottom:64px}
  .cats-wrap,
  .brands-wrap,
  .testimonials-wrap,
  .about-wrap,
  .contact-wrap{padding-left:18px;padding-right:18px}
}

/* About Final Override */
.about-wrap{
  grid-template-columns:minmax(0,1.08fr) minmax(360px,.92fr);
  grid-template-areas:
    "copy visual"
    "manifesto manifesto";
  gap:clamp(40px,5.8vw,86px);
}
.about-copy-stage,
.about-visual-stage,
.about-manifesto-stage{
  position:relative;
  z-index:1;
}
.about-visual-stage{
  align-items:flex-start;
  justify-content:flex-end;
  padding-top:24px;
}
.a-frame,
.a-brand-card,
.about-wrap .w-card,
.a-note{
  animation:none!important;
}
.a-frame{
  width:min(100%,430px);
  position:relative;
  opacity:0;
  transform:translateY(28px) scale(.988);
  transition:
    opacity .96s cubic-bezier(.16,1,.3,1),
    transform 1.2s cubic-bezier(.16,1,.3,1);
}
.about-wrap.section-live .a-frame{
  opacity:1;
  transform:none;
}
.a-frame::before{
  content:'';
  position:absolute;
  left:18px;
  right:18px;
  top:-16px;
  height:1px;
  background:linear-gradient(90deg,rgba(193,92,138,0),rgba(193,92,138,.4),rgba(193,92,138,0));
}
.a-frame::after{
  content:'';
  position:absolute;
  right:-12px;
  bottom:-12px;
  width:146px;
  height:146px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(231,183,203,.28),rgba(231,183,203,0) 72%);
  filter:blur(18px);
  pointer-events:none;
}
.a-brand-card{
  position:relative;
  width:100%;
  border-radius:26px;
  background:linear-gradient(180deg,#fbfaf8 0%,#f2ede8 100%);
  border:1px solid rgba(201,122,158,.12);
  box-shadow:0 24px 56px rgba(20,35,45,.08), inset 0 1px 0 rgba(255,255,255,.92);
  opacity:0;
  transform:translateY(26px);
  transition:
    opacity .88s cubic-bezier(.16,1,.3,1) .12s,
    transform 1.06s cubic-bezier(.16,1,.3,1) .12s,
    box-shadow .3s ease;
}
.about-wrap.section-live .a-brand-card{
  opacity:1;
  transform:none;
}
.a-brand-card::before{
  content:'';
  position:absolute;
  inset:1px;
  border-radius:24px;
  background:linear-gradient(180deg,rgba(255,255,255,.52),rgba(255,255,255,.14));
  pointer-events:none;
}
.a-brand-card::after{
  content:'';
  position:absolute;
  inset:18px;
  border-radius:18px;
  border:1px solid rgba(87,37,62,.05);
  pointer-events:none;
}
.a-brand-shell{
  position:relative;
  padding:24px 24px 26px;
  overflow:hidden;
}
.a-brand-shell::before{
  content:'';
  position:absolute;
  right:-24px;
  bottom:-28px;
  width:186px;
  height:186px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(193,92,138,.08),rgba(193,92,138,0) 72%);
  filter:blur(12px);
  pointer-events:none;
}
.a-brand-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  margin-bottom:26px;
}
.a-city{
  padding:10px 14px;
  font-size:9.5px;
  letter-spacing:2.3px;
  text-transform:uppercase;
  border-radius:999px;
  border:1px solid rgba(87,37,62,.08);
  background:rgba(255,255,255,.56);
  color:#6a4155;
}
.a-meta{
  font-size:10px;
  letter-spacing:2.1px;
  text-transform:uppercase;
  color:#8d7d83;
}
.a-brand-core{
  display:grid;
  grid-template-columns:96px minmax(0,1fr);
  column-gap:22px;
  align-items:start;
}
.a-logo-wrap{
  display:flex;
  align-items:flex-start;
  justify-content:flex-start;
}
.a-logo{
  width:84px;
  padding:10px;
  border-radius:20px;
  background:#fff;
  box-shadow:0 18px 34px rgba(20,35,45,.08);
}
.a-brand-copy-wrap{
  display:flex;
  flex-direction:column;
  gap:12px;
  min-width:0;
}
.a-brand-eyebrow{
  font-size:11px;
  letter-spacing:3px;
  text-transform:uppercase;
  color:#7f5a6d;
}
.a-brand-title{
  font-family:var(--serif);
  font-size:clamp(38px,3.2vw,50px);
  line-height:.92;
  letter-spacing:-.045em;
  color:#24313a;
  text-wrap:balance;
}
.a-brand-copy{
  max-width:27ch;
  font-size:15px;
  line-height:1.9;
  color:#66747c;
}
.a-note{
  width:min(100%,560px);
}
.a-note-text{
  max-width:30ch;
  font-size:15px;
  line-height:1.78;
  color:#6c7b84;
}
.about-manifesto-stage{
  margin-top:6px;
}
.why-grid{
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:28px;
  border:none;
}
.about-wrap .w-card{
  min-height:0;
  padding:18px 8px 0 0;
  grid-template-columns:1fr;
  row-gap:12px;
  background:none;
  border:none;
  box-shadow:none;
  opacity:0;
  transform:translateY(20px);
  transition:
    opacity .72s cubic-bezier(.22,1,.36,1),
    transform .98s cubic-bezier(.16,1,.3,1);
}
.about-wrap.section-live .w-card{
  opacity:1;
  transform:none;
}
.about-wrap.section-live .w-card:nth-child(1){transition-delay:.22s}
.about-wrap.section-live .w-card:nth-child(2){transition-delay:.3s}
.about-wrap.section-live .w-card:nth-child(3){transition-delay:.38s}
.about-wrap .w-card::before{
  content:'';
  position:absolute;
  left:0;
  top:0;
  width:42px;
  height:1px;
  background:linear-gradient(90deg,rgba(193,92,138,.6),rgba(193,92,138,0));
}
.about-wrap .w-card::after,
.about-wrap .w-card .w-ic{
  display:none;
}
.about-wrap .w-card:hover{
  transform:translateY(-3px);
}
.about-wrap .w-card .w-title{
  max-width:8ch;
  margin-bottom:0;
  padding-top:18px;
  font-size:28px;
  line-height:.92;
  letter-spacing:-.03em;
}
.about-wrap .w-card .w-desc{
  max-width:22ch;
  margin:0;
  font-size:13.5px;
  line-height:1.86;
  color:#697983;
}

@media(max-width:960px){
  .about-wrap{
    grid-template-columns:1fr;
    grid-template-areas:
      "copy"
      "visual"
      "manifesto";
    gap:32px;
  }
  .about-visual-stage{
    justify-content:flex-start;
    padding-top:0;
  }
  .a-frame{
    width:min(100%,520px);
    margin:0;
  }
  .a-brand-title{
    font-size:40px;
  }
  .why-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:24px 18px;
  }
  .why-grid .w-card:last-child{
    grid-column:span 2;
  }
}

@media(max-width:640px){
  .a-brand-shell{
    padding:20px;
  }
  .a-brand-head{
    align-items:flex-start;
    flex-direction:column;
  }
  .a-brand-core{
    grid-template-columns:1fr;
    row-gap:14px;
  }
  .a-logo{
    width:76px;
  }
  .a-brand-title{
    font-size:36px;
  }
  .why-grid{
    grid-template-columns:1fr;
    gap:18px;
  }
  .why-grid .w-card:last-child{
    grid-column:auto;
  }
  .about-wrap .w-card{
    padding:20px 0 0;
  }
  .about-wrap .w-card .w-title{
    font-size:24px;
  }
}

/* About Creative Override v2 */
#about.about-wrap{
  grid-template-columns:minmax(0,1.08fr) minmax(360px,.92fr);
  grid-template-areas:
    "copy visual"
    "manifesto manifesto";
  gap:clamp(42px,6vw,88px);
}

#about .about-visual-stage{
  display:flex;
  justify-content:flex-end;
  align-items:flex-start;
  padding-top:28px;
}

#about .a-frame{
  width:min(100%,440px);
  position:relative;
  opacity:0;
  transform:translateY(28px) scale(.988);
  transition:
    opacity .96s cubic-bezier(.16,1,.3,1),
    transform 1.18s cubic-bezier(.16,1,.3,1);
}

#about.section-live .a-frame{
  opacity:1;
  transform:none;
}

#about .a-frame::before{
  content:'';
  position:absolute;
  left:24px;
  right:24px;
  top:-16px;
  height:1px;
  background:linear-gradient(90deg,rgba(193,92,138,0),rgba(193,92,138,.38),rgba(193,92,138,0));
}

#about .a-frame::after{
  content:'';
  position:absolute;
  right:-18px;
  bottom:-22px;
  width:170px;
  height:170px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(231,183,203,.26),rgba(231,183,203,0) 72%);
  filter:blur(20px);
  pointer-events:none;
}

#about .about-atelier{
  position:relative;
  min-height:520px;
  padding-left:36px;
}

#about .about-atelier-rail{
  position:absolute;
  inset:0 auto 0 0;
  width:78px;
  border-radius:30px;
  background:linear-gradient(180deg,#4b2037 0%,#5f2c48 52%,#733a58 100%);
  box-shadow:0 24px 52px rgba(53,23,39,.20);
}

#about .about-atelier-card{
  position:relative;
  margin-left:30px;
  min-height:520px;
  padding:28px 28px 30px;
  border-radius:28px;
  background:linear-gradient(180deg,#fcfaf8 0%,#f5efea 100%);
  border:1px solid rgba(201,122,158,.12);
  box-shadow:
    0 24px 56px rgba(20,35,45,.09),
    inset 0 1px 0 rgba(255,255,255,.92);
  overflow:hidden;
  opacity:0;
  transform:translateY(24px);
  transition:
    opacity .88s cubic-bezier(.16,1,.3,1) .12s,
    transform 1.02s cubic-bezier(.16,1,.3,1) .12s;
}

#about.section-live .about-atelier-card{
  opacity:1;
  transform:none;
}

#about .about-atelier-card::before{
  content:'';
  position:absolute;
  inset:18px;
  border-radius:22px;
  border:1px solid rgba(87,37,62,.05);
  pointer-events:none;
}

#about .about-atelier-card::after{
  content:'DMPA';
  position:absolute;
  right:20px;
  top:18px;
  font-family:var(--serif);
  font-size:78px;
  line-height:.82;
  letter-spacing:-.08em;
  color:rgba(87,37,62,.045);
  pointer-events:none;
}

#about .about-atelier-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  position:relative;
  z-index:1;
}

#about .about-chip{
  display:inline-flex;
  align-items:center;
  padding:10px 14px;
  border-radius:999px;
  border:1px solid rgba(87,37,62,.08);
  background:rgba(255,255,255,.56);
  font-size:9.5px;
  letter-spacing:2.3px;
  text-transform:uppercase;
  color:#6a4155;
}

#about .about-meta{
  font-size:10px;
  letter-spacing:2.1px;
  text-transform:uppercase;
  color:#8d7d83;
}

#about .about-atelier-brand{
  display:grid;
  grid-template-columns:92px minmax(0,1fr);
  gap:22px;
  align-items:start;
  position:relative;
  z-index:1;
  margin-top:78px;
}

#about .about-logo-wrap{
  display:flex;
  align-items:flex-start;
  justify-content:flex-start;
}

#about .about-logo-mark{
  width:82px;
  padding:10px;
  border-radius:20px;
  background:#fff;
  box-shadow:0 18px 34px rgba(20,35,45,.08);
}

#about .about-atelier-copy{
  display:flex;
  flex-direction:column;
  gap:14px;
}

#about .about-atelier-kicker{
  font-size:11px;
  letter-spacing:3px;
  text-transform:uppercase;
  color:#7f5a6d;
}

#about .about-atelier-body{
  max-width:24ch;
  font-family:var(--serif);
  font-size:clamp(32px,2.9vw,42px);
  line-height:1.02;
  letter-spacing:-.04em;
  color:#24313a;
  text-wrap:balance;
}

#about .about-atelier-divider{
  width:56px;
  height:1px;
  margin:34px 0 0 114px;
  background:linear-gradient(90deg,rgba(193,92,138,.6),rgba(193,92,138,0));
}

#about .about-atelier-motto{
  margin:18px 0 0 114px;
  font-size:12px;
  letter-spacing:3px;
  text-transform:uppercase;
  color:#8b7d84;
}

#about .why-grid{
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:28px;
  border:none;
}

#about .w-card{
  min-height:0;
  padding:18px 8px 0 0;
  grid-template-columns:1fr;
  row-gap:12px;
  background:none;
  border:none;
  box-shadow:none;
  opacity:0;
  transform:translateY(20px);
  transition:
    opacity .72s cubic-bezier(.22,1,.36,1),
    transform .98s cubic-bezier(.16,1,.3,1);
}

#about.section-live .w-card{
  opacity:1;
  transform:none;
}

#about.section-live .w-card:nth-child(1){transition-delay:.22s}
#about.section-live .w-card:nth-child(2){transition-delay:.3s}
#about.section-live .w-card:nth-child(3){transition-delay:.38s}

#about .w-card::before{
  content:'';
  position:absolute;
  left:0;
  top:0;
  width:42px;
  height:1px;
  background:linear-gradient(90deg,rgba(193,92,138,.6),rgba(193,92,138,0));
}

#about .w-card::after,
#about .w-card .w-ic{
  display:none;
}

#about .w-card .w-title{
  max-width:8ch;
  margin-bottom:0;
  padding-top:18px;
  font-size:28px;
  line-height:.92;
  letter-spacing:-.03em;
}

#about .w-card .w-desc{
  max-width:22ch;
  margin:0;
  font-size:13.5px;
  line-height:1.86;
  color:#697983;
}

@media(max-width:960px){
  #about.about-wrap{
    grid-template-columns:1fr;
    grid-template-areas:
      "copy"
      "visual"
      "manifesto";
    gap:32px;
  }

  #about .about-visual-stage{
    justify-content:flex-start;
    padding-top:0;
  }

  #about .a-frame{
    width:min(100%,520px);
  }

  #about .why-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:24px 18px;
  }

  #about .why-grid .w-card:last-child{
    grid-column:span 2;
  }
}

@media(max-width:640px){
  #about .about-atelier{
    min-height:0;
    padding-left:22px;
  }

  #about .about-atelier-rail{
    width:56px;
    border-radius:24px;
  }

  #about .about-atelier-card{
    margin-left:18px;
    min-height:0;
    padding:22px 20px 24px;
  }

  #about .about-atelier-top{
    flex-direction:column;
    align-items:flex-start;
  }

  #about .about-atelier-brand{
    grid-template-columns:1fr;
    gap:14px;
    margin-top:34px;
  }

  #about .about-logo-mark{
    width:76px;
  }

  #about .about-atelier-body{
    font-size:34px;
  }

  #about .about-atelier-divider,
  #about .about-atelier-motto{
    margin-left:0;
  }

  #about .why-grid{
    grid-template-columns:1fr;
    gap:18px;
  }

  #about .why-grid .w-card:last-child{
    grid-column:auto;
  }

  #about .w-card{
    padding:20px 0 0;
  }

  #about .w-card .w-title{
    font-size:24px;
  }
}

/* About Reset Override */
#about.about-wrap{
  grid-template-columns:minmax(0,1.04fr) minmax(360px,.96fr);
  grid-template-areas:
    "copy visual"
    "manifesto manifesto";
  gap:clamp(40px,5.5vw,84px);
}

#about .about-visual-stage{
  display:flex;
  align-items:flex-start;
  justify-content:flex-end;
  padding-top:22px;
}

#about .about-signature{
  width:min(100%,430px);
  position:relative;
  padding:26px 26px 28px 42px;
  border-radius:28px;
  background:
    linear-gradient(90deg,#4a2137 0, #4a2137 18px, #fbfaf8 18px, #f3eee9 100%);
  border:1px solid rgba(201,122,158,.12);
  box-shadow:
    0 24px 56px rgba(20,35,45,.08),
    inset 0 1px 0 rgba(255,255,255,.92);
  opacity:0;
  transform:translateY(28px);
  transition:
    opacity .92s cubic-bezier(.16,1,.3,1),
    transform 1.1s cubic-bezier(.16,1,.3,1);
}

#about.section-live .about-signature{
  opacity:1;
  transform:none;
}

#about .about-signature::before{
  content:'';
  position:absolute;
  inset:16px 16px 16px 34px;
  border-radius:22px;
  border:1px solid rgba(87,37,62,.05);
  pointer-events:none;
}

#about .about-signature::after{
  content:'';
  position:absolute;
  right:-18px;
  bottom:-18px;
  width:150px;
  height:150px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(231,183,203,.22),rgba(231,183,203,0) 72%);
  filter:blur(18px);
  pointer-events:none;
}

#about .about-signature-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  margin-bottom:34px;
  position:relative;
  z-index:1;
}

#about .about-signature-place,
#about .about-signature-years{
  font-size:10px;
  letter-spacing:2.2px;
  text-transform:uppercase;
  color:#826576;
}

#about .about-signature-place{
  display:inline-flex;
  align-items:center;
  padding:10px 14px;
  border-radius:999px;
  border:1px solid rgba(87,37,62,.08);
  background:rgba(255,255,255,.56);
  color:#6a4155;
}

#about .about-signature-main{
  display:grid;
  grid-template-columns:88px minmax(0,1fr);
  gap:22px;
  align-items:start;
  position:relative;
  z-index:1;
}

#about .about-signature-main::before{
  content:'';
  position:absolute;
  left:110px;
  right:0;
  top:-12px;
  height:1px;
  background:linear-gradient(90deg,rgba(193,92,138,.3),rgba(193,92,138,0));
}

#about .about-signature-logo{
  width:80px;
  padding:10px;
  border-radius:20px;
  background:#fff;
  box-shadow:0 16px 34px rgba(20,35,45,.08);
}

#about .about-signature-copy-wrap{
  display:flex;
  flex-direction:column;
  gap:14px;
  min-width:0;
}

#about .about-signature-name{
  font-family:var(--serif);
  font-size:clamp(38px,3.3vw,50px);
  line-height:.9;
  letter-spacing:-.045em;
  color:#24313a;
  text-wrap:balance;
}

#about .about-signature-copy{
  max-width:25ch;
  font-size:15px;
  line-height:1.86;
  color:#66747c;
}

#about .about-manifesto-stage{
  margin-top:10px;
}

#about .about-values{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:34px;
}

#about .about-value{
  position:relative;
  padding-top:24px;
  opacity:0;
  transform:translateY(20px);
  transition:
    opacity .72s cubic-bezier(.22,1,.36,1),
    transform .98s cubic-bezier(.16,1,.3,1);
}

#about.section-live .about-value{
  opacity:1;
  transform:none;
}

#about.section-live .about-value:nth-child(1){transition-delay:.22s}
#about.section-live .about-value:nth-child(2){transition-delay:.3s}
#about.section-live .about-value:nth-child(3){transition-delay:.38s}

#about .about-value::before{
  content:'';
  position:absolute;
  left:0;
  top:0;
  width:54px;
  height:1px;
  background:linear-gradient(90deg,rgba(193,92,138,.6),rgba(193,92,138,0));
}

#about .about-value h3{
  max-width:8ch;
  margin:0 0 12px;
  font-size:30px;
  line-height:.92;
  letter-spacing:-.03em;
  color:#24313a;
}

#about .about-value p{
  max-width:22ch;
  margin:0;
  font-size:13.5px;
  line-height:1.86;
  color:#697983;
}

@media(max-width:960px){
  #about.about-wrap{
    grid-template-columns:1fr;
    grid-template-areas:
      "copy"
      "visual"
      "manifesto";
    gap:32px;
  }

  #about .about-visual-stage{
    justify-content:flex-start;
    padding-top:0;
  }

  #about .about-values{
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:24px 18px;
  }

  #about .about-value:last-child{
    grid-column:span 2;
  }
}

@media(max-width:640px){
  #about .about-signature{
    padding:22px 20px 24px 32px;
  }

  #about .about-signature-top{
    flex-direction:column;
    align-items:flex-start;
  }

  #about .about-signature-main{
    grid-template-columns:1fr;
    gap:16px;
  }

  #about .about-signature-main::before{
    left:0;
  }

  #about .about-signature-logo{
    width:76px;
  }

  #about .about-signature-name{
    font-size:36px;
  }

  #about .about-values{
    grid-template-columns:1fr;
    gap:18px;
  }

  #about .about-value:last-child{
    grid-column:auto;
  }

  #about .about-value h3{
    font-size:24px;
  }
}

/* About Final Reset v3 */
#about.about-wrap{
  grid-template-columns:minmax(0,1.02fr) minmax(340px,.98fr);
  gap:clamp(36px,5vw,72px);
}

#about .about-copy-stage{
  padding-top:4px;
}

#about .about-title{
  max-width:6.9ch;
  font-size:clamp(56px,5.3vw,76px);
  line-height:.9;
}

#about .a-lead{
  max-width:30ch;
  margin-top:22px;
  font-size:16px;
  line-height:1.7;
}

#about .a-note{
  width:min(100%,520px);
  margin-top:28px;
  padding-left:18px;
}

#about .a-note-text{
  max-width:34ch;
  font-size:13px;
  line-height:1.7;
}

#about .about-visual-stage{
  padding-top:10px;
}

#about .about-signature{
  width:min(100%,420px);
  padding:24px;
  border-radius:20px;
  background:#ffffff;
  border:1px solid rgba(20,35,45,.08);
  box-shadow:
    0 16px 36px rgba(20,35,45,.05),
    inset 0 1px 0 rgba(255,255,255,.94);
}

#about .about-signature::before{
  inset:14px;
  border-radius:14px;
  border:1px solid rgba(20,35,45,.04);
}

#about .about-signature::after{
  display:none;
}

#about .about-signature-top{
  margin-bottom:20px;
}

#about .about-signature-place,
#about .about-signature-years{
  font-size:9px;
  letter-spacing:1.8px;
  color:#7f6f76;
}

#about .about-signature-place{
  padding:7px 10px;
  background:transparent;
  border:1px solid rgba(20,35,45,.08);
  color:#5e4a53;
}

#about .about-signature-main{
  grid-template-columns:64px minmax(0,1fr);
  gap:16px;
}

#about .about-signature-main::before{
  display:none;
}

#about .about-signature-logo{
  width:60px;
  padding:7px;
  border-radius:14px;
  box-shadow:0 10px 20px rgba(20,35,45,.05);
}

#about .about-signature-copy-wrap{
  gap:8px;
}

#about .about-signature-name{
  font-size:clamp(22px,1.9vw,28px);
  line-height:1;
  color:#1d2b33;
}

#about .about-signature-copy{
  max-width:26ch;
  font-size:12.5px;
  line-height:1.68;
  color:#67757d;
}

#about .about-manifesto-stage{
  margin-top:0;
}

#about .about-values{
  gap:18px;
  border-top:1px solid rgba(20,35,45,.07);
  padding-top:18px;
}

#about .about-value{
  padding-top:10px;
}

#about .about-value::before{
  width:22px;
  background:linear-gradient(90deg,rgba(193,92,138,.4),rgba(193,92,138,0));
}

#about .about-value h3{
  max-width:9ch;
  margin-bottom:6px;
  padding-top:12px;
  font-size:18px;
  line-height:1.02;
  color:#1f2d35;
}

#about .about-value p{
  max-width:24ch;
  font-size:12px;
  line-height:1.68;
  color:#6f7f88;
}

@media(max-width:960px){
  #about.about-wrap{
    grid-template-columns:1fr;
    gap:30px;
  }

  #about .about-signature{
    width:min(100%,500px);
  }

  #about .about-values{
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:18px 16px;
  }
}

@media(max-width:640px){
  #about .about-title{
    font-size:36px;
    max-width:8.2ch;
  }

  #about .a-lead{
    font-size:14px;
  }

  #about .about-signature{
    padding:18px;
  }

  #about .about-signature-top{
    flex-direction:column;
    align-items:flex-start;
    gap:10px;
  }

  #about .about-signature-main{
    grid-template-columns:1fr;
    gap:14px;
  }

  #about .about-signature-logo{
    width:60px;
  }

  #about .about-signature-name{
    font-size:24px;
  }

  #about .about-values{
    grid-template-columns:1fr;
    gap:16px;
  }
}

/* About Block V6 */
#about.about-block-v6{
  display:grid;
  grid-template-columns:minmax(0,1.04fr) minmax(320px,.96fr);
  grid-template-areas:
    "copy stage"
    "values values";
  gap:clamp(38px,5.4vw,78px);
  background:
    radial-gradient(circle at 16% 14%, rgba(231,183,203,.14), transparent 22%),
    linear-gradient(180deg,#fcfbf9 0%,#f4f5f6 100%);
}

#about.about-block-v6 .about-v6-copy{
  grid-area:copy;
  position:relative;
  z-index:1;
  padding-top:10px;
}

#about.about-block-v6 .about-v6-title{
  max-width:7.2ch;
  font-size:clamp(50px,5vw,68px);
  line-height:.95;
  letter-spacing:-.045em;
}

#about.about-block-v6 .about-v6-line{
  display:block;
  overflow:hidden;
  padding-bottom:.05em;
  margin-bottom:-.05em;
}

#about.about-block-v6 .about-v6-line > span{
  display:block;
  opacity:0;
  transform:translateY(102%);
  clip-path:inset(0 0 100% 0);
  transition:
    opacity .88s cubic-bezier(.16,1,.3,1),
    transform 1.12s cubic-bezier(.16,1,.3,1),
    clip-path 1.12s cubic-bezier(.16,1,.3,1);
}

#about.about-block-v6.section-live .about-v6-line > span{
  opacity:1;
  transform:none;
  clip-path:inset(0 0 0 0);
}

#about.about-block-v6.section-live .about-v6-line:nth-child(2) > span{
  transition-delay:.12s;
}

#about.about-block-v6 .about-v6-lead{
  max-width:34ch;
  margin-top:18px;
  font-size:16px;
  line-height:1.76;
  color:#667782;
}

#about.about-block-v6 .about-v6-note{
  width:min(100%,500px);
  margin-top:22px;
  padding-left:16px;
  position:relative;
  font-size:13px;
  line-height:1.72;
  color:#6e7e87;
}

#about.about-block-v6 .about-v6-note::before{
  content:'';
  position:absolute;
  left:0;
  top:4px;
  bottom:4px;
  width:1px;
  background:linear-gradient(180deg,var(--g),rgba(193,92,138,.16));
}

#about.about-block-v6 .about-v6-stage{
  grid-area:stage;
  position:relative;
  z-index:1;
  display:flex;
  justify-content:flex-end;
  align-items:flex-start;
  padding-top:6px;
}

#about.about-block-v6 .about-v6-shadow{
  position:absolute;
  right:18px;
  top:26px;
  width:calc(100% - 34px);
  height:100%;
  border-radius:26px;
  background:linear-gradient(180deg,#5a2840 0%,#6f3956 100%);
  opacity:.14;
  transform:translate(16px,16px);
  filter:blur(2px);
  pointer-events:none;
}

#about.about-block-v6 .about-v6-panel{
  width:min(100%,408px);
  position:relative;
  padding:24px;
  border-radius:26px;
  background:linear-gradient(180deg,#fffdfa 0%,#f4efea 100%);
  border:1px solid rgba(20,35,45,.08);
  box-shadow:
    0 20px 42px rgba(20,35,45,.06),
    inset 0 1px 0 rgba(255,255,255,.94);
  opacity:0;
  transform:translateY(26px);
  transition:
    opacity .9s cubic-bezier(.16,1,.3,1),
    transform 1.08s cubic-bezier(.16,1,.3,1);
}

#about.about-block-v6 .about-v6-panel::before{
  content:'';
  position:absolute;
  inset:14px;
  border-radius:18px;
  border:1px solid rgba(20,35,45,.05);
  pointer-events:none;
}

#about.about-block-v6.section-live .about-v6-panel{
  opacity:1;
  transform:none;
}

#about.about-block-v6 .about-v6-meta{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom:34px;
  position:relative;
  z-index:1;
}

#about.about-block-v6 .about-v6-place,
#about.about-block-v6 .about-v6-years{
  font-size:9px;
  letter-spacing:2px;
  text-transform:uppercase;
  color:#85747b;
}

#about.about-block-v6 .about-v6-place{
  padding:8px 12px;
  border-radius:999px;
  border:1px solid rgba(20,35,45,.08);
  background:rgba(255,255,255,.58);
  color:#6a4a59;
}

#about.about-block-v6 .about-v6-brand{
  display:grid;
  grid-template-columns:72px minmax(0,1fr);
  gap:18px;
  align-items:start;
  position:relative;
  z-index:1;
}

#about.about-block-v6 .about-v6-logo{
  width:64px;
  padding:8px;
  border-radius:16px;
  background:#fff;
  box-shadow:0 10px 20px rgba(20,35,45,.06);
}

#about.about-block-v6 .about-v6-brand-copy{
  display:flex;
  flex-direction:column;
  gap:10px;
}

#about.about-block-v6 .about-v6-kicker{
  font-family:var(--serif);
  font-size:clamp(24px,2.2vw,30px);
  line-height:.98;
  letter-spacing:-.03em;
  color:#223039;
}

#about.about-block-v6 .about-v6-brand-copy p{
  max-width:25ch;
  margin:0;
  font-size:12.5px;
  line-height:1.76;
  color:#6b7b83;
}

#about.about-block-v6 .about-v6-divider{
  width:48px;
  height:1px;
  margin:26px 0 0 90px;
  background:linear-gradient(90deg,rgba(193,92,138,.56),rgba(193,92,138,0));
}

#about.about-block-v6 .about-v6-motto{
  margin:14px 0 0 90px;
  font-size:11px;
  letter-spacing:2.6px;
  text-transform:uppercase;
  color:#8b7b83;
}

#about.about-block-v6 .about-v6-values{
  grid-area:values;
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:24px;
  padding-top:14px;
  border-top:1px solid rgba(20,35,45,.07);
}

#about.about-block-v6 .about-v6-value{
  position:relative;
  padding-top:18px;
  opacity:0;
  transform:translateY(18px);
  transition:
    opacity .72s cubic-bezier(.22,1,.36,1),
    transform .96s cubic-bezier(.16,1,.3,1);
}

#about.about-block-v6.section-live .about-v6-value{
  opacity:1;
  transform:none;
}

#about.about-block-v6.section-live .about-v6-value:nth-child(1){transition-delay:.22s}
#about.about-block-v6.section-live .about-v6-value:nth-child(2){transition-delay:.3s}
#about.about-block-v6.section-live .about-v6-value:nth-child(3){transition-delay:.38s}

#about.about-block-v6 .about-v6-value::before{
  content:'';
  position:absolute;
  left:0;
  top:0;
  width:34px;
  height:1px;
  background:linear-gradient(90deg,rgba(193,92,138,.54),rgba(193,92,138,0));
}

#about.about-block-v6 .about-v6-value h3{
  max-width:10ch;
  margin:0 0 8px;
  font-size:18px;
  line-height:1.08;
  letter-spacing:-.02em;
  color:#223039;
}

#about.about-block-v6 .about-v6-value p{
  max-width:24ch;
  margin:0;
  font-size:12px;
  line-height:1.72;
  color:#72818a;
}

@media(max-width:960px){
  #about.about-block-v6{
    grid-template-columns:1fr;
    grid-template-areas:
      "copy"
      "stage"
      "values";
    gap:30px;
  }

  #about.about-block-v6 .about-v6-stage{
    justify-content:flex-start;
    padding-top:0;
  }

  #about.about-block-v6 .about-v6-values{
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:20px 18px;
  }

  #about.about-block-v6 .about-v6-value:last-child{
    grid-column:span 2;
  }
}

@media(max-width:640px){
  #about.about-block-v6 .about-v6-title{
    font-size:38px;
    max-width:8.4ch;
  }

  #about.about-block-v6 .about-v6-lead{
    font-size:14px;
  }

  #about.about-block-v6 .about-v6-panel{
    width:100%;
    padding:20px;
  }

  #about.about-block-v6 .about-v6-meta{
    flex-direction:column;
    align-items:flex-start;
    gap:10px;
    margin-bottom:24px;
  }

  #about.about-block-v6 .about-v6-brand{
    grid-template-columns:1fr;
    gap:14px;
  }

  #about.about-block-v6 .about-v6-logo{
    width:60px;
  }

  #about.about-block-v6 .about-v6-kicker{
    font-size:24px;
  }

  #about.about-block-v6 .about-v6-divider,
  #about.about-block-v6 .about-v6-motto{
    margin-left:0;
  }

  #about.about-block-v6 .about-v6-values{
    grid-template-columns:1fr;
    gap:18px;
  }

  #about.about-block-v6 .about-v6-value:last-child{
    grid-column:auto;
  }
}

/* Contact V2 Override */
#contact.contact-wrap{
  grid-template-columns:minmax(0,.96fr) minmax(360px,1.04fr);
  gap:clamp(32px,4.8vw,64px);
  background:
    radial-gradient(circle at 12% 14%, rgba(193,92,138,.10), transparent 22%),
    linear-gradient(180deg,#fbfcfd 0%,#f2f6f8 100%);
}

#contact > div:first-child{
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
}

#contact .sec-h{
  max-width:8ch;
}

#contact .sec-tag + .sec-h + .c-rows::before,
#contact .sec-tag + .sec-h + .c-rows::after{
  display:none;
}

#contact .sec-tag + .sec-h{
  margin-bottom:0;
}

#contact > div:first-child::after{
  content:'';
  width:56px;
  height:1px;
  margin-top:18px;
  background:linear-gradient(90deg,rgba(193,92,138,.56),rgba(193,92,138,0));
}

#contact .c-rows{
  display:grid;
  grid-template-columns:1fr;
  gap:14px;
  margin-top:22px;
}

#contact .c-row{
  min-height:0;
  padding:18px 18px 18px 16px;
  border-radius:20px;
  border:1px solid rgba(20,35,45,.07);
  background:
    linear-gradient(180deg,rgba(255,255,255,.94),rgba(248,250,252,.98));
  box-shadow:
    0 14px 28px rgba(20,35,45,.05),
    inset 0 1px 0 rgba(255,255,255,.92);
}

#contact .c-row .c-ic{
  width:44px;
  height:44px;
  border-radius:14px;
  background:linear-gradient(180deg,rgba(255,255,255,.95),rgba(244,234,239,.96));
  border:1px solid rgba(193,92,138,.10);
  box-shadow:none;
}

#contact .c-row .c-lbl{
  font-size:10px;
  letter-spacing:2px;
  text-transform:uppercase;
  color:#8b7a82;
}

#contact .c-row .c-val{
  font-size:18px;
  line-height:1.24;
  color:#1f2d35;
}

#contact .c-row .c-val2{
  margin-top:4px;
  font-size:13px;
  line-height:1.68;
  color:#6c7d87;
}

#contact .wa-cta{
  margin-top:18px;
  align-self:flex-start;
}

#contact > div:last-child{
  display:flex;
  flex-direction:column;
  gap:14px;
}

#contact > div:last-child::before{
  content:'Accès rapide';
  font-size:10px;
  letter-spacing:2.1px;
  text-transform:uppercase;
  color:#8b7a82;
}

#contact > div:last-child::after{
  content:'Un point de repère simple pour venir en boutique.';
  margin-top:-6px;
  font-size:14px;
  line-height:1.7;
  color:#6c7d87;
}

#contact .map-wrap{
  margin-top:0;
  height:100%;
  min-height:460px;
  border-radius:26px;
  border:1px solid rgba(20,35,45,.07);
  box-shadow:
    0 20px 42px rgba(20,35,45,.06),
    inset 0 1px 0 rgba(255,255,255,.9);
  overflow:hidden;
}

#contact .map-wrap iframe{
  filter:saturate(.92) contrast(1.02);
}

@media(max-width:960px){
  #contact.contact-wrap{
    grid-template-columns:1fr;
    gap:28px;
  }

  #contact .map-wrap{
    min-height:360px;
  }
}

@media(max-width:640px){
  #contact .c-row{
    padding:16px 16px 16px 14px;
    border-radius:18px;
  }

  #contact .c-row .c-val{
    font-size:16px;
  }

  #contact .map-wrap{
    min-height:320px;
    border-radius:22px;
  }
}

/* About Editorial Override v4 */
#about.about-wrap{
  grid-template-columns:minmax(0,1.06fr) minmax(320px,.94fr);
  gap:clamp(40px,5.4vw,78px);
}

#about .about-copy-stage{
  padding-top:10px;
}

#about .about-tag{
  margin-bottom:14px;
}

#about .about-title{
  max-width:7.2ch;
  font-size:clamp(52px,5.2vw,72px);
  line-height:.94;
  letter-spacing:-.05em;
}

#about .a-lead{
  max-width:33ch;
  margin-top:20px;
  font-size:16px;
  line-height:1.76;
  color:#65757f;
}

#about .a-note{
  width:min(100%,500px);
  margin-top:24px;
  padding:0 0 0 16px;
}

#about .a-note::after{
  top:4px;
  bottom:4px;
  width:1px;
}

#about .a-note-text{
  max-width:38ch;
  font-size:13px;
  line-height:1.72;
  color:#6f7f88;
}

#about .about-visual-stage{
  padding-top:6px;
}

#about .about-signature{
  width:min(100%,396px);
  padding:0;
  border:none;
  border-radius:0;
  background:none;
  box-shadow:none;
}

#about .about-signature::before,
#about .about-signature::after{
  display:none;
}

#about .about-signature-top{
  margin:0 0 14px;
  padding:0 0 0 18px;
}

#about .about-signature-place,
#about .about-signature-years{
  font-size:9px;
  letter-spacing:1.9px;
  color:#837279;
}

#about .about-signature-place{
  padding:0;
  border:none;
  background:none;
  color:#6f5a63;
}

#about .about-signature-main{
  grid-template-columns:76px minmax(0,1fr);
  gap:18px;
  padding:24px 22px 22px;
  border-radius:26px;
  background:
    linear-gradient(180deg,rgba(255,255,255,.96),rgba(246,240,236,.98));
  border:1px solid rgba(20,35,45,.07);
  box-shadow:
    0 20px 40px rgba(20,35,45,.06),
    inset 0 1px 0 rgba(255,255,255,.95);
}

#about .about-signature-main::before{
  display:none;
}

#about .about-signature-main::after{
  content:'';
  position:absolute;
  inset:14px;
  border-radius:18px;
  border:1px solid rgba(87,37,62,.05);
  pointer-events:none;
}

#about .about-signature-logo{
  width:64px;
  padding:8px;
  border-radius:16px;
  background:#fff;
  box-shadow:0 10px 20px rgba(20,35,45,.05);
}

#about .about-signature-copy-wrap{
  gap:10px;
  justify-content:center;
}

#about .about-signature-name{
  font-size:clamp(24px,2vw,30px);
  line-height:.98;
  letter-spacing:-.035em;
  color:#1c2a33;
}

#about .about-signature-copy{
  max-width:24ch;
  font-size:12.5px;
  line-height:1.74;
  color:#6b7a82;
}

#about .about-manifesto-stage{
  margin-top:2px;
}

#about .about-values{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:0;
  border-top:1px solid rgba(20,35,45,.07);
  border-bottom:1px solid rgba(20,35,45,.07);
}

#about .about-value{
  padding:18px 20px 18px 0;
  border-right:1px solid rgba(20,35,45,.07);
}

#about .about-value:last-child{
  border-right:none;
}

#about .about-value::before{
  width:0;
  height:0;
  background:none;
}

#about .about-value h3{
  max-width:11ch;
  margin:0 0 6px;
  padding-top:0;
  font-size:18px;
  line-height:1.08;
  letter-spacing:-.02em;
  color:#21303a;
}

#about .about-value p{
  max-width:26ch;
  font-size:12px;
  line-height:1.72;
  color:#73828b;
}

@media(max-width:960px){
  #about.about-wrap{
    grid-template-columns:1fr;
    gap:28px;
  }

  #about .about-visual-stage{
    justify-content:flex-start;
  }

  #about .about-signature{
    width:min(100%,480px);
  }

  #about .about-values{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }

  #about .about-value{
    padding:18px 16px 18px 0;
    border-bottom:1px solid rgba(20,35,45,.07);
  }

  #about .about-value:nth-child(2){
    border-right:none;
  }

  #about .about-value:last-child{
    grid-column:span 2;
    border-bottom:none;
  }
}

@media(max-width:640px){
  #about .about-title{
    font-size:38px;
    max-width:8.4ch;
  }

  #about .a-lead{
    font-size:14px;
  }

  #about .about-signature-main{
    grid-template-columns:1fr;
    gap:14px;
    padding:20px 18px 18px;
  }

  #about .about-signature-logo{
    width:60px;
  }

  #about .about-signature-name{
    font-size:24px;
  }

  #about .about-values{
    grid-template-columns:1fr;
  }

  #about .about-value{
    padding:16px 0;
    border-right:none;
  }

  #about .about-value:last-child{
    grid-column:auto;
  }
}

/* Contact V3 Final */
#contact.contact-v3{
  grid-template-columns:minmax(0,.92fr) minmax(420px,1.08fr);
  gap:clamp(34px,4.6vw,68px);
  align-items:stretch;
  background:
    radial-gradient(circle at 10% 16%, rgba(193,92,138,.12), transparent 24%),
    radial-gradient(circle at 92% 18%, rgba(20,35,45,.05), transparent 26%),
    linear-gradient(180deg, rgba(255,255,255,.94), rgba(245,248,250,.97));
}

#contact.contact-v3 > div:last-child::before,
#contact.contact-v3 > div:last-child::after,
#contact.contact-v3 > div:first-child::after{
  content:none;
  display:none;
}

#contact.contact-v3 .contact-v3-copy{
  display:flex;
  flex-direction:column;
  justify-content:center;
  min-width:0;
}

#contact.contact-v3 .sec-h{
  max-width:8ch;
  margin-bottom:0;
}

#contact.contact-v3 .contact-v3-lead{
  max-width:31ch;
  margin:22px 0 0;
  font-size:18px;
  line-height:1.8;
  color:#667781;
}

#contact.contact-v3 .contact-v3-ribbon{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:22px;
}

#contact.contact-v3 .contact-v3-ribbon span{
  display:inline-flex;
  align-items:center;
  min-height:38px;
  padding:0 16px;
  border-radius:999px;
  border:1px solid rgba(193,92,138,.18);
  background:rgba(255,255,255,.72);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.9);
  font-size:12px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:#7f6973;
}

#contact.contact-v3 .contact-v3-rows{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:16px;
  margin-top:24px;
}

#contact.contact-v3 .contact-v3-row{
  min-height:0;
  padding:20px 20px 18px 18px;
  border-radius:26px;
  border:1px solid rgba(20,35,45,.08);
  background:
    linear-gradient(180deg, rgba(255,255,255,.94), rgba(248,250,252,.98));
  box-shadow:
    0 18px 34px rgba(20,35,45,.06),
    inset 0 1px 0 rgba(255,255,255,.92);
}

#contact.contact-v3 .contact-v3-row:last-child{
  grid-column:1 / -1;
}

#contact.contact-v3 .contact-v3-row .c-ic{
  width:48px;
  height:48px;
  border-radius:16px;
  background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(244,234,239,.92));
  border:1px solid rgba(193,92,138,.14);
  box-shadow:0 12px 24px rgba(193,92,138,.08);
}

#contact.contact-v3 .contact-v3-row .c-lbl{
  font-size:10px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:#8d7b84;
}

#contact.contact-v3 .contact-v3-row .c-val{
  font-size:20px;
  line-height:1.28;
  color:#1d2d37;
}

#contact.contact-v3 .contact-v3-row .c-val2{
  margin-top:5px;
  font-size:13px;
  line-height:1.72;
  color:#6c7c86;
}

#contact.contact-v3 .contact-v3-cta{
  margin-top:22px;
  align-self:flex-start;
}

#contact.contact-v3 .contact-v3-visual{
  display:flex;
  align-items:stretch;
  min-width:0;
}

#contact.contact-v3 .contact-v3-panel{
  position:relative;
  display:flex;
  flex-direction:column;
  width:100%;
  padding:24px;
  border-radius:34px;
  border:1px solid rgba(20,35,45,.08);
  background:
    linear-gradient(145deg, rgba(255,255,255,.92), rgba(246,240,244,.94));
  box-shadow:
    0 28px 54px rgba(20,35,45,.08),
    inset 0 1px 0 rgba(255,255,255,.9);
  overflow:hidden;
}

#contact.contact-v3 .contact-v3-panel::before{
  content:'';
  position:absolute;
  inset:0 auto auto 0;
  width:100%;
  height:150px;
  background:linear-gradient(180deg, rgba(193,92,138,.10), rgba(193,92,138,0));
  pointer-events:none;
}

#contact.contact-v3 .contact-v3-panel-top{
  position:relative;
  z-index:1;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  margin-bottom:12px;
}

#contact.contact-v3 .contact-v3-kicker{
  font-size:10px;
  letter-spacing:.24em;
  text-transform:uppercase;
  color:#8e7c84;
}

#contact.contact-v3 .contact-v3-badge{
  display:inline-flex;
  align-items:center;
  min-height:34px;
  padding:0 14px;
  border-radius:999px;
  background:rgba(255,255,255,.68);
  border:1px solid rgba(193,92,138,.15);
  font-size:11px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:#6a4d5b;
}

#contact.contact-v3 .contact-v3-panel-copy{
  position:relative;
  z-index:1;
  max-width:34ch;
  margin:0 0 18px;
  font-size:15px;
  line-height:1.78;
  color:#667781;
}

#contact.contact-v3 .contact-v3-map{
  position:relative;
  z-index:1;
  flex:1;
  min-height:440px;
  margin-top:0;
  border-radius:28px;
  border:1px solid rgba(20,35,45,.07);
  overflow:hidden;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.9),
    0 18px 34px rgba(20,35,45,.08);
}

#contact.contact-v3 .contact-v3-map iframe{
  filter:saturate(.95) contrast(1.03);
}

@media(max-width:1080px){
  #contact.contact-v3{
    grid-template-columns:1fr;
    gap:30px;
  }

  #contact.contact-v3 .contact-v3-panel{
    min-height:0;
  }
}

@media(max-width:640px){
  #contact.contact-v3 .contact-v3-lead{
    font-size:15px;
    line-height:1.72;
  }

  #contact.contact-v3 .contact-v3-ribbon{
    gap:8px;
  }

  #contact.contact-v3 .contact-v3-ribbon span{
    min-height:34px;
    padding:0 14px;
    font-size:11px;
    letter-spacing:.06em;
  }

  #contact.contact-v3 .contact-v3-rows{
    grid-template-columns:1fr;
  }

  #contact.contact-v3 .contact-v3-row:last-child{
    grid-column:auto;
  }

  #contact.contact-v3 .contact-v3-row{
    padding:18px 16px;
    border-radius:22px;
  }

  #contact.contact-v3 .contact-v3-row .c-val{
    font-size:17px;
  }

  #contact.contact-v3 .contact-v3-panel{
    padding:18px;
    border-radius:26px;
  }

  #contact.contact-v3 .contact-v3-panel-top{
    flex-direction:column;
    align-items:flex-start;
  }

  #contact.contact-v3 .contact-v3-map{
    min-height:320px;
    border-radius:22px;
  }
}
