:root {
  --c1: #A47251;
  --c2: #DD9E59;
  --c3: #F0D8A1;
  --c4: #DCF0C3;
  --ink: #2b2521;
  --paper: #fffdf9;
  --line: #e8d4be;
  --shadow: 0 14px 30px rgba(85, 58, 34, .12);
  --s1: .5rem;
  --s2: 1rem;
  --s3: 1.5rem;
  --s4: 2.4rem;
  --s5: 3.5rem;
}

* {
  box-sizing: border-box
}

html {
  scroll-behavior: smooth
}

body {
  margin: 0;
  font-family: "Segoe UI", Arial, sans-serif;
  color: var(--ink);
  background: radial-gradient(circle at 90% 10%, #fff, var(--c3) 42%, #fff 80%)
}

a {
  color: inherit;
  text-decoration: none
}

img {
  max-width: 100%;
  display: block
}

.site-header {
  position: sticky;
  top: 0;
  background: rgba(255, 253, 249, .95);
  backdrop-filter: blur(6px);
  border-bottom: 1px solid var(--line);
  z-index: 20
}

.header-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--s2) var(--s3)
}

.brand {
  display: block;
}

.brand img {
  width: 4rem;
  position: relative;
  z-index: 20;
}

.brand img {
  display: inline-block;
  transform: rotate(-5deg);
  transition: transform var(--transition-normal);
}

.brand:hover img {
  transform: rotate(0);
}

/* Responsive Styles */
@media (max-width: 992px) {
  .brand img {
    width: 3rem;
    position: relative;
    z-index: 20;
  }
}

@media (max-width: 768px) {
  .brand img {
    width: 3rem;
    position: relative;
    z-index: 20;
  }
}

@media (max-width: 576px) {
  .brand img {
    width: 2rem;
    position: relative;
    z-index: 20;
  }
}

@media (max-width: 400px) {
  .brand img {
    width: 2rem;
    position: relative;
    z-index: 20;
  }
}

.menu-toggle {
  border: 1px solid var(--c1);
  padding: .45rem .8rem;
  background: transparent;
  cursor: pointer;
  transition: all .25s
}

.menu-toggle:hover {
  background: var(--c1);
  color: #fff
}

.site-nav {
  display: none;
  border-top: 1px solid var(--line);
  padding: var(--s2) var(--s3)
}

.site-nav.open {
  display: block
}

.site-nav ul {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: .7rem
}

.site-nav a {
  border-bottom: 2px solid transparent;
  display: inline-block;
  padding-bottom: .15rem
}

.site-nav a:hover,
.site-nav a.active {
  border-color: var(--c2)
}

main {
  padding: var(--s3);
  display: grid;
  gap: var(--s4)
}

.hero-note,
.hero-context,
.timeline,
.paper,
.workings,
.faq,
.notice,
.history-strip,
.ethics,
.brief,
.matrix>div,
.doc-stack article,
.limits,
.contact-layout aside,
.contact-layout form,
.policy,
.thanks,
.local-proof article,
.mini-tool,
.checklist,
.roles,
.response-note,
.tabs,
.tab-panel {
  background: var(--paper);
  border-radius: 18px;
  padding: var(--s3);
  box-shadow: var(--shadow)
}

.collage-hero .hero-grid {
  display: grid;
  grid-template-columns: 1.15fr .85fr;
  gap: var(--s3)
}

.hero-fragment img {
  border-radius: 16px;
  min-height: 200px;
  object-fit: cover
}

.hero-fragment.a {
  transform: translateY(10px)
}

.hero-fragment.b {
  transform: translateY(-10px)
}

.eyebrow {
  font-size: .85rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: #6f5b4b
}

.local-proof {
  display: grid;
  grid-template-columns: 1.1fr .9fr;
  gap: var(--s2)
}

.timeline ol {
  display: grid;
  gap: .5rem;
  padding-left: 1.2rem
}

.split-story {
  display: grid;
  grid-template-columns: 1fr .9fr;
  gap: var(--s3)
}

.workings-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s2)
}

.indicator-wrap {
  display: grid;
  gap: .8rem
}

input[type="range"] {
  accent-color: var(--c1)
}

#minutesAdvice {
  padding: .7rem;
  background: #fff7eb;
  border-left: 4px solid var(--c2)
}

.faq-list article {
  border-bottom: 1px dashed #d6b590;
  padding: .2rem 0
}

.faq button {
  width: 100%;
  text-align: left;
  background: none;
  border: 0;
  padding: .8rem 0;
  font-size: 1rem;
  cursor: pointer
}

.answer {
  max-height: 0;
  overflow: hidden;
  transition: max-height .35s ease
}

.faq-list article.open .answer {
  max-height: 160px
}

.disclaimer-band {
  padding: var(--s2) var(--s3);
  background: var(--c4);
  border-left: 5px solid var(--c1);
  border-radius: 12px
}

