/* ===========================================================
   Nasyp si — bezobalový obchod Brno
   Warm, paper-like, hand-made feeling. Mobile-first.
   =========================================================== */

:root{
  --cream:        #f7eedc;
  --cream-soft:   #fbf5e6;
  --paper:        #fff8ea;
  --ink:          #1f2a1c;
  --ink-soft:     #3e4b36;
  --moss:         #6d8a61;
  --moss-deep:    #2d3a2a;
  --terra:        #c56a3a;
  --terra-deep:   #a8512a;
  --mustard:      #d9a441;
  --line:         rgba(45,58,42,.18);

  --serif: "Fraunces", "Iowan Old Style", Georgia, serif;
  --sans:  "Inter", system-ui, -apple-system, "Helvetica Neue", Arial, sans-serif;

  --maxw: 1120px;
  --pad:  clamp(1.1rem, 4vw, 2.2rem);
  --r:    16px;
}

/* -------- reset-ish -------- */
*,*::before,*::after{ box-sizing:border-box; }
html{
  scroll-behavior:smooth;
  -webkit-text-size-adjust:100%;
  -webkit-tap-highlight-color: rgba(197,106,58,.18);
}
body{
  margin:0;
  font-family:var(--sans);
  font-size:17px;
  line-height:1.6;
  color:var(--ink);
  background:var(--cream);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
  /* long Czech words wrap cleanly on narrow screens */
  overflow-wrap: break-word;
  word-wrap: break-word;
  hyphens: auto;
}
img,svg{ display:block; max-width:100%; height:auto; }
img{ font-style:italic; } /* visible hint when src fails to load */
a{ color:inherit; text-decoration:none; }
a:focus-visible, button:focus-visible{
  outline:3px solid var(--terra);
  outline-offset:3px;
  border-radius:6px;
}

/* subtle paper grain everywhere */
body::before{
  content:"";
  position:fixed; inset:0;
  pointer-events:none;
  z-index:1;
  opacity:.35;
  mix-blend-mode:multiply;
  background-image:
    radial-gradient(rgba(45,58,42,.08) 1px, transparent 1px),
    radial-gradient(rgba(197,106,58,.06) 1px, transparent 1px);
  background-size: 3px 3px, 7px 7px;
  background-position: 0 0, 1px 2px;
}

.skip{
  position:absolute; left:-9999px; top:0;
  background:var(--ink); color:var(--cream); padding:.6rem 1rem;
}
.skip:focus{ left:1rem; top:1rem; z-index:100; }

.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 var(--pad); }

/* ===========================================================
   Navigation
   =========================================================== */
.nav{
  position:sticky; top:0; z-index:50;
  display:flex; align-items:center; justify-content:space-between;
  gap:1rem;
  padding:.35rem var(--pad);
  background:rgba(247,238,220,.85);
  backdrop-filter:saturate(140%) blur(8px);
  -webkit-backdrop-filter:saturate(140%) blur(8px);
  border-bottom:1px solid var(--line);
}
.brand{
  display:inline-flex; align-items:center; gap:.55rem;
  color:var(--ink);
  font-family:var(--serif);
  font-weight:700;
  font-size:1.25rem;
  letter-spacing:-.01em;
}
.brand-mark{ width:64px; height:64px; object-fit:contain; }
.brand-name .dot{ color:var(--terra); }

.nav-menu{
  display:flex; align-items:center; gap:.25rem;
}
.nav-menu a{
  padding:.6rem .9rem;
  font-weight:500;
  font-size:.97rem;
  border-radius:999px;
  transition:background .2s, color .2s;
  min-height: 44px;
  display: inline-flex;
  align-items: center;
}
.nav-menu a:hover{ background:var(--paper); color:var(--terra-deep); }

.nav-toggle{
  display:none;
  width:42px; height:42px;
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:12px;
  cursor:pointer;
  position:relative;
}
.nav-toggle span{
  position:absolute; left:9px; right:9px; height:2px;
  background:var(--ink);
  transition:transform .25s, opacity .2s, top .25s;
}
.nav-toggle span:nth-child(1){ top:13px; }
.nav-toggle span:nth-child(2){ top:20px; }
.nav-toggle span:nth-child(3){ top:27px; }
.nav-toggle[aria-expanded="true"] span:nth-child(1){ top:20px; transform:rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3){ top:20px; transform:rotate(-45deg); }

