
:root{
  --bg:#ffffff; --text:#1b2430; --muted:#5b6b7f; --accent:#1a5fd0; --sub:#e7edf7; --line:#e6ebf3; --card:#ffffff; --radius:16px;
}
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;font:16px/1.6 system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, Arial; color:var(--text); background:var(--bg); display:flex; flex-direction:column}
main{flex:1}
.container{max-width:1140px; margin:0 auto; padding:22px}
header{border-bottom:1px solid var(--line); background:#fffcc; background:rgba(255,255,255,.9); backdrop-filter:blur(6px); position:sticky; top:0; z-index:5}
.nav{display:flex; align-items:center; justify-content:space-between}
.logo{display:flex; gap:10px; align-items:center; font-weight:800}
.logo-mark{width:40px; height:40px; border-radius:10px; background:linear-gradient(135deg, var(--accent), #74a5ff); display:grid; place-items:center; color:#fff}
nav ul{display:flex; gap:14px; list-style:none; margin:0; padding:0}
nav a{padding:10px 14px; border-radius:10px}
nav a.active, nav a:hover{background:var(--sub)}
.hero{background:linear-gradient(180deg, var(--sub), transparent); padding:64px 0 36px}
.grid{display:grid; gap:20px}
.grid-2{display:block}
.card{background:var(--card); border:1px solid var(--line); border-radius:var(--radius); padding:22px}
h1{font-size:40px; line-height:1.15; margin:0 0 10px}
h2{font-size:26px; margin:0 0 6px}
.lead{color:var(--muted); max-width:60ch}
.btn{display:inline-block; background:var(--accent); color:#fff; padding:12px 18px; border-radius:12px; font-weight:700; margin-top:14px}
.features{display:grid; grid-template-columns:repeat(3,1fr); gap:12px}
.tile{background:var(--sub); border:1px solid var(--line); border-radius:12px; padding:16px; min-height:84px}
.gallery{display:grid; grid-template-columns:repeat(3,1fr); gap:12px}
.ph{background:#dfe8f6; border:1px dashed #b8c8e3; border-radius:12px; aspect-ratio:16/10}
form{display:grid; gap:10px}
input, textarea{width:100%; padding:12px 14px; border:1px solid var(--line); border-radius:12px; background:#fff}
textarea{min-height:120px}
button{background:var(--accent); color:#fff; border:0; padding:12px 18px; border-radius:12px; font-weight:700; cursor:pointer}
footer{border-top:1px solid var(--line); padding:22px 0; color:var(--muted)}
@media (max-width:900px){ .grid-2{display:block} .features{grid-template-columns:1fr 1fr} }

.page--gallery .grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}


header, nav, body, main, section:first-of-type {
    margin-top: 0 !important;
    padding-top: 0 !important;
}


/* === Hard fix: eliminate top gap under the header on all pages === */
header, nav { margin-top: 0 !important; padding-top: 0 !important; }
body { margin-top: 0 !important; padding-top: 0 !important; }
header + * { margin-top: 0 !important; padding-top: 0 !important; }         /* element right after header */
main, .main, .content, .container, section:first-of-type { margin-top: 0 !important; padding-top: 0 !important; }
/* If any template adds spacing via first-child inside wrapper */
header ~ .wrapper:first-child, header ~ .container:first-child, header ~ main:first-child { margin-top:0!important; padding-top:0!important; }


/* === Global fix: remove any top gap below header on all pages === */
html, body { margin:0 !important; padding:0 !important; }
header, nav { margin-top:0 !important; padding-top:0 !important; }
body > *:first-child { margin-top:0 !important; padding-top:0 !important; }
header + * { margin-top:0 !important; padding-top:0 !important; }
main, .main, .content, .container, .wrapper, .page, .section, section:first-of-type {
  margin-top:0 !important; padding-top:0 !important;
}
/* Some templates put margin on first container inside main */
main > .container:first-child,
main > .wrapper:first-child,
.content > .container:first-child {
  margin-top:0 !important; padding-top:0 !important;
}


/* === Fix top gap under header on all pages (margin-collapsing) === */
header { margin-bottom: 0 !important; }
main { margin-top: 0 !important; padding-top: 1px; display: flow-root; } /* create new BFC to stop margin-collapsing */
main > *:first-child { margin-top: 0 !important; }
.content > *:first-child, .container > *:first-child { margin-top: 0 !important; }
h1:first-child, h2:first-child, h3:first-child { margin-top: 0 !important; }


/* === Simple text menu reset === */
html, body { margin:0; padding:0; }
#simple-menu { position:relative; }
#simple-menu + * { margin-top: 0 !important; }


/* === Simple-menu enforcement (global) === */
#simple-menu{
  position: relative;
  display: flex;
  flex-wrap: nowrap;     /* keep on one line when possible */
  align-items: center;
  justify-content: flex-start;
  gap: 12px;
  width: 100vw;          /* span full viewport width */
  max-width: 100vw;
  margin: 0 calc(-50vw + 50%); /* full-bleed: stretch to page edges even if inside centered parent */
  padding: 8px 16px;
  border-bottom: 1px solid #eee;
  text-align: left;
}
#simple-menu a{
  display: inline-block;
  text-decoration: none;
  color: #4a4a4a;
  white-space: nowrap;   /* prevent line breaks in links */
}
/* On very small screens allow wrapping nicely */
@media (max-width: 560px){
  #simple-menu{ flex-wrap: wrap; gap: 8px 14px; }
}


/* Active menu link */
#simple-menu a.active {
  font-weight: bold;
  color: var(--accent);
  border-bottom: 2px solid var(--accent);
  padding-bottom: 2px;
}

/* Hamburger styles */
#simple-menu { display:flex; align-items:center; justify-content:space-between; }
#simple-menu .menu-toggle { display:none; }
#simple-menu .links { display:flex; gap:14px; }

@media (max-width: 768px){
  #simple-menu { flex-direction:column; align-items:flex-start; }
  #simple-menu .menu-toggle {
    display:inline-block;
    background:none;
    border:0;
    font-size:28px;
    cursor:pointer;
    margin-bottom:8px;
  }
  #simple-menu .links { display:none; flex-direction:column; gap:10px; width:100%; }
  #simple-menu.open .links { display:flex; }
}


/* === MENU FINAL FIX === */
#simple-menu{
  display:inline-flex;
  justify-content:flex-start;
  align-items:center;
  gap:16px;
  padding:8px 16px;
  border-bottom:1px solid #eee;
  white-space:nowrap;
}
#simple-menu a{
  text-decoration:none;
  color:#1f2937;
  font-weight:500;
}
#simple-menu a.active{
  color:orange;
  font-weight:600;
}


