/* Zeus Gyros & Grill — Menu Card Heritage Theme */
:root{
  --paper:#F5EFE0;
  --paper-d:#EBE3CE;
  --ink:#1A1410;
  --ink-s:#3A2F26;
  --accent:#0D5EAF;
  --accent-d:#074488;
  --muted:#8A7A68;
  --line:#D6C9AE;
  --gold:#B8924A;

  --font-display:'Cormorant', 'Cormorant Garamond', Georgia, serif;
  --font-body:'IBM Plex Mono', ui-monospace, monospace;
}

body{font-family:var(--font-body);font-size:14.5px;line-height:1.7;color:var(--ink);background:var(--paper)}
::selection{background:var(--accent);color:var(--paper)}

/* Demo banner */
.demo-banner{background:var(--ink);color:var(--paper);padding:0.65rem 1rem;font-size:0.76rem;text-align:center;letter-spacing:0.05em}
.demo-banner strong{color:var(--gold)}
.demo-banner a{color:var(--paper);text-decoration:underline;text-decoration-color:var(--gold)}

/* Masthead */
.masthead{padding:1.25rem 2.5rem;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;gap:2rem;position:sticky;top:0;background:var(--paper);z-index:9}
.brand{display:flex;align-items:center;gap:0.85rem}
.brand .orn{width:34px;height:34px;border:1.5px solid var(--accent);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-style:italic;font-size:1.3rem;color:var(--accent);font-weight:500}
.brand-name{font-family:var(--font-display);font-weight:500;font-style:italic;font-size:1.45rem;letter-spacing:-0.005em;line-height:1}
.brand-name a{color:inherit}
.brand-sub{font-size:0.62rem;text-transform:uppercase;letter-spacing:0.22em;color:var(--muted);margin-top:4px;font-weight:500}
.masthead nav{display:flex;gap:1.75rem;font-size:0.78rem;font-weight:500;text-transform:uppercase;letter-spacing:0.14em}
.masthead nav a{padding-bottom:3px;border-bottom:1.5px solid transparent;transition:all 0.2s}
.masthead nav a.active,.masthead nav a:hover{border-bottom-color:var(--accent);color:var(--accent)}

main{flex:1}

