:root {
  --bg: #1C1917;
  --surface: #292524;
  --surface-2: #3a3532;
  --ink: #FAFAF9;
  --ink-soft: #a8a29e;
  --accent: #D97706;
  --accent-2: #78716C;
  --line: rgba(250,250,249,0.10);
  --line-strong: rgba(250,250,249,0.22);
  --header-h: 72px;
  --container: 1320px;
  --radius: 10px;
  --radius-lg: 16px;
  interpolate-size: allow-keywords;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:hidden;max-width:100vw}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
html.no-js .reveal{opacity:1;transform:none}

body{
  font-family:'Inter',system-ui,sans-serif;
  font-weight:400;
  font-size:clamp(15px,1vw,17px);
  line-height:1.7;
  color:var(--ink);
  background:var(--bg);
  overflow-x:hidden;
  max-width:100vw;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

body::after{
  content:'';
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:0;
  background-image:
    repeating-linear-gradient(90deg,
      transparent 0,transparent 23px,
      rgba(217,119,6,0.018) 23px,rgba(217,119,6,0.018) 24px,
      transparent 24px,transparent 37px,
      rgba(250,250,249,0.012) 37px,rgba(250,250,249,0.012) 38.5px,
      transparent 38.5px,transparent 54px,
      rgba(217,119,6,0.015) 54px,rgba(217,119,6,0.015) 55px,
      transparent 55px,transparent 71px
    );
  opacity:.6;
}

h1,h2,h3,h4,h5,h6{
  font-family:'Bitter',Georgia,'Times New Roman',serif;
  font-weight:600;
  line-height:1.2;
  letter-spacing:-0.012em;
  color:var(--ink);
}
h1{font-size:clamp(2.4rem, 5vw, 4.2rem)}
h2{font-size:clamp(1.8rem,3.5vw,2.8rem)}
h3{font-size:clamp(1.2rem,2vw,1.6rem)}
h4{font-size:clamp(1.05rem,1.4vw,1.25rem)}

p{margin-bottom:1em;color:var(--ink-soft)}
a{color:var(--accent);text-decoration:none;transition:color 240ms cubic-bezier(.4,0,.2,1)}
a:hover{color:var(--ink)}
img{max-width:100%;height:auto;display:block}

.mono{font-family:'JetBrains Mono',monospace;font-weight:500}

.skip-link{
  position:fixed;top:-100%;left:16px;
  background:var(--accent);color:var(--bg);
  padding:8px 18px;border-radius:0 0 6px 6px;
  z-index:10000;font-weight:600;font-size:14px;
  transition:top 200ms;
}
.skip-link:focus{top:0}

.container{
  width:100%;
  max-width:var(--container);
  margin:0 auto;
  padding-left:clamp(16px,4vw,32px);
  padding-right:clamp(16px,4vw,32px);
}

/* ===================== HEADER ===================== */
.site-header{
  position:fixed;top:0;left:0;right:0;
  z-index:1080;
  background:rgba(28, 25, 23, 0.92);
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
  transition:background 240ms ease,box-shadow 240ms ease,padding 240ms ease;
  height:var(--header-h);
}
.site-header.scrolled{
  background:rgba(28,25,23,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:var(--container);
  margin:0 auto;
  padding:0 clamp(16px,4vw,32px);
}
.logo{
  font-family:'Bitter',serif;font-weight:700;
  font-size:clamp(1.1rem,1.8vw,1.4rem);
  color:var(--ink);
  text-decoration:none;
  display:flex;align-items:center;gap:10px;
  z-index:1100;
  letter-spacing:-0.02em;
}
.logo svg{width:32px;height:32px;flex-shrink:0;color:var(--accent)}
.logo:hover{color:var(--accent)}
.logo span{color:var(--accent)}

.nav-desktop{display:none}
@media(min-width:1024px){
  .nav-desktop{
    display:flex;align-items:center;gap:clamp(20px,2.5vw,36px);
  }
  .nav-desktop a{
    font-size:14px;font-weight:500;
    color:var(--ink-soft);
    text-decoration:none;
    position:relative;
    padding:6px 0;
    transition:color 240ms cubic-bezier(.4,0,.2,1);
  }
  .nav-desktop a::after{
    content:'';position:absolute;bottom:0;left:0;right:0;
    height:2px;background:var(--accent);
    transform:scaleX(0);transform-origin:right;
    transition:transform 320ms cubic-bezier(.2,.7,.2,1);
  }
  .nav-desktop a:hover,
  .nav-desktop a.is-active{color:var(--ink)}
  .nav-desktop a:hover::after,
  .nav-desktop a.is-active::after{transform:scaleX(1);transform-origin:left}
  .nav-desktop .nav-cta{
    background:var(--accent);color:var(--bg);
    padding:8px 20px;border-radius:6px;
    font-weight:600;font-size:13px;
    letter-spacing:.02em;
    transition:background 240ms,color 240ms,transform 180ms;
  }
  .nav-desktop .nav-cta::after{display:none}
  .nav-desktop .nav-cta:hover{
    background:var(--ink);color:var(--bg);
    transform:translateY(-2px);
  }
}

.nav-toggle{
  display:flex;flex-direction:column;justify-content:center;
  align-items:center;gap:5px;
  width:44px;height:44px;
  background:none;border:none;cursor:pointer;
  z-index:1100;position:relative;
  padding:0;
}
.nav-toggle span{
  display:block;width:22px;height:2px;
  background:var(--ink);border-radius:2px;
  transition:transform 320ms cubic-bezier(.2,.7,.2,1),opacity 200ms;
  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}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
@media(min-width:1024px){.nav-toggle{display:none}}

/* ===================== DRAWER ===================== */
.drawer-backdrop{
  position:fixed;inset:0;
  background:rgba(0,0,0,0.55);
  z-index:1040;
  opacity:0;pointer-events:none;
  transition:opacity 240ms;
}
.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%);
  transition:transform 320ms cubic-bezier(.2,.7,.2,1);
  padding:calc(var(--header-h) + 24px) 28px 32px;
  overflow-y:auto;
  display:flex;flex-direction:column;gap:8px;
}
.drawer.is-open{transform:translateX(0)}

