html { color-scheme: light; }
body { background: linear-gradient(180deg,#eef2f7 0%, #f6f8fa 100%) !important; color: #0f1724 !important; }

/* -- (ez után jöhet a meglévő tartalom) -- */
:root{
  --bg: #f6f8fa;
  --panel: #ffffff;
  --muted: #6b7280;
  --accent: #ff7a18;
  --accent-2: #ffb86b;
  --glass: rgba(15,23,42,0.03);
  --shadow: 0 10px 30px rgba(16,24,40,0.06);
  --radius: 14px;
  --gap:16px;
  --maxw:1100px;
  --mono: "Inter", "Segoe UI", Roboto, system-ui, -apple-system, Arial;
}

/* Base */
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:var(--mono);
  background: linear-gradient(180deg,#eef2f7 0%, #f6f8fa 100%);
  color:#0f1724;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  line-height:1.45;
  display:flex;
  flex-direction:column;
  align-items:center;
  padding-bottom:48px;
}

/* Container */
.site-header{
  width:100%;
  max-width:var(--maxw);
  padding:14px;
  display:flex;
  align-items:center;
  gap:12px;
  position:sticky;
  top:12px;
  z-index:20;
  background:transparent;
}
.logo{
  font-weight:700;
  color:var(--accent);
  text-decoration:none;
  font-size:1.15rem;
}
.nav-toggle{
  margin-left:auto;
  background:transparent;
  border:0;
  display:flex;
  flex-direction:column;
  gap:4px;
  padding:8px;
  cursor:pointer;
}
.nav-toggle span{
  display:block;
  width:22px;height:2px;background:var(--muted);border-radius:2px;
  transition:transform .2s;
}
.site-nav{
  display:none;
  gap:12px;
  align-items:center;
}
.site-nav a{
  color:var(--muted); text-decoration:none; font-size:.95rem;
}
.site-nav a:hover{color:var(--accent)}

/* Main */
main{
  width:100%;
  max-width:var(--maxw);
  padding:16px;
}

/* Card */
.card{
  background:var(--panel);
  margin:12px 0;
  padding:16px;
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  transition:transform .18s ease,box-shadow .18s ease;
}
.card:hover{ transform: translateY(-3px); box-shadow: 0 20px 40px rgba(16,24,40,0.08); }

/* Slideshow */
.slideshow{
  position:relative;
  height:56vw;
  max-height=420px;
  border-radius:var(--radius);
  overflow:hidden;
  background:linear-gradient(180deg,#fff,#fbfdff);
}
.slides{
  height:100%;
  display:flex;
  transition:transform .8s cubic-bezier(.2,.9,.2,1);
}
.slide{
  min-width:100%;
  background-size:cover;
  background-position:center;
  display:flex;
  align-items:flex-end;
  padding:18px;
}
.slide-caption{
  background:linear-gradient(90deg, rgba(255,255,255,0.9), rgba(255,255,255,0.85));
  color:#0b1220;
  padding:10px 14px;
  border-radius:10px;
  font-weight:700;
  box-shadow:0 8px 24px rgba(15,23,42,0.06);
}

/* Controls */
.slide-controls{
  position:absolute;
  left:16px;right:16px;bottom:12px;
  display:flex;align-items:center;justify-content:space-between;
}
.slide-controls button{
  background:linear-gradient(90deg,#fff,#fbfdff);
  border:1px solid rgba(15,23,42,0.04);
  color:var(--muted);
  padding:8px 12px;border-radius:10px;
  box-shadow:0 6px 20px rgba(2,6,23,0.04);
}
.dots{display:flex;gap:8px;align-items:center}
.dots button{
  width:10px;height:10px;border-radius:50%;background:rgba(15,23,42,0.08);border:0;transition:transform .12s;
}
.dots button.active{ background:linear-gradient(90deg,var(--accent),var(--accent-2)); transform:scale(1.2); }

/* Responsive nav */
@media(min-width:900px){
  .nav-toggle{display:none}
  .site-nav{display:flex !important}
}

/* Services */
.services ul{padding-left:18px}

/* Gallery */
.gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.media-item{
  background:linear-gradient(180deg,#fff,#fbfdff);
  border-radius:10px;overflow:hidden;cursor:pointer;border:1px solid rgba(15,23,42,0.04);
  transition:transform .12s ease, box-shadow .12s ease;
}
.media-item:hover{ transform:translateY(-4px); box-shadow:0 18px 40px rgba(15,23,42,0.06); }
.media-item img{width:100%;height:160px;object-fit:cover;display:block}
.media-item figcaption{padding:8px;font-size:.95rem;color:var(--muted)}

/* Modal */
.modal{
  position:fixed;inset:0;display:none;align-items:center;justify-content:center;
  background: rgba(6,10,20,0.6);
  z-index:60;padding:16px;
}
.modal[aria-hidden="false"]{display:flex}

.modal-content{
  width:100%;max-width:900px;background:var(--panel);padding:12px;border-radius:12px;position:relative;max-height:90vh;overflow:auto;
  box-shadow:var(--shadow);
}
.modal-close{
  position:absolute;
  right:10px;
  top:10px;
  background:rgba(0,0,0,0.6);
  color:#fff;
  border:0;
  width:36px;
  height:36px;
  border-radius:6px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  z-index:120;
  font-size:18px;
}
.modal-close:hover { background: rgba(0,0,0,0.75); }
.modal-content iframe, .modal-content video{width:100%;height:480px;border-radius:8px;background:#000}

/* Ensure modal stays visible when opened by JS */
#mediaModal[aria-hidden="false"] {
  display: flex !important;
  align-items: center;
  justify-content: center;
  visibility: visible !important;
  opacity: 1 !important;
  pointer-events: auto !important;
  z-index: 99999 !important;
}

/* ModalManager stronger overlay rules (ensures overlay wins over accidental rules) */
#mediaModal {
  position: fixed !important;
  inset: 0 !important;
  display: none !important;
  align-items: center !important;
  justify-content: center !important;
  background: rgba(6,10,20,0.6) !important;
  z-index: 99999 !important;
  padding: 16px !important;
}
#mediaModal[aria-hidden="false"] {
  display: flex !important;
  visibility: visible !important;
  opacity: 1 !important;
  pointer-events: auto !important;
}
#mediaModal .modal-content {
  max-width: 920px !important;
  width: 100% !important;
  max-height: 90vh !important;
  overflow: auto !important;
  position: relative !important;
  border-radius: 12px !important;
  background: var(--panel) !important;
  box-shadow: var(--shadow) !important;
}
/* ensure modal-close sits on top */
#mediaModal .modal-close { z-index: 100000 !important; }

/* Forms */
.form-card label{display:block;margin:8px 0}
.form-card input, .form-card textarea, .form-card select{width:100%;padding:10px;border-radius:8px;border:1px solid #eef2f7;background:#fbfdff;color:var(--muted)}
.form-actions{display:flex;gap:10px;margin-top:8px}
button.primary{background:linear-gradient(90deg,var(--accent),var(--accent-2));color:#fff}

/* Stars — improved visuals and accessibility */
.stars{display:flex;gap:6px;align-items:center}
.stars label{
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:42px;
  height:36px;
  border-radius:8px;
  transition:transform .12s ease, background .12s ease;
  position:relative;
}
.stars label span{
  font-size:18px;
  line-height:1;
  color:#cbd5e1; /* muted star color */
  display:inline-block;
  width:100%;
  text-align:center;
  user-select:none;
}
/* visually hide inputs but keep accessible to screen readers / keyboard */
.stars input{
  position:absolute !important;
  opacity:0 !important;
  width:1px !important;
  height:1px !important;
  padding:0 !important;
  margin:-1px !important;
  border:0 !important;
  clip:rect(0 0 0 0) !important;
  overflow:hidden !important;
}
/* hover state */
.stars label.hover span,
.stars label:hover span { 
  color: #ffb86b;
  transform: scale(1.15);
}
/* selected state (more prominent) */
.stars label.selected span{
  background: linear-gradient(90deg,var(--accent),var(--accent-2));
  color: #071424;
  padding:6px;
  border-radius:6px;
  box-shadow: 0 6px 16px rgba(16,24,40,0.06);
}
/* numeric indicator next to stars */
.star-value{
  margin-left:8px;
  color:var(--muted);
  font-weight:600;
  font-size:0.95rem;
}

/* Reviews list */
.reviews-list {
  margin-top:12px;
}
.reviews-list ul {
  list-style:none;
  padding:0;
  margin:0;
  display:block;
}
.reviews-list li.review-item {
  background: var(--panel);
  padding: 12px;
  border-radius: 10px;
  margin-bottom: 12px;
  box-shadow: var(--shadow);
  display:block;
  transition: transform .12s ease, box-shadow .12s ease;
}
.reviews-list li.review-item:hover {
  transform: translateY(-3px);
  box-shadow: 0 18px 36px rgba(16,24,40,0.06);
}

.review-header {
  display:flex;
  gap:12px;
  align-items:center;
  justify-content:space-between;
  margin-bottom:8px;
}
.review-author {
  font-weight:700;
  color:#0b1220;
  margin-right:8px;
}
.review-rating {
  color:var(--accent);
  font-weight:700;
  white-space:nowrap;
  margin-left:auto;
}

.review-body {
  margin-bottom:8px;
}
.review-excerpt {
  color:var(--muted);
  line-height:1.35;
  overflow:hidden;
  text-overflow:ellipsis;
  display:-webkit-box;
  -webkit-line-clamp:4; /* default: show 4 lines */
  -webkit-box-orient:vertical;
  max-height: calc(1.35em * 4);
  white-space: normal;
}

/* expanded state shows full text */
.review-item.expanded .review-excerpt {
  -webkit-line-clamp: unset;
  -webkit-box-orient: unset;
  max-height: none;
}

/* Read-more button */
.review-controls {
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:8px;
}
.read-more {
  background:transparent;
  border:0;
  color:var(--accent);
  cursor:pointer;
  font-weight:600;
  padding:6px 8px;
  border-radius:8px;
}
.read-more:focus {
  outline:2px solid rgba(255,122,24,0.18);
}

/* Footer / date */
.review-footer {
  text-align:right;
  color:var(--muted);
  font-size:0.85rem;
}

/* Small screens: tighter spacing */
@media (max-width:720px) {
  .review-header {
    flex-direction:column;
    align-items:flex-start;
    gap:6px;
  }
  .review-footer {
    text-align:left;
    margin-top:6px;
  }
}

/* Small utilities */
.hidden{display:none}
.center{display:flex;align-items:center;justify-content:center}

/* Fullscreen image overlay (force center; high specificity) */
.fs-overlay {
  position: fixed !important;
  inset: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: rgba(6,10,20,0.85) !important;
  z-index: 99999 !important;
  padding: 24px;
  animation: overlayFade .16s ease;
}
.fs-overlay img { max-width: 96%; max-height: 96%; border-radius: 12px; box-shadow: 0 20px 60px rgba(2,6,23,0.6); }
.fs-overlay .fs-close {
  position: absolute;
  right: 18px;
  top: 18px;
  width: 36px;
  height: 36px;
  background: rgba(0,0,0,0.6);
  color: #fff;
  border-radius: 6px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 100000;
  font-size: 18px;
}
.fs-overlay .fs-close:hover { background: rgba(0,0,0,0.75); }

@keyframes overlayFade { from { opacity: 0 } to { opacity: 1 } }

/* When overlay/modal open, prevent background scroll */
body.fs-open { overflow: hidden !important; touch-action: none;}

/* Review avatars and work thumbnails */
.review-avatar {
  width:48px;
  height:48px;
  border-radius:50%;
  object-fit:cover;
  border:2px solid rgba(255,122,24,0.08);
  box-shadow: 0 6px 18px rgba(2,6,23,0.04);
}
.work-thumbs {
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:8px;
}
.work-thumb {
  width:80px;
  height:56px;
  object-fit:cover;
  border-radius:8px;
  border:1px solid rgba(15,23,42,0.04);
  box-shadow: 0 6px 12px rgba(2,6,23,0.04);
}
@media (max-width:720px) {
  .work-thumb { width:64px; height:48px; }
  .review-avatar { width:40px; height:40px; }
}

/* Carousel controls inside fs-overlay */
.carousel-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: rgba(0,0,0,0.5);
  color: #fff;
  border: 0;
  width:48px;
  height:64px;
  font-size:28px;
  border-radius:8px;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  z-index:100001;
}
.carousel-nav.prev { left: 8px; }
.carousel-nav.next { right: 8px; }
.carousel-counter {
  position: relative;
  text-align:center;
  z-index:100001;
  font-size:14px;
  color:#fff;
}
.carousel-close {
  position: absolute;
  right: 18px;
  top: 18px;
  z-index:100002;
  background: rgba(0,0,0,0.6);
  color: #fff;
  border-radius:6px;
  width:36px;height:36px;border:0;
  display:inline-flex;align-items:center;justify-content:center;
}
@media (max-width:720px) {
  .carousel-nav { width:40px; height:48px; font-size:22px; }
  .carousel-counter { font-size:13px; }
}

/* Mobile nav: open by class instead of inline styles */
.site-nav{ display:none; } /* already present, keep */
.nav-open .site-nav{
  display:flex !important;
  flex-direction:column;
  gap:8px;
  position:relative;
}
@media(min-width:900px){
  /* desktop keeps existing behavior */
  .nav-open .site-nav { display:flex !important; }
}

/* DEBUG: disable thumbnail hover/transition to rule out hover-induced flicker */
body.debug-no-thumb-hover .media-item,
body.debug-no-thumb-hover .media-item:hover {
  transform: none !important;
  box-shadow: none !important;
  transition: none !important;
}

/* Kalkulátor: layout-fix — wider sidebar so breakdown fits */
#calculator {
  max-width: 1200px;       /* slight increase to overall width */
  margin: 24px auto;
  padding: 0 14px;
  box-sizing: border-box;
}

/* use a wider sidebar column so the breakdown can show without wrapping */
#calculator > .calc-layout,
#calculator .calc-layout {
  display: grid;
  grid-template-columns: 1fr 380px; /* increased from 260/220px to 380px */
  gap: 16px;
  align-items: start;
}

/* Mobile: one column */
@media (max-width: 880px) {
  #calculator > .calc-layout,
  #calculator .calc-layout {
    grid-template-columns: 1fr;
  }
}