/* --- Services grid on Home --- */
.services-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  margin: 24px auto;
}
@media (max-width: 1024px){
  .services-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 768px){
  .services-grid { grid-template-columns: repeat(2, 1fr); }
}
.svc { display:flex; flex-direction:column; align-items:flex-start; gap:8px;
  padding:16px; border:1px solid #e5e7eb; border-radius:12px; background:#fff;
  color:#111827; text-decoration:none; transition:transform .15s, box-shadow .15s, border-color .15s; }
.svc:hover, .svc:focus-visible { transform: translateY(-2px); box-shadow:0 6px 18px rgba(0,0,0,.06); border-color:#d1d5db; outline:none; }
.svc-ico { width:40px; height:40px; display:grid; place-items:center; border-radius:10px; border:2px solid #111; background:#fff; }
.svc-title { font-weight:600; line-height:1.2; }
.svc-accent { border-style:dashed; }


/* --- Oranžový hover efekt pro služby --- */
.svc:hover, .svc:focus-visible {
  transform: translateY(-2px);
  box-shadow: 0 6px 18px rgba(0,0,0,.06);
  border-color: #f97316;       /* oranžová */
  background-color: #fff7ed;   /* jemný oranžový podklad */
}
.svc-ico {
  border: 2px solid #111;
  background: #fff;
  transition: border-color .15s, background-color .15s;
}
.svc:hover .svc-ico {
  border-color: #f97316;
  background-color: #fff7ed;
}


/* === HAMBURGER FINAL (bars + right dropdown) === */
#topbar{ position:sticky; top:0; z-index:100; background:#ffffffcc; backdrop-filter:blur(6px); border-bottom:1px solid #e6ebf3; }
#topbar .bar{ display:flex; align-items:center; justify-content:space-between; padding:10px 16px; position:relative; }

#topbar .menu-toggle{
  width:44px; height:44px;
  display:flex; justify-content:center; align-items:center;
  cursor:pointer; background:#fff; border:1px solid #e6ebf3; border-radius:10px;
  position:relative;
}
#topbar .menu-toggle .burger,
#topbar .menu-toggle .burger::before,
#topbar .menu-toggle .burger::after{
  content:""; display:block; width:20px; height:2px; background:#333;
}
#topbar .menu-toggle .burger{ position:relative; }
#topbar .menu-toggle .burger::before{ position:absolute; top:-6px; left:0; }
#topbar .menu-toggle .burger::after{ position:absolute; top:6px; left:0; }

/* default horizontal menu */
#simple-menu { display:flex; gap:16px; padding:8px 16px; border-bottom:1px solid #eee; }
#simple-menu a{ text-decoration:none; color:#1f2937; font-weight:500; }
#simple-menu a.active{ color:orange; font-weight:600; }

/* mobile dropdown on the right */
@media (max-width: 820px){
  #simple-menu{
    display:none; flex-direction:column; gap:12px;
    position:absolute; right:0; top:100%;
    background:#fff; border:1px solid #e6ebf3; border-radius:10px;
    padding:12px; width:220px;
    box-shadow:0 6px 18px rgba(0,0,0,.12);
  }
  #topbar.open #simple-menu{ display:flex; }
  #simple-menu a{ padding:8px 6px; }
}