.drawer a{
  display:block;
  font-size:17px;font-weight:500;
  color:var(--ink-soft);
  padding:14px 0;
  border-bottom:1px solid var(--line);
  text-decoration:none;
  transition:color 200ms,padding-left 200ms;
}
.drawer a:hover,.drawer a.is-active{color:var(--accent);padding-left:8px}
.drawer .drawer-cta{
  display:block;margin-top:16px;
  background:var(--accent);color:var(--bg);
  text-align:center;
  padding:14px 24px;border-radius:8px;
  font-weight:600;font-size:15px;
  border-bottom:none;
  transition:background 200ms,color 200ms;
}
.drawer .drawer-cta:hover{background:var(--ink);color:var(--bg);padding-left:0}

/* ===================== MAIN ===================== */
main{padding-top:var(--header-h);position:relative;z-index:1}

/* ===================== HERO ===================== */
.hero{
  min-height:min(90vh,800px);
  display:grid;
  grid-template-columns:1fr;
  align-items:center;
  gap:clamp(24px,4vw,48px);
  padding:clamp(48px,8vw,80px) 0;
}
@media(min-width:768px){
  .hero{grid-template-columns:3fr 2fr;min-height:min(85vh,780px)}
}
.hero-visual{
  position:relative;
  border-radius:var(--radius-lg);
  overflow:hidden;
  aspect-ratio:4/3;
  background:var(--surface);
  box-shadow:0 32px 64px -24px rgba(0,0,0,.5);
}
.hero-visual img{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
}
.hero-visual .ba-after{
  clip-path:inset(0 50% 0 0);
  z-index:2;
}
.hero-visual .ba-before{z-index:1}
.hero-visual .ba-handle{
  position:absolute;top:0;bottom:0;
  left:50%;z-index:3;
  width:3px;
  background:var(--accent);
  cursor:ew-resize;
  transform:translateX(-50%);
  box-shadow:0 0 12px rgba(217,119,6,.4);
}
.hero-visual .ba-handle::before{
  content:'';
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:36px;height:36px;
  background:var(--accent);
  border-radius:50%;
  box-shadow:0 2px 12px rgba(217,119,6,.5);
}
.hero-visual .ba-handle::after{
  content:'\2194';
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  color:var(--bg);font-size:16px;font-weight:700;
  z-index:1;
}
.hero-visual .ba-label{
  position:absolute;bottom:16px;
  padding:4px 12px;
  font-size:11px;font-weight:600;letter-spacing:.08em;
  text-transform:uppercase;
  border-radius:4px;z-index:4;
  pointer-events:none;
}
.hero-visual .ba-label--before{left:16px;background:rgba(28,25,23,.8);color:var(--ink-soft)}
.hero-visual .ba-label--after{right:16px;background:rgba(217,119,6,.85);color:var(--bg)}

.hero-content{
  display:flex;flex-direction:column;gap:20px;
}
.eyebrow{
  font-family:'Inter',sans-serif;
  font-size:clamp(11px,1.1vw,13px);
  font-weight:600;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--accent);
  display:flex;align-items:center;gap:12px;
}
.eyebrow::before{
  content:'';width:32px;height:1.5px;
  background:var(--accent);flex-shrink:0;
}
.hero h1{margin-bottom:4px}
.hero .sub{
  font-size:clamp(15px,1.2vw,18px);
  color:var(--ink-soft);
  line-height:1.65;
  max-width:440px;
}

.btn-primary{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--accent);color:var(--bg);
  padding:14px 28px;border-radius:8px;
  font-family:'Inter',sans-serif;
  font-weight:600;font-size:15px;
  border:none;cursor:pointer;
  text-decoration:none;
  transition:background 240ms,color 240ms,transform 180ms,box-shadow 240ms;
  letter-spacing:.01em;
  width:fit-content;
}
.btn-primary:hover,.btn-primary:focus-visible{
  background:var(--ink);color:var(--bg);
  transform:translateY(-2px);
  box-shadow:0 8px 24px -8px rgba(217,119,6,.35);
}
.btn-primary svg{width:18px;height:18px}

.btn-ghost{
  display:inline-flex;align-items:center;gap:8px;
  background:transparent;color:var(--ink);
  padding:12px 24px;border-radius:8px;
  border:1.5px solid var(--line-strong);
  font-family:'Inter',sans-serif;
  font-weight:500;font-size:14px;
  cursor:pointer;text-decoration:none;
  transition:background 240ms,color 240ms,border-color 240ms,transform 180ms;
  width:fit-content;
}
.btn-ghost:hover,.btn-ghost:focus-visible{
  background:var(--surface);color:var(--ink);
  border-color:var(--accent);
  transform:translateY(-2px);
}

.trust-strip{
  display:flex;flex-wrap:wrap;gap:12px;
  margin-top:8px;
}
.trust-badge{
  display:inline-flex;align-items:center;gap:6px;
  font-size:12px;font-weight:500;
  color:var(--ink-soft);
  background:var(--surface);
  padding:6px 14px;border-radius:20px;
  border:1px solid var(--line);
}
.trust-badge svg{width:14px;height:14px;color:var(--accent);flex-shrink:0}

