/* =========================
   hassan-teppiche.de theme
   ========================= */
:root{
  --bg:#faf7f2;
  --fg:#222;
  --muted:#555;
  --brand:#a62822;   /* Bordeaux/Rot */
  --brand-2:#5b2c25; /* Dunkelrotbraun */
  --card:#fff;
  --line:rgba(0,0,0,.08);
}

/* Offline-Fonts */
@font-face{
  font-family:"InterVar";
  src:url("/fonts/inter-var.woff2") format("woff2-variations");
  font-weight:100 900; font-style:normal; font-display:swap;
}
@font-face{
  font-family:"Playfair";
  src:url("/fonts/playfair-display-700.woff2") format("woff2");
  font-weight:700; font-style:normal; font-display:swap;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--bg);color:var(--fg);
  font-family:InterVar,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,"Helvetica Neue",Arial,sans-serif;
  line-height:1.65;
}
a{color:inherit;text-decoration:none}
img,video{max-width:100%;height:auto}
.container{max-width:1120px;margin:0 auto;padding:0 16px}

/* Header / Burger */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(250,247,242,.9); backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line)
}
.nav{display:flex;align-items:center;justify-content:space-between;padding:10px 0}
.brand{display:flex;gap:12px;align-items:center}
.brand .dot{width:14px;height:14px;border-radius:999px;background:var(--brand)}
.brand-link{font-family:Playfair,serif;font-weight:700;letter-spacing:.3px;font-size:1.25rem;color:#2a2a2a}
.links{display:flex;gap:16px;align-items:center}
.links a{font-weight:700;font-size:.95rem;color:#2a2a2a}

.menu-toggle{display:none;flex-direction:column;gap:4px;width:38px;height:38px;background:none;border:none;cursor:pointer}
.menu-toggle .bar{width:26px;height:3px;background:#2a2a2a;border-radius:2px;transition:.3s}
.menu-toggle.active .bar:nth-child(1){transform:translateY(7px) rotate(45deg)}
.menu-toggle.active .bar:nth-child(2){opacity:0}
.menu-toggle.active .bar:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
@media (max-width:880px){
  .menu-toggle{display:flex}
  .links{
    position:absolute; top:64px; right:0; left:0; background:#fff;
    flex-direction:column; align-items:center; gap:18px; padding:24px 0;
    border-bottom:1px solid var(--line); transform:translateY(-150%); transition:.35s;
  }
  .links.show{transform:translateY(0)}
}
@media (min-width:881px){ .links{display:flex !important; position:static; transform:none; padding:0; background:none} }

/* Buttons */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:12px 16px;border-radius:12px;font-weight:800;
  border:1px solid var(--line);background:#fff;transition:.2s;
  box-shadow:0 2px 8px rgba(0,0,0,.05)
}
.btn:hover{transform:translateY(-1px);box-shadow:0 4px 14px rgba(0,0,0,.08)}
.btn.small{padding:8px 12px;font-size:.9rem}
.btn.accent{background:var(--brand);color:#fff;border-color:transparent}
.btn.ghost{background:transparent}

/* Hero */
.hero{background:linear-gradient(180deg,#fff, #faf7f2 60%)}
.hero-inner{text-align:center;padding:52px 0}
.kicker{
  color:#7f1d1d;background:#fdecec;border:1px solid #e6b3b3;
  padding:6px 10px;border-radius:999px;font-weight:900;letter-spacing:.06em;text-transform:uppercase;display:inline-block
}
h1{
  font-family:Playfair,serif;font-weight:700;
  font-size:clamp(28px,4vw,44px);margin:.6rem 0 0;color:#1b1b1b
}
.sub{color:#3a3a3a;max-width:850px;margin:10px auto 0}
.cta-stack{margin-top:16px;display:flex;flex-wrap:wrap;gap:12px;justify-content:center}
.btn-cta{
  min-width:240px;display:flex;align-items:center;gap:12px;padding:12px 16px;
  background:#fff;color:#1c1c1c;border:1px solid var(--line);border-radius:14px;box-shadow:0 2px 8px rgba(0,0,0,.05)
}
.btn-cta .ico{
  width:36px;height:36px;border-radius:10px;background:#fdecec;color:#a62822;
  display:inline-flex;align-items:center;justify-content:center;flex:0 0 36px
}
.btn-cta .cta-content{display:flex;flex-direction:column;line-height:1.25}
.btn-cta .cta-title{font-weight:800}
.btn-cta .cta-detail{font-size:.95rem;color:#333}
.inline-cta.centered{justify-content:center;margin-top:16px}

/* Sections */
.section{padding:56px 0}
.section.alt{background:#fff;border-block:1px solid var(--line)}
h2{font-family:Playfair,serif;font-weight:700;font-size:clamp(22px,3vw,32px);margin:0 0 10px;color:#1b1b1b}
.muted{color:var(--muted)}
.small{font-size:.92rem}

/* Cards */
.cards{display:grid;gap:16px;margin-top:14px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.cards.three{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.card{
  background:var(--card);border:1px solid var(--line);border-radius:14px;padding:18px;
  box-shadow:0 3px 10px rgba(0,0,0,.06);min-height:160px;display:flex;flex-direction:column;gap:6px
}
.card h3{margin:0 0 6px;color:var(--brand-2)}

/* Footer */
.site-footer{border-top:1px solid var(--line);padding:24px 0;color:var(--muted);font-size:.95rem;background:#fff;text-align:center}

/* Tooltips (DSGVO-Hinweis) */
.has-tooltip{position:relative;z-index:1}
.has-tooltip::after{
  content:attr(data-tooltip);
  position:absolute;bottom:130%;left:50%;transform:translateX(-50%);
  width:240px;background:rgba(0,0,0,.9);color:#fff;padding:8px 10px;border-radius:8px;
  font-size:.78rem;line-height:1.3;text-align:center;opacity:0;pointer-events:none;transition:opacity .25s;z-index:1000
}
.has-tooltip::before{
  content:"";position:absolute;bottom:120%;left:50%;transform:translateX(-50%);
  border-width:6px;border-style:solid;border-color:rgba(0,0,0,.9) transparent transparent transparent;
  opacity:0;transition:opacity .25s;z-index:1001
}
.has-tooltip:hover::after,.has-tooltip:hover::before,
.has-tooltip:focus-visible::after,.has-tooltip:focus-visible::before{opacity:1}
.has-tooltip.show-tip::after,.has-tooltip.show-tip::before{opacity:1}
@media (max-width:600px){
  .has-tooltip::after{bottom:auto;top:130%}
  .has-tooltip::before{bottom:auto;top:120%;border-color:transparent transparent rgba(0,0,0,.9) transparent}
}
/* ===== Hassan Legacy Hero (grüner Kopf + Bildstreifen) ===== */
.hero-legacy{background:var(--bg);}

.legacy-head{
  background:#2f7f80;           /* Grün wie früher – bei Bedarf feintunen */
  padding:26px 0;
}
.legacy-brand{
  display:flex; align-items:center; justify-content:center; gap:12px;
  color:#ffe; text-transform:uppercase; letter-spacing:.12em;
}
.legacy-logo{
  font-family:Playfair,serif; font-weight:700; font-size:clamp(26px,4vw,40px);
  border-top:2px solid #e7d9b6; border-bottom:2px solid #e7d9b6; padding:2px 14px;
}
.legacy-sub{
  font-weight:800; font-size:clamp(12px,2vw,14px); opacity:.95; letter-spacing:.22em;
}

.legacy-strip{
  display:grid; grid-template-columns:repeat(3,1fr); gap:0;
  border-bottom:1px solid var(--line);
}
.legacy-tile{position:relative; margin:0; line-height:0;}
.legacy-tile picture, .legacy-tile img{display:block; width:100%; height:100%; object-fit:cover; aspect-ratio: 16/9;}
.legacy-tile figcaption{
  position:absolute; left:50%; top:50%; transform:translate(-50%,-50%);
  color:#fff; background:rgba(0,0,0,.35);
  padding:8px 14px; border-radius:8px; font-weight:800; letter-spacing:.02em;
  text-shadow:0 2px 6px rgba(0,0,0,.35); font-size:clamp(14px,1.8vw,18px);
}

@media (max-width:900px){ .legacy-strip{ grid-template-columns:1fr; } }

/* Intro-Abschnitt */
.section.intro{ background:#efe6d5; padding:36px 0 28px; }
.section.intro .lead{
  font-family:Playfair,serif; font-size:clamp(18px,2.6vw,26px); color:#2b5e5f;
}
.section.intro a{ color:#2b5e5f; text-decoration:underline; text-decoration-color:rgba(43,94,95,.35); }
.section.intro a:hover{ text-decoration-color:rgba(43,94,95,.7); }


/* ===== Logo-Stack: TEPPICHE unter HASSAN ===== */
.legacy-brand.stack{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:6px;                 /* Abstand zwischen HASSAN und TEPPICHE */
  text-transform:uppercase;
  letter-spacing:.12em;
  color:#F3EFE2;           /* leicht warmes Weiß */
}
.legacy-logo{
  font-family:Playfair,serif;
  font-weight:700;
  font-size:clamp(28px,4.4vw,44px);
  line-height:1.1;
  padding:4px 16px;
  border-top:2px solid #e7d9b6;
  border-bottom:2px solid #e7d9b6;
}
.legacy-sub{
  font-weight:800;
  font-size:clamp(12px,2.2vw,15px);
  letter-spacing:.24em;
  opacity:.98;
}

/* === Intro zentriert & harmonisch === */
.section.intro {
  background:#efe6d5;
  padding:56px 0 48px;              /* etwas mehr Luft */
  text-align:center;                /* alles mittig */
}

.section.intro .container {
  max-width:960px;                  /* Inhalt zentriert begrenzen */
  margin:0 auto;
}

.section.intro .lead {
  font-family:Playfair,serif;
  font-size:clamp(20px,3vw,30px);
  line-height:1.35;
  color:#2b5e5f;
  margin:0 auto 18px;
}

.section.intro .contact-lines {
  font-size:1rem;
  line-height:1.6;
  color:#333;
  margin:0 auto;
}

.section.intro a {
  color:#2b5e5f;
  text-decoration:underline;
  text-decoration-color:rgba(43,94,95,.35);
}

.section.intro a:hover {
  text-decoration-color:rgba(43,94,95,.7);
}

/* Mobile Nachschärfung */
@media (max-width:700px){
  .section.intro .lead {
    font-size:clamp(19px,4.6vw,24px);
  }
}