@media (max-width: 760px){
  .nav-toggle{ display:block; }
  .nav-menu{
    position:absolute; top:100%; left:0; right:0;
    flex-direction:column; align-items:stretch;
    gap:0;
    background:var(--cream);
    border-bottom:1px solid var(--line);
    padding:.5rem var(--pad) 1rem;
    transform:translateY(-12px);
    opacity:0; pointer-events:none;
    transition:opacity .2s, transform .2s;
  }
  .nav-menu.is-open{
    opacity:1; pointer-events:auto; transform:none;
  }
  .nav-menu a{
    padding:.85rem .25rem;
    border-bottom:1px dashed var(--line);
    border-radius:0;
  }
  .nav-menu a:last-child{ border-bottom:0; }
}

/* ===========================================================
   Typography
   =========================================================== */
h1,h2,h3{
  font-family:var(--serif);
  color:var(--ink);
  font-weight:700;
  letter-spacing:-.015em;
  line-height:1.1;
  margin:0 0 .6em;
}
h2{ font-size:clamp(1.9rem, 4.5vw, 3rem); }
h3{ font-size:1.2rem; line-height:1.25; }
p{ margin:0 0 1em; }
.lead{ font-size:1.1rem; color:var(--ink-soft); }
.lead.narrow{ max-width:48ch; }
.eyebrow{
  display:inline-block;
  font-family:var(--sans);
  font-size:.78rem;
  font-weight:600;
  letter-spacing:.18em;
  text-transform:uppercase;
  /* terra-deep for WCAG AA contrast on cream backgrounds (5:1) */
  color:var(--terra-deep);
  margin:0 0 1.2rem;
}
.eyebrow-dark{ color:var(--moss-deep); }

/* ===========================================================
   Buttons
   =========================================================== */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.5rem;
  padding:.85rem 1.3rem;
  min-height: 44px;
  font-weight:600;
  font-size:.97rem;
  border-radius:999px;
  transition:transform .15s, background .2s, color .2s, box-shadow .2s;
  border:1.5px solid transparent;
  cursor:pointer;
  text-decoration: none;
}
.btn-primary{
  background:var(--ink);
  color:var(--cream-soft);
}
.btn-primary:hover{
  background:var(--terra-deep); color:var(--cream-soft);
  transform:translateY(-1px);
  box-shadow:0 8px 20px -10px rgba(168,81,42,.6);
}
.btn-ghost{
  background:transparent;
  color:var(--ink);
  border-color:var(--ink);
}
.btn-ghost:hover{
  background:var(--ink); color:var(--cream-soft);
  transform:translateY(-1px);
}

/* ===========================================================
   Hero
   =========================================================== */
.hero{
  position:relative;
  padding: clamp(2rem, 6vw, 4.5rem) var(--pad) clamp(3rem, 8vw, 6rem);
  overflow:hidden;
}
.hero-grain{
  position:absolute; inset:0;
  background:
    radial-gradient(1100px 400px at 80% 0%, rgba(217,164,65,.18), transparent 60%),
    radial-gradient(800px 500px at 0% 100%, rgba(109,138,97,.18), transparent 60%);
  pointer-events:none; z-index:0;
}
.hero-inner{
  position:relative; z-index:1;
  max-width:var(--maxw); margin:0 auto;
  display:grid; grid-template-columns: minmax(0,1fr);
  gap:2rem;
}
.hero-title{
  font-family:var(--serif);
  font-size: clamp(2.6rem, 8vw, 5.4rem);
  line-height:.98;
  margin:.4rem 0 1.4rem;
  letter-spacing:-.025em;
}
.hero-title em{
  display:block;
  font-style:italic;
  font-weight:500;
  color:var(--moss-deep);
}
.hero-title span:last-of-type{
  color:var(--terra-deep);
}
.hero-lead{
  font-size:clamp(1.05rem, 1.6vw, 1.25rem);
  max-width:54ch;
  color:var(--ink-soft);
}
.hero-cta{
  display:flex; flex-wrap:wrap; gap:.7rem;
  margin-top:1rem;
}
.hero-illo{
  order: -1;               /* mobile: illustration above copy */
  margin: 0 auto 1rem;
  width:100%;
  max-width:420px;
  height:auto;
  align-self:center;
  justify-self:center;
}
.hero-copy{ min-width:0; }
@media (prefers-reduced-motion: reduce){
  .hero-illo .stream{ display:none; }
  html{ scroll-behavior:auto; }
}

