:root{
  --ink:#12323a;
  --muted:#5e7379;
  --sand:#fff8ed;
  --sand-2:#f3e7d2;
  --aqua:#00a6a6;
  --aqua-dark:#007f87;
  --sea:#0a6c74;
  --sun:#f6b94b;
  --coral:#ff6b4a;
  --card:#ffffff;
  --line:#d7e5e7;
  --shadow:0 18px 55px rgba(7,54,62,.15);
  --radius:24px;
  --radius-sm:16px;
}
*{box-sizing:border-box}
body{
  margin:0;
  font-family:'Montserrat', sans-serif;
  color:var(--ink);
  background:
    radial-gradient(circle at 10% 0%, rgba(246,185,75,.28), transparent 28%),
    radial-gradient(circle at 90% 4%, rgba(0,166,166,.22), transparent 26%),
    linear-gradient(180deg,#fbfffd 0%,#fff8ed 44%,#f7fbfa 100%);
  background-attachment: fixed;
  min-height:100vh;
  line-height:1.5;
}
a{color:inherit}
.wrap{width:min(1180px,92vw); margin-inline:auto}
.topbar{
  position:sticky; top:0; z-index:20;
  backdrop-filter:blur(14px);
  background:rgba(255,255,255,.78);
  border-bottom:1px solid rgba(18,50,58,.08);
}
.nav{display:flex; align-items:center; justify-content:space-between; gap:16px; padding:14px 0}
.brand{display:flex; align-items:center; gap:12px; text-decoration:none; font-weight:800; letter-spacing:.2px}
.mark{width:40px; height:40px; border-radius:14px; display:grid; place-items:center; background:linear-gradient(135deg,var(--aqua),var(--sun)); color:#fff; box-shadow:0 10px 22px rgba(0,127,135,.25)}
.navlinks{display:flex; gap:18px; font-size:.94rem; color:var(--muted)}
.navlinks a{text-decoration:none}
.pill{border:1px solid var(--line); border-radius:999px; padding:9px 13px; background:#fff}
.hero{padding:90px 0 70px; position:relative; overflow:hidden}
.hero-grid{display:grid; grid-template-columns:1.05fr .95fr; align-items:center; gap:42px}
.eyebrow{display:inline-flex; gap:8px; align-items:center; border:1px solid rgba(0,166,166,.25); color:var(--sea); background:rgba(255,255,255,.7); padding:8px 12px; border-radius:999px; font-weight:700; font-size:.88rem}
h1,h2,h3,h4,h5,h6{font-family:'Poppins', sans-serif}
h1{font-size:clamp(2.35rem,6vw,4.5rem); line-height:1.08; margin:24px 0 24px; font-weight:800}
.lead{font-size:1.15rem; color:var(--muted); max-width:650px}
.hero-actions{display:flex; flex-wrap:wrap; gap:12px; margin-top:28px}
.btn{display:inline-flex; align-items:center; justify-content:center; gap:9px; border:none; cursor:pointer; text-decoration:none; font-weight:800; border-radius:999px; padding:13px 18px; transition:.18s transform,.18s box-shadow,.18s background; white-space:nowrap}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:var(--ink); color:#fff}
.btn-aqua{background:var(--aqua); color:#fff; }
.btn-soft{background:#fff; color:var(--ink); border:1px solid var(--line)}
.btn-sun{background:var(--sun); color:var(--ink); }
.btn-coral{background:var(--coral); color:#fff; }
.btn-sea{background:var(--sea); color:#fff; }
.hero-card{position:relative; border-radius:34px; background:linear-gradient(150deg,rgba(255,255,255,.96),rgba(255,248,237,.94)); box-shadow:var(--shadow); padding:24px; overflow:hidden; border:1px solid rgba(255,255,255,.7)}
.hero-card:before{content:""; position:absolute; inset:-40% -20% auto auto; width:260px; height:260px; background:radial-gradient(circle,rgba(0,166,166,.2),transparent 68%); border-radius:50%}
.phone{position:relative; border:10px solid #102f37; border-radius:32px; background:#fff; padding:16px; box-shadow:0 25px 60px rgba(18,50,58,.25); max-width:360px; margin:auto}
.phone-top{height:17px; width:92px; background:#102f37; border-radius:0 0 18px 18px; margin:-16px auto 14px}
.mini-hero{border-radius:22px; min-height:180px; background:linear-gradient(135deg,rgba(0,166,166,.9),rgba(246,185,75,.9)), url('https://www.hollywoodfl.org/ImageRepository/Document?documentID=24326') center/cover; padding:18px; color:white; display:flex; align-items:flex-end}
.mini-hero h3{margin:0; font-size:1.55rem; line-height:1}
.mini-row{display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-top:12px}
.mini-card{border:1px solid var(--line); border-radius:16px; padding:13px; background:#fff}
.mini-card strong{display:block}
.mini-card span{font-size:.83rem; color:var(--muted)}
section{padding:80px 0}
.section-head{display:flex; justify-content:space-between; align-items:end; gap:22px; margin-bottom:42px}
.section-head h2{font-size:clamp(1.8rem,4vw,3rem); letter-spacing:-.04em; margin:0 0 4px; line-height:1; font-weight:800; position:relative; padding-bottom:16px}
.section-head h2::after{content:''; position:absolute; bottom:0; left:0; width:44px; height:4px; background:var(--aqua); border-radius:4px}
.section-head p{margin:0; max-width:560px; color:var(--muted)}
.selector{display:grid; grid-template-columns:repeat(3,1fr); gap:14px}
.select-card{border:1px solid var(--line); background:#fff; border-radius:var(--radius); padding:18px; cursor:pointer; box-shadow:0 8px 25px rgba(18,50,58,.06); transition:.16s transform,.16s border-color,.16s box-shadow}
.select-card:hover,.select-card.active{transform:translateY(-3px); border-color:rgba(0,166,166,.7); box-shadow:0 14px 38px rgba(0,127,135,.13)}
.badge{display:inline-flex; align-items:center; gap:6px; padding:5px 9px; border-radius:999px; background:rgba(0,166,166,.1); color:var(--sea); font-weight:800; font-size:.78rem}
.select-card h3{margin:14px 0 6px; font-size:1.18rem}
.select-card p{margin:0; color:var(--muted); font-size:.93rem}
.dashboard{display:grid; grid-template-columns:.85fr 1.15fr; gap:20px; margin-top:20px; align-items:start}
.panel{background:#fff; border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow); padding:22px}
.panel h3{margin:0 0 10px; font-size:1.2rem; letter-spacing:-.02em}
.muted{color:var(--muted)}
.info-list{display:grid; gap:12px; margin-top:16px}
.info-item{display:flex; gap:12px; align-items:flex-start; border:1px solid var(--line); border-radius:16px; padding:12px; background:#fbfefe}
.ico{width:34px; height:34px; flex:0 0 auto; border-radius:12px; display:grid; place-items:center; background:rgba(246,185,75,.22)}
.info-item strong{display:block}
.info-item span{font-size:.9rem; color:var(--muted)}
.planner{display:grid; gap:12px}
label{font-weight:800; font-size:.88rem}
input,select{width:100%; padding:13px 14px; border:1px solid var(--line); border-radius:14px; background:#fff; color:var(--ink); font:inherit; outline:none}
input:focus,select:focus{border-color:var(--aqua); box-shadow:0 0 0 4px rgba(0,166,166,.12)}
.field-row{display:grid; grid-template-columns:1fr 1fr; gap:12px}
.button-row{display:flex; flex-direction:row; gap:10px; margin-top:4px}
.button-row .btn{flex:1}
.btn-google-maps{background:#34A853; color:#fff}
.btn-google-maps:hover{background:#2d9248}
.btn-waze{background:#05C8F7; color:#fff}
.btn-waze:hover{background:#04b0db}
.route-grid{display:grid; grid-template-columns:repeat(2,1fr); gap:14px; margin-top:16px}
.route-card{display:block; border-radius:20px; padding:20px; border:1px solid var(--line); border-top-width:4px; text-decoration:none; color:inherit; transition:.16s border-color,.16s box-shadow,.16s transform}
.route-card h4{margin:0 0 6px; font-size:1rem; font-weight:800}
.route-card p{margin:0; color:var(--muted); font-size:.92rem}
.route-ico{width:46px; height:46px; border-radius:14px; display:grid; place-items:center; font-size:1.3rem; color:#fff; margin-bottom:12px}
.route-link{display:inline-block; margin-top:10px; font-size:.82rem; font-weight:800; color:var(--sea)}
.route-card-aqua{background:linear-gradient(150deg,rgba(0,166,166,.07) 0%,#fff 60%); border-color:#00a6a6}
.route-card-aqua .route-ico{background:#00a6a6}
.route-card-aqua:hover{border-color:#00a6a6; box-shadow:0 10px 28px rgba(0,166,166,.22); transform:translateY(-2px)}
.line-dot{display:inline-block; width:12px; height:12px; border-radius:999px; margin-right:6px; vertical-align:-1px; background:var(--aqua)}
.red{background:#e33831}.orange{background:#f5a623}.blue{background:#19a9e5}.green{background:#6abf4b}.gold{background:var(--sun)}
.cards{display:grid; grid-template-columns:repeat(4,1fr); gap:14px}
.tile{position:relative; overflow:hidden; background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:20px; min-height:210px; box-shadow:0 9px 30px rgba(18,50,58,.07); transition:.18s transform,.18s box-shadow}
.tile:hover{transform:translateY(-5px); box-shadow:0 18px 45px rgba(18,50,58,.13)}
.tile:after{content:""; position:absolute; width:120px; height:120px; border-radius:50%; background:rgba(0,166,166,.09); right:-36px; bottom:-44px}
.tile .big{font-size:1.5rem; margin-bottom:18px}
.tile h3{margin:0 0 8px}
.tile p{margin:0 0 14px; color:var(--muted); font-size:.94rem}
.tile a{font-weight:800; text-decoration:none; color:var(--sea)}
.nearby-col{display:flex; flex-direction:column; gap:15px}
.near-card{background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:20px; box-shadow:0 8px 25px rgba(18,50,58,.06)}
.near-card h3{margin:0 0 10px}
.near-card ul{list-style:none; padding:0; margin:0; display:grid; gap:8px}
.near-card li{display:flex; justify-content:space-between; align-items:flex-start; gap:10px; color:var(--muted); border-bottom:1px dashed #e5eeee; padding-bottom:8px}
.near-card li span{min-width:0; flex-shrink:1; font-size: 14px;}
.near-card li:last-child{border-bottom:none; padding-bottom:0}
.near-btns{display:flex; gap:5px; flex-shrink:0}
.near-btns a{font-size:.75rem; padding:4px 10px; border-radius:999px; font-weight:700; text-decoration:none; white-space:nowrap; transition:.15s background,.15s color}
.near-btns .gmaps{background:var(--ink); color:#fff}
.near-btns .gmaps:hover{background:var(--sea)}
.near-btns .waze{background:#fff; color:var(--ink); border:1px solid var(--line)}
.near-btns .waze:hover{border-color:var(--aqua); color:var(--aqua)}
.message-box{display:grid; grid-template-columns:1fr 1fr; gap:20px}
.message{background:#102f37; color:#fff; border-radius:var(--radius); padding:24px; box-shadow:var(--shadow)}
.message p{color:rgba(255,255,255,.82)}
.message textarea{width:100%; min-height:260px; border:none; border-radius:18px; padding:16px; resize:vertical; font:inherit; color:var(--ink)}
.urlbox{background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:24px}
.url{font-family:ui-monospace, SFMono-Regular, Menlo, monospace; background:#f7fbfa; border:1px solid #e5eeee; padding:10px 12px; border-radius:12px; display:block; margin:8px 0 14px; overflow:auto}
.footer{padding:34px 0 50px; color:var(--muted); font-size:.92rem}
.whatsapp-fab{position:fixed; bottom:28px; right:28px; z-index:999; width:60px; height:60px; border-radius:50%; display:grid; place-items:center; box-shadow:0 6px 20px rgba(0,0,0,.22); transition:.2s transform,.2s box-shadow}
.whatsapp-fab img{width:60px; height:60px; display:block}
.whatsapp-fab::before{content:'Stay in touch with us!'; position:absolute; right:72px; bottom:50%; transform:translateY(50%); background:#1a1a1a; color:#fff; font-size:.78rem; font-weight:700; white-space:nowrap; padding:7px 12px; border-radius:8px; pointer-events:none; opacity:0; transition:.18s opacity; font-family:'Montserrat',sans-serif}
.whatsapp-fab::after{content:''; position:absolute; right:66px; bottom:50%; transform:translateY(50%); border:6px solid transparent; border-left-color:#1a1a1a; pointer-events:none; opacity:0; transition:.18s opacity}
.whatsapp-fab:hover{transform:scale(1.1); box-shadow:0 10px 28px rgba(0,0,0,.28)}
.whatsapp-fab:hover::before,.whatsapp-fab:hover::after{opacity:1}
.small-note{font-size:.86rem; color:var(--muted)}
.lang-pill{display:flex; align-items:center; gap:6px; border:1px solid var(--line); border-radius:999px; padding:7px 12px; background:#fff; font-size:.88rem; white-space:nowrap}
.lang-pill select{border:none; background:transparent; padding:0; margin:0; font:inherit; font-size:.88rem; color:var(--ink); cursor:pointer; outline:none; max-width:110px; appearance:none; -webkit-appearance:none}
/* Moving boxes / oversized items warning section */
#moving-boxes{padding:80px 0 100px}
.boxes-banner{display:flex; gap:24px; align-items:flex-start; background:linear-gradient(135deg,rgba(246,185,75,.13) 0%,rgba(255,107,74,.08) 100%); border:2px solid rgba(246,185,75,.5); border-radius:var(--radius); padding:32px 36px; margin-top:20px}
.boxes-banner-icon{font-size:3rem; flex-shrink:0; line-height:1.1; margin-top:4px}
.boxes-banner h3{font-size:1.28rem; font-weight:800; margin:0 0 10px; color:var(--ink)}
.boxes-banner p{color:var(--muted); margin:0; line-height:1.65}
.boxes-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:24px}
.boxes-card{background:var(--card); border-radius:var(--radius-sm); padding:24px; border:1px solid var(--line); border-top:4px solid var(--sun); box-shadow:0 4px 18px rgba(246,185,75,.08); transition:.18s transform,.18s box-shadow}
.boxes-card:hover{transform:translateY(-3px); box-shadow:0 12px 32px rgba(246,185,75,.14)}
.boxes-icon{font-size:2rem; line-height:1; margin-bottom:14px}
.boxes-card h4{font-size:.98rem; font-weight:800; margin:0 0 8px; color:var(--ink)}
.boxes-card p{color:var(--muted); font-size:.91rem; margin:0; line-height:1.6}
@media(max-width:900px){.boxes-grid{grid-template-columns:1fr 1fr}; .boxes-banner{flex-direction:column; gap:16px}}
@media(max-width:600px){.boxes-grid{grid-template-columns:1fr}}
/* Suppress Google Translate intrusive toolbar */
.goog-te-banner-frame{display:none!important}
.skiptranslate{display:none!important}
body{top:0!important}
.goog-text-highlight{background:none!important; box-shadow:none!important}
@media (max-width:900px){
  .hero-grid,.dashboard,.message-box{grid-template-columns:1fr}
  .selector,.cards,.nearby{grid-template-columns:1fr}
  .route-grid,.field-row{grid-template-columns:1fr}
  .navlinks{display:none}
  .phone{max-width:100%}
}
.near-card h3{
  font-weight: 900;
  padding-bottom: 20px;
}
.accent{color:var(--aqua)}
.section-tag{display:inline-block; font-size:.75rem; font-weight:800; color:var(--aqua); text-transform:uppercase; letter-spacing:.1em; margin-bottom:10px}
.pet-banner{background:linear-gradient(135deg,var(--aqua),var(--sea)); color:#fff; border-radius:var(--radius); padding:36px 40px; margin-bottom:28px; display:flex; gap:28px; align-items:center; box-shadow:var(--shadow)}
.pet-banner-icon{font-size:3.5rem; flex-shrink:0; line-height:1}
.pet-banner h3{margin:0 0 8px; font-size:1.6rem; font-weight:800}
.pet-banner p{margin:0; opacity:.9; font-size:.97rem}
.pet-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:16px}
.pet-card{background:#fff; border:1px solid var(--line); border-radius:var(--radius-sm); padding:24px; box-shadow:0 8px 25px rgba(18,50,58,.06); transition:.18s transform,.18s box-shadow}
.pet-card:hover{transform:translateY(-4px); box-shadow:0 16px 40px rgba(18,50,58,.12)}
.pet-icon{font-size:2rem; margin-bottom:14px}
.pet-card h4{margin:0 0 8px; font-size:1.05rem; font-weight:800; font-family:'Poppins', sans-serif}
.pet-card p{margin:0; color:var(--muted); font-size:.92rem; line-height:1.55}
#originInput[readonly]{cursor:default; background:#f7fbfa; color:var(--muted)}
@media(max-width:900px){
  .pet-grid{grid-template-columns:1fr 1fr}
  .pet-banner{flex-direction:column; gap:16px; text-align:center}
}

/* ============================================================
   RESPONSIVE FULL — Mobile & Tablet
   ============================================================ */

/* Prefix backdrop-filter for iOS Safari */
.topbar { -webkit-backdrop-filter: blur(14px); }

/* Logo constrained height so it never overflows the header */
.brand img { height: 36px; width: auto; display: block; }

/* ── 768 px and below ─────────────────────────────────────── */
@media (max-width: 768px) {

  /* iOS Safari: background-attachment:fixed causes scroll glitches */
  body { background-attachment: scroll; }

  /* ── Header ── */
  .nav { padding: 10px 0; gap: 10px; }
  .brand img { height: 28px; }
  .brand span { font-size: .82rem; }
  .lang-pill { padding: 5px 9px; }
  .lang-pill select { max-width: 82px; font-size: .80rem; }

  /* ── Hero ── */
  .hero { padding: 40px 0 32px; }
  .hero-grid { gap: 20px; }
  .hero-grid > div:last-child img {
    width: 100%;
    height: 240px;
    object-fit: cover;
    border-radius: 18px !important;
    display: block;
  }
  h1 {
    font-size: clamp(1.8rem, 7vw, 2.6rem);
    margin: 12px 0 12px;
    line-height: 1.12;
  }
  .lead { font-size: .96rem; }
  .eyebrow { font-size: .82rem; padding: 6px 10px; }
  .hero-actions { gap: 8px; margin-top: 16px; }
  .hero-actions .btn { font-size: .82rem; padding: 10px 14px; }

  /* ── Sections ── */
  section { padding: 44px 0; }
  #moving-boxes { padding: 44px 0 54px; }

  /* ── Section header ── */
  .section-head {
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
    margin-bottom: 24px;
  }
  .section-head p { max-width: 100%; font-size: .93rem; }

  /* ── Transport tiles ── */
  .tile { min-height: auto; padding: 16px; }
  .tile .big { font-size: 1.25rem; margin-bottom: 10px; }
  .tile h3 { font-size: 1rem; margin-bottom: 6px; }
  .tile p { font-size: .88rem; }

  /* ── Transport planner panel ── */
  .panel { padding: 16px; }
  .panel h3 { font-size: 1.05rem; }
  .button-row { flex-direction: column; }
  .button-row .btn { width: 100%; }
  .route-grid { gap: 10px; }
  .route-card { padding: 14px; }
  .route-ico { width: 38px; height: 38px; font-size: 1.1rem; margin-bottom: 8px; }
  .route-card h4 { font-size: .9rem; }
  .route-card p { font-size: .84rem; }
  .small-note { font-size: .82rem; }

  /* ── Nearby — force single column ── */
  #nearby .col-6 {
    flex: 0 0 100%;
    width: 100%;
  }
  .near-card { padding: 14px; }
  .near-card h3 { font-size: .95rem; padding-bottom: 10px; }
  /* Stack name above buttons */
  .near-card li {
    flex-wrap: wrap;
    align-items: flex-start;
    gap: 6px;
  }
  .near-card li span {
    width: 100%;
    font-size: .86rem;
    font-weight: 600;
    color: var(--ink);
  }
  .near-btns { width: 100%; }
  .near-btns a { font-size: .73rem; padding: 5px 10px; }

  /* ── Pet policy ── */
  .pet-banner { padding: 22px 18px; gap: 14px; }
  .pet-banner-icon { font-size: 2.4rem; }
  .pet-banner h3 { font-size: 1.25rem; }
  .pet-banner p { font-size: .92rem; }
  .pet-grid { grid-template-columns: 1fr; gap: 12px; }
  .pet-card { padding: 18px; }
  .pet-icon { font-size: 1.7rem; margin-bottom: 10px; }
  .pet-card h4 { font-size: .96rem; }
  .pet-card p { font-size: .88rem; }

  /* ── Moving boxes ── */
  .boxes-banner { padding: 20px 18px; gap: 14px; }
  .boxes-banner-icon { font-size: 2.2rem; margin-top: 0; }
  .boxes-banner h3 { font-size: 1.1rem; }
  .boxes-banner p { font-size: .90rem; }

  /* ── WhatsApp FAB ── */
  .whatsapp-fab { bottom: 18px; right: 14px; width: 52px; height: 52px; }
  .whatsapp-fab img { width: 52px; height: 52px; }
  .whatsapp-fab::before,
  .whatsapp-fab::after { display: none !important; }
}

/* ── 480 px and below ─────────────────────────────────────── */
@media (max-width: 480px) {

  /* Slightly more breathing room on narrow phones */
  .wrap { width: min(1180px, 95vw); }

  h1 { font-size: clamp(1.55rem, 9vw, 2rem); }

  .hero { padding: 30px 0 24px; }
  .hero-grid > div:last-child img { height: 200px; }

  /* Hero buttons go full-width and stack */
  .hero-actions { flex-direction: column; }
  .hero-actions .btn {
    width: 100%;
    font-size: .88rem;
    padding: 12px 16px;
    justify-content: center;
  }

  section { padding: 34px 0; }
  #moving-boxes { padding: 34px 0 42px; }

  .section-head { margin-bottom: 18px; }
  .section-head h2 { font-size: clamp(1.35rem, 7vw, 1.7rem) !important; }

  .panel { padding: 12px; }
  .near-card { padding: 12px; }
  .near-btns a { font-size: .70rem; padding: 4px 8px; }

  .pet-banner { padding: 16px 14px; }
  .pet-banner h3 { font-size: 1.1rem; }
  .boxes-banner { padding: 16px 14px; }

  /* Hide "Guidebook" text on tiny screens to save space */
  .brand span { display: none; }
  .nav { gap: 6px; }
}

/* ── PWA Install button (Android only — shown via JS) ── */
.pwa-install-btn {
  position: fixed;
  bottom: 100px;          /* sits above the WhatsApp FAB */
  right: 28px;
  z-index: 997;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  background: rgba(18, 50, 58, 0.88);
  color: #fff;
  border: none;
  border-radius: 999px;
  padding: 10px 16px 10px 13px;
  font-family: 'Montserrat', sans-serif;
  font-weight: 700;
  font-size: .82rem;
  letter-spacing: .01em;
  cursor: pointer;
  box-shadow: 0 4px 18px rgba(18, 50, 58, .28);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  opacity: 0;
  transform: translateY(8px);
  transition: opacity .3s ease, transform .3s ease, box-shadow .2s;
  pointer-events: none;
}
.pwa-install-btn.visible {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
.pwa-install-btn i {
  font-size: .88rem;
  color: var(--aqua);
}
.pwa-install-btn:active {
  transform: scale(.96);
}
@media (max-width: 768px) {
  .pwa-install-btn {
    bottom: 84px;
    right: 14px;
    font-size: .80rem;
    padding: 9px 14px 9px 11px;
  }
}