:root{
  --ivory:#fbf6ef;
  --paper:#f7efe6;
  --champagne:#efe3d6;
  --sand:#eadbca;
  --blush:#f2d6d9;
  --rose:#d7a7ae;
  --accent:#A5BDC1;
  --ink:#15100f;
  --cocoa:#2f211f;
  --muted:#6f5b58;
  --hair: rgba(47,33,31,.14);
  --glass: rgba(255,255,255,.68);
  --shadow: 0 28px 92px rgba(21,16,15,.14);
  --shadow2: 0 14px 34px rgba(21,16,15,.10);
  --r: 28px;
  --ease: cubic-bezier(.22,1,.36,1);
}

@font-face{
  font-family: "Billion Miracles";
  src: url("./fonts/billion.ttf") format("truetype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face{
  font-family: "Sparkling";
  src: url("./fonts/sparkling.ttf") format("truetype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

*{ box-sizing:border-box; }
html{
  scroll-behavior:smooth;
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
  touch-action: manipulation;
}
body{
  margin:0;
  font-family:"Manrope", system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  color: var(--cocoa);
  background:
    radial-gradient(1200px 620px at 18% -10%, rgba(242,214,217,.48), transparent 65%),
    radial-gradient(980px 560px at 88% 18%, rgba(239,227,214,.92), transparent 60%),
    radial-gradient(1100px 680px at 50% 112%, rgba(234,219,202,.70), transparent 62%),
    linear-gradient(180deg, var(--paper) 0%, var(--ivory) 52%, #f6eee6 100%);
  min-height:100svh;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x:hidden;
  touch-action: manipulation;
}
a{ color: inherit; text-decoration:none; }
button{ font-family:inherit; }
::selection{ background: rgba(215,167,174,.35); }

.serif{ font-family:"Fraunces", Georgia, serif; letter-spacing:.2px; }
.container{
  max-width: 560px;
  margin: 0 auto;
  padding: 0 18px calc(108px + env(safe-area-inset-bottom));
  position:relative;
  z-index: 2;
}
.hero .container{
  padding-bottom: 18px;
}

/* Background texture */
.bg-grain{
  position:fixed;
  inset:-40px;
  pointer-events:none;
  opacity:.14;
  z-index:2;
  mix-blend-mode: soft-light;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='260' height='260'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='260' height='260' filter='url(%23n)' opacity='.28'/%3E%3C/svg%3E");
  background-size: 260px 260px;
}
.bg-filigree{
  position:fixed;
  inset:-20px;
  pointer-events:none;
  opacity:.26;
  z-index:0;
  background:
    radial-gradient(circle at 16% 22%, rgba(239,227,214,.55) 0 1px, transparent 2px),
    radial-gradient(circle at 72% 24%, rgba(242,214,217,.50) 0 1px, transparent 2px),
    radial-gradient(circle at 28% 76%, rgba(234,219,202,.62) 0 1px, transparent 2px),
    radial-gradient(circle at 86% 78%, rgba(239,227,214,.45) 0 1px, transparent 2px);
  background-size: 150px 150px, 170px 170px, 210px 210px, 240px 240px;
  background-position: 0 0, 40px 90px, 10px 30px, 80px 10px;
  mix-blend-mode:multiply;
  filter: blur(.2px);
}

/* Floating shapes (subtle, animated) */
.bg-shapes{
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:1;
  opacity:1;
  transform: translateZ(0);
}
.bg-shapes__shape{
  position:absolute;
  left: 0;
  top: 0;
  width: var(--s);
  height: var(--s);
  border-radius: 999px;
  background:
    radial-gradient(circle at 32% 28%, rgba(255,255,255,.60) 0%, rgba(255,255,255,0) 52%),
    radial-gradient(circle at 65% 72%, var(--c1) 0%, rgba(255,255,255,0) 64%),
    radial-gradient(circle at 44% 52%, var(--c2) 0%, rgba(255,255,255,0) 70%);
  filter: blur(var(--b));
  box-shadow: 0 0 0 1px rgba(165,189,193,.10), 0 30px 120px rgba(165,189,193,.12);
  mix-blend-mode: normal;
  opacity: var(--o);
  will-change: transform;
  transform: translate3d(var(--x), var(--y), 0) scale(var(--k));
}
.bg-shapes__heart{
  position:absolute;
  left: 0;
  top: 0;
  width: var(--s);
  height: var(--s);
  opacity: var(--o);
  filter: blur(var(--b));
  background: var(--hc);
  will-change: transform;
  transform: translate3d(var(--x), var(--y), 0) rotate(var(--r));
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 21.35l-1.45-1.32C5.4 15.36 2 12.28 2 8.5 2 5.42 4.42 3 7.5 3c1.74 0 3.41.81 4.5 2.09C13.09 3.81 14.76 3 16.5 3 19.58 3 22 5.42 22 8.5c0 3.78-3.4 6.86-8.55 11.54L12 21.35z'/%3E%3C/svg%3E");
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-position: center;
  -webkit-mask-size: contain;
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 21.35l-1.45-1.32C5.4 15.36 2 12.28 2 8.5 2 5.42 4.42 3 7.5 3c1.74 0 3.41.81 4.5 2.09C13.09 3.81 14.76 3 16.5 3 19.58 3 22 5.42 22 8.5c0 3.78-3.4 6.86-8.55 11.54L12 21.35z'/%3E%3C/svg%3E");
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: contain;
  box-shadow: 0 16px 70px rgba(165,189,193,.18);
}
@media (prefers-reduced-motion: reduce){
  .bg-shapes{ display:none; }
}

/* UI */
.pill{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding: 9px 12px;
  border-radius: 999px;
  border: 1px solid rgba(47,33,31,.12);
  background: rgba(255,255,255,.68);
  color: rgba(21,16,15,.86);
  font-weight: 600;
  font-size: 12px;
  backdrop-filter: blur(10px);
}
.pill--kicker{ letter-spacing:.18em; text-transform: uppercase; }
.pill--meta{ letter-spacing:.06em; }
.pill--band{
  border-color: rgba(215, 167, 174, .42);
  background: linear-gradient(145deg, rgba(255,255,255,.78), rgba(242,214,217,.52));
  color: rgba(47,33,31,.88);
  box-shadow: 0 12px 28px rgba(215, 167, 174, .14);
}

.btn{
  width:100%;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding: 13px 14px;
  border-radius: 18px;
  border: 1px solid rgba(47,33,31,.12);
  background: rgba(255,255,255,.76);
  box-shadow: 0 12px 26px rgba(21,16,15,.08);
  color: rgba(21,16,15,.94);
  font-weight: 650;
  letter-spacing: .2px;
  transition: transform .14s var(--ease);
  cursor:pointer;
  -webkit-tap-highlight-color: transparent;
}
.btn:active{ transform: translateY(1px) scale(.99); }
.btn--primary{ background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(255,255,255,.70)); box-shadow: var(--shadow); }

/* Takvim: Apple links, Google rechts — gleiche Typo, Icons neben Text */
.btn--cal{
  font-size: 14px;
  font-weight: 650;
  letter-spacing: .02em;
  min-height: 48px;
  padding: 12px 10px;
  gap: 8px;
}
.btn--cal .btn__icon{
  display: inline-flex;
  flex-shrink: 0;
  line-height: 0;
}
.btn--cal .icon-maps-pin{
  display: block;
}
.btn--cal .btn__label{
  line-height: 1.2;
}
.btn--cal-apple .icon-apple{ color: var(--cocoa); }

.grid1{ display:grid; grid-template-columns: 1fr; gap: 10px; }
.grid2{ display:grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.grid2--cal{ align-items: stretch; }
.mt{ margin-top: 14px; }

.card{
  border-radius: var(--r);
  border: 1px solid rgba(47,33,31,.10);
  background: var(--glass);
  box-shadow: var(--shadow2);
  backdrop-filter: blur(12px);
  padding: 20px;
}
.card--center{ text-align:center; }

.section{ padding: 22px 0; }
.container > .section:first-child{ padding-top: 12px; }
.h2{
  margin:0 0 10px;
  font-family:"Fraunces", Georgia, serif;
  font-size: 22px;
  line-height:1.15;
  color: var(--ink);
}
.p{ margin:0; color: var(--muted); font-size: 14px; line-height: 1.75; }
.p--center{ text-align:center; margin-top: 10px; }

/* Hero */
.hero{
  min-height: auto;
  padding-top: max(18px, calc(10px + env(safe-area-inset-top)));
  padding-bottom: 14px;
  position:relative;
  overflow:hidden;
}
.hero__backdrop{
  position:absolute;
  inset:-60px;
  background:
    radial-gradient(980px 520px at 22% 24%, rgba(242,214,217,.62), transparent 62%),
    radial-gradient(980px 540px at 80% 22%, rgba(239,227,214,.95), transparent 60%),
    radial-gradient(1200px 720px at 50% 115%, rgba(234,219,202,.66), transparent 62%),
    linear-gradient(180deg, rgba(251,247,241,1), rgba(247,239,230,1));
  z-index: 0;
}
.hero__content{ position:relative; z-index:1; }
.hero__content{
  padding-top: 18px;
}
.title{
  margin: 10px 0 0;
  text-align:center;
  color: var(--ink);
  font-family:"Billion Miracles","Fraunces", Georgia, serif;
  font-size: clamp(54px, 10.8vw, 84px);
  line-height: 1.02;
  letter-spacing: .02em;
  font-weight: 400;
  text-shadow: 0 18px 60px rgba(21,16,15,.10);
  white-space: nowrap;
  max-width: 95%;
  margin-left: auto;
  margin-right: auto;
}
.title__word{ display:inline-block; }
.title__word{ font-size: 1.2em; }
.title__amp{
  display:inline-block;
  margin: 0 .16em;
  font-family: "Sparkling","Billion Miracles","Fraunces", Georgia, serif;
  font-weight: 400;
  font-size: .68em;
  letter-spacing: 0;
  opacity: .66;
  transform: translateY(.08em);
}
.title--closing{
  margin: 18px auto 0;
}
.meta{
  margin: 14px auto 0;
  display:flex;
  flex-wrap: wrap;
  justify-content:center;
  gap: 8px;
}
.subtitle{
  text-align:center;
  margin: 14px auto 0;
  max-width: 38ch;
  color: rgba(47,33,31,.76);
  font-size: 14px;
  line-height: 1.85;
}
.rule{
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(47,33,31,.18), transparent);
  margin: 14px auto 0;
  width: min(420px, 100%);
}
.frame{
  position:relative;
  margin: 14px auto 6px;
  width: min(420px, 100%);
  border-radius: 34px;
  border: 1px solid rgba(47,33,31,.12);
  background: linear-gradient(180deg, rgba(255,255,255,.90), rgba(255,255,255,.66));
  box-shadow: 0 34px 120px rgba(21,16,15,.16), 0 10px 28px rgba(21,16,15,.10);
  padding: 10px;
  overflow:hidden;
}
.frame::before{
  content:"";
  position:absolute;
  inset:-2px;
  border-radius: 36px;
  background: linear-gradient(135deg, rgba(242,214,217,.62), rgba(239,227,214,.62), rgba(255,255,255,0));
  opacity:.55;
  pointer-events:none;
}
.mat{
  position:relative;
  border-radius: 28px;
  overflow:hidden;
  aspect-ratio: 4 / 5;
  background: rgba(255,255,255,.5);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.55);
}
.mat img{
  width:100%;
  height:100%;
  object-fit: cover;
  object-position: 50% 18%;
  display:block;
  transform: scale(1.02);
}
.mat::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(900px 520px at 50% 18%, rgba(242,214,217,.14), transparent 60%),
    linear-gradient(180deg, rgba(0,0,0,.05), transparent 35%, rgba(0,0,0,.13));
  pointer-events:none;
  mix-blend-mode: soft-light;
}
.frame__shine{
  position:absolute;
  inset:0;
  pointer-events:none;
  opacity:0;
  background: linear-gradient(120deg, transparent 0%, rgba(255,255,255,.62) 42%, transparent 60%);
  transform: translateX(-120%);
}
.section--tight{ padding: 10px 0; }

/* iOS-style Düğün / Kına switch */
.event-switch-row{
  margin-top: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.event-switch{
  flex: 0 1 auto;
  width: 100%;
  max-width: 280px;
  margin-left: 0;
  border: 0;
  padding: 0;
  background: transparent;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
}
.event-switch:focus-visible{
  outline: 2px solid rgba(165,189,193,.65);
  outline-offset: 4px;
  border-radius: 999px;
}
.event-switch__track{
  position: relative;
  display: block;
  height: 44px;
  border-radius: 999px;
  background: rgba(120,120,128,.14);
  padding: 4px;
  box-shadow: inset 0 1px 2px rgba(0,0,0,.06);
}
.event-switch__thumb{
  position: absolute;
  top: 4px;
  left: 4px;
  width: calc(50% - 8px);
  height: calc(100% - 8px);
  border-radius: 999px;
  background: #fff;
  box-shadow: 0 2px 10px rgba(0,0,0,.10), 0 1px 2px rgba(0,0,0,.06);
  transition: transform 0.38s cubic-bezier(.25, .1, .25, 1);
  z-index: 1;
}
.event-switch[data-state="kina"] .event-switch__thumb{
  transform: translateX(calc(100% + 8px));
}
.event-switch__lbl{
  position: absolute;
  top: 4px;
  z-index: 2;
  width: calc(50% - 4px);
  height: calc(100% - 8px);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  font-weight: 750;
  letter-spacing: .15px;
  pointer-events: none;
  transition: color 0.28s ease, opacity 0.28s ease;
}
.event-switch__lbl--dugun{ left: 4px; }
.event-switch__lbl--kina{ right: 4px; left: auto; }
.event-switch[data-state="dugun"] .event-switch__lbl--dugun{ color: rgba(21,16,15,.92); }
.event-switch[data-state="dugun"] .event-switch__lbl--kina{
  color: rgba(165, 75, 88, 0.88);
  font-weight: 800;
}
.event-switch[data-state="kina"] .event-switch__lbl--dugun{ color: rgba(21,16,15,.38); }
.event-switch[data-state="kina"] .event-switch__lbl--kina{ color: rgba(21,16,15,.92); }
.event-switch[data-state="dugun"] .event-switch__thumb{
  box-shadow: 0 2px 10px rgba(165,189,193,.22), 0 1px 2px rgba(0,0,0,.06);
}
.event-switch[data-state="kina"] .event-switch__thumb{
  box-shadow: 0 2px 10px rgba(215,120,120,.18), 0 1px 2px rgba(0,0,0,.06);
}
@media (max-width: 380px){
  .event-switch{ max-width: none; }
}
.tabpanes{
  margin-top: 12px;
  position: relative;
  width: 100%;
  overflow: hidden;
}
.tabpane{
  width: 100%;
  box-sizing: border-box;
  transition: opacity 0.45s cubic-bezier(.22,1,.36,1);
  opacity: 0;
  pointer-events: none;
  z-index: 0;
  visibility: hidden;
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
}
.tabpanes[data-active="dugun"] .tabpane[data-pane="dugun"],
.tabpanes[data-active="kina"] .tabpane[data-pane="kina"]{
  position: relative;
  opacity: 1;
  pointer-events: auto;
  z-index: 1;
  visibility: visible;
}

.tabpane[data-pane="dugun"],
.tabpane[data-pane="kina"]{
  padding: 14px;
  border-radius: 22px;
}
@media (prefers-reduced-motion: reduce){
  .tabpane{ transition-duration: 0.01ms; }
}
.tabpane[data-pane="dugun"]{
  border: 1px solid rgba(165,189,193,.28);
  background: linear-gradient(180deg, rgba(165,189,193,.14), rgba(255,255,255,.62));
}
.tabpane[data-pane="kina"]{
  border: 1px solid rgba(215,120,120,.26);
  background: linear-gradient(180deg, rgba(242,214,217,.42), rgba(255,255,255,.72));
}
.tabpane .list{ margin-top: 8px; }

.tabpane-inner{
  opacity: 1;
  transform: translateY(0);
}
.tabpane-inner--anim{
  animation: tabPaneInnerIn 0.52s cubic-bezier(.22,1,.36,1) forwards;
}
@keyframes tabPaneInnerIn{
  from{ opacity: 0; transform: translateY(8px); }
  to{ opacity: 1; transform: translateY(0); }
}
@media (prefers-reduced-motion: reduce){
  .tabpane-inner--anim{ animation: none; }
}

.btn--dugun.btn--primary{
  background: linear-gradient(180deg, rgba(165,189,193,.50), rgba(165,189,193,.24));
  border-color: rgba(165,189,193,.38);
  box-shadow: 0 14px 34px rgba(165,189,193,.22);
}
.btn--dugun-outline{
  border-color: rgba(165,189,193,.34);
  background: rgba(255,255,255,.86);
}
.btn--kina.btn--primary{
  background: linear-gradient(180deg, rgba(230,165,165,.48), rgba(242,214,217,.52));
  border-color: rgba(215,120,120,.30);
  box-shadow: 0 14px 34px rgba(215,120,120,.14);
}
.btn--kina-outline{
  border-color: rgba(215,120,120,.32);
  background: rgba(255,255,255,.88);
}

/* Countdown */
#countdown .h2{
  text-align: center;
}
.countdown{
  margin-top: 12px;
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
}
.countbox{
  border-radius: 22px;
  border: 1px solid rgba(47,33,31,.10);
  background: rgba(255,255,255,.70);
  box-shadow: 0 12px 26px rgba(21,16,15,.06);
  padding: 12px 10px;
  text-align:center;
}
.countnum{
  font-family:"Fraunces", Georgia, serif;
  font-size: 26px;
  line-height: 1;
  color: var(--ink);
}
.countlbl{
  margin-top: 6px;
  font-size: 11px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--muted);
}

