/* MrDodo — marka yazı tipi (sunucu /font/ altında servis eder) */
@font-face { font-family: "MrDodo"; font-weight: 400; font-display: swap; src: url("/font/MrDodo-Regular.woff2") format("woff2"); }
@font-face { font-family: "MrDodo"; font-weight: 500; font-display: swap; src: url("/font/MrDodo-Medium.woff2") format("woff2"); }
@font-face { font-family: "MrDodo"; font-weight: 700; font-display: swap; src: url("/font/MrDodo-Bold.woff2") format("woff2"); }

/* GÖVDE: Quicksand (OFL) — geometrik, zarif yuvarlak. Değişken, tam Türkçe. */
@font-face { font-family: "Quicksand"; font-weight: 300 700; font-display: swap; src: url("/font/Quicksand-latinext.woff2") format("woff2");
  unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB, U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF; }
@font-face { font-family: "Quicksand"; font-weight: 300 700; font-display: swap; src: url("/font/Quicksand-latin.woff2") format("woff2"); }
/* Nunito (OFL) — alternatif gövde fontu (tek satırla geçilebilir) */
@font-face { font-family: "Nunito"; font-weight: 400 800; font-display: swap; src: url("/font/Nunito-latinext.woff2") format("woff2");
  unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB, U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF; }
@font-face { font-family: "Nunito"; font-weight: 400 800; font-display: swap; src: url("/font/Nunito-latin.woff2") format("woff2"); }

/* BAŞLIK ADAYLARI (OFL) — tek satır değiştirilerek denenebilir */
/* Baloo 2 — kalın, yuvarlak */
@font-face { font-family: "Baloo 2"; font-weight: 400 800; font-display: swap; src: url("/font/Baloo2-latinext.woff2") format("woff2");
  unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB, U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF; }
@font-face { font-family: "Baloo 2"; font-weight: 400 800; font-display: swap; src: url("/font/Baloo2-latin.woff2") format("woff2"); }
/* Lilita One — yuvarlak, kalın display */
@font-face { font-family: "Lilita One"; font-weight: 400; font-display: swap; src: url("/font/LilitaOne-latinext.woff2") format("woff2");
  unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB, U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF; }
@font-face { font-family: "Lilita One"; font-weight: 400; font-display: swap; src: url("/font/LilitaOne-latin.woff2") format("woff2"); }

/* Luckiest Guy (Apache 2.0) — yerelde vendor'landı. Tüm-büyük-harf display font.
   Eksik Türkçe karakterler için fallback (font stack). */
@font-face { font-family: "Luckiest Guy"; font-weight: 400; font-display: swap; src: url("/font/LuckiestGuy-latinext.woff2") format("woff2");
  unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB, U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF; }
@font-face { font-family: "Luckiest Guy"; font-weight: 400; font-display: swap; src: url("/font/LuckiestGuy-latin.woff2") format("woff2"); }

:root {
  --navy: #1f3b8f; --navy-deep: #142a6b; --blue: #3f6fe0;
  --sky: #dcebfb; --mint: #36c9b8; --mint-deep: #1fa896;
  --lilac: #b79ce8; --pink: #f5a6c8; --ink: #16245c;
  --font: "Quicksand", "Trebuchet MS", system-ui, sans-serif;       /* gövde metni */
  --display: "Luckiest Guy", "Quicksand", "Trebuchet MS", system-ui, sans-serif; /* ana başlık, logo, menü, buton */
  --heading: "Quicksand", "Trebuchet MS", system-ui, sans-serif;   /* gövde içi başlıklar (bölüm/kart) — kalın */
}
* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--font); color: var(--ink); min-height: 100vh;
  background: radial-gradient(130% 90% at 50% -10%, #fff 0%, var(--sky) 45%, #cfe0f7 100%) fixed;
}
a { color: inherit; text-decoration: none; }
.hidden { display: none !important; }
b { color: var(--mint-deep); }

/* Ana başlık + logo + menü + buton → Luckiest Guy (tümü BÜYÜK; tr: i→İ, ı→I) */
.brand, .hero__title, .btn, .hero__age, .nav a,
.offcanvas__nav a, .offcanvas__account a { font-family: var(--display); letter-spacing: .5px; text-transform: uppercase; }
/* Gövde içi başlıklar (bölüm/kart/sayfa başlıkları) → Lilita One */
.section__title, .subhead, .product__intro h1, .product__brand, .story__title,
.story-card__title, .feature h3, .gift__name, .levelcard__lvl, .stat__val,
.go-title, .acard__val, .oc-user__name { font-family: var(--heading); font-weight: 700; letter-spacing: 0; }

