:root {
  interpolate-size: allow-keywords;
  --bg: #F4EFE6;
  --surface: #FAFAF7;
  --surface-2: #ECE7DD;
  --ink: #1E1A14;
  --ink-soft: #6B6359;
  --accent: #7A3B10;
  --accent-2: #BFA07A;
  --line: rgba(30,26,20,0.10);
  --line-strong: rgba(30,26,20,0.22);
  --header-h: 72px;
  --radius: 6px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{overflow-x:hidden;max-width:100vw;margin:0}

@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

body{
  font-family:'Source Serif 4','Georgia',serif;
  font-weight:400;
  font-size:clamp(16px,1.05vw,18px);
  line-height:1.7;
  letter-spacing:-0.01em;
  color:var(--ink);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--accent);text-decoration:none;transition:color 240ms cubic-bezier(.4,0,.2,1)}
a:hover{color:var(--ink)}
a:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--accent);outline-offset:2px}

h1,h2,h3,h4,h5,h6{
  font-family:'Playfair Display','Palatino Linotype','Georgia',serif;
  font-weight:700;font-style:normal;line-height:1.15;letter-spacing:-0.012em;color:var(--ink);
}
h1{font-size:clamp(2.5rem, 6vw, 4.5rem)}
h2{font-size:clamp(1.8rem,3.5vw,2.8rem);margin-bottom:.5em}
h3{font-size:clamp(1.3rem,2.2vw,1.7rem)}
h4{font-size:clamp(1.1rem,1.5vw,1.3rem)}
p{margin-bottom:1em;max-width:68ch}
strong{font-weight:600}
ul,ol{padding-left:1.2em;margin-bottom:1em}

.container{
  width:100%;max-width:1080px;margin:0 auto;
  padding-left:clamp(16px,4vw,32px);padding-right:clamp(16px,4vw,32px);
}
main{padding-top:var(--header-h);position:relative}
section{padding:clamp(3rem,8vw,6rem) 0;position:relative}
.section-alt{background:var(--surface)}

.skip-link{
  position:absolute;top:-100%;left:16px;background:var(--ink);color:var(--surface);
  padding:8px 16px;z-index:10000;font-size:14px;border-radius:var(--radius);
}
.skip-link:focus{top:8px}

/* ═══ HEADER ═══ */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:1080;
  background:rgba(244, 239, 230, 0.92);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  transition:background 240ms ease,box-shadow 240ms ease,padding 240ms ease;
}
.site-header.scrolled{
  background:rgba(244,239,230,0.98);
  box-shadow:0 8px 24px -16px rgba(0,0,0,.18);
}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:var(--header-h);max-width:1080px;margin:0 auto;
  padding:0 clamp(16px,4vw,32px);
}
.logo{
  font-family:'Playfair Display',serif;font-weight:700;
  font-size:clamp(1.05rem,1.8vw,1.3rem);color:var(--ink);
  text-decoration:none;letter-spacing:-0.02em;white-space:nowrap;
}
.logo:hover{color:var(--accent)}
.logo span{color:var(--accent-2)}

/* ═══ NAV DESKTOP ═══ */
.nav-desktop{display:none;align-items:center;gap:clamp(14px,2.2vw,24px)}
@media(min-width:1024px){.nav-desktop{display:flex}}
.nav-desktop a{
  font-family:'Source Serif 4',serif;font-size:.88rem;font-weight:400;
  color:var(--ink);text-decoration:none;position:relative;padding:4px 0;
  transition:color 240ms cubic-bezier(.4,0,.2,1);
}
.nav-desktop a::after{
  content:'';position:absolute;bottom:-2px;left:0;width:0;height:1.5px;
  background:var(--accent);transition:width 280ms cubic-bezier(.2,.7,.2,1);
}
.nav-desktop a:hover::after,.nav-desktop a.is-active::after{width:100%}
.nav-desktop a.is-active{color:var(--accent)}
.nav-desktop .nav-cta{
  background:var(--ink);color:var(--surface);padding:8px 18px;
  border-radius:var(--radius);font-weight:600;font-size:.82rem;letter-spacing:.01em;
  transition:background 240ms ease,color 240ms ease,transform 180ms ease;
}
.nav-desktop .nav-cta::after{display:none}
.nav-desktop .nav-cta:hover{background:var(--accent);color:var(--surface);transform:translateY(-2px)}

/* ═══ NAV TOGGLE ═══ */
.nav-toggle{
  display:flex;flex-direction:column;justify-content:center;align-items:center;
  width:44px;height:44px;background:none;border:none;cursor:pointer;
  z-index:1100;position:relative;padding:0;
}
@media(min-width:1024px){.nav-toggle{display:none}}
.nav-toggle:hover span{background:var(--accent)}
.nav-toggle:active{transform:scale(.92)}
@media(max-width:1023px){
  .nav-toggle{
    background:rgba(30,26,20,0.06);border-radius:var(--radius);
    border:1.5px solid var(--line);
  }
  .nav-toggle:hover{background:rgba(30,26,20,0.1)}
}
.nav-toggle span{
  display:block;width:22px;height:2.5px;background:var(--ink);border-radius:2px;
  transition:transform 320ms cubic-bezier(.2,.7,.2,1),opacity 240ms ease;position:absolute;
}
.nav-toggle span:nth-child(1){transform:translateY(-7px)}
.nav-toggle span:nth-child(2){transform:translateY(0)}
.nav-toggle span:nth-child(3){transform:translateY(7px)}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:rotate(-45deg)}

/* ═══ DRAWER ═══ */
.drawer-backdrop{
  position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:1040;
  opacity:0;pointer-events:none;transition:opacity 240ms ease;
}
.drawer-backdrop.is-open{opacity:1;pointer-events:auto}
.drawer{
  position:fixed;top:0;right:0;bottom:0;width:min(360px,92vw);
  background:var(--surface);z-index:1050;
  transform:translateX(100%);visibility:hidden;
  transition:transform 320ms cubic-bezier(.2,.7,.2,1),visibility 0s 320ms;
  padding:calc(var(--header-h) + 24px) clamp(24px,5vw,40px) 32px;
  display:flex;flex-direction:column;gap:8px;overflow-y:auto;
}
.drawer.is-open{transform:translateX(0);visibility:visible;transition:transform 320ms cubic-bezier(.2,.7,.2,1),visibility 0s 0s}
.drawer a{
  font-family:'Playfair Display',serif;font-size:1.15rem;font-weight:700;
  color:var(--ink);text-decoration:none;padding:12px 0;
  border-bottom:1px solid var(--line);display:block;
  transition:color 240ms ease,padding-left 240ms ease;
}
.drawer a:hover,.drawer a.is-active{color:var(--accent);padding-left:8px}
.drawer .nav-cta-mobile{
  margin-top:16px;background:var(--ink);color:var(--surface);text-align:center;
  padding:14px 24px;border-radius:var(--radius);border-bottom:none;font-size:1rem;
}
.drawer .nav-cta-mobile:hover{background:var(--accent);color:var(--surface)}

