/* ============================================================
   EUROREPAR PORTAL — style.css
   Sin dependencias externas
   ============================================================ */

:root {
  --blue:       #003087;
  --blue-dark:  #00205c;
  --blue-light: #1a4aad;
  --red:        #E2001A;
  --red-dark:   #b8001a;
  --gray-50:    #f8f9fb;
  --gray-100:   #f0f2f5;
  --gray-200:   #e2e6ea;
  --gray-400:   #9aa3af;
  --gray-600:   #5a6373;
  --gray-900:   #111827;
  --white:      #ffffff;
  --radius:     12px;
  --radius-sm:  8px;
  --shadow:     0 2px 16px rgba(0,0,0,.08);
  --shadow-lg:  0 8px 40px rgba(0,0,0,.14);
  --transition: .2s cubic-bezier(.4,0,.2,1);
  --font:       'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --sidebar-w:  260px;
}

/* ---- RESET ---- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth}
body{font-family:var(--font);color:var(--gray-900);background:var(--gray-50);line-height:1.6}
a{color:var(--blue);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;height:auto;display:block}
button{cursor:pointer;font-family:inherit}
input,select,textarea{font-family:inherit;font-size:1rem}

/* ============================================================
   LAYOUT
   ============================================================ */
.layout-wrap{
  margin-left:var(--sidebar-w);
  min-height:100vh;
  display:flex;
  flex-direction:column;
  transition:margin var(--transition);
}
.main-content{
  flex:1;
  padding:2rem 2rem 1rem;
  max-width:1400px;
  width:100%;
}
.main-footer{
  text-align:center;
  padding:.75rem 2rem;
  font-size:.8rem;
  color:var(--gray-400);
  border-top:1px solid var(--gray-200);
  background:var(--white);
}
.main-footer a{color:var(--gray-600)}

/* ============================================================
   SIDEBAR
   ============================================================ */
