/* Dorset Vans - Main Stylesheet */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{--primary:#1a56db;--primary-dark:#1648c0;--primary-light:#e8effd;--accent:#f59e0b;--accent-dark:#d97706;--dark:#1f2937;--darker:#111827;--gray-50:#f9fafb;--gray-100:#f3f4f6;--gray-200:#e5e7eb;--gray-300:#d1d5db;--gray-400:#9ca3af;--gray-500:#6b7280;--gray-600:#4b5563;--gray-700:#374151;--white:#fff;--shadow-sm:0 1px 2px rgba(0,0,0,.05);--shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -2px rgba(0,0,0,.1);--shadow-lg:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -4px rgba(0,0,0,.1);--radius:8px;--radius-lg:12px}
html{scroll-behavior:smooth}
body{font-family:'Inter',-apple-system,sans-serif;color:var(--gray-700);background:var(--gray-50);line-height:1.6;min-height:100vh;display:flex;flex-direction:column}
main{flex:1}
.container{max-width:1200px;margin:0 auto;padding:0 20px}
a{color:var(--primary);text-decoration:none}
a:hover{color:var(--primary-dark)}
img{max-width:100%;height:auto}

/* Header */
.site-header{background:var(--primary);color:var(--white);position:sticky;top:0;z-index:100;box-shadow:0 2px 10px rgba(0,0,0,.15)}
.header-top{display:flex;align-items:center;justify-content:space-between;padding:15px 0;gap:20px}
.logo{display:flex;align-items:center;gap:10px;color:var(--white);font-weight:800;font-size:1.6rem}
.logo:hover{color:var(--white)}
.logo-icon{font-size:1.8rem}
.logo-accent{color:var(--accent)}
.header-contact{text-align:right;display:none}
.header-phone{color:var(--accent);font-weight:700;font-size:1.2rem;text-decoration:none;display:block}
.header-slogan{font-size:.8rem;color:var(--gray-200)}
.nav-toggle{display:block;background:none;border:2px solid rgba(255,255,255,.3);color:var(--white);font-size:1.5rem;padding:5px 12px;border-radius:var(--radius);cursor:pointer}
.main-nav{display:none;padding:0 0 15px}
.main-nav ul{list-style:none;display:flex;flex-direction:column;gap:2px}
.main-nav a{display:block;padding:10px 15px;color:var(--gray-100);border-radius:var(--radius);font-weight:500}
.main-nav a:hover,.main-nav a.active{background:rgba(255,255,255,.15);color:var(--white)}
.nav-open .main-nav{display:block}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;padding:12px 28px;border-radius:var(--radius);font-weight:600;font-size:.95rem;border:none;cursor:pointer;transition:all .2s;text-decoration:none;gap:8px}
.btn-primary{background:var(--primary);color:var(--white)}
.btn-primary:hover{background:var(--primary-dark);color:var(--white);transform:translateY(-1px)}
.btn-accent{background:var(--accent);color:var(--darker)}
.btn-accent:hover{background:var(--accent-dark);color:var(--darker);transform:translateY(-1px)}
.btn-outline{background:transparent;border:2px solid var(--primary);color:var(--primary)}
.btn-outline:hover{background:var(--primary);color:var(--white)}
.btn-white{background:var(--white);color:var(--primary);font-size:1.05rem;padding:14px 32px}
.btn-white:hover{background:var(--gray-100);transform:translateY(-1px)}
.btn-sm{padding:8px 16px;font-size:.85rem}

/* Sections */
.section{padding:60px 0}
.section-title{text-align:center;font-size:2rem;font-weight:800;color:var(--darker);margin-bottom:10px}
.section-subtitle{text-align:center;color:var(--gray-500);margin-bottom:40px;font-size:1.1rem}

