/* ============================================================
   Ceramic Deluxe — stil comun (toate paginile)
   ============================================================ */
:root{
  --ink:#0B0B0C; --panel:#141416; --bone:#F2F0EC; --silver:#8C8C8F;
  --hair:rgba(242,240,236,.14); --hair-soft:rgba(242,240,236,.07);
  --serif:"Cormorant Garamond", Georgia, serif;
  --sans:"Jost", system-ui, -apple-system, sans-serif;
  --ease:cubic-bezier(.22,.61,.36,1); --slow:cubic-bezier(.16,1,.3,1);
}
*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{ background:var(--ink); color:var(--bone); font-family:var(--sans); font-weight:300; line-height:1.6; overflow-x:hidden; -webkit-font-smoothing:antialiased; }
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
.wrap{ width:min(92%,1240px); margin-inline:auto; }
.eyebrow{ font-size:.72rem; letter-spacing:.32em; text-transform:uppercase; color:var(--silver); font-weight:400; }

/* ---- NAV ---- */
header{ position:fixed; inset:0 0 auto 0; z-index:50; transition:background .5s var(--ease), border-color .5s var(--ease); border-bottom:1px solid transparent; }
header.scrolled{ background:rgba(11,11,12,.72); backdrop-filter:blur(14px) saturate(120%); -webkit-backdrop-filter:blur(14px) saturate(120%); border-bottom:1px solid var(--hair); }
.nav{ display:flex; align-items:center; justify-content:space-between; height:84px; }
.logo{ font-family:var(--serif); font-size:1.5rem; font-weight:400; letter-spacing:.18em; text-transform:uppercase; line-height:1; }
.logo span{ color:var(--silver); }
.nav-links{ display:flex; align-items:center; gap:2.4rem; }
.nav-links a{ font-size:.78rem; letter-spacing:.18em; text-transform:uppercase; color:var(--bone); opacity:.82; position:relative; padding:.4em 0; transition:opacity .35s var(--ease); cursor:pointer; }
.nav-links a::after{ content:""; position:absolute; left:0; bottom:0; height:1px; width:0; background:var(--bone); transition:width .4s var(--ease); }
.nav-links a:hover{ opacity:1; }
.nav-links a:hover::after{ width:100%; }
.nav-links .quote{ border:1px solid var(--hair); padding:.7em 1.4em; border-radius:999px; opacity:1; }
.nav-links .quote::after{ display:none; }
.nav-links .quote:hover{ background:var(--bone); color:var(--ink); }
.burger{ display:none; width:34px; height:34px; position:relative; background:none; border:0; cursor:pointer; }
.burger span{ position:absolute; left:5px; right:5px; height:1px; background:var(--bone); transition:transform .4s var(--ease), opacity .3s; }
.burger span:nth-child(1){ top:12px; } .burger span:nth-child(2){ bottom:12px; }
body.menu-open .burger span:nth-child(1){ top:16px; transform:rotate(45deg); }
body.menu-open .burger span:nth-child(2){ bottom:17px; transform:rotate(-45deg); }
.overlay{ position:fixed; inset:0; z-index:40; background:var(--ink); display:flex; flex-direction:column; justify-content:center; align-items:center; gap:1.2rem; opacity:0; pointer-events:none; transition:opacity .5s var(--ease); }
body.menu-open .overlay{ opacity:1; pointer-events:auto; }
.overlay a{ font-family:var(--serif); font-size:2.4rem; font-weight:300; letter-spacing:.04em; opacity:0; transform:translateY(18px); transition:opacity .6s var(--slow), transform .6s var(--slow); cursor:pointer; }
body.menu-open .overlay a{ opacity:1; transform:none; }
body.menu-open .overlay a:nth-child(1){ transition-delay:.10s; }
body.menu-open .overlay a:nth-child(2){ transition-delay:.16s; }
body.menu-open .overlay a:nth-child(3){ transition-delay:.22s; }
body.menu-open .overlay a:nth-child(4){ transition-delay:.28s; }
body.menu-open .overlay a:nth-child(5){ transition-delay:.34s; }