.sidebar{
  position:fixed;
  top:0;left:0;
  width:var(--sidebar-w);
  height:100vh;
  background:var(--blue-dark);
  display:flex;
  flex-direction:column;
  overflow-y:auto;
  z-index:200;
  transition:transform var(--transition);
}
.sidebar-logo{
  padding:1.25rem 1rem;
  border-bottom:1px solid rgba(255,255,255,.1);
}
.logo-svg-sm{width:100%;height:auto}
.sidebar-nav{
  list-style:none;
  padding:.5rem 0 2rem;
  flex:1;
}
.nav-section{
  font-size:.65rem;
  font-weight:700;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:rgba(255,255,255,.4);
  padding:.9rem 1.25rem .3rem;
  margin-top:.25rem;
}
.nav-link{
  display:flex;
  align-items:center;
  gap:.6rem;
  padding:.6rem 1.25rem;
  color:rgba(255,255,255,.75);
  font-size:.9rem;
  border-radius:0;
  transition:background var(--transition),color var(--transition);
  border-left:3px solid transparent;
}
.nav-link svg{width:18px;height:18px;flex-shrink:0;opacity:.7}
.nav-link:hover{background:rgba(255,255,255,.08);color:#fff;text-decoration:none;border-left-color:rgba(255,255,255,.3)}
.nav-link.active{background:rgba(255,255,255,.12);color:#fff;border-left-color:var(--red);font-weight:600}
.nav-link.active svg{opacity:1}
.sidebar-overlay{
  display:none;
  position:fixed;inset:0;
  background:rgba(0,0,0,.4);
  z-index:199;
}

/* ============================================================
   TOPBAR
   ============================================================ */
.topbar{
  position:sticky;top:0;z-index:100;
  display:flex;
  align-items:center;
  gap:1rem;
  background:var(--white);
  border-bottom:1px solid var(--gray-200);
  padding:.75rem 2rem;
  box-shadow:0 1px 4px rgba(0,0,0,.06);
}
.burger{
  display:none;
  background:none;border:none;
  padding:.25rem;
  color:var(--gray-600);
}
.burger svg{width:24px;height:24px}
.topbar-title{
  font-weight:600;
  font-size:1rem;
  color:var(--gray-900);
  flex:1;
}
.topbar-user{
  display:flex;
  align-items:center;
  gap:1rem;
}
.user-name{
  display:flex;align-items:center;gap:.4rem;
  font-size:.875rem;color:var(--gray-600);
}
.badge-admin{
  background:var(--blue);color:#fff;
  font-size:.65rem;font-weight:700;
  padding:.15rem .45rem;border-radius:99px;
  letter-spacing:.05em;
}
.btn-logout{
  display:flex;align-items:center;gap:.3rem;
  background:none;border:1px solid var(--gray-200);
  padding:.35rem .75rem;border-radius:var(--radius-sm);
  font-size:.8rem;color:var(--gray-600);
  transition:all var(--transition);
}
.btn-logout:hover{background:var(--red);color:#fff;border-color:var(--red)}

/* ============================================================
   CARDS
   ============================================================ */
.card{
  background:var(--white);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:1.5rem;
  border:1px solid var(--gray-200);
}
.card+.card{margin-top:1.5rem}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  display:inline-flex;align-items:center;gap:.4rem;
  padding:.55rem 1.25rem;
  border-radius:var(--radius-sm);
  font-size:.875rem;font-weight:500;
  border:1px solid transparent;
  cursor:pointer;
  transition:all var(--transition);
  white-space:nowrap;
  text-decoration:none;
}
.btn-primary{background:var(--blue);color:#fff;border-color:var(--blue)}
.btn-primary:hover{background:var(--blue-light);border-color:var(--blue-light);text-decoration:none;color:#fff}
.btn-secondary{background:var(--white);color:var(--gray-900);border-color:var(--gray-200)}
.btn-secondary:hover{background:var(--gray-100);text-decoration:none;color:var(--gray-900)}
.btn-danger{background:var(--red);color:#fff;border-color:var(--red)}
.btn-danger:hover{background:var(--red-dark);border-color:var(--red-dark);text-decoration:none;color:#fff}
.btn-block{width:100%;justify-content:center}
.btn-sm{padding:.3rem .75rem;font-size:.8rem}

/* ============================================================
   FORMS
   ============================================================ */
.form-page{max-width:860px}
.form-card{padding:2rem}
.form-title{font-size:1.25rem;font-weight:700;margin-bottom:1.5rem;color:var(--gray-900)}
.form-section{margin-bottom:1.75rem}
.section-label{font-size:.8rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--gray-400);margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid var(--gray-100)}
.form-group{display:flex;flex-direction:column;gap:.35rem;margin-bottom:1rem}
.form-group label{font-size:.85rem;font-weight:500;color:var(--gray-600)}
.form-group input,.form-group select,.form-group textarea{
  border:1px solid var(--gray-200);
  border-radius:var(--radius-sm);
  padding:.6rem .85rem;
  font-size:.9rem;
  color:var(--gray-900);
  background:var(--white);
  transition:border-color var(--transition),box-shadow var(--transition);
}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{
  outline:none;
  border-color:var(--blue);
  box-shadow:0 0 0 3px rgba(0,48,135,.12);
}
.form-hint{font-size:.77rem;color:var(--gray-400)}
.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1rem}
.form-actions{display:flex;gap:.75rem;margin-top:1.5rem;flex-wrap:wrap}
.form-note{font-size:.85rem;color:var(--gray-600);margin-bottom:1rem;display:flex;align-items:center;gap:.35rem}

/* File upload */
.upload-zone{border:2px dashed var(--gray-200);border-radius:var(--radius);transition:border-color var(--transition)}
.upload-zone:hover{border-color:var(--blue)}
.upload-placeholder{
  text-align:center;padding:2rem 1rem;cursor:pointer;
  color:var(--gray-400);
}
.upload-placeholder svg{margin:0 auto .75rem}
.upload-placeholder p{font-weight:500;color:var(--gray-600);margin-bottom:.25rem}
.upload-placeholder span{font-size:.8rem}
#photosInput{display:none}
.photos-preview{display:flex;flex-wrap:wrap;gap:.5rem;padding:.75rem;padding-top:0}
.preview-img{width:90px;height:70px;object-fit:cover;border-radius:var(--radius-sm)}

/* Current photos (edit) */
.photos-current{display:flex;flex-wrap:wrap;gap:.75rem}
.photo-item{position:relative;border:1px solid var(--gray-200);border-radius:var(--radius-sm);overflow:hidden}
.photo-item img{width:120px;height:90px;object-fit:cover;display:block}
.photo-item-actions{display:flex;gap:.5rem;padding:.4rem .5rem;background:var(--gray-50);font-size:.75rem}
.radio-main,.checkbox-delete{display:flex;align-items:center;gap:.2rem;cursor:pointer}

/* Input with icon */
.input-with-icon{position:relative}
.input-with-icon input{padding-right:2.5rem}
.toggle-password{
  position:absolute;right:.6rem;top:50%;transform:translateY(-50%);
  background:none;border:none;color:var(--gray-400);padding:.2rem;
}
.toggle-password svg{width:18px;height:18px}
.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.875rem}

/* ============================================================
   ALERTS
   ============================================================ */
.alert{
  padding:.85rem 1rem;border-radius:var(--radius-sm);
  margin-bottom:1rem;font-size:.875rem;border-left:4px solid;
}
.alert-success{background:#f0fdf4;border-color:#16a34a;color:#15803d}
.alert-error{background:#fef2f2;border-color:var(--red);color:#b91c1c}

/* ============================================================
   TABLES
   ============================================================ */
.table-responsive{overflow-x:auto}
.data-table{width:100%;border-collapse:collapse;font-size:.875rem}
.data-table thead{background:var(--gray-50)}
.data-table th{padding:.65rem 1rem;text-align:left;font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.04em;color:var(--gray-600);border-bottom:2px solid var(--gray-200)}
.data-table td{padding:.7rem 1rem;border-bottom:1px solid var(--gray-100);vertical-align:middle}
.data-table tbody tr:hover{background:var(--gray-50)}
.data-table-sm th,.data-table-sm td{padding:.5rem .65rem}
.table-card{padding:0;overflow:hidden}
.table-thumb{width:60px;height:45px;object-fit:cover;border-radius:var(--radius-sm)}
.table-thumb-empty{width:60px;height:45px;background:var(--gray-100);border-radius:var(--radius-sm)}
.table-link{color:var(--gray-900);font-weight:500}
.table-link:hover{color:var(--blue)}
.table-actions{display:flex;gap:.4rem;flex-wrap:wrap}

/* ============================================================
   STATUS BADGES
   ============================================================ */
.status-badge{
  display:inline-flex;align-items:center;gap:.3rem;
  padding:.2rem .6rem;border-radius:99px;
  font-size:.75rem;font-weight:600;
}
.status-active{background:#dcfce7;color:#15803d}
.status-suspended{background:#fef9c3;color:#854d0e}
.status-deleted{background:#fee2e2;color:#b91c1c}
.badge-role{padding:.2rem .6rem;border-radius:99px;font-size:.75rem;font-weight:600}
.badge-admin{background:#ede9fe;color:#5b21b6}
.badge-user{background:#e0f2fe;color:#0369a1}

/* ============================================================
   CAR CARDS (BUSCADOR)
   ============================================================ */
.cars-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
  gap:1.25rem;
  margin-top:1rem;
}
.car-card{
  background:var(--white);
  border-radius:var(--radius);
  border:1px solid var(--gray-200);
  box-shadow:var(--shadow);
  overflow:hidden;
  transition:transform var(--transition),box-shadow var(--transition);
  display:flex;flex-direction:column;
}
.car-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.car-card-img-wrap{
  position:relative;
  display:block;
  height:190px;
  background:var(--gray-100);
  overflow:hidden;
}
.car-card-img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition)}
.car-card:hover .car-card-img-wrap img{transform:scale(1.03)}
.car-card-no-photo{
  width:100%;height:100%;
  display:flex;align-items:center;justify-content:center;
  color:var(--gray-400);
}
.car-card-body{padding:1rem;flex:1;display:flex;flex-direction:column;gap:.3rem}
.car-card-title{font-size:1rem;font-weight:700}
.car-card-title a{color:var(--gray-900)}
.car-card-title a:hover{color:var(--blue);text-decoration:none}
.car-card-version{font-size:.8rem;color:var(--gray-600);margin-top:-.2rem}
.car-card-specs{display:flex;align-items:center;gap:.35rem;font-size:.85rem;color:var(--gray-600);flex-wrap:wrap;margin-top:.25rem}
.car-price{font-weight:700;color:var(--blue);font-size:.95rem}
.sep{color:var(--gray-400)}
.car-card-meta{display:flex;align-items:center;gap:.3rem;font-size:.8rem;color:var(--gray-400);margin-top:auto}
.car-card-dealer{font-size:.8rem;font-weight:600;color:var(--gray-600)}

/* Favorite button */
.fav-btn{
  position:absolute;top:.5rem;right:.5rem;
  background:rgba(255,255,255,.9);
  border:none;border-radius:50%;
  width:36px;height:36px;
  display:flex;align-items:center;justify-content:center;
  color:var(--gray-400);
  box-shadow:0 1px 4px rgba(0,0,0,.15);
  transition:all var(--transition);
}
.fav-btn:hover,.fav-btn.is-fav{color:var(--red)}
.fav-btn.is-fav svg{fill:var(--red)}

.fav-btn-lg{
  display:inline-flex;align-items:center;gap:.5rem;
  background:var(--gray-50);border:1px solid var(--gray-200);
  border-radius:var(--radius-sm);padding:.5rem 1rem;
  font-size:.875rem;color:var(--gray-600);
  transition:all var(--transition);
}
.fav-btn-lg:hover,.fav-btn-lg.is-fav{color:var(--red);border-color:var(--red);background:#fff0f1}
.fav-btn-lg.is-fav svg{fill:var(--red)}

/* ============================================================
   SEARCH FILTERS
   ============================================================ */
.search-page{}
.search-filters{margin-bottom:1.5rem}
.filters-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem}
.filters-actions{display:flex;gap:.75rem;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--gray-100)}
.results-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}
.results-count{font-size:.875rem;color:var(--gray-600)}

/* ============================================================
   DETAIL PAGE
   ============================================================ */
.detail-page{display:grid;grid-template-columns:1fr 300px;gap:1.5rem;align-items:start}
.detail-main{}
.carousel{
  position:relative;
  border-radius:var(--radius);
  overflow:hidden;
  background:var(--gray-100);
  aspect-ratio:16/9;
  max-height:480px;
}
.carousel-track{position:relative;width:100%;height:100%}
.carousel-slide{
  position:absolute;inset:0;
  opacity:0;transition:opacity .35s ease;
}
.carousel-slide.active{opacity:1;position:relative}
.carousel-slide img{width:100%;height:100%;object-fit:contain;background:#000}
.car-no-photo-lg{
  width:100%;height:100%;display:flex;align-items:center;justify-content:center;
  color:var(--gray-400);
}
.carousel-btn{
  position:absolute;top:50%;transform:translateY(-50%);
  background:rgba(255,255,255,.85);border:none;border-radius:50%;
  width:42px;height:42px;font-size:1.5rem;line-height:1;
  color:var(--gray-900);box-shadow:var(--shadow);
  transition:all var(--transition);z-index:10;
  display:flex;align-items:center;justify-content:center;
}
.carousel-btn:hover{background:#fff;box-shadow:var(--shadow-lg)}
.carousel-btn.prev{left:.75rem}
.carousel-btn.next{right:.75rem}
.carousel-counter{
  position:absolute;bottom:.5rem;right:.75rem;
  background:rgba(0,0,0,.5);color:#fff;
  font-size:.75rem;padding:.15rem .5rem;border-radius:99px;
}
.carousel-thumbs{display:flex;gap:.5rem;margin-top:.5rem;flex-wrap:wrap}
.thumb{
  width:72px;height:54px;border-radius:var(--radius-sm);
  overflow:hidden;cursor:pointer;border:2px solid transparent;
  transition:border-color var(--transition);flex-shrink:0;
}
.thumb img{width:100%;height:100%;object-fit:cover}
.thumb.active,.thumb:hover{border-color:var(--blue)}

.detail-card{margin-top:1rem}
.detail-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;flex-wrap:wrap;margin-bottom:1.25rem}
.detail-title{font-size:1.5rem;font-weight:800;line-height:1.2}
.detail-version{color:var(--gray-600);font-size:.9rem;margin-top:.25rem}
.detail-price-wrap{text-align:right;flex-shrink:0}
.detail-price{display:block;font-size:2rem;font-weight:800;color:var(--blue);line-height:1}
.specs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;padding:1rem 0;border-top:1px solid var(--gray-100);border-bottom:1px solid var(--gray-100);margin-bottom:1rem}
.spec-item{display:flex;flex-direction:column;gap:.15rem}
.spec-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--gray-400);font-weight:600}
.spec-value{font-size:.95rem;font-weight:600;color:var(--gray-900)}
.detail-description{margin-top:1rem}
.detail-description h3{font-size:.95rem;font-weight:700;margin-bottom:.5rem;color:var(--gray-600)}
.rich-text{font-size:.9rem;line-height:1.8;color:var(--gray-900)}
.rich-text p{margin-bottom:.5rem}
.detail-actions{display:flex;gap:.75rem;margin-top:1rem}

/* Aside */
.detail-aside{display:flex;flex-direction:column;gap:1rem}
.aside-card{padding:1.25rem}
.aside-title{font-size:.8rem;text-transform:uppercase;letter-spacing:.06em;font-weight:700;color:var(--gray-400);margin-bottom:.75rem}
.aside-company{font-weight:700;font-size:1rem;margin-bottom:.35rem}
.aside-meta{font-size:.85rem;color:var(--gray-600);display:flex;align-items:center;gap:.3rem;margin-bottom:.75rem}
.aside-contact{display:flex;align-items:center;gap:.4rem;font-size:.85rem;color:var(--gray-600);margin-bottom:.35rem}
.aside-contact:hover{color:var(--blue)}
.comm-photo{width:56px;height:56px;border-radius:50%;object-fit:cover;margin-bottom:.5rem}

/* ============================================================
   BANNERS
   ============================================================ */
.banner-zone{
  border-radius:var(--radius);overflow:hidden;
  margin-bottom:1.5rem;cursor:pointer;
  background:var(--gray-100);
  min-height:80px;
}
.aside-banner{margin-top:0;min-height:100px}
.banner-slide{display:none}
.banner-slide.active{display:block}
.banner-slide img{width:100%;display:block;border-radius:var(--radius)}
.banner-placeholder{
  min-height:80px;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--blue-dark),var(--blue-light));
  color:#fff;font-weight:600;font-size:.95rem;padding:1rem;
}

/* ============================================================
   EMPTY STATE
   ============================================================ */
.empty-state{
  text-align:center;padding:4rem 2rem;color:var(--gray-400);
}
.empty-state svg{margin:0 auto 1rem;color:var(--gray-200)}
.empty-state h3{font-size:1.1rem;color:var(--gray-600);margin-bottom:.5rem}
.empty-state p{margin-bottom:1rem}
.empty-state a,.empty-state button{margin-top:.5rem}

/* ============================================================
   SECTION HEADER
   ============================================================ */
.section-header{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:1.5rem;flex-wrap:wrap;gap:.75rem;
}
.section-header h2{font-size:1.25rem;font-weight:700}

/* ============================================================
   STATS CARDS (admin dashboard)
   ============================================================ */
.stats-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}
.stat-card{
  background:var(--white);border-radius:var(--radius);border:1px solid var(--gray-200);
  box-shadow:var(--shadow);padding:1.25rem;display:flex;align-items:center;gap:1rem;
}
.stat-icon{width:52px;height:52px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.stat-number{display:block;font-size:1.75rem;font-weight:800;color:var(--gray-900);line-height:1}
.stat-label{font-size:.8rem;color:var(--gray-600)}
.admin-quick-links{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1.5rem}
.stats-grid-admin{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}

/* ============================================================
   USER STATS
   ============================================================ */
.stats-car-card{margin-bottom:1.5rem}
.stats-car-header{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:.75rem;margin-bottom:1rem}
.stats-summary{display:flex;gap:.5rem;flex-wrap:wrap}
.stat-pill{
  display:inline-flex;align-items:center;gap:.3rem;
  padding:.3rem .75rem;border-radius:99px;
  background:var(--gray-100);color:var(--gray-600);
  font-size:.8rem;font-weight:600;
}
.stats-two-cols{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-top:1.25rem}
.stats-two-cols h4{font-size:.85rem;font-weight:700;margin-bottom:.5rem;color:var(--gray-600)}

/* Bar chart (CSS) */
.views-chart{margin:1rem 0;padding:1rem;background:var(--gray-50);border-radius:var(--radius-sm)}
.views-chart h4{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--gray-400);margin-bottom:.75rem}
.bar-chart{display:flex;gap:4px;align-items:flex-end;height:96px;overflow-x:auto}
.bar-wrap{display:flex;flex-direction:column;align-items:center;gap:4px;min-width:28px}
.bar{background:var(--blue);border-radius:3px 3px 0 0;width:20px;min-height:4px;transition:height .4s ease}
.bar-label{font-size:.55rem;color:var(--gray-400);transform:rotate(-45deg);transform-origin:top left;margin-top:4px;white-space:nowrap}

