:root{
  --bg:#f6f1e8;
  --bg-soft:#efe8dc;
  --card:#fffdf8;
  --text:#262522;
  --muted:#655f57;
  --line:#e4d8c7;
  --green:#334b3c;
  --sand:#d7c5a8;
  --gold:#a78549;
  --shadow:0 16px 40px rgba(37,31,22,.08);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--text);font-family:Arial,Helvetica,sans-serif}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
.container{width:min(1280px,calc(100% - 40px));margin:0 auto}

/* ===== HEADER ===== */

.site-header{
  position:sticky;
  top:0;
  z-index:40;
  background:rgba(246,241,232,.92);
  backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(51,75,60,.12);
}

.header-inner{
  min-height:82px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
}

.brand{
  display:flex;
  align-items:center;
  gap:14px;
}

.brand-logo{
  width:58px;
  height:58px;
  object-fit:cover;
  border-radius:50%;
  border:1px solid var(--line);
  box-shadow:var(--shadow);
}

.brand-title{
  font-size:12px;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--green);
  font-weight:700;
}

.brand-subtitle{
  font-size:13px;
  color:var(--muted);
  margin-top:4px;
}

.main-nav{
  display:flex;
  gap:24px;
  font-size:15px;
  color:#4e4a44;
}

.main-nav a:hover{color:var(--green)}

/* ===== HERO ===== */

.hero-video{
  position:relative;
  min-height:85vh;
  overflow:hidden;
  background:#000;
}

.hero-video iframe{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  border:0;
  transform:scale(1.04);
}

.hero-overlay{
  position:relative;
  min-height:85vh;
  background:linear-gradient(180deg,rgba(17,18,16,.24),rgba(17,18,16,.58));
  display:flex;
  align-items:end;
}

.hero-inner{
  padding:120px 0 70px;
  color:#fff;
}

.eyebrow{
  font-size:12px;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--gold);
  font-weight:700;
}

.hero-inner h1,
.page-hero h1{
  font-size:clamp(46px,7vw,92px);
  line-height:.92;
  letter-spacing:-.05em;
  margin:14px 0 0;
  max-width:10ch;
  font-family:Georgia,"Times New Roman",serif;
}

.page-hero h1{
  color:var(--text);
  max-width:none;
}

.hero-baseline{
  font-size:19px;
  line-height:1.6;
  max-width:50ch;
  margin:16px 0 0;
  color:rgba(255,255,255,.92);
}

.page-hero .section-copy{max-width:58ch}

.hero-actions,
.section-cta{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-top:28px;
}

/* ===== BUTTONS ===== */

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:14px 20px;
  border-radius:999px;
  border:1px solid transparent;
  font-weight:700;
  cursor:pointer;
}

.btn-primary{
  background:var(--green);
  color:#fff;
}

.btn-secondary{
  background:rgba(255,255,255,.14);
  color:#fff;
  border-color:rgba(255,255,255,.28);
}

.btn-outline-dark{
  background:#fff;
  color:var(--green);
  border-color:var(--line);
}

/* ===== LAYOUT ===== */