/* ---- HERO (layered + apă WebGL) ---- */
.hero{ position:relative; min-height:100svh; display:flex; align-items:center; overflow:hidden; isolation:isolate; }
.hero-photo{ position:absolute; inset:0; z-index:0; background:#08080a url("/images/leonis/leonis-herobanner-desktopn.jpg") center/cover no-repeat; transform:scale(1.06); }
.hero-veil{ position:absolute; inset:0; z-index:1; background:linear-gradient(180deg, rgba(8,8,10,.5) 0%, rgba(8,8,10,.28) 38%, rgba(8,8,10,.88) 100%); }
/* fallback CSS caustics (rămâne dacă WebGL nu pornește) */
.water{ position:absolute; inset:-20%; z-index:2; pointer-events:none; mix-blend-mode:screen; opacity:.5;
  background:radial-gradient(60% 30% at 30% 40%, rgba(242,240,236,.10), transparent 60%),
    radial-gradient(50% 25% at 70% 60%, rgba(242,240,236,.08), transparent 60%),
    repeating-linear-gradient(100deg, transparent 0 38px, rgba(242,240,236,.05) 38px 40px);
  background-size:140% 140%,160% 160%,100% 100%; animation:drift 26s linear infinite; }
.water.b{ opacity:.32; mix-blend-mode:overlay; background:repeating-linear-gradient(82deg, transparent 0 70px, rgba(242,240,236,.06) 70px 73px); animation:drift2 38s linear infinite; }
@keyframes drift{ 0%{ background-position:0% 0%,100% 0%,0 0; } 100%{ background-position:30% 40%,70% 60%,120px 0; } }
@keyframes drift2{ 0%{ background-position:0 0; } 100%{ background-position:240px 60px; } }
/* canvas WebGL — caustice principale */
.water-gl{ position:absolute; inset:0; z-index:3; width:100%; height:100%; pointer-events:none; mix-blend-mode:screen; opacity:.42; }

.hero-inner{ position:relative; z-index:4; padding-top:84px; text-shadow:0 2px 30px rgba(0,0,0,.35); }
.hero .eyebrow{ opacity:0; transform:translateY(14px); animation:rise .9s var(--slow) .3s forwards; }
.hero h1{ font-family:var(--serif); font-weight:300; font-size:clamp(2.8rem,8vw,6.6rem); line-height:1.02; letter-spacing:-.01em; margin:.4em 0 .5em; max-width:14ch; }
.hero h1 .line{ display:block; overflow:hidden; }
.hero h1 .line span{ display:block; transform:translateY(110%); animation:slideUp 1s var(--slow) forwards; }
.hero h1 .line:nth-child(1) span{ animation-delay:.4s; }
.hero h1 .line:nth-child(2) span{ animation-delay:.55s; }
.hero h1 .line:nth-child(3) span{ font-style:italic; color:var(--silver); animation-delay:.7s; }
.hero p.lede{ max-width:46ch; opacity:0; transform:translateY(14px); animation:rise .9s var(--slow) .9s forwards; }
.cta{ display:inline-flex; align-items:center; gap:.8em; margin-top:2.4rem; font-size:.8rem; letter-spacing:.22em; text-transform:uppercase; opacity:0; transform:translateY(14px); animation:rise .9s var(--slow) 1.05s forwards; cursor:pointer; }
.cta .dash{ width:46px; height:1px; background:var(--bone); transition:width .4s var(--ease); }
.cta:hover .dash{ width:72px; }
.scroll-cue{ position:absolute; left:50%; bottom:2.2rem; transform:translateX(-50%); z-index:4; font-size:.62rem; letter-spacing:.3em; text-transform:uppercase; color:var(--silver); display:flex; flex-direction:column; align-items:center; gap:.7rem; opacity:0; animation:rise 1s var(--slow) 1.4s forwards; }
.scroll-cue .bar{ width:1px; height:46px; background:linear-gradient(var(--silver), transparent); animation:pulse 2.6s var(--ease) infinite; }
@keyframes rise{ to{ opacity:1; transform:none; } }
@keyframes slideUp{ to{ transform:none; } }
@keyframes pulse{ 0%,100%{ opacity:.3; transform:scaleY(.6); } 50%{ opacity:1; transform:scaleY(1); } }

/* ---- REVEAL ---- */
section{ padding:clamp(5rem,12vw,10rem) 0; }
.reveal{ opacity:0; transform:translateY(34px); transition:opacity 1s var(--slow), transform 1s var(--slow); }
.reveal.in{ opacity:1; transform:none; }
.reveal[data-d="1"]{ transition-delay:.12s; } .reveal[data-d="2"]{ transition-delay:.24s; } .reveal[data-d="3"]{ transition-delay:.36s; }

/* ---- CATEGORII (3 pe mărime) ---- */
.cats{ border-top:1px solid var(--hair-soft); }
.cats .head{ display:flex; justify-content:space-between; align-items:flex-end; flex-wrap:wrap; gap:1rem; margin-bottom:clamp(2.5rem,5vw,4rem); }
.cats .head h2{ font-family:var(--serif); font-weight:300; font-size:clamp(2rem,5vw,3.4rem); line-height:1.05; }
.cat-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(1rem,2.2vw,1.6rem); }
.cat-card{ position:relative; display:block; overflow:hidden; aspect-ratio:3/4; background:var(--panel); }
.cat-card img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; filter:saturate(0) brightness(.78); transform:scale(1.1); clip-path:inset(0 0 100% 0); transition:clip-path 1.1s var(--slow), transform 1.6s var(--slow), filter .8s var(--ease), brightness .8s; }
.cat-card.in img{ clip-path:inset(0 0 0 0); transform:scale(1.04); }
.cat-card:hover img{ transform:scale(1.1); filter:saturate(1) brightness(.92); }
.cat-card .lbl{ position:absolute; inset:auto 0 0 0; z-index:2; padding:clamp(1.2rem,2.5vw,1.8rem); background:linear-gradient(transparent, rgba(8,8,10,.7)); }
.cat-card .lbl h3{ font-family:var(--serif); font-weight:400; font-size:clamp(1.6rem,3vw,2.2rem); line-height:1; }
.cat-card .lbl .meta{ display:flex; justify-content:space-between; margin-top:.7rem; font-size:.7rem; letter-spacing:.16em; text-transform:uppercase; color:var(--silver); }