.availability{
  font-size:13px;color:var(--accent);font-weight:500;
  display:flex;align-items:center;gap:8px;
  margin-top:4px;
}
.availability::before{
  content:'';width:8px;height:8px;
  background:var(--accent);border-radius:50%;
  animation:pulse-dot 2s ease infinite;
}
@keyframes pulse-dot{
  0%,100%{opacity:1;transform:scale(1)}
  50%{opacity:.5;transform:scale(.8)}
}

/* ===================== STATS STRIP ===================== */
.stats{
  background:var(--surface);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  padding:clamp(32px,5vw,56px) 0;
}
.stats-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:clamp(16px,3vw,32px);
  text-align:center;
}
@media(max-width:640px){.stats-grid{grid-template-columns:repeat(2,1fr)}}
.stat-item{display:flex;flex-direction:column;gap:4px}
.stat-num{
  font-family:'JetBrains Mono',monospace;
  font-size:clamp(1.8rem,3.5vw,2.6rem);
  font-weight:500;
  color:var(--accent);
  line-height:1;
}
.stat-label{
  font-size:13px;color:var(--ink-soft);
  font-weight:500;
}

/* ===================== SECTION COMMON ===================== */
.section{
  padding:clamp(56px,8vw,96px) 0;
  position:relative;
}
.section--alt{background:var(--surface)}
.section-header{
  text-align:center;
  margin-bottom:clamp(32px,5vw,56px);
  max-width:640px;
  margin-left:auto;margin-right:auto;
}
.section-header .eyebrow{justify-content:center}
.section-header .eyebrow::before{display:none}
.section-header h2{margin:12px 0 8px}
.section-header p{color:var(--ink-soft);font-size:15px}

.stitch-divider{
  width:120px;height:2px;margin:16px auto 0;
  background:repeating-linear-gradient(
    90deg,
    var(--accent) 0,var(--accent) 8px,
    transparent 8px,transparent 14px
  );
  animation:stitch-draw 2s ease forwards;
}
@keyframes stitch-draw{
  from{width:0}
  to{width:120px}
}

/* ===================== SERVICES GRID ===================== */
.services-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:clamp(12px,2vw,20px);
}
@media(max-width:1024px){.services-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:768px){.services-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.services-grid{grid-template-columns:1fr}}

.card-flip{
  perspective:900px;
  height:260px;
  cursor:pointer;
}
.card-flip-inner{
  position:relative;
  width:100%;height:100%;
  transition:transform 600ms cubic-bezier(.2,.7,.2,1);
  transform-style:preserve-3d;
}
.card-flip:hover .card-flip-inner,
.card-flip.is-flipped .card-flip-inner{
  transform:rotateY(180deg);
}
.card-flip-front,.card-flip-back{
  position:absolute;inset:0;
  backface-visibility:hidden;
  -webkit-backface-visibility:hidden;
  border-radius:var(--radius);
  padding:clamp(16px,2vw,24px);
  display:flex;flex-direction:column;
  border:1px solid var(--line);
}
.card-flip-front{
  background:var(--surface);
  justify-content:space-between;
}
.card-flip-front .card-icon{
  width:44px;height:44px;
  color:var(--accent);
  margin-bottom:12px;
  flex-shrink:0;
}
.card-flip-front h4{margin-bottom:6px;font-size:clamp(0.95rem,1.2vw,1.1rem)}
.card-flip-front p{font-size:13px;color:var(--ink-soft);line-height:1.55;margin:0}
.card-flip-front .card-hint{
  font-size:11px;color:var(--accent-2);
  margin-top:auto;
  padding-top:10px;
  display:flex;align-items:center;gap:4px;
}
.card-flip-front .card-hint svg{width:12px;height:12px}
.card-flip-back{
  background:linear-gradient(160deg,var(--surface-2),var(--surface));
  transform:rotateY(180deg);
  justify-content:center;
  align-items:center;
  text-align:center;
  gap:12px;
}
.card-flip-back .card-result-icon{
  width:32px;height:32px;color:var(--accent);
}
.card-flip-back h4{font-size:1rem;color:var(--accent)}
.card-flip-back p{font-size:13px;color:var(--ink-soft);margin:0;max-width:90%}
.card-flip-back .card-price{
  font-family:'JetBrains Mono',monospace;
  font-size:clamp(1.1rem,1.5vw,1.3rem);
  font-weight:500;
  color:var(--ink);
  margin-top:4px;
}

/* ===================== BEFORE / AFTER ===================== */
.ba-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:clamp(16px,2.5vw,24px);
}
@media(max-width:768px){.ba-grid{grid-template-columns:1fr}}