/* ensure summary column allows content (prevent forced wrapping) */
#calcSummary {
  min-width: 320px;
  max-width: 100%;
  padding: 12px;
  background: #fbfdff;
  border: 1px solid #eef2f7;
  border-radius: 10px;
  box-sizing: border-box;
  overflow: hidden;
}
#calcBreakdown { min-width: 0; word-break: break-word; overflow-wrap: break-word; }
/* Always-visible header + nav (override near the end of file) */
/* Keeps header fixed during scroll, ensures nav is always visible and
   pushes main content down so it doesn't hide under the fixed header. */

:root {
  --header-h: 64px; /* adjust if header height changes */
}

/* Make header fixed and centered, add subtle backdrop so content under it is readable */
.site-header {
  position: fixed !important;
  top: 12px !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  width: 100% !important;
  max-width: var(--maxw) !important;
  z-index: 120 !important;
  background: rgba(255,255,255,0.90) !important;
  backdrop-filter: blur(6px);
  min-height: var(--header-h);
  padding: 12px 14px !important;
  box-shadow: 0 8px 30px rgba(2,6,23,0.06) !important;
}

/* Always show navigation (desktop + mobile). It will wrap on small screens. */
.site-nav {
  display: flex !important;
  gap: 12px;
  align-items: center;
  flex-wrap: wrap;
}