/* ═══ BUTTONS ═══ */
.btn-primary{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--ink);color:var(--surface);padding:14px 32px;
  border:none;border-radius:var(--radius);
  font-family:'Source Serif 4',serif;font-size:1rem;font-weight:600;
  cursor:pointer;text-decoration:none;position:relative;overflow:hidden;
  transition:background 280ms cubic-bezier(.16,1,.3,1),color 240ms ease,transform 220ms cubic-bezier(.16,1,.3,1),box-shadow 280ms ease;
}
.btn-primary:hover,.btn-primary:focus-visible{
  background:var(--accent);color:var(--surface);
  transform:translateY(-3px);box-shadow:0 8px 24px rgba(122,59,16,.3),0 2px 8px rgba(122,59,16,.1),0 0 48px rgba(122,59,16,.08);
}
.btn-primary::after{content:'→';font-size:1.1em;transition:transform 320ms cubic-bezier(.22,1,.36,1)}
.btn-primary:hover::after{transform:translateX(6px)}
.btn-ghost{
  display:inline-flex;align-items:center;gap:8px;
  background:transparent;color:var(--ink);padding:12px 28px;
  border:1.5px solid var(--line-strong);border-radius:var(--radius);
  font-family:'Source Serif 4',serif;font-size:.95rem;font-weight:600;
  cursor:pointer;text-decoration:none;
  transition:background 280ms cubic-bezier(.16,1,.3,1),color 240ms ease,border-color 280ms ease,transform 220ms cubic-bezier(.16,1,.3,1),box-shadow 280ms ease;
}
.btn-ghost:hover,.btn-ghost:focus-visible{
  background:var(--surface);color:var(--ink);border-color:var(--accent);
  transform:translateY(-2px);box-shadow:0 4px 16px rgba(122,59,16,.1);
}

/* ═══ HERO ═══ */
.hero{
  min-height:0;display:flex;align-items:center;position:relative;
  background:linear-gradient(175deg,var(--bg) 0%,var(--surface) 35%,var(--bg) 100%);
  overflow:hidden;
  padding-top:clamp(3rem,8vw,5rem);padding-bottom:clamp(2.5rem,6vw,4rem);
}
.hero::before{
  content:'';position:absolute;inset:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E");
  pointer-events:none;z-index:0;
}
.hero>.container{position:relative;z-index:1}

.eyebrow{
  display:inline-block;font-family:'Source Serif 4',serif;font-size:.78rem;
  font-weight:600;letter-spacing:.18em;text-transform:uppercase;
  color:var(--accent);margin-bottom:1.5rem;position:relative;padding-left:36px;
}
.eyebrow::before{
  content:'';position:absolute;left:0;top:50%;width:24px;height:1.5px;background:var(--accent-2);
}

.hero__title{
  font-size:clamp(2.8rem, 7vw, 4.5rem);line-height:1.05;letter-spacing:-0.02em;
  margin-bottom:1.5rem;max-width:14ch;
}
.drop-cap-hero{
  float:left;font-size:clamp(6rem,15vw,12rem);line-height:.75;
  margin-right:.05em;margin-top:.08em;color:var(--accent);
  font-family:'Playfair Display',serif;font-weight:700;
  animation:dropCapScale .6s ease-out both;animation-delay:.3s;
}
.hero__sub{
  font-size:clamp(1.05rem,1.4vw,1.2rem);line-height:1.75;color:var(--ink-soft);
  max-width:52ch;margin-bottom:2rem;
}

.hero__img{
  border-radius:var(--radius);margin-top:2rem;
  max-height:520px;width:100%;object-fit:cover;
}
@media(max-width:640px){.hero__img{max-height:320px}}

.trust-strip{display:flex;flex-wrap:wrap;gap:10px;margin-top:1.5rem}
.trust-badge{
  display:inline-flex;align-items:center;gap:6px;font-size:.73rem;font-weight:600;
  letter-spacing:.02em;color:var(--ink-soft);background:var(--surface);
  border:1px solid var(--line);padding:6px 14px;border-radius:100px;
}
.trust-badge svg{width:14px;height:14px;flex-shrink:0}

/* ═══ SECTION TITLES ═══ */
.section-eyebrow{
  font-family:'Source Serif 4',serif;font-size:.73rem;font-weight:600;
  letter-spacing:.18em;text-transform:uppercase;color:var(--accent);margin-bottom:.75rem;
}
.section-title{margin-bottom:1rem}
.section-intro{
  color:var(--ink-soft);font-size:clamp(1rem,1.2vw,1.1rem);max-width:60ch;margin-bottom:2.5rem;
}

/* ═══ STITCH DECORATION ═══ */
.stitch-line{
  display:block;width:100%;height:4px;margin:0 auto;
  background:repeating-linear-gradient(90deg,var(--accent-2) 0 6px,transparent 6px 14px);opacity:.5;
}
.stitch-border{border-top:none;position:relative;padding-top:2rem}
.stitch-border::before{
  content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:min(200px,40%);height:3px;
  background:repeating-linear-gradient(90deg,var(--accent-2) 0 5px,transparent 5px 12px);opacity:.6;
}
.stitch-heading{position:relative;display:inline-block}
.stitch-heading::after{
  content:'';position:absolute;bottom:-6px;left:0;width:0;height:2px;
  background:repeating-linear-gradient(90deg,var(--accent) 0 4px,transparent 4px 9px);
  transition:width 1000ms cubic-bezier(.22,1,.36,1);
}
.stitch-heading.is-in::after{width:100px}

/* ═══ THREAD SVG ═══ */
.thread-container{
  position:absolute;left:clamp(-30px,-3vw,-20px);top:0;width:50px;height:100%;
  pointer-events:none;z-index:1;overflow:visible;
}
@media(max-width:1024px){.thread-container{display:none}}
.thread-path{stroke:var(--accent-2);stroke-width:1.5;fill:none;stroke-linecap:round;opacity:.6}
.thread-needle{fill:var(--accent);transition:transform .3s ease}

/* ═══ DROP CAP ═══ */
.drop-cap::first-letter{
  float:left;font-family:'Playfair Display',serif;font-weight:700;
  font-size:3.6em;line-height:.8;margin-right:.08em;margin-top:.05em;color:var(--accent);
}

/* ═══ MANIFESTO ═══ */
.manifesto{background:var(--surface)}
.manifesto__text{font-size:clamp(1.15rem,1.5vw,1.35rem);line-height:1.85;max-width:64ch}
.pull-quote{
  font-family:'Playfair Display',serif;font-weight:400;font-style:italic;
  font-size:clamp(1.4rem,2.5vw,2rem);line-height:1.45;color:var(--accent);
  border-left:3px solid var(--accent-2);padding-left:clamp(16px,3vw,28px);
  margin:clamp(2rem,5vw,3.5rem) 0;max-width:48ch;
  transition:border-color 400ms ease,padding-left 400ms cubic-bezier(.22,1,.36,1);
}
.pull-quote:hover{border-color:var(--accent);padding-left:calc(clamp(16px,3vw,28px) + 4px)}