.section{padding:74px 0}
.alt-section{background:var(--bg-soft)}
.warm-section{background:linear-gradient(180deg,#fbf8f2,#f2ebdf)}

.section-head{
  display:flex;
  justify-content:space-between;
  align-items:end;
  gap:20px;
  margin-bottom:28px;
}

.split-head .section-copy{max-width:52ch}

.section h2{
  font-family:Georgia,"Times New Roman",serif;
  font-size:clamp(32px,4vw,52px);
  line-height:1.02;
  letter-spacing:-.04em;
  margin:12px 0 0;
}

.section-copy,
.muted{
  color:var(--muted);
  line-height:1.75;
  font-size:16px;
}

.search-wrap{width:min(100%,360px)}

.search-input{
  width:100%;
  padding:14px 16px;
  border-radius:999px;
  border:1px solid var(--line);
  background:#fff;
  font:inherit;
}

/* ===== COMMON CARDS ===== */

.selection-card,
.vehicle-card,
.featured-automobilia,
.maison-strip,
.news-card,
.contact-box,
.video-card,
.detail-sidebar .sidebar-box{
  background:var(--card);
  border:1px solid var(--line);
  box-shadow:var(--shadow);
  border-radius:28px;
  overflow:hidden;
  transition:transform .28s ease, box-shadow .28s ease, border-color .28s ease;
}

.selection-card:hover,
.selection-hero:hover,
.vehicle-card:hover,
.featured-automobilia:hover,
.maison-strip:hover,
.news-card:hover{
  transform:translateY(-4px);
  box-shadow:0 24px 56px rgba(37,31,22,.12);
  border-color:#d7c5a8;
}

.card-topline{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  margin-bottom:10px;
}

.pill{
  display:inline-flex;
  padding:8px 12px;
  border-radius:999px;
  background:#f0e8db;
  color:var(--green);
  font-size:12px;
  font-weight:700;
}

.pill.sold{
  background:#e8dfd2;
  color:#7a4e33;
}

.selection-body,
.vehicle-body,
.featured-automobilia-body{
  padding:20px;
}

.selection-card h3,
.vehicle-card h3,
.featured-automobilia h3,
.news-card strong{
  font-family:Georgia,"Times New Roman",serif;
  font-size:28px;
  line-height:1.06;
  margin:0;
}

.selection-card.large h3{font-size:40px}

.card-link-row{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  margin-top:16px;
  font-size:15px;
}

.card-link-row a,
.selection-body h3 a,
.vehicle-body h3 a,
.featured-automobilia-body h3 a{
  transition:opacity .2s ease;
}

.card-link-row a:hover,
.selection-body h3 a:hover,
.vehicle-body h3 a:hover,
.featured-automobilia-body h3 a:hover{
  opacity:.7;
}

/* ===== HOME SELECTION ===== */

.selection-grid-alt{
  display:grid;
  grid-template-columns:1.25fr .75fr .75fr;
  gap:20px;
  align-items:start;
}

.selection-card.large{grid-row:span 2}

.selection-image,
.vehicle-thumb,
.featured-automobilia-image{
  background-repeat:no-repeat;
  background-position:center center;
}

.selection-image{
  background-size:cover;
  aspect-ratio:4/3;
}

.selection-card.large .selection-image{aspect-ratio:4/5}

.selection-home{
  display:grid;
  gap:24px;
}

.selection-hero{
  display:grid;
  grid-template-columns:minmax(0, 1.45fr) minmax(280px, 0.85fr);
  gap:24px;
  align-items:center;
  background:var(--card);
  border:1px solid var(--line);
  box-shadow:var(--shadow);
  border-radius:28px;
  overflow:hidden;
  padding:22px;
  transition:transform .28s ease, box-shadow .28s ease, border-color .28s ease;
}

.selection-hero-media{
  display:block;
}

.vehicle-thumb-hero{
  height:360px;
  aspect-ratio:auto;
  border-radius:22px;
}

.selection-hero-body{
  padding:8px 6px 8px 0;
  display:flex;
  flex-direction:column;
  justify-content:center;
}

.selection-hero-body h3{
  font-size:clamp(28px, 3vw, 40px);
}

.selection-row{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
}

.selection-image.hero{
  width:100%;
  height:520px;
  background:#efe8dc;
  border-radius:28px;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
}

.selection-card .selection-image{
  height:260px;
  background:#efe8dc;
  border-radius:18px;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
}

.selection-image.hero img,
.selection-card .selection-image img{
  width:100%;
  height:100%;
  object-fit:contain;
  object-position:center center;
  display:block;
}

.selection-hero,
.selection-card{
  overflow:hidden;
}

.selection-body{text-align:left}

.selection-brand-logo,
.selection-brand-row{
  display:none !important;
}

/* ===== VEHICLE CARDS ===== */

.cards-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
}

.vehicle-card{
  display:flex;
  flex-direction:column;
  height:100%;
}

.vehicle-thumb{
  width:100%;
  height:260px;
  background-color:#efe8dc;
  background-size:cover;
  border-bottom:1px solid var(--line);
}

.vehicle-body{
  flex:1;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
}

.vehicle-body h3{
  font-family:Georgia,"Times New Roman",serif;
  font-size:26px;
  line-height:1.08;
  margin:0 0 12px;
}

.vehicle-body .card-link-row{
  margin-top:18px;
}

.sold-card .vehicle-thumb{filter:saturate(.75)}

/* ===== FEATURED AUTOMOBILIA ===== */

.featured-automobilia{
  display:grid;
  grid-template-columns:minmax(0, 1.15fr) minmax(320px, 0.85fr);
  gap:0;
  align-items:stretch;
}

.featured-automobilia-image{
  min-height:420px;
  background-color:#efe8dc;
  background-size:contain;
}

.featured-automobilia-body{
  padding:28px 30px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}

.featured-automobilia-body h3{
  font-family:Georgia,"Times New Roman",serif;
  font-size:clamp(28px, 3vw, 40px);
  line-height:1.04;
  margin:0 0 14px;
}

.featured-automobilia-body .muted,
.featured-automobilia-body p{
  line-height:1.8;
  color:var(--muted);
}

.featured-automobilia .card-link-row{
  margin-top:22px;
}

/* ===== AUTOMOBILIA MINI CARDS ===== */

.automobilia-small-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
  margin-top:28px;
}

