/* ==========================================================
   NarxBot — Tüm stil kuralları
   ========================================================== */

:root{
  --bg:#f2f2f7;
  --surface:#fff;
  --surface-2:#f8faf9;
  --border:#ececec;
  --border-2:#e5e5e5;
  --text:#1a1a1a;
  --text-2:#555;
  --text-3:#767676;
  --text-4:#bbb;
  --brand:#1D9E75;
  --brand-d:#168062;
  --brand-soft:#f0fdf4;
  --red:#E24B4A;
  --yellow:#F59E0B;
  --blue:#0088cc;
  --green:#7BC043;
}
@media (prefers-color-scheme: dark){
  :root{
    --bg:#0b0b0f;
    --surface:#15151b;
    --surface-2:#1e1e26;
    --border:#24242c;
    --border-2:#2a2a33;
    --text:#e7e7ea;
    --text-2:#a0a0ac;
    --text-3:#8a8a95;
    --text-4:#555;
    --brand-soft:#1a2a22;
  }
}

/* ==========================================================
   BASE / RESET
   ========================================================== */
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:-apple-system,system-ui,sans-serif;background:var(--bg);color:var(--text)}
h1{font:inherit;margin:0}
:focus-visible{outline:2px solid var(--brand);outline-offset:2px;border-radius:4px}
@media (prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:0.01ms !important;animation-iteration-count:1 !important;transition-duration:0.01ms !important}}

/* ==========================================================
   ÜST BAR
   ========================================================== */