/* KPI */
.kpi-list{display:flex;flex-direction:column;gap:.75rem}
.kpi-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid var(--gray-100)}
.kpi-label{font-size:.875rem;color:var(--gray-600)}
.kpi-value{font-size:1.1rem;font-weight:700;color:var(--blue)}

/* ============================================================
   COMMERCIALS
   ============================================================ */
.commercials-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem}
.commercial-card{padding:1.25rem;text-align:center}
.comm-photo-wrap{margin-bottom:1rem}
.comm-card-photo{width:72px;height:72px;border-radius:50%;object-fit:cover;margin:0 auto}
.comm-card-avatar{
  width:72px;height:72px;border-radius:50%;background:var(--blue);color:#fff;
  display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;margin:0 auto;
}
.comm-card-body h3{font-size:1rem;font-weight:700;margin-bottom:.35rem}
.comm-card-body p{font-size:.85rem;color:var(--gray-600);margin-bottom:.2rem}
.comm-card-actions{display:flex;justify-content:center;gap:.5rem;margin-top:1rem}

/* Logo preview */
.current-logo{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}
.logo-preview{width:80px;height:60px;object-fit:contain;border:1px solid var(--gray-200);border-radius:var(--radius-sm)}

/* ============================================================
   BRANDS LAYOUT
   ============================================================ */