/* ═══ TECHNIQUES ═══ */
.techniques-grid{display:grid;gap:clamp(2rem,4vw,3rem)}
@media(min-width:768px){.techniques-grid{grid-template-columns:1fr 1fr}}
.technique-item{
  display:grid;grid-template-columns:auto 1fr;gap:clamp(14px,2.5vw,24px);align-items:start;
  padding:clamp(20px,3vw,32px);background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius);position:relative;overflow:hidden;
  transition:transform 420ms cubic-bezier(.16,1,.3,1),box-shadow 420ms cubic-bezier(.16,1,.3,1),border-color 320ms ease;
}
.technique-item::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:3px;
  background:repeating-linear-gradient(90deg,var(--accent) 0 5px,transparent 5px 12px);
  transform:scaleX(0);transform-origin:left;
  transition:transform 500ms cubic-bezier(.16,1,.3,1);
}
.technique-item:hover{
  transform:translateY(-6px);
  box-shadow:0 16px 40px rgba(122,59,16,.16),0 4px 12px rgba(122,59,16,.08),0 0 0 1px rgba(122,59,16,.04);
  border-color:var(--accent-2);
}
.technique-item:hover::after{transform:scaleX(1)}
.technique-item img{transition:transform 600ms cubic-bezier(.22,1,.36,1),filter 400ms ease}
.technique-item:hover img{transform:scale(1.02);filter:brightness(1.04) saturate(1.08)}
.technique-icon{
  width:56px;height:56px;display:flex;align-items:center;justify-content:center;
  border-radius:50%;background:rgba(122,59,16,.08);color:var(--accent);
  flex-shrink:0;grid-row:1/3;
  transition:background 320ms ease,transform 320ms cubic-bezier(.16,1,.3,1);
}
.technique-item:hover .technique-icon{
  background:rgba(122,59,16,.14);transform:scale(1.08);
}
.technique-icon svg{width:28px;height:28px}
.technique-item h3{margin-bottom:.3em}
.technique-item p{color:var(--ink-soft);margin-bottom:0;font-size:.95rem}

/* ═══ STATS BAR ═══ */
.stats-bar{background:var(--ink);color:var(--surface);padding:clamp(2rem,5vw,3.5rem) 0}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(16px,3vw,24px);text-align:center}
.stat-number{
  font-family:'Playfair Display',serif;font-size:clamp(2rem,4vw,3.2rem);
  font-weight:700;line-height:1.1;color:var(--accent-2);display:block;margin-bottom:.3em;
}
.stat-label{font-size:.85rem;color:rgba(250,250,247,.7);letter-spacing:.02em}

/* ═══ WORKSHOP / PRICING ═══ */
.table-scroll{
  display:block;width:100%;max-width:100%;min-width:0;
  overflow-x:auto;-webkit-overflow-scrolling:touch;margin:18px 0;
  border:1px solid var(--line);border-radius:var(--radius);
  position:relative;
}
.table-scroll>table{margin:0 !important;min-width:480px;width:100%}
@media(max-width:520px){
  .table-scroll>table{min-width:440px}
  .table-scroll{
    -webkit-mask-image:linear-gradient(to right,#000 calc(100% - 28px),transparent);
    mask-image:linear-gradient(to right,#000 calc(100% - 28px),transparent);
  }
  .table-scroll.is-scrolled-end{
    -webkit-mask-image:none;mask-image:none;
  }
}
:where(*:has(>.table-scroll),*:has(>*>.table-scroll),*:has(>*>*>.table-scroll)){min-width:0}

table{border-collapse:collapse;width:100%;font-size:.9rem}
th,td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--line)}
th{
  font-family:'Source Serif 4',serif;font-weight:600;font-size:.78rem;
  letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);background:var(--surface-2);
}
td{color:var(--ink)}
tr:last-child td{border-bottom:none}
.level-badge{
  display:inline-block;font-size:.72rem;font-weight:600;letter-spacing:.04em;
  padding:3px 10px;border-radius:100px;background:rgba(122,59,16,.08);color:var(--accent);
}
.level-badge--ileri{background:rgba(30,26,20,.08);color:var(--ink)}
.level-badge--orta{background:rgba(191,160,122,.2);color:var(--accent)}

.pricing-grid{display:grid;gap:clamp(16px,3vw,24px)}
@media(min-width:768px){.pricing-grid{grid-template-columns:repeat(3,1fr)}}
.pricing-card{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:clamp(20px,3vw,32px);display:flex;flex-direction:column;
  transition:transform 420ms cubic-bezier(.16,1,.3,1),box-shadow 420ms cubic-bezier(.16,1,.3,1),border-color 320ms ease;
}
.pricing-card:hover{
  transform:translateY(-6px);
  box-shadow:0 16px 40px rgba(122,59,16,.16),0 4px 12px rgba(122,59,16,.08),inset 0 1px 0 rgba(191,160,122,.15);
  border-color:var(--accent-2);
}
.pricing-card--featured{border-color:var(--accent);position:relative}
.pricing-card--featured::before{
  content:'En Popüler';position:absolute;top:-12px;left:50%;transform:translateX(-50%);
  background:var(--accent);color:var(--surface);font-size:.7rem;font-weight:600;
  letter-spacing:.08em;text-transform:uppercase;padding:4px 14px;border-radius:100px;white-space:nowrap;
}
.pricing-card h3{font-size:1.2rem;margin-bottom:.5em}
.pricing-price{
  font-family:'Playfair Display',serif;font-size:clamp(1.8rem,3vw,2.4rem);
  font-weight:700;color:var(--accent);margin-bottom:.3em;font-variant-numeric:tabular-nums;
}
.pricing-unit{font-family:'Source Serif 4',serif;font-size:.85rem;font-weight:400;color:var(--ink-soft)}
.pricing-includes,.pricing-excludes{list-style:none;padding:0;margin:16px 0;font-size:.9rem}
.pricing-includes li{padding:6px 0 6px 22px;position:relative;color:var(--ink)}
.pricing-includes li::before{content:'✓';position:absolute;left:0;color:var(--accent);font-weight:700}
.pricing-excludes li{padding:4px 0 4px 22px;position:relative;color:var(--ink-soft);font-size:.85rem}
.pricing-excludes li::before{content:'—';position:absolute;left:0;color:var(--ink-soft)}
.pricing-disclaimer{font-size:.8rem;color:var(--ink-soft);font-style:italic;margin-top:1.5rem}

/* ═══ PROCESS STEPS ═══ */
.process-steps{position:relative;padding-left:clamp(24px,4vw,40px)}
.process-steps::before{
  content:'';position:absolute;left:8px;top:0;bottom:0;width:2px;
  background:repeating-linear-gradient(180deg,var(--accent-2) 0 8px,transparent 8px 16px);opacity:.5;
}
.process-step{
  position:relative;margin-bottom:clamp(2rem,4vw,3rem);padding-left:clamp(16px,2vw,24px);
  transition:transform 320ms cubic-bezier(.16,1,.3,1);
}
.process-step:hover{transform:translateX(4px)}
.process-step:last-child{margin-bottom:0}
.process-step::before{
  content:'';position:absolute;left:calc(-1 * clamp(24px,4vw,40px) + 2px);top:6px;
  width:14px;height:14px;border-radius:50%;background:var(--accent);border:3px solid var(--bg);
  transition:transform 320ms cubic-bezier(.16,1,.3,1),box-shadow 320ms ease;
}
.process-step:hover::before{
  transform:scale(1.2);box-shadow:0 0 0 4px rgba(122,59,16,.1);
}
.section-alt .process-step::before{border-color:var(--surface)}
.step-time{
  font-size:.73rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  color:var(--accent-2);margin-bottom:.3em;display:block;
}
.process-step h4{margin-bottom:.4em}
.process-step p{color:var(--ink-soft);font-size:.95rem;margin-bottom:0}