.ba-item{
  position:relative;
  border-radius:var(--radius-lg);
  overflow:hidden;
  aspect-ratio:4/3;
  background:var(--surface);
  cursor:ew-resize;
  box-shadow:0 8px 32px -12px rgba(0,0,0,.4);
  border:1px solid var(--line);
}
.ba-item img{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
}
.ba-item .ba-after{clip-path:inset(0 50% 0 0);z-index:2}
.ba-item .ba-before{z-index:1}
.ba-item .ba-handle{
  position:absolute;top:0;bottom:0;
  left:50%;z-index:3;
  width:2px;
  background:var(--accent);
  cursor:ew-resize;
  transform:translateX(-50%);
}
.ba-item .ba-handle::before{
  content:'';position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:32px;height:32px;
  background:var(--accent);border-radius:50%;
  box-shadow:0 2px 8px rgba(217,119,6,.4);
}
.ba-item .ba-handle::after{
  content:'\2194';
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  color:var(--bg);font-size:14px;font-weight:700;
}
.ba-item .ba-label{
  position:absolute;bottom:12px;
  padding:3px 10px;
  font-size:10px;font-weight:600;letter-spacing:.08em;
  text-transform:uppercase;border-radius:3px;
  z-index:4;pointer-events:none;
}
.ba-item .ba-label--before{left:12px;background:rgba(28,25,23,.8);color:var(--ink-soft)}
.ba-item .ba-label--after{right:12px;background:rgba(217,119,6,.85);color:var(--bg)}
.ba-item .ba-caption{
  position:absolute;top:12px;left:12px;z-index:4;
  font-size:12px;font-weight:600;color:var(--ink);
  background:rgba(28,25,23,.75);
  padding:4px 12px;border-radius:4px;
  pointer-events:none;
}

/* ===================== MATERIALS ===================== */
.materials-layout{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(24px,4vw,48px);
  align-items:start;
}
@media(max-width:768px){.materials-layout{grid-template-columns:1fr}}

.materials-list{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
  list-style:none;
}
@media(max-width:480px){.materials-list{grid-template-columns:1fr}}

.material-item{
  display:flex;align-items:flex-start;gap:12px;
  background:var(--surface);
  padding:16px;border-radius:var(--radius);
  border:1px solid var(--line);
  transition:border-color 240ms,transform 180ms;
}
.material-item:hover{
  border-color:var(--accent);
  transform:translateY(-2px);
}
.material-item svg{
  width:20px;height:20px;flex-shrink:0;
  color:var(--accent);margin-top:2px;
}
.material-item strong{
  display:block;font-size:14px;
  color:var(--ink);font-weight:600;
  margin-bottom:2px;
}
.material-item span{font-size:12px;color:var(--ink-soft);line-height:1.4}

.materials-image{
  border-radius:var(--radius-lg);
  overflow:hidden;
  position:relative;
  aspect-ratio:3/4;
  background:var(--surface);
}
.materials-image img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 600ms cubic-bezier(.2,.7,.2,1);
}
.materials-image:hover img{transform:scale(1.04)}
.materials-image::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to top,rgba(28,25,23,.6) 0%,transparent 40%);
  pointer-events:none;
}

/* ===================== PROCESS TIMELINE ===================== */
.timeline{
  position:relative;
  max-width:780px;
  margin:0 auto;
}
.timeline::before{
  content:'';
  position:absolute;
  left:24px;top:0;bottom:0;
  width:2px;
  background:repeating-linear-gradient(
    to bottom,
    var(--accent) 0,var(--accent) 8px,
    transparent 8px,transparent 14px
  );
}
@media(min-width:768px){.timeline::before{left:50%;transform:translateX(-50%)}}

.timeline-step{
  display:grid;
  grid-template-columns:48px 1fr;
  gap:20px;
  padding-bottom:clamp(32px,4vw,48px);
  position:relative;
  align-items:start;
}
@media(min-width:768px){
  .timeline-step{
    grid-template-columns:1fr 48px 1fr;
    gap:clamp(20px,3vw,40px);
    text-align:left;
  }
  .timeline-step .timeline-marker{grid-column:2;grid-row:1;justify-self:center}
  .timeline-step:nth-child(odd) .timeline-content{grid-column:1;grid-row:1;text-align:right}
  .timeline-step:nth-child(even) .timeline-content{grid-column:3;grid-row:1;text-align:left}
}

.timeline-marker{
  width:48px;height:48px;
  border-radius:50%;
  background:var(--surface);
  border:2px solid var(--accent);
  display:flex;align-items:center;justify-content:center;
  font-family:'JetBrains Mono',monospace;
  font-size:16px;font-weight:500;
  color:var(--accent);
  position:relative;z-index:2;
  flex-shrink:0;
}
.timeline-content{
  background:var(--surface);
  padding:clamp(16px,2.5vw,24px);
  border-radius:var(--radius);
  border:1px solid var(--line);
  transition:border-color 240ms,box-shadow 240ms;
}
.timeline-content:hover{
  border-color:var(--accent);
  box-shadow:0 8px 24px -8px rgba(217,119,6,.15);
}
.timeline-content h4{margin-bottom:6px}
.timeline-content p{font-size:14px;color:var(--ink-soft);margin:0}
.timeline-content .timeline-time{
  font-family:'JetBrains Mono',monospace;
  font-size:12px;color:var(--accent);
  margin-top:8px;display:block;
}
@media(min-width:768px){
  .timeline-step:nth-child(odd) .timeline-content{text-align:right}
}

/* ===================== PRICING ===================== */
.pricing-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:clamp(16px,2.5vw,24px);
  align-items:start;
}
@media(max-width:768px){.pricing-grid{grid-template-columns:1fr}}

