/* =============================================
   Lezzet Kadrajı — Design System
   Turkish Kitchen Warmth / Wood / Linen
   ============================================= */

/* --- Reset & Base --- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  /* Palette */
  --clr-cream:  #faf5ef;
  --clr-linen:  #f0e8db;
  --clr-wood:   #8b6f47;
  --clr-wood-dk:#5e4a30;
  --clr-wood-lt:#b89b71;
  --clr-terra:  #c27a4f;
  --clr-terra-dk:#a15d35;
  --clr-olive:  #6b7c4e;
  --clr-olive-lt:#8fa568;
  --clr-charcoal:#2e2a25;
  --clr-text:   #3b352e;
  --clr-text-lt:#6b6159;
  --clr-white:  #ffffff;
  --clr-border: #ddd2c3;
  --clr-shadow: rgba(94,74,48,.12);

  /* Type — system stack */
  --ff-body: "Segoe UI", system-ui, -apple-system, sans-serif;
  --ff-heading: Georgia, "Times New Roman", serif;

  /* Sizes */
  --fs-sm:   .875rem;
  --fs-base: 1rem;
  --fs-md:   1.125rem;
  --fs-lg:   1.5rem;
  --fs-xl:   2rem;
  --fs-xxl:  2.75rem;

  /* Spacing */
  --sp-xs: .25rem;
  --sp-sm: .5rem;
  --sp-md: 1rem;
  --sp-lg: 1.5rem;
  --sp-xl: 2.5rem;
  --sp-xxl:4rem;

  /* Layout */
  --max-w: 1140px;
  --radius: 8px;
  --radius-lg: 16px;

  /* Motion */
  --ease: cubic-bezier(.4,0,.2,1);
  --dur: .3s;
}

html{
  scroll-behavior:smooth;
  font-size:100%;
  -webkit-text-size-adjust:100%;
}

body{
  font-family:var(--ff-body);
  font-size:var(--fs-base);
  line-height:1.7;
  color:var(--clr-text);
  background:var(--clr-cream);
  -webkit-font-smoothing:antialiased;
}

/* --- Skip Link --- */
.skip-link{
  position:absolute;
  top:-100%;
  left:var(--sp-md);
  background:var(--clr-wood-dk);
  color:var(--clr-white);
  padding:var(--sp-sm) var(--sp-md);
  border-radius:0 0 var(--radius) var(--radius);
  z-index:10000;
  font-size:var(--fs-sm);
  text-decoration:none;
  transition:top var(--dur) var(--ease);
}
.skip-link:focus{top:0}

/* --- Container --- */
.container{
  width:100%;
  max-width:var(--max-w);
  margin:0 auto;
  padding:0 var(--sp-lg);
}

/* --- Typography --- */
h1,h2,h3,h4{
  font-family:var(--ff-heading);
  color:var(--clr-wood-dk);
  line-height:1.25;
  margin-bottom:var(--sp-md);
}
h1{font-size:var(--fs-xxl);font-weight:700}
h2{font-size:var(--fs-xl);font-weight:700}
h3{font-size:var(--fs-lg);font-weight:600}
h4{font-size:var(--fs-md);font-weight:600}

p{margin-bottom:var(--sp-md)}
a{color:var(--clr-terra);text-decoration:none;transition:color var(--dur) var(--ease)}
a:hover,a:focus{color:var(--clr-terra-dk);text-decoration:underline}
a:focus-visible{outline:2px solid var(--clr-terra);outline-offset:2px;border-radius:2px}

ul,ol{margin-bottom:var(--sp-md);padding-left:var(--sp-lg)}
li{margin-bottom:var(--sp-xs)}

strong{color:var(--clr-wood-dk)}

/* --- Header --- */
.site-header{
  background:var(--clr-white);
  border-bottom:1px solid var(--clr-border);
  position:sticky;
  top:0;
  z-index:900;
  box-shadow:0 1px 4px var(--clr-shadow);
}
.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:var(--sp-md) var(--sp-lg);
  max-width:var(--max-w);
  margin:0 auto;
}
.site-logo{
  font-family:var(--ff-heading);
  font-size:var(--fs-lg);
  font-weight:700;
  color:var(--clr-wood-dk);
  text-decoration:none;
}
.site-logo span{color:var(--clr-terra)}
.site-logo:hover{text-decoration:none;color:var(--clr-wood)}

/* Nav */
.main-nav ul{
  list-style:none;
  display:flex;
  gap:var(--sp-sm);
  padding:0;
  margin:0;
  flex-wrap:wrap;
}
.main-nav a{
  display:block;
  padding:var(--sp-xs) var(--sp-sm);
  font-size:var(--fs-sm);
  color:var(--clr-text);
  border-radius:var(--radius);
  transition:background var(--dur) var(--ease), color var(--dur) var(--ease);
}
.main-nav a:hover,
.main-nav a:focus,
.main-nav a.active{
  background:var(--clr-linen);
  color:var(--clr-terra);
  text-decoration:none;
}

