/* ==========================================================================
   SOL Concept Salzburg — Design tokens
   Palette:  paper #F6F3EA · ink #2B2A22 · olive-deep #3F4B33
             sage #94A180 · brass #B08D57 · dawn #E7C79A · dusk #4A5240
   Type:     Display  — 'Cormorant Garamond' (wide-tracked small caps)
             Body     — 'Work Sans'
             Utility  — 'Work Sans' 500, tracked, uppercase, small
   Signature: the sun's arc — a single path that carries the day's rhythm
              (Patisserie → FroYo → Daybar) through the whole site.
   ========================================================================== */

:root{
  --paper:#F6F3EA;
  --paper-soft:#EFEBDE;
  --ink:#2B2A22;
  --ink-soft:#5B5A4E;
  --olive:#3F4B33;
  --olive-deep:#2E3626;
  --sage:#94A180;
  --sage-soft:#C7CFB9;
  --brass:#FECB2F;
  --brass-soft:#F7DE8C;
  --brass-dark:#C99A12;
  --dawn:#FBE3A0;
  --dusk:#4A5240;
  --line:#D8D3C2;

  --serif:'Cormorant Garamond', 'Times New Roman', serif;
  --sans:'Work Sans', -apple-system, BlinkMacSystemFont, sans-serif;

  --maxw:1120px;
  --radius:2px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--sans);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}

img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}

.eyebrow{
  font-family:var(--sans);
  font-size:.72rem;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--olive);
  font-weight:600;
}

h1,h2,h3{
  font-family:var(--serif);
  font-weight:500;
  color:var(--ink);
  margin:0;
}

h2.section-title{
  font-size:clamp(1.8rem,3.2vw,2.6rem);
  letter-spacing:.14em;
  text-transform:uppercase;
  text-align:center;
}

.section-title small{
  display:block;
  font-family:var(--sans);
  font-size:.7rem;
  letter-spacing:.3em;
  color:var(--olive);
  text-transform:uppercase;
  font-weight:600;
  margin-bottom:.7rem;
}

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

/* ---------- nav ---------- */
.nav{
  position:fixed;
  top:0;left:0;right:0;
  z-index:50;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:22px 32px;
  transition:background .4s ease, padding .4s ease, box-shadow .4s ease;
}
.nav.scrolled{
  background:rgba(246,243,234,.92);
  backdrop-filter:blur(6px);
  padding:14px 32px;
  box-shadow:0 1px 0 var(--line);
}
.nav-logo{
  font-family:var(--serif);
  font-size:1.5rem;
  letter-spacing:.42em;
  font-weight:600;
  color:var(--olive-deep);
  display:flex;
  align-items:center;
}
.nav-logo-img{
  height:32px;
  width:auto;
  display:block;
}
.nav-links{
  display:flex;
  gap:34px;
  list-style:none;
  margin:0;padding:0;
}
.nav-links a{
  font-size:.72rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  font-weight:600;
  color:var(--ink);
  padding-bottom:4px;
  border-bottom:1px solid transparent;
  transition:border-color .25s ease, color .25s ease;
}
.nav-links a:hover{border-color:var(--brass);color:var(--olive-deep);}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;}

@media (max-width:760px){
  .nav-links{
    position:fixed;
    inset:0 0 0 auto;
    height:100vh;
    width:78vw;
    background:var(--paper);
    flex-direction:column;
    justify-content:center;
    align-items:flex-start;
    padding:0 40px;
    gap:26px;
    transform:translateX(100%);
    transition:transform .4s ease;
    box-shadow:-6px 0 24px rgba(0,0,0,.08);
  }
  .nav-links.open{transform:translateX(0);}
  .nav-toggle{display:block;}
}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:14px 30px;
  font-size:.74rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  font-weight:600;
  border-radius:var(--radius);
  border:1px solid var(--olive-deep);
  cursor:pointer;
  transition:transform .25s ease, background .25s ease, color .25s ease;
}
.btn-solid{background:var(--olive-deep);color:var(--paper);}
.btn-solid:hover{background:var(--olive);transform:translateY(-2px);}
.btn-outline{background:transparent;color:var(--olive-deep);}
.btn-outline:hover{background:var(--olive-deep);color:var(--paper);transform:translateY(-2px);}
.btn-brass{border-color:var(--brass);color:var(--brass-soft);}

