/* Unified stylesheet — redesigned palette, spacing and consistent rounding */
:root{
  /* Palette */
  --primary: #F8951D; /* brand orange */
  --primary-700: #d87a00;
  --muted-600: #6d7480;
  --muted-400: #9aa3ad;
  --accent: #004aad; /* deep blue */
  --accent-2: #0099ff; /* bright blue */
  --bg: #f6f8fa;
  --surface: #ffffff;

  /* Layout */
  --max-width: 1200px;
  --space-xs: 8px;
  --space-sm: 16px;
  --space-md: 32px;
  --space-lg: 64px;

  /* Radii */
  --radius-sm: 8px;
  --radius-md: 16px;
  --radius-lg: 24px;
  --radius-pill: 9999px;

  /* Shadows */
  --shadow-sm: 0 6px 16px rgba(16,24,40,0.06);
  --shadow-md: 0 12px 30px rgba(16,24,40,0.08);

  /* Typography */
  --font-sans: 'Poppins', system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial;
}

/* ===== Reset & global ===== */
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{font-family:var(--font-sans);background:var(--bg);color:#111;line-height:1.6;-webkit-font-smoothing:antialiased}
.container{width:90%;max-width:var(--max-width);margin:0 auto}
.section{padding:var(--space-lg) 0}
.text-center{text-align:center}
.hidden{display:none!important}

/* ===== Logo images ===== */
img.logo{display:block;max-height:64px;width:auto;height:auto}
#loga img{max-width:220px;width:100%;height:auto}

/* ===== Logos strip (partner bar) ===== */
.logos-strip{display:flex;justify-content:center;padding:18px;margin:0 auto;max-width:980px;background:linear-gradient(180deg, rgba(255,255,255,0.95), rgba(250,250,250,0.85));border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}
.logos{display:flex;align-items:center;justify-content:center;gap:36px;flex-wrap:wrap;padding:6px 12px}
.logo-item{flex:0 0 auto;display:flex;align-items:center;justify-content:center;padding:6px;border-radius:var(--radius-sm);transition:transform .22s ease,box-shadow .22s ease}
.logo-item:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);background:rgba(255,255,255,0.6)}

@media (max-width:768px){
  .logos-strip{padding:12px;margin:0 10px}
  .logos{gap:18px}
  #loga img{max-width:140px}
}

/* ===== Header / navigation ===== */
.header,.glass-header{background:var(--surface);box-shadow:var(--shadow-sm);position:sticky;top:0;z-index:1000}
.glass-header{background:rgba(255,255,255,0.15);backdrop-filter:blur(6px);padding:12px;margin:12px;border-radius:var(--radius-pill)}
.header .container,.glass-header .container{display:flex;align-items:center;justify-content:space-between;padding:12px 0}
.logo{font-size:1.6rem;font-weight:700;color:var(--primary)}
.logo span{color:var(--accent)}
.nav ul{display:flex;list-style:none;gap:18px}
.nav a,.glass-header .nav-link{text-decoration:none;color:var(--muted-600);padding:8px 14px;border-radius:var(--radius-pill);transition:all .18s ease}
.nav a:hover,.glass-header .nav-link:hover{color:var(--primary);background:rgba(0,0,0,0.03)}
.nav a.active,.glass-header .nav-link.aktivni{color:var(--primary);background:rgba(255,249,240,0.9);font-weight:600}
.menu-toggle{display:none;background:none;border:none;font-size:1.2rem;padding:8px;border-radius:8px}

@media (max-width:768px){
  .nav ul{display:none;flex-direction:column;gap:12px;background:var(--surface);position:absolute;right:18px;top:62px;box-shadow:var(--shadow-sm);padding:12px;border-radius:var(--radius-sm)}
  .nav.active ul{display:flex}
  .menu-toggle{display:block}
  .glass-header{flex-direction:column;align-items:flex-start;gap:10px;padding:8px}
}

/* ===== Hero ===== */
.hero{background:linear-gradient(rgba(0,0,0,0.28),rgba(0,0,0,0.28)),url('../obr/hero.png') center/cover no-repeat;color:#fff;text-align:center;padding:120px 20px;position:relative}
.hero::before{content:"";position:absolute;inset:0;background:rgba(0,0,0,0.32)}
.hero-content{position:relative;z-index:2;max-width:820px;margin:0 auto}
.hero h1{font-size:2.8rem;margin-bottom:18px}
.hero p{font-size:1.1rem;margin-bottom:24px;color:rgba(255,255,255,0.92)}

/* ===== Buttons ===== */
.btn{display:inline-block;background:var(--primary);color:#fff;padding:12px 28px;border-radius:var(--radius-pill);text-decoration:none;font-weight:600;transition:all .22s ease}
.btn.secondary{background:transparent;color:var(--primary);border:1px solid rgba(0,0,0,0.06)}
.btn:hover{background:var(--primary-700);transform:translateY(-3px)}

/* ===== Cards / grid ===== */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:28px;max-width:var(--max-width);margin:28px auto;padding:0 12px}
.card{background:var(--surface);backdrop-filter:blur(6px);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:28px;transition:transform .22s,box-shadow .22s;cursor:pointer}
.card:hover{transform:translateY(-8px);box-shadow:var(--shadow-md)}
.card h3{color:var(--primary);font-size:1.25rem;margin-bottom:10px}
.card p{color:var(--muted-600);line-height:1.65}
.card img{width:100%;height:200px;object-fit:cover;border-radius:var(--radius-sm)}

/* Small card variant for galleries */
.card-wrapper .card{border-radius:12px;padding:12px;box-shadow:0 4px 12px rgba(0,0,0,0.06)}

/* ===== Timeline ===== */
.timeline{position:relative;padding-left:40px;display:flex;flex-direction:column;gap:40px}
.timeline::before{content:'';position:absolute;left:16px;top:0;bottom:0;width:6px;background:linear-gradient(180deg,var(--primary),var(--primary-700));border-radius:4px}
.timeline-item{position:relative;padding-left:48px}
.timeline-item::before{content:'';position:absolute;left:-6px;top:0;width:24px;height:24px;background:var(--surface);border:4px solid var(--primary);border-radius:50%;transition:transform .22s}
.timeline-item .year{font-weight:700;color:var(--primary);display:block;margin-bottom:8px}
.timeline-item:hover::before{transform:scale(1.08)}

/* ===== Unified panel utility ===== */
.panel{
  background:var(--surface);
  border-radius:var(--radius-md);
  box-shadow:var(--shadow-sm);
  transition:transform .22s,box-shadow .22s,background .18s;
}
.panel-hover{cursor:pointer}
.panel-hover:hover{transform:translateY(-8px);box-shadow:var(--shadow-md)}

/* Apply panel styles to common blocks */
.contact-card, .card, .card-wrapper .card, .timeline-item, .faq-item, .logo-item{background:var(--surface);border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}
.contact-card:hover, .timeline-item:hover, .faq-item:hover, .logo-item:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}