/* If you still have a nav toggle element, hide it because nav is always visible */
#navToggle,
.nav-toggle {
  display: none !important;
}

/* Make room for the fixed header so page content isn't hidden behind it */
main {
  padding-top: calc(var(--header-h) + 24px); /* header + breathing space */
}

/* Small screens: tighten spacing and allow nav to wrap nicely */
@media (max-width: 720px) {
  :root { --header-h: 88px; } /* taller header on phones if wraps */
  .site-header { padding: 10px 12px; top: 8px; }
  main { padding-top: calc(var(--header-h) + 16px); }
  .site-nav { gap: 8px; }
}

/* Modern rounded nav — append near end of file to override earlier rules */
.site-header { align-items: center; }

/* Pill-style navigation */
.site-header .site-nav {
  display: flex !important;
  margin-left: auto;              /* keep nav to the right of the logo */
  gap: 10px;
  align-items: center;
  padding: 6px;
  background: rgba(15,23,42,0.02);
  border-radius: 999px;
  box-shadow: 0 6px 18px rgba(2,6,23,0.04);
  transition:background .18s ease, box-shadow .18s ease, transform .12s ease;
}

/* Individual links as pills */
.site-header .site-nav a {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  border-radius: 999px;
  color: var(--muted);
  background: transparent;
  text-decoration: none;
  font-weight: 600;
  transition: background .16s ease, color .16s ease, transform .08s ease, box-shadow .12s ease;
  box-shadow: none;
  border: 1px solid transparent;
}