/* Details list */
.list{ display:grid; gap: 10px; margin-top: 12px; }
.row{
  display:flex;
  gap: 12px;
  align-items:flex-start;
  padding: 14px;
  border-radius: 22px;
  border: 1px solid rgba(47,33,31,.10);
  background: rgba(255,255,255,.70);
  box-shadow: 0 12px 26px rgba(21,16,15,.06);
}
.ico{
  width: 40px;
  height: 40px;
  border-radius: 18px;
  display:grid;
  place-items:center;
  border: 1px solid rgba(47,33,31,.10);
  background: rgba(255,255,255,.70);
  flex: 0 0 auto;
}
.k{ font-size: 11px; letter-spacing: .18em; text-transform: uppercase; color: var(--muted); }
.v{ margin-top: 4px; font-weight: 650; color: var(--ink); line-height: 1.25; }
.v--address{ line-height: 1.35; }

/* Closing */
.closing{ margin:0; font-size:18px; line-height:1.6; color: var(--ink); }
.closing__sign{ margin-top: 10px; font-size: 12px; letter-spacing: .22em; text-transform: uppercase; color: var(--muted); }

/* Sticky */
.sticky{
  position: fixed;
  left:0; right:0; bottom:0;
  padding: 10px 12px calc(14px + env(safe-area-inset-bottom));
  background: linear-gradient(180deg, rgba(247,239,230,0) 0%, rgba(247,239,230,.84) 36%, rgba(247,239,230,.96) 100%);
  backdrop-filter: blur(12px);
  z-index: 20;
}
.sticky--memories{
  padding: 12px 14px calc(18px + env(safe-area-inset-bottom));
  background: linear-gradient(180deg, rgba(247,239,230,0) 0%, rgba(242,214,217,.38) 22%, rgba(247,239,230,.98) 100%);
}
.sticky--memories .sticky__inner--single{
  padding: 14px;
  border-radius: 28px;
  border: 1px solid rgba(140, 95, 105, 0.22);
  background: rgba(255, 252, 250, 0.96);
  box-shadow:
    0 22px 56px rgba(21, 16, 15, 0.12),
    0 0 0 1px rgba(255, 255, 255, 0.6) inset;
}
.sticky__inner{
  max-width: 560px;
  margin: 0 auto;
  display:grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 10px;
  padding: 10px;
  border-radius: 26px;
  border: 1px solid rgba(47,33,31,.10);
  background: rgba(255,255,255,.64);
  box-shadow: 0 18px 60px rgba(21,16,15,.14);
}
.sticky__inner--single{
  grid-template-columns: 1fr;
  padding: 12px;
}
.sticky__btn{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  padding: 12px 10px;
  border-radius: 20px;
  background: rgba(255,255,255,.58);
  border: 1px solid rgba(47,33,31,.10);
  gap: 6px;
  cursor:pointer;
  -webkit-tap-highlight-color: transparent;
  transition: transform .14s var(--ease);
}
.sticky__btn--full{
  flex-direction: row;
  justify-content: center;
  gap: 10px;
  width: 100%;
  padding: 14px 16px;
  border-radius: 22px;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: .02em;
  color: rgba(21,16,15,.92);
  background: linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.72));
  box-shadow: 0 14px 34px rgba(21,16,15,.10);
}
.sticky--memories .sticky__btn--full{
  padding: 16px 18px;
  border-radius: 24px;
  font-size: 15px;
  color: #1f1211;
  background: linear-gradient(
    155deg,
    #fff8f9 0%,
    #fdeef1 38%,
    #f5d9df 100%
  );
  border: 2px solid rgba(150, 72, 88, 0.42);
  box-shadow:
    0 10px 28px rgba(120, 52, 66, 0.22),
    0 4px 14px rgba(21, 16, 15, 0.1),
    inset 0 1px 0 rgba(255, 255, 255, 0.85);
  transition: transform 0.14s var(--ease), box-shadow 0.14s var(--ease);
}
.sticky--memories .sticky__btn--full:hover{
  border-color: rgba(130, 58, 72, 0.55);
  box-shadow:
    0 14px 36px rgba(120, 52, 66, 0.28),
    0 6px 18px rgba(21, 16, 15, 0.12),
    inset 0 1px 0 rgba(255, 255, 255, 0.9);
}
.sticky--memories .sticky__btn--full:focus-visible{
  outline: 3px solid rgba(165, 189, 193, 0.85);
  outline-offset: 3px;
}
.sticky__emojis{
  display: inline-flex;
  align-items: center;
  gap: 4px;
  flex-shrink: 0;
  line-height: 1;
}
.sticky__emoji{
  font-size: 1.45em;
  line-height: 1;
  flex-shrink: 0;
}
.sticky__text{
  text-align: center;
}
.sticky--memories .sticky__text{
  font-size: 15px;
  font-weight: 700;
  letter-spacing: 0.02em;
  color: #2a1418;
  opacity: 1;
  text-shadow: 0 1px 0 rgba(255, 255, 255, 0.65);
}
a.sticky__btn{
  text-decoration: none;
  color: inherit;
}
.sticky__btn:active{ transform: translateY(1px) scale(.99); }
.sticky__btn b{ font-size: 12px; color: rgba(21,16,15,.92); letter-spacing:.2px; }
.sticky__btn:not(.sticky__btn--full) span{ font-size: 12px; opacity:.95; }
.sticky__btn--full .sticky__text{ font-size: inherit; opacity: 1; }