.automobilia-home-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
  margin-top:24px;
}

.automobilia-mini-card{
  background:var(--card);
  border:1px solid var(--line);
  box-shadow:var(--shadow);
  border-radius:22px;
  overflow:hidden;
  transition:transform .28s ease, box-shadow .28s ease, border-color .28s ease;
}

.automobilia-mini-card:hover{
  transform:translateY(-4px);
  box-shadow:0 24px 56px rgba(37,31,22,.12);
  border-color:#d7c5a8;
}

.automobilia-mini-image{
  width:100%;
  height:190px;
  background-color:#efe8dc;
  background-repeat:no-repeat;
  background-position:center center;
  background-size:cover;
}

.automobilia-mini-body{
  padding:16px;
}

.automobilia-mini-body h3{
  font-family:Georgia,"Times New Roman",serif;
  font-size:22px;
  line-height:1.08;
  margin:0;
}

/* ===== AUTOMOBILIA THUMBS ===== */

.automobilia-home-thumbs{
  display:grid;
  grid-template-columns:repeat(5, 1fr);
  gap:12px;
  margin-top:20px;
}

.automobilia-thumb-link{
  display:block;
  border-radius:14px;
  overflow:hidden;
  transition:transform .22s ease, box-shadow .22s ease;
}

.automobilia-thumb-link:hover{
  transform:translateY(-3px);
  box-shadow:0 16px 34px rgba(37,31,22,.10);
}

.automobilia-thumb-image{
  width:100%;
  aspect-ratio:1 / 1;
  background-color:#efe8dc;
  background-repeat:no-repeat;
  background-position:center center;
  background-size:cover;
  border-radius:14px;
}

/* ===== MAISON ===== */

.maison-strips{
  display:grid;
  gap:20px;
}

.maison-strip{
  display:grid;
  grid-template-columns:1.15fr .85fr;
}

.maison-strip img{
  width:100%;
  height:100%;
  object-fit:cover;
  min-height:260px;
}

.maison-strip-large img{min-height:420px}

.maison-strip-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:20px;
}

.strip-copy{padding:22px}

.strip-copy h3{
  margin:0 0 10px;
  font-family:Georgia,"Times New Roman",serif;
  font-size:30px;
}

.maison-story{
  display:grid;
  gap:20px;
}

.story-wide img{aspect-ratio:16/8}

.story-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:20px;
}

.story-block{
  background:var(--card);
  border:1px solid var(--line);
  box-shadow:var(--shadow);
  border-radius:28px;
  overflow:hidden;
}

.story-block img{
  width:100%;
  aspect-ratio:4/3;
  object-fit:cover;
}

.story-copy{padding:22px}
.story-copy h2{margin-top:0}

/* ===== NEWS / SOCIAL / CONTACT ===== */

.news-placeholder{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:20px;
}

.news-card{
  padding:22px;
  display:block;
  min-height:180px;
}

.news-card strong{
  display:block;
  margin-bottom:12px;
}

.news-card p{margin:0}

.contact-box{
  padding:34px;
  display:grid;
  grid-template-columns:minmax(320px, 1.15fr) minmax(420px, 0.85fr);
  gap:40px;
  align-items:start;
}

.contact-details{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:26px 34px;
  color:var(--muted);
  align-items:start;
}

