/* ============================================================
   Artopia Genève — feuille de styles globale
   Tout le CSS du site (extrait des templates). Intégrable
   directement dans les templates PHP MVC.
   ============================================================ */

:root{
  --bg:#15120e;
  --bg2:#1c1914;
  --marques:#34302a;
  --cream:#efe9dd;
  --text:#cfc8bd;
  --muted:#8b857a;
  --head:#f3efe7;
  --line:rgba(255,255,255,.1);
  --accent:#b08d57;
  --hero-h:100vh;
}

/* ---- reset / base ---- */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:'Jost',sans-serif;
  font-weight:300;
  line-height:1.7;
  min-height:100vh;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{display:block}
a{color:inherit}
.logo-sprite{position:absolute;width:0;height:0;overflow:hidden}
.logo{display:block;height:auto}
::selection{background:#b08d57;color:#15120e}
input,textarea{font-family:inherit}
::placeholder{color:rgba(255,255,255,.32)}

/* ---- animations ---- */
@keyframes kenburns{from{transform:scale(1.04)}to{transform:scale(1.15)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:none}}
@keyframes scrollcue{0%,100%{opacity:.25;transform:translateY(0)}50%{opacity:.9;transform:translateY(7px)}}

/* ---- images utilitaires ---- */
.cover-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.cover-img--kb{animation:kenburns 28s ease-in-out infinite alternate}
.sofa-img{position:relative;width:100%;height:auto}

/* ---- éléments réutilisables ---- */
.eyebrow{font-size:11px;letter-spacing:.34em;text-transform:uppercase;color:var(--accent);margin-bottom:16px}
.eyebrow--center{letter-spacing:.4em;margin-bottom:18px}
.section-title{
  margin:0 0 22px;
  font-size:clamp(26px,3.4vw,44px);line-height:1.18;letter-spacing:.12em;
  text-transform:uppercase;font-weight:300;color:var(--head);
}
.rule{width:54px;height:1px;background:var(--accent)}
.accent{color:var(--head);font-weight:400}
.clip-corner{clip-path:polygon(0 0,calc(100% - 30px) 0,100% 30px,100% 100%,0 100%)}

/* ---- en-tête ---- */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:22px clamp(22px,5vw,72px);color:#fff;
  transition:background .45s ease, border-color .45s ease, backdrop-filter .45s ease;
  background:transparent;border-bottom:1px solid transparent;
}
.site-header.is-scrolled{
  background:rgba(20,17,13,.9);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(255,255,255,.08);
}
/* page presse : en-tête toujours plein */
.site-header--solid{
  padding:20px clamp(22px,5vw,72px);
  background:rgba(20,17,13,.92);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.site-header--menu-only{justify-content:flex-end}
.site-header__brand{display:flex;align-items:center;color:#fff;text-decoration:none}
.site-header__brand .logo{width:112px;color:#fff}
.site-header--solid .site-header__brand .logo{width:108px}

.menu-toggle{
  display:flex;align-items:center;gap:13px;background:none;border:none;color:#fff;
  cursor:pointer;font-size:12px;letter-spacing:.26em;text-transform:uppercase;
  font-weight:400;padding:6px 0;font-family:inherit;
}
.menu-toggle__icon{display:inline-block;width:26px;height:8px;position:relative}
.menu-toggle__icon span{position:absolute;left:0;width:100%;height:1px;background:currentColor}
.menu-toggle__icon span:first-child{top:0}
.menu-toggle__icon span:last-child{bottom:0}

/* en-tête de la page presse : nav en ligne */
.header-nav{display:flex;align-items:center;gap:clamp(16px,2.4vw,34px);font-size:11px;letter-spacing:.22em;text-transform:uppercase}
.header-nav a{color:rgba(255,255,255,.7);text-decoration:none;transition:color .3s}
.header-nav a:hover{color:#fff}
.header-nav a.is-active{color:var(--accent)}
.header-nav a.is-active:hover{color:var(--accent)}

/* ---- menu plein écran ---- */
.nav-overlay{
  position:fixed;inset:0;z-index:60;
  background:rgba(17,14,10,.98);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;
  transition:opacity .55s ease;
  opacity:0;visibility:hidden;pointer-events:none;
}
.nav-overlay.is-open{opacity:1;visibility:visible;pointer-events:auto}
.nav-overlay__close{
  position:absolute;top:24px;right:clamp(22px,5vw,72px);
  background:none;border:none;color:#fff;font-size:32px;font-weight:200;line-height:1;cursor:pointer;
}
.nav-overlay__link{
  color:#d6d0c6;text-decoration:none;text-align:center;
  font-size:clamp(28px,5.5vw,58px);letter-spacing:.14em;text-transform:uppercase;
  font-weight:300;padding:6px 0;transition:color .3s;
}
.nav-overlay__link:hover{color:#fff}
.nav-overlay__addr{margin-top:42px;font-size:12px;letter-spacing:.24em;text-transform:uppercase;color:var(--muted)}

/* ---- héros ---- */
.hero{
  position:relative;height:var(--hero-h);min-height:580px;width:100%;
  overflow:hidden;display:flex;align-items:center;justify-content:center;
}
.hero__bg{position:absolute;inset:0;animation:kenburns 28s ease-in-out infinite alternate}
.hero__overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(10,8,6,.4),rgba(10,8,6,.12) 42%,rgba(10,8,6,.6))}
.hero__content{position:relative;z-index:2;color:#fff;text-align:center;animation:fadeUp 1.3s cubic-bezier(.16,1,.3,1) both}
.hero__title{
  margin:0 0 clamp(28px,4vh,40px);
  font-size:clamp(34px,6.4vw,84px);line-height:1.04;letter-spacing:.07em;
  text-transform:uppercase;font-weight:300;color:#fff;
}
.hero__rule-group{display:flex;align-items:center;justify-content:center;gap:clamp(14px,3vw,24px)}
.hero__rule-group .logo{width:clamp(138px,18vw,216px);color:#fff}
.hero__rule{flex:none;width:clamp(26px,5vw,64px);height:1px;background:rgba(255,255,255,.42)}
.hero__content--logo{display:flex;flex-direction:column;align-items:center}
.hero__logo{margin:0;display:flex;align-items:center;justify-content:center;gap:clamp(14px,3vw,28px)}
.hero__logo .logo{width:clamp(240px,48vw,640px);color:#fff}
.hero__tagline{margin-top:clamp(26px,4vh,46px);font-size:clamp(11px,1.3vw,14px);letter-spacing:.44em;text-transform:uppercase;color:rgba(255,255,255,.78)}
.hero__scroll{
  position:absolute;bottom:30px;left:50%;transform:translateX(-50%);z-index:2;
  display:flex;flex-direction:column;align-items:center;gap:9px;text-decoration:none;color:rgba(255,255,255,.6);
}
.hero__scroll-label{font-size:10px;letter-spacing:.28em;text-transform:uppercase}
.hero__scroll-line{display:block;width:1px;height:40px;background:linear-gradient(rgba(255,255,255,.6),transparent);animation:scrollcue 2s ease-in-out infinite}

/* ---- sections génériques ---- */
.section{padding:clamp(90px,13vh,170px) clamp(24px,6vw,120px);background:var(--bg)}
.section--bg2{background:var(--bg2)}
.section--marques{background:var(--marques);padding:clamp(62px,8vh,110px) clamp(24px,6vw,90px)}
.section--studio{padding:clamp(70px,10vh,140px) clamp(24px,6vw,120px)}
.section--revente{position:relative;overflow:hidden;padding:clamp(80px,11vh,150px) clamp(24px,6vw,120px)}
.section--contact{padding:clamp(80px,11vh,150px) clamp(24px,6vw,120px)}
.section--tight-top{padding-top:0;padding-bottom:clamp(70px,9vh,120px)}

/* ---- bienvenue ---- */
.welcome-grid{
  max-width:1240px;margin:0 auto;
  display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));
  gap:clamp(40px,6vw,90px);align-items:start;
}
.welcome-title{
  margin:0 0 28px;
  font-size:clamp(26px,3.4vw,44px);line-height:1.18;letter-spacing:.12em;
  text-transform:uppercase;font-weight:300;color:var(--head);
}
.welcome-lead{margin:0 0 24px;font-size:clamp(14px,1.15vw,16px);color:var(--muted);max-width:46ch}
.welcome-p{margin:0 0 20px;font-size:clamp(14px,1.15vw,16px);max-width:50ch;color:var(--text)}
.welcome-p:last-child{margin-bottom:0}

/* figure / image légendée */
.figure{position:relative;overflow:hidden}
.figure--43{width:100%;aspect-ratio:4/3}
.figure--tall{min-height:340px}
.figure__grad{position:absolute;inset:0;background:linear-gradient(to top,rgba(10,8,6,.5),transparent 45%)}
.figure__grad--soft{background:linear-gradient(to top,rgba(10,8,6,.45),transparent 50%)}
.figure__caption{position:absolute;left:20px;bottom:16px;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.85)}

/* duo d'images */
.duo-grid{
  max-width:1240px;margin:0 auto;
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,3vw,48px);align-items:stretch;
}
@media (max-width:720px){.duo-grid{grid-template-columns:1fr}}

/* ---- studio (deux colonnes) ---- */
.studio-grid{
  max-width:1180px;margin:0 auto;
  display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));
  gap:clamp(40px,5vw,80px);align-items:center;
}
.studio-intro-text{margin:0 0 28px;font-size:clamp(14px,1.15vw,16px);line-height:1.8;color:var(--text)}
.studio-figure{position:relative;aspect-ratio:16/11;overflow:hidden}