/* ═══ TESTIMONIALS ═══ */
.testimonials-grid{display:grid;gap:clamp(16px,3vw,24px)}
@media(min-width:768px){.testimonials-grid{grid-template-columns:1fr 1fr}}
.testimonial-card{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:clamp(20px,3vw,28px);position:relative;
  transition:transform 420ms cubic-bezier(.16,1,.3,1),box-shadow 420ms cubic-bezier(.16,1,.3,1),border-color 320ms ease;
}
.testimonial-card:hover{
  transform:translateY(-4px);
  box-shadow:0 12px 32px rgba(122,59,16,.14),0 4px 10px rgba(122,59,16,.06),0 0 0 1px rgba(191,160,122,.1);
  border-color:var(--accent-2);
}
.testimonial-card::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:2px;
  background:repeating-linear-gradient(90deg,var(--accent-2) 0 4px,transparent 4px 10px);
  transform:scaleX(0);transform-origin:left;
  transition:transform 600ms cubic-bezier(.22,1,.36,1);
}
.testimonial-card:hover::after{transform:scaleX(1)}
.testimonial-card::before{
  content:'\201C';font-family:'Playfair Display',serif;font-size:4rem;line-height:1;
  color:var(--accent-2);opacity:.4;position:absolute;top:12px;left:20px;
}
.testimonial-card blockquote{
  font-size:.95rem;line-height:1.7;color:var(--ink);margin-bottom:1rem;
  padding-top:2rem;font-style:italic;
}
.testimonial-author{font-size:.82rem;font-weight:600;color:var(--ink)}
.testimonial-meta{font-size:.78rem;color:var(--ink-soft)}

/* ═══ FAQ ═══ */
.faq-list{max-width:720px}
.faq-item{border-bottom:1px solid var(--line)}
.faq-item summary{
  display:flex;align-items:center;justify-content:space-between;cursor:pointer;
  padding:clamp(14px,2vw,18px) 0;font-family:'Source Serif 4',serif;
  font-weight:600;font-size:clamp(.95rem,1.1vw,1.05rem);color:var(--ink);list-style:none;
  transition:color 240ms ease;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::marker{display:none;content:''}
.faq-item summary::after{
  content:'+';font-family:'Source Serif 4',serif;font-size:1.4rem;font-weight:400;
  color:var(--accent-2);transition:transform 360ms cubic-bezier(.16,1,.3,1),color 240ms ease;
  flex-shrink:0;margin-left:16px;
}
.faq-item[open] summary::after{transform:rotate(45deg);color:var(--accent)}
.faq-item summary:hover{color:var(--accent)}
.faq-item summary:hover::after{color:var(--accent)}
.faq-body{
  height:0;padding:0 clamp(0px,1vw,4px);overflow:hidden;
  transition:height 360ms cubic-bezier(.4,0,.2,1),padding-block-end 360ms cubic-bezier(.4,0,.2,1);
}
.faq-item[open]>.faq-body{height:auto;padding-block-end:20px}
.faq-body p{font-size:.92rem;color:var(--ink-soft);line-height:1.75;max-width:62ch}
@media(prefers-reduced-motion:reduce){.faq-body{transition:none}}

/* ═══ CONTACT SECTION ═══ */
.contact-grid{display:grid;gap:clamp(2rem,4vw,3rem)}
@media(min-width:768px){.contact-grid{grid-template-columns:1fr 1fr;align-items:start}}
.contact-info h3{margin-bottom:1.5rem}
.contact-channels{display:grid;gap:14px}
.contact-channel{
  display:grid;grid-template-columns:auto 1fr;gap:14px;align-items:start;
  padding:8px 0;transition:transform 240ms cubic-bezier(.4,0,.2,1);
}
.contact-channel:hover{transform:translateX(4px)}
.contact-channel svg{
  width:20px;height:20px;color:var(--accent);flex-shrink:0;margin-top:2px;
  transition:transform 240ms ease;
}
.contact-channel:hover svg{transform:scale(1.08)}
.channel-label{
  font-size:.76rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;
  color:var(--ink-soft);margin-bottom:2px;
}
.channel-value{
  font-size:.95rem;color:var(--ink);word-break:break-word;overflow-wrap:anywhere;
}
.channel-value a{color:var(--ink);border-bottom:1px solid var(--line);transition:border-color 240ms ease,color 240ms ease}
.channel-value a:hover{color:var(--accent);border-color:var(--accent)}

.hours-list{margin-top:1rem}
.hours-row{
  display:flex;justify-content:space-between;padding:6px 0;font-size:.9rem;
  font-variant-numeric:tabular-nums;border-bottom:1px solid var(--line);
}
.hours-row:last-child{border-bottom:none}
.hours-day{font-weight:600;color:var(--ink)}
.hours-time{color:var(--ink-soft)}

/* ═══ FORM ═══ */
.form{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:clamp(20px,4vw,32px);position:relative;
}
.form-grid{display:grid;gap:16px}
@media(min-width:640px){
  .form-grid--2col{grid-template-columns:1fr 1fr}
  .form-grid--2col .field--full{grid-column:1/-1}
}
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-size:.82rem;font-weight:600;letter-spacing:.02em;color:var(--ink)}
.field input[type="text"],.field input[type="email"],.field input[type="tel"],
.field select,.field textarea{
  font-family:'Source Serif 4',serif;font-size:.95rem;color:var(--ink);
  background:var(--bg);border:1.5px solid var(--line-strong);border-radius:var(--radius);
  padding:12px 14px;transition:border-color 240ms ease,box-shadow 240ms ease;width:100%;
}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(122,59,16,.1);
}
.field textarea{resize:vertical;min-height:120px}
.field select{cursor:pointer}

.field-checkbox{flex-direction:row;align-items:flex-start;gap:10px}
.field input[type="checkbox"]{
  appearance:auto;-webkit-appearance:auto;width:18px;height:18px;
  min-width:18px;min-height:18px;padding:0;border:0;margin:2px 0 0;
  accent-color:var(--accent);cursor:pointer;
}
.field-checkbox label{font-size:.82rem;font-weight:400;color:var(--ink-soft);line-height:1.5;cursor:pointer}
.form-submit{margin-top:8px}
@media(max-width:640px){.form-submit .btn-primary{width:100%;justify-content:center}}
.hp-field{position:absolute;left:-9999px;opacity:0}

/* ═══ NEWS BLOCK ═══ */
.news-block{
  margin-top:clamp(2rem,4vw,3rem);padding:clamp(16px,3vw,24px);
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
}
.news-block h4{font-size:.95rem;margin-bottom:1rem;display:flex;align-items:center;gap:8px}
.news-item{
  display:flex;gap:12px;padding:8px 0;border-bottom:1px solid var(--line);font-size:.88rem;
}
.news-item:last-child{border-bottom:none}
.news-date{font-variant-numeric:tabular-nums;color:var(--accent);font-weight:600;white-space:nowrap;font-size:.82rem}
.news-text{color:var(--ink-soft)}

/* ═══ CAPACITY ═══ */
.capacity-badge{
  display:inline-flex;align-items:center;gap:6px;
  background:rgba(122,59,16,.06);border:1px solid rgba(122,59,16,.15);
  padding:8px 16px;border-radius:var(--radius);font-size:.85rem;
  color:var(--accent);font-weight:600;margin:1rem 0;
}
.capacity-badge::before{
  content:'';width:8px;height:8px;border-radius:50%;background:var(--accent);
  animation:capacityPulse 2s ease-in-out infinite;
}