/* Hero */
.hero{background:linear-gradient(135deg,var(--primary) 0%,#0d3a8a 100%);color:var(--white);padding:80px 0;text-align:center}
.hero h1{font-size:2.5rem;font-weight:800;margin-bottom:15px;line-height:1.15}
.hero p{font-size:1.15rem;margin-bottom:30px;color:rgba(255,255,255,.85);max-width:600px;margin-left:auto;margin-right:auto}
.hero-search{background:var(--white);border-radius:var(--radius-lg);padding:20px;display:flex;flex-direction:column;gap:10px;max-width:700px;margin:0 auto;box-shadow:var(--shadow-lg)}
.hero-search select,.hero-search input{padding:12px 16px;border:2px solid var(--gray-200);border-radius:var(--radius);font-size:.95rem;font-family:inherit;background:var(--white);width:100%}
.hero-search .btn{width:100%;padding:14px}

/* Vehicle Cards */
.vehicle-grid{display:grid;grid-template-columns:1fr;gap:24px}
.vehicle-card{background:var(--white);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);transition:transform .2s,box-shadow .2s}
/* Vehicle Cards - fix thumbnail cropping */
.vehicle-card-image{position:relative;aspect-ratio:16/10;overflow:hidden;background:var(--gray-100)}
.vehicle-card-image img{width:100%;height:100%;object-fit:cover}

/* Admin Image Gallery */
.admin-image-gallery{margin-bottom:20px}
.image-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:10px;margin-bottom:10px}
.image-grid-item{position:relative;border:3px solid var(--gray-200);border-radius:8px;overflow:hidden;background:var(--gray-100);aspect-ratio:4/3}
.image-grid-item.is-main{border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-light)}
.image-grid-item img{width:100%;height:100%;object-fit:cover;display:block}
.image-grid-item .img-radio{position:absolute;bottom:4px;left:4px;background:rgba(255,255,255,.9);padding:2px 6px;border-radius:4px;font-size:.7rem;display:flex;align-items:center;gap:3px}
.image-grid-item .img-radio input{margin:0}
.image-grid-item .img-remove{position:absolute;top:2px;right:2px;background:rgba(220,38,38,.9);color:white;width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;text-decoration:none;font-size:.75rem;line-height:1}
.image-grid-item .img-remove:hover{background:#dc2626}
.img-sort-handle{position:absolute;z-index:2;background:rgba(0,0,0,.5);color:white;width:20px;height:16px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:.65rem;line-height:1;border-radius:3px;user-select:none}
.img-sort-handle:first-child{top:2px;left:2px}
.img-sort-handle:nth-child(2){top:20px;left:2px}
.img-sort-handle:hover{background:rgba(0,0,0,.8)}
.image-upload-area input[type=file]{display:none}
#fileCount{font-size:.85rem;color:var(--gray-500)}
.vehicle-card-badge{position:absolute;top:12px;left:12px;background:var(--accent);color:var(--darker);padding:4px 12px;border-radius:20px;font-size:.75rem;font-weight:700}
.vehicle-card-price{position:absolute;bottom:12px;right:12px;background:var(--primary);color:var(--white);padding:6px 14px;border-radius:20px;font-weight:700;font-size:.95rem}
.vehicle-card-body{padding:16px}
.vehicle-card-title{font-size:1.05rem;font-weight:700;color:var(--darker);margin-bottom:10px}
.vehicle-card-specs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}
.vehicle-card-specs span{display:flex;align-items:center;gap:4px;font-size:.82rem;color:var(--gray-500);background:var(--gray-100);padding:4px 10px;border-radius:20px}
.vehicle-card .btn{width:100%}

/* Features List */
.features-grid{display:grid;grid-template-columns:1fr;gap:24px;margin:40px 0}
.feature-card{background:var(--white);padding:30px;border-radius:var(--radius-lg);box-shadow:var(--shadow);text-align:center;border-top:4px solid var(--primary)}
.feature-card-icon{font-size:2.5rem;margin-bottom:15px}
.feature-card h3{font-size:1.2rem;font-weight:700;color:var(--darker);margin-bottom:10px}
.feature-card p{color:var(--gray-500);font-size:.95rem}