.steps{display:flex;flex-direction:column}
.step{display:grid;grid-template-columns:auto 1fr;gap:clamp(20px,3vw,46px);padding:16px 0;border-top:1px solid var(--line)}
.step:first-child{padding:0 0 16px;border-top:none}
.step:last-child{padding:16px 0 0}
.step__num{font-size:13px;letter-spacing:.2em;color:var(--accent);padding-top:4px}
.step__title{margin:0 0 8px;font-size:clamp(16px,1.5vw,20px);letter-spacing:.08em;text-transform:uppercase;font-weight:400;color:var(--head)}
.step__desc{margin:0;font-size:14px;color:var(--muted);max-width:62ch}
.step__list{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:11px;max-width:62ch}
.step__list li{font-size:14px;color:var(--muted);padding-left:18px;position:relative}
.step__list li::before{content:"";position:absolute;left:0;top:9px;width:5px;height:5px;background:var(--accent)}

/* ---- mur de marques ---- */
.brands-wrap{max-width:1460px;margin:0 auto}
.brands-title{margin:0 0 12px;text-align:center;font-size:clamp(26px,3.4vw,44px);line-height:1.18;letter-spacing:.12em;text-transform:uppercase;font-weight:300;color:var(--head)}
.brands-sub{margin:0 auto clamp(44px,6vh,68px);text-align:center;font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted)}
.brand-cell{display:flex;align-items:center;justify-content:center;width:112px;height:auto;opacity:.8;transition:opacity .35s ease}
.brand-cell:hover{opacity:1}
.brand-logo{width:100%;height:100%;object-fit:contain}