.contact-details > div{
  min-width:0;
}

.contact-details strong{
  display:block;
  margin-bottom:8px;
  color:var(--text);
  font-size:15px;
}

.contact-details a,
.contact-details span{
  display:block;
  line-height:1.7;
  word-break:break-word;
}

.contact-details p{
  margin:0;
  line-height:1.7;
}

.social-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
}

.social-card{
  display:flex;
  align-items:center;
  gap:18px;
  padding:22px;
  background:#fffdf8;
  border:1px solid #e4d8c7;
  border-radius:24px;
  box-shadow:0 16px 40px rgba(37,31,22,.08);
  transition:transform .25s ease, box-shadow .25s ease;
}

.social-card:hover{
  transform:translateY(-4px);
  box-shadow:0 24px 56px rgba(37,31,22,.12);
}

.social-icon{
  width:42px;
  height:42px;
  border-radius:50%;
  background:#efe8dc;
  display:flex;
  align-items:center;
  justify-content:center;
}

.social-icon svg{
  width:18px;
  height:18px;
  stroke:var(--green);
  stroke-width:1.2;
  fill:none;
}

.social-card strong{
  display:block;
  font-family:Georgia,"Times New Roman",serif;
  font-size:24px;
  margin-bottom:6px;
}

.social-card p{
  margin:0;
  color:#655f57;
}

.nav-social{
  display:flex;
  align-items:center;
  gap:10px;
  margin-left:8px;
}

.nav-social a{
  display:flex;
  align-items:center;
  justify-content:center;
  width:28px;
  height:28px;
  border-radius:50%;
  background:transparent;
  opacity:0.7;
  transition:all .2s ease;
}

.nav-social a:hover{
  opacity:1;
  transform:translateY(-1px);
}

.nav-social svg{
  width:16px;
  height:16px;
  stroke:var(--green);
  stroke-width:1.2;
  fill:none;
}

/* ===== INSTAGRAM ===== */

.instagram-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:28px;
  align-items:start;
}

.insta-item{
  background:#fffdf8;
  border:1px solid #e4d8c7;
  border-radius:22px;
  padding:14px;
  box-shadow:0 16px 40px rgba(37,31,22,.08);
  display:flex;
  justify-content:center;
}

.insta-item iframe,
.insta-item blockquote{
  max-width:420px !important;
  width:100% !important;
  margin:0 auto !important;
}

.insta-item:hover{
  transform:translateY(-4px);
  box-shadow:0 24px 60px rgba(37,31,22,.12);
  transition:.3s ease;
}

/* ===== DETAIL VEHICLE ===== */

.detail-layout{
  display:grid;
  grid-template-columns:1.2fr .8fr;
  gap:28px;
}

.detail-sidebar{
  align-self:start;
  position:sticky;
  top:96px;
}

.detail-gallery{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:12px;
}

.detail-gallery img{
  width:100%;
  aspect-ratio:4/3;
  object-fit:cover;
  border-radius:20px;
  border:1px solid var(--line);
}

.detail-block{margin-top:26px}