.pricing-card{
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:clamp(24px,3vw,36px);
  display:flex;flex-direction:column;gap:16px;
  position:relative;
  transition:border-color 240ms,transform 240ms,box-shadow 240ms;
}
.pricing-card:hover{
  border-color:var(--accent);
  transform:translateY(-6px);
  box-shadow:0 16px 48px -16px rgba(217,119,6,.2);
}
.pricing-card.featured{
  border-color:var(--accent);
  background:linear-gradient(170deg,var(--surface-2) 0%,var(--surface) 100%);
}
.pricing-card.featured::before{
  content:'En Popüler';
  position:absolute;top:-12px;right:24px;
  background:var(--accent);color:var(--bg);
  font-size:11px;font-weight:700;
  padding:4px 14px;border-radius:20px;
  letter-spacing:.04em;
}
.pricing-card h3{font-size:clamp(1.1rem,1.6vw,1.3rem)}
.pricing-card .price{
  font-family:'JetBrains Mono',monospace;
  font-size:clamp(1.6rem,2.5vw,2.2rem);
  font-weight:500;
  color:var(--accent);
  line-height:1;
}
.pricing-card .price small{
  font-size:14px;color:var(--ink-soft);
  font-weight:400;display:block;
  margin-top:4px;
}
.pricing-includes{list-style:none;display:flex;flex-direction:column;gap:8px}
.pricing-includes li{
  display:flex;align-items:flex-start;gap:8px;
  font-size:14px;color:var(--ink-soft);
  line-height:1.5;
}
.pricing-includes li svg{
  width:16px;height:16px;flex-shrink:0;
  margin-top:3px;
}
.pricing-includes li.included svg{color:#22c55e}
.pricing-includes li.excluded{color:var(--accent-2);opacity:.7}
.pricing-includes li.excluded svg{color:#ef4444}
.pricing-disclaimer{
  font-size:12px;color:var(--accent-2);
  margin-top:auto;padding-top:8px;
  border-top:1px solid var(--line);
}

/* ===================== TESTIMONIALS ===================== */
.testimonials-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:clamp(16px,2.5vw,24px);
}
@media(max-width:768px){.testimonials-grid{grid-template-columns:1fr}}

.testimonial-card{
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:clamp(20px,3vw,32px);
  display:flex;flex-direction:column;gap:16px;
  position:relative;
  transition:border-color 240ms,transform 180ms;
}
.testimonial-card:hover{
  border-color:var(--accent);
  transform:translateY(-4px);
}
.testimonial-card::before{
  content:'\201C';
  font-family:'Bitter',serif;
  font-size:4rem;line-height:1;
  color:var(--accent);
  opacity:.3;
  position:absolute;top:12px;left:20px;
}
.testimonial-card blockquote{
  font-size:14px;line-height:1.7;
  color:var(--ink-soft);
  font-style:italic;
  padding-top:24px;
  margin:0;
}
.testimonial-author{
  display:flex;flex-direction:column;gap:2px;
  margin-top:auto;
  padding-top:12px;
  border-top:1px solid var(--line);
}
.testimonial-author strong{font-size:14px;color:var(--ink)}
.testimonial-author span{font-size:12px;color:var(--accent-2)}

/* ===================== FAQ ===================== */
.faq-list{
  max-width:780px;
  margin:0 auto;
  display:flex;flex-direction:column;gap:8px;
}
.faq-item{
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--radius);
  overflow:hidden;
  transition:border-color 240ms;
}
.faq-item[open]{border-color:var(--accent)}
.faq-item summary{
  padding:clamp(14px,2vw,20px) clamp(18px,3vw,28px);
  cursor:pointer;
  font-family:'Bitter',serif;
  font-weight:600;
  font-size:clamp(0.95rem,1.2vw,1.1rem);
  color:var(--ink);
  list-style:none;
  display:flex;justify-content:space-between;align-items:center;gap:16px;
  transition:color 240ms;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{
  content:'+';
  font-family:'JetBrains Mono',monospace;
  font-size:20px;font-weight:400;
  color:var(--accent);
  transition:transform 320ms cubic-bezier(.2,.7,.2,1);
  flex-shrink:0;
}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item summary:hover{color:var(--accent)}

.faq-item .faq-body{
  height:0;
  padding:0 clamp(18px,3vw,28px);
  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:24px;
}
.faq-item .faq-body p{
  font-size:14px;color:var(--ink-soft);
  line-height:1.7;margin:0;
}
@media(prefers-reduced-motion:reduce){
  .faq-item .faq-body{transition:none}
}

/* ===================== NEWS / ATOLYE NOTLARI ===================== */
.news-list{
  max-width:780px;
  margin:0 auto;
  display:flex;flex-direction:column;gap:12px;
}
.news-item{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:16px;
  align-items:start;
  background:var(--surface);
  padding:clamp(14px,2vw,20px) clamp(16px,2.5vw,24px);
  border-radius:var(--radius);
  border:1px solid var(--line);
  transition:border-color 240ms;
}
.news-item:hover{border-color:var(--accent)}
.news-date{
  font-family:'JetBrains Mono',monospace;
  font-size:12px;color:var(--accent);
  white-space:nowrap;
  padding-top:2px;
}
.news-text{font-size:14px;color:var(--ink-soft);margin:0}

/* ===================== CONTACT SECTION ===================== */
.contact-layout{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(24px,5vw,56px);
  align-items:start;
}
@media(max-width:768px){.contact-layout{grid-template-columns:1fr}}

.contact-channels{
  display:flex;flex-direction:column;gap:14px;
}
.contact-channel{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:14px;
  align-items:start;
  padding:14px 0;
  border-bottom:1px solid var(--line);
  transition:transform 240ms cubic-bezier(.4,0,.2,1),background 240ms;
}
.contact-channel:hover{transform:translateX(4px)}
.contact-channel svg{
  width:20px;height:20px;
  color:var(--accent-2);
  margin-top:2px;
  transition:color 240ms;
  flex-shrink:0;
}
.contact-channel:hover svg{color:var(--accent)}
.contact-channel strong{
  display:block;font-size:13px;
  color:var(--ink-soft);font-weight:500;
  margin-bottom:2px;
}
.contact-channel a,
.contact-channel span.val{
  font-size:15px;color:var(--ink);
  word-break:break-all;
}

.hours-grid{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:4px 16px;
  font-size:14px;
  font-variant-numeric:tabular-nums;
}
.hours-grid .day{color:var(--ink-soft);font-weight:500}
.hours-grid .time{color:var(--ink)}
.hours-grid .today .day,.hours-grid .today .time{color:var(--accent);font-weight:600}

/* ===================== FORM ===================== */
.form{display:flex;flex-direction:column;gap:18px}
.form-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
}
@media(max-width:640px){.form-row{grid-template-columns:1fr}}