.brands-layout{display:grid;grid-template-columns:1fr 1.5fr;gap:1.25rem;align-items:start}

/* ============================================================
   MODALS
   ============================================================ */
.modal{
  position:fixed;inset:0;z-index:500;
  display:none;align-items:center;justify-content:center;
}
.modal.open{display:flex}
.modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.45)}
.modal-box{
  position:relative;z-index:1;
  background:var(--white);border-radius:var(--radius);
  box-shadow:var(--shadow-lg);
  width:90%;max-width:540px;max-height:90vh;overflow-y:auto;
  padding:1.5rem;
  animation:modalIn .2s cubic-bezier(.4,0,.2,1);
}
.modal-box-lg{max-width:680px}
@keyframes modalIn{from{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:none}}
.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem}
.modal-header h3{font-size:1.1rem;font-weight:700}
.modal-close{background:none;border:none;font-size:1.5rem;line-height:1;color:var(--gray-400);padding:.1rem .25rem}
.modal-close:hover{color:var(--gray-900)}

/* ============================================================
   AUTH
   ============================================================ */
.auth-body{background:var(--gray-100);display:flex;align-items:center;justify-content:center;min-height:100vh}
.auth-wrap{width:100%;padding:1rem}
.auth-card{
  background:var(--white);border-radius:var(--radius);
  box-shadow:var(--shadow-lg);
  max-width:420px;margin:0 auto;padding:2.5rem;
}
.auth-logo{text-align:center;margin-bottom:1.75rem}
.logo-svg{max-width:200px}
.auth-title{font-size:1.25rem;font-weight:700;margin-bottom:1.25rem;text-align:center}
.auth-form{display:flex;flex-direction:column;gap:.5rem}
.auth-note{font-size:.78rem;color:var(--gray-400);text-align:center;margin-top:1.25rem;line-height:1.5}