/* ═══ FOOTER ═══ */
.site-footer{
  background:var(--ink);color:rgba(250,250,247,.75);
  padding:clamp(3rem,6vw,4.5rem) 0 0;font-size:.88rem;
}
.footer-grid{display:grid;gap:clamp(2rem,4vw,3rem)}
@media(min-width:768px){.footer-grid{grid-template-columns:2fr 1fr 1fr 1fr}}
.footer-brand{max-width:320px}
.footer-brand .logo{color:var(--surface);font-size:1.2rem;margin-bottom:1rem;display:inline-block}
.footer-brand .logo:hover{color:var(--accent-2)}
.footer-brand p{color:rgba(250,250,247,.6);font-size:.85rem;line-height:1.7}
.footer-col h4{
  font-family:'Source Serif 4',serif;font-weight:600;font-size:.8rem;
  letter-spacing:.08em;text-transform:uppercase;color:var(--surface);margin-bottom:1rem;
}
.footer-col a{
  display:block;color:rgba(250,250,247,.6);padding:4px 0;font-size:.85rem;
  transition:color 240ms ease,padding-left 240ms ease;
}
.footer-col a:hover{color:var(--accent-2);padding-left:4px}
.footer-bottom{
  border-top:1px solid rgba(250,250,247,.1);margin-top:clamp(2rem,4vw,3rem);
  padding:20px 0;display:flex;flex-wrap:wrap;justify-content:space-between;
  gap:12px;font-size:.78rem;color:rgba(250,250,247,.45);
}
.footer-bottom a{color:rgba(250,250,247,.45);font-size:.78rem}
.footer-bottom a:hover{color:var(--accent-2)}
.footer-legal{display:flex;flex-wrap:wrap;gap:8px 16px}

/* ═══ COOKIE BANNER ═══ */
.cookie-banner{
  position:fixed;bottom:16px;left:16px;right:16px;max-width:520px;margin:0 auto;
  background:var(--surface);border:1px solid var(--line-strong);border-radius:12px;
  padding:clamp(16px,3vw,24px);box-shadow:0 12px 40px rgba(0,0,0,.15);
  transform:translateY(140%);opacity:0;
  transition:transform 400ms cubic-bezier(.22,1,.36,1),opacity 320ms ease;z-index:9999;
}
@media(min-width:768px){.cookie-banner{left:24px;right:auto;max-width:420px}}
.cookie-banner.is-visible{transform:translateY(0);opacity:1}
.cookie-banner h4{font-size:.95rem;margin-bottom:.5em}
.cookie-banner p{font-size:.82rem;color:var(--ink-soft);line-height:1.6;margin-bottom:1rem}
.cookie-actions{display:flex;flex-wrap:wrap;gap:8px}
.cookie-btn{
  flex:1;min-width:100px;min-height:44px;padding:10px 16px;
  border:1.5px solid var(--line);border-radius:var(--radius);
  background:transparent;color:var(--ink-soft);font-family:'Source Serif 4',serif;
  font-size:.82rem;font-weight:600;cursor:pointer;
  transition:background 240ms ease,color 240ms ease,border-color 240ms ease,transform 180ms ease;
}
.cookie-btn:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-1px)}
.cookie-btn--accept{background:var(--ink);color:var(--surface);border-color:var(--ink)}
.cookie-btn--accept:hover{background:var(--accent);color:var(--surface);border-color:var(--accent);transform:translateY(-1px)}
.cookie-btn--reject{border-color:var(--line-strong);color:var(--ink-soft);background:transparent}
.cookie-btn--reject:hover{border-color:var(--accent);color:var(--accent)}

/* ═══ PAGE HERO ═══ */
.page-hero{
  min-height:240px;display:flex;align-items:flex-end;
  background:linear-gradient(175deg,var(--bg) 0%,var(--surface) 100%);
  padding:clamp(3rem,8vw,5rem) 0 clamp(2rem,5vw,3rem);position:relative;
}
.page-hero::after{
  content:'';position:absolute;bottom:0;left:50%;transform:translateX(-50%);
  width:min(200px,40%);height:3px;
  background:repeating-linear-gradient(90deg,var(--accent-2) 0 5px,transparent 5px 12px);opacity:.5;
}
.page-hero h1{font-size:clamp(2rem, 5vw, 3.5rem)}
.page-hero .eyebrow{margin-bottom:1rem}
.page-hero p{color:var(--ink-soft);max-width:52ch;margin-top:.75rem}

/* ═══ CONTACT PAGE ═══ */
.contact-cards{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:clamp(12px,2vw,16px);margin-bottom:clamp(2rem,4vw,3rem);
}
.contact-card{
  border:1px solid var(--line);border-radius:12px;padding:clamp(18px,3vw,24px);
  background:var(--surface);
  transition:transform 420ms cubic-bezier(.16,1,.3,1),box-shadow 420ms cubic-bezier(.16,1,.3,1),border-color 320ms ease;
}
.contact-card:hover{
  transform:translateY(-3px);
  box-shadow:0 12px 32px rgba(122,59,16,.12),0 4px 10px rgba(122,59,16,.05);
  border-color:var(--accent-2);
}
.contact-card__icon{
  width:48px;height:48px;border-radius:50%;background:rgba(122,59,16,.08);
  display:flex;align-items:center;justify-content:center;margin-bottom:12px;color:var(--accent);
  transition:background 320ms ease,transform 320ms cubic-bezier(.16,1,.3,1);
}
.contact-card:hover .contact-card__icon{
  background:rgba(122,59,16,.14);transform:scale(1.06);
  box-shadow:0 4px 16px rgba(122,59,16,.12);
}
.contact-card__icon svg{width:22px;height:22px}
.contact-card__title{
  font-family:'Source Serif 4',serif;font-weight:600;font-size:.8rem;
  letter-spacing:.04em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:6px;
}
.contact-card__value{font-size:1rem;color:var(--ink);font-weight:600;margin-bottom:4px}
.contact-card__value a{color:var(--ink);border-bottom:1px solid var(--line)}
.contact-card__value a:hover{color:var(--accent);border-color:var(--accent)}
.contact-card__sub{font-size:.8rem;color:var(--ink-soft)}

/* ═══ ABOUT PAGE ═══ */
.team-grid{display:grid;gap:clamp(2rem,4vw,3rem)}
@media(min-width:768px){.team-grid{grid-template-columns:repeat(3,1fr)}}
.team-card{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:clamp(20px,3vw,28px);text-align:center;
  transition:transform 420ms cubic-bezier(.16,1,.3,1),box-shadow 420ms cubic-bezier(.16,1,.3,1),border-color 320ms ease;
}
.team-card:hover{
  transform:translateY(-4px);
  box-shadow:0 12px 32px rgba(122,59,16,.12),0 4px 10px rgba(122,59,16,.05);
  border-color:var(--accent-2);
}
.team-avatar{
  width:80px;height:80px;border-radius:50%;background:var(--surface-2);
  display:flex;align-items:center;justify-content:center;margin:0 auto 16px;
  font-family:'Playfair Display',serif;font-size:1.8rem;font-weight:700;color:var(--accent);
  border:2px solid transparent;
  transition:border-color 320ms ease,transform 320ms cubic-bezier(.16,1,.3,1),box-shadow 320ms ease;
}
.team-card:hover .team-avatar{
  border-color:var(--accent-2);transform:scale(1.06);
  box-shadow:0 4px 16px rgba(122,59,16,.12);
}
.team-card h3{font-size:1.1rem;margin-bottom:.2em}
.team-role{
  font-size:.8rem;color:var(--accent);font-weight:600;letter-spacing:.04em;
  text-transform:uppercase;margin-bottom:1rem;display:block;
}
.team-bio{font-size:.9rem;color:var(--ink-soft);line-height:1.7;text-align:left}

/* ═══ THANK YOU ═══ */
.thankyou-section{min-height:60vh;display:flex;align-items:center;text-align:center}
.thankyou-section h1{margin-bottom:.5em}
.thankyou-section p{max-width:48ch;margin:0 auto 2rem;color:var(--ink-soft)}