/* ikonlar */
.ic { width: 1em; height: 1em; display: inline-block; vertical-align: -0.14em; }
i[data-icon] { display: inline-flex; }

/* ---------- üst bar ---------- */
.topbar { position: sticky; top: 0; z-index: 50; display: flex; align-items: center; gap: 18px; padding: 12px clamp(16px,4vw,40px); background: rgba(255,255,255,.85); backdrop-filter: blur(12px); border-bottom: 2px solid rgba(31,59,143,.08); }
.brand { font-size: 26px; font-weight: 700; color: var(--navy); }
.brand__kids { margin-left: 6px; background: linear-gradient(90deg,#36c9b8,#3f6fe0 35%,#b79ce8 70%,#f5a6c8); -webkit-background-clip: text; background-clip: text; color: transparent; }
.nav { display: flex; gap: 16px; margin-left: 10px; font-size: 16px; font-weight: 500; }
.nav a { color: var(--navy); opacity: .72; padding: 4px 2px; border-bottom: 2px solid transparent; }
.nav a:hover { opacity: 1; color: var(--mint-deep); }
.nav a.is-active { opacity: 1; color: var(--navy); border-bottom-color: var(--mint); }
.topbar__right { margin-left: auto; display: flex; align-items: center; gap: 12px; }

.btn { font-family: var(--display); font-weight: 700; font-size: 16px; border: none; cursor: pointer; border-radius: 999px; padding: 10px 22px; color: #fff; display: inline-flex; align-items: center; gap: 7px; transition: transform .08s, box-shadow .08s, background .15s; }
.btn { line-height: 1; }
/* Luckiest Guy glifleri satır kutusunun ~0.146em üstünde oturur; ikonu o seviyeye
   çek (ikon font-size'ı 1.15em olduğu için 0.146/1.15 ≈ 0.127em). */
.btn .ic, .offcanvas__nav a .ic, .offcanvas__account a .ic { font-size: 1.15em; transform: translateY(-0.127em); }
.btn--play { background: linear-gradient(180deg,#41ddca,var(--mint)); box-shadow: 0 5px 0 var(--mint-deep); }
.btn--play:active { transform: translateY(4px); box-shadow: 0 1px 0 var(--mint-deep); }
.btn--ghost { background: rgba(31,59,143,.08); color: var(--navy); border: 2px solid rgba(31,59,143,.18); }
.btn--ghost:hover { background: rgba(31,59,143,.14); }
.btn--lg { font-size: 19px; padding: 15px 30px; }
.btn--block { width: 100%; justify-content: center; margin-top: 6px; }

.userchip { display: flex; align-items: center; gap: 8px; background: #fff; color: var(--navy); border-radius: 999px; padding: 5px 8px 5px 6px; font-weight: 700; box-shadow: 0 3px 10px rgba(31,59,143,.12); }
.userchip__lvl { background: var(--lilac); color: #fff; border-radius: 999px; padding: 3px 10px; font-size: 13px; }
.userchip__pts { background: var(--mint); color: #fff; border-radius: 999px; padding: 3px 10px; font-size: 13px; }
.userchip__pts::after { content: " p"; opacity: .7; }
.userchip__id { display: flex; flex-direction: column; line-height: 1.05; }
.userchip__name { font-size: 15px; }
.userchip__sub { font-size: 11px; color: var(--mint-deep); font-weight: 700; display: inline-flex; align-items: center; gap: 3px; }
.userchip__caret { font-size: 12px; transition: transform .15s; }

/* kullanıcı menüsü (hover/focus ile açılır) */
.userwrap { position: relative; cursor: pointer; outline: none; }
.userwrap .userchip { display: flex; }
.usermenu {
  position: absolute; top: calc(100% + 8px); right: 0; min-width: 200px;
  background: #fff; border-radius: 16px; padding: 8px;
  box-shadow: 0 14px 34px rgba(20, 33, 90, .22); border: 1px solid rgba(31,59,143,.08);
  display: flex; flex-direction: column; gap: 2px; z-index: 60;
  opacity: 0; visibility: hidden; transform: translateY(-6px); transition: opacity .15s, transform .15s, visibility .15s;
}
.userwrap:hover .usermenu, .userwrap:focus-within .usermenu { opacity: 1; visibility: visible; transform: translateY(0); }
.userwrap:hover .userchip__caret, .userwrap:focus-within .userchip__caret { transform: rotate(180deg); }
.usermenu a { display: flex; align-items: center; gap: 10px; padding: 10px 12px; border-radius: 10px; color: var(--navy); font-weight: 700; font-size: 15px; }
.usermenu a:hover { background: #eef2ff; }
.usermenu a .ic { color: var(--mint); font-size: 1.15em; }
.usermenu__out { display: flex; align-items: center; gap: 10px; width: 100%; padding: 10px 12px; margin-top: 4px; border: 0; border-top: 1px solid #eef2ff; border-radius: 10px; background: none; color: #d6336c; font-family: var(--font); font-weight: 700; font-size: 15px; cursor: pointer; text-align: left; }
.usermenu__out:hover { background: #fff0f3; }
.usermenu__out .ic { color: #d6336c; font-size: 1.15em; }
.userchip__out { border: none; background: #eef2ff; color: var(--navy); width: 28px; height: 28px; border-radius: 50%; cursor: pointer; font-size: 15px; display: grid; place-items: center; }

/* ---------- hamburger + offcanvas (mobil) ---------- */
.hamburger { display: none; flex-direction: column; justify-content: center; gap: 5px; width: 46px; height: 46px; border: none; background: rgba(31,59,143,.08); border-radius: 12px; cursor: pointer; padding: 0 12px; }
.hamburger span { display: block; height: 3px; border-radius: 3px; background: var(--navy); transition: transform .25s, opacity .2s; }
.hamburger[aria-expanded="true"] span:nth-child(1) { transform: translateY(8px) rotate(45deg); }
.hamburger[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.hamburger[aria-expanded="true"] span:nth-child(3) { transform: translateY(-8px) rotate(-45deg); }

.offcanvas { position: fixed; inset: 0; z-index: 90; visibility: hidden; }
.offcanvas.open { visibility: visible; }
.offcanvas__backdrop { position: absolute; inset: 0; background: rgba(20,33,90,.5); opacity: 0; transition: opacity .25s; }
.offcanvas.open .offcanvas__backdrop { opacity: 1; }
.offcanvas__panel { position: absolute; top: 0; right: 0; height: 100%; width: min(320px, 86vw); background: #fff; box-shadow: -12px 0 40px rgba(20,33,90,.25); padding: 18px; display: flex; flex-direction: column; gap: 6px; transform: translateX(100%); transition: transform .28s ease; overflow-y: auto; }
.offcanvas.open .offcanvas__panel { transform: translateX(0); }
.offcanvas__head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 8px; }
.offcanvas__head .brand { font-size: 22px; }
.offcanvas__close { border: none; background: #eef2ff; width: 38px; height: 38px; border-radius: 50%; font-size: 17px; color: var(--navy); cursor: pointer; }
.oc-user { display: flex; flex-direction: column; gap: 2px; background: linear-gradient(135deg,var(--navy),var(--blue)); color: #fff; border-radius: 16px; padding: 14px 16px; margin-bottom: 8px; }
.oc-user__lvl { font-size: 12px; background: rgba(255,255,255,.2); align-self: flex-start; padding: 2px 10px; border-radius: 999px; }
.oc-user__name { font-size: 18px; font-weight: 700; margin-top: 4px; }
.oc-user__pts { font-size: 14px; color: #c8f5ee; font-weight: 700; }
.offcanvas__nav, .offcanvas__account { display: flex; flex-direction: column; }
.offcanvas__nav a, .offcanvas__account a { display: flex; align-items: center; gap: 12px; padding: 13px 12px; border-radius: 12px; color: var(--navy); font-weight: 700; font-size: 16px; }
.offcanvas__nav a:hover, .offcanvas__account a:hover { background: #eef2ff; }
.offcanvas__nav a .ic, .offcanvas__account a .ic { color: var(--mint); font-size: 1.2em; }
.offcanvas__account { margin-top: 8px; padding-top: 8px; border-top: 1px solid #eef2fb; }
.offcanvas__label { font-size: 12px; text-transform: uppercase; letter-spacing: .5px; color: #8a93bb; padding: 4px 12px; font-weight: 700; }
.offcanvas__cta { margin-top: auto; display: flex; flex-direction: column; gap: 10px; padding-top: 16px; }

/* ---------- görünümler / bölümler ---------- */
.view { animation: fade .25s ease; }
@keyframes fade { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: none; } }
.section { max-width: 960px; margin: 36px auto; padding: 0 20px; }
.section--narrow { max-width: 620px; }
.section__title { font-size: 30px; font-weight: 700; color: var(--navy); display: flex; align-items: center; gap: 10px; }
.section__title .ic { font-size: 1.05em; color: var(--mint); }
.section__sub { color: #5a6699; margin: 6px 0 22px; }
.acchead { display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap; }
.subhead { color: var(--navy); font-size: 20px; margin: 30px 0 4px; display: flex; align-items: center; gap: 8px; }
.subhead .ic { color: var(--mint); }
.backlink { display: inline-flex; align-items: center; gap: 6px; color: var(--navy); opacity: .7; font-weight: 700; margin-bottom: 10px; }
.backlink .ic { transform: scaleX(-1); }
.backlink:hover { opacity: 1; }

/* ---------- hero ---------- */
.hero { position: relative; padding: clamp(36px,8vw,40px) 20px 40px; text-align: center; overflow: hidden; }
.hero__inner { position: relative; z-index: 2; max-width: 720px; margin: 0 auto; }
.hero__titlewrap { position: relative; display: inline-block; padding-top: 265px; }
.hero__mascot { position: absolute; left: 50%; top: 0; transform: translateX(-50%); height: 300px; width: auto; max-width: 92vw; z-index: -1; pointer-events: none; user-select: none; filter: drop-shadow(0 14px 26px rgba(31,59,143,.18)); }
.hero__title { font-size: clamp(44px,10vw,86px); line-height: .92; font-weight: 700; color: var(--navy);
  -webkit-text-stroke: clamp(4px, 0.9vw, 7px) #fff; text-stroke: clamp(4px, 0.9vw, 7px) #fff; paint-order: stroke fill;
  text-shadow: 0 6px 0 rgba(0,0,0,.2); }
.hero__title span { color: var(--mint-deep); }
.hero__tag { margin: 22px auto 26px; max-width: 34ch; font-size: clamp(16px,4vw,20px); font-weight: 500; line-height: 1.5; color: #36406e; }
.hero__cta { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }
.hero__hint { margin-top: 18px; font-size: 14px; color: #5a6699; }
.hero__bubbles { position: absolute; inset: 0; z-index: 1; pointer-events: none; overflow: hidden; }
.bubble { position: absolute; border-radius: 50%; bottom: -60px; opacity: .5; animation: rise linear infinite; }
@keyframes rise { to { transform: translateY(-120vh) translateX(var(--dx,0)); opacity: 0; } }

/* ---------- oyunlaştırma şeridi ---------- */
.features { max-width: 1000px; margin: 10px auto 30px; padding: 0 20px; display: grid; grid-template-columns: repeat(5,1fr); gap: 14px; }
.feature { background: #fff; border-radius: 22px; padding: 22px 14px; text-align: center; box-shadow: 0 8px 22px rgba(31,59,143,.08); }
.feature__ic { font-size: 40px; color: var(--mint); }
.feature h3 { font-size: 16px; color: var(--navy); margin: 10px 0 4px; }
.feature p { font-size: 13px; color: #6b75a0; line-height: 1.35; }

/* ---------- değer döngüsü ---------- */
.loop__steps { list-style: none; display: flex; flex-wrap: wrap; gap: 10px; }
.loop__steps li { flex: 1 1 130px; background: #fff; border-radius: 18px; padding: 16px; text-align: center; font-weight: 700; color: var(--navy); box-shadow: 0 6px 16px rgba(31,59,143,.07); }
.loop__steps li .ic { display: block; margin: 0 auto 8px; font-size: 34px; color: var(--mint); }

/* ---------- güven ---------- */
.trust { max-width: 960px; margin: 30px auto; padding: 0 20px; }
.trust__box { background: #fff; border-radius: 24px; padding: 26px; box-shadow: 0 8px 22px rgba(31,59,143,.08); border-left: 6px solid var(--mint); }
.trust__box h3 { color: var(--navy); font-size: 20px; margin-bottom: 8px; display: flex; align-items: center; gap: 8px; }
.trust__box h3 .ic { color: var(--mint); }
.trust__box p { color: #4a5588; line-height: 1.55; }

/* ---------- seviye kartı + stats ---------- */
.levelcard { background: linear-gradient(135deg,var(--navy),var(--blue)); color: #fff; border-radius: 24px; padding: 22px 24px; box-shadow: 0 12px 30px rgba(31,59,143,.25); margin-bottom: 14px; }
.levelcard__top { display: flex; justify-content: space-between; align-items: baseline; }
.levelcard__lvl { font-size: 26px; font-weight: 700; }
.levelcard__pts { font-size: 16px; opacity: .9; } .levelcard__pts b { color: #c8f5ee; }
.progress { height: 14px; background: rgba(255,255,255,.22); border-radius: 999px; margin: 14px 0 8px; overflow: hidden; }
.progress__bar { height: 100%; width: 0%; background: linear-gradient(90deg,var(--mint),#7be3d6); border-radius: 999px; transition: width .5s ease; }
.levelcard__next { font-size: 13px; opacity: .85; }
.ministats { display: grid; grid-template-columns: repeat(3,1fr); gap: 14px; }
.stat { background: #fff; border-radius: 20px; padding: 18px; text-align: center; box-shadow: 0 8px 22px rgba(31,59,143,.08); }
.stat__ic { font-size: 26px; color: var(--lilac); }
.stat__val { font-size: 36px; font-weight: 700; color: var(--mint-deep); line-height: 1; margin-top: 4px; }
.stat__lbl { font-size: 12px; letter-spacing: 1px; text-transform: uppercase; color: #8a93bb; margin-top: 6px; }

/* ---------- ödüller ---------- */
.rewardbar { display: inline-flex; align-items: center; gap: 8px; background: #fff; border-radius: 999px; padding: 8px 16px; margin-bottom: 18px; box-shadow: 0 6px 16px rgba(31,59,143,.08); font-weight: 700; color: var(--navy); }
.rewardbar .ic { color: var(--mint); font-size: 1.2em; }
.rewardbar .muted { color: #8a93bb; font-weight: 500; }
.gift-grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(180px,1fr)); gap: 16px; }
.gift { background: #fff; border-radius: 22px; padding: 20px 16px; text-align: center; box-shadow: 0 8px 0 rgba(31,59,143,.08); display: flex; flex-direction: column; align-items: center; gap: 6px; }
.gift__ic { font-size: 46px; color: var(--mint); }
.gift__kind { font-size: 11px; letter-spacing: .5px; text-transform: uppercase; color: var(--lilac); font-weight: 700; }
.gift__name { font-weight: 700; font-size: 16px; color: var(--navy); min-height: 2.4em; display: flex; align-items: center; }
.gift__cost { font-size: 15px; color: var(--mint-deep); font-weight: 700; }
.gift__btn { margin-top: 6px; border: none; border-radius: 999px; padding: 9px 22px; font-family: var(--font); font-weight: 700; cursor: pointer; background: var(--mint); color: #fff; transition: transform .08s, background .15s; }
.gift__btn:hover { background: var(--mint-deep); }
.gift__btn:active { transform: scale(.96); }
.gift__btn:disabled { background: #d2d8ea; color: #8a93bb; cursor: not-allowed; }

/* ---------- hediye alma ---------- */
.redeem__summary { display: flex; align-items: center; gap: 16px; background: #fff; border-radius: 20px; padding: 18px 20px; box-shadow: 0 8px 22px rgba(31,59,143,.08); margin-bottom: 18px; }
.redeem__summary .ic { font-size: 50px; color: var(--mint); }
.redeem__info h3 { color: var(--navy); font-size: 19px; }
.redeem__info .kind { color: var(--lilac); font-size: 12px; text-transform: uppercase; font-weight: 700; }
.redeem__info .cost { color: var(--mint-deep); font-weight: 700; margin-top: 2px; }

/* ---------- formlar ---------- */
.form { display: flex; flex-direction: column; gap: 14px; }
.form--grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; background: #fff; padding: 22px; border-radius: 22px; box-shadow: 0 8px 22px rgba(31,59,143,.08); }
.form--grid .form__wide, .form--grid .form__note, .form--grid .form__err, .form--grid button[type=submit] { grid-column: 1 / -1; }
.form label { display: flex; flex-direction: column; gap: 6px; font-weight: 700; font-size: 14px; color: var(--navy); }
.form input, .form textarea { font-family: var(--font); font-size: 16px; padding: 12px 14px; border: 2px solid #dbe2f5; border-radius: 14px; outline: none; resize: vertical; }
.form input:focus, .form textarea:focus { border-color: var(--mint); }
.form__note { color: #5a6699; font-size: 14px; }
.form__err { color: #e24a6a; font-weight: 700; font-size: 14px; }
.form__err:not(.hidden) { display: block; }
.form__demo { margin-top: 16px; text-align: center; font-size: 13px; color: #8a93bb; }

/* ---------- lider tablosu ---------- */
.board-head, .board li { display: grid; grid-template-columns: 48px 1fr 70px 80px 90px; align-items: center; gap: 10px; }
.board-head { padding: 6px 18px; color: #8a93bb; font-size: 12px; text-transform: uppercase; letter-spacing: .5px; }
.board { list-style: none; display: flex; flex-direction: column; gap: 8px; }
.board li { background: #fff; border: 2px solid transparent; border-radius: 16px; padding: 12px 18px; box-shadow: 0 6px 16px rgba(31,59,143,.06); }
.board li .rk { font-size: 18px; font-weight: 700; color: var(--lilac); display: inline-flex; align-items: center; }
.board li .rk .ic { font-size: 22px; }
.board li .nm { font-weight: 700; font-size: 17px; color: var(--navy); }
.board li .lv { color: var(--lilac); font-weight: 700; }
.board li .sc { font-weight: 700; color: var(--mint-deep); }
.board li .pt { color: #8a93bb; font-weight: 700; }
.board li.me { border-color: var(--mint); background: #f0fdfb; }
.board__me { margin-top: 14px; color: var(--navy); font-weight: 700; }

/* ---------- siparişler ---------- */
.orders { display: flex; flex-direction: column; gap: 12px; margin-top: 8px; }
.order { display: grid; grid-template-columns: 48px 1fr auto; align-items: center; gap: 14px; background: #fff; border-radius: 18px; padding: 14px 18px; box-shadow: 0 6px 16px rgba(31,59,143,.06); }
.order__ic { font-size: 30px; color: var(--mint); }
.order__name { font-weight: 700; color: var(--navy); }
.order__meta { font-size: 13px; color: #8a93bb; }
.order__status { display: inline-flex; align-items: center; gap: 6px; background: #eafaf7; color: var(--mint-deep); font-weight: 700; font-size: 13px; padding: 6px 12px; border-radius: 999px; }
.order__status .ic { font-size: 1.1em; }
.orders__empty { color: #8a93bb; background: #fff; border-radius: 16px; padding: 18px; text-align: center; }

/* ---------- üst bar qr butonu ---------- */
.btn--qr { padding: 9px 16px; }

/* ---------- ana sayfa önizleme başlığı ---------- */
.prevhead { display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap; }
.prevhead .btn { padding: 8px 16px; font-size: 14px; }

/* ---------- ürün sayfası ---------- */
.product__hero { max-width: 960px; margin: 30px auto 10px; padding: 0 20px; display: grid; grid-template-columns: 320px 1fr; gap: 26px; align-items: center; }
.product__art { position: relative; background: linear-gradient(160deg,#eaf3ff,#d4e6fb); border-radius: 28px; padding: 18px; text-align: center; box-shadow: 0 12px 30px rgba(31,59,143,.12); }
.product__img { display: block; width: 100%; height: auto; border-radius: 16px; }
.product__brand { color: var(--navy); font-weight: 700; font-size: 20px; }
.product__brand b { background: linear-gradient(90deg,#36c9b8,#3f6fe0 40%,#b79ce8 70%,#f5a6c8); -webkit-background-clip: text; background-clip: text; color: transparent; }
.product__intro h1 { font-size: clamp(34px,6vw,52px); color: var(--navy); line-height: .95; margin: 6px 0 14px; }
.product__intro p { color: #44508a; line-height: 1.55; font-size: 17px; max-width: 46ch; }
.product__cta { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 18px; }

.badges { display: grid; grid-template-columns: repeat(4,1fr); gap: 14px; }
.badge { background: #fff; border-radius: 20px; padding: 20px 16px; text-align: center; box-shadow: 0 8px 22px rgba(31,59,143,.08); }
.badge .ic { font-size: 36px; color: var(--mint); }
.badge h4 { color: var(--navy); margin: 8px 0 4px; font-size: 16px; }
.badge p { color: #6b75a0; font-size: 13px; line-height: 1.35; }

.spec { list-style: none; background: #fff; border-radius: 20px; padding: 8px 20px; box-shadow: 0 8px 22px rgba(31,59,143,.08); }
.spec li { display: flex; justify-content: space-between; gap: 16px; padding: 14px 0; border-bottom: 1px solid #eef2fb; }
.spec li:last-child { border-bottom: none; }
.spec li span { color: #8a93bb; } .spec li b { color: var(--navy); text-align: right; }
.product__note { color: #8a93bb; font-size: 13px; margin-top: 12px; }

/* ---------- qr kod sayfası ---------- */
.qrcard { background: #fff; border-radius: 24px; padding: 26px; text-align: center; box-shadow: 0 12px 30px rgba(31,59,143,.1); }
.qrcard__ic { font-size: 70px; color: var(--mint); }
.qrcard .form { margin-top: 12px; text-align: left; }
.qrcard__hint { margin-top: 12px; font-weight: 700; }
.qrcard__hint.good { color: var(--mint-deep); } .qrcard__hint.bad { color: #d8456a; }
.qrcard__demo { margin-top: 16px; color: #8a93bb; font-size: 13px; text-align: center; line-height: 1.6; }

/* ---------- KVKK onay kutusu ---------- */
.consent { flex-direction: row !important; align-items: flex-start; gap: 10px; background: #f3f7ff; border-radius: 14px; padding: 12px 14px; font-weight: 500 !important; font-size: 13px !important; color: #44508a !important; line-height: 1.4; }
.consent input { width: 20px; height: 20px; margin-top: 2px; accent-color: var(--mint); flex: none; }

/* ---------- fırçalama timer ---------- */
.brush { background: #fff; border-radius: 26px; padding: 24px; box-shadow: 0 12px 30px rgba(31,59,143,.1); text-align: center; }
.brush__slots { display: flex; gap: 10px; justify-content: center; margin-bottom: 18px; }
.slotbtn { display: inline-flex; align-items: center; gap: 6px; border: 2px solid #dbe2f5; background: #fff; color: var(--navy); font-family: var(--font); font-weight: 700; font-size: 15px; padding: 8px 18px; border-radius: 999px; cursor: pointer; }
.slotbtn.is-active { background: var(--mint); border-color: var(--mint); color: #fff; }
.slotbtn:disabled { opacity: .45; cursor: not-allowed; }
.timer { position: relative; width: 240px; height: 240px; margin: 6px auto 18px; }
.timer__ring { width: 100%; height: 100%; transform: rotate(-90deg); }
.timer__track { fill: none; stroke: #e7edfb; stroke-width: 9; }
.timer__bar { fill: none; stroke: var(--mint); stroke-width: 9; stroke-linecap: round; stroke-dasharray: 339.292; stroke-dashoffset: 0; transition: stroke-dashoffset 1s linear; }
.timer__face { position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; }
.timer__time { font-size: 56px; font-weight: 700; color: var(--navy); line-height: 1; font-variant-numeric: tabular-nums; }
.timer__hint { color: #8a93bb; margin-top: 6px; font-weight: 700; }
.brush__note { margin-top: 12px; font-weight: 700; color: var(--mint-deep); min-height: 1.2em; }
.brush__stats { display: flex; justify-content: space-around; margin-top: 20px; padding-top: 18px; border-top: 1px solid #eef2fb; }
.bstat { text-align: center; } .bstat .ic { font-size: 24px; color: var(--lilac); }
.bstat__val { font-size: 26px; font-weight: 700; color: var(--mint-deep); }
.bstat__lbl { font-size: 12px; color: #8a93bb; }
.dot { display: inline-block; width: 22px; height: 22px; border-radius: 50%; background: #e0e6f5; }
.dot.on { background: var(--mint); }

/* ---------- ebeveyn paneli ---------- */
.week { display: grid; grid-template-columns: repeat(7,1fr); gap: 8px; }
.day { background: #fff; border-radius: 16px; padding: 12px 6px; text-align: center; box-shadow: 0 6px 16px rgba(31,59,143,.06); }
.day__d { font-size: 12px; color: #8a93bb; margin-bottom: 8px; }
.day__slots { display: flex; flex-direction: column; gap: 5px; align-items: center; }
.day__slot { width: 20px; height: 20px; border-radius: 50%; background: #e7edfb; display: grid; place-items: center; color: #fff; font-size: 11px; }
.day__slot.on { background: var(--mint); }
.notify { display: flex; flex-direction: column; gap: 12px; background: #fff; border-radius: 18px; padding: 18px 20px; box-shadow: 0 8px 22px rgba(31,59,143,.08); }
.switch { display: flex; align-items: center; gap: 12px; font-weight: 700; color: var(--navy); cursor: pointer; }
.switch input { width: 20px; height: 20px; accent-color: var(--mint); }

/* ---------- admin ---------- */
.admincards { display: grid; grid-template-columns: repeat(auto-fit,minmax(130px,1fr)); gap: 12px; }
.acard { background: linear-gradient(135deg,var(--navy),var(--blue)); color: #fff; border-radius: 18px; padding: 16px; text-align: center; }
.acard__val { font-size: 30px; font-weight: 700; color: #c8f5ee; }
.acard__lbl { font-size: 12px; opacity: .85; text-transform: uppercase; letter-spacing: .5px; }
.qrgen__out { background: #eafaf7; color: var(--mint-deep); border-radius: 14px; padding: 12px 16px; font-weight: 700; word-break: break-all; }
.admin-orders, .admin-users { display: flex; flex-direction: column; gap: 8px; }
.arow { display: grid; grid-template-columns: 1fr auto; gap: 10px; align-items: center; background: #fff; border-radius: 14px; padding: 12px 16px; box-shadow: 0 6px 16px rgba(31,59,143,.06); }
.arow__main { color: var(--navy); font-weight: 700; }
.arow__sub { color: #8a93bb; font-size: 13px; font-weight: 500; }
.arow select { font-family: var(--font); border: 2px solid #dbe2f5; border-radius: 10px; padding: 6px 10px; color: var(--navy); font-weight: 700; }

/* ---------- kayıt: çocuk satırı ---------- */
.childrow { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.childrow label { font-size: 14px; }

/* ---------- masallar ---------- */
.story-grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(260px,1fr)); gap: 16px; }
.story-card { background: #fff; border-radius: 22px; padding: 0; overflow: hidden; box-shadow: 0 8px 22px rgba(31,59,143,.08); cursor: pointer; transition: transform .1s; display: flex; flex-direction: column; text-align: left; }
.story-card:hover { transform: translateY(-3px); }
.story-card__cover { display: block; background: #eaf3ff; aspect-ratio: 1 / 1; }
.story-card__cover img { display: block; width: 100%; height: 100%; object-fit: cover; }
.story-card__body { display: flex; flex-direction: column; gap: 8px; padding: 18px 20px 20px; flex: 1; }
.story-card__ic { font-size: 40px; color: var(--lilac); padding: 22px 22px 0; }
.story-card__title { font-size: 19px; font-weight: 700; color: var(--navy); }
.story-card__sum { color: #6b75a0; font-size: 14px; line-height: 1.4; }
.story-card__meta { margin-top: auto; display: flex; align-items: center; gap: 6px; color: var(--mint-deep); font-weight: 700; font-size: 13px; }

.story { background: #fff; border-radius: 24px; padding: 30px clamp(20px,5vw,40px); box-shadow: 0 12px 30px rgba(31,59,143,.1); }
.story__cover { display: block; margin: 0 auto 22px; max-width: 420px; }
.story__cover img { display: block; width: 100%; height: auto; border-radius: 20px; box-shadow: 0 12px 28px rgba(31,59,143,.18); }
.story__ic { font-size: 54px; color: var(--lilac); }
.story__title { font-size: clamp(26px,5vw,36px); color: var(--navy); line-height: 1.05; margin: 8px 0 6px; }
.story__meta { color: #8a93bb; font-weight: 700; font-size: 14px; margin-bottom: 18px; }
.story p { color: #34406e; font-size: 18px; line-height: 1.7; margin-bottom: 16px; }
.story p:first-letter { }
.story__end { text-align: center; color: var(--lilac); font-weight: 700; margin-top: 6px; }

.footer { text-align: center; padding: 26px 20px 46px; color: #8a93bb; font-size: 14px; }

/* ---------- modal ---------- */
.modal { position: fixed; inset: 0; z-index: 100; display: grid; place-items: center; padding: 20px; background: rgba(20,33,90,.55); backdrop-filter: blur(6px); }
.modal__box { position: relative; width: min(380px,100%); background: #fff; color: var(--ink); border-radius: 28px; padding: 30px 26px; box-shadow: 0 30px 80px rgba(20,33,90,.45); }
.modal__mascot { font-size: 52px; text-align: center; margin-bottom: 6px; color: var(--mint); }
.modal__close { position: absolute; top: 14px; right: 14px; border: none; background: #eef2ff; width: 34px; height: 34px; border-radius: 50%; cursor: pointer; font-size: 16px; color: var(--navy); }
.tabs { display: flex; gap: 8px; margin-bottom: 18px; background: #eef2ff; border-radius: 999px; padding: 5px; }
.tab { flex: 1; border: none; background: transparent; padding: 10px; border-radius: 999px; font-family: var(--font); font-weight: 700; font-size: 15px; color: var(--navy); cursor: pointer; }
.tab.is-active { background: var(--mint); color: #fff; }

/* toast */
.toast { position: fixed; left: 50%; bottom: 28px; transform: translateX(-50%); z-index: 200; background: var(--navy); color: #fff; padding: 14px 24px; border-radius: 14px; font-weight: 700; box-shadow: 0 12px 30px rgba(20,33,90,.4); animation: toastIn .3s ease; max-width: 90vw; text-align: center; }
.toast--good { background: var(--mint-deep); } .toast--bad { background: #d8456a; }
@keyframes toastIn { from { opacity: 0; transform: translate(-50%,14px); } to { opacity: 1; transform: translate(-50%,0); } }

@media (max-width: 768px) {
  /* masaüstü nav + sağ butonlar gizlenir, hamburger görünür */
  .nav, .topbar__right { display: none; }
  .hamburger { display: flex; }
  .topbar { justify-content: space-between; }
}
@media (max-width: 720px) {
  .features { grid-template-columns: repeat(2,1fr); }
  .badges { grid-template-columns: repeat(2,1fr); }
  .product__hero { grid-template-columns: 1fr; }
}
@media (max-width: 560px) {
  .ministats { grid-template-columns: 1fr; }
  .form--grid { grid-template-columns: 1fr; }
  .form__spacer { display: none; }
  .board-head, .board li { grid-template-columns: 38px 1fr 56px 70px; }
  .board-head span:nth-child(4), .board li .sc { display: none; }
}