.approach-layout {
  grid-template-columns: 1.2fr .8fr
}

.matrix {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--s2)
}

.doc-stack {
  display: grid;
  gap: var(--s2)
}

.limits {
  align-self: start
}

.filter-bar {
  display: flex;
  flex-wrap: wrap;
  gap: .65rem
}

.filter {
  padding: .55rem .95rem;
  background: #fff;
  border: 1px solid #d4b390;
  cursor: pointer;
  transition: all .25s
}

.filter.active,
.filter:hover {
  background: var(--c3)
}

.routine-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(220px, 1fr));
  gap: var(--s2)
}

.routine-list article {
  background: #fff;
  border: 1px solid var(--line);
  padding: var(--s2);
  transition: transform .22s ease, border-color .22s ease
}

.routine-list article:hover {
  transform: translateY(-4px);
  border-color: var(--c2)
}

.tabs {
  display: grid;
  gap: var(--s2)
}

.tab-buttons {
  display: flex;
  gap: .5rem;
  flex-wrap: wrap
}

.tab-btn {
  padding: .45rem .8rem;
  border: 1px solid var(--line);
  background: #fff;
  cursor: pointer
}

.tab-btn.active {
  background: var(--c4);
  border-color: #88af66
}

.tab-panel {
  display: none
}

.tab-panel.active {
  display: block;
  animation: fadeIn .35s ease
}

.team-main {
  display: grid;
  gap: var(--s3)
}

.team-cards {
  display: grid;
  grid-template-columns: 2fr 1fr 1.2fr;
  gap: var(--s2)
}

.team-cards article {
  background: #fff;
  padding: var(--s2);
  border-top: 4px solid var(--c2)
}

.contact-layout {
  display: grid;
  grid-template-columns: 1.15fr .85fr;
  gap: var(--s3)
}

form label {
  display: block;
  margin-bottom: .9rem
}

input,
textarea {
  width: 100%;
  padding: .65rem;
  border: 1px solid #cdb49a;
  background: #fff
}

textarea {
  min-height: 140px;
  resize: vertical
}

.gdpr {
  display: flex;
  gap: .6rem;
  align-items: flex-start
}

.error {
  color: #8b2a2a;
  font-size: .85rem;
  display: block;
  min-height: 1em
}

button[type="submit"],
.cta {
  background: var(--c1);
  color: #fff;
  border: 0;
  padding: .72rem 1rem;
  cursor: pointer;
  transition: transform .22s, background .22s
}

button[type="submit"]:hover,
.cta:hover {
  transform: translateY(-2px);
  background: #8e5e3f
}

.cookie-banner {
  position: fixed;
  left: 1rem;
  right: 1rem;
  bottom: 1rem;
  background: #fff;
  padding: var(--s2);
  box-shadow: var(--shadow);
  border: 1px solid #dcbf9f;
  z-index: 25
}

.cookie-actions {
  display: flex;
  gap: .5rem;
  flex-wrap: wrap
}

#cookieDialog {
  border: 0;
  border-radius: 14px;
  padding: 0
}

.cookie-settings {
  padding: var(--s3);
  min-width: min(92vw, 420px)
}

.switch {
  display: flex;
  gap: .5rem;
  margin-bottom: .6rem
}

.switch.fixed {
  opacity: .82
}

.site-footer {
  margin-top: var(--s5);
  background: #2f2721;
  color: #f9ebd4;
  padding: var(--s4);
  display: grid;
  gap: var(--s2);
  grid-template-columns: 1.2fr .8fr
}

.footer-meta a {
  margin-right: .7rem;
  text-decoration: underline;
  text-underline-offset: 2px
}

.mini-footer {
  padding: var(--s2) var(--s3)
}

.policy {
  max-width: 960px;
  margin: 2rem auto;
  display: grid;
  gap: var(--s2)
}

.imprint dl {
  display: grid;
  grid-template-columns: 180px 1fr;
  gap: .35rem .7rem
}

.thanks {
  max-width: 620px;
  margin: 14vh auto;
  text-align: center
}

iframe {
  width: 100%;
  height: 220px;
  border: 0
}

.reveal {
  opacity: 0;
  transform: translateY(14px);
  transition: opacity .55s ease, transform .55s ease
}

.reveal.is-visible {
  opacity: 1;
  transform: translateY(0)
}

@keyframes fadeIn {
  from {
    opacity: 0
  }

  to {
    opacity: 1
  }
}

@media (max-width:860px) {

  .collage-hero .hero-grid,
  .local-proof,
  .split-story,
  .approach-layout,
  .contact-layout,
  .workings-grid,
  .team-cards,
  .routine-list {
    grid-template-columns: 1fr
  }

  .hero-fragment.a,
  .hero-fragment.b {
    transform: none
  }
}