/* ═══ ABOUT STATS ═══ */
.about-stats-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(16px,3vw,24px);text-align:center;
}
.about-stats-grid .stat-number{color:var(--accent)}

/* ═══ POLICY PAGES ═══ */
.policy-content{padding:clamp(2rem,5vw,4rem) 0}
.policy-content h2{
  font-size:clamp(1.3rem,2vw,1.6rem);margin:2.5em 0 .6em;
  padding-bottom:.4em;border-bottom:2px solid var(--line);position:relative;
}
.policy-content h2::after{
  content:'';position:absolute;bottom:-2px;left:0;width:40px;height:2px;
  background:var(--accent-2);
}
.policy-content h2:first-child{margin-top:0}
.policy-content h3{font-size:clamp(1.1rem,1.5vw,1.3rem);margin:1.5em 0 .5em}
.policy-content p{color:var(--ink-soft);max-width:72ch;line-height:1.8}
.policy-content ul,.policy-content ol{color:var(--ink-soft);margin-bottom:1.5em;max-width:72ch;line-height:1.8}
.policy-content li{margin-bottom:.5em;padding-left:.3em}

/* ═══ 404 ═══ */
.page-404{min-height:70vh;display:flex;align-items:center;text-align:center}
.page-404 .error-code{
  font-family:'Playfair Display',serif;font-size:clamp(5rem,12vw,9rem);font-weight:700;
  color:var(--accent-2);opacity:.3;line-height:1;margin-bottom:0;
}
.page-404 h2{margin-bottom:.5em}
.page-404 p{max-width:48ch;margin:0 auto 2rem;color:var(--ink-soft)}

/* ═══ SITEMAP PAGE ═══ */
.sitemap-content ul{list-style:none;padding:0}
.sitemap-content li{padding:8px 0;border-bottom:1px solid var(--line)}
.sitemap-content li:last-child{border-bottom:none}
.sitemap-content li a{display:flex;justify-content:space-between;align-items:center;font-size:.95rem}

/* ═══ CANCELLATION ═══ */
.cancel-tiers{display:grid;gap:12px;margin:1.5rem 0}
.cancel-tier{
  display:grid;grid-template-columns:auto 1fr;gap:16px;align-items:start;
  padding:16px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
}
.cancel-tier__period{
  font-weight:600;font-size:.9rem;color:var(--accent);white-space:nowrap;min-width:100px;
}
.cancel-tier__detail{font-size:.9rem;color:var(--ink-soft)}

/* ═══ REVEAL ═══ */
.reveal{
  opacity:0;transform:translateY(32px);
  transition:opacity 800ms cubic-bezier(.22,1,.36,1),transform 800ms cubic-bezier(.22,1,.36,1);
}
.reveal.is-in{opacity:1;transform:none}
.reveal[style*="--i"]{transition-delay:calc(var(--i,0) * 120ms)}

.hero .reveal{
  opacity:1;transform:none;
  animation:heroFadeIn 1s cubic-bezier(.22,1,.36,1) both;
}
.hero .reveal[style*="--i"]{animation-delay:calc(var(--i,0) * 140ms + .15s)}
.page-hero .eyebrow,.page-hero h1,.page-hero p{
  animation:heroFadeIn .9s cubic-bezier(.22,1,.36,1) both;
}
.page-hero h1{animation-delay:.12s}
.page-hero p{animation-delay:.24s}

/* ═══ KEYFRAMES ═══ */
@keyframes heroFadeIn{
  from{opacity:0;transform:translateY(28px)}
  to{opacity:1;transform:none}
}
@keyframes dropCapScale{
  from{transform:scale(.2) rotate(-8deg);opacity:0}
  60%{transform:scale(1.05) rotate(1deg);opacity:1}
  to{transform:scale(1) rotate(0);opacity:1}
}
@keyframes capacityPulse{0%,100%{opacity:1}50%{opacity:.4}}
@keyframes needleBob{0%,100%{transform:translateY(0) rotate(-45deg)}50%{transform:translateY(-4px) rotate(-45deg)}}
@keyframes threadGlow{0%,100%{stroke:var(--accent-2)}50%{stroke:var(--accent)}}
@keyframes paperGrain{0%,100%{transform:translate(0,0)}25%{transform:translate(1px,1px)}50%{transform:translate(-1px,0)}75%{transform:translate(0,-1px)}}
@keyframes stitchDraw{from{width:0}to{width:100px}}
@keyframes warmPulse{
  0%,100%{box-shadow:0 8px 24px rgba(122,59,16,.08)}
  50%{box-shadow:0 12px 32px rgba(122,59,16,.18)}
}
@keyframes threadWeave{
  0%{background-position:0 0}
  100%{background-position:40px 0}
}
@keyframes inkSpread{
  from{opacity:0;transform:scale(.95);filter:blur(2px)}
  to{opacity:1;transform:scale(1);filter:blur(0)}
}

/* ═══ RESPONSIVE ═══ */
@media(max-width:1024px){:root{--header-h:64px}.thread-container{display:none}}
@media(max-width:768px){
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:20px 12px}
  .pricing-grid{grid-template-columns:1fr}
  .testimonials-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .contact-cards{grid-template-columns:1fr}
  .team-grid{grid-template-columns:1fr}
  .cancel-tier{grid-template-columns:1fr}
  .cookie-banner{left:12px;right:12px;bottom:12px;max-width:100%;padding:clamp(14px,3vw,20px)}
  .about-stats-grid{grid-template-columns:repeat(2,1fr) !important}
}
@media(max-width:640px){
  section{padding:clamp(2rem,6vw,3.5rem) 0}
  .hero{padding-top:clamp(2rem,6vw,3rem);padding-bottom:clamp(1.5rem,5vw,2.5rem)}
  .hero__title{font-size:clamp(2.2rem, 9vw, 3.5rem)}
  .drop-cap-hero{font-size:clamp(4.5rem,20vw,7rem)}
  .technique-item{grid-template-columns:1fr}
  .technique-icon{grid-row:auto;margin-bottom:8px}
  .form-grid--2col{grid-template-columns:1fr}
  .trust-strip{gap:8px}
  .trust-badge{font-size:.7rem;padding:5px 10px}
  body{padding-bottom:0}
}
@media(max-width:430px){
  .pricing-card{padding:18px}
  .technique-item{padding:16px}
  .hero__title{max-width:100%}
}
@media(max-width:390px){
  body{font-size:15px}
  .trust-strip{flex-direction:column}
}
@media(max-width:360px){
  .container{padding-left:14px;padding-right:14px}
}

/* ═══ REDUCED MOTION ═══ */
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1 !important;transform:none !important;transition:none !important}
  .hero .reveal{animation:none !important;opacity:1 !important;transform:none !important}
  .page-hero .eyebrow,.page-hero h1,.page-hero p{animation:none !important;opacity:1;transform:none}
  .drop-cap-hero{animation:none !important;opacity:1;transform:none}
  .thread-path{transition:none}
  .technique-item,.pricing-card,.testimonial-card,.contact-card,.team-card,.contact-channel,.process-step{transition:none}
  .technique-item::after,.testimonial-card::after,.process-step::before{transition:none}
  .technique-item img{transition:none}
  .technique-icon,.team-avatar,.contact-card__icon{transition:none}
  .capacity-badge::before{animation:none}
  .faq-body{transition:none}
  .stitch-heading::after{transition:none}
  .btn-primary,.btn-ghost,.cookie-btn{transition:none}
  .pull-quote{transition:none}
  .nav-toggle span{transition:none}
}