/* Vehicle Detail */
.vehicle-detail{padding:40px 0}
.breadcrumb{font-size:.85rem;color:var(--gray-500);margin-bottom:20px}
.breadcrumb a{color:var(--primary)}
.vehicle-header{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:15px;margin-bottom:30px}
.vehicle-header h1{font-size:1.8rem;font-weight:800;color:var(--darker)}
.vehicle-price-tag{font-size:2rem;font-weight:800;color:var(--primary)}
.vehicle-status{display:inline-block;padding:4px 14px;border-radius:20px;font-size:.85rem;font-weight:600}
.vehicle-status.available{background:#dcfce7;color:#166534}
.vehicle-status.sold{background:#fee2e2;color:#991b1b}
.vehicle-status.reserved{background:#fef3c7;color:#92400e}
.vehicle-gallery{margin-bottom:30px;border-radius:var(--radius-lg);overflow:hidden;background:var(--gray-200);aspect-ratio:16/9;position:relative}
.vehicle-gallery img{width:100%;height:100%;object-fit:contain}
.vehicle-thumbs{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:30px}
.vehicle-thumbs img{width:80px;height:60px;object-fit:cover;border-radius:6px;cursor:pointer;border:2px solid transparent;transition:border-color .2s}
.vehicle-thumbs img.active{border-color:var(--primary)}
.vehicle-specs{background:var(--white);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow);margin-bottom:24px}
.vehicle-specs h2{font-size:1.3rem;font-weight:700;color:var(--darker);margin-bottom:20px}
.specs-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.spec-item{padding:10px 0;border-bottom:1px solid var(--gray-100)}
.spec-label{font-size:.82rem;color:var(--gray-500)}
.spec-value{font-weight:600;color:var(--darker)}
.vehicle-desc{background:var(--white);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow);margin-bottom:24px;line-height:1.8;color:var(--gray-600)}
.vehicle-desc h2{font-size:1.3rem;font-weight:700;color:var(--darker);margin-bottom:15px}
.vehicle-features{display:flex;flex-wrap:wrap;gap:10px;margin:15px 0}
.vehicle-features span{background:var(--primary-light);color:var(--primary);padding:6px 16px;border-radius:20px;font-size:.85rem;font-weight:500}
.enquiry-form{background:var(--white);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow)}
.enquiry-form h3{font-size:1.2rem;font-weight:700;color:var(--darker);margin-bottom:20px}
.form-group{margin-bottom:16px}
.form-group label{display:block;font-weight:600;font-size:.9rem;color:var(--gray-700);margin-bottom:5px}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px 14px;border:2px solid var(--gray-200);border-radius:var(--radius);font-size:.95rem;font-family:inherit;transition:border-color .2s}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary)}
.form-group textarea{min-height:120px;resize:vertical}

