/* ============================================================
   Homepage layout & component CSS.
   Imports the root tokens via colors_and_type.css.
   ============================================================ */

/* ============================================================
   AYURVEDA MÜNCHEN — Design Tokens
   Sabine Köckerbauer · Praxis im Glockenbachviertel
   ============================================================

   Brand vibe: editorial wellness magazine, NOT spa-temple.
   Warm paper-like backgrounds, terracotta accent, sage secondary.
   Serif headlines (Cormorant Garamond), humanist body (Inter Tight).
   ============================================================ */

/* cyrillic-ext */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/e4eb06de-f067-40b5-be76-a1d7661e0562.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/66b61923-21a7-47da-b462-8d4b2708da0c.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/d4f233a5-5248-431a-8381-139af67acb46.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/5ffec917-c60e-4b90-917c-3927c48070d7.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/1e25ce47-48ad-40b0-a2dc-564afedeba83.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: italic;
  font-weight: 500;
  font-display: swap;
  src: url("../fonts/e4eb06de-f067-40b5-be76-a1d7661e0562.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: italic;
  font-weight: 500;
  font-display: swap;
  src: url("../fonts/66b61923-21a7-47da-b462-8d4b2708da0c.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: italic;
  font-weight: 500;
  font-display: swap;
  src: url("../fonts/d4f233a5-5248-431a-8381-139af67acb46.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: italic;
  font-weight: 500;
  font-display: swap;
  src: url("../fonts/5ffec917-c60e-4b90-917c-3927c48070d7.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: italic;
  font-weight: 500;
  font-display: swap;
  src: url("../fonts/1e25ce47-48ad-40b0-a2dc-564afedeba83.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/55a51c62-5aa9-4833-a01c-fa31cc6d03a1.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/80aa30ac-7da1-43af-bf59-21eca77e1b9a.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/60f96aa2-341b-4bdb-b3ab-7d197d5d01b7.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/48f57cf6-2e55-43aa-ae29-bd6832afc2d3.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/c3a5deb1-bf63-47e7-9f98-9f4a9c6db4db.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../fonts/55a51c62-5aa9-4833-a01c-fa31cc6d03a1.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../fonts/80aa30ac-7da1-43af-bf59-21eca77e1b9a.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../fonts/60f96aa2-341b-4bdb-b3ab-7d197d5d01b7.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../fonts/48f57cf6-2e55-43aa-ae29-bd6832afc2d3.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../fonts/c3a5deb1-bf63-47e7-9f98-9f4a9c6db4db.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../fonts/55a51c62-5aa9-4833-a01c-fa31cc6d03a1.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../fonts/80aa30ac-7da1-43af-bf59-21eca77e1b9a.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../fonts/60f96aa2-341b-4bdb-b3ab-7d197d5d01b7.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../fonts/48f57cf6-2e55-43aa-ae29-bd6832afc2d3.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../fonts/c3a5deb1-bf63-47e7-9f98-9f4a9c6db4db.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Inter Tight';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/1a366e40-b88c-477d-8eb0-07b94d7b11f3.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Inter Tight';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/2e00ba0a-11c5-4f46-87ec-0c3d0974992d.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek-ext */
@font-face {
  font-family: 'Inter Tight';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/76f40fe7-4666-4cab-86f4-3dfa212b802a.woff2") format('woff2');
  unicode-range: U+1F00-1FFF;
}
/* greek */
@font-face {
  font-family: 'Inter Tight';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/2370a1c1-8784-4e71-b35a-168a83d04bd8.woff2") format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* vietnamese */
@font-face {
  font-family: 'Inter Tight';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/44c24038-263e-4ffd-841c-ee5f4ac8ecb3.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Inter Tight';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/00283a17-2efa-454a-8909-759aaa332763.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Inter Tight';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/f422cdf8-732f-4b34-b5a3-bf366989e90c.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Inter Tight';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../fonts/1a366e40-b88c-477d-8eb0-07b94d7b11f3.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Inter Tight';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../fonts/2e00ba0a-11c5-4f46-87ec-0c3d0974992d.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek-ext */
@font-face {
  font-family: 'Inter Tight';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../fonts/76f40fe7-4666-4cab-86f4-3dfa212b802a.woff2") format('woff2');
  unicode-range: U+1F00-1FFF;
}
/* greek */
@font-face {
  font-family: 'Inter Tight';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../fonts/2370a1c1-8784-4e71-b35a-168a83d04bd8.woff2") format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* vietnamese */
@font-face {
  font-family: 'Inter Tight';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../fonts/44c24038-263e-4ffd-841c-ee5f4ac8ecb3.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Inter Tight';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../fonts/00283a17-2efa-454a-8909-759aaa332763.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Inter Tight';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../fonts/f422cdf8-732f-4b34-b5a3-bf366989e90c.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Inter Tight';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../fonts/1a366e40-b88c-477d-8eb0-07b94d7b11f3.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Inter Tight';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../fonts/2e00ba0a-11c5-4f46-87ec-0c3d0974992d.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek-ext */
@font-face {
  font-family: 'Inter Tight';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../fonts/76f40fe7-4666-4cab-86f4-3dfa212b802a.woff2") format('woff2');
  unicode-range: U+1F00-1FFF;
}
/* greek */
@font-face {
  font-family: 'Inter Tight';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../fonts/2370a1c1-8784-4e71-b35a-168a83d04bd8.woff2") format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* vietnamese */
@font-face {
  font-family: 'Inter Tight';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../fonts/44c24038-263e-4ffd-841c-ee5f4ac8ecb3.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Inter Tight';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../fonts/00283a17-2efa-454a-8909-759aaa332763.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Inter Tight';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../fonts/f422cdf8-732f-4b34-b5a3-bf366989e90c.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}


:root {
  /* ─── COLOR — Paper / Sand neutrals ─────────────────────── */
  --paper:        #FBF7F0;  /* warmest, off-white paper */
  --sand-50:      #F5EFE3;  /* primary background */
  --sand-100:    #EDE4D2;   /* one step deeper, section background */
  --sand-200:    #E0D2B6;   /* card hover, inputs */
  --sand-300:    #C8B591;   /* dividers on darker surfaces */

  /* ─── COLOR — Terracotta accent ──────────────────────────── */
  --terracotta-50:  #F4E1D4;
  --terracotta-100: #E8C0A5;
  --terracotta-300: #C68062;
  --terracotta-500: #A85A3C;  /* primary accent — links on hover, marks */
  --terracotta-700: #7A3D26;  /* deepest, headline emphasis */

  /* ─── COLOR — Sage (muted green) secondary ───────────────── */
  --sage-50:  #EAEBE0;
  --sage-100: #D6D9C2;
  --sage-300: #9DA686;
  --sage-500: #6B7A5A;
  --sage-700: #4A5640;

  /* ─── COLOR — Ink (deep warm brown-black) ────────────────── */
  --ink:        #2B2418;   /* default text */
  --ink-80:    #4A4032;
  --ink-60:    #6C6253;
  --ink-40:    #95897A;
  --ink-20:    #C5B8A6;
  --ink-10:    rgba(43, 36, 24, 0.10);  /* hairlines */
  --ink-05:    rgba(43, 36, 24, 0.05);

  /* ─── COLOR — Semantic ───────────────────────────────────── */
  --bg:           var(--sand-50);
  --bg-elev:      var(--paper);
  --bg-section:   var(--sand-100);
  --bg-quote:     var(--sage-50);
  --fg:           var(--ink);
  --fg-muted:     var(--ink-60);
  --fg-subtle:    var(--ink-40);
  --accent:       var(--terracotta-500);
  --accent-deep:  var(--terracotta-700);
  --hairline:     var(--ink-10);

  /* ─── TYPOGRAPHY — Families ──────────────────────────────── */
  --font-serif:   'Cormorant Garamond', 'Lyon Display', Georgia, serif;
  --font-sans:    'Inter Tight', 'Söhne', -apple-system, BlinkMacSystemFont, 'Helvetica Neue', sans-serif;

  /* ─── TYPOGRAPHY — Scale ─────────────────────────────────── */
  --fs-display: clamp(3.5rem, 7vw + 1rem, 6.5rem);   /* 56–104px hero */
  --fs-h1:      clamp(2.75rem, 4vw + 1rem, 4.5rem);   /* 44–72px */
  --fs-h2:      clamp(2rem, 2.5vw + 1rem, 3rem);      /* 32–48px */
  --fs-h3:      clamp(1.5rem, 1.2vw + 1rem, 2rem);    /* 24–32px */
  --fs-h4:      1.375rem;                              /* 22px */
  --fs-lead:    1.25rem;                               /* 20px intro paragraph */
  --fs-body:    1.0625rem;                             /* 17px default */
  --fs-small:   0.9375rem;                             /* 15px */
  --fs-eyebrow: 0.75rem;                               /* 12px uppercase label */

  --lh-display: 1.04;
  --lh-heading: 1.15;
  --lh-body:    1.65;
  --lh-tight:   1.3;

  --ls-eyebrow: 0.14em;
  --ls-display: -0.015em;
  --ls-heading: -0.01em;
  --ls-body:    0;

  /* ─── SPACING — 4px base ─────────────────────────────────── */
  --space-1:  4px;
  --space-2:  8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 24px;
  --space-6: 32px;
  --space-7: 48px;
  --space-8: 64px;
  --space-9: 96px;
  --space-10:128px;
  --space-11:192px;

  /* ─── RADIUS ─────────────────────────────────────────────── */
  --radius-sm: 4px;
  --radius-md: 8px;
  --radius-lg: 16px;

  /* ─── SHADOWS (used sparingly) ───────────────────────────── */
  --shadow-nav:  0 1px 0 var(--ink-10), 0 8px 24px rgba(60, 38, 22, 0.04);
  --shadow-card-hover: 0 1px 0 var(--terracotta-500);

  /* ─── MOTION ─────────────────────────────────────────────── */
  --ease-out:   cubic-bezier(0.4, 0, 0.2, 1);
  --ease-quiet: cubic-bezier(0.22, 0.61, 0.36, 1);
  --dur-quick:  120ms;
  --dur-base:   200ms;
  --dur-slow:   600ms;

  /* ─── LAYOUT ─────────────────────────────────────────────── */
  --container:   1200px;
  --container-narrow: 720px;
  --container-prose:  640px;
  --gutter:      24px;
}

/* ============================================================
   SEMANTIC ELEMENT STYLES
   ============================================================ */

html { color: var(--fg); background: var(--bg); }

body {
  font-family: var(--font-sans);
  font-size: var(--fs-body);
  line-height: var(--lh-body);
  font-weight: 400;
  letter-spacing: var(--ls-body);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

h1, h2, h3, h4, h5 {
  font-family: var(--font-serif);
  font-weight: 400;
  letter-spacing: var(--ls-heading);
  line-height: var(--lh-heading);
  color: var(--fg);
  text-wrap: balance;
  margin: 0;
}

h1 { font-size: var(--fs-h1); line-height: var(--lh-display); letter-spacing: var(--ls-display); }
h2 { font-size: var(--fs-h2); }
h3 { font-size: var(--fs-h3); }
h4 { font-size: var(--fs-h4); font-family: var(--font-sans); font-weight: 500; letter-spacing: 0; }

.display {
  font-family: var(--font-serif);
  font-size: var(--fs-display);
  line-height: var(--lh-display);
  letter-spacing: var(--ls-display);
  font-weight: 400;
  text-wrap: balance;
}

.lead {
  font-size: var(--fs-lead);
  line-height: 1.55;
  color: var(--fg-muted);
  text-wrap: pretty;
}

.eyebrow {
  font-family: var(--font-sans);
  font-size: var(--fs-eyebrow);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: var(--ls-eyebrow);
  color: var(--fg-muted);
}

p { margin: 0; text-wrap: pretty; }
p + p { margin-top: 1em; }

em, i { font-family: var(--font-serif); font-style: italic; }
strong { font-weight: 500; }

a {
  color: inherit;
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
  text-decoration-color: var(--ink-20);
  transition: color var(--dur-base) var(--ease-out),
              text-decoration-color var(--dur-base) var(--ease-out),
              text-decoration-thickness var(--dur-base) var(--ease-out);
}
a:hover {
  color: var(--accent);
  text-decoration-thickness: 2px;
  text-decoration-color: currentColor;
}

hr {
  border: 0;
  border-top: 1px solid var(--hairline);
  margin: var(--space-7) 0;
}

blockquote {
  margin: 0;
  padding-left: var(--space-5);
  border-left: 2px solid var(--accent);
  font-family: var(--font-serif);
  font-style: italic;
  font-size: var(--fs-h3);
  line-height: 1.35;
  color: var(--ink-80);
  text-wrap: balance;
}

/* ============================================================
   UTILITY
   ============================================================ */

.container { max-width: var(--container); margin: 0 auto; padding: 0 var(--gutter); }
.container-narrow { max-width: var(--container-narrow); margin: 0 auto; padding: 0 var(--gutter); }
.container-prose  { max-width: var(--container-prose); margin: 0 auto; padding: 0 var(--gutter); }

.section { padding: var(--space-9) 0; }
@media (max-width: 720px) { .section { padding: var(--space-7) 0; } }


* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  background: var(--bg);
  color: var(--fg);
}

/* Anchor jumps should clear the sticky header (~72px tall). */
[id] { scroll-margin-top: 88px; }

/* ───────── REVEAL ON SCROLL ─────────────────────────────── */
[data-reveal] {
  opacity: 0;
  transform: translateY(18px);
  transition: opacity 700ms var(--ease-quiet),
              transform  700ms var(--ease-quiet);
  will-change: opacity, transform;
}
[data-reveal].is-in-view {
  opacity: 1;
  transform: translateY(0);
}
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  [data-reveal] { opacity: 1; transform: none; transition: none; }
}

/* ───────── BUTTONS (page-scoped) ────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-family: var(--font-sans);
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.04em;
  padding: 13px 22px;
  border-radius: var(--radius-md);
  border: 1px solid transparent;
  cursor: pointer;
  text-decoration: none;
  color: inherit;
  transition: background var(--dur-base) var(--ease-out),
              color var(--dur-base) var(--ease-out),
              border-color var(--dur-base) var(--ease-out);
}
.btn:hover { text-decoration: none; }
.btn:active { transform: scale(0.99); }
.btn--primary   { background: var(--accent); color: var(--paper); }
.btn--primary:hover { background: var(--accent-deep); }
.btn--secondary { background: transparent; color: var(--ink); border-color: var(--ink); }
.btn--secondary:hover { background: var(--ink); color: var(--paper); }
.btn--ghost     { background: transparent; color: var(--ink); padding-left: 0; padding-right: 0; border-radius: 0; }
.btn--ghost::after { content: ""; }
.btn--ghost:hover { color: var(--accent); }
.btn--sm  { padding: 10px 18px; font-size: 13px; }
.btn--lg  { padding: 16px 28px; font-size: 15px; }

/* ───────── HEADER ───────────────────────────────────────── */
.site-header {
  position: sticky;
  top: 0;
  z-index: 60;
  background: rgba(245, 239, 227, 0.78);
  transition: background var(--dur-base) var(--ease-out), box-shadow var(--dur-base) var(--ease-out);
}
.site-header.is-scrolled {
  background: rgba(251, 247, 240, 0.92);
  backdrop-filter: blur(12px);
  box-shadow: var(--shadow-nav);
}
/* When the mobile menu is open, the header should blend with the menu's
   paper background instead of showing the translucent sand strip. */
body.menu-is-open .site-header {
  background: var(--paper);
  box-shadow: none;
  backdrop-filter: none;
}
.site-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 0;
  gap: 32px;
}
.brand {
  font-family: var(--font-serif);
  font-size: 22px;
  letter-spacing: -0.01em;
  color: var(--ink);
  text-decoration: none;
  white-space: nowrap;
  flex-shrink: 0;
}
.btn { white-space: nowrap; }
.primary-nav a { white-space: nowrap; }
.brand em { font-style: italic; color: var(--accent); }
.brand__amp { color: var(--accent); font-style: italic; }
.brand--dark { color: var(--paper); }
.brand--dark em { color: var(--terracotta-300); }
.brand--dark .brand__amp { color: var(--terracotta-300); }

.primary-nav {
  display: flex;
  gap: 28px;
}
.primary-nav a {
  font-family: var(--font-sans);
  font-size: 14px;
  font-weight: 500;
  color: var(--ink-80);
  text-decoration: none;
  transition: color var(--dur-base) var(--ease-out);
}
.primary-nav a:hover { color: var(--accent); }

@media (max-width: 1040px) {
  .primary-nav { display: none; }
  .site-header__inner { gap: 16px; }
	
	.brand {
	padding-left: 11px
	}
}
@media (max-width: 720px) {
  .header-cta { display: none; }
}

/* ───────── BURGER + MOBILE MENU ─────────────────────────── */
.burger {
  display: none;
  width: 44px;
  height: 44px;
  background: transparent;
  border: 0;
  cursor: pointer;
  padding: 0;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  position: relative;
  z-index: 60;
}
.burger__bar {
  display: block;
  width: 22px;
  height: 1.5px;
  background: var(--ink);
  transition: transform var(--dur-base) var(--ease-out),
              opacity var(--dur-base) var(--ease-out);
  transform-origin: center;
}
.burger__bar.is-open:nth-child(1) { transform: translateY(3.75px) rotate(45deg); }
.burger__bar.is-open:nth-child(2) { transform: translateY(-3.75px) rotate(-45deg); }

@media (max-width: 1040px) {
  .burger { display: flex; }
}

.mobile-menu {
  position: fixed;
  inset: 0;
  z-index: 50;
  background: var(--paper);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 96px var(--gutter) var(--space-7);
  opacity: 0;
  pointer-events: none;
  transform: translateY(-12px);
  transition: opacity 300ms var(--ease-quiet),
              transform 300ms var(--ease-quiet);
}
.mobile-menu.is-open {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}
.mobile-menu__nav {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  margin-top: var(--space-6);
}
.mobile-menu__nav a {
  font-family: var(--font-serif);
  font-size: clamp(2rem, 6vw, 2.75rem);
  line-height: 1.1;
  letter-spacing: -0.01em;
  color: var(--ink);
  text-decoration: none;
  padding: 4px 0;
  border-bottom: 1px solid var(--hairline);
  transition: color var(--dur-base) var(--ease-out),
              border-color var(--dur-base) var(--ease-out);
}
.mobile-menu__nav a:hover,
.mobile-menu__nav a:active {
  color: var(--accent);
  border-bottom-color: var(--accent);
}
.mobile-menu__foot {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  padding-top: var(--space-5);
  border-top: 1px solid var(--hairline);
}
.mobile-menu__foot a {
  font-family: var(--font-sans);
  font-size: 16px;
  color: var(--ink-80);
  text-decoration: none;
  padding: 4px 0;
}
.mobile-menu__foot a:hover { color: var(--accent); }
.mobile-menu__addr {
  font-family: var(--font-sans);
  font-size: 13px;
  line-height: 1.5;
  color: var(--ink-60);
  margin: var(--space-3) 0 0;
}

/* ───────── HERO ─────────────────────────────────────────── */
.hero {
  position: relative;
  min-height: 88vh;
  display: flex;
  align-items: center;
  overflow: hidden;
  isolation: isolate;
}
.hero__bg {
  position: absolute; inset: 0; z-index: -2;
  background:
    radial-gradient(60% 70% at 75% 35%, #E8C0A5 0%, transparent 60%),
    radial-gradient(50% 60% at 15% 85%, #D6D9C2 0%, transparent 55%),
    linear-gradient(180deg, #F5EFE3 0%, #EDE4D2 100%);
}
.hero__veil {
  position: absolute; inset: 0; z-index: -1;
  background: linear-gradient(90deg, rgba(251,247,240,0.65) 0%, rgba(251,247,240,0) 60%);
}
.hero__inner {
  padding: var(--space-9) 0 var(--space-10);
  width: 100%;
}
.hero__copy {
  max-width: 760px;
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}
.hero__copy .display em {
  color: var(--accent);
  font-style: italic;
}
.hero__copy .lead {
  max-width: 520px;
  margin-top: var(--space-2);
}
.hero__actions {
  display: flex;
  gap: 18px;
  align-items: center;
  margin-top: var(--space-3);
  flex-wrap: wrap;
}
.hero__separator {
  margin-top: var(--space-7);
  padding-top: var(--space-5);
  border-top: 1px solid var(--hairline);
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  font-family: var(--font-sans);
  font-size: 13px;
  letter-spacing: 0.06em;
  color: var(--fg-muted);
}
.hero__separator span[aria-hidden="true"] { color: var(--accent); }

/* Zwei-Spalten-Hero mit Bild rechts */
.hero--has-image .hero__inner {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
  gap: var(--space-9);
  align-items: center;
}
.hero--has-image .hero__copy { max-width: none; }
.hero__image {
  position: relative;
  width: 100%;
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: 0 30px 60px -30px rgba(43, 36, 24, 0.35);
}
.hero__image img {
  display: block;
  width: 100%;
  height: 100%;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  object-position: center;
}
@media (max-width: 960px) {
  .hero--has-image { min-height: 0; }
  .hero--has-image .hero__inner {
    grid-template-columns: 1fr;
    gap: var(--space-6);
    padding-top: var(--space-6);
  }

	.hero__copy {
		padding: 0 var(--gutter);
	}
  /* Bild zuerst, Text darunter — editorial Magazin-Look */
  .hero--has-image .hero__image { order: 1; max-width: 560px; margin: 0 auto; }
  .hero--has-image .hero__copy  { order: 2; }
  /* Schmaleres Format, damit der erste CTA noch sichtbar bleibt */
  .hero__image img { aspect-ratio: 3 / 4; }
}
@media (max-width: 560px) {
  /* Auf kleinen Phones nochmal etwas flacher */
  .hero__image img { aspect-ratio: 4 / 3; }
}

/* ───────── ORNAMENT (chapter mark) ──────────────────────── */
.ornament {
  display: flex;
  justify-content: center;
  margin: 0 auto var(--space-8);
  max-width: 320px;
  width: 100%;
}
.ornament svg {
  width: 100%;
  height: auto;
  max-height: 28px;
}

/* ───────── PAGE HERO (sub-pages) ─────────────────────────── */
.page-hero {
  background: linear-gradient(180deg, var(--sand-50) 0%, var(--paper) 100%);
  padding: var(--space-9) 0 var(--space-8);
  border-bottom: 1px solid var(--hairline);
}
.page-hero__inner {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  max-width: 980px;
}
.page-hero__back {
  font-family: var(--font-sans);
  font-size: 13px;
  letter-spacing: 0.04em;
  color: var(--fg-muted);
  text-decoration: none;
  margin-bottom: var(--space-3);
  transition: color var(--dur-base) var(--ease-out);
}
.page-hero__back:hover { color: var(--accent); }
.page-hero .display {
  font-size: clamp(2.75rem, 5vw + 1rem, 5rem);
}
.page-hero .display em { color: var(--accent); font-style: italic; }
.page-hero .lead {
  color: var(--fg-muted);
  max-width: 560px;
  margin-bottom: var(--space-5);
}
.page-hero__index {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--hairline);
  border-top: 1px solid var(--hairline);
  border-bottom: 1px solid var(--hairline);
  margin-top: var(--space-5);
}
.page-hero__index a {
  background: var(--paper);
  padding: var(--space-4) var(--space-3);
  text-decoration: none;
  color: inherit;
  display: flex;
  flex-direction: column;
  gap: 4px;
  transition: background var(--dur-base) var(--ease-out);
}
.page-hero__index a:hover { background: var(--sand-50); }
.page-hero__index .num {
  font-family: var(--font-sans);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--accent);
  line-height: 1.4;
}
.page-hero__index .nm {
  font-family: var(--font-serif);
  font-size: 18px;
  line-height: 1.2;
  color: var(--ink);
  word-break: normal;
  overflow-wrap: anywhere;
}
@media (max-width: 880px) {
  .page-hero__index { grid-template-columns: repeat(2, 1fr); }
}

/* ───────── SECTION CTA & PAGE CTA ──────────────────────── */
.section__cta {
  display: flex;
  justify-content: center;
  margin-top: var(--space-8);
}
.section--page-cta {
  background: var(--ink);
  color: var(--sand-100);
  padding: var(--space-9) 0;
}
.section--page-cta .ornament { color: var(--sand-300); }
.page-cta { text-align: center; display: flex; flex-direction: column; gap: var(--space-4); align-items: center; }
.page-cta h2 { color: var(--paper); font-family: var(--font-serif); }
.page-cta h2 em { color: var(--terracotta-300); font-style: italic; }
.page-cta .lead { color: var(--sand-200); max-width: 480px; margin: 0 auto; }
.page-cta__actions { display: flex; gap: var(--space-4); flex-wrap: wrap; justify-content: center; margin-top: var(--space-3); }
.page-cta__actions .btn--ghost { color: var(--paper); border-bottom: 1px solid var(--terracotta-300); padding: 13px 0; }
.page-cta__actions .btn--ghost:hover { color: var(--terracotta-300); }

/* ───────── SECTIONS ─────────────────────────────────────── */
.section { padding: var(--space-10) 0; position: relative; }
@media (max-width: 720px) { .section { padding: var(--space-8) 0; } }

.section__head {
  max-width: 720px;
  margin: 0 auto var(--space-8);
  text-align: center;
}
.section__head .eyebrow { display: block; margin-bottom: var(--space-3); }
.section__head h2 { margin-bottom: var(--space-3); }
.section__head h2 em { color: var(--accent); font-style: italic; }
.section__head .lead { color: var(--fg-muted); max-width: 560px; margin: 0 auto; }

/* ───────── TWO-COL EDITORIAL ─────────────────────────────── */
.section--ayurveda { background: var(--sand-100); }
.two-col {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: var(--space-9);
  align-items: start;
}
.two-col__a h2 em { color: var(--accent); font-style: italic; }
.two-col__b.prose p { max-width: 56ch; }
.prose .lead { margin-bottom: var(--space-4); }
.prose h2 { margin: var(--space-3) 0 var(--space-5); }
.prose .eyebrow { display: block; margin-bottom: var(--space-3); }
.prose p + p { margin-top: var(--space-4); }
@media (max-width: 880px) {
  .two-col { grid-template-columns: 1fr; gap: var(--space-6); }
}

/* ───────── TREATMENT GRID ───────────────────────────────── */
.section--treatments { background: var(--bg); }
.t-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--hairline);
  border-top: 1px solid var(--hairline);
  border-bottom: 1px solid var(--hairline);
}
.t-card {
  background: var(--bg);
  padding: var(--space-6) var(--space-5) var(--space-5);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  transition: background var(--dur-base) var(--ease-out);
  text-decoration: none;
  color: inherit;
  position: relative;
}
.t-card:hover { background: var(--paper); text-decoration: none; }
.t-card:hover .t-card__more { color: var(--accent); }
.t-card__more {
  font-family: var(--font-sans);
  font-size: 12px;
  letter-spacing: 0.08em;
  color: var(--ink-60);
  margin-top: var(--space-2);
  transition: color var(--dur-base) var(--ease-out);
}
.t-card__title {
  font-family: var(--font-serif);
  font-size: 28px;
  line-height: 1.1;
  letter-spacing: -0.01em;
  margin: 0;
  font-weight: 400;
}
.t-card__title em { color: var(--accent); font-style: italic; }
.t-card__desc {
  font-size: 14px;
  line-height: 1.55;
  color: var(--ink-80);
  margin: 0;
  flex: 1;
}
.t-card__meta {
  display: flex;
  gap: 10px;
  font-family: var(--font-sans);
  font-size: 13px;
  color: var(--ink-60);
  padding-top: var(--space-3);
  border-top: 1px solid var(--hairline);
  flex-wrap: wrap;
}
.t-card__meta > span { white-space: nowrap; }
.t-card__price { color: var(--ink); font-weight: 500; margin-left: auto; }
@media (max-width: 980px) { .t-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .t-grid { grid-template-columns: 1fr; } }

/* ───────── TREATMENT DETAIL SPREADS ───────────────────────── */
.section--treatments-detail {
  background: var(--sage-50);
  padding-top: var(--space-9);
}
.section__head--narrow { max-width: 640px; }
.t-detail-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-10);
  margin-top: var(--space-9);
}
.t-detail {
  display: grid;
  grid-template-columns: 5fr 7fr;
  gap: var(--space-8);
  align-items: start;
  scroll-margin-top: 100px;
}
.t-detail.is-flipped { grid-template-columns: 7fr 5fr; }
.t-detail.is-flipped .t-detail__visual { order: 2; }

.t-detail__visual {
  position: sticky;
  top: 100px;
  align-self: start;
}
.t-visual {
  aspect-ratio: 4/5;
  border-radius: var(--radius-lg);
  display: flex;
  align-items: flex-end;
  padding: var(--space-6);
  color: var(--paper);
  position: relative;
  overflow: hidden;
}
.t-visual__no {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: clamp(4rem, 6vw, 7rem);
  line-height: 1;
  color: var(--paper);
  opacity: 0.85;
  letter-spacing: -0.02em;
}
.t-visual--0 { background: radial-gradient(circle at 35% 35%, #E8C0A5, #A85A3C 70%, #7A3D26); }
.t-visual--1 { background: radial-gradient(circle at 65% 40%, #D6D9C2, #6B7A5A 70%, #4A5640); }
.t-visual--2 { background: radial-gradient(circle at 50% 60%, #F4E1D4, #C68062 70%, #4A4032); }
.t-visual--3 { background: radial-gradient(circle at 40% 50%, #EDE4D2, #95897A 70%, #4A4032); }

.t-visual__img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  z-index: 1;
}
.t-visual--has-image::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(43,36,24,0) 35%, rgba(43,36,24,0.55) 100%);
  z-index: 2;
  pointer-events: none;
}
.t-visual--has-image .t-visual__no {
  position: relative;
  z-index: 3;
}

.t-detail__copy {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}
.t-detail__title {
  font-family: var(--font-serif);
  font-size: clamp(2.25rem, 3vw + 1rem, 3.5rem);
  line-height: 1.05;
  letter-spacing: -0.015em;
  margin: 0;
  font-weight: 400;
}
.t-detail__title em { color: var(--accent); font-style: italic; }
.t-detail__copy .prose p {
  font-size: 17px;
  line-height: 1.65;
  color: var(--ink-80);
  max-width: 56ch;
}
.t-detail__copy .prose p + p { margin-top: var(--space-3); }

.t-detail__effects {
  margin-top: var(--space-4);
  padding-top: var(--space-5);
  border-top: 1px solid var(--hairline);
}
.eyebrow--accent { color: var(--accent); }
.t-detail__effects h4 {
  font-family: var(--font-sans);
  font-size: var(--fs-eyebrow);
  letter-spacing: var(--ls-eyebrow);
  text-transform: uppercase;
  margin: 0 0 var(--space-4);
  font-weight: 500;
}
.t-detail__effects ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-2) var(--space-5);
}
.t-detail__effects li {
  font-family: var(--font-serif);
  font-size: 18px;
  line-height: 1.4;
  color: var(--ink);
  padding-left: var(--space-4);
  position: relative;
}
.t-detail__effects li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.6em;
  width: 8px;
  height: 1px;
  background: var(--accent);
}

.t-detail__meta {
  display: flex;
  align-items: center;
  gap: var(--space-6);
  margin-top: var(--space-5);
  padding-top: var(--space-5);
  border-top: 1px solid var(--hairline);
  flex-wrap: wrap;
}
.t-detail__meta > div {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.t-detail__meta .lab {
  font-family: var(--font-sans);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fg-muted);
}
.t-detail__meta .val {
  font-family: var(--font-serif);
  font-size: 22px;
  color: var(--ink);
}
.t-detail__meta .val--accent { color: var(--accent); }
.t-detail__meta .btn { margin-left: auto; }

@media (max-width: 880px) {
  .t-detail, .t-detail.is-flipped { grid-template-columns: 1fr; gap: var(--space-5); }
  .t-detail.is-flipped .t-detail__visual { order: 0; }
  .t-detail__visual { position: static; }
  .t-visual { aspect-ratio: 16/10; }
  .t-detail__effects ul { grid-template-columns: 1fr; }
  .t-detail__meta .btn { margin-left: 0; width: 100%; }
}

/* ───────── ABOUT (dark editorial spread) ────────────────── */
.section--about {
  background: var(--ink);
  color: var(--sand-100);
}
.section--about .eyebrow { color: var(--sand-300); }
.section--about h2 { color: var(--paper); }
.section--about h2 em { color: var(--terracotta-300); font-style: italic; }
.section--about .prose p { color: var(--sand-100); }
.about-grid {
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: var(--space-9);
  align-items: center;
}
.portrait-placeholder {
  aspect-ratio: 4/5;
  border-radius: var(--radius-lg);
  background:
    radial-gradient(circle at 50% 40%, #E8C0A5, #C68062 70%, #7A3D26);
  display: flex;
  align-items: flex-end;
  padding: var(--space-5);
  color: var(--paper);
  font-family: var(--font-sans);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}
.about-grid__portrait { width: 100%; }
.portrait-image {
  display: block;
  width: 100%;
  aspect-ratio: 4/5;
  object-fit: cover;
  object-position: center;
  border-radius: var(--radius-lg);
}
.about-grid__copy h2 em { color: var(--terracotta-300); font-style: italic; }
.cred-list {
  list-style: none;
  padding: 0;
  margin: var(--space-5) 0 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  font-size: 14px;
  color: var(--sand-200);
}
.cred-list li {
  padding-left: var(--space-4);
  position: relative;
}
.cred-list li::before {
  content: "–";
  position: absolute;
  left: 0;
  color: var(--terracotta-300);
}
@media (max-width: 880px) {
  .about-grid { grid-template-columns: 1fr; gap: var(--space-6); }
  .portrait-placeholder,
  .portrait-image { max-width: 480px; }
  .about-grid__portrait { display: flex; justify-content: center; }
}

/* ───────── QUOTES ───────────────────────────────────────── */
.section--quotes { background: var(--sage-50); text-align: left; }
.section--quotes .container-narrow {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}
.quote-fade {
  position: relative;
  transition: height 420ms var(--ease-quiet);
  will-change: height;
  /* sanfter Mindestplatz, damit Controls nicht direkt am Eyebrow kleben */
  min-height: 3.5em;
}
.quote-slide {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  /* kein bottom/inset:0 — sonst zieht der Slide die Höhe des Containers
     auf und scrollHeight misst nicht mehr den tatsächlichen Inhalt */
  opacity: 0;
  visibility: hidden;
  transform: translateY(6px);
  transition: opacity 360ms var(--ease-quiet), transform 360ms var(--ease-quiet), visibility 0s linear 360ms;
}
.quote-slide.is-active {
  opacity: 1;
  visibility: visible;
  transform: none;
  transition: opacity 360ms var(--ease-quiet) 60ms, transform 360ms var(--ease-quiet) 60ms, visibility 0s;
}
.big-quote {
  font-family: var(--font-serif);
  font-style: italic;
  color: var(--ink);
  margin: 0;
  padding-left: var(--space-5);
  border-left: 2px solid var(--accent);
  text-wrap: pretty;
  /* single consistent size for ALL testimonials */
  font-size: clamp(1.5rem, 1.5vw + 0.875rem, 1.875rem);
  line-height: 1.4;
}
.cite--quote {
  font-family: var(--font-sans);
  font-size: 13px;
  letter-spacing: 0.06em;
  color: var(--fg-muted);
  padding-left: var(--space-5);
  margin-top: var(--space-4);
  display: block;
}

.quote-controls {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  padding-left: var(--space-5);
  margin-top: var(--space-3);
}
.qbtn {
  width: 36px; height: 36px;
  border-radius: 50%;
  border: 1px solid var(--ink-20);
  background: transparent;
  color: var(--ink-80);
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background var(--dur-base) var(--ease-out),
              border-color var(--dur-base) var(--ease-out),
              color var(--dur-base) var(--ease-out);
}
.qbtn:hover {
  background: var(--ink);
  border-color: var(--ink);
  color: var(--paper);
}
.qbtn:active { transform: scale(0.96); }
.qcounter {
  font-family: var(--font-sans);
  font-size: 13px;
  letter-spacing: 0.18em;
  color: var(--fg-muted);
  display: inline-flex;
  align-items: baseline;
  gap: 10px;
  min-width: 80px;
  justify-content: center;
}
.qcounter em {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 22px;
  color: var(--accent);
  letter-spacing: 0;
}

/* ───────── PRICING ──────────────────────────────────────── */
.section--pricing { background: var(--bg); }
.price-block {
  max-width: var(--container-narrow);
  margin: 0 auto var(--space-7);
}
.price-block--full {
  margin-bottom: var(--space-9);
  scroll-margin-top: 100px;
}
.price-block__header {
  margin-bottom: var(--space-5);
  padding-bottom: var(--space-4);
  border-bottom: 1px solid var(--accent);
}
.price-block__header .price-block__head { margin-bottom: var(--space-2); }
.price-block__note {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 16px;
  color: var(--fg-muted);
  margin: 0;
}
.price-block__head {
  font-family: var(--font-serif);
  font-size: 28px;
  margin: 0 0 var(--space-3);
  letter-spacing: -0.005em;
  font-weight: 400;
}
.price-block__head em {
  color: var(--accent);
  font-style: italic;
  display: block;
  font-size: 20px;
  margin-top: 2px;
}
.price-row {
  display: grid;
  grid-template-columns: 1fr auto auto;
  gap: 20px;
  align-items: baseline;
  padding: 14px 0;
  border-bottom: 1px solid var(--hairline);
}
.price-row span:first-child { font-family: var(--font-serif); font-size: 18px; }
.price-row .dur { font-family: var(--font-sans); font-size: 13px; color: var(--ink-60); white-space: nowrap; }
.price-row .price { font-family: var(--font-sans); font-size: 16px; font-weight: 500; color: var(--ink); min-width: 80px; text-align: right; white-space: nowrap; }
.price-foot {
  max-width: var(--container-narrow);
  margin: var(--space-7) auto 0;
  font-style: italic;
  color: var(--ink-60);
  text-align: center;
  font-family: var(--font-serif);
  font-size: 18px;
}
@media (max-width: 560px) {
  .price-row { grid-template-columns: 1fr auto; }
  .price-row .dur { grid-column: 1 / -1; font-size: 12px; }
}

/* ───────── CONTACT ──────────────────────────────────────── */
.section--contact { background: var(--sand-100); }
.contact-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-9);
  align-items: start;
}
.contact-grid__a h2 em { color: var(--accent); font-style: italic; }
.contact-grid__a .lead { color: var(--fg-muted); max-width: 460px; margin-bottom: var(--space-6); }
.kv { display: flex; flex-direction: column; gap: var(--space-4); margin: 0; padding-top: var(--space-5); border-top: 1px solid var(--hairline); }
.kv > div { display: grid; grid-template-columns: 100px 1fr; gap: 18px; align-items: baseline; }
.kv dt { font-family: var(--font-sans); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--fg-muted); margin: 0; }
.kv dd { margin: 0; font-family: var(--font-serif); font-size: 20px; line-height: 1.35; color: var(--ink); }
.kv dd a { color: inherit; text-decoration-color: var(--ink-20); }
.kv dd a:hover { color: var(--accent); }

.contact-form {
  background: var(--paper);
  padding: var(--space-7);
  border-radius: var(--radius-lg);
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}
.field { display: flex; flex-direction: column; gap: 8px; }
.field label {
  font-family: var(--font-sans);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fg-muted);
}
.field input, .field textarea {
  width: 100%;
  background: transparent;
  border: 0;
  border-bottom: 1px solid var(--ink-20);
  padding: 8px 0 12px;
  font-family: var(--font-serif);
  font-size: 22px;
  color: var(--ink);
  outline: none;
  resize: vertical;
  transition: border-color var(--dur-base) var(--ease-out);
}
.field input::placeholder, .field textarea::placeholder { color: var(--ink-40); }
.field input:focus, .field textarea:focus { border-bottom-color: var(--accent); }

/* Contact Form 7 — sieht aus wie das eingebaute Formular */
.contact-form--cf7 .wpcf7-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}
.contact-form--cf7 .wpcf7-form > p { margin: 0; }
.contact-form--cf7 .wpcf7-form label {
  display: flex;
  flex-direction: column;
  gap: 8px;
  font-family: var(--font-sans);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fg-muted);
}
.contact-form--cf7 .wpcf7-form-control-wrap { display: block; }
.contact-form--cf7 input[type="text"],
.contact-form--cf7 input[type="email"],
.contact-form--cf7 input[type="tel"],
.contact-form--cf7 textarea {
  width: 100%;
  background: transparent;
  border: 0;
  border-bottom: 1px solid var(--ink-20);
  padding: 8px 0 12px;
  font-family: var(--font-serif);
  font-size: 22px;
  color: var(--ink);
  outline: none;
  resize: vertical;
  transition: border-color var(--dur-base) var(--ease-out);
}
.contact-form--cf7 input::placeholder,
.contact-form--cf7 textarea::placeholder { color: var(--ink-40); }
.contact-form--cf7 input:focus,
.contact-form--cf7 textarea:focus { border-bottom-color: var(--accent); }
.contact-form--cf7 .wpcf7-submit {
  /* übernimmt .btn .btn--primary .btn--lg Look */
  align-self: flex-start;
}
.contact-form--cf7 .wpcf7-not-valid-tip {
  font-family: var(--font-sans);
  font-size: 12px;
  color: #B0392B;
  margin-top: 4px;
  text-transform: none;
  letter-spacing: 0;
}
.contact-form--cf7 .wpcf7-response-output {
  border: 0 !important;
  border-radius: var(--radius-md);
  padding: var(--space-4) var(--space-5) !important;
  margin: 0 !important;
  font-family: var(--font-sans);
  font-size: 14px;
}
.contact-form--cf7 .wpcf7 form.sent .wpcf7-response-output { background: var(--sage-50); color: var(--ink); }
.contact-form--cf7 .wpcf7 form.invalid .wpcf7-response-output,
.contact-form--cf7 .wpcf7 form.failed .wpcf7-response-output { background: #FAE7E2; color: #7A2D1D; }
.form-thanks {
  text-align: center;
  padding: var(--space-6) 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.form-thanks h3 { font-family: var(--font-serif); font-size: 36px; margin: 0; }
.form-thanks h3 em { color: var(--accent); font-style: italic; }
@media (max-width: 880px) {
  .contact-grid { grid-template-columns: 1fr; gap: var(--space-6); }
}

/* ───────── FOOTER ───────────────────────────────────────── */
.site-footer {
  background: var(--ink);
  color: var(--sand-100);
  padding: var(--space-9) 0 var(--space-5);
}
.site-footer__inner {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: var(--space-7);
}
.site-footer__brand p {
  font-family: var(--font-sans);
  font-size: 13px;
  line-height: 1.6;
  color: var(--sand-200);
  margin: var(--space-4) 0 0;
}
.site-footer__col h4 {
  font-family: var(--font-sans);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--sand-300);
  margin: 0 0 var(--space-3);
  font-weight: 500;
}
.site-footer__col a {
  display: block;
  padding: 4px 0;
  font-family: var(--font-sans);
  font-size: 14px;
  color: var(--sand-100);
  text-decoration: none;
  transition: color var(--dur-base) var(--ease-out);
}
.site-footer__col a:hover { color: var(--terracotta-300); }
.site-footer__disclaimer {
  grid-column: 1 / -1;
  margin: var(--space-7) 0 0;
  padding-top: var(--space-5);
  border-top: 1px solid rgba(255,255,255,0.08);
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 14px;
  color: var(--sand-300);
  max-width: 720px;
}
@media (max-width: 880px) {
  .site-footer__inner { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 560px) {
  .site-footer__inner { grid-template-columns: 1fr; }
}