/* ---- MODÈLES EN VEDETTE (editorial alternativ) ---- */
.featured{ border-top:1px solid var(--hair-soft); }
.featured .head{ margin-bottom:clamp(3rem,6vw,5rem); }
.featured .head h2{ font-family:var(--serif); font-weight:300; font-size:clamp(2rem,5vw,3.4rem); }
.feat-row{ display:grid; grid-template-columns:1.15fr .85fr; gap:clamp(1.5rem,5vw,4rem); align-items:center; margin-bottom:clamp(4rem,9vw,8rem); }
.feat-row:last-child{ margin-bottom:0; }
.feat-row:nth-child(even){ grid-template-columns:.85fr 1.15fr; }
.feat-row:nth-child(even) .feat-media{ order:2; }
.feat-media{ position:relative; overflow:hidden; aspect-ratio:4/5; background:var(--panel); }
.feat-media img{ width:100%; height:100%; object-fit:cover; filter:saturate(0); transform:scale(1.12); clip-path:inset(0 0 100% 0); transition:clip-path 1.2s var(--slow), transform 1.5s var(--slow), filter .8s var(--ease); }
.feat-row.in .feat-media img{ clip-path:inset(0 0 0 0); transform:scale(1.03); }
.feat-row:hover .feat-media img{ transform:scale(1.06); filter:saturate(1); }
.feat-body .num{ font-family:var(--serif); font-size:clamp(3rem,7vw,5rem); line-height:1; color:transparent; -webkit-text-stroke:1px var(--hair); margin-bottom:.4rem; }
.feat-body h3{ font-family:var(--serif); font-weight:400; font-size:clamp(2rem,4.5vw,3rem); line-height:1.05; }
.feat-body .tag{ font-size:.7rem; letter-spacing:.2em; text-transform:uppercase; color:var(--silver); margin:.6rem 0 1.1rem; }
.feat-body p{ color:var(--silver); max-width:42ch; margin-bottom:1.6rem; }
.feat-link{ display:inline-flex; align-items:center; gap:.7em; font-size:.76rem; letter-spacing:.2em; text-transform:uppercase; }
.feat-link .dash{ width:42px; height:1px; background:var(--bone); transition:width .4s var(--ease); }
.feat-link:hover .dash{ width:66px; }

/* ---- FOOTER ---- */
footer{ border-top:1px solid var(--hair); padding:clamp(3rem,7vw,5rem) 0 2.5rem; }
.foot-top{ display:flex; justify-content:space-between; flex-wrap:wrap; gap:2rem; align-items:flex-start; }
.foot-links{ display:flex; gap:2.2rem; flex-wrap:wrap; }
.foot-links a{ font-size:.78rem; letter-spacing:.16em; text-transform:uppercase; color:var(--silver); transition:color .35s; cursor:pointer; }
.foot-links a:hover{ color:var(--bone); }
.foot-bottom{ display:flex; justify-content:space-between; flex-wrap:wrap; gap:1rem; margin-top:clamp(2.5rem,6vw,4rem); padding-top:1.6rem; border-top:1px solid var(--hair-soft); }
.foot-bottom small{ color:var(--silver); font-size:.72rem; letter-spacing:.04em; }