/* défilement automatique */
.brand-marquee{display:flex;flex-direction:column;gap:clamp(22px,3vh,40px);overflow:hidden}
.brand-row{overflow:hidden;width:100%;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);
          mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);}
.brand-track{display:flex;align-items:center;gap:clamp(38px,4.5vw,66px);width:max-content;will-change:transform}
.brand-track--left{animation:marquee-left 55s linear infinite}
.brand-track--right{animation:marquee-right 55s linear infinite}
[data-brand-track-c]{animation-duration:68s}
.brand-track .brand-cell{flex:0 0 auto;width:120px;height:50px}
@keyframes marquee-left{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes marquee-right{from{transform:translateX(-50%)}to{transform:translateX(0)}}

@media (max-width:860px){
  .brand-track{gap:38px}
  .brand-track--left{animation-duration:32s}
  .brand-track--right{animation-duration:32s}
  .brand-track .brand-cell{width:96px;height:42px}
}
@media (prefers-reduced-motion:reduce){
  .brand-track--left,.brand-track--right{animation:none}
}

/* ---- pièces à revendre ---- */
.revente-glow{position:absolute;inset:0;background:radial-gradient(55% 60% at 50% 52%,rgba(176,141,87,.16),transparent 72%)}
.revente-inner{position:relative;z-index:2;max-width:1100px;margin:0 auto}
.revente-head{text-align:center}
.revente-lead{margin:0 auto;font-size:clamp(14px,1.15vw,16px);color:var(--muted);max-width:56ch}
.sofa-wrap{position:relative;margin:clamp(40px,6vh,72px) auto 0;max-width:820px}
.sofa-shadow{position:absolute;left:50%;bottom:6%;transform:translateX(-50%);width:64%;height:42px;background:radial-gradient(50% 50% at 50% 50%,rgba(0,0,0,.55),transparent 72%);filter:blur(6px)}
.revente-meta{display:flex;flex-wrap:wrap;justify-content:center;align-items:baseline;gap:10px 22px;margin-top:clamp(26px,3.5vh,40px);text-align:center}
.revente-meta__name{font-size:clamp(16px,1.6vw,21px);font-weight:300;color:var(--head);letter-spacing:.02em}
.revente-meta__sub{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.revente-meta__price{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent)}
.chips{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin-top:clamp(30px,4vh,46px)}
.chip{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);border:1px solid var(--line);padding:9px 18px;border-radius:999px}

