/*
Theme Name: Sergio Porta FullFrame
Theme URI: https://www.schankanlagen-muenchen.de/
Author: Sergio Porta
Description: Fullscreen hero (image-only) with fast, clean navigation. Includes Local SEO (meta description + LocalBusiness schema) and auto-setup pages/menus on activation.
Version: 1.5.2-originalwp-exactdesign
License: GPL-2.0-or-later
Text Domain: sergio-porta-fullframe
*/

/* ===== Base ===== */
:root{
  --sp-bg:#0b0b0b;
  --sp-text:#ffffff;
  --sp-gold:#caa64b;
  --sp-max:1200px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;color:#111;background:#fff}
a{color:inherit}

/* ===== Header ===== */
.sp-header{
  position:fixed; top:0; left:0; right:0;
  z-index:1000;
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 18px;
  background:rgba(0,0,0,.35);
  backdrop-filter:saturate(120%) blur(6px);
}
.sp-brand{display:flex; align-items:center; gap:12px; text-decoration:none; color:var(--sp-text)}
.sp-brand__title{font-weight:800; letter-spacing:.08em; font-size:14px; text-transform:uppercase}
.sp-brand__sub{display:block; font-size:11px; opacity:.85; letter-spacing:.04em}
.sp-logo img{height:38px; width:auto; display:block}

/* Nav */
.sp-nav{display:flex; align-items:center; gap:18px}
.sp-nav ul{list-style:none; margin:0; padding:0; display:flex; gap:18px; align-items:center}
.sp-nav a{color:var(--sp-text); text-decoration:none; font-weight:650; font-size:14px; padding:8px 10px; border-radius:10px}
.sp-nav a:hover{background:rgba(255,255,255,.10)}

/* Dropdown */
.sp-nav .menu-item-has-children{position:relative}
.sp-nav .sub-menu{
  position:absolute; top:100%; left:0;
  min-width:280px;
  background:rgba(0,0,0,.88);
  border:1px solid rgba(255,255,255,.12);
  padding:10px;
  border-radius:14px;
  display:none;
}
.sp-nav .menu-item-has-children:hover > .sub-menu{display:block}
.sp-nav .sub-menu li{display:block}
.sp-nav .sub-menu a{display:block; padding:10px 12px}

/* CTA */
.sp-cta{display:flex; gap:10px; align-items:center}
.sp-cta a{color:var(--sp-text); text-decoration:none; font-weight:700; font-size:13px; padding:9px 12px; border-radius:12px; border:1px solid rgba(255,255,255,.22)}
.sp-cta a:hover{border-color:rgba(255,255,255,.5)}
.sp-cta a.sp-cta--gold{border-color:rgba(202,166,75,.65); color:var(--sp-gold)}

/* Mobile toggle */
.sp-burger{display:none; border:1px solid rgba(255,255,255,.22); background:transparent; color:var(--sp-text); padding:9px 12px; border-radius:12px; font-weight:800}

@media (max-width: 980px){
  .sp-nav{display:none}
  .sp-burger{display:inline-flex}
}

/* ===== Mobile drawer ===== */
.sp-drawer{
  position:fixed; inset:0;
  background:rgba(0,0,0,.92);
  z-index:1200;
  display:none;
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
  overscroll-behavior: contain;
  height:100dvh;
}
.sp-drawer.is-open{display:block}
.sp-drawer__inner{max-width:520px; margin:0 auto; padding:22px; min-height:100%; box-sizing:border-box; padding-bottom: calc(140px + env(safe-area-inset-bottom))}
.sp-drawer__top{display:flex; justify-content:space-between; align-items:center; margin-bottom:10px}
.sp-drawer__close{border:1px solid rgba(255,255,255,.22); background:transparent; color:#fff; padding:9px 12px; border-radius:12px; font-weight:800}
.sp-drawer nav ul{list-style:none; padding:0; margin:14px 0 0 0}
.sp-drawer nav a{display:block; padding:14px 12px; border-radius:14px; color:#fff; text-decoration:none; font-weight:750}
.sp-drawer nav a:hover{background:rgba(255,255,255,.08)}
.sp-drawer .sub-menu{margin-left:10px; border-left:1px solid rgba(255,255,255,.15); padding-left:10px}

/* ===== Hero (Image only) ===== */
.sp-hero{
  width:100vw;
  height:100svh;
  height:100vh;
  background:#000;
  display:block;
}
.sp-hero picture, .sp-hero img{
  width:100%;
  height:100%;
  display:block;
}
/* Show full image (no crop) */
.sp-hero img{object-fit:contain; object-position:center}

/* Offset content under fixed header */
.sp-page-wrap{padding-top:72px}

/* ===== Content ===== */
.sp-container{max-width:var(--sp-max); margin:0 auto; padding:28px 18px}
.sp-h1{font-size:34px; margin:0 0 10px 0}
.sp-lead{font-size:17px; line-height:1.6; color:#222}
.sp-section{padding:22px 0}
.sp-grid{display:grid; grid-template-columns:repeat(12,1fr); gap:16px}
.sp-card{grid-column:span 6; border:1px solid #eee; border-radius:18px; padding:18px; background:#fff}
.sp-card h2{margin:0 0 8px 0; font-size:18px}
.sp-card p{margin:0; color:#333; line-height:1.55}
@media (max-width: 900px){ .sp-card{grid-column:span 12} }

/* ===== Footer ===== */
.sp-footer{background:#0b0b0b; color:#fff; padding:26px 0}
.sp-footer a{color:#fff; text-decoration:none}
.sp-footer__grid{display:grid; grid-template-columns: 1.3fr 1fr 1fr; gap:18px}
.sp-footer__title{font-weight:900; letter-spacing:.08em; text-transform:uppercase; margin:0 0 8px 0; font-size:13px}
.sp-footer__small{opacity:.85; line-height:1.6; font-size:14px}
.sp-footer nav ul{list-style:none; margin:0; padding:0}
.sp-footer nav a{display:inline-block; padding:6px 0}
@media (max-width: 900px){ .sp-footer__grid{grid-template-columns:1fr} }

/* WP core */
.alignwide{max-width:var(--sp-max)}

.sp-footer-legal {
  text-align: center;
  padding: 20px;
  font-size: 14px;
  opacity: 0.8;
}
.sp-footer-legal a {
  color: #c9a24d;
  text-decoration: none;
}
.sp-footer-legal a:hover {
  text-decoration: underline;
}

/* v1.3.0 Footer legal links (clean) */
.sp-footer-links{
  text-align:center;
  padding: 18px 16px;
  font-size: 13px;
  opacity: .85;
}
.sp-footer-links a{
  color: inherit;
  text-decoration: none;
  border-bottom: 1px solid transparent;
}
.sp-footer-links a:hover{
  border-bottom-color: currentColor;
}
.sp-footer-links .sp-dot{
  margin: 0 10px;
  opacity: .6;
}

/* ===== Buttons ===== */
.sp-btn{
  display:inline-block;
  padding:10px 14px;
  border-radius:14px;
  border:1px solid rgba(0,0,0,.18);
  text-decoration:none;
  font-weight:800;
}
.sp-btn--gold{
  background:var(--sp-gold);
  color:#111;
  border-color:transparent;
}
.sp-btn--ghost{
  background:transparent;
}

.sp-drawer__title{color:#fff;letter-spacing:.10em}
.sp-drawer__cta{margin-top:14px;display:flex;gap:10px;flex-wrap:wrap}
.sp-cta__btn{display:inline-flex;align-items:center;gap:8px;padding:10px 12px;border-radius:14px;border:1px solid rgba(255,255,255,.18);color:#fff;text-decoration:none;font-weight:800}
.sp-cta__btn--gold{background:var(--sp-gold);border-color:transparent;color:#111}

/* Visually hidden (accessible) – used for SEO/semantics without affecting layout */
.sp-visually-hidden{
  position:absolute !important;
  width:1px !important;
  height:1px !important;
  padding:0 !important;
  margin:-1px !important;
  overflow:hidden !important;
  clip:rect(0,0,0,0) !important;
  white-space:nowrap !important;
  border:0 !important;
}

/* ===== Mobile Call Bar ===== */
.sp-mobilebar{
  position:fixed;
  left:0; right:0; bottom:0;
  display:none;
  gap:10px;
  padding:10px 12px;
  backdrop-filter: blur(8px);
  background: rgba(0,0,0,.55);
  z-index:9999;
}
.sp-mobilebar__btn{
  flex:1;
  display:inline-flex;
  justify-content:center;
  align-items:center;
  padding:12px 10px;
  border-radius:16px;
  text-decoration:none;
  font-weight:900;
  border:1px solid rgba(255,255,255,.18);
  color:#fff;
}
.sp-mobilebar__btn--gold{
  background: var(--sp-gold);
  border-color: transparent;
  color:#111;
}
@media (max-width: 820px){
  body{ padding-bottom: 74px; }
  .sp-mobilebar{ display:flex; }
}

/* ===== Notdienst Conversion Block ===== */
.sp-notdienst-hero{
  padding:16px;
  border-radius:18px;
  border:1px solid rgba(0,0,0,.12);
  background: rgba(255,255,255,.72);
}
.sp-notdienst-hero__lead{ margin:0 0 10px 0; }
.sp-notdienst-hero__cta{ display:flex; gap:10px; flex-wrap:wrap; margin:10px 0 6px; }
.sp-notdienst-steps{ margin:10px 0 0; padding-left:18px; }
.sp-cities{ opacity:.9; }

/* Hide fixed mobile call bar while drawer is open */
body.sp-drawer-open .sp-mobilebar{display:none !important;}


/* Drawer open: hide fixed bottom callbar to prevent covering links */
body.sp-drawer-open .sp-mobile-cta{display:none !important;}
/* Ensure inner has bottom padding so last links are visible */
.sp-drawer__inner{padding-bottom: calc(24px + env(safe-area-inset-bottom));}