/* Arka plan müziği */
.audio-toggle{
  position: fixed;
  left: max(14px, env(safe-area-inset-left));
  bottom: calc(102px + env(safe-area-inset-bottom));
  z-index: 25;
  width: 44px;
  height: 44px;
  padding: 0;
  border-radius: 50%;
  border: 1px solid rgba(47,33,31,.12);
  background: rgba(255,255,255,.88);
  box-shadow: 0 12px 34px rgba(21,16,15,.12);
  color: var(--cocoa);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  -webkit-tap-highlight-color: transparent;
  transition: transform .14s var(--ease), box-shadow .14s var(--ease);
}
.audio-toggle:hover{
  box-shadow: 0 14px 38px rgba(21,16,15,.16);
}
.audio-toggle:active{ transform: scale(.96); }
.audio-toggle:focus-visible{
  outline: 3px solid rgba(165, 189, 193, 0.75);
  outline-offset: 3px;
}
.audio-toggle--muted{
  color: var(--muted);
  background: rgba(255,255,255,.76);
}
/* İki ayrı SVG: <g hidden> bazı tarayıcılarda çift ikon gösteriyordu — span + display ile tek yüz */
.audio-toggle__face{
  display: flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  line-height: 0;
}
.audio-toggle__face--mute{
  display: none;
}
.audio-toggle--muted .audio-toggle__face--sound{
  display: none;
}
.audio-toggle--muted .audio-toggle__face--mute{
  display: flex;
}
.audio-toggle__svg{
  display: block;
  width: 22px;
  height: 22px;
}