/* ---- boutons ---- */
.btn-solid{
  display:inline-flex;align-items:center;gap:12px;color:#15120e;background:var(--accent);
  text-decoration:none;font-size:12px;letter-spacing:.24em;text-transform:uppercase;padding:16px 40px;transition:opacity .35s;
}
.btn-solid:hover{opacity:.88}
.btn-outline{
  display:inline-block;color:var(--head);text-decoration:none;font-size:12px;letter-spacing:.26em;
  text-transform:uppercase;border:1px solid var(--accent);padding:15px 38px;transition:background .35s,color .35s;
}
.btn-outline:hover{background:var(--accent);color:#15120e}
.cta-center{text-align:center}

/* ---- presse (liste) ---- */
.press-list{border-bottom:1px solid var(--line)}
.press-row{
  display:grid;grid-template-columns:clamp(96px,13vw,140px) 1fr auto;gap:clamp(16px,4vw,48px);
  align-items:center;padding:clamp(24px,3vh,34px) 6px;border-top:1px solid var(--line);
  text-decoration:none;transition:background .35s;
}
.press-row:hover{background:rgba(255,255,255,.025)}
.press-row__year{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent)}
.press-row__name{font-size:clamp(17px,1.9vw,25px);font-weight:300;color:var(--head);letter-spacing:.01em}
.press-row__action{display:flex;align-items:center;gap:12px;color:var(--muted);font-size:11px;letter-spacing:.2em;text-transform:uppercase}
.press-intro{margin:0 0 18px;text-align:center}
.presse-page-list .press-row{grid-template-columns:clamp(96px,12vw,130px) 1fr auto}
.presse-page-list .press-row__name{font-size:clamp(17px,1.9vw,26px)}