/* Hover / focus states */
.site-header .site-nav a:hover,
.site-header .site-nav a:focus-visible {
  background: linear-gradient(90deg, rgba(255,186,107,0.14), rgba(255,122,24,0.09));
  color: #0b1220;
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(16,24,40,0.06);
  outline: none;
}

/* Active / current page indicator (supports aria-current or .active) */
.site-header .site-nav a[aria-current="page"],
.site-header .site-nav a.active {
  background: linear-gradient(90deg,var(--accent),var(--accent-2));
  color: #fff;
  box-shadow: 0 10px 30px rgba(255,122,24,0.12);
  transform: none;
}

/* Small icon spacing and readable size on mobile */
.site-header .site-nav a .nav-icon {
  display:inline-flex;
  width:18px; height:18px;
  align-items:center; justify-content:center;
  font-size:0.9rem;
}

/* Make sure nav wraps nicely on narrow screens */
@media (max-width: 720px) {
  .site-header .site-nav {
    gap: 8px;
    padding: 8px;
    background: rgba(255,255,255,0.95);
    border-radius: 12px;
    box-shadow: 0 10px 30px rgba(2,6,23,0.06);
    flex-wrap: wrap;
    justify-content: center;
  }
  /* keep links touch-friendly */
  .site-header .site-nav a { padding: 10px 12px; font-size: 0.95rem; }
}

