/*
Theme Name: Bates Auction Modern
Theme URI: https://www.batesauctionandrealty.com
Author: Bates Auction & Realty
Description: Modern dark-hero theme for Bates Auction & Realty. Inter font, blue accents, Owl Carousel banner.
Version: 2.0.0
License: GNU General Public License v2 or later
Text Domain: bates-theme
*/

/* ==========================================================================
   VARIABLES
   ========================================================================== */
:root {
  --blue: #2563EB;
  --blue-dark: #1D4ED8;
  --blue-light: #60A5FA;
  --blue-bg: #EFF6FF;
  --dark: #0B1120;
  --dark-deeper: #050A14;
  --body-bg: #FAFAFA;
  --card-bg: #ffffff;
  --text: #111111;
  --text-muted: #888888;
  --text-light: #999999;
  --border: #eeeeee;
  --srv-bg: #f4f4f5;
  --green: #22C55E;
  --container: 1200px;
}

/* ==========================================================================
   RESET & BASE
   ========================================================================== */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;background:var(--body-bg);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit;transition:color 0.3s,border-color 0.3s,background 0.3s,opacity 0.3s}
img{max-width:100%;height:auto;display:block}
ul,ol{list-style:none}
.container{max-width:var(--container);margin:0 auto;padding:0 60px}

/* ==========================================================================
   HEADER - transparent over hero
   ========================================================================== */