/* ---------- hero ---------- */
.hero{
  min-height:100vh;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  position:relative;
  padding:120px 24px 60px;
  background:
    radial-gradient(ellipse at 50% -10%, rgba(176,141,87,.18), transparent 55%),
    linear-gradient(180deg, var(--paper) 0%, var(--paper) 100%);
  overflow:hidden;
}
.hero-mark{
  font-family:var(--serif);
  font-size:clamp(3.2rem,9vw,6.4rem);
  letter-spacing:.5em;
  padding-left:.5em; /* optical centering for tracked text */
  font-weight:500;
  color:var(--olive-deep);
  margin-bottom:22px;
}
.hero-logo{
  width:min(72vw,320px);
  height:auto;
  margin:0 auto 26px;
}
.hero-claim{
  font-family:var(--serif);
  font-style:italic;
  font-size:clamp(1.3rem,2.6vw,1.9rem);
  color:var(--ink-soft);
  max-width:560px;
  margin:0 auto 46px;
}
.hero-ctas{
  display:flex;
  flex-wrap:wrap;
  gap:16px;
  justify-content:center;
}
.hero-scroll{
  position:absolute;
  bottom:34px;
  left:50%;
  transform:translateX(-50%);
  font-size:.65rem;
  letter-spacing:.3em;
  text-transform:uppercase;
  color:var(--ink-soft);
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:8px;
}
.hero-scroll .line{
  width:1px;height:34px;background:var(--olive);
  animation:scrollpulse 2.2s ease-in-out infinite;
}
@keyframes scrollpulse{
  0%,100%{transform:scaleY(.6);opacity:.4;}
  50%{transform:scaleY(1);opacity:1;}
}

/* ---------- sun arc / rhythm section ---------- */
.rhythm{
  padding:110px 0 90px;
  background:linear-gradient(180deg, var(--paper) 0%, var(--paper-soft) 100%);
}
.arc-wrap{
  position:relative;
  max-width:920px;
  margin:60px auto 0;
}
.arc-svg{width:100%;height:auto;display:block;}
.arc-sun{
  filter:drop-shadow(0 0 8px rgba(176,141,87,.5));
}
.rhythm-cards{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:28px;
  margin-top:56px;
}
.rhythm-card{
  border-top:1px solid var(--olive);
  padding-top:18px;
  text-align:center;
}
.rhythm-card .icon{
  font-family:var(--serif);
  font-size:1.6rem;
  color:var(--brass);
  margin-bottom:6px;
  letter-spacing:.05em;
}
.rhythm-card h3{
  font-size:1.35rem;
  letter-spacing:.1em;
  text-transform:uppercase;
  margin-bottom:8px;
}
.rhythm-card p{
  margin:2px 0;
  color:var(--ink-soft);
  font-size:.92rem;
}
@media (max-width:760px){
  .rhythm-cards{grid-template-columns:1fr;gap:34px;}
}

/* ---------- access / location ---------- */
.access{
  padding:100px 0;
  background:var(--olive-deep);
  color:var(--paper);
}
.access .section-title{color:var(--paper);}
.access .section-title small{color:var(--sage-soft);}
.access-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:56px;
  margin-top:56px;
  align-items:start;
}
.access-list{list-style:none;margin:0;padding:0;}
.access-list li{
  display:flex;
  gap:16px;
  padding:18px 0;
  border-bottom:1px solid rgba(246,243,234,.14);
  font-size:.98rem;
}
.access-list li:first-child{border-top:1px solid rgba(246,243,234,.14);}
.access-list b{
  font-family:var(--serif);
  font-size:1.1rem;
  color:var(--brass-soft);
  min-width:120px;
}
.map-frame{
  width:100%;
  aspect-ratio:4/3;
  border:0;
  filter:grayscale(.3) contrast(1.05);
  border-radius:var(--radius);
}
@media (max-width:760px){
  .access-grid{grid-template-columns:1fr;}
}