/* Compact logo + company name under logo, smaller nav pills (append to end of file) */

/* reduce header height slightly for the compact look */
:root { --header-h: 56px; }

/* Logo container: stack image and company name vertically */
.site-header .logo {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 4px;
  padding-right: 8px;
  line-height: 1;
}

/* make the logo image smaller and remove extra margin */
.site-header .logo img#siteLogo {
  height: 28px;           /* smaller logo */
  width: auto;
  margin: 0;
  display: block;
}

/* company name under the logo, slightly smaller and bold */
.site-header .logo #siteCompanyName {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--accent);
  display: block;
  margin: 0;
  white-space: nowrap;
}

/* Tighten nav pill container and individual pills */
.site-header .site-nav {
  gap: 8px;
  padding: 4px;
  background: rgba(15,23,42,0.02);
  border-radius: 999px;
}

/* smaller pill buttons */
.site-header .site-nav a {
  padding: 6px 10px;
  font-size: 0.9rem;
  border-radius: 999px;
}

/* reduce hover lift to match compact style */
.site-header .site-nav a:hover,
.site-header .site-nav a:focus-visible {
  transform: translateY(-1px);
  box-shadow: 0 6px 18px rgba(16,24,40,0.05);
}

/* Ensure the header spacing still matches new header height */
main {
  padding-top: calc(var(--header-h) + 20px);
}