/* Hamburger / X toggle */
.nav-toggle{
  display:none;
  background:none;
  border:none;
  cursor:pointer;
  padding:var(--sp-sm);
  flex-direction:column;
  gap:5px;
  width:40px;
  height:40px;
  align-items:center;
  justify-content:center;
  border-radius:var(--radius);
  transition:background var(--dur) var(--ease);
}
.nav-toggle:hover{background:var(--clr-linen)}
.nav-toggle span{
  display:block;
  width:22px;
  height:2px;
  background:var(--clr-wood-dk);
  border-radius:2px;
  transition:transform .35s var(--ease), opacity .25s var(--ease);
  transform-origin:center;
}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

@media(max-width:860px){
  .nav-toggle{display:flex}
  .main-nav{
    position:absolute;
    top:100%;
    left:0;right:0;
    background:var(--clr-white);
    border-bottom:1px solid var(--clr-border);
    box-shadow:0 4px 12px var(--clr-shadow);
    padding:0 var(--sp-lg);
    max-height:0;
    overflow:hidden;
    opacity:0;
    transition:max-height .4s var(--ease), opacity .3s var(--ease), padding .4s var(--ease);
  }
  .main-nav.open{
    max-height:500px;
    opacity:1;
    padding:var(--sp-md) var(--sp-lg);
  }
  .main-nav ul{flex-direction:column;gap:0}
  .main-nav a{
    padding:var(--sp-sm) var(--sp-md);
    font-size:var(--fs-base);
    border-radius:var(--radius);
  }
}

/* --- Hero --- */
.hero{
  position:relative;
  padding:var(--sp-xxl) 0;
  text-align:center;
  overflow:hidden;
}
.hero::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    repeating-linear-gradient(
      90deg,
      transparent 0, transparent 40px,
      rgba(139,111,71,.04) 40px, rgba(139,111,71,.04) 41px
    ),
    linear-gradient(180deg, var(--clr-linen) 0%, var(--clr-cream) 100%);
  z-index:0;
}
.hero .container{position:relative;z-index:1}
.hero h1{
  font-size:clamp(2rem,5vw,3.5rem);
  margin-bottom:var(--sp-md);
}
.hero .lead{
  font-size:clamp(1rem, 2.2vw, 1.15rem);
  color:var(--clr-text-lt);
  max-width:620px;
  margin:0 auto var(--sp-xl);
  line-height:1.9;
  letter-spacing:.005em;
}

/* --- Sections --- */
.section{padding:var(--sp-xxl) 0}
.section--alt{background:var(--clr-white)}
.section-title{text-align:center;margin-bottom:var(--sp-xl)}
.section-subtitle{
  text-align:center;
  color:var(--clr-text-lt);
  max-width:620px;
  margin:-1.5rem auto var(--sp-xl);
  font-size:clamp(.95rem, 2vw, 1.075rem);
  line-height:1.8;
}

/* --- Cards (warm glow) --- */
.card-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(300px,1fr));
  gap:var(--sp-xl);
}
.card{
  background:var(--clr-white);
  border:1px solid var(--clr-border);
  border-radius:var(--radius-lg);
  padding:var(--sp-xl);
  transition:transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
  position:relative;
  overflow:hidden;
}
.card::before{
  content:"";
  position:absolute;
  top:0;left:0;right:0;
  height:4px;
  background:linear-gradient(90deg, var(--clr-terra), var(--clr-wood-lt));
  opacity:0;
  transition:opacity var(--dur) var(--ease);
}
.card:hover{
  transform:translateY(-4px);
  box-shadow:0 8px 32px var(--clr-shadow);
}
.card:hover::before{opacity:1}
.card h3{margin-bottom:var(--sp-sm)}
.card p{color:var(--clr-text-lt);font-size:var(--fs-sm);line-height:1.7}
.card-link{
  display:inline-block;
  margin-top:var(--sp-md);
  color:var(--clr-terra);
  font-weight:600;
  font-size:var(--fs-sm);
}