/* ---- POPUP DEVIS ---- */
.modal{ position:fixed; inset:0; z-index:80; display:grid; place-items:center; padding:1.2rem; opacity:0; pointer-events:none; transition:opacity .4s var(--ease); }
.modal.open{ opacity:1; pointer-events:auto; }
.modal-bg{ position:absolute; inset:0; background:rgba(8,8,10,.66); backdrop-filter:blur(8px); -webkit-backdrop-filter:blur(8px); }
.modal-panel{ position:relative; width:min(100%,480px); max-height:92vh; overflow:auto; background:var(--panel); border:1px solid var(--hair); padding:clamp(1.6rem,4vw,2.6rem); transform:translateY(22px) scale(.985); transition:transform .5s var(--slow); }
.modal.open .modal-panel{ transform:none; }
.modal-panel .eyebrow{ margin-bottom:.6rem; }
.modal-panel h3{ font-family:var(--serif); font-weight:300; font-size:clamp(1.7rem,4vw,2.3rem); line-height:1.1; margin-bottom:1.6rem; }
.modal-close{ position:absolute; top:.9rem; right:.9rem; width:38px; height:38px; background:none; border:0; color:var(--silver); cursor:pointer; font-size:1.1rem; line-height:1; transition:color .3s; }
.modal-close:hover{ color:var(--bone); }
.field{ margin-bottom:1.3rem; }
.field label{ display:block; font-size:.66rem; letter-spacing:.2em; text-transform:uppercase; color:var(--silver); margin-bottom:.5rem; }
.field input, .field select, .field textarea{ width:100%; background:transparent; border:0; border-bottom:1px solid var(--hair); color:var(--bone); font-family:var(--sans); font-size:1rem; font-weight:300; padding:.5rem 0; transition:border-color .3s; }
.field textarea{ resize:vertical; min-height:64px; }
.field input:focus, .field select:focus, .field textarea:focus{ outline:none; border-bottom-color:var(--bone); }
.field select{ -webkit-appearance:none; appearance:none; cursor:pointer; }
.field select option, .field select optgroup{ background:var(--panel); color:var(--bone); }
.hp{ position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden; }
.modal .submit{ width:100%; margin-top:.4rem; padding:1rem; background:var(--bone); color:var(--ink); border:0; font-family:var(--sans); font-size:.8rem; letter-spacing:.2em; text-transform:uppercase; cursor:pointer; transition:opacity .3s; }
.modal .submit:hover{ opacity:.85; }
.modal .submit:disabled{ opacity:.5; cursor:default; }
.form-note{ margin-top:1rem; font-size:.85rem; color:var(--silver); min-height:1.2em; }
.form-note.err{ color:#d98a8a; }
.modal.sent .modal-form{ display:none; }
.modal-success{ display:none; } .modal.sent .modal-success{ display:block; }
.modal-success h3{ margin-bottom:.6rem; } .modal-success p{ color:var(--silver); }

/* ---- CONTACT ---- */
.page-head{ padding-top:clamp(8rem,16vw,11rem); padding-bottom:clamp(2rem,6vw,4rem); border-bottom:1px solid var(--hair-soft); }
.page-head .eyebrow{ margin-bottom:1rem; }
.page-head h1{ font-family:var(--serif); font-weight:300; font-size:clamp(2.6rem,7vw,5rem); line-height:1.02; }
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,6vw,5rem); align-items:start; }
.contact-block h2{ font-family:var(--serif); font-weight:400; font-size:1.4rem; margin-bottom:.6rem; }
.contact-row{ padding:1.2rem 0; border-bottom:1px solid var(--hair-soft); }
.contact-row .k{ font-size:.66rem; letter-spacing:.2em; text-transform:uppercase; color:var(--silver); margin-bottom:.35rem; }
.contact-row .v{ font-size:1.05rem; }
.contact-row a:hover{ text-decoration:underline; }
.map{ width:100%; aspect-ratio:4/3; border:1px solid var(--hair); filter:grayscale(1) contrast(.95) brightness(.9); }
.btn-line{ display:inline-flex; align-items:center; gap:.8em; margin-top:1.8rem; font-size:.8rem; letter-spacing:.2em; text-transform:uppercase; cursor:pointer; background:none; border:0; color:var(--bone); font-family:var(--sans); }
.btn-line .dash{ width:46px; height:1px; background:var(--bone); transition:width .4s var(--ease); }
.btn-line:hover .dash{ width:72px; }

/* ---- RESPONSIVE ---- */
@media (max-width:860px){
  .nav-links{ display:none; } .burger{ display:block; }
  .cat-grid{ grid-template-columns:1fr; gap:2rem; }
  .feat-row, .feat-row:nth-child(even){ grid-template-columns:1fr; gap:1.5rem; }
  .feat-row:nth-child(even) .feat-media{ order:0; }
  .contact-grid{ grid-template-columns:1fr; gap:2.5rem; }
  .hero h1{ max-width:100%; }
}
@media (max-width:480px){ .nav{ height:72px; } }
:focus-visible{ outline:1px solid var(--bone); outline-offset:4px; }
@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; transition-duration:.001s !important; }
  .hero h1 .line span{ transform:none; }
  .cat-card img, .feat-media img{ clip-path:none; transform:none; }
  .reveal{ opacity:1; transform:none; }
  .modal-panel{ transform:none; }
  .water-gl{ display:none; }
}