.points-list{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

.point-pill{
  display:inline-flex;
  padding:10px 14px;
  border-radius:999px;
  background:#fff;
  border:1px solid var(--line);
  color:var(--green);
  font-size:14px;
}

.sidebar-box{padding:24px}

.vehicle-price{
  font-family:Georgia,"Times New Roman",serif;
  font-size:34px;
  margin-bottom:16px;
}

.specs>div{
  display:flex;
  justify-content:space-between;
  gap:12px;
  padding:12px 0;
  border-bottom:1px solid #eee4d6;
  font-size:14px;
}

.specs span{color:var(--muted)}

/* ===== VEHICLE DETAIL CLEAN ===== */

.vehicle-topband{
  background:#334b3c;
  padding:18px 0;
  border-bottom:1px solid rgba(255,255,255,0.08);
}

.vehicle-topband-inner{
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:15px;
}

.vehicle-brand-block{
  display:flex;
  align-items:center;
  gap:10px;
  min-width:0;
}

.vehicle-brand-logo{
  height:34px;
  max-width:100px;
  object-fit:contain;
  background:#fff;
  padding:4px 8px;
  border-radius:6px;
}

.vehicle-brand-fallback{
  color:#d7c5a8;
  font-size:12px;
  text-transform:uppercase;
}

.vehicle-topband h1{
  color:#fff;
  margin:0;
  font-size:32px;
  font-family:Georgia,"Times New Roman",serif;
  line-height:1.05;
}

.vehicle-topband-year{
  color:#d7c5a8;
  font-weight:600;
  white-space:nowrap;
}

.vehicle-layout{
  display:grid;
  grid-template-columns:1.25fr 0.75fr;
  gap:36px;
  padding-top:36px;
  padding-bottom:60px;
}

.vehicle-left,
.vehicle-right{
  min-width:0;
}

.vehicle-main-image-wrap{
  position:relative;
}

.vehicle-main-image{
  width:100%;
  height:680px;
  background-size:contain;
  background-repeat:no-repeat;
  background-position:center;
  background-color:#efe8dc;
  border:1px solid #d7c5a8;
  border-radius:22px;
  cursor:zoom-in;
  box-shadow:0 16px 40px rgba(37,31,22,.08);
}

.vehicle-main-image:hover{
  transform:scale(1.01);
  transition:transform .3s ease;
}

.vehicle-nav{
  position:absolute;
  top:0;
  bottom:0;
  width:70px;
  border:none;
  background:linear-gradient(to right, rgba(0,0,0,0.35), transparent);
  color:#fff;
  font-size:34px;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
}

.vehicle-nav.prev{left:0}

.vehicle-nav.next{
  right:0;
  background:linear-gradient(to left, rgba(0,0,0,0.35), transparent);
}

.vehicle-nav:hover{
  background:rgba(0,0,0,0.55);
}

.vehicle-thumbs{
  display:flex;
  gap:10px;
  margin-top:14px;
  overflow-x:auto;
  padding-bottom:6px;
}

.vehicle-thumbs img{
  width:110px;
  height:82px;
  object-fit:contain;
  background:#efe8dc;
  border-radius:10px;
  border:1px solid #d7c5a8;
  padding:4px;
  cursor:pointer;
  flex:0 0 auto;
}

.vehicle-gallery-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:12px;
  margin-top:22px;
}

.vehicle-gallery-grid img{
  width:100%;
  aspect-ratio:4/3;
  object-fit:contain;
  background:#efe8dc;
  border-radius:18px;
  border:1px solid #d7c5a8;
  padding:6px;
  cursor:pointer;
}

.vehicle-sidebar{
  position:sticky;
  top:100px;
  background:#fffdf8;
  border:1px solid #e4d8c7;
  border-radius:24px;
  padding:26px;
  box-shadow:0 16px 40px rgba(37,31,22,.08);
}

.vehicle-main-infos,
.vehicle-secondary-infos{
  display:grid;
  gap:12px;
}

.vehicle-main-infos div,
.vehicle-secondary-infos div{
  display:flex;
  justify-content:space-between;
  gap:16px;
  padding-bottom:10px;
  border-bottom:1px solid #eee4d6;
}

.vehicle-main-infos span,
.vehicle-secondary-infos span{
  color:#6a6358;
}

.vehicle-main-infos strong,
.vehicle-secondary-infos strong{
  text-align:right;
}

.vehicle-description-block{
  margin:26px 0;
}

.vehicle-description-block h2,
.vehicle-secondary-infos h3{
  font-family:Georgia,"Times New Roman",serif;
  margin:0 0 14px;
}

.vehicle-description-block p{
  line-height:1.8;
  color:#4d4943;
}

.vehicle-lightbox{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.88);
  display:none;
  align-items:center;
  justify-content:center;
  z-index:9999;
  padding:30px;
}

.vehicle-lightbox.open{
  display:flex;
}

.vehicle-lightbox img{
  max-width:92vw;
  max-height:90vh;
  border-radius:14px;
}

.vehicle-lightbox-close{
  position:absolute;
  top:18px;
  right:24px;
  color:#fff;
  font-size:42px;
  cursor:pointer;
}

/* ===== VEHICLE CONTACT ===== */

.vehicle-contact-box{
  margin-top:20px;
  display:flex;
  flex-direction:column;
  gap:10px;
}