/* --- Placeholder Panels (wood/linen texture) --- */
.placeholder-panel{
  width:100%;
  min-height:220px;
  border-radius:var(--radius-lg);
  background:
    repeating-linear-gradient(
      0deg,
      rgba(139,111,71,.06) 0px,
      transparent 1px,
      transparent 8px,
      rgba(139,111,71,.06) 9px
    ),
    linear-gradient(135deg, #dbc7a8 0%, #c9b48e 30%, #e0d3be 60%, #d4c4a5 100%);
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--clr-wood);
  font-family:var(--ff-heading);
  font-style:italic;
  font-size:var(--fs-sm);
  text-align:center;
  padding:var(--sp-lg);
  margin:var(--sp-lg) 0;
}
.placeholder-panel--linen{
  background:
    repeating-linear-gradient(
      45deg,
      transparent 0, transparent 2px,
      rgba(139,111,71,.03) 2px, rgba(139,111,71,.03) 4px
    ),
    linear-gradient(180deg, #efe6d5 0%, #e8dcc8 100%);
}

/* --- SVG illustrations --- */
.svg-illustration{
  display:block;
  max-width:100%;
  height:auto;
  margin:var(--sp-lg) auto;
}

/* ==============================================
   Content Pages — Warm Editorial Paper
   ============================================== */

.content-page{
  padding:0 0 clamp(2.5rem,6vw,5rem);
  background:var(--clr-cream);
}

/* --- Article Hero — warm open page --- */
.article-hero{
  padding:clamp(2.5rem,7vw,5.5rem) 0 clamp(2rem,5vw,3.5rem);
  background:var(--clr-white);
  border-bottom:1px solid var(--clr-border);
  position:relative;
}
.article-hero::after{
  content:"";
  position:absolute;
  bottom:-1px;left:50%;
  transform:translateX(-50%);
  width:60px;height:3px;
  background:var(--clr-terra);
  border-radius:2px;
}
.article-hero .container{position:relative;z-index:1}
.article-hero .breadcrumb{
  padding:0 0 var(--sp-lg);
  margin:0;
}
.article-hero h1{
  font-size:clamp(1.85rem, 5vw, 3.2rem);
  line-height:1.15;
  letter-spacing:-.02em;
  margin-bottom:var(--sp-lg);
  max-width:680px;
  color:var(--clr-wood-dk);
}
.article-hero__intro{
  color:var(--clr-text-lt);
  font-size:clamp(1rem, 2.2vw, 1.125rem);
  line-height:1.85;
  max-width:600px;
  margin:0;
  font-family:var(--ff-heading);
  font-style:italic;
}

/* --- Paper card --- */
.content-paper{
  max-width:800px;
  margin:0 auto;
  background:var(--clr-white);
  border-radius:var(--radius-lg);
  box-shadow:0 2px 40px rgba(94,74,48,.07), 0 0 0 1px rgba(221,210,195,.5);
  padding:clamp(2rem,5vw,3.5rem) clamp(1.5rem,4vw,3rem);
}

/* --- Content body --- */
.content-body{
  max-width:100%;
  margin:0;
  position:relative;
}

.content-body p{
  margin-bottom:1.5em;
  font-size:clamp(1rem, 1.9vw, 1.0625rem);
  line-height:1.9;
  color:#453d35;
  letter-spacing:.008em;
  word-spacing:.01em;
}

/* First paragraph — lead style */
.content-body > p:first-of-type{
  font-size:clamp(1.05rem, 2.1vw, 1.15rem);
  color:var(--clr-text);
  line-height:1.85;
}
.content-body > p:first-of-type::first-letter{
  float:left;
  font-family:var(--ff-heading);
  font-size:3.6em;
  line-height:.78;
  font-weight:700;
  color:var(--clr-terra);
  margin:.02em .14em 0 0;
}

/* --- H2 — section opener with ornament --- */
.content-body h2,
.content-page h2{
  margin-top:clamp(2.5rem,5vw,3.5rem);
  margin-bottom:var(--sp-lg);
  font-size:clamp(1.35rem, 3.2vw, 1.85rem);
  line-height:1.22;
  color:var(--clr-wood-dk);
  text-align:center;
  position:relative;
  padding-top:clamp(1.5rem,3vw,2.5rem);
}
.content-body h2::before,
.content-page h2::before{
  content:"";
  position:absolute;
  top:0;
  left:50%;
  transform:translateX(-50%);
  width:32px;height:2px;
  background:var(--clr-wood-lt);
  border-radius:1px;
}

/* first H2 needs no top-divider since hero already has one */
.content-body > h2:first-of-type{padding-top:var(--sp-md)}
.content-body > h2:first-of-type::before{display:none}

/* --- H3 — warm inline --- */
.content-body h3,
.content-page h3{
  margin-top:clamp(1.5rem,3vw,2.2rem);
  margin-bottom:var(--sp-sm);
  font-size:clamp(1.1rem, 2.5vw, 1.3rem);
  color:var(--clr-terra-dk);
  font-weight:700;
  padding-left:0;
  border-left:none;
}

/* --- Lists --- */
.content-body ul,
.content-body ol{
  margin-bottom:1.5em;
  padding-left:1.3em;
  font-size:clamp(1rem, 1.9vw, 1.0625rem);
  line-height:1.9;
  list-style:none;
}
.content-body li{
  margin-bottom:.6em;
  padding-left:1.2em;
  position:relative;
}
.content-body li::before{
  content:"";
  position:absolute;
  left:0;top:.7em;
  width:6px;height:6px;
  border:1.5px solid var(--clr-terra);
  border-radius:50%;
  background:transparent;
}
.content-body ol{counter-reset:items}
.content-body ol li{counter-increment:items}
.content-body ol li::before{
  content:counter(items);
  border:none;
  width:auto;height:auto;
  border-radius:0;
  font-weight:700;
  font-size:.85em;
  color:var(--clr-terra);
  top:.05em;
}

.content-body strong{font-weight:700;color:var(--clr-wood-dk)}

.content-body a{
  color:var(--clr-terra);
  text-decoration:underline;
  text-decoration-color:rgba(194,122,79,.3);
  text-underline-offset:3px;
  text-decoration-thickness:1px;
  transition:text-decoration-color var(--dur) var(--ease), color var(--dur) var(--ease);
}
.content-body a:hover{
  color:var(--clr-terra-dk);
  text-decoration-color:var(--clr-terra);
}

.content-page h1{
  margin-bottom:var(--sp-lg);
  font-size:clamp(1.75rem, 4vw, 2.75rem);
  line-height:1.2;
}

/* --- Responsive --- */
@media(max-width:700px){
  .content-paper{
    margin-top:0;
    border-radius:0;
    box-shadow:none;
    padding:var(--sp-xl) var(--sp-md);
  }
  .content-body > p:first-of-type::first-letter{font-size:2.8em}
  .content-body h2,
  .content-page h2{text-align:left}
  .content-body h2::before,
  .content-page h2::before{left:0;transform:none}
}

/* ==============================
   Content Components
   ============================== */

/* --- Related Box --- */
.related-box{
  margin-top:clamp(2rem,4vw,3.5rem);
  padding:var(--sp-xl);
  background:var(--clr-linen);
  border-radius:var(--radius-lg);
  position:relative;
}
.related-box__header{
  display:flex;
  align-items:center;
  gap:var(--sp-sm);
  margin-bottom:var(--sp-lg);
}
.related-box__header svg{width:18px;height:18px;flex-shrink:0;opacity:.5}
.related-box h3{
  margin:0;
  font-size:.75rem;
  font-family:var(--ff-body);
  font-weight:700;
  color:var(--clr-wood);
  letter-spacing:.08em;
  text-transform:uppercase;
}
.related-box ul{
  list-style:none;
  padding:0;
  margin:0;
  display:grid;
  gap:var(--sp-sm);
}
.related-box li{margin:0}
.related-box li::before{display:none}
.related-box a{
  display:block;
  padding:var(--sp-md) var(--sp-lg);
  background:var(--clr-white);
  border-radius:var(--radius);
  font-weight:500;
  font-size:var(--fs-sm);
  color:var(--clr-text);
  text-decoration:none;
  line-height:1.5;
  transition:transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
  box-shadow:0 1px 3px rgba(94,74,48,.04);
}
.related-box a:hover{
  transform:translateY(-2px);
  box-shadow:0 4px 12px rgba(94,74,48,.1);
  color:var(--clr-terra-dk);
  text-decoration:none;
}

/* --- Pull Quote --- */
.pull-quote{
  margin:clamp(2rem,4vw,3rem) auto;
  padding:var(--sp-xl) 0;
  text-align:center;
  position:relative;
  max-width:580px;
}
.pull-quote::before,
.pull-quote::after{
  content:"";
  display:block;
  width:40px;height:1px;
  background:var(--clr-wood-lt);
  margin:0 auto var(--sp-lg);
}
.pull-quote::after{
  margin:var(--sp-lg) auto 0;
}
.pull-quote p{
  font-family:var(--ff-heading);
  font-size:clamp(1.1rem,2.5vw,1.3rem);
  line-height:1.7;
  color:var(--clr-wood-dk);
  margin:0;
  font-style:italic;
}

/* --- Tip Card --- */
.tip-card{
  margin:clamp(1.5rem,3vw,2.5rem) 0;
  padding:var(--sp-lg) var(--sp-xl);
  background:linear-gradient(135deg, #faf5ef 0%, #f5ede0 100%);
  border-radius:var(--radius-lg);
  display:flex;
  gap:var(--sp-lg);
  align-items:flex-start;
  border:1px solid rgba(184,155,113,.2);
}
.tip-card__icon{
  flex-shrink:0;
  width:44px;height:44px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  background:var(--clr-white);
  box-shadow:0 2px 8px rgba(94,74,48,.08);
}
.tip-card__icon--light{background:linear-gradient(135deg,#fffbeb,#fef3c7)}
.tip-card__icon--color{background:linear-gradient(135deg,#eff6ff,#dbeafe)}
.tip-card__icon--camera{background:linear-gradient(135deg,#faf5ef,#e8dcc8)}
.tip-card__icon--share{background:linear-gradient(135deg,#ecfdf5,#d1fae5)}
.tip-card__icon--scene{background:linear-gradient(135deg,#fdf2f8,#fce7f3)}
.tip-card__icon svg{width:20px;height:20px}
.tip-card__body{flex:1;min-width:0}
.tip-card__body strong{
  display:block;
  font-size:.7rem;
  color:var(--clr-wood);
  margin-bottom:var(--sp-xs);
  text-transform:uppercase;
  letter-spacing:.06em;
}
.tip-card__body p{
  margin:0;
  font-size:var(--fs-sm);
  line-height:1.75;
  color:var(--clr-text);
}
@media(max-width:480px){
  .tip-card{flex-direction:column;gap:var(--sp-md)}
}

/* --- Key Concept --- */
.key-concept{
  margin:clamp(2rem,4vw,3rem) 0;
  padding:clamp(1.5rem,3vw,2.5rem);
  background:var(--clr-white);
  border:2px solid var(--clr-linen);
  border-radius:var(--radius-lg);
  text-align:center;
  position:relative;
}
.key-concept__label{
  display:inline-block;
  font-size:.65rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.12em;
  color:var(--clr-wood);
  background:var(--clr-linen);
  padding:.3em .9em;
  border-radius:20px;
  margin-bottom:var(--sp-md);
}
.key-concept h3{
  font-size:clamp(1.2rem,2.8vw,1.5rem);
  margin:0 0 var(--sp-sm);
  color:var(--clr-wood-dk);
  text-align:center;
  padding-top:0;
}
.key-concept h3::before{display:none}
.key-concept p{
  max-width:520px;
  margin:0 auto;
  font-size:var(--fs-sm);
  line-height:1.8;
  color:var(--clr-text-lt);
}

/* --- Feature Row --- */
.feature-row{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(190px,1fr));
  gap:var(--sp-md);
  margin:clamp(1.5rem,3vw,2.5rem) 0;
}
.feature-item{
  text-align:center;
  padding:var(--sp-xl) var(--sp-lg);
  background:var(--clr-white);
  border:1px solid var(--clr-border);
  border-radius:var(--radius-lg);
  transition:transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.feature-item:hover{
  transform:translateY(-3px);
  box-shadow:0 8px 24px rgba(94,74,48,.1);
}
.feature-item__icon{
  width:52px;height:52px;
  margin:0 auto var(--sp-md);
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  background:var(--clr-linen);
}
.feature-item__icon svg{width:24px;height:24px;color:var(--clr-terra)}
.feature-item h4{
  font-size:var(--fs-sm);
  font-family:var(--ff-body);
  margin-bottom:var(--sp-xs);
  color:var(--clr-wood-dk);
  font-weight:700;
}
.feature-item p{
  font-size:.825rem;
  line-height:1.65;
  color:var(--clr-text-lt);
  margin:0;
}

/* --- Light Direction Selector --- */
.light-selector{
  background:var(--clr-white);
  border:1px solid var(--clr-border);
  border-radius:var(--radius-lg);
  padding:var(--sp-xl);
  margin:var(--sp-xl) 0;
}
.light-selector h3{text-align:center;margin-bottom:var(--sp-lg)}
.light-options{
  display:flex;
  gap:var(--sp-md);
  justify-content:center;
  flex-wrap:wrap;
  margin-bottom:var(--sp-lg);
}
.light-btn{
  padding:var(--sp-sm) var(--sp-lg);
  border:2px solid var(--clr-border);
  border-radius:var(--radius);
  background:var(--clr-cream);
  color:var(--clr-text);
  cursor:pointer;
  font-family:var(--ff-body);
  font-size:var(--fs-sm);
  font-weight:600;
  transition:all var(--dur) var(--ease);
}
.light-btn:hover{border-color:var(--clr-wood-lt);background:var(--clr-linen)}
.light-btn:focus-visible{outline:2px solid var(--clr-terra);outline-offset:2px}
.light-btn[aria-pressed="true"]{
  border-color:var(--clr-terra);
  background:var(--clr-terra);
  color:var(--clr-white);
}
.light-result{
  min-height:160px;
  display:flex;
  gap:var(--sp-xl);
  align-items:flex-start;
  flex-wrap:wrap;
}
.light-result__text{flex:1;min-width:240px;font-size:var(--fs-sm);line-height:1.8}
.light-result__text h4{margin-bottom:var(--sp-sm);color:var(--clr-terra-dk)}
.light-result__text p{line-height:1.85}
.light-result__svg{flex:0 0 220px}

/* --- FAQ Accordion --- */
.faq-list{max-width:780px;margin:0 auto}
.faq-item{
  border-bottom:1px solid var(--clr-border);
}
.faq-question{
  display:flex;
  align-items:center;
  justify-content:space-between;
  width:100%;
  padding:var(--sp-lg) 0;
  background:none;
  border:none;
  cursor:pointer;
  font-family:var(--ff-heading);
  font-size:var(--fs-md);
  color:var(--clr-wood-dk);
  text-align:left;
  line-height:1.4;
  transition:color var(--dur) var(--ease);
}
.faq-question:hover{color:var(--clr-terra)}
.faq-question:focus-visible{outline:2px solid var(--clr-terra);outline-offset:2px;border-radius:2px}
.faq-icon{
  flex-shrink:0;
  width:24px;height:24px;
  margin-left:var(--sp-md);
  transition:transform .35s var(--ease);
}
.faq-item[open] .faq-icon{transform:rotate(180deg)}
.faq-answer{
  color:var(--clr-text-lt);
  line-height:1.8;
  overflow:hidden;
  max-height:0;
  opacity:0;
  padding:0;
  transition:max-height .4s var(--ease), opacity .35s var(--ease), padding .4s var(--ease);
}
.faq-answer.open{
  max-height:600px;
  opacity:1;
  padding:0 0 var(--sp-lg);
}
.faq-answer p{
  font-size:var(--fs-base);
  line-height:1.85;
}

/* --- Form --- */
.form-group{margin-bottom:var(--sp-lg)}
.form-group label{
  display:block;
  margin-bottom:var(--sp-xs);
  font-weight:600;
  font-size:var(--fs-sm);
  color:var(--clr-wood-dk);
}
.form-group input,
.form-group textarea,
.form-group select{
  width:100%;
  padding:.75rem var(--sp-md);
  border:1px solid var(--clr-border);
  border-radius:var(--radius);
  font-family:var(--ff-body);
  font-size:var(--fs-base);
  line-height:1.5;
  color:var(--clr-text);
  background:var(--clr-white);
  transition:border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.form-group input:focus,
.form-group textarea:focus{
  outline:none;
  border-color:var(--clr-terra);
  box-shadow:0 0 0 3px rgba(194,122,79,.15);
}
.form-group textarea{resize:vertical;min-height:140px}
.form-group .field-note{font-size:.75rem;color:var(--clr-text-lt);margin-top:var(--sp-xs)}

.form-check{
  display:flex;
  align-items:flex-start;
  gap:var(--sp-sm);
  margin-bottom:var(--sp-lg);
}
.form-check input[type="checkbox"]{
  margin-top:4px;
  accent-color:var(--clr-terra);
  width:18px;height:18px;
  flex-shrink:0;
}
.form-check label{font-size:var(--fs-sm);line-height:1.5;font-weight:400}

.btn{
  display:inline-block;
  padding:var(--sp-sm) var(--sp-xl);
  background:var(--clr-terra);
  color:var(--clr-white);
  border:none;
  border-radius:var(--radius);
  font-family:var(--ff-body);
  font-size:var(--fs-base);
  font-weight:600;
  cursor:pointer;
  transition:background var(--dur) var(--ease), transform var(--dur) var(--ease);
}
.btn:hover{background:var(--clr-terra-dk);transform:translateY(-1px)}
.btn:focus-visible{outline:2px solid var(--clr-wood-dk);outline-offset:2px}
.btn:disabled{opacity:.6;cursor:not-allowed;transform:none}

.form-status{
  margin-top:var(--sp-md);
  padding:var(--sp-md);
  border-radius:var(--radius);
  font-size:var(--fs-sm);
  display:none;
}
.form-status--success{display:block;background:#e8f5e9;color:#2e7d32;border:1px solid #a5d6a7}
.form-status--error{display:block;background:#fbe9e7;color:#c62828;border:1px solid #ef9a9a}

.hp-field{position:absolute;left:-9999px;height:0;overflow:hidden;tab-index:-1}

/* --- Contact Info --- */
.contact-info{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:var(--sp-lg);
  margin-bottom:var(--sp-xxl);
}
.contact-info-item{
  background:var(--clr-white);
  padding:var(--sp-lg);
  border-radius:var(--radius);
  border:1px solid var(--clr-border);
}
.contact-info-item h3{font-size:var(--fs-sm);margin-bottom:var(--sp-xs);margin-top:0;font-family:var(--ff-body);padding:0;border:none}
.contact-info-item h3::before{display:none}
.contact-info-item p{color:var(--clr-text-lt);font-size:var(--fs-sm);margin:0}

/* --- Footer --- */
.site-footer{
  background:var(--clr-wood-dk);
  color:var(--clr-linen);
  padding:var(--sp-xxl) 0 var(--sp-lg);
}
.footer-inner{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
  gap:var(--sp-xl);
  max-width:var(--max-w);
  margin:0 auto;
  padding:0 var(--sp-lg);
}
.footer-col h4{
  color:var(--clr-wood-lt);
  font-family:var(--ff-body);
  font-size:var(--fs-sm);
  text-transform:uppercase;
  letter-spacing:.05em;
  margin-bottom:var(--sp-md);
}
.footer-col ul{list-style:none;padding:0}
.footer-col li{margin-bottom:var(--sp-sm)}
.footer-col a{color:var(--clr-linen);font-size:var(--fs-sm);opacity:.85;transition:opacity var(--dur) var(--ease)}
.footer-col a:hover{opacity:1;color:var(--clr-white);text-decoration:underline}
.footer-bottom{
  text-align:center;
  padding-top:var(--sp-xl);
  margin-top:var(--sp-xl);
  border-top:1px solid rgba(255,255,255,.12);
  font-size:var(--fs-sm);
  opacity:.7;
  max-width:var(--max-w);
  margin-left:auto;
  margin-right:auto;
  padding-left:var(--sp-lg);
  padding-right:var(--sp-lg);
}

/* --- Cookie Banner --- */
.cookie-banner{
  position:fixed;
  bottom:0;left:0;right:0;
  background:var(--clr-white);
  border-top:1px solid var(--clr-border);
  box-shadow:0 -4px 24px var(--clr-shadow);
  padding:var(--sp-lg);
  z-index:9999;
  transform:translateY(100%);
  transition:transform .4s var(--ease);
}
.cookie-banner.visible{transform:translateY(0)}
.cookie-inner{
  max-width:var(--max-w);
  margin:0 auto;
}
.cookie-inner__row{
  display:flex;
  align-items:center;
  gap:var(--sp-lg);
  flex-wrap:wrap;
}
.cookie-text{flex:1;min-width:220px;font-size:var(--fs-sm);line-height:1.6}
.cookie-text a{font-weight:600}
.cookie-text p{margin:0}
.cookie-actions{
  display:flex;
  gap:var(--sp-sm);
  flex-shrink:0;
  align-items:center;
}
.cookie-btn{
  padding:var(--sp-sm) var(--sp-lg);
  border-radius:var(--radius);
  font-family:var(--ff-body);
  font-size:var(--fs-sm);
  font-weight:600;
  cursor:pointer;
  transition:all var(--dur) var(--ease);
  border:2px solid var(--clr-terra);
}
.cookie-btn:focus-visible{outline:2px solid var(--clr-wood-dk);outline-offset:2px}
.cookie-btn--accept{background:var(--clr-terra);color:var(--clr-white)}
.cookie-btn--accept:hover{background:var(--clr-terra-dk);border-color:var(--clr-terra-dk)}
.cookie-btn--reject{background:var(--clr-white);color:var(--clr-terra)}
.cookie-btn--reject:hover{background:var(--clr-linen)}
.cookie-btn--settings{background:transparent;color:var(--clr-text);border-color:var(--clr-border)}
.cookie-btn--settings:hover{border-color:var(--clr-wood-lt);background:var(--clr-linen)}

/* Cookie Settings Panel */
.cookie-settings{
  margin-top:var(--sp-md);
  padding:0 var(--sp-lg);
  background:var(--clr-cream);
  border-radius:var(--radius);
  border:1px solid var(--clr-border);
  width:100%;
  max-height:0;
  overflow:hidden;
  opacity:0;
  transition:max-height .4s var(--ease), opacity .3s var(--ease), padding .4s var(--ease);
}
.cookie-settings.open{
  max-height:400px;
  opacity:1;
  padding:var(--sp-lg);
}
.cookie-settings h3{font-size:var(--fs-base);margin-bottom:var(--sp-md);font-family:var(--ff-body)}
.cookie-option{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:var(--sp-sm) 0;
  border-bottom:1px solid var(--clr-border);
}
.cookie-option:last-child{border-bottom:none}
.cookie-option label{font-size:var(--fs-sm);font-weight:600}
.cookie-option span{font-size:.75rem;color:var(--clr-text-lt)}

/* Toggle switch */
.toggle{
  position:relative;
  width:44px;height:24px;
  flex-shrink:0;
}
.toggle input{opacity:0;width:0;height:0;position:absolute}
.toggle-slider{
  position:absolute;
  inset:0;
  background:var(--clr-border);
  border-radius:12px;
  cursor:pointer;
  transition:background var(--dur) var(--ease);
}
.toggle-slider::before{
  content:"";
  position:absolute;
  left:2px;top:2px;
  width:20px;height:20px;
  background:var(--clr-white);
  border-radius:50%;
  transition:transform var(--dur) var(--ease);
}
.toggle input:checked + .toggle-slider{background:var(--clr-olive)}
.toggle input:checked + .toggle-slider::before{transform:translateX(20px)}
.toggle input:disabled + .toggle-slider{opacity:.6;cursor:not-allowed}
.toggle input:focus-visible + .toggle-slider{outline:2px solid var(--clr-terra);outline-offset:2px}
.cookie-save-btn{
  margin-top:var(--sp-md);
  padding:var(--sp-sm) var(--sp-lg);
  background:var(--clr-wood);
  color:var(--clr-white);
  border:none;
  border-radius:var(--radius);
  font-family:var(--ff-body);
  font-size:var(--fs-sm);
  font-weight:600;
  cursor:pointer;
}
.cookie-save-btn:hover{background:var(--clr-wood-dk)}

/* --- 404 --- */
.page-404{
  text-align:center;
  padding:var(--sp-xxl) 0;
  min-height:60vh;
  display:flex;
  align-items:center;
  justify-content:center;
}
.page-404 h1{font-size:clamp(4rem,10vw,8rem);color:var(--clr-wood-lt);margin-bottom:var(--sp-sm)}
.page-404 p{font-size:var(--fs-lg);color:var(--clr-text-lt);margin-bottom:var(--sp-xl)}

/* --- Sitemap page --- */
.sitemap-list{
  columns:2;
  column-gap:var(--sp-xl);
  list-style:none;
  padding:0;
}
.sitemap-list li{
  break-inside:avoid;
  margin-bottom:var(--sp-sm);
  padding:var(--sp-sm) 0;
  border-bottom:1px solid var(--clr-border);
}
@media(max-width:480px){.sitemap-list{columns:1}}

/* --- Breadcrumb --- */
.breadcrumb{
  font-size:var(--fs-sm);
  color:var(--clr-text-lt);
  padding:var(--sp-md) 0 var(--sp-lg);
  margin-bottom:var(--sp-sm);
}
.breadcrumb a{
  color:var(--clr-text-lt);
  text-decoration:none;
  transition:color var(--dur) var(--ease);
}
.breadcrumb a:hover{color:var(--clr-terra);text-decoration:none}
.breadcrumb span{margin:0 var(--sp-xs);opacity:.5}

/* --- Utility --- */
.text-center{text-align:center}
.mt-xl{margin-top:var(--sp-xl)}
.mb-xl{margin-bottom:var(--sp-xl)}
.visually-hidden{
  position:absolute!important;
  width:1px!important;height:1px!important;
  padding:0!important;margin:-1px!important;
  overflow:hidden!important;
  clip:rect(0,0,0,0)!important;
  white-space:nowrap!important;
  border:0!important;
}

/* --- Reduced Motion --- */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.01ms!important;
    animation-iteration-count:1!important;
    transition-duration:.01ms!important;
    scroll-behavior:auto!important;
  }
}

/* --- Content Images --- */
.content-image{
  margin:clamp(1.5rem,3vw,2.5rem) 0;
  border-radius:var(--radius);
  overflow:hidden;
}
.content-image img{
  display:block;
  width:100%;
  height:auto;
  border-radius:var(--radius);
}
.content-image figcaption{
  font-size:.8rem;
  color:var(--clr-text-lt);
  font-style:italic;
  margin-top:var(--sp-sm);
  text-align:center;
  letter-spacing:.02em;
}

/* Image + text side-by-side */
.text-with-image{
  display:flex;
  gap:var(--sp-xl);
  align-items:center;
  margin:clamp(1.5rem,3vw,2.5rem) calc(-1 * var(--sp-lg));
  padding:var(--sp-lg);
  background:var(--clr-linen);
  border-radius:var(--radius-lg);
}
.text-with-image__img{
  flex:0 0 260px;
  max-width:260px;
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:0 4px 20px rgba(94,74,48,.12);
}
.text-with-image__img img{
  display:block;
  width:100%;
  height:auto;
}
.text-with-image__content{
  flex:1;
  min-width:0;
}
.text-with-image__content p{
  font-size:clamp(.925rem, 1.7vw, 1rem);
  line-height:1.8;
  color:var(--clr-text);
  margin-bottom:0;
}
.text-with-image__content h3{
  margin-top:0;
  text-align:left;
  padding-top:0;
}
.text-with-image__content h3::before{display:none}
.text-with-image--reverse{
  flex-direction:row-reverse;
}
@media(max-width:680px){
  .text-with-image{
    flex-direction:column;
    margin-left:0;margin-right:0;
    padding:var(--sp-md);
  }
  .text-with-image--reverse{
    flex-direction:column;
  }
  .text-with-image__img{
    flex:none;
    max-width:100%;
  }
}

/* --- Print --- */
@media print{
  .site-header,.site-footer,.cookie-banner,.skip-link{display:none}
  body{color:#000;background:#fff}
  a{color:#000;text-decoration:underline}
}