.field{display:flex;flex-direction:column;gap:6px}
.field label{
  font-size:13px;font-weight:500;
  color:var(--ink-soft);
  display:flex;align-items:center;gap:4px;
}
.field input[type="text"],
.field input[type="email"],
.field input[type="tel"],
.field select,
.field textarea{
  background:var(--bg);
  border:1.5px solid var(--line-strong);
  border-radius:6px;
  padding:12px 14px;
  font-family:'Inter',sans-serif;
  font-size:15px;
  color:var(--ink);
  transition:border-color 240ms,box-shadow 240ms;
  width:100%;
}
.field input:focus,
.field select:focus,
.field textarea:focus{
  outline:none;
  border-color:var(--accent);
  box-shadow:0 0 0 3px rgba(217,119,6,.15);
}
.field textarea{min-height:120px;resize:vertical}
.field select{cursor:pointer}

.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);
}
.kvkk-field{
  display:flex;align-items:flex-start;gap:10px;
}
.kvkk-field label{
  font-size:13px;color:var(--ink-soft);
  line-height:1.5;cursor:pointer;
}
.form .btn-primary{width:100%}
@media(min-width:640px){.form .btn-primary{width:auto}}

/* ===================== FOOTER ===================== */
.site-footer{
  background:var(--surface);
  border-top:1px solid var(--line);
  padding:clamp(40px,6vw,64px) 0 clamp(24px,3vw,32px);
}
.footer-grid{
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1fr;
  gap:clamp(24px,4vw,48px);
  margin-bottom:clamp(32px,4vw,48px);
}
@media(max-width:768px){
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px 24px}
}
@media(max-width:480px){
  .footer-grid{grid-template-columns:1fr}
}

.footer-brand{display:flex;flex-direction:column;gap:12px}
.footer-brand .logo{margin-bottom:4px}
.footer-brand p{font-size:13px;color:var(--ink-soft);max-width:300px}

.footer-col h4{
  font-size:13px;font-weight:600;
  text-transform:uppercase;letter-spacing:.1em;
  color:var(--ink);margin-bottom:14px;
}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:8px}
.footer-col li a{
  font-size:14px;color:var(--ink-soft);
  text-decoration:none;
  transition:color 200ms,padding-left 200ms;
}
.footer-col li a:hover{color:var(--accent);padding-left:4px}

.footer-bottom{
  display:flex;flex-wrap:wrap;
  justify-content:space-between;align-items:center;
  gap:12px;
  padding-top:24px;
  border-top:1px solid var(--line);
  font-size:12px;color:var(--accent-2);
}
.footer-bottom a{color:var(--accent-2);transition:color 200ms}
.footer-bottom a:hover{color:var(--accent)}
.footer-legal{display:flex;flex-wrap:wrap;gap:8px 18px}
.footer-vkn{font-family:'JetBrains Mono',monospace;font-size:11px}

/* ===================== 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:var(--radius-lg);
  padding:20px 24px;
  z-index:9999;
  transform:translateY(140%);
  opacity:0;
  transition:transform 280ms cubic-bezier(.2,.7,.2,1),opacity 240ms;
  box-shadow:0 16px 48px -12px rgba(0,0,0,.5);
}
@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:15px;margin-bottom:8px;color:var(--ink);
}
.cookie-banner p{
  font-size:13px;color:var(--ink-soft);
  line-height:1.6;margin-bottom:16px;
}
.cookie-banner p a{color:var(--accent);text-decoration:underline}
.cookie-actions{
  display:flex;gap:8px;flex-wrap:wrap;
}
.cookie-actions button{
  flex:1;min-width:100px;
  padding:10px 16px;
  border-radius:6px;
  font-family:'Inter',sans-serif;
  font-size:13px;font-weight:600;
  cursor:pointer;
  border:1.5px solid var(--line-strong);
  transition:background 200ms,color 200ms,border-color 200ms;
  min-height:44px;
}
.cookie-actions .cookie-accept{
  background:var(--accent);
  color:var(--bg);
  border-color:var(--accent);
}
.cookie-actions .cookie-accept:hover{
  background:var(--ink);color:var(--bg);
  border-color:var(--ink);
}
.cookie-actions .cookie-reject{
  background:transparent;color:var(--ink);
  border-color:var(--line-strong);
}
.cookie-actions .cookie-reject:hover{
  background:var(--surface-2);color:var(--ink);
  border-color:var(--accent-2);
}
.cookie-actions .cookie-settings{
  background:transparent;color:var(--ink-soft);
  border-color:var(--line);
}
.cookie-actions .cookie-settings:hover{
  background:var(--surface-2);color:var(--ink);
  border-color:var(--accent-2);
}

/* ===================== PAGE HERO (subpages) ===================== */
.page-hero{
  padding:clamp(56px,8vw,96px) 0 clamp(32px,5vw,56px);
  text-align:center;
}
.page-hero h1{margin:12px 0 8px}
.page-hero p{color:var(--ink-soft);max-width:540px;margin:0 auto}