/* Toast */
.toast{
  position: fixed;
  left: 50%;
  transform: translateX(-50%);
  bottom: calc(96px + env(safe-area-inset-bottom));
  z-index: 30;
  padding: 10px 12px;
  border-radius: 999px;
  background: rgba(21,16,15,.86);
  color: rgba(255,255,255,.92);
  font-size: 12px;
  letter-spacing: .2px;
  box-shadow: 0 18px 56px rgba(0,0,0,.24);
  backdrop-filter: blur(12px);
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior: auto; }
}

/* Android o. Ä.: keine aufwendigen Animationen (main.js setzt Klasse) — gleiche Reduktion wie prefers-reduced-motion */
html.no-heavy-motion{
  scroll-behavior: auto;
}
html.no-heavy-motion .tabpane{
  transition-duration: 0.01ms;
}
html.no-heavy-motion .tabpane-inner--anim{
  animation: none;
}
html.no-heavy-motion .bg-shapes{
  display: none;
}
html.no-heavy-motion .event-switch__thumb{
  transition: none;
}
html.no-heavy-motion .event-switch__lbl{
  transition: none;
}

@media (max-width: 420px){
  .title{ font-size: clamp(60px, 12.8vw, 102px); }
  .title__word{ font-size: 1.18em; }
  .title__amp{ font-size: .58em; }
}