html.no-js .reveal{opacity:1;transform:none;animation:none}
html.no-js .hero .reveal{animation:none}
html.no-js .page-hero .eyebrow,html.no-js .page-hero h1,html.no-js .page-hero p{animation:none}
html.no-js .drop-cap-hero{animation:none;opacity:1;transform:none}

/* ═══ BOOKBINDING MICRO-EFFECTS ═══ */
.technique-item:hover{
  box-shadow:0 16px 40px rgba(122,59,16,.16),0 4px 12px rgba(122,59,16,.08),0 0 48px rgba(191,160,122,.08);
}
.pricing-card:hover{
  box-shadow:0 16px 40px rgba(122,59,16,.16),0 4px 12px rgba(122,59,16,.08),0 0 48px rgba(191,160,122,.06);
}
.testimonial-card:hover{
  box-shadow:0 12px 32px rgba(122,59,16,.14),0 4px 10px rgba(122,59,16,.06),0 0 32px rgba(191,160,122,.06);
}
.contact-card:hover{
  box-shadow:0 12px 32px rgba(122,59,16,.12),0 4px 10px rgba(122,59,16,.05),0 0 32px rgba(191,160,122,.05);
}

.technique-item img{border-radius:var(--radius);overflow:hidden}
.technique-item:hover img{filter:brightness(1.04) saturate(1.08) contrast(1.02)}

.hero__img{
  transition:transform 600ms cubic-bezier(.22,1,.36,1),filter 500ms ease;
}
.hero__img:hover{
  transform:scale(1.01);
  filter:brightness(1.03) saturate(1.05);
}

.pull-quote{
  transition:border-color 400ms ease,padding-left 400ms cubic-bezier(.22,1,.36,1),box-shadow 400ms ease;
}
.pull-quote:hover{
  border-color:var(--accent);
  padding-left:calc(clamp(16px,3vw,28px) + 4px);
  box-shadow:-4px 0 16px rgba(122,59,16,.06);
}

.process-step:hover::before{
  box-shadow:0 0 0 4px rgba(122,59,16,.1),0 0 16px rgba(122,59,16,.08);
}

.stitch-heading::after{
  background:repeating-linear-gradient(90deg,var(--accent) 0 4px,transparent 4px 9px);
  transition:width 1200ms cubic-bezier(.22,1,.36,1);
}

.reveal{transition:opacity 900ms cubic-bezier(.22,1,.36,1),transform 900ms cubic-bezier(.22,1,.36,1)}
.reveal[style*="--i"]{transition-delay:calc(var(--i,0) * 100ms)}

.hero .reveal[style*="--i"]{animation-delay:calc(var(--i,0) * 120ms + .1s)}

.faq-item summary{transition:color 240ms ease,padding-left 280ms cubic-bezier(.22,1,.36,1)}
.faq-item summary:hover{padding-left:6px}

.btn-primary{
  position:relative;overflow:hidden;
}
.btn-primary::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle at 50% 120%,rgba(191,160,122,.3),transparent 60%);
  opacity:0;transition:opacity 360ms ease;pointer-events:none;
}
.btn-primary:hover::before{opacity:1}

.team-card:hover{
  box-shadow:0 12px 32px rgba(122,59,16,.12),0 4px 10px rgba(122,59,16,.05),0 0 32px rgba(191,160,122,.06);
}
.team-card:hover .team-avatar{
  box-shadow:0 4px 16px rgba(122,59,16,.15),0 0 24px rgba(191,160,122,.08);
}

.news-item{transition:background 240ms ease,padding-left 280ms cubic-bezier(.22,1,.36,1)}
.news-item:hover{background:rgba(122,59,16,.03);padding-left:4px;border-radius:var(--radius)}

.footer-col a{transition:color 240ms ease,padding-left 280ms cubic-bezier(.22,1,.36,1),text-shadow 240ms ease}
.footer-col a:hover{text-shadow:0 0 12px rgba(191,160,122,.2)}

.cookie-banner{backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}

.capacity-badge{transition:transform 240ms ease,box-shadow 240ms ease}
.capacity-badge:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(122,59,16,.12)}

.field input:focus,.field select:focus,.field textarea:focus{
  box-shadow:0 0 0 3px rgba(122,59,16,.1),0 2px 8px rgba(122,59,16,.06);
}

@keyframes warmGlow{
  0%,100%{box-shadow:0 0 0 rgba(191,160,122,0)}
  50%{box-shadow:0 0 24px rgba(191,160,122,.12)}
}

@media(max-width:768px){
  .cookie-banner{
    bottom:0;left:0;right:0;border-radius:12px 12px 0 0;
    max-width:100%;padding-bottom:max(16px,env(safe-area-inset-bottom));
  }
}

@media(prefers-reduced-motion:reduce){
  .hero__img{transition:none}
  .pull-quote{transition:none}
  .btn-primary::before{display:none}
  .news-item{transition:none}
  .faq-item summary{transition:color 240ms ease}
  .footer-col a{transition:color 240ms ease}
  .capacity-badge{transition:none}
}

