/* Mobile responsive overrides */

@media (max-width: 768px) {
  .hamburger {
    display: flex;
    flex-direction: column;
    gap: 6px;
    background: none;
    border: none;
    cursor: pointer;
    padding: 8px;
    inline-size: 44px;
    block-size: 44px;
    justify-content: center;
    align-items: center;
    position: absolute;
    inset-inline-end: 1rem;
    inset-block-start: 50%;
    transform: translateY(-50%);
    border-radius: 8px;
    transition: background-color 0.3s ease;
  }

  .hamburger:hover {
    background-color: rgba(157, 95, 56, 0.1);
  }

  .hamburger span {
    inline-size: 100%;
    block-size: 3px;
    background: var(--accent);
    border-radius: 2px;
    transition: all 0.3s ease;
    display: block;
  }

  .hamburger.active span:nth-child(1) {
    transform: rotate(45deg) translate(8px, 8px);
  }

  .hamburger.active span:nth-child(2) {
    opacity: 0;
  }

  .hamburger.active span:nth-child(3) {
    transform: rotate(-45deg) translate(7px, -7px);
  }

  .nav {
    min-block-size: 60px;
    padding: 0.45rem 0;
    justify-content: center;
    gap: 0.5rem;
    position: relative;
  }

  .brand {
    font-size: 1rem;
  }

  .nav-links {
    position: absolute;
    inset-block-start: 60px;
    inset-inline-start: 0;
    inset-inline-end: 0;
    background: #f4ece5c9;
    border-block-end: 1px solid var(--line);
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    max-block-size: 0;
    overflow: hidden;
    transition: max-height 0.3s ease;
    z-index: 20;
    gap: 0;
    font-size: 0.92rem;
  }

  .nav-links.active {
    max-block-size: 400px;
  }

  .nav-links a {
    padding: 0.75rem 1.2rem;
    border-block-end: 1px solid var(--line);
    display: block;
  }

  .nav-links a:last-child {
    border-block-end: none;
  }

  .container {
    inline-size: calc(100% - 1.2rem);
  }

  .hero {
    padding: 2rem 0 1.2rem;
  }

  .hero-grid,
  .home-columns {
    grid-template-columns: 1fr;
  }

  .hero-copy {
    padding: 1rem 0.8rem;
    border-radius: 18px;
  }

  .hero-media img {
    min-block-size: 220px;
  }

  .hero-card {
    position: static;
    margin-block-start: 0.8rem;
    max-inline-size: none;
    color: var(--coffee-900);
    background: linear-gradient(180deg, #fff8f4, #fff4ea);
    border: 1px solid var(--line);
  }

  .menu-grid,
  .specials-grid,
  .quick-contact-grid,
  .reviews-grid {
    grid-template-columns: 1fr;
  }

  .menu-card,
  .special-card,
  .contact-card {
    padding: 0.85rem;
  }

  .metrics {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.5rem;
    justify-items: center;
  }

  .metrics div {
    text-align: center;
    inline-size: 100%;
  }

  .metrics div:last-child:nth-child(odd) {
    grid-column: 1 / -1;
    max-inline-size: 50%;
    margin-inline: auto;
  }

  .metrics strong,
  .metrics span {
    text-align: center;
    display: block;
  }

  .section {
    padding: 1.6rem 0;
  }

  .hero-media {
    border-radius: 14px;
  }

  .about-grid,
  .contact-grid {
    grid-template-columns: 1fr;
  }

  .photo-stack {
    grid-template-columns: 1fr;
  }

  /* Centrovanie */
  h1,
  h2,
  h3 {
    text-align: center;
  }

  p {
    text-align: center;
  }

  .eyebrow {
    text-align: center;
  }

  .section-head {
    flex-direction: column;
    align-items: center;
    text-align: center;
  }

  .section-head p {
    margin-inline: auto;
  }

  .menu-card,
  .special-card,
  .contact-card,
  .hero-card {
    text-align: center;
  }

  .panel,
  .panel p,
  .panel h2,
  .panel h3 {
    text-align: center;
  }

  .facts {
    text-align: start;
    display: inline-block;
    padding-inline-start: 0;
  }

  .facts li {
    text-align: center;
    list-style: none;
  }

  .button-row {
    justify-content: center;
  }

  .btn {
    display: block;
    inline-size: 100%;
    text-align: center;
    box-sizing: border-box;
  }

  .panel > .btn {
    display: block;
    inline-size: 100%;
    text-align: center;
    box-sizing: border-box;
    margin-block-start: 0.75rem;
  }

  .event-list li {
    text-align: center;
  }

  .event-note {
    text-align: center;
  }

  .review-head-side {
    justify-items: center;
  }

  .review-card strong {
    display: block;
    text-align: center;
  }

  .review-card p {
    text-align: center;
  }

  .review-stars {
    text-align: center;
  }

  .hours div {
    justify-content: center;
  }

  .footer-wrap {
    flex-direction: column;
    text-align: center;
  }
}

@media (min-width: 769px) {
  .hamburger {
    display: none;
  }

  .nav-links {
    position: relative !important;
    inset-block-start: auto !important;
    inset-inline-start: auto !important;
    inset-inline-end: auto !important;
    background: none !important;
    border-block-end: none !important;
    max-block-size: none !important;
  }

  .nav-links a {
    border-block-end: none !important;
  }
}

@media (max-width: 480px) {
  .container {
    inline-size: calc(100% - 1rem);
  }

  .nav {
    min-block-size: 50px;
  }

  .brand {
    font-size: 0.95rem;
  }

  .button-row {
    flex-direction: column;
    gap: 0.6rem;
  }

  .btn {
    inline-size: 100%;
    text-align: center;
  }

  h1 {
    font-size: clamp(1.5rem, 4vw, 2.25rem);
  }

  h2 {
    font-size: clamp(1.3rem, 2.5vw, 1.8rem);
  }
}

a.btn {
    text-align: center;
    display: flex;
    justify-content: center;
    align-items: center;
  }