@media (min-width: 860px){
  .hero-inner{
    grid-template-columns: .9fr 1.1fr;   /* illustration | copy */
    align-items:center;
    gap:3rem;
  }
  .hero-illo{
    order:0;                /* desktop: natural DOM order = left column */
    margin:0;
    justify-self:start;
    max-width:100%;
  }
}

.scroll-hint{
  position:absolute;
  left:50%; bottom:1.2rem;
  transform:translateX(-50%);
  width:38px; height:38px;
  display:grid; place-items:center;
  border:1.5px solid var(--ink);
  border-radius:999px;
  font-size:1rem;
  z-index:2;
  animation:bob 2.2s ease-in-out infinite;
}
/* On narrow screens the hero is short and the arrow overlaps CTAs */
@media (max-width: 760px){
  .scroll-hint{ display:none; }
}
@keyframes bob{ 0%,100%{ transform:translate(-50%,0); } 50%{ transform:translate(-50%,6px); } }

/* ===========================================================
   Sections
   =========================================================== */
.section{
  position:relative;
  padding: clamp(3rem, 7vw, 5.5rem) 0;
  z-index:2;
}
.section-about{ background:var(--cream-soft); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.section-assort{ background:var(--cream); }
.section-how{
  background:var(--moss-deep);
  color:var(--cream-soft);
}
.section-how h2,
.section-how h3{ color:var(--cream-soft); }
.section-how .eyebrow{ color:var(--mustard); }
.section-contact{
  background:var(--terra);
  color:var(--cream-soft);
}
.section-contact h2,
.section-contact .eyebrow{ color:var(--cream-soft); }
.section-contact .eyebrow{ opacity:.85; }
.section-contact .lead{ color:rgba(255,248,234,.9); }

.two-col{
  display:grid; gap:2.5rem;
  grid-template-columns: 1fr;
  align-items:center;
}
@media (min-width: 860px){
  .two-col{ grid-template-columns: 1.1fr .9fr; gap:4rem; }
}

/* ===========================================================
   About
   =========================================================== */
.pills{
  list-style:none; padding:0; margin:1.5rem 0 0;
  display:flex; flex-wrap:wrap; gap:.5rem;
}
.pills li{
  background:var(--paper);
  border:1px solid var(--line);
  padding:.4rem .85rem;
  border-radius:999px;
  font-size:.9rem;
  font-weight:500;
}
.about-card{
  display:grid; place-items:center;
  padding:1.5rem;
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:24px;
  box-shadow:
    0 1px 0 rgba(255,255,255,.6) inset,
    0 30px 60px -40px rgba(45,58,42,.4);
}
.about-card img{
  width:min(340px, 100%); height:auto;
  display:block;
}

/* ===========================================================
   Sortiment cards
   =========================================================== */
.cards{
  list-style:none; padding:0; margin:2.4rem 0 1.5rem;
  display:grid; gap:1rem;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}
.card{
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:18px;
  padding:1.4rem 1.3rem 1.5rem;
  transition: transform .2s, box-shadow .2s, border-color .2s;
}
.card:hover{
  transform: translateY(-3px);
  border-color: var(--terra);
  box-shadow: 0 18px 30px -22px rgba(168,81,42,.45);
}
.card-emoji{
  display:inline-block;
  font-size:1.7rem;
  margin-bottom:.4rem;
  filter: saturate(.9);
}
.card h3{ margin-bottom:.3rem; }
.card p{ margin:0; color:var(--ink-soft); font-size:.96rem; }
.note{
  margin-top:.5rem;
  font-size:.94rem;
  color:var(--ink-soft);
}
.note a{
  text-decoration:underline;
  text-decoration-thickness:2px;
  text-underline-offset:3px;
  text-decoration-color: var(--terra);
}
.note a:hover{ color:var(--terra-deep); }

/* ===========================================================
   How it works
   =========================================================== */
.steps{
  list-style:none; padding:0; margin:2.5rem 0 3rem;
  display:grid; gap:1.5rem;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}
.steps li{
  position:relative;
  background: rgba(255,248,234,.06);
  border:1px solid rgba(247,238,220,.15);
  padding:1.7rem 1.4rem 1.6rem;
  border-radius:18px;
}
.step-num{
  font-family:var(--serif);
  font-size:2.2rem;
  font-weight:700;
  color:var(--mustard);
  display:block;
  margin-bottom:.4rem;
  line-height:1;
}
.steps p{ color:rgba(247,238,220,.85); margin:0; }


/* ===========================================================
   Visit + Contact (merged)
   =========================================================== */
.visit-grid{
  display:grid; gap:2rem;
  grid-template-columns: 1fr;
  align-items:start;
  margin-top: 2rem;
}
@media (min-width: 820px){
  .visit-grid{ grid-template-columns: 1.1fr .9fr; gap:3rem; align-items:start; }
}
.map-card{ max-width: 400px; margin-inline: auto; width:100%; }
@media (min-width: 820px){
  .map-card{ margin-inline: 0; justify-self:end; align-self:start; }
}

.visit-info{ min-width:0; }
.visit-block{
  font-style:normal;
  font-size:1.1rem;
  margin: 0 0 1.3rem;
  line-height:1.55;
  color: var(--cream-soft);
}
.hours{
  margin:0 0 1.5rem;
  display:grid; grid-template-columns: max-content 1fr;
  gap:.4rem 1.4rem;
  font-size:1rem;
}
.hours dt{ font-weight:600; color:var(--cream-soft); }
.hours dd{ margin:0; color:rgba(255,248,234,.8); }

.map-card{
  background:var(--paper);
  color:var(--ink);
  border:1px solid rgba(0,0,0,.06);
  border-radius:20px;
  padding:.5rem .5rem .75rem;
  box-shadow: 0 30px 60px -30px rgba(45,58,42,.55);
}
@media (min-width: 820px){
  .map-card{ padding:1rem; border-radius:24px; }
}
.map-link{
  display:inline-block;
  margin: .7rem .3rem 0;
  font-size:.92rem;
  font-weight:600;
  color: var(--terra-deep);
  text-decoration: underline;
  text-decoration-thickness: 2px;
  text-underline-offset: 3px;
}
.map-link:hover{ color: var(--ink); }
.map-card svg,
.map-card .map-frame{
  width:100%;
  border-radius:16px;
  display:block;
}
.map-card .map-frame{
  height: 350px;
  border: 1px solid rgba(0,0,0,.08);
  background: #efe5cd;
  overflow: hidden;
  /* warm the cool Carto tiles slightly toward our cream palette */
  filter: sepia(.18) saturate(.9) hue-rotate(-6deg);
}

/* Custom Leaflet pin */
.pin{ pointer-events:auto; }
.pin .pin-dot{
  position:absolute; inset:0;
  width:22px; height:22px;
  background: var(--terra);
  border: 4px solid var(--cream-soft);
  border-radius: 50%;
  box-shadow:
    0 0 0 1.5px var(--terra-deep),
    0 6px 12px -3px rgba(0,0,0,.45);
}
.pin::before{
  content:'';
  position:absolute;
  left:50%; top:50%;
  width:22px; height:22px;
  margin:-11px 0 0 -11px;
  border-radius:50%;
  background: var(--terra);
  opacity:.45;
  animation: pin-pulse 2s ease-out infinite;
  pointer-events:none;
}
@keyframes pin-pulse{
  0%   { transform: scale(.6); opacity:.5; }
  100% { transform: scale(2.4); opacity:0; }
}
@media (prefers-reduced-motion: reduce){
  .pin::before{ animation:none; opacity:0; }
}

/* Tone Leaflet UI to match the palette */
.leaflet-container{
  font-family: var(--sans);
  background: #efe5cd;
}
.leaflet-control-zoom a{
  background:#fff8ea !important;
  color:#2d3a2a !important;
  border-color: rgba(0,0,0,.12) !important;
}
.leaflet-control-zoom a:hover{
  background: var(--terra) !important;
  color:#fff8ea !important;
}
.leaflet-control-attribution{
  background: rgba(255,248,234,.85) !important;
  color:#3e4b36 !important;
  font-size: 10px !important;
}
.leaflet-control-attribution a{ color: var(--terra-deep) !important; }
.leaflet-popup-content-wrapper{
  background: #fff8ea !important;
  color: var(--ink) !important;
  border-radius: 12px !important;
  box-shadow: 0 10px 24px -8px rgba(0,0,0,.35) !important;
}
.leaflet-popup-tip{ background:#fff8ea !important; }
.leaflet-popup-content{ font-family: var(--sans); margin: .6rem .8rem; line-height:1.4; }
.map-sub{
  margin: .8rem .3rem 0;
  font-size:.92rem;
  color:var(--ink-soft);
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: .5rem;
}
.map-sub a{
  color: var(--terra-deep);
  font-weight: 600;
  text-decoration: underline;
  text-decoration-thickness: 2px;
  text-underline-offset: 3px;
}
.map-sub a:hover{ color: var(--ink); }

/* Button variant used on terracotta bg */
.btn-paper{
  background: var(--cream-soft);
  color: var(--terra-deep);
}
.btn-paper:hover{
  background: var(--ink);
  color: var(--cream-soft);
  transform: translateY(-1px);
}

.extra-note{
  margin: 2.5rem auto 0;
  max-width: 56ch;
  padding-top: 1.6rem;
  border-top: 1px dashed rgba(255,248,234,.3);
  text-align: center;
  font-size: .95rem;
  color: rgba(255,248,234,.85);
}
.extra-note strong{ color: var(--cream-soft); font-weight: 600; }

/* ===========================================================
   Contact
   =========================================================== */
.contact-grid{
  display:grid; gap:1rem;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  margin-top:3rem;
  padding-top: 2rem;
  border-top: 1px dashed rgba(255,248,234,.3);
}
.contact-tile{
  display:grid; gap:.25rem;
  background: rgba(255,248,234,.12);
  border:1.5px solid rgba(255,248,234,.25);
  padding:1.3rem 1.3rem;
  border-radius:18px;
  transition: background .2s, transform .15s, border-color .2s;
}
.contact-tile:hover{
  background: rgba(255,248,234,.95);
  color: var(--terra-deep);
  border-color: var(--cream-soft);
  transform: translateY(-2px);
}
.tile-label{
  font-size:.78rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  opacity:.85;
}
.tile-value{
  font-family:var(--serif);
  font-size: clamp(1.1rem, 1rem + .6vw, 1.35rem);
  font-weight:700;
  letter-spacing:-.01em;
  /* atomic strings (email, handle, phone) must not be hyphenated or
     broken mid-token by the global body rule */
  hyphens: none;
  overflow-wrap: normal;
  word-break: normal;
  white-space: nowrap;
}

/* ===========================================================
   Footer
   =========================================================== */
.foot{
  background:var(--moss-deep);
  color:var(--cream-soft);
  padding: 1.6rem 0;
  font-size:.92rem;
}
.foot-inner{
  display:flex; flex-wrap:wrap; gap:1rem;
  justify-content:space-between; align-items:center;
}
.foot p{ margin:0; }
.foot-love{ color:var(--mustard); font-style:italic; }

/* ===========================================================
   Reveal on scroll
   =========================================================== */
.reveal{
  opacity:0;
  transform: translateY(18px);
  transition: opacity .7s ease, transform .7s ease;
}
.reveal.is-in{ opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce){
  .reveal{ opacity:1; transform:none; transition:none; }
}