.site-header{
  position:absolute;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 60px;height:72px;
  background:rgba(0,0,0,0.6);backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(255,255,255,0.06);
}
.site-logo{display:flex;align-items:center;gap:12px;text-decoration:none}
.logo-mark{width:36px;height:36px;background:var(--blue);border-radius:8px;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:16px;color:#fff}
.logo-text{font-size:18px;font-weight:800;color:#fff;letter-spacing:-0.3px}
.logo-text span{color:var(--blue)}
/* Custom logo image */
.site-logo .custom-logo-link{display:flex;align-items:center}
.site-logo .custom-logo-link img{max-height:44px;width:auto}

/* Nav - WordPress ul>li>a structure */
.main-nav{display:flex;align-items:center;gap:24px}
.main-nav .nav-menu{display:flex;gap:24px;align-items:center;list-style:none;margin:0;padding:0}
.main-nav .nav-menu li{list-style:none}
.main-nav .nav-menu li a{color:rgba(255,255,255,0.55);font-size:13px;font-weight:500;letter-spacing:0.5px}
.main-nav .nav-menu li a:hover,
.main-nav .nav-menu li.current-menu-item a,
.main-nav .nav-menu li.current_page_item a{color:#fff}
.main-nav .nav-menu li .sub-menu{display:none}

.nav-right{display:flex;gap:14px;align-items:center}
.nav-phone{color:rgba(255,255,255,0.7);font-size:13px;font-weight:600}
.nav-cta{background:var(--blue);color:#fff !important;padding:10px 22px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:1px;border-radius:6px}
.nav-cta:hover{background:var(--blue-dark)}

/* Mobile toggle */
.menu-toggle{display:none;background:none;border:none;color:#fff;font-size:28px;cursor:pointer}

/* ==========================================================================
   HERO BANNER / OWL CAROUSEL
   ========================================================================== */
.hero-banner{position:relative;background:var(--dark);overflow:hidden}
.hero-slide{position:relative;height:650px;display:flex;align-items:center;overflow:hidden}
.hero-slide-bg{position:absolute;inset:0;background-size:cover;background-position:center}
.hero-slide-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,rgba(11,17,32,0.9),rgba(11,17,32,0.5) 50%,rgba(11,17,32,0.3))}
/* Fallback when no image */
.hero-slide-bg.no-img{background:linear-gradient(160deg,#0B1120,#162240,#0d1a30)}
.hero-slide-content{position:relative;z-index:2;padding:0 60px;max-width:700px}
.hero-tag{display:inline-flex;align-items:center;gap:8px;padding:7px 16px;background:rgba(37,99,235,0.1);border:1px solid rgba(37,99,235,0.2);border-radius:50px;font-size:11px;font-weight:700;color:var(--blue-light);text-transform:uppercase;letter-spacing:2px;margin-bottom:28px}
.hero-tag .live-dot{width:8px;height:8px;border-radius:50%;background:var(--green)}
.hero-slide-content h2{font-size:72px;font-weight:900;line-height:0.92;letter-spacing:-3px;color:#fff;margin-bottom:24px;text-transform:uppercase}
.hero-slide-content h2 em{font-style:normal;color:var(--blue)}
.hero-slide-content p{font-size:17px;color:rgba(255,255,255,0.45);line-height:1.7;margin-bottom:36px;max-width:500px}
.hero-btns{display:flex;gap:12px;flex-wrap:wrap}
.btn-fill{display:inline-block;background:var(--blue);color:#fff;padding:16px 34px;font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:1px;border-radius:6px}
.btn-fill:hover{background:var(--blue-dark);color:#fff}
.btn-out{display:inline-block;border:1px solid rgba(255,255,255,0.15);color:#fff;padding:16px 34px;font-size:14px;font-weight:600;letter-spacing:1px;border-radius:6px}
.btn-out:hover{border-color:var(--blue);color:var(--blue)}

/* Owl nav/dots */
.hero-banner .owl-nav{position:absolute;bottom:36px;right:60px;display:flex;gap:8px;z-index:3}
.hero-banner .owl-nav button{width:40px;height:40px;border:1px solid rgba(255,255,255,0.12)!important;background:transparent!important;color:#fff!important;font-size:18px!important;border-radius:6px;display:flex;align-items:center;justify-content:center}
.hero-banner .owl-nav button:hover{border-color:var(--blue)!important}
.hero-banner .owl-dots{position:absolute;bottom:44px;right:170px;display:flex;gap:6px;z-index:3}
.hero-banner .owl-dots .owl-dot span{width:36px;height:3px;border-radius:2px;background:rgba(255,255,255,0.12);display:block;transition:background 0.3s}
.hero-banner .owl-dots .owl-dot.active span{background:var(--blue)}

/* ==========================================================================
   TICKER BAR
   ========================================================================== */
.ticker{background:var(--blue);padding:13px 0;overflow:hidden;white-space:nowrap}
.ticker-track{display:inline-block;animation:ticker-scroll 22s linear infinite}
.ticker-track span{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:#fff;margin-right:50px}
@keyframes ticker-scroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ==========================================================================
   SECTIONS
   ========================================================================== */
.section{padding:90px 0}
.sec-label{font-size:11px;font-weight:700;color:var(--blue);text-transform:uppercase;letter-spacing:3px;margin-bottom:14px;text-align:center}
.sec-title{font-size:40px;font-weight:800;letter-spacing:-1px;text-align:center;margin-bottom:10px}
.sec-subtitle{font-size:16px;color:var(--text-muted);text-align:center;margin-bottom:56px}

/* ==========================================================================
   AUCTION CARDS
   ========================================================================== */
.auction-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.auction-card{background:var(--card-bg);border:1px solid var(--border);border-radius:12px;overflow:hidden;transition:box-shadow 0.3s,transform 0.3s}
.auction-card:hover{box-shadow:0 12px 40px rgba(0,0,0,0.08);transform:translateY(-2px)}
.auction-card-img{height:190px;position:relative;background:linear-gradient(135deg,#e4eaf2,#d4dce8);overflow:hidden}
.auction-card-img img{width:100%;height:100%;object-fit:cover}
.auction-badge{position:absolute;top:12px;left:12px;background:var(--blue);color:#fff;padding:5px 12px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;border-radius:50px}
.auction-badge.live{background:#111}
.auction-card-body{padding:22px}
.auction-card-date{font-size:12px;font-weight:700;color:var(--blue);margin-bottom:6px;letter-spacing:0.5px}
.auction-card-body h3{font-size:18px;font-weight:700;margin-bottom:6px;letter-spacing:-0.2px}
.auction-card-body h3 a{color:var(--text)}.auction-card-body h3 a:hover{color:var(--blue)}
.auction-card-body p{font-size:13px;color:var(--text-light);line-height:1.5;margin-bottom:14px}
.auction-link{color:var(--blue);font-size:13px;font-weight:600}

/* ==========================================================================
   SERVICES
   ========================================================================== */
.services-section{background:var(--srv-bg)}
.srv-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.srv-card{background:var(--card-bg);border:1px solid var(--border);border-radius:12px;padding:32px;display:flex;gap:22px;align-items:flex-start;transition:border-color 0.3s}
.srv-card:hover{border-color:var(--blue)}
.srv-icon{width:52px;height:52px;min-width:52px;border-radius:10px;background:linear-gradient(135deg,var(--blue),var(--blue-dark));display:flex;align-items:center;justify-content:center;font-size:22px}
.srv-card h4{font-size:16px;font-weight:700;margin-bottom:6px;letter-spacing:-0.2px}
.srv-card p{font-size:14px;color:var(--text-muted);line-height:1.5}

/* ==========================================================================
   FAQ
   ========================================================================== */
.faq-list{max-width:800px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.faq-item{background:var(--card-bg);border:1px solid var(--border);border-radius:10px;padding:24px 28px}
.faq-item h4{font-size:15px;font-weight:700;margin-bottom:8px;display:flex;gap:10px}
.faq-item h4 .q-mark{color:var(--blue);font-weight:800}
.faq-item p{font-size:14px;color:#777;line-height:1.6;padding-left:26px}

/* ==========================================================================
   NEWSLETTER
   ========================================================================== */
.newsletter-section{background:var(--dark);color:#fff;text-align:center}
.newsletter-section .sec-title{color:#fff}
.newsletter-section .sec-subtitle{color:rgba(255,255,255,0.4)}
.nl-form{display:flex;gap:0;max-width:500px;margin:0 auto}
.nl-form input[type="email"]{flex:1;padding:16px 20px;background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.1);border-right:none;border-radius:8px 0 0 8px;color:#fff;font-size:15px;font-family:'Inter',sans-serif}
.nl-form input[type="email"]::placeholder{color:rgba(255,255,255,0.3)}
.nl-form input[type="email"]:focus{outline:none;border-color:var(--blue)}
.nl-form button{padding:16px 26px;background:var(--blue);color:#fff;border:1px solid var(--blue);border-radius:0 8px 8px 0;font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:1px;cursor:pointer;font-family:'Inter',sans-serif}
.nl-form button:hover{background:var(--blue-dark)}

/* ==========================================================================
   FOOTER
   ========================================================================== */
.site-footer{background:var(--dark-deeper);color:#fff;padding:60px 60px 30px}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:50px;max-width:var(--container);margin:0 auto 50px}
.footer-brand h4{font-size:18px;font-weight:800;margin-bottom:14px}
.footer-brand h4 span{color:var(--blue)}
.footer-brand p{color:rgba(255,255,255,0.3);font-size:14px;line-height:1.8}
.footer-col h5{font-size:11px;text-transform:uppercase;letter-spacing:2px;color:var(--blue);margin-bottom:18px;font-weight:700}
.footer-col a{display:block;color:rgba(255,255,255,0.3);font-size:14px;margin-bottom:10px}
.footer-col a:hover{color:var(--blue)}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.04);padding-top:20px;display:flex;justify-content:space-between;font-size:12px;color:rgba(255,255,255,0.15);max-width:var(--container);margin:0 auto}

/* ==========================================================================
   SINGLE PAGES
   ========================================================================== */
.page-header{background:var(--dark);padding:120px 0 60px;text-align:center}
.page-header h1{font-size:48px;font-weight:800;color:#fff;letter-spacing:-1px}
.page-content{max-width:800px;margin:0 auto;padding:60px 40px}
.page-content h2{font-size:28px;font-weight:800;margin:32px 0 16px;letter-spacing:-0.5px}
.page-content p{margin-bottom:16px;line-height:1.7;color:#555}

.single-auction-header{background:var(--dark);padding:120px 0 60px;text-align:center}
.single-auction-header h1{font-size:44px;font-weight:800;color:#fff;letter-spacing:-1px;margin-bottom:10px}
.single-auction-meta{color:rgba(255,255,255,0.5);font-size:15px}
.single-auction-content{max-width:800px;margin:0 auto;padding:60px 40px}
.single-auction-content img{border-radius:12px;margin-bottom:24px}

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */
@media(max-width:1024px){
  .site-header{padding:0 30px}
  .hero-slide-content{padding:0 30px}
  .hero-slide-content h2{font-size:52px}
  .auction-grid{grid-template-columns:1fr 1fr}
  .srv-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .container{padding:0 30px}
}
@media(max-width:768px){
  .menu-toggle{display:block}
  .main-nav{display:none;position:absolute;top:72px;left:0;right:0;background:rgba(0,0,0,0.95);flex-direction:column;padding:20px 30px;gap:0;border-top:1px solid rgba(255,255,255,0.06)}
  .main-nav.active{display:flex}
  .main-nav .nav-menu{flex-direction:column;gap:16px;width:100%}
  .nav-right{gap:10px}
  .nav-phone{display:none}
  .hero-slide{height:500px}
  .hero-slide-content h2{font-size:38px;letter-spacing:-1.5px}
  .hero-slide-content{padding:0 20px}
  .auction-grid{grid-template-columns:1fr}
  .faq-list{padding:0 20px}
  .nl-form{flex-direction:column;padding:0 20px}
  .nl-form input[type="email"]{border-right:1px solid rgba(255,255,255,0.1);border-radius:8px;margin-bottom:10px}
  .nl-form button{border-radius:8px}
  .site-footer{padding:40px 20px 20px}
  .footer-grid{grid-template-columns:1fr;gap:30px}
  .footer-bottom{flex-direction:column;gap:8px;text-align:center}
  .section{padding:60px 0}
  .sec-title{font-size:30px}
  .container{padding:0 20px}
}