/* DEBUG: show burger on all widths so it's visible on desktop too */



/* === FINAL HAMBURGER (build from robust patch) === */
#topbar{ position:sticky; top:0; z-index:100; background:#ffffffcc; backdrop-filter:blur(6px); border-bottom:1px solid #e6ebf3; }
#topbar .bar{ display:flex; align-items:center; justify-content:space-between; padding:10px 16px; position:relative; }

#topbar .menu-toggle{
  width:44px; height:44px;
  display:flex; justify-content:center; align-items:center;
  cursor:pointer; background:#fff; border:1px solid #e6ebf3; border-radius:10px;
  position:relative;
}
#topbar .menu-toggle .burger,
#topbar .menu-toggle .burger::before,
#topbar .menu-toggle .burger::after{
  content:""; display:block; width:20px; height:2px; background:#333;
}
#topbar .menu-toggle .burger{ position:relative; }
#topbar .menu-toggle .burger::before{ position:absolute; top:-6px; left:0; }
#topbar .menu-toggle .burger::after{ position:absolute; top:6px; left:0; }

/* default horizontal menu */
#simple-menu { display:flex; gap:16px; padding:8px 16px; border-bottom:1px solid #eee; }
#simple-menu a{ text-decoration:none; color:#1f2937; font-weight:500; }
#simple-menu a.active{ color:orange; font-weight:600; }

/* mobile dropdown on the right */
@media (max-width: 820px){
  #simple-menu{
    display:none; flex-direction:column; gap:12px;
    position:absolute; right:0; top:100%;
    background:#fff; border:1px solid #e6ebf3; border-radius:10px;
    padding:12px; width:220px;
    box-shadow:0 6px 18px rgba(0,0,0,.12);
  }
  #topbar.open #simple-menu{ display:flex; }
  #simple-menu a{ padding:8px 6px; }
}





@media (max-width: 820px){
  #topbar .menu-toggle{ display:flex; }
}


/* === VISIBILITY: burger ONLY on mobile === */
#topbar .menu-toggle{ display:none; }
@media (max-width: 820px){
  #topbar .menu-toggle{ display:flex; }
}


html{scroll-behavior:smooth}


/* Simple 3-column responsive grid for service lists */
.cols-3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
.cols-3 h3 { margin: 8px 0; font-size: 1.1rem; }
.cols-3 ul { margin: 0 0 6px 18px; }
.muted { opacity: 0.8; font-size: 0.95em; }

/* Stack on small screens */
@media (max-width: 768px) {
  .cols-3 { grid-template-columns: 1fr; }
}


/* Ensure equal height service boxes */
.cols-3 > div {
  display: flex;
  flex-direction: column;
  background: #fff;
  padding: 12px;
  border-radius: 8px;
  box-shadow: 0 2px 6px rgba(0,0,0,0.08);
}
.cols-3 > div h3 { margin-top: 0; }
.cols-3 > div p.muted { margin-top: auto; }


/* Footer link styling */
footer a {
  color: #000;
  text-decoration: none;
}
footer a:hover {
  text-decoration: underline;
}


/* === MOBILE SERVICES GRID FIX (2025-09-17) === */
/* Ensure the Startseite services grid is not offset to the right and uses sensible columns */
.services-grid {
  margin-left: 0 !important;
  margin-right: 0 !important;
  justify-content: stretch;
  justify-items: stretch;
}
/* If services-grid carries the container class inside a card, drop side padding on small screens */
@media (max-width: 768px){
  .services-grid.container { padding-left: 0 !important; padding-right: 0 !important; }
  .services-grid { grid-template-columns: repeat(2, minmax(0,1fr)) !important; }
}
@media (max-width: 360px){
  .services-grid { grid-template-columns: 1fr !important; }
}


/* === SERVICE TITLE NO-OVERFLOW FIX (2025-09-17) === */
.services-grid .svc { min-width: 0; }
.services-grid .svc-title{
  max-width: 100%;
  white-space: normal;
  overflow-wrap: anywhere;
  word-break: break-word;
  hyphens: auto;
  line-height: 1.2;
}
@media (max-width: 768px){
  .services-grid .svc-title{ font-size: clamp(14px, 3.8vw, 18px); }
}
