/*
Theme Name: Petland Largo Florida 2025
Author: Cosmick Media
Version: 1.0.1
Requires at least: 6.0
Tested up to: 6.6
Text Domain: petland-florida-2025
*/

:root{
  --primary:#D45224;
  --primary-dark:#B3451E;
  --secondary:#FC8F04;
  --secondary-dark:#E67E00;
  --dark-gray:#45515D;
  --ink:#212529;
  --muted:#F5F5F5;
  --white:#FFFFFF;
  --btn-hover:#B3451E;
  --container-max:1350px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:"Lato",system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--ink);
  background:#fff;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

.container-max{max-width:var(--container-max);margin-inline:auto;padding-inline:16px}

a{color:var(--primary);text-decoration:none}
a:focus-visible,button:focus-visible{outline:2px solid var(--dark-gray);outline-offset:2px}

/* Buttons (Bootstrap-compatible helpers) */
.btn-square{border-radius:1px !important}
.btn-primary{background:var(--primary) !important;border-color:var(--primary) !important}
.btn-primary:hover{background:var(--btn-hover) !important;border-color:var(--btn-hover) !important}
.btn-darkgray{background:var(--dark-gray) !important;border-color:var(--dark-gray) !important;color:#fff !important}

/* Header */
.site-header{position:sticky;top:0;z-index:1040;background:#fff;box-shadow:0 2px 8px rgba(0,0,0,.06);border-bottom:1px solid #ccc}
.site-header .navbar{min-height:70px;padding-top:0;padding-bottom:0}
.site-header .container-max{display:flex;align-items:center;justify-content:space-between;width:1350px}
@media (max-width: 992px) {
  .site-header .container-max{width:100%;max-width:100%}
}
.site-header .navbar-brand{margin-right:0;padding:0}
.site-header .navbar-brand img{height:32px;display:block}
.site-header .navbar-nav{margin:0;align-items:center;gap:8px}
.site-header .nav-link{padding:.5rem 1rem;font-weight:600;position:relative}

/* Desktop: Center navigation */
@media (min-width: 993px) {
  .site-header .navbar-collapse{flex-grow:0;position:absolute;left:50%;transform:translateX(-50%)}
}

/* Active page indicator */
.site-header .nav-item.current-menu-item > .nav-link::after,
.site-header .nav-item.current_page_item > .nav-link::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 30px;
  height: 2px;
  background: var(--primary);
}

/* Mobile menu styling */
@media (max-width: 992px) {
  .site-header .container-max{
    flex-wrap:wrap;
  }
  .site-header .navbar-collapse{
    position:absolute;
    top:70px;
    left:0;
    right:0;
    background:#fff;
    box-shadow:0 4px 12px rgba(0,0,0,.08);
    margin:0;
    padding:16px;
  }
  .site-header .navbar-nav{
    flex-direction:column;
    align-items:stretch;
    gap:2px;
    margin:0;
  }
  .site-header .nav-item{
    width:100%;
  }
  .site-header .nav-link{
    display:block;
    padding:14px 16px;
    width:100%;
    border-radius:6px;
    font-weight:500;
    transition:background .15s ease;
  }
  .site-header .nav-link:hover,
  .site-header .nav-link:active{
    background:var(--muted);
    color:var(--primary);
  }
  .site-header .dropdown-menu{
    position:static;
    border:none;
    box-shadow:none;
    padding-left:16px;
    background:transparent;
  }
  .site-header .dropdown-item{
    padding:10px 16px;
    border-radius:4px;
    font-size:.95rem;
  }
  .site-header .dropdown-item:hover,
  .site-header .dropdown-item:active,
  .site-header .dropdown-item:focus{
    background:var(--primary);
    color:#fff;
  }
}

/* Footer */
.site-footer{background:#fff;border-top:1px solid #EDEDED;margin-top:32px}
.site-footer .footer-bottom{border-top:1px solid #EDEDED;color:#6c757d}

/* === HOMEPAGE SECTIONS === */
.hero {
  position: relative;
  color: #fff;
  background: #000; /* fallback */
}
.hero__media {
  position: relative;
  overflow: hidden;
}
.hero__media::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0);
  pointer-events: none;
}
@media (max-width: 768px) {
  .hero__media::after {
    background: rgba(0, 0, 0, 0.4);
  }
}
.hero__media img {
  width: 100%;
  height: 56vw;          /* responsive; capped below */
  max-height: 560px;
  object-fit: cover;
  object-position: center;
  display: block;
}
@media (max-width: 768px) {
  .hero__media img {
    height: 45vh;
    max-height: 45vh;
    object-position: left center;
  }
  .hero__inner {
    padding: 40px 16px;
  }
}
.hero__inner {
  position: absolute;
  top: 50%;
  left: 0;
  right: 0;
  transform: translateY(-50%);
}
@media (max-width: 992px) {
  .hero__inner { padding: 0 16px; }
}
.hero h1 {
  font-weight: 900;
  font-size: clamp(2rem, 3.6vw, 3.7rem);
  line-height: 1.1;
  margin: 0 0 1rem;
  text-align: left;
}
@media (max-width: 768px) {
  .hero h1 {
    font-size: 3rem;
  }
}
.hero p {
  margin: 0 0 1.5rem;
  text-align: left;
  font-size: 1.125rem;
}

/* Reservation Card */
.reservation { padding: 40px 0; }
.reservation__card {
  background: var(--muted);
  border: 1px solid #ececec;
  border-radius: 6px;
  padding: 40px;
}
@media (max-width: 768px) {
  .reservation__card {
    padding: 24px 16px;
  }
}
.reservation .eyebrow {
  text-transform: uppercase;
  letter-spacing: .18em;
  color: var(--dark-gray);
  margin: 0 0 8px;
  font-weight: 700;
  font-size: 16px;
}
.reservation h2 {
  margin: 0 0 10px;
  font-size: clamp(2rem, 3vw, 3rem);
  line-height: 1.12;
  color: var(--ink);
  font-weight: 900;
}
.reservation p { margin: 0 0 16px; }

/* Tiles */
.tiles { padding: 24px 0 48px; }
.tiles__grid {
  display: grid;
  gap: 8px;
  grid-template-columns: 1fr;
}
@media (min-width: 768px) {
  .tiles__grid { grid-template-columns: repeat(3, 1fr); }
}
.tile {
  position: relative;
  display: block;
  overflow: hidden;
  border-radius: 4px;
}
.tile img {
  width: 100%;
  height: 280px;
  object-fit: cover;
  object-position: center;
  display: block;
  transform: scale(1);
  transition: transform .25s ease;
}
.tile:hover img { transform: scale(1.06); }
.tile__label {
  position: absolute;
  left: 14px;
  bottom: 14px;
  color: #fff;
  font-weight: 900;
  letter-spacing: .28em;
  font-size: 2.0rem;
  text-transform: uppercase;
  text-shadow: 0 4px 13px rgba(0, 0, 0, 3.5);
}
@media (max-width: 768px) {
  .tile__label {
    font-size: 1.5rem;
    left: 12px;
    bottom: 12px;
  }
}

/* Button helpers */
.btn-square { border-radius: 1px !important; }
.btn-darkgray { background: var(--dark-gray) !important; border-color: var(--dark-gray) !important; color: #fff !important; }

/* Utility */
.section-pad { padding: 40px 0; }

/* Skip link helper (a11y) */
.visually-hidden-focusable {
  position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden;
}
.visually-hidden-focusable:focus {
  position:static;width:auto;height:auto;margin:8px;z-index:1050;display:inline-block;
  background:#fff;border:2px solid var(--dark-gray);padding:6px 10px;border-radius:4px;
}

/* Footer refinements */
.site-footer h6{letter-spacing:.12em}
.site-footer address{line-height:1.4}
.footer-bottom small{color:#6c757d}
.link-underline{text-decoration:underline}
.not-italic{font-style:normal}
.footer-social{display:flex;gap:10px;flex-wrap:wrap}
.footer-social a{font-size:1.25rem;color:var(--ink);text-decoration:none;transition:color .2s ease}
.footer-social a:hover{color:var(--primary)}

/* Keep Bootstrap toggler visible on light header */
.navbar-light .navbar-toggler-icon{ background-image: var(--bs-navbar-toggler-icon-bg); }

/* Better address line-height */
address{line-height:1.5}

/* Subtle image rounding in tiles (matches brand) */
.tile{border-radius:4px;overflow:hidden}

/* Reduce padding on default page template (not homepage) */
body:not(.home) .py-5{
  padding-top:1rem !important;
  padding-bottom:1rem !important;
}

/* Header Location Info */
.header-location {
  display: flex;
  align-items: center;
  margin-left: auto;
  padding-left: 2rem;
}

.header-location__link {
  display: flex;
  align-items: center;
  text-decoration: none;
  color: var(--ink);
  transition: all 0.2s ease;
  padding: 8px 16px;
  border-radius: 8px;
}

.header-location__link:hover {
  background: var(--muted);
}

.header-location__link:hover .header-location__phone {
  color: var(--primary);
}

.header-location__icon-mobile {
  display: none;
}

.header-location__details {
  display: flex;
  flex-direction: column;
  gap: 2px;
  text-align: right;
}

.header-location__name {
  font-weight: 700;
  font-size: 0.875rem;
  color: var(--ink);
  line-height: 1.2;
}

.header-location__address {
  font-size: 0.75rem;
  color: var(--dark-gray);
  line-height: 1.2;
  text-decoration: none;
  transition: color 0.2s ease;
}

.header-location__address:hover {
  color: var(--primary);
  text-decoration: underline;
}

.header-location__phone {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--ink);
  line-height: 1.2;
  display: flex;
  align-items: center;
  gap: 6px;
  justify-content: flex-end;
  text-decoration: none;
  transition: color 0.2s ease;
}

.header-location__phone:hover {
  color: var(--primary);
}

.header-location__icon-mobile-link {
  text-decoration: none;
}

.header-location__phone i {
  font-size: 0.875rem;
  color: var(--primary);
}

/* Mobile Layout */
@media (max-width: 992px) {
  .site-header .container-max {
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
  }

  .site-header .navbar-toggler {
    order: 1;
  }

  .site-header .navbar-brand {
    order: 2;
    margin: 0 auto;
  }

  .header-location {
    order: 3;
    margin-left: 0;
    padding-left: 0;
  }

  .header-location__link {
    padding: 8px;
  }

  .header-location__details {
    display: none;
  }

  .header-location__icon-mobile {
    display: block;
    font-size: 1.5rem;
    color: var(--primary);
  }
}