/* ============================================================
   PAGINA MODÈLES — grilă carduri grupate pe mărime
   ============================================================ */
.filters{ display:flex; flex-wrap:wrap; gap:.6rem; padding-bottom:clamp(2rem,4vw,3rem); }
.filter-btn{ background:none; border:1px solid var(--hair); color:var(--silver); font-family:var(--sans); font-size:.72rem; letter-spacing:.18em; text-transform:uppercase; padding:.7em 1.3em; border-radius:999px; cursor:pointer; transition:color .3s, border-color .3s, background .3s; }
.filter-btn:hover{ color:var(--bone); border-color:var(--bone); }
.filter-btn.active{ background:var(--bone); color:var(--ink); border-color:var(--bone); }

.group{ margin-top:clamp(2.5rem,5vw,3.5rem); padding:0; }
.group:first-child{ margin-top:0; }
.list-wrap{ padding-top:clamp(2rem,4vw,3rem); }
.group-head{ display:flex; align-items:baseline; gap:1rem; padding-bottom:1.3rem; margin-bottom:clamp(2.2rem,4vw,3.2rem); border-bottom:1px solid var(--hair); }
.group-head h2{ font-family:var(--serif); font-weight:300; font-size:clamp(1.9rem,4vw,2.9rem); line-height:1; }
.group-head .count{ font-size:.7rem; letter-spacing:.2em; text-transform:uppercase; color:var(--silver); }

.model-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(1.6rem,3vw,2.6rem); }
.mcard{ display:block; text-align:center; opacity:0; transform:translateY(26px); transition:opacity .85s var(--slow), transform .85s var(--slow); }
.mcard.in{ opacity:1; transform:none; }
.mcard .frame{ position:relative; overflow:hidden; aspect-ratio:4/5; background:var(--panel); margin-bottom:1.3rem; }
.mcard .frame img{ width:100%; height:100%; object-fit:cover; filter:saturate(0); transform:scale(1.1); clip-path:inset(0 0 100% 0); transition:clip-path 1.1s var(--slow), transform 1.5s var(--slow), filter .7s var(--ease); }
.mcard.in .frame img{ clip-path:inset(0 0 0 0); transform:scale(1.03); }
.mcard:hover .frame img{ transform:scale(1.07); filter:saturate(1); }
.mcard h3{ font-family:var(--serif); font-weight:400; font-size:clamp(1.7rem,2.8vw,2.3rem); line-height:1; }
.mcard .mdim{ color:var(--silver); font-size:1rem; margin-top:.55rem; }
.mcard .mdim small{ display:block; font-size:.64rem; letter-spacing:.16em; text-transform:uppercase; margin-top:.25rem; }
.mcard .mbadges{ display:flex; flex-wrap:wrap; gap:.4rem; justify-content:center; margin-top:.95rem; }
.badge{ font-size:.6rem; letter-spacing:.12em; text-transform:uppercase; color:var(--silver); border:1px solid var(--hair); padding:.4em .7em; border-radius:999px; white-space:nowrap; }
.mcard .more{ display:inline-flex; align-items:center; gap:.6em; margin-top:1.2rem; font-size:.72rem; letter-spacing:.2em; text-transform:uppercase; color:var(--bone); }
.mcard .more .arr{ transition:transform .4s var(--ease); }
.mcard:hover .more .arr{ transform:translateX(6px); }
.list-empty{ padding:3rem 0; color:var(--silver); }

@media (max-width:900px){ .model-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:600px){
  .model-grid{ grid-template-columns:1fr; gap:2.6rem; }
  .mcard .frame{ aspect-ratio:4/3; }
}
@media (prefers-reduced-motion:reduce){ .mcard{ opacity:1; transform:none; } .mcard .frame img{ clip-path:none; transform:none; } }

/* două grupe cu un singur model -> pe același rând (stânga / gol / dreapta) */
.group-duo{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(1.6rem,3vw,2.6rem); margin-top:clamp(2.5rem,5vw,3.5rem); }
.group-duo .group{ margin-top:0; }
.group-duo .group:nth-child(1){ grid-column:1; }
.group-duo .group:nth-child(2){ grid-column:3; }   /* mijlocul (col 2) rămâne gol */
.group-duo .model-grid{ grid-template-columns:1fr; } /* cardul umple coloana, aceeași mărime ca restul */
@media (max-width:900px){
  .group-duo{ grid-template-columns:1fr; }
  .group-duo .group{ grid-column:auto; }
  .group-duo .group + .group{ margin-top:clamp(2.5rem,5vw,3.5rem); }
}