/* About / Contact Pages */
.page-hero{background:linear-gradient(135deg,var(--primary) 0%,#0d3a8a 100%);color:var(--white);padding:60px 0;text-align:center}
.page-hero h1{font-size:2.2rem;font-weight:800;margin-bottom:10px}
.page-content{padding:50px 0}
.content-block{background:var(--white);border-radius:var(--radius-lg);padding:40px;box-shadow:var(--shadow)}
.content-block h2{font-size:1.5rem;font-weight:700;color:var(--darker);margin-bottom:15px}
.content-block p{color:var(--gray-600);margin-bottom:15px;line-height:1.8}
.content-block ul{list-style:none;padding:0}
.content-block ul li{padding:8px 0;padding-left:24px;position:relative;color:var(--gray-600)}
.content-block ul li::before{content:'✓';position:absolute;left:0;color:var(--primary);font-weight:700}
.contact-details{display:grid;grid-template-columns:1fr;gap:20px;margin:30px 0}
.contact-item{display:flex;align-items:flex-start;gap:15px;padding:20px;background:var(--gray-50);border-radius:var(--radius)}
.contact-icon{font-size:1.5rem;flex-shrink:0}

/* Filters Sidebar */
.filter-section{background:var(--white);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow);margin-bottom:24px}
.filter-section h3{font-size:1rem;font-weight:700;color:var(--darker);margin-bottom:15px}
.filter-group{margin-bottom:15px}
.filter-group label{display:block;font-weight:500;font-size:.85rem;color:var(--gray-600);margin-bottom:4px}
.filter-group select,.filter-group input{width:100%;padding:10px 12px;border:2px solid var(--gray-200);border-radius:var(--radius);font-size:.9rem;font-family:inherit}
.filter-actions{display:flex;gap:10px}
.filter-actions .btn{flex:1}

/* Pagination */
.pagination{display:flex;justify-content:center;gap:8px;margin:40px 0}
.pagination a,.pagination span{padding:10px 16px;border-radius:var(--radius);font-weight:500;transition:all .2s}
.pagination a{background:var(--white);color:var(--gray-700);box-shadow:var(--shadow-sm)}
.pagination a:hover{background:var(--primary);color:var(--white)}
.pagination .active{background:var(--primary);color:var(--white)}

/* Footer */
.site-footer{background:var(--dark);color:var(--gray-300);padding:50px 0 20px;margin-top:auto}
.footer-grid{display:grid;grid-template-columns:1fr;gap:30px;margin-bottom:30px}
.footer-col h3{color:var(--white);font-size:1.1rem;font-weight:700;margin-bottom:15px}
.footer-col p{font-size:.9rem;line-height:1.7}
.footer-col ul{list-style:none}
.footer-col ul li{margin-bottom:8px}
.footer-col a{color:var(--gray-300)}.footer-col a:hover{color:var(--accent)}
.footer-contact li{font-size:.9rem}
.footer-bottom{border-top:1px solid var(--gray-700);padding-top:20px;text-align:center;font-size:.85rem;color:var(--gray-500)}

/* Empty state */
.empty-state{text-align:center;padding:60px 20px}
.empty-state-icon{font-size:4rem;margin-bottom:15px}
.empty-state h3{font-size:1.3rem;font-weight:700;color:var(--darker);margin-bottom:10px}
.empty-state p{color:var(--gray-500)}

/* Messages */
.alert{padding:16px;border-radius:var(--radius);margin-bottom:20px;font-weight:500}
.alert-success{background:#dcfce7;color:#166534;border:1px solid #bbf7d0}
.alert-error{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}

/* Admin Styles */
.admin-body{background:var(--gray-100);font-family:'Inter',sans-serif}
.admin-login{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px}
.admin-login-box{background:var(--white);padding:40px;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:400px}
.admin-login-box h1{text-align:center;margin-bottom:30px;color:var(--darker);font-size:1.5rem}
.admin-login-box .logo{display:flex;justify-content:center;margin-bottom:20px;color:var(--primary);font-size:1.8rem;font-weight:800}
.admin-header{background:var(--darker);color:var(--white);padding:15px 0}
.admin-header .container{display:flex;justify-content:space-between;align-items:center}
.admin-header a{color:var(--gray-300)}.admin-header a:hover{color:var(--white)}
.admin-dashboard{padding:30px 0}
.admin-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px;margin-bottom:30px}
.admin-stat-card{background:var(--white);padding:20px;border-radius:var(--radius);box-shadow:var(--shadow-sm);text-align:center}
.admin-stat-card h3{font-size:.85rem;color:var(--gray-500);font-weight:600}
.admin-stat-card .number{font-size:2rem;font-weight:800;color:var(--darker)}
.admin-table{width:100%;background:var(--white);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm)}
.admin-table th,.admin-table td{padding:12px 16px;text-align:left;font-size:.9rem}
.admin-table th{background:var(--gray-50);font-weight:700;color:var(--gray-600)}
.admin-table tr{border-bottom:1px solid var(--gray-100)}
.admin-table tr:last-child{border-bottom:none}
.admin-actions{display:flex;gap:6px}
.btn-danger{background:#dc2626;color:var(--white)}.btn-danger:hover{background:#b91c1c;color:var(--white)}
.btn-success{background:#16a34a;color:var(--white)}.btn-success:hover{background:#15803d;color:var(--white)}
.admin-form{background:var(--white);padding:30px;border-radius:var(--radius-lg);box-shadow:var(--shadow)}
.admin-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.admin-form h2{font-size:1.3rem;margin-bottom:20px}

/* Responsive */
@media(min-width:640px){
  .vehicle-grid{grid-template-columns:repeat(2,1fr)}
  .features-grid{grid-template-columns:repeat(2,1fr)}
  .hero h1{font-size:3rem}
  .hero-search{flex-direction:row;padding:16px}
  .hero-search select,.hero-search input{flex:1}
  .hero-search .btn{width:auto;flex-shrink:0}
  .contact-details{grid-template-columns:repeat(2,1fr)}
}
@media(min-width:768px){
  .header-contact{display:block}
  .nav-toggle{display:none}
  .main-nav{display:block !important;padding:0 0 5px}
  .main-nav ul{flex-direction:row;gap:4px}
  .main-nav a{padding:8px 16px;font-size:.9rem}
  .specs-grid{grid-template-columns:1fr 1fr 1fr}
  .footer-grid{grid-template-columns:repeat(3,1fr)}
}
@media(min-width:1024px){
  .vehicle-grid{grid-template-columns:repeat(3,1fr)}
  .features-grid{grid-template-columns:repeat(3,1fr)}
  .hero{padding:100px 0}
  .listings-layout{display:grid;grid-template-columns:300px 1fr;gap:30px;align-items:start}
}