/* Hero */
.hero{padding:5.5rem 2.5rem 4.5rem;border-bottom:1px solid var(--line);position:relative}
.hero-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1.1fr 0.9fr;gap:4rem;align-items:center}
.hero-text .eyebrow{font-size:0.7rem;text-transform:uppercase;letter-spacing:0.28em;color:var(--accent);margin-bottom:1.5rem;font-weight:500}
.hero-text h1{font-family:var(--font-display);font-weight:400;font-style:italic;font-size:clamp(3rem,7vw,5.8rem);line-height:1;letter-spacing:-0.015em;margin-bottom:1.75rem;color:var(--ink)}
.hero-text h1 .amp{color:var(--accent);font-style:italic}
.hero-text p{color:var(--ink-s);line-height:1.8;margin-bottom:1.75rem;font-size:0.94rem;max-width:470px}
.hero-text .tag{display:inline-flex;align-items:center;gap:0.5rem;padding:0.35rem 0.9rem;background:var(--paper-d);border:1px solid var(--line);font-size:0.76rem;color:var(--accent);font-weight:500;border-radius:0}
.hero-card{aspect-ratio:4/5;background:linear-gradient(165deg,#1E88D6 0%,#0D5EAF 55%,#063366 100%);padding:2.5rem;display:flex;flex-direction:column;justify-content:space-between;color:var(--paper);position:relative;overflow:hidden;border:1px solid var(--ink)}
.hero-card::before{content:'';position:absolute;inset:14px;border:1px solid rgba(245,239,224,0.35);pointer-events:none}
.hero-card .top{font-family:var(--font-display);font-style:italic;font-weight:400;font-size:2.1rem;line-height:1.2;position:relative;z-index:1}
.hero-card .top em{color:var(--gold)}
.hero-card .mid{display:flex;gap:0.55rem;align-items:center;font-size:0.68rem;text-transform:uppercase;letter-spacing:0.28em;color:rgba(245,239,224,0.85);font-weight:500;margin-top:1rem;position:relative;z-index:1}
.hero-card .mid span{width:22px;height:1px;background:rgba(245,239,224,0.6);display:inline-block}
.hero-card .bot{position:relative;z-index:1}
.hero-card .bot .l{font-size:0.66rem;text-transform:uppercase;letter-spacing:0.25em;color:var(--gold);font-weight:500;margin-bottom:0.5rem}
.hero-card .bot .v{font-family:var(--font-display);font-style:italic;font-size:1.15rem;line-height:1.45}

/* Story */
.story{padding:5rem 2.5rem;background:var(--paper-d);border-bottom:1px solid var(--line);text-align:center}
.story-inner{max-width:720px;margin:0 auto}
.story .k{font-size:0.7rem;text-transform:uppercase;letter-spacing:0.28em;color:var(--accent);margin-bottom:0.85rem;font-weight:500}
.story h2{font-family:var(--font-display);font-weight:400;font-style:italic;font-size:clamp(2rem,4.5vw,3rem);letter-spacing:-0.01em;margin-bottom:1.5rem;line-height:1.1}
.story h2 em{color:var(--accent)}
.story p{color:var(--ink-s);line-height:1.85;font-size:0.95rem}
.story p+p{margin-top:1rem}
.story .dropcap::first-letter{font-family:var(--font-display);font-style:italic;font-size:3.5rem;float:left;line-height:0.9;padding:0.3rem 0.6rem 0 0;color:var(--accent)}

/* Leistungen */
.three{padding:5rem 2.5rem;border-bottom:1px solid var(--line)}
.three-inner{max-width:1080px;margin:0 auto}
.three-head{text-align:center;margin-bottom:3rem}
.three-head .k{font-size:0.7rem;text-transform:uppercase;letter-spacing:0.28em;color:var(--accent);margin-bottom:0.85rem;font-weight:500}
.three-head h2{font-family:var(--font-display);font-weight:400;font-style:italic;font-size:clamp(2rem,4vw,2.8rem);letter-spacing:-0.01em}
.three-head h2 em{color:var(--accent)}
.three-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.th{padding:2rem 1.75rem;border:1px solid var(--line);background:var(--paper);transition:all 0.2s;position:relative}
.th:hover{border-color:var(--accent);transform:translateY(-3px)}
.th .no{font-family:var(--font-display);font-style:italic;font-size:1.2rem;color:var(--accent);margin-bottom:0.75rem;letter-spacing:0.04em}
.th h3{font-family:var(--font-display);font-weight:500;font-style:italic;font-size:1.55rem;margin-bottom:0.6rem;letter-spacing:-0.005em;color:var(--ink)}
.th p{font-size:0.88rem;color:var(--ink-s);line-height:1.7}

/* Info CTA */
.info-cta{padding:5rem 2.5rem;background:var(--ink);color:var(--paper);text-align:center}
.info-cta-inner{max-width:680px;margin:0 auto}
.info-cta .k{font-size:0.7rem;text-transform:uppercase;letter-spacing:0.28em;color:var(--gold);margin-bottom:0.85rem;font-weight:500}
.info-cta h2{font-family:var(--font-display);font-weight:400;font-style:italic;font-size:clamp(2rem,4vw,3rem);letter-spacing:-0.01em;margin-bottom:1.5rem;line-height:1.1}
.info-cta h2 em{color:var(--gold)}
.info-cta .hours{font-family:var(--font-display);font-style:italic;font-size:1.3rem;margin-bottom:2rem;opacity:0.95;line-height:1.6}
.info-cta-buttons{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap}
.btn{padding:0.85rem 1.7rem;font-size:0.78rem;font-weight:500;text-transform:uppercase;letter-spacing:0.18em;border:1.5px solid var(--paper);transition:all 0.2s;border-radius:0;font-family:var(--font-body)}
.btn-fill{background:var(--paper);color:var(--ink)}
.btn-fill:hover{background:var(--gold);border-color:var(--gold);color:var(--ink)}
.btn-line{background:transparent;color:var(--paper)}
.btn-line:hover{background:var(--paper);color:var(--ink)}

/* Kontakt-Sektion auf Startseite */
.kontakt-home{padding:5rem 2.5rem;border-bottom:1px solid var(--line)}
.kontakt-home-inner{max-width:1080px;margin:0 auto;display:grid;grid-template-columns:1fr 1.2fr;gap:3rem;align-items:start}
.kontakt-home h2{font-family:var(--font-display);font-weight:400;font-style:italic;font-size:clamp(1.8rem,3.5vw,2.4rem);margin-bottom:1.5rem}
.kontakt-home h2 em{color:var(--accent)}
.kontakt-home dl{display:grid;grid-template-columns:auto 1fr;gap:0.85rem 1.5rem;font-size:0.9rem}
.kontakt-home dt{font-size:0.66rem;text-transform:uppercase;letter-spacing:0.2em;color:var(--muted);padding-top:0.25rem;font-weight:500}
.kontakt-home dd{color:var(--ink-s);line-height:1.55}
.kontakt-home dd a{border-bottom:1.5px solid var(--gold)}
.kontakt-home dd a:hover{color:var(--accent)}
.map-wrap{border:1px solid var(--line);overflow:hidden}
.map-wrap iframe{width:100%;height:100%;min-height:420px;border:none;display:block}

/* Footer */
footer{padding:1.75rem 2.5rem;background:var(--paper-d);border-top:1px solid var(--line);font-size:0.74rem;color:var(--muted);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:0.75rem;letter-spacing:0.04em}
footer .orn{color:var(--accent);font-family:var(--font-display);font-style:italic;font-size:1.1rem}
footer a:hover{color:var(--accent)}

/* Page-head (karte/kontakt) */
.page-head{padding:4.5rem 2.5rem 3rem;text-align:center;border-bottom:1px solid var(--line)}
.page-head .k{font-size:0.7rem;text-transform:uppercase;letter-spacing:0.28em;color:var(--accent);margin-bottom:1rem;font-weight:500}
.page-head h1{font-family:var(--font-display);font-weight:400;font-style:italic;font-size:clamp(2.8rem,6vw,4.8rem);letter-spacing:-0.015em;line-height:1}
.page-head .lead{margin-top:1rem;color:var(--ink-s);font-size:0.95rem}

/* Menu */
.menu{padding:3.5rem 2.5rem}
.menu-inner{max-width:820px;margin:0 auto}
.menu-group{margin-bottom:3rem}
.menu-group h2{font-family:var(--font-display);font-weight:500;font-style:italic;font-size:1.75rem;padding-bottom:0.6rem;border-bottom:1px solid var(--line);margin-bottom:1.25rem;display:flex;justify-content:space-between;align-items:baseline;color:var(--accent)}
.menu-group h2 .n{font-family:var(--font-body);font-size:0.68rem;text-transform:uppercase;letter-spacing:0.2em;color:var(--muted);font-weight:500;font-style:normal}
.item{display:flex;align-items:baseline;gap:1rem;padding:0.85rem 0;border-bottom:1px dotted var(--line)}
.item:last-child{border-bottom:none}
.item .nm{font-size:1rem;font-weight:500;color:var(--ink)}
.item .nm em{font-style:italic;font-family:var(--font-display);color:var(--accent);font-size:1.15rem}
.item .dots{flex:1;border-bottom:1.5px dotted var(--line);transform:translateY(-5px);margin:0 0.4rem;min-width:20px}
.item .pr{font-family:var(--font-display);font-style:italic;font-size:1.2rem;color:var(--accent);font-weight:500;white-space:nowrap}
.item .dc{display:block;font-size:0.8rem;color:var(--muted);margin-top:0.3rem;line-height:1.5}
.note{max-width:820px;margin:2rem auto 0;padding:1.25rem 1.5rem;background:var(--paper-d);border-left:3px solid var(--accent);font-size:0.9rem;color:var(--ink-s);line-height:1.65;font-family:var(--font-display);font-style:italic;font-size:1.05rem}

/* Kontakt Page */
.kontakt{padding:3.5rem 2.5rem}
.kontakt-inner{max-width:1080px;margin:0 auto;display:grid;grid-template-columns:1fr 1.2fr;gap:3rem;align-items:start}
.info h2{font-family:var(--font-display);font-weight:500;font-style:italic;font-size:1.7rem;margin-bottom:1.25rem;color:var(--accent)}
.info dl{display:grid;grid-template-columns:auto 1fr;gap:0.9rem 1.5rem;font-size:0.92rem}
.info dt{font-size:0.66rem;text-transform:uppercase;letter-spacing:0.2em;color:var(--muted);padding-top:0.25rem;font-weight:500}
.info dd{color:var(--ink-s);line-height:1.55}
.info dd a{border-bottom:1.5px solid var(--gold)}
.info dd a:hover{color:var(--accent)}

/* Form */
.form-wrap{margin-top:2.5rem;padding-top:2rem;border-top:1px solid var(--line)}
.form-wrap h3{font-family:var(--font-display);font-weight:500;font-style:italic;font-size:1.45rem;margin-bottom:1rem;color:var(--accent)}
.form-wrap form{display:grid;gap:1rem}
.form-wrap label{display:block;font-size:0.7rem;text-transform:uppercase;letter-spacing:0.2em;color:var(--muted);margin-bottom:0.4rem;font-weight:500}
.form-wrap input,.form-wrap textarea{width:100%;padding:0.75rem 0.9rem;border:1px solid var(--line);background:var(--paper);font-family:var(--font-body);font-size:0.9rem;color:var(--ink);border-radius:0}
.form-wrap input:focus,.form-wrap textarea:focus{outline:none;border-color:var(--accent)}
.form-wrap textarea{min-height:110px;resize:vertical}
.form-wrap button{padding:0.85rem 1.7rem;background:var(--accent);color:var(--paper);font-family:var(--font-body);font-size:0.78rem;font-weight:500;text-transform:uppercase;letter-spacing:0.18em;border:none;cursor:pointer;transition:background 0.2s;justify-self:start}
.form-wrap button:hover{background:var(--accent-d)}

/* Responsive */
@media(max-width:880px){
  .hero{padding:3.5rem 1.25rem 3rem}
  .hero-inner{grid-template-columns:1fr;gap:2.5rem}
  .hero-card{aspect-ratio:3/2}
  .story,.three,.info-cta,.kontakt-home{padding:3.5rem 1.25rem}
  .three-grid{grid-template-columns:1fr;gap:1.25rem}
  .kontakt-home-inner,.kontakt-inner{grid-template-columns:1fr;gap:2rem}
}
@media(max-width:780px){
  .masthead{flex-direction:column;gap:0.85rem;padding:1rem 1.25rem}
  .masthead nav{flex-wrap:wrap;gap:1.1rem;justify-content:center}
  footer{padding:1.25rem;justify-content:center;text-align:center}
  .page-head{padding:3rem 1.25rem 2rem}
  .menu,.kontakt{padding:2.5rem 1.25rem}
}