.top{position:fixed;top:0;left:0;right:0;z-index:200;background:var(--surface);border-bottom:1px solid var(--border-2);height:54px;display:flex;align-items:center;padding:0 14px;gap:10px}
.logo{width:34px;height:34px;border-radius:9px;background:var(--brand);display:flex;align-items:center;justify-content:center;color:#fff;font-size:16px;font-weight:800}
.topright{margin-left:auto;display:flex;align-items:center;gap:6px}
.lb{min-width:44px;min-height:36px;padding:8px 14px;border:1.5px solid var(--border);border-radius:18px;background:var(--surface);font-size:12px;font-weight:700;cursor:pointer;color:var(--text-3);transition:all .15s}
.lb.on{background:var(--brand);color:#fff;border-color:var(--brand)}

/* ==========================================================
   ANA KAPSAYICI + ALT NAVİGASYON
   ========================================================== */
.main{max-width:960px;margin:0 auto;padding:62px 10px 88px}
.tabs{position:fixed;bottom:0;left:0;right:0;background:var(--surface);border-top:1px solid var(--border-2);display:flex;z-index:100;height:64px;padding-bottom:env(safe-area-inset-bottom,0);box-shadow:0 -2px 10px rgba(0,0,0,.04)}
.tab-btn{flex:1;min-height:56px;padding:8px 4px;font-size:11px;font-weight:600;background:transparent;border:none;cursor:pointer;text-align:center;color:var(--text-3);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;transition:color .15s}
.tab-btn .tab-icon{font-size:22px;line-height:1;transition:transform .2s cubic-bezier(.2,.8,.4,1.2)}
.tab-btn.on{color:var(--brand)}
.tab-btn.on .tab-icon{transform:scale(1.15) translateY(-1px)}
.tab-btn:active .tab-icon{transform:scale(.92)}
.sec{display:none}.sec.active{display:block}

/* ==========================================================
   KATEGORİ + MARKA CHIP'LERİ
   ========================================================== */
.cats{display:flex;gap:6px;overflow-x:auto;padding-bottom:4px;-webkit-overflow-scrolling:touch}.cats::-webkit-scrollbar{display:none}
.cat{padding:7px 12px;font-size:12px;font-weight:500;border-radius:18px;border:1.5px solid var(--border);background:var(--surface);cursor:pointer;color:var(--text-2);white-space:nowrap;flex-shrink:0}
.cat.on{background:var(--brand);color:#fff;border-color:var(--brand)}

/* ==========================================================
   MARKET FİLTRE TABLARI
   ========================================================== */
.ftabs{display:flex;gap:6px;flex-wrap:wrap}
.ftab{padding:7px 12px;font-size:12px;font-weight:500;border-radius:18px;border:1.5px solid var(--border);background:var(--surface);cursor:pointer;color:var(--text-2);display:flex;align-items:center;gap:5px}
.ftab.on{color:#fff;border-color:transparent}
.ftab.on.all{background:var(--text)}
.ftab.on.fk{background:var(--red)}
.ftab.on.fm{background:var(--green)}
.ftab.on.fb{background:var(--yellow)}

/* ==========================================================
   TOOLBAR (filtre/sıralama barı)
   ========================================================== */
.toolbar{display:flex;gap:8px;margin-bottom:10px;position:relative}
.tb-btn{flex:1;min-height:44px;padding:11px 14px;font-size:13px;font-weight:600;background:var(--surface);border:1.5px solid var(--border);border-radius:10px;color:var(--text);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;transition:all .18s cubic-bezier(.2,.8,.4,1)}
.tb-btn:hover{border-color:var(--brand);color:var(--brand)}
.tb-btn:active{transform:scale(.97)}
.tb-badge{background:var(--brand);color:#fff;font-size:10px;font-weight:700;min-width:18px;height:18px;border-radius:9px;display:none;align-items:center;justify-content:center;padding:0 5px}
.tb-badge.show{display:inline-flex}
.filter-panel{display:none;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:14px;margin-bottom:12px;animation:slideDown .2s ease}
.filter-panel.open{display:block}
@keyframes slideDown{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
.fp-section{margin-bottom:14px}
.fp-section:last-child{margin-bottom:0}
.fp-title{font-size:11px;font-weight:700;color:var(--text-3);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}

/* ==========================================================
   MARKET + KATEGORİ ROZETLERİ (kart içinde)
   ========================================================== */
.mb{width:18px;height:18px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:9px;font-weight:800;color:#fff}
.mb.k{background:var(--red)}.mb.m{background:var(--green)}.mb.b{background:var(--yellow)}
.mn2{font-size:11px;font-weight:600}.ck{color:#c0392b}.cm{color:#27ae60}.cb{color:#d68910}
.pcm{display:flex;align-items:center;gap:5px;margin-bottom:6px}
.cic{font-size:13px;margin-left:auto;opacity:.7}

/* ==========================================================
   SIRALAMA AÇILIR MENÜSÜ
   ========================================================== */
.swrp{position:relative;flex-shrink:0}
.sdd{position:absolute;right:0;top:calc(100% + 4px);background:var(--surface);border:1px solid var(--border);border-radius:10px;box-shadow:0 4px 16px rgba(0,0,0,.1);z-index:100;min-width:160px;display:none}.sdd.open{display:block}
.sop{padding:8px 12px;font-size:12px;cursor:pointer;color:var(--text)}.sop:hover{background:var(--surface-2)}.sop.on{font-weight:600;color:var(--brand)}

/* ==========================================================
   ARAMA KUTUSU
   ========================================================== */
.qw{margin-bottom:8px}
.qw input{width:100%;padding:8px 12px;border:1.5px solid var(--border);border-radius:10px;font-size:13px;background:var(--surface);color:var(--text);outline:none}
.qw input:focus{border-color:var(--brand)}

/* ==========================================================
   ÜRÜN GRID'İ (2/3/4 sütun responsive)
   ========================================================== */
.grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
@media(min-width:600px){.grid{grid-template-columns:repeat(3,1fr);gap:12px}}
@media(min-width:900px){.grid{grid-template-columns:repeat(4,1fr);gap:14px}}

/* ==========================================================
   ÜRÜN KARTI
   ========================================================== */
.pc{background:var(--surface);border:1px solid var(--border);border-radius:14px;overflow:hidden;cursor:pointer;position:relative;transition:transform .18s cubic-bezier(.2,.8,.4,1), box-shadow .18s}
.pc:active{transform:scale(.97)}
.pc:hover{box-shadow:0 6px 18px rgba(0,0,0,.08);transform:translateY(-2px)}

/* ==========================================================
   YANGI / INDIRIM SÜRESİ / TREND ROZETLERİ
   ========================================================== */
.nb{position:absolute;top:8px;left:8px;background:var(--red);color:#fff;font-size:10px;font-weight:800;padding:3px 7px;border-radius:6px;letter-spacing:.3px;z-index:2;box-shadow:0 2px 6px rgba(226,75,74,.4)}
.expire{display:inline-flex;align-items:center;gap:3px;font-size:10px;font-weight:700;color:var(--yellow);background:#fff8e6;padding:2px 6px;border-radius:5px;margin-left:5px}
.expire.urgent{color:#fff;background:var(--red)}
.trend{font-size:14px;margin-left:auto}

/* ==========================================================
   SPARKLINE + BİRİM FİYAT
   ========================================================== */
.sprk{display:block;margin:6px 0 4px;width:100%;height:18px;opacity:.85}
.unit-price{font-size:10px;color:var(--text-3);margin-top:2px;font-weight:500;font-variant-numeric:tabular-nums}

/* ==========================================================
   KART MEDYA + TİPOGRAFİ
   ========================================================== */
.pci{width:100%;height:140px;object-fit:cover;background:var(--surface-2)}
@media(min-width:600px){.pci{height:150px}}
.pcb{padding:10px 11px 12px}
.pcn{font-size:13px;font-weight:600;line-height:1.3;height:2.6em;overflow:hidden;margin-bottom:6px;color:var(--text)}
.pcp{display:flex;align-items:baseline;gap:6px;flex-wrap:wrap;margin-bottom:2px}
.pr{font-size:20px;font-weight:800;color:var(--text);letter-spacing:-.3px}
.ol{font-size:12px;color:var(--text-3);text-decoration:line-through;font-weight:500}
.ds{font-size:11px;font-weight:800;color:#fff;background:var(--brand);padding:3px 7px;border-radius:6px;letter-spacing:.2px}

/* ==========================================================
   KART EYLEM BUTONLARI
   ========================================================== */
.wb{display:block;margin-top:8px;padding:10px;font-size:12px;border:1.5px solid var(--blue);border-radius:8px;background:var(--surface);cursor:pointer;color:var(--blue);font-weight:700;text-decoration:none;text-align:center;transition:all .18s cubic-bezier(.2,.8,.4,1)}
.wb:hover{background:#e6f4fb}.wb:active{transform:scale(.96)}

/* ==========================================================
   FAVORİ KALP BUTONU
   ========================================================== */
.fav-btn{position:absolute;top:8px;right:8px;background:rgba(255,255,255,.95);border:none;width:34px;height:34px;border-radius:50%;font-size:18px;cursor:pointer;z-index:3;display:flex;align-items:center;justify-content:center;padding:0;box-shadow:0 2px 8px rgba(0,0,0,.15);color:var(--text-4);transition:color .2s, transform .2s cubic-bezier(.2,.8,.4,1.2)}
.fav-btn:hover{color:var(--red);transform:scale(1.08)}
.fav-btn:active{transform:scale(.85)}
.fav-btn.on{color:var(--red);animation:pop .3s cubic-bezier(.2,.8,.4,1.4)}
@keyframes pop{0%{transform:scale(1)}40%{transform:scale(1.3)}100%{transform:scale(1)}}

/* ==========================================================
   MODAL WATCH + SOSYAL PAYLAŞIM BUTONLARI
   ========================================================== */
.mwb{display:inline-flex;align-items:center;gap:6px;padding:10px 18px;background:var(--blue);color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:700;text-decoration:none;margin-bottom:12px}
.shr-row{display:flex;gap:8px;margin-bottom:12px}
.shr{flex:1;padding:10px 12px;border:none;border-radius:10px;font-size:12px;font-weight:700;text-decoration:none;text-align:center;display:inline-flex;align-items:center;justify-content:center;gap:6px;cursor:pointer}
.shr.wa{background:#25D366;color:#fff}
.shr.tg{background:var(--blue);color:#fff}

/* ==========================================================
   YAZDIRMA
   ========================================================== */
@media print {
  .top, .tabs, .qw, .bdg, .btt, .fav-btn, .nb, #sec-map, #sec-fav { display: none !important; }
  body { background: #fff; color: #000; }
  .main { max-width: none; padding: 0; }
  .grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 8px; }
  .pc { break-inside: avoid; border: 1px solid #000; box-shadow: none; }
  .pci { height: 60px; }
  .pcn { font-size: 11px; color: #000; }
  .pr { font-size: 13px; color: #000; }
  .ol { color: #666; }
  .ds { background: #000 !important; color: #fff !important; }
  .pcm { color: #000; }
  .trend { display: none; }
}

/* ==========================================================
   KARANILIK MOD — tek blok
   ========================================================== */
@media (prefers-color-scheme: dark){
  .expire{background:#2a2214}
  .fav-btn{background:rgba(21,21,27,.95);color:var(--text-4)}
  .wb{background:var(--surface);color:#33a6dd;border-color:#33a6dd}
  .wb:hover{background:#112736}
  .loc-btn{background:var(--brand);color:#fff}
  .bdg{background:var(--surface);color:var(--text-3)}
  .nr{color:var(--text-3)}
  .ol{color:#6a6a75}
  .about-btn:not(.primary){background:var(--surface-2);color:var(--text);border-color:var(--border-2)}
  .about-btn:not(.primary):hover{background:var(--border)}
  .hero{background:linear-gradient(135deg,var(--brand) 0%,#0f5c44 100%)}
  .featured{background:var(--surface);border-color:var(--yellow)}
}

/* ==========================================================
   BOŞ SONUÇ DURUMU
   ========================================================== */
.nr{text-align:center;padding:2rem;color:var(--text-3);font-size:12px;grid-column:1/-1}

/* ==========================================================
   HAKKIMIZDA KARTI
   ========================================================== */
.about-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:20px;margin-top:24px;margin-bottom:12px}
.about-head{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.about-logo{width:46px;height:46px;border-radius:12px;background:linear-gradient(135deg,var(--brand),var(--brand-d));color:#fff;display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:800;flex-shrink:0;box-shadow:0 2px 8px rgba(29,158,117,.25)}
.about-name{font-size:17px;font-weight:800;color:var(--text);margin-bottom:2px}
.about-tag{font-size:11px;color:var(--text-3);line-height:1.3}
.about-body{font-size:12px;color:var(--text-2);line-height:1.55;margin-bottom:14px}
.about-body a{color:var(--brand);text-decoration:none;font-weight:600}
.about-trust{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:14px;padding:12px;background:var(--surface-2);border-radius:10px}
.trust-item{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text-2);font-weight:500}
.ti-ic{font-size:14px}
.about-cta{display:flex;gap:8px}
.about-btn{flex:1;padding:12px;border-radius:10px;background:var(--bg);color:var(--text);font-size:12px;font-weight:700;text-decoration:none;text-align:center;display:flex;align-items:center;justify-content:center;gap:6px;border:1.5px solid var(--border);transition:background .15s}
.about-btn.primary{background:var(--brand);color:#fff;border-color:var(--brand)}
.about-btn.primary:hover{background:var(--brand-d)}
.about-btn:not(.primary):hover{background:var(--surface-2)}
.about-legal{margin-top:14px;padding-top:14px;border-top:1px solid var(--border);text-align:center;font-size:11px;color:var(--text-3)}
.about-legal a{color:var(--text-2);text-decoration:none;font-weight:600}
.about-legal a:hover{color:var(--brand)}
.about-legal .sep{margin:0 8px;color:var(--text-4)}

/* ==========================================================
   ONBOARDING TOUR
   ========================================================== */
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes tourPop{from{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}
@keyframes tourPulse{
  0%,100%{box-shadow:0 0 0 9999px rgba(0,0,0,.72), 0 0 0 0 rgba(29,158,117,.5)}
  50%{box-shadow:0 0 0 9999px rgba(0,0,0,.72), 0 0 0 8px rgba(29,158,117,.15)}
}
.tour-overlay{display:none;position:fixed;inset:0;z-index:900;pointer-events:auto;animation:fadeIn .3s ease}
.tour-overlay.show{display:block}
.tour-spot{
  position:fixed;top:50%;left:50%;width:0;height:0;
  border-radius:14px;
  box-shadow:0 0 0 9999px rgba(0,0,0,.72);
  pointer-events:none;
  transition:top .4s cubic-bezier(.4,0,.2,1),left .4s cubic-bezier(.4,0,.2,1),width .4s cubic-bezier(.4,0,.2,1),height .4s cubic-bezier(.4,0,.2,1);
  animation:tourPulse 2s infinite;
}
.tour-tooltip{
  position:fixed;z-index:901;
  background:var(--surface);border-radius:14px;
  padding:18px 16px 14px;max-width:300px;width:calc(100vw - 32px);
  box-shadow:0 12px 40px rgba(0,0,0,.28);
  transition:top .4s cubic-bezier(.4,0,.2,1), left .4s cubic-bezier(.4,0,.2,1);
  animation:tourPop .35s cubic-bezier(.2,.8,.4,1);
  display:none;
}
.tour-tooltip.show{display:block}
.tour-tooltip.center{top:50% !important;left:50% !important;transform:translate(-50%,-50%);text-align:center}
.tour-icon{font-size:44px;margin-bottom:10px;display:none;line-height:1}
.tour-tooltip.center .tour-icon{display:block}
.tour-title{font-size:16px;font-weight:800;color:var(--text);margin-bottom:6px;line-height:1.3}
.tour-body{font-size:13px;color:var(--text-2);line-height:1.5;margin-bottom:14px}
.tour-controls{display:flex;gap:8px;align-items:center}
.tour-dots{display:flex;gap:5px;margin-right:auto}
.tour-dot{width:6px;height:6px;border-radius:50%;background:var(--border);transition:all .25s}
.tour-dot.on{background:var(--brand);width:18px;border-radius:3px}
.tour-next{padding:9px 16px;background:var(--brand);color:#fff;border:none;border-radius:8px;font-size:12px;font-weight:700;cursor:pointer;transition:all .15s}
.tour-next:hover{background:var(--brand-d)}
.tour-next:active{transform:scale(.96)}
.tour-skip{background:transparent;border:none;color:var(--text-3);font-size:11px;cursor:pointer;padding:6px 8px}
.tour-skip:hover{color:var(--text-2)}

/* ==========================================================
   HERO
   ========================================================== */
.hero{background:linear-gradient(135deg,var(--brand) 0%,var(--brand-d) 100%);color:#fff;border-radius:16px;padding:20px 18px;margin-bottom:14px;position:relative;overflow:hidden}
.hero::before{content:"";position:absolute;top:-30%;right:-10%;width:180px;height:180px;border-radius:50%;background:rgba(255,255,255,.06);pointer-events:none}
.hero::after{content:"";position:absolute;bottom:-40%;left:-10%;width:200px;height:200px;border-radius:50%;background:rgba(255,255,255,.04);pointer-events:none}
.hero-title{font-size:22px;font-weight:800;margin-bottom:6px;line-height:1.2;letter-spacing:-.3px;position:relative}
.hero-sub{font-size:13px;opacity:.92;line-height:1.4;margin-bottom:14px;position:relative}
.hero-stats{display:flex;gap:8px;position:relative}
.hstat{flex:1;background:rgba(255,255,255,.13);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);border-radius:10px;padding:10px 8px;text-align:center;transition:transform .2s cubic-bezier(.2,.8,.4,1.2)}
.hstat:hover{transform:translateY(-2px)}
.hstat-num{font-size:20px;font-weight:800;line-height:1;margin-bottom:3px}
.hstat-lbl{font-size:9px;font-weight:600;opacity:.85;text-transform:uppercase;letter-spacing:.3px}
.hero-meta{font-size:10px;opacity:.75;margin-top:12px;position:relative;display:flex;align-items:center;gap:5px}
.hero-meta::before{content:"";width:6px;height:6px;border-radius:50%;background:#fff;animation:pls 2s infinite}

/* ==========================================================
   HAFTALIK İSTATİSTİK ŞERİDİ
   ========================================================== */
.wstats{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:14px;padding:12px;background:var(--surface);border-radius:12px;border:1px solid var(--border)}
.ws-item{text-align:center;padding:4px}
.ws-ic{font-size:18px;margin-bottom:4px;line-height:1}
.ws-val{font-size:15px;font-weight:800;color:var(--text);line-height:1.2;margin-bottom:2px;font-variant-numeric:tabular-nums}
.ws-lbl{font-size:9px;color:var(--text-3);font-weight:600;text-transform:uppercase;letter-spacing:.3px;line-height:1.2}

/* ==========================================================
   FEATURED (bugünün teklifi)
   ========================================================== */
.featured{background:var(--surface);border:2px solid var(--yellow);border-radius:16px;padding:14px;margin-bottom:14px;display:flex;gap:14px;align-items:center;cursor:pointer;position:relative;overflow:hidden;transition:transform .2s cubic-bezier(.2,.8,.4,1), box-shadow .2s;width:100%;text-align:left;font:inherit;color:inherit}
.featured::before{content:attr(data-label);position:absolute;top:0;right:0;background:var(--yellow);color:#fff;font-size:9px;font-weight:800;padding:4px 10px;border-radius:0 0 0 10px;letter-spacing:.4px;z-index:2}
.featured:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(245,158,11,.15)}
.featured:active{transform:scale(.98)}
.feat-img{width:110px;height:110px;border-radius:10px;object-fit:cover;background:var(--surface-2);flex-shrink:0}
.feat-body{flex:1;min-width:0}
.feat-name{font-size:14px;font-weight:700;line-height:1.3;margin-bottom:4px;color:var(--text)}
.feat-market{font-size:11px;color:var(--text-3);margin-bottom:8px}
.feat-prices{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap}
.feat-pr{font-size:22px;font-weight:800;color:var(--text);letter-spacing:-.3px}
.feat-ol{font-size:13px;color:var(--text-4);text-decoration:line-through}
.feat-ds{font-size:12px;font-weight:800;color:#fff;background:var(--red);padding:3px 8px;border-radius:6px;margin-left:auto}

/* ==========================================================
   HARİTA
   ========================================================== */
#map{width:100%;height:400px;border-radius:12px;margin-bottom:12px}
.loc-btn{width:100%;padding:10px;background:var(--brand);color:#fff;border:none;border-radius:10px;font-size:13px;font-weight:600;cursor:pointer;margin-bottom:12px}
.store-list{margin-top:8px}
.store-item{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:10px 12px;margin-bottom:6px;display:flex;align-items:center;gap:10px}
.store-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.store-dot.k{background:var(--red)}.store-dot.m{background:var(--green)}.store-dot.b{background:var(--yellow)}
.store-info{flex:1}
.store-name{font-size:12px;font-weight:700;color:var(--text)}
.store-addr{font-size:11px;color:var(--text-3)}
.store-dist{font-size:11px;font-weight:700;color:var(--brand)}

/* ==========================================================
   ALT SABİT ROZET + YUKARI ÇIK + PULSE
   ========================================================== */
.bdg{position:fixed;bottom:72px;left:50%;transform:translateX(-50%);background:rgba(26,26,26,.85);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);color:#aaa;padding:5px 14px;border-radius:16px;font-size:10px;z-index:99;display:flex;align-items:center;gap:6px}
.btt{position:fixed;bottom:80px;right:14px;width:46px;height:46px;border-radius:50%;background:var(--brand);color:#fff;border:none;font-size:22px;cursor:pointer;box-shadow:0 4px 14px rgba(29,158,117,.4);z-index:98;display:none;align-items:center;justify-content:center}
.btt.show{display:flex}
.btt:active{transform:scale(.92)}
.dot{width:5px;height:5px;border-radius:50%;background:var(--brand);animation:pls 2s infinite}
@keyframes pls{0%,100%{opacity:1}50%{opacity:.3}}

/* ==========================================================
   ÜRÜN DETAY MODAL
   ========================================================== */
.modal-ov{display:none;position:fixed;inset:0;z-index:600;background:rgba(0,0,0,.5)}.modal-ov.open{display:flex;align-items:flex-end}
.modal{width:100%;max-height:85vh;background:var(--surface);border-radius:16px 16px 0 0;overflow-y:auto;padding:16px;animation:slideUp .25s ease}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.modal-img{width:100%;height:200px;object-fit:contain;background:var(--surface-2);border-radius:12px;margin-bottom:12px}
.modal-name{font-size:16px;font-weight:700;margin-bottom:4px}
.modal-market{display:flex;align-items:center;gap:6px;margin-bottom:8px}
.modal-prices{display:flex;align-items:baseline;gap:8px;margin-bottom:12px}
.modal-prices .pr{font-size:20px}.modal-prices .ol{font-size:14px}
.modal-chart{background:var(--surface-2);border-radius:12px;padding:12px;margin-bottom:12px}
.modal-chart canvas{max-height:200px}
.modal-close{position:absolute;top:12px;right:12px;width:32px;height:32px;border-radius:50%;border:none;background:var(--surface-2);cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;color:var(--text)}