/* ============================================================
   TEXT UTILS
   ============================================================ */
.text-danger{color:#dc2626;font-weight:600}
.text-warn{color:#d97706;font-weight:600}
.text-muted{color:var(--gray-400);font-size:.875rem;font-style:italic}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1024px){
  .detail-page{grid-template-columns:1fr}
  .detail-aside{grid-row:1}
  .stats-two-cols{grid-template-columns:1fr}
  .brands-layout{grid-template-columns:1fr}
  .stats-grid-admin{grid-template-columns:1fr}
}

@media(max-width:768px){
  :root{--sidebar-w:0px}
  .sidebar{transform:translateX(-260px);width:260px}
  .sidebar.open{transform:translateX(0)}
  .sidebar-overlay.open{display:block}
  .layout-wrap{margin-left:0}
  .burger{display:flex}
  .main-content{padding:1.25rem 1rem}
  .topbar{padding:.6rem 1rem}
  .form-row-2,.form-row-3{grid-template-columns:1fr}
  .filters-grid{grid-template-columns:1fr 1fr}
  .cars-grid{grid-template-columns:1fr}
  .specs-grid{grid-template-columns:1fr 1fr}
  .form-card{padding:1.25rem}
  .topbar-user .user-name span:not(.badge-admin){display:none}
}

@media(max-width:480px){
  .filters-grid{grid-template-columns:1fr}
  .stats-cards{grid-template-columns:1fr}
  .detail-header{flex-direction:column}
  .detail-price-wrap{text-align:left}
  .commercials-grid{grid-template-columns:1fr}
}