.page-content{
  max-width:780px;
  margin:0 auto;
  padding-bottom:clamp(56px,8vw,96px);
}
.page-content h2{margin:clamp(28px,4vw,40px) 0 12px;font-size:clamp(1.3rem,2vw,1.7rem)}
.page-content h3{margin:24px 0 8px;font-size:clamp(1.05rem,1.4vw,1.2rem)}
.page-content p{font-size:15px;color:var(--ink-soft);line-height:1.75;margin-bottom:14px}
.page-content ul,.page-content ol{
  margin:12px 0 16px 20px;
  color:var(--ink-soft);font-size:15px;line-height:1.75;
}
.page-content ul li,.page-content ol li{margin-bottom:6px}
.page-content a{color:var(--accent);text-decoration:underline}

/* ===================== TABLE SCROLL ===================== */
.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:6px;
}
.table-scroll>table{margin:0!important;min-width:480px;width:100%}
:where(*:has(>.table-scroll),*:has(>*>.table-scroll),*:has(>*>*>.table-scroll)){min-width:0}

table{
  border-collapse:collapse;width:100%;
  font-size:14px;color:var(--ink-soft);
}
table th{
  text-align:left;font-weight:600;
  color:var(--ink);font-size:13px;
  padding:12px 16px;
  background:var(--surface-2);
  border-bottom:1px solid var(--line);
}
table td{
  padding:10px 16px;
  border-bottom:1px solid var(--line);
}
table tr:last-child td{border-bottom:none}
table tr:hover td{background:rgba(217,119,6,.04)}

/* ===================== TEAM ===================== */
.team-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:clamp(16px,3vw,24px);
}
@media(max-width:768px){.team-grid{grid-template-columns:1fr}}

.team-card{
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  overflow:hidden;
  transition:border-color 240ms,transform 240ms;
}
.team-card:hover{
  border-color:var(--accent);
  transform:translateY(-4px);
}
.team-card .team-photo{
  aspect-ratio:4/5;
  background:var(--surface-2);
  overflow:hidden;
}
.team-card .team-photo img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 600ms cubic-bezier(.2,.7,.2,1);
}
.team-card:hover .team-photo img{transform:scale(1.04)}
.team-card .team-info{
  padding:clamp(16px,2.5vw,24px);
}
.team-card .team-info h3{
  font-size:clamp(1rem,1.3vw,1.15rem);
  margin-bottom:4px;
}
.team-card .team-info .role{
  font-size:12px;color:var(--accent);
  font-weight:600;letter-spacing:.06em;
  text-transform:uppercase;
  margin-bottom:10px;display:block;
}
.team-card .team-info p{
  font-size:13px;color:var(--ink-soft);
  line-height:1.6;margin:0;
}

/* ===================== CONTACT PAGE ===================== */
.contact-cards{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:16px;
}
.contact-card{
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:12px;
  padding:clamp(18px,2.5vw,24px);
  display:flex;flex-direction:column;gap:10px;
  transition:transform 240ms,border-color 240ms,box-shadow 240ms;
}
.contact-card:hover{
  transform:translateY(-3px);
  border-color:var(--accent);
  box-shadow:0 12px 32px -8px rgba(217,119,6,.15);
}
.contact-card .card-icon-wrap{
  width:48px;height:48px;
  border-radius:12px;
  background:rgba(217,119,6,.1);
  display:flex;align-items:center;justify-content:center;
}
.contact-card .card-icon-wrap svg{width:22px;height:22px;color:var(--accent)}
.contact-card h4{font-size:14px;margin:0}
.contact-card .card-value{
  font-size:15px;color:var(--ink);
  word-break:break-all;overflow-wrap:anywhere;
}
.contact-card .card-value a{color:var(--ink);text-decoration:none}
.contact-card .card-value a:hover{color:var(--accent)}
.contact-card .card-sub{font-size:12px;color:var(--ink-soft)}

/* ===================== REVEAL ANIMATION ===================== */
.reveal{
  opacity:0;
  transform:translateY(28px);
  transition:opacity 600ms cubic-bezier(.2,.7,.2,1),
             transform 600ms cubic-bezier(.2,.7,.2,1);
}
.reveal.is-in{opacity:1;transform:none}
.reveal[style*="--i"]{
  transition-delay:calc(var(--i,0) * 80ms);
}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1!important;transform:none!important;transition:none!important}
}

/* ===================== NICHE ANIMATIONS ===================== */
@keyframes goldShimmer{
  0%,100%{filter:brightness(1) saturate(1)}
  50%{filter:brightness(1.15) saturate(1.1)}
}
.gold-shimmer{animation:goldShimmer 8s ease infinite}

@keyframes stitchPulse{
  0%,100%{stroke-dashoffset:0}
  50%{stroke-dashoffset:16}
}

@keyframes pageCornerCurl{
  0%,100%{transform:rotate(0deg) scale(1)}
  50%{transform:rotate(-2deg) scale(1.01)}
}
.page-curl{animation:pageCornerCurl 12s ease-in-out infinite}

@keyframes inkSpread{
  from{clip-path:inset(0 100% 0 0)}
  to{clip-path:inset(0 0 0 0)}
}

@keyframes leatherBreath{
  0%,100%{box-shadow:0 4px 16px -4px rgba(217,119,6,.1)}
  50%{box-shadow:0 8px 32px -8px rgba(217,119,6,.2)}
}
.leather-breath{animation:leatherBreath 10s ease-in-out infinite}