/* Mobile adjustments: center logo + name and make nav wrap comfortably */
@media (max-width: 720px) {
  .site-header { align-items: center; }
  .site-header .logo { align-items: center; text-align: center; }
  .site-header .logo img#siteLogo { height: 32px; }
  .site-header .logo #siteCompanyName { font-size: 1rem; }
  .site-header .site-nav { justify-content: center; gap: 6px; padding: 8px; border-radius: 12px; }
  .site-header .site-nav a { padding: 8px 10px; font-size: 0.95rem; }
  :root { --header-h: 80px; } /* allow for wrapping */
}

/* Glass / translucent theme — make panels and header much more transparent */
/* Append this to the end of the file (overrides earlier opaque rules) */

:root{
  --panel: rgba(255,255,255,0.60);       /* translucent panel */
  --panel-strong: rgba(255,255,255,0.75);/* slightly stronger where needed */
  --input-bg: rgba(255,255,255,0.50);    /* form fields */
  --panel-border: rgba(15,23,42,0.06);
  --backdrop-blur: 10px;
}

/* Slightly lighten the page background so glass effect is visible */
body {
  background: linear-gradient(180deg, rgba(238,242,247,0.92) 0%, rgba(246,248,250,0.92) 100%) !important;
}

/* Panels, cards, modals become translucent glass */
.card,
.modal-content,
#calcSummary,
.media-item,
.reviews-list li.review-item,
.site-footer,
.fs-overlay,
.modal,
.work-thumb {
  background: var(--panel) !important;
  border: 1px solid var(--panel-border) !important;
  backdrop-filter: blur(var(--backdrop-blur));
  -webkit-backdrop-filter: blur(var(--backdrop-blur));
}

/* Make header more translucent (keeps readability) */
.site-header {
  background: rgba(255,255,255,0.55) !important;
  border: 1px solid rgba(15,23,42,0.04) !important;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

/* Inputs / selects / textareas: translucent */
.form-card input,
.form-card textarea,
.form-card select,
input, textarea, select {
  background: var(--input-bg) !important;
  border: 1px solid rgba(15,23,42,0.04) !important;
  color: #0f1724 !important;
}

/* Slideshow captions and other little panels slightly stronger */
.slide-caption,
.dots button.active,
.site-header .logo {
  background: linear-gradient(90deg, rgba(255,255,255,0.7), rgba(255,255,255,0.65)) !important;
  backdrop-filter: blur(6px);
}

/* Ensure modals / overlays remain readable */
.modal,
.fs-overlay {
  background: rgba(6,10,20,0.45) !important; /* slightly darker backdrop for contrast */
}

/* Tweak shadows to suit translucency */
:root { --shadow: 0 8px 28px rgba(16,24,40,0.06); }

/* Mobile: reduce blur a little for perf */
@media (max-width:720px) {
  :root { --backdrop-blur: 6px; }
}

/* Header collapse / expand controls */
:root {
  --header-collapsed-h: 56px; /* visible row height when collapsed */
}

/* header toggle button */
.header-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width:40px;
  height:40px;
  margin-left:8px;
  background:transparent;
  border:1px solid rgba(15,23,42,0.04);
  border-radius:8px;
  cursor:pointer;
  color:var(--muted);
  transition:transform .18s ease, background .12s ease;
}
.header-toggle:hover { transform: translateY(-2px); background: rgba(15,23,42,0.02); }

/* Collapsible header behavior */
.site-header {
  transition: max-height .28s ease, padding .18s ease, box-shadow .18s ease;
  will-change: max-height;
  overflow: visible;
}

/* When collapsed, limit visible header area and hide nav content */
body.header-collapsed .site-header {
  max-height: var(--header-collapsed-h) !important;
  overflow: hidden !important;
  box-shadow: 0 6px 20px rgba(2,6,23,0.04);
}