/* ============================================================
   PAGINA MODEL (detaliu)
   ============================================================ */
.dhero{ position:relative; min-height:78svh; display:flex; align-items:flex-end; overflow:hidden; isolation:isolate; }
.dhero-photo{ position:absolute; inset:0; z-index:0; background:#08080a center/cover no-repeat; transform:scale(1.05); }
.dhero-veil{ position:absolute; inset:0; z-index:1; background:linear-gradient(180deg, rgba(8,8,10,.55) 0%, rgba(8,8,10,.2) 45%, rgba(8,8,10,.9) 100%); }
.dhero .inner{ position:relative; z-index:2; padding-bottom:clamp(3rem,7vw,5.5rem); padding-top:120px; text-shadow:0 2px 30px rgba(0,0,0,.4); }
.dhero .eyebrow{ margin-bottom:1rem; }
.dhero h1{ font-family:var(--serif); font-weight:300; font-size:clamp(3rem,9vw,7rem); line-height:.98; letter-spacing:-.01em; }
.dhero .tagline{ font-family:var(--serif); font-style:italic; font-weight:300; font-size:clamp(1.3rem,3vw,2rem); color:var(--silver); margin-top:.6rem; }
.back-link{ display:inline-flex; align-items:center; gap:.6em; font-size:.72rem; letter-spacing:.2em; text-transform:uppercase; color:var(--silver); margin-bottom:1.4rem; transition:color .3s; }
.back-link:hover{ color:var(--bone); }

.spec-strip{ display:flex; flex-wrap:wrap; gap:clamp(1.5rem,5vw,4rem); padding:clamp(2rem,4vw,3rem) 0; border-bottom:1px solid var(--hair-soft); }
.spec-strip .item .k{ font-size:.64rem; letter-spacing:.2em; text-transform:uppercase; color:var(--silver); margin-bottom:.4rem; }
.spec-strip .item .v{ font-family:var(--serif); font-size:clamp(1.4rem,3vw,2rem); }

.detail-intro p{ font-size:clamp(1.1rem,2.2vw,1.45rem); line-height:1.5; max-width:60ch; color:var(--bone); }

.features-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:clamp(1.5rem,4vw,3rem); }
.feature{ border-top:1px solid var(--hair); padding-top:1.4rem; }
.feature h3{ font-family:var(--serif); font-weight:400; font-size:clamp(1.4rem,2.6vw,1.9rem); margin-bottom:.6rem; }
.feature p{ color:var(--silver); }

.section-label{ font-family:var(--serif); font-weight:300; font-size:clamp(1.8rem,4vw,2.8rem); margin-bottom:clamp(2rem,4vw,3rem); }

.gallery-grid{ columns:3; column-gap:clamp(.6rem,1.5vw,1rem); }
.gallery-grid .g{ break-inside:avoid; margin-bottom:clamp(.6rem,1.5vw,1rem); overflow:hidden; background:var(--panel); cursor:zoom-in; opacity:0; transform:translateY(22px); transition:opacity .8s var(--slow), transform .8s var(--slow); }
.gallery-grid .g.in{ opacity:1; transform:none; }
.gallery-grid img{ width:100%; height:auto; display:block; filter:saturate(0); transition:filter .6s var(--ease), transform 1.2s var(--slow); }
.gallery-grid .g:hover img{ filter:saturate(1); transform:scale(1.04); }
@media (max-width:760px){ .gallery-grid{ columns:2; } }
@media (max-width:480px){ .gallery-grid{ columns:1; } }

.dimtable-wrap{ overflow-x:auto; }
.dimtable{ width:100%; border-collapse:collapse; min-width:520px; }
.dimtable th, .dimtable td{ text-align:left; padding:1rem 1.2rem; border-bottom:1px solid var(--hair-soft); white-space:nowrap; }
.dimtable th{ font-size:.64rem; letter-spacing:.2em; text-transform:uppercase; color:var(--silver); font-weight:400; }
.dimtable td{ font-size:1rem; }
.dimtable td:first-child{ font-family:var(--serif); font-size:1.2rem; }
.dimtable tr:hover td{ background:rgba(242,240,236,.03); }

.swatch-block{ margin-bottom:clamp(2.5rem,5vw,4rem); }
.swatch-block .lbl{ font-size:.7rem; letter-spacing:.2em; text-transform:uppercase; color:var(--silver); margin-bottom:1.2rem; }
.swatches{ display:grid; grid-template-columns:repeat(6,1fr); gap:clamp(1rem,2vw,1.6rem); }
.swatch{ text-align:center; }
.swatch .sw{ aspect-ratio:1; overflow:hidden; border-radius:50%; border:1px solid var(--hair); background:var(--panel); }
@media (max-width:600px){ .swatches{ grid-template-columns:repeat(3,1fr); } }
.swatch .sw img{ width:100%; height:100%; object-fit:cover; }
.swatch .nm{ font-size:.66rem; letter-spacing:.1em; text-transform:uppercase; color:var(--silver); margin-top:.5rem; }
.chips{ display:flex; flex-wrap:wrap; gap:.6rem; }
.chip{ font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--bone); border:1px solid var(--hair); padding:.6em 1.1em; border-radius:999px; }