@media print{
  .site-header,.nav-toggle,.drawer,.drawer-backdrop,.cookie-banner,.thread-container{display:none !important}
  main{padding-top:0}body{color:#000;background:#fff}
  a{color:#000;text-decoration:underline}section{page-break-inside:avoid}
}

.scroll-progress{position:fixed;top:0;left:0;height:3px;width:0;background:var(--accent);z-index:9998;transition:width 80ms linear;pointer-events:none}

/* form-reveal-opacity-fix */
main form.reveal, .form-section form.reveal, .contact-form.reveal, form[id*='iletisim'].reveal, form[class*='contact'].reveal { opacity: 1 !important; transform: none !important; translate: none !important; }
main form, .form-section form, .contact-form, form[id*='iletisim'], form[class*='contact'] { opacity: 1 !important; }

/* consent-checkbox-inline-fix */
main form label.checkbox, main form .form-checkbox, main form .consent, main form .kvkk, .contact-form label.checkbox, .contact-form .checkbox-group { display: flex !important; flex-direction: row !important; align-items: flex-start !important; gap: 10px !important; font-size: 14px !important; line-height: 1.5 !important; flex-wrap: nowrap !important; }
main form label.checkbox span, main form label.checkbox a, main form .form-checkbox span, main form .form-checkbox a, .contact-form label.checkbox span, .contact-form label.checkbox a { display: inline !important; flex: 1 1 auto; }
main form label.checkbox input[type='checkbox'], main form .form-checkbox input[type='checkbox'] { flex-shrink: 0 !important; width: 18px !important; height: 18px !important; margin-top: 3px !important; }

/* iletisim-form-responsive-guard v2 */
main form, .form-section form, .contact-form, .iletisim-form, form#contact-form, form[id*="iletisim"], form[class*="iletisim"], form[class*="contact"] {
  display: block;
  max-width: 720px;
  margin: 24px auto;
  padding: clamp(20px, 4vw, 36px);
  background: var(--surface, rgba(255,255,255,0.04));
  border: 1px solid var(--line, rgba(127,127,127,0.18));
  border-radius: 16px;
  box-shadow: 0 8px 32px -12px rgba(0,0,0,0.25);
  box-sizing: border-box;
}
main form .form-grid,
main form > .grid,
.contact-form .form-grid,
form[class*="contact"] .form-grid,
form[class*="iletisim"] .form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px 18px;
  width: 100%;
}
@media (max-width: 640px) {
  main form .form-grid,
  main form > .grid,
  .contact-form .form-grid,
  form[class*="contact"] .form-grid,
  form[class*="iletisim"] .form-grid {
    grid-template-columns: 1fr;
  }
}
main form .form-grid > .field-full,
main form .form-grid > .col-full,
main form .form-grid > [class*="full"] {
  grid-column: 1 / -1;
}
main form .field, main form label,
.contact-form .field, .contact-form label {
  display: flex;
  flex-direction: column;
  gap: 6px;
  width: 100%;
}
main form input[type="text"],
main form input[type="email"],
main form input[type="tel"],
main form input[type="number"],
main form input[type="date"],
main form input[type="url"],
main form input[type="search"],
main form input:not([type]),
main form select,
main form textarea,
.contact-form input:not([type=checkbox]):not([type=radio]):not([type=submit]):not([type=hidden]),
.contact-form select,
.contact-form textarea {
  width: 100%;
  box-sizing: border-box;
  padding: 12px 14px;
  min-height: 44px;
  font-size: 16px;
  line-height: 1.4;
  font-family: inherit;
  border: 1px solid var(--line, rgba(127,127,127,0.22));
  border-radius: 10px;
  background: var(--input-bg, rgba(0,0,0,0.04));
  color: inherit;
  appearance: none;
  -webkit-appearance: none;
}
main form textarea, .contact-form textarea {
  min-height: 120px;
  resize: vertical;
}
main form input:focus, main form select:focus, main form textarea:focus,
.contact-form input:focus, .contact-form select:focus, .contact-form textarea:focus {
  outline: 2px solid var(--accent, #5a8dee);
  outline-offset: 1px;
  border-color: transparent;
}
main form .checkbox, main form label.checkbox,
.contact-form .checkbox {
  flex-direction: row;
  align-items: flex-start;
  gap: 10px;
  font-size: 14px;
  line-height: 1.5;
}
main form input[type="checkbox"], main form input[type="radio"],
.contact-form input[type="checkbox"], .contact-form input[type="radio"] {
  width: 18px;
  height: 18px;
  min-width: 18px;
  margin-top: 2px;
  flex-shrink: 0;
  accent-color: var(--accent, #5a8dee);
}
main form button[type="submit"],
main form input[type="submit"],
main form .btn-submit,
.contact-form button[type="submit"],
.contact-form .btn-submit {
  width: 100%;
  min-height: 48px;
  padding: 14px 28px;
  background: var(--accent, #5a8dee);
  color: #fff;
  font-weight: 700;
  font-size: 15px;
  letter-spacing: 0;
  border: none;
  border-radius: 10px;
  cursor: pointer;
  margin-top: 8px;
  transition: filter 200ms ease, transform 120ms ease;
}
@media (min-width: 640px) {
  main form button[type="submit"],
  main form input[type="submit"],
  .contact-form button[type="submit"] {
    width: auto;
    min-width: 220px;
    display: block;
    margin-left: auto;
    margin-right: auto;
  }
}
main form button[type="submit"]:hover,
.contact-form button[type="submit"]:hover {
  filter: brightness(1.05);
}
main form button[type="submit"]:active,
.contact-form button[type="submit"]:active {
  transform: translateY(1px);
}


/* bookbinding-design-v1 */

/* ---------- Paper-grain background overlay ---------- */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 1;
  opacity: 0.05;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/></filter><rect width='200' height='200' filter='url(%23n)'/></svg>");
  background-size: 200px 200px;
}
body > * { position: relative; z-index: 2; }

/* ---------- Stitched divider between sections (decorative) ---------- */
section + section { position: relative; }
section + section::before {
  content: '';
  display: block;
  position: absolute;
  top: 0; left: 50%;
  transform: translate(-50%, -50%);
  width: clamp(60px, 12vw, 120px);
  height: 2px;
  background-image: repeating-linear-gradient(
    to right,
    var(--accent, currentColor) 0 8px,
    transparent 8px 14px
  );
  opacity: 0.55;
  border-radius: 2px;
}

/* ---------- Gold-foil shimmer on .eyebrow + .logo ---------- */
.eyebrow {
  background: linear-gradient(
    100deg,
    var(--accent, #b8860b) 0%,
    #f4d57c 30%,
    var(--accent, #b8860b) 60%,
    #d4a017 100%
  );
  background-size: 200% 100%;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  animation: bb-shimmer 8s ease-in-out infinite;
  font-weight: 600;
  letter-spacing: 0.12em;
}
@keyframes bb-shimmer {
  0%, 100% { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
}
@media (prefers-reduced-motion: reduce) {
  .eyebrow { animation: none; }
}

/* ---------- Card hover: page-lift ---------- */
.product-card, .course-card, .gallery-item {
  transition: transform 350ms cubic-bezier(.2,.7,.2,1),
              box-shadow 350ms cubic-bezier(.2,.7,.2,1);
}
.team-card, .package-card, .feature-card, .case-card, .testimonial-card, .pricing-card {
  transition: transform 280ms ease, box-shadow 280ms ease;
}
.product-card:hover, .course-card:hover, .gallery-item:hover,
.team-card:hover, .package-card:hover, .feature-card:hover,
.case-card:hover, .testimonial-card:hover {
  transform: translateY(-6px) !important;
  box-shadow: 0 20px 40px -16px rgba(0,0,0,0.18),
              0 4px 12px -4px rgba(0,0,0,0.08) !important;
}

/* ---------- Button: ink-blot ripple on hover ---------- */
.btn-primary, button[type="submit"], .nav-cta, .cta {
  position: relative;
  overflow: hidden;
  isolation: isolate;
}
.btn-primary::after, button[type="submit"]::after,
.nav-cta::after, .cta::after {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(
    circle at var(--mx, 50%) var(--my, 50%),
    rgba(255,255,255,0.25) 0%,
    transparent 50%
  );
  opacity: 0;
  transition: opacity 240ms ease;
  pointer-events: none;
  z-index: -1;
}
.btn-primary:hover::after, button[type="submit"]:hover::after,
.nav-cta:hover::after, .cta:hover::after { opacity: 1; }

/* ---------- Smooth scroll site-wide ---------- */

/* ---------- Stitched section header underline ---------- */
section h2 {
  position: relative;
  padding-bottom: 0.5em;
}
section h2::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0;
  width: 64px;
  height: 2px;
  background-image: repeating-linear-gradient(
    to right,
    var(--accent, currentColor) 0 6px,
    transparent 6px 11px
  );
  opacity: 0.7;
  border-radius: 2px;
}
section[style*="text-align:center"] h2::after,
.section-head h2::after,
.text-center h2::after {
  left: 50%;
  transform: translateX(-50%);
}


/* per-site spice: blueprint grid on timeline */
.timeline, [class*="timeline"], [class*="process"] {
  background-image:
    linear-gradient(rgba(37,99,235,0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(37,99,235,0.04) 1px, transparent 1px);
  background-size: 32px 32px;
}

/* batch-overflow-guard */
html, body { overflow-x: hidden; max-width: 100vw; }
img, picture, svg, video { max-width: 100%; height: auto; }
.hero-visual, .split-visual, .gallery-item, .gallery-card, figure {
  overflow: hidden;
  max-width: 100%;
}
.hero-visual img, .split-visual img, .gallery-item img, .gallery-card img {
  max-width: none;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
section.hero, header.hero, .hero, [class*="hero"] { overflow-x: clip; }
.hero-content, .gallery-grid, .gallery { overflow-x: hidden; }
