.elementor-20 .elementor-element.elementor-element-8eacd3c{--display:flex;}.elementor-theme-builder-content-area{height:400px;}.elementor-location-header:before, .elementor-location-footer:before{content:"";display:table;clear:both;}/* Start custom CSS for html, class: .elementor-element-827da30 *//* ── FULL-WIDTH GUEST HEADER ───────────────── */

/* Bar that breaks out of Elementor's boxed container */
.toto-header-bar {
  position: relative;
  left: 50%;
  right: 50%;
  margin-left: -50vw;
  margin-right: -50vw;
  width: 100vw;                 /* full viewport width */
  background: #252b36;
  border-bottom: 1px solid rgba(255,255,255,0.08);
  z-index: 999;
}

/* Inner content area (centered, limited width) */
.toto-header-inner {
  max-width: 1320px;
  margin: 0 auto;
  padding: 12px 24px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
}

/* Logo */
.toto-header-left {
  display:flex;
  align-items:center;
  gap:10px;
}
.toto-logo-mark {
  background: #e14761;
  color:#fff;
  width: 40px;
  height: 40px;
  border-radius: 12px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:700;
  font-size:14px;
}
.toto-logo-text .brand {
  font-size:18px;
  font-weight:700;
  color:#f9fafb;
}
.toto-logo-text .tagline {
  font-size:11px;
  color:#e5e7eb;
  opacity:.8;
}

/* Nav links */
.toto-nav {
  display:flex;
  align-items:center;
  gap:24px;
}
.toto-nav a {
  font-size:14px;
  text-decoration:none;
  color:#e5e7eb;
  position:relative;
  padding-bottom:3px;
  transition:.2s;
}
.toto-nav a:hover {
  color:#38bdf8;
}
.toto-nav a::after {
  content:"";
  position:absolute;
  left:0;
  bottom:-3px;
  width:0;
  height:2px;
  background:#38bdf8;
  border-radius:99px;
  transition:width .2s;
}
.toto-nav a:hover::after {
  width:100%;
}

/* Right side buttons */
.toto-header-cta {
  display:flex;
  align-items:center;
  gap:10px;
}
.toto-chip {
  font-size:11px;
  padding:6px 10px;
  border-radius:999px;
  color:#e5e7eb;
  background:rgba(15,23,42,0.7);
}
.toto-btn-outline,
.toto-btn-primary {
  border-radius:999px;
  padding:7px 16px;
  font-size:13px;
  font-weight:600;
  text-decoration:none;
  border:1px solid transparent;
  transition:.2s;
}
.toto-btn-outline {
  border-color:#94a3b8;
  color:#e5e7eb;
}
.toto-btn-outline:hover {
  border-color:#38bdf8;
  color:#38bdf8;
}
.toto-btn-primary {
  background:linear-gradient(135deg,#f97316,#fb923c);
  color:#fff;
}
.toto-btn-primary:hover {
  filter:brightness(1.05);
}

/* Basic responsive: hide nav on small screens for now */
@media (max-width:900px){
  .toto-header-inner {
    padding:10px 14px;
  }
  .toto-nav {
    display:none;
  }
}/* End custom CSS */
/* Start custom CSS *//* ---------- Global TOTO Shell Styles ---------- */

/* Header layout */
.toto-header {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 10px 18px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}

.toto-header-left {
  display: flex;
  align-items: center;
  gap: 10px;
}

.toto-logo-mark {
  width: 36px;
  height: 36px;
  border-radius: 12px;
  background: linear-gradient(135deg,#b91c1c,#7f1d1d);
  display:flex;
  align-items:center;
  justify-content:center;
  color:#fff;
  font-weight:700;
  font-size:14px;
}

.toto-logo-text {
  display:flex;
  flex-direction:column;
  line-height:1.1;
}
.toto-logo-text .brand {
  font-size:18px;
  font-weight:700;
  color:#f9fafb;
}
.toto-logo-text .tagline {
  font-size:11px;
  color:#e5e7eb;
  opacity:0.8;
}

/* Menu */
.toto-nav {
  display:flex;
  align-items:center;
  gap:18px;
}

.toto-nav a {
  font-size:14px;
  text-decoration:none;
  color:#e5e7eb;
  opacity:0.85;
  position:relative;
}
.toto-nav a:hover {
  opacity:1;
}
.toto-nav a::after {
  content:"";
  position:absolute;
  left:0;
  bottom:-4px;
  width:0;
  height:2px;
  border-radius:999px;
  background:#f97316;
  transition:width .25s ease;
}
.toto-nav a:hover::after {
  width:100%;
}

/* Header CTAs */
.toto-header-cta {
  display:flex;
  align-items:center;
  gap:10px;
}

.toto-chip {
  padding:6px 10px;
  border-radius:999px;
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.8px;
  background:rgba(15,23,42,0.85);
  color:#e5e7eb;
}

.toto-btn-outline,
.toto-btn-primary {
  border-radius:999px;
  padding:8px 16px;
  font-size:13px;
  border:1px solid #f97316;
  background:transparent;
  color:#f97316;
  text-decoration:none;
  font-weight:600;
}
.toto-btn-primary {
  background:linear-gradient(135deg,#b91c1c,#f97316);
  border-color:transparent;
  color:#fff;
}
.toto-btn-outline:hover,
.toto-btn-primary:hover {
  filter:brightness(1.05);
}

/* Responsive header */
@media (max-width:768px){
  .toto-header {
    padding:10px 14px;
    flex-wrap:wrap;
  }
  .toto-nav {
    display:none; /* You can enable and convert to hamburger later */
  }
}

/* ---------- Footer ---------- */

.toto-footer {
  width:100%;
  background:#020617;
  border-top:1px solid rgba(148,163,184,0.25);
  padding:20px 18px 80px; /* extra bottom for mobile bar */
  color:#e5e7eb;
}
.toto-footer-inner {
  max-width:1200px;
  margin:0 auto;
  display:grid;
  grid-template-columns:2fr 1fr 1fr;
  gap:24px;
}
.toto-footer h4 {
  font-size:14px;
  text-transform:uppercase;
  letter-spacing:.08em;
  margin-bottom:8px;
  color:#f97316;
}
.toto-footer a {
  color:#e5e7eb;
  font-size:13px;
  text-decoration:none;
  opacity:0.85;
}
.toto-footer a:hover { opacity:1; }

.toto-footer-small {
  margin-top:18px;
  padding-top:10px;
  border-top:1px solid rgba(15,23,42,0.8);
  font-size:11px;
  opacity:0.8;
  display:flex;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:8px;
}

/* Responsive footer */
@media (max-width:768px){
  .toto-footer-inner {
    grid-template-columns:1fr;
  }
}

/* ---------- Mobile Floating Footer Nav ---------- */

.toto-mobile-bar {
  position:fixed;
  left:0;
  right:0;
  bottom:0;
  z-index:9999;
  background:#020617;
  border-top:1px solid rgba(148,163,184,0.4);
  display:flex;
  justify-content:space-around;
  padding:6px 4px 8px;
}
.toto-mobile-bar a {
  flex:1;
  text-align:center;
  font-size:11px;
  text-decoration:none;
  color:#e5e7eb;
  opacity:0.9;
}
.toto-mobile-bar span {
  display:block;
}
.toto-mobile-bar .icon {
  font-size:16px;
  margin-bottom:2px;
}

/* Only show on mobile */
@media (min-width:769px){
  .toto-mobile-bar { display:none; }
}/* End custom CSS */