/* ════════════════════════════════════════
   ANA SAYFA
════════════════════════════════════════ */
#main{padding-top:var(--bar-h);}

/* ─── KARŞILAMA — 2 slide carousel ─── */
.welcome-carousel{
  position:relative;
  max-width:680px;margin:0 auto;
  overflow:hidden;
  touch-action:pan-y pinch-zoom; /* dikey scroll iletilsin */
}
/* Masaüstü navigasyon okları — sadece hover'da görünür, fareyle
   kenara yaklaşınca slide değiştirir. Mobilde gizli (swipe yeter). */
.welcome-nav{
  position:absolute;top:50%;transform:translateY(-50%);
  width:36px;height:36px;border-radius:50%;
  background:color-mix(in srgb, var(--surface, #1a1a1d) 75%, transparent);
  border:1px solid var(--border, #333);color:var(--text, #eee);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;z-index:5;
  opacity:0;transition:opacity .25s,background .2s,transform .15s;
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
}
.welcome-carousel:hover .welcome-nav{opacity:.85;}
.welcome-nav:hover{
  opacity:1 !important;
  background:var(--accent, #d4a843);color:#0a0a0a;border-color:transparent;
}
.welcome-nav:active{transform:translateY(-50%) scale(.92);}
.welcome-nav-prev{left:10px;}
.welcome-nav-next{right:10px;}
@media (max-width: 767px) {
  .welcome-nav{display:none;}
}
.welcome-track{
  display:flex;
  transition:transform .35s cubic-bezier(.34,1.1,.64,1);
  will-change:transform;
}
.welcome-slide{
  flex:0 0 100%;min-width:0;
  padding:36px 20px 28px;
  text-align:center;
  position:relative;
}
.welcome-dots{
  display:flex;justify-content:center;gap:8px;
  padding:8px 0 16px;
}
.welcome-dot{
  width:8px;height:8px;border-radius:50%;
  background:color-mix(in srgb, var(--text, #eee) 30%, transparent);
  border:0;padding:0;cursor:pointer;
  transition:background .3s,transform .3s,opacity .3s;
}
.welcome-dot:hover{
  background:color-mix(in srgb, var(--text, #eee) 55%, transparent);
  transform:scale(1.15);
}
/* Aktif dot: aynı boyut, sadece altın rengi + hafif glow.
   Eski "çizgi" tarzı kaldırıldı (width:22px), yuvarlak korunur. */
.welcome-dot.active{
  background:var(--accent, #d4a843);
  box-shadow:0 0 0 3px color-mix(in srgb, var(--accent, #d4a843) 22%, transparent);
}
.welcome-install-actions{
  display:flex;gap:10px;justify-content:center;flex-wrap:wrap;
  margin-top:14px;
}
.welcome-install-btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 16px;border-radius:10px;
  font-family:var(--body-font);font-size:13.5px;font-weight:700;
  cursor:pointer;text-decoration:none;
  transition:transform .15s,filter .15s;
}
.welcome-install-btn:active{transform:scale(.96);}
.welcome-install-btn.primary{
  background:var(--accent);color:#0a0a0a;border:0;
}
.welcome-install-btn.primary:hover{filter:brightness(1.1);}
.welcome-install-btn.ghost{
  background:transparent;color:var(--text);
  border:1.5px solid var(--border);
}
.welcome-install-btn.ghost:hover{border-color:var(--accent);color:var(--accent);}

/* Eski .welcome-section kullananlar için backward compat (kullanılmayacak ama
   ust-bar veya başka yer referans almıyor mu kontrol ettim, OK) */
.welcome-section{
  padding:36px 20px 28px;
  max-width:680px;margin:0 auto;
  text-align:center;
  position:relative;
}
.welcome-eyebrow{
  font-size:calc(10px * var(--fs,1));font-weight:600;letter-spacing:.16em;
  text-transform:uppercase;color:var(--accent);
  margin-bottom:8px;
  display:flex;align-items:center;justify-content:center;gap:8px;
}
.welcome-eyebrow::before,.welcome-eyebrow::after{
  content:'';width:28px;height:1px;background:var(--accent);opacity:.5;
}
/* Hero altın flourish — eyebrow ile başlık arası zarif ayraç (JS ekler) */
.welcome-flourish{
  display:flex;justify-content:center;align-items:center;
  color:var(--accent);
  margin:4px auto 12px;
  opacity:.7;
}
.welcome-flourish svg{width:min(230px,64%);height:auto;display:block;}

.welcome-title{
  /* ORİJİNAL "efsane" hero: başlık Cinzel serif — Roma yazıtı gibi asil duruş.
     (Kullanıcı fontundan bağımsız sabit; asaleti veren buydu.) */
  font-family:'Cinzel',serif;
  font-size:clamp(22px,5vw,32px);
  font-weight:700;line-height:1.25;
  color:var(--text);margin-bottom:8px;
  letter-spacing:.03em;
}
.welcome-sub{
  font-size:calc(14px * var(--fs,1));color:var(--text-muted);line-height:1.6;
  max-width:340px;margin:0 auto;
}

/* ─── BÖLÜM BAŞLIĞI ─── */
.sec-header{
  display:flex;align-items:baseline;justify-content:space-between;
  padding:0 20px;margin-bottom:4px;
}
.sec-title{
  font-family:var(--body-font);font-size:calc(18px * var(--fs,1));font-weight:600;
  color:var(--text);display:flex;align-items:center;gap:8px;
}
.sec-title-ico{font-size:calc(16px * var(--fs,1));}
.sec-title-new{
  font-size:calc(10px * var(--fs,1));font-weight:700;letter-spacing:.08em;
  text-transform:uppercase;color:var(--accent);
  background:var(--accent-dim);
  border:1px solid color-mix(in srgb,var(--accent) 25%,transparent);
  padding:2px 7px;border-radius:20px;
  vertical-align:middle;
}
.sec-more{
  font-size:calc(12px * var(--fs,1));font-weight:500;color:var(--accent);
  transition:opacity .15s;
}
.sec-more:hover{opacity:.7;}

/* Unutulmazlar — Yeniler/Popüler ile aynı boyut/yapı, ama yazı kısmı
   havalı: Cinzel font + ince altın gradient + harf aralığı.
   Bölüm DAİMA görünür (display none yapma) — JS render sonrası
   sadece scroll içeriği değişir, "pop in" hissi olmasın. */
.section-unforgettable {
  /* min-height: kart yüksekliği kadar — boş anda da yer kaplar */
  min-height: 240px;
}
.sec-title--eternal{
  /* Boyut sec-title ile aynı, sadece yazı stili değişiyor */
  align-items:center;
}
.sec-title--eternal .sec-title-ico{
  color:var(--accent);
  font-size:calc(15px * var(--fs,1));
  /* Hafif glow ile ❦ ornamenti vurgula — minimal */
  text-shadow:0 0 8px color-mix(in srgb, var(--accent) 50%, transparent);
}
.sec-title--eternal .sec-title-text{
  font-family:'Cinzel',serif;
  font-weight:600;
  letter-spacing:.08em;
  /* İnce altın gradient — accent'in iki tonu, parlama yok, sadece
     metalik his. clip:text ile yazı içine işliyor. */
  background:linear-gradient(
    100deg,
    color-mix(in srgb, var(--accent) 75%, var(--text)) 0%,
    var(--accent) 50%,
    color-mix(in srgb, var(--accent) 75%, var(--text)) 100%
  );
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
}

.section-wrap{margin-bottom:36px;}

/* ─── YATAY SCROLL ─── */
.h-scroll-outer{overflow:visible;position:relative;}
.h-scroll{
  display:flex;gap:14px;
  overflow-x:auto;overflow-y:visible;
  padding:16px 20px 20px;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
}
.h-scroll::-webkit-scrollbar{display:none;}

/* ─── KİTAP KARTI (küçük) ─── */
/* NOT: Kapak boyutları --fs (font-scale) ile çarpılmaz — kullanıcı yazıyı
   büyütünce kapaklar grid'i bozacak şekilde devleşiyordu. Title ve author
   yazıları zaten kendi kurallarında --fs alıyor; kapak sabit kalır. */
.bcard{
  flex-shrink:0;width:108px;cursor:pointer;
  position:relative;z-index:1;
  transition:z-index 0s;
}
.bcard.expanded{z-index:50;}
.bcard-cover{
  width:108px;height:152px;border-radius:10px;
  overflow:hidden;position:relative;
  /* background-image inline style ile veriliyor (_makeRecCard) — cover sizing
     burada zorla, yoksa orijinal görsel boyutuyla render olur ve karttan taşar */
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  background-color:#1a1a20;
  box-shadow:0 6px 20px rgba(0,0,0,.4);
  transition:transform .3s cubic-bezier(.34,1.15,.64,1),
             box-shadow .3s,
             width .3s cubic-bezier(.34,1.15,.64,1),
             height .3s cubic-bezier(.34,1.15,.64,1);
  margin-bottom:8px;
}
.bcard.expanded .bcard-cover{
  width:148px;
  height:210px;
  transform:translateY(-8px) translateX(-20px);
  box-shadow:0 20px 50px rgba(0,0,0,.7);
}
.bcard-img{width:100%;height:100%;object-fit:cover;display:block;}

/* Normal hover overlay — sadece masaüstü */
.bcard-ov{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(0,0,0,.88) 0%,rgba(0,0,0,.5) 38%,transparent 62%);
  opacity:0;transition:opacity .22s;
  display:flex;flex-direction:column;align-items:flex-start;
  justify-content:flex-end;padding:8px;gap:3px;
}
/* Expanded info overlay */
.bcard.expanded .bcard-ov{opacity:1!important;}
@media (hover:hover){
  .bcard:not(.expanded):hover .bcard-cover{
    transform:translateY(-4px) scale(1.04);
    box-shadow:0 14px 36px rgba(0,0,0,.55);
  }
  .cg-card:not(.expanded):hover .cg-cover{
    transform:translateY(-6px) scale(1.07);
    box-shadow:0 14px 36px rgba(0,0,0,.55);
  }
}
/* Kütüphane — köşe katlama */
.bcard-lib-btn{
  position:absolute;top:0;right:0;
  width:36px;height:36px;
  overflow:hidden;
  display:none;
  z-index:3;cursor:pointer;
  font-size:0;color:transparent;
}
.bcard.expanded .bcard-lib-btn{display:block;}
.bcard-lib-btn::before{
  content:'';
  position:absolute;top:0;right:0;
  width:0;height:0;
  border-style:solid;
  border-width:0 36px 36px 0;
  border-color:transparent var(--accent) transparent transparent;
  opacity:.85;
  transition:border-color .2s, opacity .2s;
}
.bcard-lib-btn.saved::before{
  opacity:1;
  border-color:transparent var(--accent) transparent transparent;
  filter:brightness(1.3);
}
.bcard-lib-btn::after{
  content:'+';
  position:absolute;top:3px;right:4px;
  font-size:13px;font-weight:700;
  color:#000;line-height:1;
}
.bcard-lib-btn.saved::after{
  content:'✓';
  font-size:11px;top:4px;right:5px;
}

/* Puan + yorum */
.bcard-ov-score{
  display:none;
  align-items:center;gap:4px;
  font-size:calc(10px * var(--fs,1));font-weight:600;color:#f4b942;
  letter-spacing:.3px;
}
.bcard-ov-rcount{
  font-size:calc(9px * var(--fs,1));color:rgba(255,255,255,.6);font-weight:400;
}
.bcard-ov-cats{
  display:none;flex-wrap:nowrap;gap:3px;
  overflow:hidden;max-width:100%;
  font-size:calc(9px * var(--fs,1));
}
.bcard-ov-cat{
  font-size:calc(9px * var(--fs,1));font-weight:600;flex-shrink:0;
  padding:2px 6px;border-radius:10px;
  background:rgba(255,255,255,.15);
  color:rgba(255,255,255,.85);
  backdrop-filter:blur(4px);
}
.bcard-ov-more{
  font-size:calc(9px * var(--fs,1));font-weight:700;flex-shrink:0;
  padding:2px 5px;border-radius:10px;
  background:rgba(255,255,255,.1);
  color:rgba(255,255,255,.6);
}
.bcard.expanded .bcard-ov-score{display:flex;}
.bcard.expanded .bcard-ov-cats{display:flex;}
.bcard-ov-desc,.card-ov-desc{
  font-size:calc(9px * var(--fs,1));color:rgba(255,255,255,.7);line-height:1.4;
  margin-bottom:4px;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;line-clamp:3;
}

/* title/author hidden in overlay */
.bcard-ov-title,.bcard-ov-author{display:none;}

.bcard-title{font-size:calc(12px * var(--fs,1));font-weight:600;color:var(--text);line-height:1.3;margin-bottom:3px;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;line-clamp:2;}
.bcard-author{font-size:calc(11px * var(--fs,1));color:var(--accent);font-weight:500;}
/* Kapak placeholder renkleri */
.cv-1{background:linear-gradient(135deg,#1a0a0a,#3d1a10,#c0392b);}
.cv-2{background:linear-gradient(135deg,#0a1020,#1e3050,#2e6090);}
.cv-3{background:linear-gradient(135deg,#0a1a0a,#1e4025,#2a8040);}
.cv-4{background:linear-gradient(135deg,#1a0a20,#3a1550,#8040c0);}
.cv-5{background:linear-gradient(135deg,#1a1000,#403010,#c08020);}
.cv-6{background:linear-gradient(135deg,#0a1818,#1a3838,#206060);}
.cv-7{background:linear-gradient(135deg,#18000a,#380018,#800040);}
.cv-8{background:linear-gradient(135deg,#101010,#282820,#505030);}
.cv-9{background:linear-gradient(135deg,#100818,#281838,#503870);}
.cv-10{background:linear-gradient(135deg,#001010,#003030,#006060);}
.cv-11{background:linear-gradient(135deg,#0f0800,#2e1a00,#6e3a00);}
.cv-12{background:linear-gradient(135deg,#08000f,#1a0030,#3a0070);}
.cover-letter{
  width:100%;height:100%;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:4px;padding:10px;
}
.cover-initial{
  font-family:'Cinzel',serif;
  /* Kart boyutu sabit (108x152) — harf de --fs'ten bağımsız sabit kalmalı,
     yoksa font büyütünce "M" gibi harfler karttan taşıyor */
  font-size:36px;font-weight:700;
  color:rgba(255,255,255,.7);
  line-height:1;
}
.cover-icon{font-size:22px;opacity:.5;}

/* ─── POPÜLER BÖLÜMÜ (Featured + Grid) ─── */
.popular-featured{
  margin:0 20px 16px;
  border-radius:16px;overflow:hidden;
  background:var(--surface);
  border:1px solid var(--border2);
  position:relative;cursor:pointer;
  transition:box-shadow .2s;
  min-height:calc(180px * var(--fs,1));
  display:flex;
}
.popular-featured:hover{box-shadow:0 8px 40px rgba(0,0,0,.5);}
.popular-featured.expanded{box-shadow:0 12px 48px rgba(0,0,0,.65);}
.popular-featured.expanded .pf-cover-bg .card-ov{opacity:1!important;}
.popular-featured.expanded .pf-cover-bg .card-lib-btn{display:block!important;}
.popular-featured .card-lib-btn{width:28px;height:28px;}
.popular-featured .card-lib-btn::before{border-width:0 28px 28px 0;}
.popular-featured .card-lib-btn::after{font-size:11px;top:3px;right:4px;}
.popular-featured .card-lib-btn.saved::after{font-size:9px;top:4px;right:5px;}
.popular-featured .card-ov{border-radius:0;}
.pf-cover-bg{
  width:calc(120px * var(--fs,1));flex-shrink:0;
  position:relative;overflow:hidden;
}
.pf-cover-inner{width:100%;height:100%;}
.pf-glow{
  position:absolute;top:0;right:0;bottom:0;width:80px;
  background:linear-gradient(to right,transparent,var(--surface));
  z-index:1;
}
.pf-body{padding:20px 16px;flex:1;z-index:2;display:flex;flex-direction:column;justify-content:space-between;}
.pf-badge{
  display:inline-flex;align-items:center;gap:5px;
  background:var(--accent);color:#000;
  font-size:calc(9px * var(--fs,1));font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  padding:3px 8px;border-radius:20px;margin-bottom:8px;
  align-self:flex-start;
}
.pf-title{
  font-family:var(--body-font);font-size:calc(17px * var(--fs,1));font-weight:600;
  line-height:1.3;color:var(--text);margin-bottom:4px;
}
.pf-author{font-size:calc(12px * var(--fs,1));color:var(--accent);font-weight:500;margin-bottom:8px;}
.pf-desc{font-size:calc(12px * var(--fs,1));color:var(--text-muted);line-height:1.5;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-clamp:2;
  margin-bottom:12px;
}
.pf-stats{display:flex;gap:12px;}
.pf-stat{display:flex;align-items:center;gap:4px;font-size:calc(11px * var(--fs,1));color:var(--text-sub);}
.pf-stat-val{font-weight:600;color:var(--text);}

.popular-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:12px;padding:0 20px;
}
.pg-card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:12px;cursor:pointer;
  position:relative;z-index:1;
  overflow:visible;
  transition:box-shadow .2s,border-color .2s;
}
.pg-card:not(.expanded):hover{
  box-shadow:0 8px 28px rgba(0,0,0,.4);
  border-color:var(--border2);
}
.pg-card.expanded{z-index:50;}
.pg-cover{
  height:calc(120px * var(--fs,1));position:relative;
  border-radius:12px 12px 0 0;overflow:hidden;
  isolation:isolate;
  transition:height .32s cubic-bezier(.34,1.15,.64,1),
             transform .32s cubic-bezier(.34,1.15,.64,1),
             box-shadow .32s;
}
.pg-card.expanded .pg-cover{
  height:calc(168px * var(--fs,1));
  transform:translateY(-10px);
  box-shadow:0 18px 42px rgba(0,0,0,.7);
  border-radius:10px;
}
.pg-cover-img{width:100%;height:100%;object-fit:cover;}
.pg-rank{
  position:absolute;top:6px;left:6px;
  background:rgba(0,0,0,.7);backdrop-filter:blur(4px);
  color:var(--accent);font-size:calc(10px * var(--fs,1));font-weight:700;
  font-family:'Cinzel',serif;
  padding:2px 6px;border-radius:6px;z-index:3;
}
.pg-body{padding:8px 8px 10px;}
.pg-title{font-size:calc(12px * var(--fs,1));font-weight:600;color:var(--text);line-height:1.3;margin-bottom:2px;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;line-clamp:2;}
.pg-views{font-size:calc(10px * var(--fs,1));color:var(--text-muted);display:flex;align-items:center;gap:3px;}

/* ─── KLASİKLER SNAP-SCROLL ─── */
.classics-outer{position:relative;overflow:hidden;}
.classics-pages{
  display:flex;
  overflow-x:auto;overflow-y:visible;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
  padding:8px 12px 4px;
  gap:0;
}
.classics-pages::-webkit-scrollbar{display:none;}
.classics-page{
  flex-shrink:0;
  width:100%;
  display:flex;flex-direction:column;gap:2px;
  scroll-snap-align:start;
}
.classics-dots{
  display:flex;justify-content:center;gap:6px;
  padding:8px 0 4px;
}
.classics-dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--border2);transition:background .2s,transform .2s;
  cursor:pointer;
}
.classics-dot.active{background:var(--accent);transform:scale(1.3);}

.classics-list{
  display:flex;flex-direction:column;gap:2px;
  padding:8px 12px;margin:0 8px;
}
.classic-item{
  display:flex;align-items:center;gap:14px;
  padding:12px 8px;border-radius:12px;
  cursor:pointer;
  border-bottom:1px solid var(--border);
  transition:background .15s;
  position:relative;z-index:1;overflow:visible;
}
.classic-item:last-child{border-bottom:none;}
.classic-item:not(.expanded):hover{background:var(--accent-dim);}
.classic-item.expanded{z-index:50;background:var(--accent-dim);}
.classic-cover{
  width:calc(68px * var(--fs,1));height:calc(96px * var(--fs,1));border-radius:7px;flex-shrink:0;
  overflow:hidden;box-shadow:0 4px 14px rgba(0,0,0,.4);
  position:relative;
  transition:width .32s cubic-bezier(.34,1.15,.64,1),
             height .32s cubic-bezier(.34,1.15,.64,1),
             transform .32s cubic-bezier(.34,1.15,.64,1),
             box-shadow .32s;
}
.classic-item.expanded .classic-cover{
  width:calc(112px * var(--fs,1));height:calc(158px * var(--fs,1));
  transform:translateY(-10px);
  box-shadow:0 18px 40px rgba(0,0,0,.7);
}
.classic-body{flex:1;min-width:0;}
.classic-label{
  display:inline-flex;align-items:center;gap:4px;
  font-size:calc(9px * var(--fs,1));font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  color:var(--accent);margin-bottom:4px;opacity:.8;
}
.classic-title{
  font-family:var(--body-font);font-size:calc(14px * var(--fs,1));font-weight:600;
  color:var(--text);line-height:1.3;margin-bottom:3px;
}
.classic-quote{
  font-size:calc(12px * var(--fs,1));font-style:italic;color:var(--text-muted);
  line-height:1.4;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-clamp:2;
}
.classic-num{
  font-family:'Cinzel',serif;font-size:calc(22px * var(--fs,1));font-weight:700;
  color:var(--border2);flex-shrink:0;width:28px;text-align:center;
}
/* Expanded overlay */
.classic-item.expanded .classic-cover .card-ov{opacity:1!important;}
.classic-item.expanded .classic-cover .card-lib-btn{display:block!important;}
.classic-item .card-lib-btn{width:28px;height:28px;}
.classic-item .card-lib-btn::before{border-width:0 28px 28px 0;}
.classic-item .card-lib-btn::after{font-size:11px;top:3px;right:4px;}
.classic-item .card-lib-btn.saved::after{font-size:9px;top:4px;right:5px;}

/* ─── TAMAMLANMIŞ SONSUZ KAYDIRMA ─── */
.completed-outer{padding:0 20px;}
.completed-infinite{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:12px;
}
.completed-sentinel{height:1px;margin-top:8px;}

/* Mobilde 3x3 kısıtlaması */
@media(max-width:599px){
  .completed-infinite .cg-card:nth-child(n+10){display:none;}
  .completed-sentinel{display:none;}
}

/* ─── SIZE ÖZEL SCROLL ─── */
.personalized-sub{
  font-size:calc(11px * var(--fs,1));color:var(--text-muted);
  padding:0 20px 8px;opacity:.7;
}
.personalized-scroll{transition:opacity .22s,transform .22s;}
.personalized-scroll.fading{opacity:0;transform:translateX(8px);}

/* ─── POPÜLER H-SCROLL ─── */
.pop-scroll .bcard{flex-shrink:0;}
.cg-card{
  cursor:pointer;
  position:relative;z-index:1;
  overflow:visible;
  transition:transform .2s;
}
.cg-card:not(.expanded):hover{transform:translateY(-3px);}
.cg-card.expanded{z-index:50;transform:none;}
.cg-cover{
  width:100%;aspect-ratio:2/3;border-radius:10px;
  overflow:hidden;position:relative;
  box-shadow:0 5px 18px rgba(0,0,0,.4);margin-bottom:7px;
  transition:transform .32s cubic-bezier(.34,1.15,.64,1),
             box-shadow .32s;
}
.cg-card.expanded .cg-cover{
  transform:translateY(-14px) scale(1.18);
  box-shadow:0 20px 48px rgba(0,0,0,.75);
}
.cg-cover-img{width:100%;height:100%;object-fit:cover;}
.cg-badge{
  position:absolute;top:0;left:0;right:0;
  background:linear-gradient(135deg,rgba(46,160,67,.9),rgba(30,120,50,.9));
  backdrop-filter:blur(4px);
  color:#fff;font-size:calc(9px * var(--fs,1));font-weight:700;
  text-align:center;padding:4px 4px;
  letter-spacing:.06em;text-transform:uppercase;
  z-index:1;
}
.cg-title{font-size:calc(11px * var(--fs,1));font-weight:600;color:var(--text);line-height:1.3;margin-bottom:2px;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;line-clamp:2;}
.cg-author{font-size:calc(10px * var(--fs,1));color:var(--text-muted);}

/* ─── SIZE ÖZEL TAGLAR ─── */
.personalized-tags{
  display:flex;flex-wrap:wrap;gap:8px;
  padding:0 20px 16px;
}
.ptag{
  padding:7px 14px;border-radius:20px;
  background:var(--accent-dim);
  border:1px solid color-mix(in srgb,var(--accent) 25%,transparent);
  color:var(--accent);font-size:calc(12px * var(--fs,1));font-weight:500;
  cursor:pointer;white-space:nowrap;
  transition:background .15s,transform .15s;
}
.ptag:hover{background:color-mix(in srgb,var(--accent) 20%,var(--surface));transform:scale(1.04);}
.ptag.active{background:var(--accent);color:#000;}

/* ─── ORTAK KART OVERLAY ─── */
.card-ov{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(0,0,0,.88) 0%,rgba(0,0,0,.5) 38%,transparent 62%);
  opacity:0;transition:opacity .22s;
  display:flex;flex-direction:column;align-items:flex-start;
  justify-content:flex-end;padding:8px;gap:3px;
  pointer-events:none;z-index:2;
}
.card-lib-btn{
  position:absolute;top:0;right:0;
  width:36px;height:36px;overflow:hidden;
  display:none;z-index:4;cursor:pointer;pointer-events:auto;
}
.card-lib-btn::before{
  content:'';position:absolute;top:0;right:0;
  width:0;height:0;border-style:solid;
  border-width:0 36px 36px 0;
  border-color:transparent var(--accent) transparent transparent;
  opacity:.85;transition:opacity .2s,filter .2s;
}
.card-lib-btn.saved::before{opacity:1;filter:brightness(1.3);}
.card-lib-btn::after{
  content:'+';position:absolute;top:3px;right:4px;
  font-size:13px;font-weight:700;color:#000;line-height:1;
}
.card-lib-btn.saved::after{content:'✓';font-size:11px;top:4px;right:5px;}
.card-ov-score{
  display:flex;align-items:center;gap:3px;
  font-size:calc(10px * var(--fs,1));font-weight:600;color:#f4b942;letter-spacing:.3px;
}
.card-ov-rcount{font-size:calc(9px * var(--fs,1));color:rgba(255,255,255,.6);font-weight:400;}
.card-ov-cats{display:flex;flex-wrap:nowrap;gap:3px;overflow:hidden;max-width:100%;font-size:calc(9px * var(--fs,1));}
.card-ov-cat{
  font-size:calc(9px * var(--fs,1));font-weight:600;flex-shrink:0;
  padding:2px 6px;border-radius:10px;
  background:rgba(255,255,255,.15);color:rgba(255,255,255,.85);
  backdrop-filter:blur(4px);
}
.card-ov-more{
  font-size:calc(9px * var(--fs,1));font-weight:700;flex-shrink:0;
  padding:2px 5px;border-radius:10px;
  background:rgba(255,255,255,.1);color:rgba(255,255,255,.6);
}
/* Expanded overlay göster */
.pg-card.expanded .pg-cover .card-ov,
.cg-card.expanded .cg-cover .card-ov{opacity:1!important;}
.pg-card.expanded .pg-cover .card-lib-btn,
.cg-card.expanded .cg-cover .card-lib-btn{display:block!important;}




footer{
  background:var(--surface);
  border-top:1px solid var(--border);
  padding:32px 20px 40px;
  margin-top:20px;
}
.footer-inner{max-width:480px;margin:0 auto;}
.footer-logo{
  display:flex;align-items:center;gap:10px;
  margin-bottom:16px;
}
.footer-logo svg{width:28px;height:28px;opacity:.7;}
.footer-logo-text{
  font-family:'Cinzel',serif;font-size:calc(14px * var(--fs,1));font-weight:600;
  color:var(--text-muted);
}
.footer-links{
  display:flex;flex-wrap:wrap;gap:16px;
  margin-bottom:20px;
}
.footer-link{
  font-size:calc(12px * var(--fs,1));color:var(--text-muted);
  transition:color .15s;
}
.footer-link:hover{color:var(--accent);}
.footer-socials{display:flex;gap:10px;margin-bottom:20px;}
.social-btn{
  width:34px;height:34px;border-radius:9px;
  background:var(--surface2);border:1px solid var(--border2);
  display:flex;align-items:center;justify-content:center;
  font-size:calc(15px * var(--fs,1));color:var(--text-muted);
  transition:background .15s,border-color .15s,color .15s;
}
.social-btn:hover{background:var(--accent-dim);border-color:var(--accent);color:var(--accent);}
.footer-copy{font-size:calc(11px * var(--fs,1));color:var(--text-muted);opacity:.6;}

/* ════════════════════════════════════════
   RESPONSIVE
════════════════════════════════════════ */
@media(min-width:600px){
  .popular-grid{grid-template-columns:repeat(4,1fr);}
  .completed-infinite{grid-template-columns:repeat(4,1fr);}
  .classics-list{margin:0 16px;}
}
@media(min-width:768px){
  .completed-infinite{grid-template-columns:repeat(5,1fr);}
}
@media(min-width:900px){
  .completed-infinite{grid-template-columns:repeat(6,1fr);}
}
@media(max-width:380px){
  #right-panel{width:78%;}
  .popular-grid{grid-template-columns:repeat(3,1fr);}
  .completed-infinite{grid-template-columns:repeat(3,1fr);}
}

/* ════════════════════════════════════════
   DESKTOP >= 1024px
════════════════════════════════════════ */
@media(min-width:1024px){
  /* Ana konteyner */
  #main{max-width:1200px;margin:0 auto;padding-left:32px;padding-right:32px;}

  /* Karşılama — masaüstünde AYRI RENKLİ KUTU YOK. Sayfayla aynı zemin; alan,
     ORİJİNAL "efsane" karşılama geri getirildi: kutu/işleme YOK; sadece
     eyebrow'u saran iki ince accent çizgi + temiz tipografi. Masaüstünde de
     ortalı, makul genişlikte (geniş boşlukta yüzmesin diye max-width sınırlı). */
  .welcome-carousel{
    max-width:720px;
    margin:20px auto 8px;
    border:none;
    background:transparent;
    box-shadow:none;
  }
  .welcome-slide{
    display:flex;flex-direction:column;align-items:center;justify-content:center;
    padding:52px 24px 44px;
    text-align:center;
  }
  .welcome-eyebrow{justify-content:center;margin-bottom:12px;}
  .welcome-eyebrow::before,.welcome-eyebrow::after{display:inline-block;width:30px;}
  .welcome-title{font-size:clamp(30px,3.4vw,42px);line-height:1.16;margin-bottom:12px;letter-spacing:.02em;}
  .welcome-sub{max-width:440px;margin:0 auto;font-size:calc(15px * var(--fs,1));line-height:1.6;}
  .welcome-install-actions{justify-content:center;margin-top:24px;}
  .welcome-install-btn{padding:12px 20px;font-size:14.5px;}
  .welcome-nav-prev{left:10px;}
  .welcome-nav-next{right:10px;}

  /* Bölüm başlığı */
  .sec-header{padding:0;}
  .section-wrap{margin-bottom:48px;}

  /* Yatay scroll bölümler masaüstünde de scroll olarak kalır */
  .h-scroll-outer{overflow:visible;}
  .h-scroll:not(.pop-scroll):not(.personalized-scroll){
    display:flex;
    flex-wrap:nowrap;
    overflow-x:auto;
    overscroll-behavior-x:contain;
    padding:16px 0 12px;
    scrollbar-width:none;
  }
  .h-scroll:not(.pop-scroll):not(.personalized-scroll)::-webkit-scrollbar{display:none;}
  .h-scroll:not(.pop-scroll):not(.personalized-scroll) .bcard{
    flex-shrink:0;
    width:calc(108px * var(--fs,1));
  }

  /* Populer: featured + scroll yan yana */
  .popular-layout{
    display:grid;
    grid-template-columns:400px 1fr;
    gap:12px;
    align-items:start;
  }
  .popular-featured{
    margin:0;
    flex-direction:row;
    min-height:200px;
    height:100%;
  }
  .pf-cover-bg{
    width:calc(130px * var(--fs,1));height:auto;flex-shrink:0;
  }
  .pf-glow{
    width:64px;height:100%;
    top:0;bottom:0;right:0;left:auto;
    background:linear-gradient(to right,transparent,var(--surface));
  }
  .popular-grid{
    grid-template-columns:repeat(3,1fr);
    padding:0;
    gap:12px;
    align-content:start;
  }

  /* Klasikler — desktop'ta snap-scroll yerine 2 sütun sayfa */
  .classics-pages{overflow-x:auto;}
  .classics-page{width:50%;}
  .classics-dots{display:none;}
  .classic-item{border-bottom:1px solid var(--border);}

  /* Tamamlananlar — desktop'ta sabit sütun sayısı */
  .completed-outer{padding:0;}
  .completed-infinite{
    grid-template-columns:repeat(7,1fr);
    gap:16px;
  }
  .completed-infinite .cg-card:nth-child(n+10){display:unset;}
  .completed-sentinel{display:unset;}

  /* Tüm h-scroll'lar flex yatay scroll kullanır */
  .personalized-scroll,
  .pop-scroll {
    display: flex;
    flex-wrap: nowrap;
    overflow-x: auto;
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }
  .personalized-scroll::-webkit-scrollbar,
  .pop-scroll::-webkit-scrollbar { display: none; }

  /* Pop-scroll'da kart sola kayarsa featured card'a taşır — translateX sıfırla */
  .pop-scroll .bcard.expanded .bcard-cover{
    transform:translateY(-8px);
  }
  .pop-scroll{
    padding-left:8px;
  }

  /* Footer */
  .footer-inner{flex-direction:row;justify-content:space-between;align-items:center;}
}

/* ════════════════════════════════════════
   ANIMASYONLAR
════════════════════════════════════════ */
@keyframes fadeUp{from{opacity:0;transform:translateY(18px);}to{opacity:1;transform:translateY(0);}}
.welcome-section{animation:fadeUp .5s ease both;}
.section-wrap:nth-child(2){animation:fadeUp .5s .08s ease both;}
.section-wrap:nth-child(3){animation:fadeUp .5s .16s ease both;}
.section-wrap:nth-child(4){animation:fadeUp .5s .22s ease both;}
.section-wrap:nth-child(5){animation:fadeUp .5s .28s ease both;}
.section-wrap:nth-child(6){animation:fadeUp .5s .34s ease both;}



/* ════════════════════════════════════════
   ÖNERİ KARTLARI — Devam Et progress bar
   ════════════════════════════════════════ */
.rec-card { position: relative; }
.rec-progress-bar {
  position: absolute;
  left: 8px; right: 8px;
  bottom: 6px;
  height: 4px;
  border-radius: 2px;
  background: rgba(255,255,255,.15);
  overflow: hidden;
}
.rec-progress-bar span {
  display: block;
  height: 100%;
  background: var(--accent, #c8922a);
  border-radius: 2px;
}