/* —— Anılar (/anilar) —— */
.page-anilar main.container.page-anilar__main{
  padding-bottom: calc(28px + env(safe-area-inset-bottom));
}
.hero--anilar{
  padding-bottom: 8px;
}
.hero__content--anilar{
  display: flex;
  flex-direction: column;
  align-items: center;
  padding-top: max(18px, calc(10px + env(safe-area-inset-top)));
}
.hero__content--anilar .anilar-back{
  align-self: flex-start;
  margin-bottom: 14px;
  text-decoration: none;
}
.h2--anilar{
  text-align: center;
  margin-top: 10px;
  margin-bottom: 8px;
  max-width: 22ch;
  margin-left: auto;
  margin-right: auto;
}
.page-anilar .hero .subtitle{
  max-width: 40ch;
}
.mem-form label.field,
.mem-form .field{
  display: block;
  margin-bottom: 16px;
}
.mem-form .field > span:first-child{
  display: block;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 8px;
}
.mem-form input[type="text"],
.mem-form textarea{
  width: 100%;
  padding: 13px 14px;
  border-radius: 18px;
  border: 1px solid rgba(47,33,31,.12);
  font-family: inherit;
  font-size: 15px;
  line-height: 1.45;
  background: rgba(255,255,255,.88);
  color: var(--ink);
  box-shadow: 0 12px 26px rgba(21,16,15,.06);
  -webkit-tap-highlight-color: transparent;
}
.mem-form textarea{
  resize: vertical;
  min-height: 132px;
}
.mem-form .field--upload{
  margin-bottom: 10px;
}
.mem-upload{
  position: relative;
}
.mem-upload__input{
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
.mem-upload__zone{
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 168px;
  padding: 22px 18px;
  border-radius: 24px;
  border: 2px dashed rgba(165, 189, 193, 0.65);
  background:
    linear-gradient(165deg, rgba(255, 255, 255, 0.95), rgba(242, 214, 217, 0.35)),
    radial-gradient(120% 80% at 50% 0%, rgba(215, 167, 174, 0.22), transparent 55%);
  box-shadow:
    0 18px 48px rgba(21, 16, 15, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.75);
  color: var(--cocoa);
  cursor: pointer;
  text-align: center;
  transition:
    border-color 0.2s var(--ease),
    box-shadow 0.2s var(--ease),
    transform 0.2s var(--ease);
  animation: memUploadPulse 4.5s ease-in-out infinite;
}
.mem-upload__zone:hover{
  border-color: rgba(165, 189, 193, 0.95);
  box-shadow:
    0 22px 56px rgba(165, 189, 193, 0.22),
    inset 0 1px 0 rgba(255, 255, 255, 0.85);
  transform: translateY(-2px);
}
.mem-upload__zone--drag{
  border-color: rgba(215, 167, 174, 0.85);
  background:
    linear-gradient(165deg, rgba(255, 255, 255, 0.98), rgba(242, 214, 217, 0.5)),
    radial-gradient(120% 80% at 50% 0%, rgba(215, 167, 174, 0.35), transparent 55%);
  animation: none;
}
.mem-upload__icon{
  display: flex;
  color: rgba(165, 189, 193, 0.95);
  filter: drop-shadow(0 6px 14px rgba(21, 16, 15, 0.08));
}
.mem-upload__title{
  font-family: "Fraunces", Georgia, serif;
  font-size: 17px;
  font-weight: 600;
  letter-spacing: 0.02em;
  color: var(--ink);
}
.mem-upload__sub{
  font-size: 13px;
  color: var(--muted);
  line-height: 1.45;
  max-width: 26ch;
}
.mem-upload__previews{
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(76px, 1fr));
  gap: 10px;
  margin-top: 14px;
}
.mem-preview{
  position: relative;
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid rgba(47, 33, 31, 0.12);
  background: rgba(255, 255, 255, 0.75);
  box-shadow: 0 10px 24px rgba(21, 16, 15, 0.08);
  aspect-ratio: 1;
  animation: memPreviewIn 0.35s var(--ease) both;
}
.mem-preview img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.mem-preview__remove{
  position: absolute;
  top: 4px;
  right: 4px;
  width: 28px;
  height: 28px;
  padding: 0;
  border: 0;
  border-radius: 10px;
  font-size: 18px;
  line-height: 1;
  cursor: pointer;
  color: #fff;
  background: rgba(21, 16, 15, 0.52);
  backdrop-filter: blur(6px);
  display: flex;
  align-items: center;
  justify-content: center;
  -webkit-tap-highlight-color: transparent;
  transition: background 0.15s var(--ease), transform 0.15s var(--ease);
}
.mem-preview__remove:hover{
  background: rgba(181, 77, 82, 0.88);
}
.mem-preview__remove:active{
  transform: scale(0.94);
}
@keyframes memUploadPulse{
  0%,
  100%{
    box-shadow:
      0 18px 48px rgba(21, 16, 15, 0.08),
      inset 0 1px 0 rgba(255, 255, 255, 0.75);
  }
  50%{
    box-shadow:
      0 22px 56px rgba(165, 189, 193, 0.2),
      inset 0 1px 0 rgba(255, 255, 255, 0.85);
  }
}
@keyframes memPreviewIn{
  from{
    opacity: 0;
    transform: scale(0.92) translateY(6px);
  }
  to{
    opacity: 1;
    transform: scale(1) translateY(0);
  }
}
@media (prefers-reduced-motion: reduce){
  .mem-upload__zone{
    animation: none;
  }
  .mem-preview{
    animation: none;
  }
}
.mem-form .hint{
  font-size: 12px;
  color: var(--muted);
  margin: -6px 0 16px;
  line-height: 1.55;
}
.mem-form .msg{
  margin-top: 14px;
  font-size: 14px;
  font-weight: 600;
  text-align: center;
}
.mem-form .msg.ok{ color: #2d6a4f; }
.mem-form .msg.err{ color: #9b2226; }
.mem-form .btn{ margin-top: 2px; }
.mem-form .btn:disabled{
  opacity: .58;
  cursor: wait;
}

/* Language */
.lang-row{
  display: flex;
  gap: 10px;
  justify-content: flex-end;
  margin-bottom: 10px;
}
.lang-row .pill{
  cursor: pointer;
  border: 0;
}
.lang-row .pill[aria-pressed="true"]{
  box-shadow: 0 0 0 2px rgba(165,189,193,.55), var(--shadow2);
}
.lang-pill{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
}
.lang-flag{
  font-size: 1.35em;
  line-height: 1;
  font-family: "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji", sans-serif;
}
.lang-flag--sm{
  font-size: 1.05em;
}