/* Make contact cards visually consistent */
.contact-card{padding:18px}
.contact-card img{border-radius:12px}

/* Tabs as subtle panels */
.tab{border-radius:9999px}
.tab:hover{transform:translateY(-4px)}

/* ===== Image hover scale (subtle) ===== */
.panel img,
.card img,
.mini-galerie img,
.logo-item img {
  transition: transform .35s cubic-bezier(.2,.9,.2,1), filter .25s;
  will-change: transform;
}
.panel-hover:hover img {
  transform: scale(1.03);
}
.panel-hover:hover img.logo {
  /* keep header logo crisp - smaller scale */
  transform: scale(1.02);
}

/* ===== FAQ ===== */
.faq-list{display:flex;flex-direction:column;gap:18px}
.faq-item{background:var(--surface);padding:18px;border-radius:var(--radius-sm);box-shadow:0 6px 18px rgba(0,0,0,0.04);cursor:pointer;transition:transform .18s,box-shadow .18s}
.faq-item:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.faq-question{font-weight:600;font-size:1.05rem;position:relative;padding-right:26px}
.faq-question::after{content:'+';position:absolute;right:0;top:0;font-size:1.1rem}
.faq-item.active .faq-question::after{content:'–'}
.faq-answer{max-height:0;overflow:hidden;opacity:0;padding-top:0;transition:max-height .4s,opacity .4s,padding-top .4s}
.faq-item.active .faq-answer{max-height:600px;opacity:1;padding-top:10px}

/* ===== Zakazky tabs & gallery ===== */
.zakazky-nav{background:transparent;border-bottom:1px solid rgba(0,0,0,0.04);padding:20px 0}
.zakazky-nav .container{display:flex;justify-content:center;gap:12px;flex-wrap:wrap}
.tab{background:var(--surface);border:1px solid rgba(0,0,0,0.06);border-radius:var(--radius-pill);padding:10px 22px;cursor:pointer;font-weight:600;transition:all .18s}
.tab:hover{background:var(--accent-2);color:#fff;border-color:var(--accent-2)}
.tab.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.tab-content{display:none}
.tab-content.active{display:block}
.gallery{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:22px;margin-top:24px}
.mini-galerie{display:none;position:relative;margin-top:10px;overflow:hidden}
.mini-galerie.active{display:flex;align-items:center}
.mini-galerie .fotky{display:flex;overflow-x:auto;gap:10px;padding:6px}
.mini-galerie img{width:120px;height:80px;object-fit:cover;border-radius:8px;cursor:pointer}
.sipka{background:rgba(0,0,0,0.45);color:#fff;border:none;font-size:20px;cursor:pointer;padding:6px 10px;border-radius:8px}

/* ===== Contact card (firma) ===== */
.contact-card.firma{display:flex;align-items:stretch;justify-content:space-between;background:rgba(255,255,255,0.85);backdrop-filter:blur(6px);border-radius:var(--radius-md);padding:26px;gap:24px;max-width:1000px;margin:0 auto 30px}
.contact-card.firma .contact-info{flex:1;display:flex;flex-direction:column;justify-content:center}
.contact-card.firma .map{flex:1;border-radius:var(--radius-md);overflow:hidden}
.contact-card.firma .map iframe{width:100%;height:100%;min-height:300px;border:0;border-radius:var(--radius-md)}

/* ===== Footer ===== */
.footer{text-align:center;background:linear-gradient(90deg,var(--primary),var(--primary-700));color:#fff;padding:28px 0;border-radius:12px}
.footer a{color:#fff;text-decoration:underline}

/* ===== Headings accent underline ===== */
#sluzby h2,#benefity h2,#historie h2,.rozpis_sluzeb_section h2{font-size:2.4rem;margin-bottom:40px;display:inline-block;color:var(--primary);position:relative}
#sluzby h2::after,#benefity h2::after,#historie h2::after,.rozpis_sluzeb_section h2::after{content:"";position:absolute;width:45%;height:4px;left:27.5%;bottom:-12px;background:var(--primary);border-radius:3px}

/* ===== Responsive tweaks ===== */
@media(max-width:768px){
  .hero{padding:80px 15px}
  .hero h1{font-size:2rem}
  .cards{gap:18px}
  .card{padding:20px}
  .contact-card.firma{flex-direction:column;padding:18px}
  .contact-card.firma .map iframe{height:250px}
}

/* End of unified stylesheet */