.contact-btn{
  display:block;
  text-align:center;
  padding:12px;
  border-radius:10px;
  font-weight:600;
  text-decoration:none;
  border:1px solid #d6cfc4;
  background:#fff;
  transition:0.2s;
}

.contact-btn:hover{
  background:#f5f5f5;
}

.contact-btn.primary{
  background:#334b3c;
  color:#fff;
  border:none;
}

.contact-btn.primary:hover{
  background:#22352a;
}

.contact-btn.whatsapp{
  background:#25D366;
  color:#fff;
  border:none;
}

.contact-btn.whatsapp:hover{
  background:#1ebe5b;
}

.vehicle-contact-simple{
  margin-top:15px;
  font-size:14px;
}

.vehicle-contact-simple a{
  text-decoration:none;
  font-weight:600;
  color:#334b3c;
}

.vehicle-contact-simple a:hover{
  text-decoration:underline;
}

/* ===== FOOTER ===== */

.site-footer{
  padding:34px 0 46px;
  border-top:1px solid rgba(51,75,60,.14);
  background:#f8f4ec;
}

.footer-grid{
  display:grid;
  grid-template-columns:1.1fr .9fr .8fr;
  gap:20px;
  align-items:start;
}

.footer-logo{
  width:74px;
  height:74px;
  border-radius:50%;
  object-fit:cover;
  border:1px solid var(--line);
  margin-bottom:14px;
}

.footer-note,
.footer-contact{
  color:var(--muted);
  line-height:1.7;
}

.footer-links{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  margin-top:10px;
}

body.home .footer-contact{
  display:none;
}

/* ===== ADMIN ===== */

.admin-body{
  background:#f4efe7;
}

.admin-shell{
  display:grid;
  grid-template-columns:280px 1fr;
  min-height:100vh;
}

.admin-sidebar{
  border-right:1px solid #e4d8c7;
  padding:24px;
  background:#fbf8f2;
}

.admin-nav{
  display:grid;
  gap:8px;
}

.admin-nav a{
  padding:12px 14px;
  border-radius:16px;
  color:#5f5a54;
}

.admin-nav a.active,
.admin-nav a:hover{
  background:#334b3c;
  color:#fff;
}

.admin-main{
  padding:28px;
}

.admin-head{
  display:flex;
  justify-content:space-between;
  gap:18px;
  align-items:end;
  margin-bottom:22px;
}

.admin-head h1{
  margin:0;
  font-size:34px;
  font-family:Georgia,"Times New Roman",serif;
}

.admin-head p{
  margin:8px 0 0;
  color:#6a6358;
}

.admin-table{
  width:100%;
  border-collapse:collapse;
  background:#fff;
}

.admin-table th,
.admin-table td{
  padding:14px;
  border-bottom:1px solid #eee4d7;
  text-align:left;
  font-size:14px;
  vertical-align:middle;
}

.admin-thumb{
  width:92px;
  height:68px;
  border-radius:14px;
  background-size:cover;
  background-position:center;
}

.admin-form-grid{
  display:grid;
  gap:18px;
}

.form-card{
  padding:22px;
  background:#fffdf8;
  border:1px solid #e4d8c7;
  border-radius:28px;
  box-shadow:0 16px 40px rgba(37,31,22,.08);
}

.form-card h2{
  font-size:24px;
  margin-top:0;
  font-family:Georgia,"Times New Roman",serif;
}

.form-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
}

.form-card label{
  display:block;
  margin:12px 0 8px;
  font-size:14px;
  font-weight:700;
  color:#5b554e;
}

.form-input,
.form-textarea{
  width:100%;
  padding:14px 16px;
  border-radius:18px;
  border:1px solid #e4d8c7;
  background:#fff;
  font:inherit;
}

.form-textarea{
  min-height:140px;
  resize:vertical;
}

.checks{
  display:flex;
  gap:20px;
  flex-wrap:wrap;
  margin-top:18px;
  font-size:14px;
  color:#5f5a54;
}

.gallery-admin{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px;
  margin-top:16px;
}

.gallery-admin-item{
  display:block;
  border:1px solid #e4d8c7;
  border-radius:18px;
  overflow:hidden;
  background:#fff;
}

.gallery-admin-item img{
  width:100%;
  aspect-ratio:4/3;
  object-fit:cover;
}