.cta-band{ border-top:1px solid var(--hair); text-align:center; }
.cta-band h2{ font-family:var(--serif); font-weight:300; font-size:clamp(2rem,5vw,3.4rem); line-height:1.1; margin-bottom:1.6rem; }
.cta-band .btn-solid{ display:inline-flex; align-items:center; gap:.8em; background:var(--bone); color:var(--ink); border:0; font-family:var(--sans); font-size:.78rem; letter-spacing:.2em; text-transform:uppercase; padding:1.1em 2.2em; cursor:pointer; transition:opacity .3s; }
.cta-band .btn-solid:hover{ opacity:.85; }

@media (max-width:760px){
  .features-grid{ grid-template-columns:1fr; gap:0; }
  .feature{ margin-top:1.6rem; }
}
@media (prefers-reduced-motion:reduce){ .gallery-grid .g{ opacity:1; transform:none; } }

/* ============================================================
   FIX-uri: spațiere pagină model, lightbox, duo mobil, touch
   ============================================================ */
/* pagina model: secțiuni mult mai strânse (gata cu golurile) */
.model section{ padding-block:clamp(2rem,4vw,3rem); }
.model .dhero{ padding-block:0; }
.model .cta-band{ padding-block:clamp(4rem,8vw,6rem); }

/* lightbox galerie */
.lightbox{ position:fixed; inset:0; z-index:90; display:grid; place-items:center; padding:2rem; background:rgba(8,8,10,.92); backdrop-filter:blur(6px); -webkit-backdrop-filter:blur(6px); opacity:0; pointer-events:none; transition:opacity .35s var(--ease); }
.lightbox.open{ opacity:1; pointer-events:auto; }
.lightbox img{ max-width:90vw; max-height:86vh; object-fit:contain; }
.lb-btn{ position:absolute; background:none; border:0; color:var(--bone); cursor:pointer; opacity:.65; transition:opacity .3s; line-height:1; }
.lb-btn:hover{ opacity:1; }
.lb-close{ top:1.3rem; right:1.5rem; font-size:1.6rem; }
.lb-prev,.lb-next{ top:50%; transform:translateY(-50%); font-size:2.8rem; padding:.3rem 1rem; }
.lb-prev{ left:.3rem; } .lb-next{ right:.3rem; }
@media (max-width:600px){ .lb-prev,.lb-next{ font-size:2rem; padding:.2rem .5rem; } }

/* duo (Grandes+Autoportante) pe mobil: stivuite, fără suprapunere */
@media (max-width:900px){
  .group-duo{ grid-template-columns:1fr; }
  .group-duo .group:nth-child(1), .group-duo .group:nth-child(2){ grid-column:auto; }
  .group-duo .group + .group{ margin-top:clamp(2.5rem,5vw,3.5rem); }
}

/* colorare la atingere (touch / mobil) */
@media (hover:none){
  .mcard.press .frame img, .cat-card.press img, .feat-row.press .feat-media img, .row.press .row-thumb img{ filter:saturate(1); }
}

/* ---- CARACTÉRISTIQUES: plan (blueprint) + points numérotés ---- */
.plan-panel{ background:var(--bone); padding:clamp(1.5rem,4vw,3rem); margin-bottom:clamp(2.5rem,5vw,4rem); }
.plan-panel img{ width:100%; height:auto; display:block; }
.points-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(1.6rem,4vw,3rem) clamp(2rem,5vw,4rem); }
.point .n{ font-family:var(--serif); font-size:1.3rem; width:2.4rem; height:2.4rem; border:1px solid var(--hair); border-radius:50%; display:flex; align-items:center; justify-content:center; color:var(--silver); margin-bottom:1rem; }
.point h3{ font-family:var(--serif); font-weight:400; font-size:clamp(1.3rem,2.4vw,1.7rem); margin-bottom:.5rem; line-height:1.1; }
.point p{ color:var(--silver); font-size:.95rem; }
@media (max-width:760px){ .points-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:520px){ .points-grid{ grid-template-columns:1fr; } }