/* ---------- footer ---------- */
footer{
  background:var(--olive-deep);
  color:var(--sage-soft);
  padding:60px 0 34px;
}
.footer-grid{
  display:flex;
  flex-wrap:wrap;
  justify-content:space-between;
  gap:40px;
  padding-bottom:34px;
  border-bottom:1px solid rgba(246,243,234,.14);
}
.footer-brand{
  font-family:var(--serif);
  font-size:1.6rem;
  letter-spacing:.3em;
  color:var(--paper);
}
.footer-logo{
  height:40px;
  width:auto;
}
.footer-col h4{
  font-family:var(--sans);
  font-size:.68rem;
  letter-spacing:.24em;
  text-transform:uppercase;
  color:var(--brass-soft);
  margin-bottom:12px;
}
.footer-col a, .footer-col p{
  display:block;
  font-size:.9rem;
  color:var(--sage-soft);
  margin:6px 0;
}
.footer-col a:hover{color:var(--paper);}
.footer-bottom{
  display:flex;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:10px;
  padding-top:24px;
  font-size:.76rem;
  color:rgba(199,207,185,.6);
}

/* ---------- generic page (subpages) ---------- */
.page-hero{
  padding:150px 0 60px;
  text-align:center;
  background:var(--paper-soft);
}
.page-hero .eyebrow{display:block;margin-bottom:14px;}
.page-hero h1{
  font-size:clamp(2.2rem,5vw,3.4rem);
  letter-spacing:.1em;
  text-transform:uppercase;
}
.content-section{padding:70px 0;}
.narrow{max-width:720px;margin:0 auto;}

/* ---------- reservation form ---------- */
.form-card{
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:44px;
}
.form-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:22px;
  margin-bottom:22px;
}
@media (max-width:600px){.form-row{grid-template-columns:1fr;}}
.field{display:flex;flex-direction:column;gap:8px;}
.field label{
  font-size:.7rem;
  letter-spacing:.16em;
  text-transform:uppercase;
  font-weight:600;
  color:var(--olive);
}
.field input, .field select{
  font-family:var(--sans);
  font-size:.95rem;
  padding:12px 14px;
  border:1px solid var(--line);
  border-radius:var(--radius);
  background:var(--paper);
  color:var(--ink);
}
.field input:focus, .field select:focus{
  outline:2px solid var(--brass);
  outline-offset:1px;
}
.form-note{
  font-size:.82rem;
  color:var(--ink-soft);
  margin-top:18px;
}

/* ---------- menu page ---------- */
.menu-viewer{
  max-width:620px;
  margin:0 auto;
  border:1px solid var(--line);
  box-shadow:0 30px 60px -30px rgba(43,42,34,.35);
  background:var(--paper);
}
.menu-viewer embed{width:100%;height:80vh;display:block;}
.menu-actions{
  display:flex;justify-content:center;gap:16px;margin-top:30px;flex-wrap:wrap;
}

/* ---------- impressum ---------- */
.imp-block{margin-bottom:30px;}
.imp-block h3{
  font-size:1.1rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  margin-bottom:10px;
  color:var(--olive-deep);
}
.imp-block p{margin:2px 0;color:var(--ink-soft);}

/* reveal-on-scroll */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease, transform .7s ease;}
.reveal.in{opacity:1;transform:translateY(0);}

@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto;}
  .reveal{opacity:1;transform:none;transition:none;}
  .hero-scroll .line{animation:none;}
}