.gallery-admin-item span{
  display:block;
  padding:10px;
  font-size:13px;
}

.alert{
  padding:14px 16px;
  border-radius:16px;
  background:#fdf0ef;
  color:#8a3d33;
  border:1px solid #f4d0cb;
  margin-bottom:18px;
}

.alert.success{
  background:#eff8f0;
  color:#2a6a35;
  border-color:#d1ecd5;
}

.admin-login-body{
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  background:linear-gradient(135deg,#efe6d7,#f8f4ec,#dbe4df);
}

.admin-login-card{
  width:min(420px,calc(100% - 24px));
  padding:28px;
  background:#fffdf8;
  border:1px solid #e4d8c7;
  border-radius:28px;
  box-shadow:0 16px 40px rgba(37,31,22,.08);
}

.admin-login-card h1{
  margin:0 0 8px;
  font-size:34px;
  font-family:Georgia,"Times New Roman",serif;
}

.admin-login-card p{
  margin:0 0 18px;
  color:#6a6358;
}

input[type="file"]{
  display:block;
  width:100%;
  padding:12px;
  background:#fff;
  border:1px solid #d7c5a8;
  border-radius:12px;
  margin-top:10px;
  cursor:pointer;
}

/* ===== MAISON LOGO / EDITORIAL ===== */

.maison-logo-full{
  width:100%;
  text-align:center;
  margin:90px 0 40px;
  position:relative;
  opacity:0;
  transform:translateY(40px) scale(0.96);
  animation:maisonLogoFade 1.6s ease forwards;
  background:transparent !important;
  box-shadow:none !important;
}

.maison-logo-full img{
  width:380px;
  max-width:90%;
  height:auto;
  display:inline-block;
  opacity:0.95;
  background:transparent !important;
  box-shadow:none !important;
}

.maison-logo-full::after{
  content:"";
  display:block;
  width:160px;
  height:1px;
  background:linear-gradient(to right, transparent, #cfc6b8, transparent);
  margin:30px auto 20px;
}

@keyframes maisonLogoFade{
  from{
    opacity:0;
    transform:translateY(40px) scale(0.96);
  }
  to{
    opacity:1;
    transform:translateY(0) scale(1);
  }
}

.maison-hero-editorial{
  padding-top:20px;
}

.maison-hero-grid{
  display:grid;
  grid-template-columns:1.15fr 0.85fr;
  gap:40px;
  align-items:start;
}

.maison-hero-copy h1{
  max-width:12ch;
  margin-bottom:20px;
}

.maison-intro-text{
  max-width:none;
  margin:26px 0 0;
  font-size:17px;
  line-height:1.85;
  color:var(--muted);
}

.maison-intro-text p{
  margin:0 0 18px;
}

.maison-intro-text p:last-child{
  margin-bottom:0;
}

.maison-hero-photos-vertical{
  display:flex;
  flex-direction:column;
  gap:18px;
}

.maison-hero-photo{
  height:220px;
  border-radius:22px;
  overflow:hidden;
  background:var(--card);
  border:1px solid var(--line);
  box-shadow:var(--shadow);
}

.maison-hero-photo img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

/* ===== RESPONSIVE ===== */

@media (max-width:1100px){
  .selection-grid-alt,
  .cards-grid,
  .news-placeholder,
  .contact-box,
  .footer-grid,
  .featured-automobilia,
  .maison-strip,
  .story-row,
  .detail-layout{
    grid-template-columns:1fr;
  }

  .selection-card.large{grid-row:auto}

  .maison-strip-row{grid-template-columns:1fr}

  .automobilia-small-grid,
  .automobilia-home-grid{
    grid-template-columns:1fr;
  }

  .automobilia-home-thumbs{
    grid-template-columns:repeat(4, 1fr);
  }

  .featured-automobilia-image{
    min-height:340px;
  }

  .admin-shell{
    grid-template-columns:1fr;
  }

  .admin-sidebar{
    border-right:0;
    border-bottom:1px solid #e4d8c7;
  }

  .vehicle-layout{
    grid-template-columns:1fr;
  }

  .vehicle-sidebar{
    position:relative;
    top:auto;
  }

  .maison-hero-grid{
    grid-template-columns:1fr;
  }

  .maison-hero-copy h1{
    max-width:none;
  }

  .maison-hero-photos-vertical{
    flex-direction:row;
    overflow-x:auto;
    gap:16px;
  }

  .maison-hero-photo{
    min-width:240px;
    height:180px;
  }
}

@media (max-width:900px){
  .hero-inner{
    padding:90px 0 46px;
  }

  .hero-inner h1{
    font-size:clamp(34px, 11vw, 54px);
    max-width:none;
  }

  .hero-baseline{
    font-size:16px;
  }

  .section{
    padding:54px 0;
  }

  .section h2{
    font-size:clamp(28px, 8vw, 40px);
  }

  .selection-body,
  .vehicle-body,
  .featured-automobilia-body,
  .strip-copy,
  .news-card{
    padding:16px;
  }

  .card-link-row{
    flex-direction:column;
    align-items:flex-start;
  }

  .contact-box,
  .contact-details,
  .footer-grid{
    grid-template-columns:1fr;
  }

  .vehicle-topband h1{
    font-size:26px;
  }

  .vehicle-nav{
    width:54px;
    font-size:28px;
  }

  .selection-hero{
    grid-template-columns:1fr;
    padding:18px;
  }

  .vehicle-thumb-hero{
    height:300px;
  }

  .selection-hero-body{
    padding:0;
  }
}

@media (max-width:760px){
  .main-nav{display:none}

  .container{
    width:min(100% - 24px,1280px);
  }

  .section-head,
  .header-inner{
    flex-direction:column;
    align-items:flex-start;
  }

  .contact-details,
  .detail-gallery{
    grid-template-columns:1fr;
  }

  .vehicle-main-image{
    height:420px;
  }

  .vehicle-gallery-grid{
    grid-template-columns:1fr;
  }

  .selection-row{
    grid-template-columns:1fr;
  }

  .vehicle-topband-inner{
    grid-template-columns:1fr;
    gap:10px;
  }

  .vehicle-topband-year{
    font-size:15px;
  }

  .vehicle-brand-logo{
    height:28px;
  }

  .instagram-grid{
    grid-template-columns:1fr;
  }

  .insta-item iframe,
  .insta-item blockquote{
    max-width:100% !important;
  }

  .social-grid{
    grid-template-columns:1fr;
  }

  .featured-automobilia-image{
    min-height:260px;
    background-size:contain;
  }

  .featured-automobilia-body{
    padding:22px 18px;
  }

  .vehicle-thumb{
    height:210px;
  }

  .automobilia-home-thumbs{
    grid-template-columns:repeat(3, 1fr);
    gap:10px;
  }

  .admin-head{
    flex-direction:column;
    align-items:flex-start;
  }

  .form-grid,
  .gallery-admin{
    grid-template-columns:1fr;
  }

  .maison-intro-text{
    font-size:16px;
    line-height:1.8;
  }
}

@media (max-width:640px){
  .container{
    width:min(100% - 18px,1280px);
  }

  .brand-logo{
    width:48px;
    height:48px;
  }

  .brand-title{
    font-size:11px;
  }

  .brand-subtitle{
    font-size:12px;
  }

  .selection-image.hero{
    height:280px;
  }

  .selection-card .selection-image{
    height:190px;
  }

  .vehicle-main-image{
    height:320px;
  }

  .vehicle-thumbs img{
    width:88px;
    height:68px;
  }

  .vehicle-sidebar{
    padding:18px;
  }
}
/* ===== RUBAN FINAL PROPRE ===== */

.status-ribbon{
  position:absolute;
  top:22px;
  right:-110px;

  width:380px;
  height:70px;

  background:#334b3c;

  transform:rotate(38deg);

  display:flex;
  align-items:center;
  justify-content:center;
  gap:12px;

  z-index:50;
}

/* réservé */
.status-ribbon.reserved{
  background:#d7c5a8;
}

/* LOGO PROPRE (SANS FILTRE) */
.status-ribbon img{
  height:28px;
  object-fit:contain;
}

/* TEXTE */
.status-ribbon span{
  color:#fff;
  font-family:Georgia, serif;
  font-size:18px;
  letter-spacing:0.25em;
  text-transform:uppercase;
}