/* visually hide nav and other non-critical header items when collapsed */
body.header-collapsed .site-header .site-nav,
body.header-collapsed .site-header .site-socials {
  opacity: 0;
  pointer-events: none;
  transform: translateY(-4px);
  transition: opacity .18s ease, transform .18s ease;
}

/* shrink logo & company name when collapsed */
body.header-collapsed .site-header .logo img#siteLogo {
  height: 28px !important;
}
body.header-collapsed .site-header .logo #siteCompanyName {
  display: none;
}

/* keep hamburger + header-toggle visible in collapsed state */
body.header-collapsed #navToggle,
body.header-collapsed .header-toggle {
  z-index: 140;
}

/* expanded state (explicit) to ensure smooth transition */
body:not(.header-collapsed) .site-header { max-height: 999px; }

/* small screens: reduce collapsed height a bit */
@media (max-width: 720px) {
  :root { --header-collapsed-h: 68px; }
}

/* --- MOBILE TWEAKS: append to the end of file --- */
/* Improves touch sizes, stacking and gallery layout on small screens */
@media (max-width: 720px) {
  :root {
    --radius: 10px;
    --gap: 10px;
    --maxw: 100%;
    --header-h: 80px;
  }

  body {
    padding: 12px !important;
    font-size: 15px;
  }

  .card {
    padding: 12px !important;
    border-radius: var(--radius) !important;
  }

  /* Header & nav: stack and make buttons touch-friendly */
  .site-header {
    padding: 10px !important;
    top: 8px !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
  }
  .site-header .logo { align-items: center; text-align: center; }
  #worksCategoryBar {
    flex-direction: column;
    align-items: stretch;
    gap: 8px;
  }
  #worksCategoryBar label { margin-left: 0; }
  #worksCategoryBar select,
  #worksCategoryBar button {
    width: 100%;
    min-height: 44px;
  }

  /* Category preview: vertical on narrow screens, smaller thumbs */
  .category-info {
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
  }
  #categoryThumbs { gap: 8px; }
  #categoryThumbs img,
  #categoryThumbs .fs-placeholder {
    width: 120px !important;
    height: 90px !important;
    object-fit: cover;
    border-radius: 8px;
  }

  /* Gallery: 1-2 columns depending on width */
  #publicGallery {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 10px !important;
  }
  @media (max-width: 420px) {
    #publicGallery { grid-template-columns: 1fr !important; }
    #categoryThumbs img,
    #categoryThumbs .fs-placeholder { width: 96px !important; height: 72px !important; }
  }

  /* Make media cards slightly taller and more tappable */
  .media-item img,
  .media-item > div {
    height: 160px !important;
    border-radius: 10px !important;
  }
  .media-item figcaption { font-size: .95rem; padding-top: 8px; }

  /* Buttons & small actions: larger hit area */
  .btn-small, button {
    min-height: 44px;
    padding: 10px 12px;
    touch-action: manipulation;
  }

  /* Modal & overlays: occupy nearly full screen for small devices */
  .modal, .fs-overlay, #mediaModal {
    align-items: center !important;
    justify-content: center !important;
    padding: 10px !important;
  }
  .modal-content, #mediaModal .modal-content {
    width: calc(100% - 20px) !important;
    max-width: 100% !important;
    height: calc(100vh - 20px) !important;
    max-height: calc(100vh - 20px) !important;
    border-radius: 12px !important;
    overflow: auto !important;
  }
  .modal-content iframe, .modal-content video, .modal-content img {
    height: auto !important;
    max-height: calc(100vh - 160px) !important;
  }

  /* Slideshow: reduce height on phones */
  .slideshow {
    height: 48vw !important;
    max-height: 320px;
  }

  /* Reviews / forms: make inputs taller */
  input, textarea, select {
    min-height: 44px;
    font-size: 15px;
  }
}

/* Minor desktop->mobile improvements for very small screens */
@media (max-width: 360px) {
  .site-header .site-nav a { padding: 8px 10px; font-size: .95rem; }
  .card { padding: 10px; }
  #categoryThumbs img, #categoryThumbs .fs-placeholder { width: 88px !important; height: 66px !important; }
}