/* ---- contact ---- */
.contact-grid{
  max-width:1180px;margin:0 auto;
  display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));
  gap:clamp(40px,5vw,80px);align-items:start;
}
.contact-lead{margin:0 0 40px;font-size:clamp(18px,2vw,26px);line-height:1.5;font-weight:300;color:var(--head);max-width:24ch}
.contact-sent{padding:40px 0;border-top:1px solid var(--line)}
.contact-sent p:first-child{margin:0;font-size:16px;color:var(--head);letter-spacing:.04em}
.contact-sent p:last-child{margin:10px 0 0;font-size:14px;color:var(--muted)}
.form{display:flex;flex-direction:column;gap:26px}
.form__row{display:grid;grid-template-columns:1fr 1fr;gap:26px}
.form__field{background:transparent;border:none;border-bottom:1px solid var(--line);color:var(--head);font-size:15px;padding:12px 0;outline:none;transition:border-color .3s}
.form__field:focus{border-bottom-color:var(--accent)}
textarea.form__field{resize:vertical}
.form__hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.form__error{margin:0;font-size:13px;color:#d98c8c}
.btn-submit{
  align-self:flex-start;margin-top:8px;background:transparent;border:1px solid var(--accent);color:var(--head);
  font-family:inherit;font-size:12px;letter-spacing:.26em;text-transform:uppercase;padding:15px 38px;cursor:pointer;
  transition:background .35s,color .35s;
}
.btn-submit:hover{background:var(--accent);color:#15120e}
.is-hidden{display:none}

.contact-card{background:var(--cream);color:#2a241c;padding:clamp(36px,4vw,56px)}
.contact-card__list{display:flex;flex-direction:column;gap:30px}
.contact-card__head{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.contact-card__head span{font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:#9a8f7d}
.contact-card p{margin:0;font-size:15px;line-height:1.6}
.contact-card__div{height:1px;background:rgba(42,36,28,.12)}
.contact-card a{font-size:15px;color:#2a241c;text-decoration:none;border-bottom:1px solid rgba(42,36,28,.25)}

@media (max-width:720px){
  .form__row{grid-template-columns:1fr}
}

/* ---- carte / map ---- */
.map-wrap{position:relative;height:clamp(360px,52vh,520px);overflow:hidden;background:#0f0c08}
.map-frame{
  position:absolute;inset:0;width:100%;height:100%;border:0;
  filter:grayscale(1) invert(.92) contrast(.92) hue-rotate(180deg) brightness(.92);
}
.map-wrap::after{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(90deg,rgba(15,12,8,.55),transparent 42%);}
.map-card{
  position:absolute;z-index:2;left:clamp(24px,6vw,120px);top:50%;transform:translateY(-50%);
  background:rgba(18,15,11,.86);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  padding:clamp(28px,3.4vw,44px);max-width:340px;
  clip-path:polygon(0 0,calc(100% - 28px) 0,100% 28px,100% 100%,0 100%);
}
.map-card__eyebrow{font-size:11px;letter-spacing:.34em;text-transform:uppercase;color:var(--accent);margin-bottom:14px}
.map-card__addr{font-size:clamp(18px,1.8vw,24px);font-weight:300;letter-spacing:.04em;color:#fff;line-height:1.4}
.map-card__link{display:inline-flex;align-items:center;gap:10px;margin-top:22px;color:#fff;text-decoration:none;font-size:12px;letter-spacing:.24em;text-transform:uppercase;border-bottom:1px solid var(--accent);padding-bottom:7px}
@media (max-width:720px){
  .map-wrap{height:auto}
  .map-frame{position:relative;height:300px}
  .map-wrap::after{display:none}
  .map-card{position:relative;top:auto;left:auto;transform:none;max-width:none;width:100%;clip-path:none;backdrop-filter:none;-webkit-backdrop-filter:none;background:#15120e;text-align:center}
  .map-card a{justify-content:center}
}

/* ---- pied de page ---- */
.site-footer{background:#100d09;padding:clamp(50px,7vh,80px) clamp(24px,6vw,120px) 40px}
.site-footer-grid{
  max-width:1180px;margin:0 auto;
  display:grid;grid-template-columns:repeat(3,1fr);gap:32px;align-items:center;
}
.site-footer-grid .foot-left{color:var(--muted);font-size:13px;text-align:left}
.site-footer-grid .foot-mid{display:flex;justify-content:center}
.site-footer-grid .foot-mid .logo{width:120px;color:rgba(255,255,255,.55)}
.site-footer-grid .foot-right{color:var(--muted);font-size:13px;text-align:right}
.foot-head{font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:rgba(255,255,255,.4);margin-bottom:10px}
.site-footer-bottom{
  max-width:1180px;margin:46px auto 0;padding-top:24px;
  border-top:1px solid rgba(255,255,255,.08);
  display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;
  font-size:12px;color:rgba(255,255,255,.32);letter-spacing:.04em;
}
.site-footer-bottom .upper{letter-spacing:.16em;text-transform:uppercase}
@media (max-width:720px){
  .site-footer-grid{grid-template-columns:1fr;gap:30px;text-align:center}
  .site-footer-grid .foot-left,.site-footer-grid .foot-right{text-align:center}
  .site-footer-grid .foot-mid{order:-1}
  .site-footer-bottom{justify-content:center;text-align:center}
}

/* ---- révélation au défilement (script.js) ---- */
[data-reveal]{opacity:0;transform:translateY(28px);transition:opacity 1s cubic-bezier(.16,1,.3,1),transform 1s cubic-bezier(.16,1,.3,1)}
[data-reveal].is-visible{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  [data-reveal]{opacity:1;transform:none;transition:none}
}

/* ---- pages intérieures (presse) ---- */
.page-head{padding:clamp(140px,20vh,220px) clamp(24px,6vw,120px) clamp(40px,6vh,70px);max-width:1040px;margin:0 auto}
.page-head__title{margin:0;font-size:clamp(44px,9vw,120px);line-height:1;letter-spacing:.05em;text-transform:uppercase;font-weight:300;color:var(--head)}
.page-head__lead{margin:34px 0 0;font-size:clamp(15px,1.3vw,18px);color:var(--muted);max-width:54ch}
.page-body{padding:0 clamp(24px,6vw,120px) clamp(90px,12vh,160px);max-width:1040px;margin:0 auto}
.page-note{margin:clamp(40px,6vh,64px) auto 0;text-align:center;font-size:14px;line-height:1.7;color:var(--muted);max-width:52ch}
.page-note a{color:var(--head);text-decoration:none;border-bottom:1px solid var(--accent)}
.back-link{color:var(--muted);text-decoration:none;font-size:12px;letter-spacing:.24em;text-transform:uppercase;transition:color .3s}
.back-link:hover{color:#fff}