/* ---- bloc Gravity (diagramă + texte) ---- */
.gravity-intro{ display:grid; grid-template-columns:.8fr 1.2fr; gap:clamp(2rem,5vw,4rem); align-items:center; margin-bottom:clamp(2.5rem,5vw,4rem); }
.gravity-intro .diag{ aspect-ratio:1; border:1px solid var(--hair); border-radius:50%; overflow:hidden; display:flex; align-items:center; justify-content:center; padding:9%; }
.gravity-intro .diag img{ width:100%; height:100%; object-fit:contain; }
.gravity-intro .txt h3{ font-family:var(--serif); font-weight:300; font-size:clamp(2rem,4vw,3rem); margin-bottom:1rem; }
.gravity-intro .txt p{ color:var(--silver); margin-bottom:1rem; }
.gravity-intro .txt p:last-child{ margin-bottom:0; }
@media (max-width:760px){ .gravity-intro{ grid-template-columns:1fr; gap:1.8rem; } .gravity-intro .diag{ max-width:300px; } }

/* ---- pierre de couronnement (3 PNG-uri) ---- */
.coping-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(1.2rem,3vw,2.4rem); align-items:end; }
.coping{ text-align:center; }
.coping img{ width:100%; height:auto; display:block; }
.coping .nm{ font-size:.66rem; letter-spacing:.16em; text-transform:uppercase; color:var(--silver); margin-top:.8rem; }
@media (max-width:480px){ .coping-grid{ grid-template-columns:1fr; gap:1.6rem; max-width:280px; } }

/* ---- previzualizator culori interactiv ---- */
.color-preview{ display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(2rem,5vw,4rem); align-items:center; }
.cp-stage{ position:relative; aspect-ratio:4/3; overflow:hidden; background:var(--panel); }
.cp-stage img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; opacity:0; transition:opacity .55s var(--ease); }
.cp-stage img.show{ opacity:1; }
.cp-caption{ position:absolute; top:1rem; left:1rem; z-index:2; background:rgba(242,240,236,.92); color:var(--ink); font-size:.62rem; letter-spacing:.14em; text-transform:uppercase; padding:.45em .8em; }
.cp-pick h3{ font-family:var(--serif); font-weight:300; font-size:clamp(1.8rem,3.5vw,2.6rem); line-height:1.05; margin-bottom:.6rem; }
.cp-pick > p{ color:var(--silver); margin-bottom:1.6rem; font-size:.95rem; }
.cp-swatches{ display:grid; grid-template-columns:repeat(6,1fr); gap:clamp(.7rem,1.5vw,1.1rem); }
.cp-sw{ cursor:pointer; text-align:center; background:none; border:0; padding:0; }
.cp-sw .sw{ aspect-ratio:1; border-radius:50%; overflow:hidden; border:1px solid var(--hair); transition:border-color .3s, transform .3s; }
.cp-sw.active .sw{ border-color:var(--bone); transform:scale(1.06); }
.cp-sw .sw img{ width:100%; height:100%; object-fit:cover; }
.cp-sw .nm{ font-size:.58rem; letter-spacing:.08em; text-transform:uppercase; color:var(--silver); margin-top:.45rem; }
.cp-sw.active .nm{ color:var(--bone); }
@media (max-width:860px){ .color-preview{ grid-template-columns:1fr; } }
@media (max-width:600px){ .cp-swatches{ grid-template-columns:repeat(4,1fr); } }

/* ---- Paramètres: selector config + plan tehnic + sub-filtru mărime ---- */
.config-tabs{ display:flex; flex-wrap:wrap; gap:.6rem; margin-bottom:1.4rem; }
.config-tab{ background:none; border:1px solid var(--hair); color:var(--silver); font-family:var(--sans); font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; padding:.7em 1.2em; border-radius:999px; cursor:pointer; transition:color .3s,border-color .3s,background .3s; }
.config-tab:hover{ color:var(--bone); border-color:var(--bone); }
.config-tab.active{ background:var(--bone); color:var(--ink); border-color:var(--bone); }
.config-desc{ color:var(--silver); max-width:62ch; margin-bottom:clamp(2rem,4vw,3rem); min-height:2.4em; }
.plan-tech{ background:var(--bone); padding:clamp(1.5rem,4vw,3rem); margin-bottom:clamp(2.5rem,5vw,4rem); }
.plan-tech img{ width:100%; height:auto; display:block; }
.size-tabs{ display:flex; flex-wrap:wrap; gap:.5rem; margin-bottom:1.5rem; }
.size-tab{ background:none; border:1px solid var(--hair); color:var(--silver); font-family:var(--sans); font-size:.66rem; letter-spacing:.14em; text-transform:uppercase; padding:.55em 1.1em; border-radius:999px; cursor:pointer; transition:.3s; }
.size-tab:hover{ color:var(--bone); }
.size-tab.active{ background:var(--bone); color:var(--ink); border-color:var(--bone); }