.paper-edge{
  position:relative;
}
.paper-edge::before{
  content:'';
  position:absolute;top:-6px;left:0;right:0;height:6px;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 120 6'%3E%3Cpath d='M0 6 Q5 0 10 4 Q15 1 20 5 Q25 0 30 4 Q35 2 40 5 Q45 0 50 3 Q55 1 60 5 Q65 0 70 4 Q75 2 80 5 Q85 0 90 3 Q95 1 100 5 Q105 0 110 4 Q115 2 120 6' fill='%231C1917'/%3E%3C/svg%3E") repeat-x;
  background-size:120px 6px;
}

/* ===================== COUNTER-UP ===================== */
.counter-up{
  font-variant-numeric:tabular-nums;
}

/* ===================== MANIFESTO ===================== */
.manifesto{
  padding:clamp(48px,8vw,80px) 0;
  text-align:center;
}
.manifesto blockquote{
  font-family:'Bitter',serif;
  font-size:clamp(1.4rem,3vw,2.4rem);
  font-weight:400;
  font-style:italic;
  color:var(--ink);
  line-height:1.45;
  max-width:720px;
  margin:0 auto;
  position:relative;
}
.manifesto blockquote::before,
.manifesto blockquote::after{
  font-size:3em;color:var(--accent);opacity:.3;
  position:absolute;line-height:1;
}
.manifesto blockquote::before{content:'\201C';top:-24px;left:-12px}
.manifesto blockquote::after{content:'\201D';bottom:-48px;right:-12px}
.manifesto cite{
  display:block;margin-top:24px;
  font-family:'Inter',sans-serif;
  font-size:14px;font-style:normal;
  color:var(--accent);font-weight:500;
}

/* ===================== FOCUS / A11Y ===================== */
*:focus-visible{
  outline:2px solid var(--accent);
  outline-offset:2px;
}
button:focus-visible,
a:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
summary:focus-visible{
  outline:2px solid var(--accent);
  outline-offset:2px;
}

/* ===================== SITEMAP PAGE ===================== */
.sitemap-list{
  list-style:none;
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
  gap:8px;
}
.sitemap-list li a{
  display:flex;align-items:center;gap:8px;
  padding:10px 14px;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:6px;
  font-size:14px;color:var(--ink-soft);
  transition:border-color 200ms,color 200ms;
}
.sitemap-list li a:hover{border-color:var(--accent);color:var(--accent)}
.sitemap-list li a svg{width:16px;height:16px;flex-shrink:0;color:var(--accent)}

/* ===================== 404 PAGE ===================== */
.page-404{
  min-height:60vh;
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  text-align:center;gap:16px;
  padding:clamp(48px,10vw,120px) 0;
}
.page-404 .code-404{
  font-family:'Bitter',serif;
  font-size:clamp(5rem,15vw,10rem);
  font-weight:700;
  color:var(--accent);
  line-height:1;
  opacity:.3;
}
.page-404 h1{font-size:clamp(1.4rem, 3vw, 2rem)}
.page-404 p{color:var(--ink-soft);max-width:400px}

/* ===================== THANK YOU PAGE ===================== */
.page-thanks{
  min-height:60vh;
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  text-align:center;gap:16px;
  padding:clamp(48px,10vw,120px) 0;
}
.page-thanks svg{width:64px;height:64px;color:var(--accent)}
.page-thanks h1{font-size:clamp(1.4rem, 3vw, 2rem)}
.page-thanks p{color:var(--ink-soft);max-width:400px}

/* ===================== PRINT ===================== */
@media print{
  .site-header,.drawer,.drawer-backdrop,.cookie-banner,.nav-toggle{display:none!important}
  main{padding-top:0!important}
  body{background:#fff;color:#111}
  .section{padding:24px 0}
  .reveal{opacity:1!important;transform:none!important}
}

/* ===================== RESPONSIVE ===================== */
@media(max-width:1024px){
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .pricing-grid{grid-template-columns:1fr}
  .team-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  .hero{grid-template-columns:1fr}
  .hero-visual{order:-1}
  .materials-layout{grid-template-columns:1fr}
  .contact-layout{grid-template-columns:1fr}
  .testimonials-grid{grid-template-columns:1fr}
  .ba-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .timeline::before{left:24px}
  .timeline-step{grid-template-columns:48px 1fr}
  .timeline-step .timeline-marker{grid-column:1;justify-self:start}
  .timeline-step:nth-child(odd) .timeline-content,
  .timeline-step:nth-child(even) .timeline-content{grid-column:2;text-align:left}
}
@media(max-width:640px){
  .services-grid{grid-template-columns:1fr}
  .card-flip{height:auto;min-height:220px}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .form-row{grid-template-columns:1fr}
  .form .btn-primary{width:100%}
}
@media(max-width:480px){
  .materials-list{grid-template-columns:1fr}
  .contact-cards{grid-template-columns:1fr}
  .trust-strip{flex-direction:column}
  h1{font-size:clamp(1.8rem, 6vw, 2.4rem)}
}
@media(max-width:360px){
  .container{padding-left:14px;padding-right:14px}
  .header-inner{padding:0 14px}
  .card-flip{min-height:200px}
}

.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);
}


/* overflow-x-guard */
html, body { overflow-x: hidden; max-width: 100vw; }


/* 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: aged-paper sepia tint hero img */
.hero img, [class*="hero"] img:not([class*="logo"]) {
  filter: sepia(0.18) contrast(1.05) saturate(0.92);
  transition: filter 600ms ease;
}
.hero img:hover, [class*="hero"] img:hover { filter: none; }

/* 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; }
