/* =========================================================
   DİRİ — Herbalife Distribütör Platformu · ortak tasarım sistemi
   premium emerald + lime + gold · app-shell
   ========================================================= */
:root{
  --bg:        oklch(0.975 0.012 152);
  --surface:   oklch(1 0 0);
  --surface-2: oklch(0.955 0.016 155);
  --ink:       oklch(0.24 0.030 162);
  --muted:     oklch(0.505 0.028 162);
  --line:      oklch(0.905 0.016 155);
  --brand:     oklch(0.475 0.115 162);
  --brand-600: oklch(0.535 0.125 161);
  --brand-deep:oklch(0.305 0.072 166);
  --brand-deeper:oklch(0.235 0.055 168);
  --lime:      oklch(0.865 0.185 126);
  --lime-700:  oklch(0.74 0.17 130);
  --lime-ink:  oklch(0.34 0.10 142);
  --gold:      oklch(0.80 0.125 80);
  --gold-soft: oklch(0.93 0.055 86);
  --gold-ink:  oklch(0.40 0.08 70);
  --danger:    oklch(0.58 0.16 25);
  --radius:14px; --radius-lg:22px; --radius-xl:28px;
  --side:266px;
  --ease:cubic-bezier(.16,1,.3,1);
  --shadow-sm:0 1px 2px oklch(0.3 0.05 162/.05), 0 6px 16px -10px oklch(0.3 0.06 162/.18);
  --shadow:0 2px 4px oklch(0.3 0.05 162/.05), 0 20px 44px -22px oklch(0.3 0.06 162/.30);
  --shadow-lg:0 30px 70px -34px oklch(0.25 0.07 166/.5);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth} @media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{margin:0;background:var(--bg);color:var(--ink);font-family:"Hanken Grotesk",system-ui,sans-serif;
  font-size:15.5px;line-height:1.55;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:"Bricolage Grotesque",sans-serif;font-weight:700;line-height:1.04;letter-spacing:-.03em;margin:0;text-wrap:balance}
p{margin:0} a{color:inherit;text-decoration:none} img{display:block;max-width:100%;height:auto}
button{font-family:inherit}
::selection{background:var(--lime);color:var(--lime-ink)}

/* ---------- buttons ---------- */
.btn{font-weight:700;font-size:.94rem;border:0;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;
  gap:.5em;padding:.74em 1.3em;border-radius:999px;transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .2s;white-space:nowrap}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--brand);color:#fff;box-shadow:0 10px 24px -12px var(--brand)}
.btn-primary:hover{background:var(--brand-600);transform:translateY(-2px);box-shadow:0 16px 30px -14px var(--brand)}
.btn-lime{background:var(--lime);color:var(--lime-ink);box-shadow:0 10px 24px -12px var(--lime-700)}
.btn-lime:hover{transform:translateY(-2px);box-shadow:0 16px 30px -12px var(--lime-700)}
.btn-ghost{background:var(--surface);color:var(--brand-deep);box-shadow:inset 0 0 0 1.5px var(--line)}
.btn-ghost:hover{box-shadow:inset 0 0 0 1.5px var(--brand);transform:translateY(-2px)}
.btn-ondark{background:#fff;color:var(--brand-deep)} .btn-ondark:hover{transform:translateY(-2px)}
.btn-sm{padding:.55em 1em;font-size:.86rem}
.btn-block{width:100%}

/* ---------- compliance strip ---------- */
.compliance{background:var(--brand-deeper);color:oklch(0.9 0.03 150);font-size:.78rem}
.compliance .in{max-width:1500px;margin-inline:auto;padding:.5em clamp(14px,3vw,28px);display:flex;gap:.4em 1.1em;flex-wrap:wrap;align-items:center}
.compliance b{color:oklch(0.97 0.04 110);font-weight:700} .compliance .sep{opacity:.4}
.compliance .badge{margin-left:auto;display:inline-flex;align-items:center;gap:.4em;background:oklch(1 0 0/.08);
  padding:.25em .7em;border-radius:999px;font-weight:600;color:oklch(0.95 0.03 120)}

/* ---------- app shell ---------- */
.app{display:grid;grid-template-columns:var(--side) 1fr;align-items:start}

/* sidebar */
.sidebar{position:sticky;top:0;height:100vh;background:
  radial-gradient(120% 60% at 0% 0%, oklch(0.36 0.085 164/.9), transparent 60%),
  linear-gradient(180deg,var(--brand-deep),var(--brand-deeper));
  color:oklch(0.92 0.03 140);display:flex;flex-direction:column;gap:.2rem;padding:1.2rem 1rem 1rem;overflow-y:auto}
.sb-brand{display:flex;align-items:center;gap:.6rem;padding:.3rem .5rem 1.1rem;color:#fff}
.sb-brand .mark{width:2.3rem;height:2.3rem;border-radius:12px;display:grid;place-items:center;flex:none;
  background:linear-gradient(150deg,var(--lime),var(--brand-600));color:var(--brand-deeper);box-shadow:0 8px 20px -8px var(--lime-700)}
.sb-brand .mark svg{width:1.6rem;height:1.6rem}
.sb-brand .nm{font-family:"Bricolage Grotesque";font-weight:800;font-size:1.4rem;letter-spacing:-.035em;line-height:1;position:relative;top:2.5px}
.sb-brand .tag{font-size:.625rem;letter-spacing:.09em;line-height:1.3;text-transform:uppercase;color:oklch(0.82 0.06 130);font-weight:700;display:inline-block;margin-top:.22rem;text-wrap:balance}
.sb-sect{font-size:.68rem;letter-spacing:.13em;text-transform:uppercase;color:oklch(0.74 0.05 135);font-weight:700;padding:1rem .8rem .4rem}
.navlink{display:flex;align-items:center;gap:.75rem;padding:.66rem .8rem;border-radius:11px;color:oklch(0.9 0.03 140);
  font-weight:600;font-size:.95rem;position:relative;transition:.18s var(--ease)}
.navlink svg{width:1.18rem;height:1.18rem;flex:none;opacity:.85}
.navlink .pill{margin-left:auto;font-size:.66rem;font-weight:800;background:var(--lime);color:var(--lime-ink);padding:.12em .5em;border-radius:999px}
.navlink:hover{background:oklch(1 0 0/.08);color:#fff}
.navlink.active{background:oklch(1 0 0/.12);color:#fff}
.navlink.active::before{content:"";position:absolute;left:-1rem;top:50%;transform:translateY(-50%);width:4px;height:60%;border-radius:0 4px 4px 0;background:var(--lime)}
.sb-foot{margin-top:auto;padding-top:1rem}
.sb-card{background:oklch(1 0 0/.07);border:1px solid oklch(1 0 0/.1);border-radius:var(--radius);padding:.9rem;display:flex;flex-direction:column;gap:.55rem}
.sb-card .t{font-weight:700;color:#fff;font-size:.92rem;display:flex;align-items:center;gap:.4em}
.sb-card p{font-size:.8rem;color:oklch(0.85 0.03 140)}

/* content + topbar */
.content{min-width:0}
.topbar{position:sticky;top:0;z-index:40;background:oklch(0.985 0.01 150/.82);backdrop-filter:saturate(1.5) blur(14px);
  border-bottom:1px solid var(--line);display:flex;align-items:center;gap:1rem;padding:.7rem clamp(16px,3vw,34px)}
.menubtn{display:none}
.search{display:flex;align-items:center;gap:.55em;background:var(--surface);border:1px solid var(--line);border-radius:999px;
  padding:.6em 1em;flex:1;max-width:520px;transition:.2s}
.search:focus-within{border-color:var(--brand);box-shadow:0 0 0 4px oklch(0.475 0.115 162/.12)}
.search svg{color:var(--muted);flex:none}
.search input{border:0;background:transparent;outline:0;font:inherit;width:100%;color:var(--ink)}
.search kbd{font-family:"Hanken Grotesk";font-size:.72rem;color:var(--muted);border:1px solid var(--line);border-bottom-width:2px;border-radius:6px;padding:.1em .45em;background:var(--bg)}
.tb-actions{margin-left:auto;display:flex;align-items:center;gap:.6rem}
.icbtn{position:relative;width:2.6rem;height:2.6rem;border-radius:12px;border:1px solid var(--line);background:var(--surface);
  display:grid;place-items:center;cursor:pointer;color:var(--brand-deep);transition:.2s}
.icbtn:hover{border-color:var(--brand);transform:translateY(-1px)}
.dotbadge{position:absolute;top:8px;right:9px;width:8px;height:8px;border-radius:50%;background:var(--lime);box-shadow:0 0 0 2px var(--surface)}
.cartcount{position:absolute;top:-5px;right:-5px;min-width:1.2rem;height:1.2rem;border-radius:999px;background:var(--brand);
  color:#fff;font-size:.7rem;font-weight:800;display:grid;place-items:center;padding:0 .25em;box-shadow:0 0 0 2px var(--surface)}
.favcount{position:absolute;top:-5px;right:-5px;min-width:1.2rem;height:1.2rem;border-radius:999px;background:var(--brand);
  color:#fff;font-size:.66rem;font-weight:800;display:grid;place-items:center;padding:0 .25em;box-shadow:0 0 0 2px var(--surface)}
.favcount[hidden]{display:none}
#favBtn:hover{color:#e0566a;border-color:#e0566a}

/* topbar profil çemberi (giriş yapılınca "Giriş/Üye ol" yerine) */
.topbar-av{width:2.6rem;height:2.6rem;border-radius:50%;border:1px solid var(--line);padding:0;flex:none;cursor:pointer;
  background:linear-gradient(150deg,var(--lime),var(--brand-600));color:var(--brand-deeper);
  font-weight:800;font-size:1.02rem;display:grid;place-items:center;transition:transform .15s ease,box-shadow .15s ease}
.topbar-av:hover{transform:translateY(-1px);box-shadow:0 5px 16px rgba(0,0,0,.16)}

/* favori çekmecesi (kalp → kayan panel) */
.favdrawer{position:fixed;inset:0;z-index:1200}
.favdrawer[hidden]{display:none}
.favdrawer-back{position:absolute;inset:0;background:rgba(12,22,16,.42);opacity:0;transition:opacity .22s ease}
.favdrawer.show .favdrawer-back{opacity:1}
.favpanel{position:absolute;top:0;right:0;height:100%;width:min(420px,92vw);background:var(--surface);border-left:1px solid var(--line);
  display:flex;flex-direction:column;transform:translateX(100%);transition:transform .24s cubic-bezier(.22,.61,.36,1);box-shadow:-14px 0 44px rgba(0,0,0,.18)}
.favdrawer.show .favpanel{transform:none}
.favpanel-head{display:flex;align-items:center;justify-content:space-between;padding:1.05rem 1.2rem;border-bottom:1px solid var(--line)}
.favpanel-head b{font-size:1.08rem}
.favpanel-x{width:2.2rem;height:2.2rem;border-radius:10px;border:1px solid var(--line);background:var(--surface);cursor:pointer;font-size:.95rem;line-height:1;color:var(--muted)}
.favpanel-x:hover{border-color:var(--brand);color:var(--ink)}
.favpanel-body{flex:1;overflow:auto;padding:.7rem .8rem 1.2rem}
.favpanel-foot{padding:.85rem 1.2rem;border-top:1px solid var(--line)}
.favrow{display:flex;gap:.7rem;align-items:center;padding:.55rem;border:1px solid var(--line);border-radius:14px;margin-bottom:.55rem;
  transition:opacity .17s ease,border-color .15s ease}
.favrow:hover{border-color:var(--brand)}
.favrow-img{width:3.4rem;height:3.4rem;border-radius:10px;object-fit:cover;background:var(--bg);flex:none}
.favrow-info{flex:1;min-width:0;cursor:pointer;display:flex;flex-direction:column;gap:.12rem}
.favrow-cat{font-size:.68rem;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}
.favrow-name{font-size:.85rem;line-height:1.25;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.favrow-pr{font-size:.84rem;font-weight:800;color:var(--brand)}
.favrow-pr s{color:var(--muted);font-weight:500;margin-left:.3rem}
.favrow-pr.out{color:var(--muted);font-weight:600}
.favrow-act{display:flex;flex-direction:column;gap:.35rem;flex:none}
.favrow-add{border:1px solid var(--line);background:var(--bg);border-radius:9px;padding:.32rem .5rem;font:inherit;font-size:.74rem;font-weight:700;cursor:pointer;white-space:nowrap;color:var(--ink)}
.favrow-add:hover{border-color:var(--brand);color:var(--brand)}
.favrow-rm{border:1px solid var(--line);background:var(--surface);border-radius:9px;width:1.9rem;height:1.7rem;cursor:pointer;color:var(--muted);line-height:1}
.favrow-rm:hover{border-color:#e0566a;color:#e0566a}
.favempty{text-align:center;padding:2.8rem 1.4rem;color:var(--muted)}
.favempty-ic{font-size:2.6rem;color:var(--brand);opacity:.5;margin-bottom:.3rem;line-height:1}
.favempty p{margin:.4rem 0 1rem}
body.favopen{overflow:hidden}

/* main + section heads */
main{padding:clamp(18px,2.4vw,30px) clamp(16px,3vw,34px) 3rem;display:flex;flex-direction:column;gap:clamp(34px,4.5vw,58px)}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:1.2rem}
.sec-head h2{font-size:clamp(1.5rem,2.6vw,2.15rem)}
.sec-head .sub{color:var(--muted);margin-top:.25rem}
.eye{display:inline-flex;align-items:center;gap:.45em;font-weight:700;font-size:.78rem;letter-spacing:.04em;text-transform:uppercase;
  color:var(--brand);background:oklch(0.475 0.115 162/.09);padding:.32em .7em;border-radius:999px}
.page-head{margin-bottom:.4rem}
.page-head h1{font-size:clamp(1.9rem,3.4vw,2.8rem)}
.page-head .sub{color:var(--muted);margin-top:.5rem;max-width:62ch}
.crumb{display:flex;gap:.5em;align-items:center;color:var(--muted);font-size:.84rem;font-weight:600;margin-bottom:.8rem}
.crumb a:hover{color:var(--brand)} .crumb .s{opacity:.5}

/* ---------- hero (home) ---------- */
.hero{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(20px,2.4vw,34px);align-items:start}
.hero-main{position:relative;overflow:hidden;border-radius:var(--radius-xl);padding:clamp(26px,3.2vw,46px);color:#fff;
  background:radial-gradient(130% 110% at 88% -10%, oklch(0.6 0.16 150/.55), transparent 55%),
   radial-gradient(90% 90% at 0% 110%, oklch(0.7 0.18 128/.3), transparent 55%),
   linear-gradient(155deg,var(--brand-deep),var(--brand-deeper));box-shadow:var(--shadow-lg)}
.hero-main::after{content:"";position:absolute;inset:0;opacity:.5;pointer-events:none;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E")}
.hero-main>*{position:relative;z-index:1}
.hero-tag{display:inline-flex;align-items:center;gap:.5em;background:oklch(1 0 0/.12);border:1px solid oklch(1 0 0/.18);
  color:oklch(0.95 0.04 120);font-weight:600;font-size:.82rem;padding:.4em .85em;border-radius:999px}
.hero-tag .dot{width:7px;height:7px;border-radius:50%;background:var(--lime);box-shadow:0 0 10px var(--lime)}
.hero-main h1{margin-top:1rem;font-size:clamp(2rem,3.6vw,3.2rem);font-weight:800;color:#fff}
.hero-main h1 em{font-style:normal;color:var(--lime)}
.hero-main .lead{margin-top:.9rem;color:oklch(0.9 0.03 135);font-size:clamp(1rem,1.2vw,1.1rem);max-width:46ch}
.finder{margin-top:1.5rem;background:oklch(1 0 0/.1);border:1px solid oklch(1 0 0/.16);border-radius:var(--radius-lg);padding:1.1rem}
.finder .fl{font-weight:700;font-size:.9rem;color:#fff;display:flex;align-items:center;gap:.5em}
.goals{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.85rem}
.goal{font-weight:700;font-size:.86rem;cursor:pointer;padding:.5em .9em;border-radius:999px;border:1.5px solid oklch(1 0 0/.22);
  background:oklch(1 0 0/.05);color:#fff;transition:.18s}
.goal:hover{border-color:var(--lime)}
.goal[aria-pressed="true"]{background:var(--lime);color:var(--lime-ink);border-color:var(--lime)}
.finder .go{margin-top:1rem;display:flex;gap:.6rem;align-items:center;flex-wrap:wrap}
.hero-stats{margin-top:1.5rem;display:flex;gap:1.6rem;flex-wrap:wrap}
.hero-stats .s b{font-family:"Bricolage Grotesque";font-weight:800;font-size:1.5rem;color:#fff;display:block;letter-spacing:-.03em}
.hero-stats .s span{font-size:.8rem;color:oklch(0.85 0.03 135)}
.panel-teaser{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-xl);box-shadow:var(--shadow);padding:1.1rem;display:flex;flex-direction:column;gap:.85rem;position:relative;overflow:hidden}
.pt-head{display:flex;align-items:center;gap:.6rem}
.pt-av{width:2.5rem;height:2.5rem;border-radius:50%;background:linear-gradient(150deg,var(--lime),var(--brand-600));flex:none;display:grid;place-items:center;font-weight:800;color:var(--brand-deeper)}
.pt-head .nm{font-weight:800;font-size:.98rem} .pt-head .rl{font-size:.76rem;color:var(--muted)}
.pt-head .live{margin-left:auto;font-size:.7rem;font-weight:700;color:var(--brand);background:oklch(0.475 0.115 162/.1);padding:.2em .55em;border-radius:999px}
.pt-stat{display:grid;grid-template-columns:1fr 1fr;gap:.6rem}
.pt-stat .b{background:var(--bg);border:1px solid var(--line);border-radius:var(--radius);padding:.7rem .8rem}
.pt-stat .b small{color:var(--muted);font-size:.74rem}
.pt-stat .b b{font-family:"Bricolage Grotesque";font-weight:800;font-size:1.25rem;display:block;margin-top:.1rem;letter-spacing:-.02em}
.pt-stat .b b.gold{color:var(--gold-ink)}
.pt-rank{background:linear-gradient(120deg,var(--gold-soft),oklch(0.97 0.02 120));border:1px solid var(--gold-soft);border-radius:var(--radius);padding:.8rem .85rem}
.pt-rank .rt{display:flex;justify-content:space-between;align-items:center;font-size:.8rem;font-weight:700;color:var(--gold-ink)}
.pt-rank .bar{height:8px;border-radius:999px;background:oklch(0.88 0.04 90);margin-top:.5rem;overflow:hidden}
.pt-rank .bar i{display:block;height:100%;width:0;border-radius:999px;background:linear-gradient(90deg,var(--gold),var(--lime-700));transition:width 1.4s var(--ease)}
.pt-rank small{display:block;margin-top:.4rem;color:var(--gold-ink);font-size:.74rem;opacity:.85}
.pt-locknote{display:flex;align-items:center;gap:.45em;font-size:.78rem;color:var(--muted);font-weight:600}
.pt-locknote svg{color:var(--brand)}

/* ---------- category rail ---------- */
.rail{display:flex;gap:.9rem;overflow-x:auto;padding-bottom:.4rem;scroll-snap-type:x mandatory;scrollbar-width:thin}
.rail::-webkit-scrollbar{height:7px} .rail::-webkit-scrollbar-thumb{background:var(--line);border-radius:99px}
.catcard{scroll-snap-align:start;flex:0 0 auto;width:185px;border-radius:var(--radius-lg);overflow:hidden;position:relative;background:var(--surface);border:1px solid var(--line);transition:.25s var(--ease);cursor:pointer}
.catcard:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:transparent}
.catcard img{width:100%;height:120px;object-fit:cover}
.catcard .cc{padding:.7rem .85rem .85rem}
.catcard .cc h3{font-family:"Hanken Grotesk";font-weight:800;font-size:1rem}
.catcard .cc small{color:var(--muted);font-size:.8rem}
.catcard .cc .go{margin-top:.5rem;display:inline-flex;align-items:center;gap:.3em;font-size:.8rem;font-weight:700;color:var(--brand)}

/* ---------- products ---------- */
.chips{display:flex;gap:.5rem;flex-wrap:wrap}
.chip{font-weight:700;font-size:.86rem;cursor:pointer;padding:.5em 1em;border-radius:999px;border:1.5px solid var(--line);background:var(--surface);color:var(--muted);transition:.18s}
.chip:hover{color:var(--ink)}
.chip[aria-pressed="true"]{background:var(--brand-deep);color:#fff;border-color:var(--brand-deep)}
.pgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(265px,1fr));gap:1.2rem}
.pcard{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;display:flex;flex-direction:column;position:relative;transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.pcard:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.pcard .picwrap{position:relative;overflow:hidden}
.pcard .pic{aspect-ratio:4/3;object-fit:cover;width:100%;transition:transform .5s var(--ease)}
.pcard:hover .pic{transform:scale(1.05)}
.pcard .fav{position:absolute;top:.6rem;right:.6rem;width:2rem;height:2rem;border-radius:50%;border:0;background:oklch(1 0 0/.9);display:grid;place-items:center;cursor:pointer;color:var(--muted);transition:.2s}
.pcard .fav:hover{color:var(--brand);transform:scale(1.1)}
.match-rib{position:absolute;top:.6rem;left:.6rem;background:var(--lime);color:var(--lime-ink);font-weight:800;font-size:.72rem;padding:.3em .6em;border-radius:8px;display:none;align-items:center;gap:.3em;z-index:2}
.pcard.match .match-rib{display:inline-flex}
.pcard.match{box-shadow:0 0 0 2px var(--lime), var(--shadow)}
.pcard .body{padding:.9rem 1rem 1rem;display:flex;flex-direction:column;gap:.35rem;flex:1}
.pcard .cat{color:var(--brand);font-weight:700;font-size:.74rem;text-transform:uppercase;letter-spacing:.04em}
.pcard h3{font-family:"Hanken Grotesk";font-weight:800;font-size:1.04rem;letter-spacing:-.01em}
.pcard p{color:var(--muted);font-size:.86rem;flex:1}
.pcard .stars{display:flex;align-items:center;gap:.3em;font-size:.78rem;color:var(--muted);font-weight:600}
.pcard .stars b{color:var(--gold-ink)}
.pcard .row{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-top:.45rem}
.lockprice{display:inline-flex;align-items:center;gap:.4em;font-weight:700;font-size:.8rem;color:var(--muted)}
.empty{color:var(--muted);padding:1rem 0}

/* ---------- two paths ---------- */
.paths{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
.path{position:relative;overflow:hidden;border-radius:var(--radius-xl);padding:clamp(22px,2.6vw,34px);display:flex;flex-direction:column;gap:.7rem;min-height:230px;color:#fff;transition:.28s var(--ease)}
.path:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.path.buy{background:linear-gradient(150deg,var(--brand-600),var(--brand-deep))}
.path.earn{background:linear-gradient(150deg,oklch(0.5 0.09 150),var(--brand-deeper))}
.path .ic{width:3rem;height:3rem;border-radius:14px;display:grid;place-items:center;background:oklch(1 0 0/.15);color:#fff}
.path.earn .ic{background:var(--lime);color:var(--lime-ink)}
.path h3{font-size:clamp(1.3rem,1.9vw,1.7rem);color:#fff}
.path p{color:oklch(0.9 0.03 135);font-size:.95rem;flex:1;max-width:40ch}
.path .go{display:inline-flex;align-items:center;gap:.4em;font-weight:800;color:#fff;margin-top:.3rem}
.path.earn .go{color:var(--lime)}
.path .num{position:absolute;right:1rem;bottom:.2rem;font-family:"Bricolage Grotesque";font-weight:800;font-size:6rem;color:oklch(1 0 0/.06);line-height:1}

/* ---------- rank / President ---------- */
.rank{background:radial-gradient(120% 80% at 100% 0%, oklch(0.55 0.1 150/.4), transparent 55%),linear-gradient(160deg,var(--brand-deep),var(--brand-deeper));border-radius:var(--radius-xl);padding:clamp(26px,3.2vw,46px);color:#fff;position:relative;overflow:hidden;box-shadow:var(--shadow-lg)}
.rank>.rkin{position:relative;z-index:1}
.rank h2{color:#fff;font-size:clamp(1.6rem,2.6vw,2.3rem)}
.rank .lead{color:oklch(0.9 0.03 135);margin-top:.7rem;max-width:60ch}
.ladder{margin-top:1.8rem;display:grid;grid-template-columns:repeat(5,1fr);gap:.7rem}
.rung{background:oklch(1 0 0/.07);border:1px solid oklch(1 0 0/.12);border-radius:var(--radius);padding:.9rem .85rem;position:relative}
.rung .lv{font-size:.72rem;color:oklch(0.8 0.05 135);font-weight:700;letter-spacing:.05em}
.rung .nm{font-family:"Bricolage Grotesque";font-weight:800;font-size:1.02rem;margin-top:.2rem;letter-spacing:-.02em}
.rung.is-pres{background:linear-gradient(150deg,var(--gold),oklch(0.7 0.12 70));border-color:var(--gold);color:var(--gold-ink)}
.rung.is-pres .lv{color:var(--gold-ink);opacity:.8} .rung.is-pres .nm{color:var(--brand-deeper)}
.rung.is-here{box-shadow:0 0 0 2px var(--lime)}
.rung .crown{position:absolute;top:.7rem;right:.7rem;color:var(--brand-deeper)}
.rung .youbadge{position:absolute;top:.6rem;right:.6rem;font-size:.6rem;font-weight:800;background:var(--lime);color:var(--lime-ink);padding:.1em .45em;border-radius:999px}
.rank-prog{margin-top:1.6rem;background:oklch(1 0 0/.08);border:1px solid oklch(1 0 0/.12);border-radius:var(--radius-lg);padding:1.1rem 1.2rem}
.rank-prog .t{display:flex;justify-content:space-between;font-size:.85rem;font-weight:700;color:#fff;flex-wrap:wrap;gap:.4rem}
.rank-prog .bar{height:10px;border-radius:999px;background:oklch(1 0 0/.14);margin-top:.6rem;overflow:hidden}
.rank-prog .bar i{display:block;height:100%;width:0;border-radius:999px;background:linear-gradient(90deg,var(--lime),var(--gold));transition:width 1.6s var(--ease)}
.rank-cta{margin-top:1.6rem;display:flex;gap:.7rem;flex-wrap:wrap;align-items:center}
.rank .fine{margin-top:1rem;font-size:.78rem;color:oklch(0.82 0.03 135)}.rank .fine a{text-decoration:underline;text-underline-offset:3px}

/* ---------- community ---------- */
.comm{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
.chan{border-radius:var(--radius-xl);padding:1.5rem 1.6rem;display:flex;flex-direction:column;gap:.6rem;color:#fff;min-height:180px;justify-content:space-between;position:relative;overflow:hidden}
.chan.wa{background:linear-gradient(150deg,oklch(0.66 0.15 150),oklch(0.52 0.13 152))}
.chan.tg{background:linear-gradient(150deg,oklch(0.64 0.12 232),oklch(0.5 0.12 240))}
.chan .ic{width:2.8rem;height:2.8rem;border-radius:14px;background:oklch(1 0 0/.18);display:grid;place-items:center}
.chan h3{font-family:"Bricolage Grotesque";font-weight:800;font-size:1.4rem;color:#fff}
.chan p{color:oklch(1 0 0/.9);font-size:.92rem}
.chan .meta{font-size:.8rem;opacity:.85;font-weight:600}
.chan a{align-self:flex-start;background:#fff;color:var(--ink);font-weight:800;padding:.55em 1.1em;border-radius:999px;font-size:.88rem}

/* ---------- trust strip ---------- */
.trust{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-xl);padding:clamp(18px,2vw,26px)}
.trust .ti{display:flex;gap:.7rem;align-items:flex-start}
.trust .ti .ic{width:2.4rem;height:2.4rem;border-radius:11px;background:oklch(0.475 0.115 162/.1);color:var(--brand);display:grid;place-items:center;flex:none}
.trust .ti b{font-family:"Hanken Grotesk";font-weight:800;font-size:.95rem;display:block}
.trust .ti small{color:var(--muted);font-size:.82rem}

/* =========================================================
   PAGE: Mağaza (full catalog)
   ========================================================= */
.shop{display:grid;grid-template-columns:248px 1fr;gap:clamp(18px,2.4vw,30px);align-items:start}
.filters{position:sticky;top:84px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:1.1rem 1.15rem;display:flex;flex-direction:column;gap:1.1rem}
.fgroup .fh{font-weight:800;font-size:.92rem;margin-bottom:.6rem;display:flex;align-items:center;justify-content:space-between}
.fopt{display:flex;align-items:center;gap:.55em;padding:.28rem 0;color:var(--muted);font-weight:600;font-size:.9rem;cursor:pointer}
.fopt input{accent-color:var(--brand);width:1.05em;height:1.05em}
.fopt:hover{color:var(--ink)}
.fopt .ct{margin-left:auto;font-size:.78rem;color:var(--muted);background:var(--bg);border:1px solid var(--line);padding:.05em .5em;border-radius:999px}
.fgroup .star{color:var(--gold-ink)}
.shop-main{min-width:0}
.sortbar{display:flex;align-items:center;gap:.8rem;flex-wrap:wrap;margin-bottom:1.1rem}
.sortbar .count{color:var(--muted);font-weight:600;font-size:.9rem}
.sortbar .sp{margin-left:auto;display:flex;align-items:center;gap:.5em}
.sel{font:inherit;font-weight:600;font-size:.88rem;color:var(--ink);background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:.5em .9em;cursor:pointer}
.view-toggle{display:flex;border:1px solid var(--line);border-radius:999px;overflow:hidden;background:var(--surface)}
.view-toggle button{border:0;background:transparent;padding:.5em .7em;cursor:pointer;color:var(--muted);display:grid;place-items:center}
.view-toggle button.on{background:var(--brand);color:#fff}

/* product detail modal */
.pd{position:fixed;inset:0;z-index:200;display:grid;place-items:center;padding:20px}
.pd[hidden]{display:none}
.pd .scrim{position:absolute;inset:0;background:oklch(0.2 0.04 165/.6);backdrop-filter:blur(4px)}
.pd .panel{position:relative;background:var(--surface);border-radius:var(--radius-xl);max-width:900px;width:100%;max-height:90vh;overflow:hidden;box-shadow:var(--shadow-lg);display:grid;grid-template-columns:.92fr 1.08fr;animation:pop .4s var(--ease)}
.pd .pimg{background:linear-gradient(165deg,oklch(0.975 0.015 150),oklch(0.945 0.032 150));display:grid;place-items:center;padding:1.8rem;position:sticky;top:0;align-self:start;height:90vh;max-height:600px}
.pd .pimg img{width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 18px 30px rgba(20,60,40,.18))}
.pd .pbody{padding:1.7rem 1.85rem;overflow-y:auto;max-height:90vh}
.pd .pbody::-webkit-scrollbar{width:8px}.pd .pbody::-webkit-scrollbar-thumb{background:var(--line);border-radius:99px}
.pd .pclose{position:absolute;top:.8rem;right:.8rem;width:2.3rem;height:2.3rem;border-radius:50%;border:0;background:oklch(1 0 0/.92);box-shadow:var(--shadow-sm);display:grid;place-items:center;cursor:pointer;z-index:3;transition:transform .25s var(--ease),background .2s}
.pd .pclose:hover{transform:rotate(90deg);background:#fff}
.pd .cat{color:var(--brand);font-weight:700;font-size:.78rem;text-transform:uppercase;letter-spacing:.04em}
.pd h3{font-family:"Bricolage Grotesque",system-ui;font-weight:800;font-size:clamp(1.4rem,2.4vw,1.85rem);line-height:1.15;margin-top:.35rem}
.pd .stars{margin-top:.55rem;color:var(--gold-ink);font-weight:700;font-size:.9rem}
.pd-chips{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.85rem}
.pd-chip{display:inline-flex;align-items:center;font-size:.76rem;font-weight:700;padding:.32rem .7rem;border-radius:99px;background:oklch(0.95 0.04 150);color:var(--brand-deep,#1a5a3a);border:1px solid oklch(0.9 0.045 150)}
.pd .lockbox{margin-top:1.1rem;background:linear-gradient(150deg,oklch(0.982 0.012 150),oklch(0.96 0.026 150));border:1px solid var(--line);border-radius:var(--radius);padding:.95rem 1.1rem}
.pd .lockbox b{font-family:"Bricolage Grotesque";font-size:1.05rem}
.pd .lockbox small{color:var(--muted)}
.pd .acts{margin-top:1rem;display:flex;gap:.6rem;flex-wrap:wrap}
.pd .acts .btn{flex:1 1 auto;min-width:140px}
.pd-descsec{margin-top:1.5rem;padding-top:1.3rem;border-top:1px solid var(--line)}
.pd-h4{font-family:"Bricolage Grotesque",system-ui;font-weight:700;font-size:1.02rem;margin:0 0 .7rem;color:var(--ink)}
.pd .desc{color:oklch(0.34 0.018 160);font-size:.96rem;line-height:1.7}
.pd .desc p{margin:0 0 .85rem}.pd .desc p:last-child{margin-bottom:0}
.pd .specs{margin-top:1rem;display:flex;flex-direction:column;gap:.5rem}
.pd .specs .r{display:flex;gap:.6rem;font-size:.9rem}.pd .specs .r svg{color:var(--brand);flex:none}

/* =========================================================
   PAGE: Üye Paneli (dashboard)
   ========================================================= */
.dash{display:flex;flex-direction:column;gap:clamp(20px,2.6vw,30px)}
.welcome{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}
.welcome .av{width:3.4rem;height:3.4rem;border-radius:50%;background:linear-gradient(150deg,var(--lime),var(--brand-600));display:grid;place-items:center;font-weight:800;font-size:1.2rem;color:var(--brand-deeper);flex:none}
.welcome h1{font-size:clamp(1.5rem,2.6vw,2rem)}
.welcome .sub{color:var(--muted)}
.welcome .act{margin-left:auto;display:flex;gap:.6rem;flex-wrap:wrap}
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.kpi{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:1.1rem 1.2rem;position:relative;overflow:hidden}
.kpi .ic{width:2.3rem;height:2.3rem;border-radius:11px;display:grid;place-items:center;background:oklch(0.475 0.115 162/.1);color:var(--brand);margin-bottom:.7rem}
.kpi.gold .ic{background:var(--gold-soft);color:var(--gold-ink)}
.kpi small{color:var(--muted);font-size:.82rem;font-weight:600}
.kpi b{font-family:"Bricolage Grotesque";font-weight:800;font-size:1.9rem;display:block;letter-spacing:-.03em;margin-top:.15rem}
.kpi .delta{font-size:.78rem;font-weight:700;color:var(--brand)}
.dash-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:clamp(16px,2vw,24px);align-items:start}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:1.2rem 1.3rem}
.card .ch{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;gap:.6rem}
.card .ch h3{font-family:"Hanken Grotesk";font-weight:800;font-size:1.1rem}
.card .ch a{font-size:.85rem;font-weight:700;color:var(--brand)}
.olist{display:flex;flex-direction:column;gap:.7rem}
.orow{display:flex;align-items:center;gap:.9rem;padding:.7rem;border:1px solid var(--line);border-radius:var(--radius)}
.orow img{width:3rem;height:3rem;border-radius:10px;object-fit:cover;flex:none}
.orow .oi{flex:1;min-width:0}
.orow .oi b{font-weight:800;font-size:.95rem;display:block}
.orow .oi small{color:var(--muted);font-size:.82rem}
.ostatus{font-size:.76rem;font-weight:800;padding:.25em .7em;border-radius:999px;white-space:nowrap}
.ostatus.yolda{background:oklch(0.95 0.06 230);color:oklch(0.45 0.12 240)}
.ostatus.hazir{background:var(--gold-soft);color:var(--gold-ink)}
.ostatus.teslim{background:oklch(0.93 0.08 150);color:var(--lime-ink)}
.ostatus.yeni{background:oklch(0.93 0.04 255);color:oklch(0.44 0.12 258)}
.ostatus.iptal{background:oklch(0.93 0.06 25);color:oklch(0.5 0.17 25)}

/* sipariş takibi v2 — açılır kart + durum çizelgesi (stepper) + detay */
.ocard{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:border-color .15s}
.ocard.open{border-color:var(--brand)}
.ohead{display:flex;align-items:center;gap:.9rem;width:100%;padding:.7rem;background:var(--surface);border:0;cursor:pointer;text-align:left;font:inherit;color:inherit}
.ohead:hover{background:var(--bg)}
.ohead .oi{flex:1;min-width:0}
.ohead .oi b{font-weight:800;font-size:.95rem;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ohead .oi small{color:var(--muted);font-size:.82rem}
.ochev{color:var(--muted);transition:transform .2s;flex:none;font-size:.8rem}
.ocard.open .ochev{transform:rotate(180deg)}
.ostep{display:flex;align-items:flex-start;padding:.25rem .8rem .75rem}
.ostep .step{flex:1;display:flex;flex-direction:column;align-items:center;gap:.32rem;position:relative}
.ostep .step::before{content:'';position:absolute;top:6px;left:-50%;width:100%;height:2px;background:var(--line)}
.ostep .step:first-child::before{display:none}
.ostep .step.done::before{background:var(--brand)}
.ostep .dot{width:14px;height:14px;border-radius:50%;background:var(--surface);border:2px solid var(--line);z-index:1}
.ostep .step.done .dot{background:var(--brand);border-color:var(--brand)}
.ostep .step.cur .dot{background:var(--lime);border-color:var(--brand)}
.ostep .sl{font-size:.66rem;color:var(--muted);text-align:center;line-height:1.12}
.ostep .step.done .sl{color:var(--ink);font-weight:700}
.ocancel{padding:.1rem .9rem .75rem;color:oklch(0.55 0.17 25);font-size:.82rem;font-weight:600}
.odetail{padding:.3rem .85rem .85rem;border-top:1px dashed var(--line)}
.oitems{list-style:none;margin:.55rem 0 0;padding:0;display:flex;flex-direction:column;gap:.34rem}
.oitems li{display:flex;justify-content:space-between;gap:1rem;font-size:.85rem}
.oitems li b{color:var(--brand);white-space:nowrap}
.ometa{display:flex;flex-direction:column;gap:.35rem;margin-top:.55rem;padding-top:.55rem;border-top:1px solid var(--line)}
.ometa>div{display:flex;justify-content:space-between;gap:1rem;font-size:.82rem}
.ometa span{color:var(--muted)}
.ometa b{font-weight:700;text-align:right}
.goalring{display:flex;align-items:center;gap:1.1rem}
.ring{--p:64;width:92px;height:92px;border-radius:50%;flex:none;display:grid;place-items:center;
  background:conic-gradient(var(--brand) calc(var(--p)*1%), oklch(0.92 0.02 160) 0)}
.ring span{width:70px;height:70px;border-radius:50%;background:var(--surface);display:grid;place-items:center;font-family:"Bricolage Grotesque";font-weight:800;font-size:1.2rem}
.goalring .gt b{display:block;font-weight:800}.goalring .gt small{color:var(--muted);font-size:.85rem}
.rankwidget{background:linear-gradient(150deg,var(--brand-deep),var(--brand-deeper));color:#fff;border-radius:var(--radius-lg);padding:1.3rem}
.rankwidget .rk{display:flex;align-items:center;gap:.6rem}
.rankwidget .crown{width:2.4rem;height:2.4rem;border-radius:11px;background:var(--gold);color:var(--gold-ink);display:grid;place-items:center}
.rankwidget .rk b{font-family:"Bricolage Grotesque";font-size:1.15rem}.rankwidget .rk small{color:oklch(0.85 0.03 135);display:block}
.rankwidget .bar{height:9px;border-radius:999px;background:oklch(1 0 0/.15);margin-top:1rem;overflow:hidden}
.rankwidget .bar i{display:block;height:100%;width:0;border-radius:999px;background:linear-gradient(90deg,var(--lime),var(--gold));transition:width 1.5s var(--ease)}
.rankwidget .nx{margin-top:.6rem;font-size:.82rem;color:oklch(0.88 0.03 135)}
.team{display:flex;flex-direction:column;gap:.55rem}
.tmrow{display:flex;align-items:center;gap:.7rem;font-size:.9rem}
.tmrow .ta{width:2rem;height:2rem;border-radius:50%;background:var(--surface-2);display:grid;place-items:center;font-weight:800;font-size:.8rem;color:var(--brand-deep)}
.tmrow .tn{font-weight:700} .tmrow .tl{margin-left:auto;font-size:.76rem;font-weight:700;color:var(--muted)}
.reco{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.8rem}
.recocard{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;cursor:pointer;transition:.2s}
.recocard:hover{box-shadow:var(--shadow-sm);transform:translateY(-3px)}
.recocard img{height:90px;width:100%;object-fit:cover}
.recocard .rb{padding:.55rem .6rem}.recocard .rb b{font-size:.85rem;font-weight:700;display:block}.recocard .rb small{color:var(--muted);font-size:.74rem}

/* =========================================================
   PAGE: Distribütör Ol
   ========================================================= */
.split-hero{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(18px,2.4vw,30px);align-items:stretch}
.benefit-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem}
.benefit{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:1.3rem;display:flex;flex-direction:column;gap:.55rem}
.benefit .ic{width:2.8rem;height:2.8rem;border-radius:13px;background:oklch(0.475 0.115 162/.1);color:var(--brand);display:grid;place-items:center}
.benefit h3{font-family:"Hanken Grotesk";font-weight:800;font-size:1.1rem}
.benefit p{color:var(--muted);font-size:.9rem}
.stepper{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;counter-reset:st}
.step{position:relative;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:1.3rem 1.2rem 1.2rem}
.step::before{counter-increment:st;content:counter(st);position:absolute;top:-.9rem;left:1.2rem;width:2.1rem;height:2.1rem;border-radius:50%;background:var(--brand);color:#fff;display:grid;place-items:center;font-family:"Bricolage Grotesque";font-weight:800;box-shadow:0 8px 18px -8px var(--brand)}
.step h3{font-family:"Hanken Grotesk";font-weight:800;font-size:1.05rem;margin-top:.7rem}
.step p{color:var(--muted);font-size:.88rem;margin-top:.3rem}
.compare{width:100%;border-collapse:separate;border-spacing:0;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden}
.compare th,.compare td{padding:.95rem 1.1rem;text-align:left;border-bottom:1px solid var(--line);font-size:.92rem}
.compare thead th{background:var(--surface-2);font-family:"Hanken Grotesk";font-weight:800}
.compare td.y{color:var(--brand);font-weight:800}.compare td.n{color:var(--muted)}
.compare tr:last-child td{border-bottom:0}
.appform{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-xl);padding:clamp(20px,2.6vw,32px);max-width:680px}
.field{margin-bottom:1rem}
.field label{font-weight:700;font-size:.88rem;display:block;margin-bottom:.4rem}
.field input,.field select,.field textarea{width:100%;font:inherit;color:var(--ink);background:var(--bg);border:1px solid var(--line);border-radius:12px;padding:.7em .9em;outline:0;transition:.18s}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--brand);box-shadow:0 0 0 4px oklch(0.475 0.115 162/.12)}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.faq{display:flex;flex-direction:column;gap:.7rem}
.qa{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.qa summary{padding:1rem 1.2rem;font-weight:700;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center}
.qa summary::-webkit-details-marker{display:none}
.qa summary::after{content:"+";font-size:1.3rem;color:var(--brand);font-weight:700}
.qa[open] summary::after{content:"–"}
.qa .ans{padding:0 1.2rem 1.1rem;color:var(--muted);font-size:.92rem}

/* =========================================================
   PAGE: Topluluk
   ========================================================= */
.feed{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.1rem}
.post{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;display:flex;flex-direction:column;transition:.25s var(--ease)}
.post:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.post img{height:160px;width:100%;object-fit:cover}
.post .pb{padding:1rem 1.1rem 1.1rem;display:flex;flex-direction:column;gap:.45rem;flex:1}
.post .tagp{align-self:flex-start;font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.04em;color:var(--brand);background:oklch(0.475 0.115 162/.1);padding:.2em .6em;border-radius:999px}
.post h3{font-family:"Hanken Grotesk";font-weight:800;font-size:1.08rem}
.post p{color:var(--muted);font-size:.88rem;flex:1}
.post .pf{display:flex;align-items:center;gap:.5em;color:var(--muted);font-size:.8rem;font-weight:600}
.events{display:flex;flex-direction:column;gap:.7rem}
.event{display:flex;align-items:center;gap:1rem;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:.9rem 1.1rem}
.event .date{flex:none;width:3.4rem;text-align:center;background:var(--brand-deep);color:#fff;border-radius:12px;padding:.4rem}
.event .date b{font-family:"Bricolage Grotesque";font-size:1.3rem;display:block;line-height:1}
.event .date small{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em}
.event .ei{flex:1}.event .ei b{font-weight:800;display:block}.event .ei small{color:var(--muted)}
.event .live2{font-size:.72rem;font-weight:800;color:var(--danger)}
.testi{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.1rem}
.quote{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:1.3rem}
.quote .stars{color:var(--gold-ink);font-weight:700}
.quote p{margin-top:.6rem;font-size:.95rem}
.quote .who{margin-top:.9rem;display:flex;align-items:center;gap:.6rem}
.quote .who .a{width:2.2rem;height:2.2rem;border-radius:50%;background:var(--surface-2);display:grid;place-items:center;font-weight:800;color:var(--brand-deep)}
.quote .who b{font-weight:800;font-size:.9rem}.quote .who small{color:var(--muted);font-size:.8rem;display:block}

/* =========================================================
   footer · modal · toast · mobile nav · reveal
   ========================================================= */
footer{background:var(--brand-deeper);color:oklch(0.85 0.03 140);font-size:.9rem;margin-top:1rem}
footer .fin{max-width:1500px;margin-inline:auto;padding:clamp(34px,4vw,52px) clamp(16px,3vw,34px)}
.foot-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:1.6rem;padding-bottom:1.6rem;border-bottom:1px solid oklch(1 0 0/.1)}
.foot-brand{font-family:"Bricolage Grotesque";font-weight:800;font-size:1.5rem;color:#fff;letter-spacing:-.04em}
.foot-top h4{color:#fff;font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;margin:0 0 .7rem;font-weight:700}
.foot-top a{display:block;color:oklch(0.84 0.03 140);padding:.2rem 0}.foot-top a:hover{color:var(--lime)}
.foot-legal{padding-top:1.4rem;color:oklch(0.74 0.03 140);font-size:.79rem;line-height:1.65}.foot-legal b{color:oklch(0.92 0.03 140)}

.modal{position:fixed;inset:0;z-index:200;display:grid;place-items:center;padding:20px}
.modal[hidden]{display:none}
.modal .scrim{position:absolute;inset:0;background:oklch(0.2 0.04 165/.6);backdrop-filter:blur(4px)}
.modal .panel{position:relative;background:var(--surface);border-radius:var(--radius-xl);max-width:460px;width:100%;padding:1.9rem;box-shadow:var(--shadow-lg);animation:pop .4s var(--ease)}
@keyframes pop{from{opacity:0;transform:translateY(14px) scale(.97)}to{opacity:1;transform:none}}
.modal .lg{display:inline-flex;align-items:center;gap:.5em;font-family:"Bricolage Grotesque";font-weight:800;color:var(--brand-deep);font-size:1.05rem}
.modal .lg .m{width:1.7rem;height:1.7rem;border-radius:8px;background:linear-gradient(150deg,var(--lime),var(--brand-600));display:grid;place-items:center;color:var(--brand-deeper)}
.modal h3{margin-top:1rem;font-family:"Bricolage Grotesque";font-size:1.4rem}
.modal p{margin-top:.6rem;color:var(--muted);font-size:.93rem}
.modal .acts{margin-top:1.4rem;display:flex;gap:.6rem;flex-wrap:wrap}
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--brand-deeper);color:#fff;padding:.75em 1.2em;border-radius:999px;font-weight:700;font-size:.9rem;opacity:0;pointer-events:none;transition:.35s var(--ease);z-index:250;box-shadow:var(--shadow)}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* auth-gated page: blur content until login */
body.locked .content main{filter:blur(8px);pointer-events:none;user-select:none;transition:filter .3s var(--ease)}

.botnav{display:none}
@media(prefers-reduced-motion:no-preference){
  html.js [data-reveal]{opacity:0;transform:translateY(18px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
  html.js [data-reveal].in{opacity:1;transform:none}
}

/* ---------- responsive ---------- */
@media(max-width:1080px){.hero{grid-template-columns:1fr}.panel-teaser{order:-1}.dash-grid{grid-template-columns:1fr}.split-hero{grid-template-columns:1fr}}
@media(max-width:980px){
  .app{grid-template-columns:1fr}
  .sidebar{display:none}
  .menubtn{display:grid}
  .ladder{grid-template-columns:repeat(2,1fr)} .rung.is-pres{grid-column:1/-1}
  .trust{grid-template-columns:1fr 1fr}
  .foot-top{grid-template-columns:1fr 1fr}
  .kpis{grid-template-columns:1fr 1fr}
  .benefit-grid{grid-template-columns:1fr}
  .stepper{grid-template-columns:1fr 1fr;gap:1.4rem 1rem}
  .shop{grid-template-columns:1fr}
  .filters{position:static}
  .pd .panel{grid-template-columns:1fr;overflow:auto}
  .pd .pimg{position:static;height:auto;max-height:300px;min-height:230px;padding:1.4rem}
  .pd .pbody{overflow:visible;max-height:none}
  main{padding-bottom:6rem}
  .botnav{position:fixed;bottom:0;left:0;right:0;z-index:60;display:flex;justify-content:space-around;background:oklch(0.99 0.008 150/.92);backdrop-filter:blur(14px);border-top:1px solid var(--line);padding:.4rem .3rem .55rem}
  .botnav a{display:flex;flex-direction:column;align-items:center;gap:.15rem;font-size:.66rem;font-weight:700;color:var(--muted);padding:.3rem .6rem;border-radius:10px}
  .botnav a.active{color:var(--brand)} .botnav a svg{width:1.3rem;height:1.3rem}
}
@media(max-width:680px){.paths{grid-template-columns:1fr}.comm{grid-template-columns:1fr}.trust{grid-template-columns:1fr}.kpis{grid-template-columns:1fr 1fr}.stepper{grid-template-columns:1fr}.field-row{grid-template-columns:1fr}}

.drawer{position:fixed;inset:0;z-index:120;display:none}
.drawer[open]{display:block}
.drawer .scrim{position:absolute;inset:0;background:oklch(0.2 0.04 165/.5)}
.drawer .panel{position:absolute;left:0;top:0;bottom:0;width:min(82vw,300px);background:linear-gradient(180deg,var(--brand-deep),var(--brand-deeper));color:#fff;padding:1.2rem 1rem;overflow-y:auto;animation:slidein .35s var(--ease)}
@keyframes slidein{from{transform:translateX(-100%)}to{transform:none}}

/* ---- ortak ürün kartı ekleri: indirim rozeti + üstü çizili fiyat + stok (mağaza/ana sayfa/bulucu) ---- */
.disc-rib{position:absolute;top:.6rem;left:.6rem;z-index:1;background:var(--danger,#d64545);color:#fff;font-weight:800;font-size:.74rem;padding:.2rem .5rem;border-radius:999px;box-shadow:0 4px 12px -4px rgba(0,0,0,.4)}
.priceblock{display:inline-flex;align-items:baseline;gap:.4rem;flex-wrap:wrap;min-width:0}
.oldprice{color:var(--muted);text-decoration:line-through;font-size:.85rem;font-weight:600}
.soldlabel{font-weight:800;color:var(--muted);font-size:.9rem}
.pcard.soldout{opacity:.66}
.pcard .row{flex-wrap:wrap;row-gap:.5rem}
.pcard .stars .rv-count{color:var(--muted);font-weight:600}
.pcard .stars.stars-empty{font-size:.78rem}

/* Hesabım paneli (favdrawer/favpanel kabuğunu yeniden kullanır) */
.acc-id{display:flex;gap:.8rem;align-items:center;padding:.3rem .1rem 1rem;border-bottom:1px solid var(--line);margin-bottom:1.1rem}
.acc-av{width:3rem;height:3rem;border-radius:50%;background:var(--brand);color:#fff;display:grid;place-items:center;font-weight:800;font-size:1.2rem;flex:none}
.acc-id b{display:block;font-size:1rem;line-height:1.2}
.acc-id span{display:block;font-size:.82rem;color:var(--muted)}
.acc-id .acc-role{margin-top:.15rem;font-size:.72rem;font-weight:700;color:var(--brand);text-transform:capitalize}
.acc-sec{margin-bottom:1.4rem}
.acc-sec h4{font-size:.74rem;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);margin:0 0 .6rem}
.acc-f{display:flex;flex-direction:column;gap:.25rem;font-size:.76rem;color:var(--muted);font-weight:600;margin-bottom:.6rem}
.acc-f input{font:inherit;font-weight:500;color:var(--ink);padding:.55rem .65rem;border:1px solid var(--line);border-radius:10px;background:var(--bg,#fff)}
.acc-f input:focus{outline:none;border-color:var(--brand)}
.acc-f input[readonly]{background:oklch(0.96 0.005 250);color:var(--muted);cursor:not-allowed}
.acc-err{color:var(--danger);font-size:.78rem;margin:.05rem 0 .5rem;min-height:0}
.acc-err:empty{margin:0}
.acc-toggle{display:flex;align-items:center;justify-content:space-between;gap:1rem;font-size:.86rem;font-weight:600;cursor:pointer;color:var(--ink)}
.acc-toggle input{width:1.3rem;height:1.3rem;accent-color:var(--brand);cursor:pointer;flex:none}
.acc-logout{width:100%;margin-top:.3rem;color:var(--danger);border-color:var(--danger)}
/* ana sayfa "Önerilen Ürünler": ürün kartlarını tek-satır şeritte tut */
#recoRail .pcard{flex:0 0 200px;width:200px;scroll-snap-align:start}
#recoRail{scrollbar-width:none}
#recoRail::-webkit-scrollbar{display:none}

/* =========================================================
   TASARIM YENİLEME v1 — canlılık katmanı (2026-06-27)
   Ek (additive) katman: mevcut kurallar korunur, bunlar sonda → override.
   Tümü prefers-reduced-motion'a saygılı.
   ========================================================= */

/* — bölüm üst-etiketi: altın varyant (renk ritmi) — */
.eye.gold{color:var(--gold-ink);background:linear-gradient(120deg,var(--gold-soft),oklch(0.95 0.04 110))}
.eye.lime{color:var(--lime-ink);background:oklch(0.865 0.185 126/.16)}

/* — indirim rozeti: kırmızı yerine ışıltılı ALTIN (göze çarpar) — */
.disc-rib{background:linear-gradient(135deg,var(--gold),oklch(0.72 0.15 64));color:oklch(0.28 0.06 70);
  box-shadow:0 5px 16px -5px oklch(0.6 0.13 70/.75);letter-spacing:.01em}

/* — kart hover'da daha derin kalkış — */
.pcard:hover,.path:hover,.catcard:hover,.chan:hover{box-shadow:var(--shadow-lg)}

/* — bölüm "zone": ferah, tonlu, yuvarlak bant (açık↔koyu ritmi) — */
.zone{background:linear-gradient(180deg,var(--surface-2),oklch(0.985 0.01 150));
  border:1px solid var(--line);border-radius:var(--radius-xl);
  padding:clamp(20px,2.6vw,34px);box-shadow:inset 0 1px 0 oklch(1 0 0/.6)}

@media(prefers-reduced-motion:no-preference){
  /* — ürün/paket kartları: sıralı (stagger) yumuşak giriş — */
  @keyframes cardIn{from{opacity:0;transform:translateY(18px) scale(.985)}to{opacity:1;transform:none}}
  #recoRail .pcard,#grid .pcard{animation:cardIn .6s var(--ease) both}
  #recoRail .pcard:nth-child(2),#grid .pcard:nth-child(2){animation-delay:.07s}
  #recoRail .pcard:nth-child(3),#grid .pcard:nth-child(3){animation-delay:.14s}
  #recoRail .pcard:nth-child(4),#grid .pcard:nth-child(4){animation-delay:.21s}
  #recoRail .pcard:nth-child(5),#grid .pcard:nth-child(5){animation-delay:.28s}
  #recoRail .pcard:nth-child(6),#grid .pcard:nth-child(6){animation-delay:.35s}
  #grid .pcard:nth-child(7){animation-delay:.42s}
  #grid .pcard:nth-child(n+8){animation-delay:.49s}

  /* — hero: yüzen ışıltı küreciği (derinlik + hareket) — */
  @keyframes orbFloat{0%{transform:translate(0,0) scale(1);opacity:.85}50%{transform:translate(-22px,16px) scale(1.15);opacity:1}100%{transform:translate(0,0) scale(1);opacity:.85}}
  .hero-main::before{content:"";position:absolute;z-index:0;width:42%;aspect-ratio:1;top:-14%;right:-4%;border-radius:50%;
    background:radial-gradient(circle,oklch(0.82 0.19 128/.45),transparent 66%);filter:blur(6px);pointer-events:none;
    animation:orbFloat 11s ease-in-out infinite}

  /* — vurgu kelimesi: akan altın↔lime gradyan yazı — */
  @keyframes shineText{to{background-position:200% center}}
  .hero-main h1 em{background:linear-gradient(100deg,var(--lime) 8%,var(--gold) 48%,var(--lime) 88%);
    background-size:200% auto;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;
    animation:shineText 6s linear infinite}

  /* — birincil CTA'larda parıltı süpürmesi (hover) — */
  @keyframes sweep{to{left:145%}}
  .btn-lime,.btn-primary{position:relative;overflow:hidden}
  .btn-lime::after,.btn-primary::after{content:"";position:absolute;top:0;left:-130%;width:55%;height:100%;pointer-events:none;
    background:linear-gradient(105deg,transparent,oklch(1 0 0/.5),transparent);transform:skewX(-18deg)}
  .btn-lime:hover::after,.btn-primary:hover::after{animation:sweep .8s var(--ease)}

  /* — hero istatistik sayacı belirirken hafif yükselsin — */
  @keyframes statRise{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
  .hero-stats .s{animation:statRise .6s var(--ease) both}
  .hero-stats .s:nth-child(2){animation-delay:.12s}
  .hero-stats .s:nth-child(3){animation-delay:.24s}

  /* — "Bana uygun ürünleri bul" küresel nabız (dikkat çek) — */
  @keyframes finderGlow{0%,100%{box-shadow:0 10px 24px -12px var(--lime-700)}50%{box-shadow:0 12px 34px -10px var(--lime-700),0 0 0 4px oklch(0.865 0.185 126/.18)}}
  #findBtn{animation:finderGlow 2.8s ease-in-out infinite}
}

/* =========================================================
   TASARIM YENİLEME v2 — açık & premium zemin + kabaran kartlar (2026-06-27)
   (A yönü: krem/nane-yeşili gradyan zemin, mevcut emerald markayla harmanlı)
   Hepsi additive override; istenirse bu iki blok silinince eski hale döner.
   ========================================================= */

/* — SAYFA ZEMİNİ: krem→nane gradyan + yumuşak ışık lekeleri.
   Performans: 'background-attachment:fixed' yerine sabit pseudo-katman →
   kaydırmada zemin yeniden boyanmaz (kendi compositor katmanında kalır). */
body{background:oklch(0.99 0.013 104);min-height:100vh}
body::before{
  content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:
    radial-gradient(56% 46% at 12% -4%, oklch(0.91 0.075 142/.55), transparent 60%),
    radial-gradient(46% 42% at 103% 5%, oklch(0.93 0.085 92/.48), transparent 56%),
    radial-gradient(72% 64% at 97% 103%, oklch(0.90 0.06 156/.4), transparent 60%),
    linear-gradient(176deg, oklch(0.99 0.013 104), oklch(0.962 0.026 152) 68%, oklch(0.95 0.03 150));
  transform:translateZ(0)}

/* — BEYAZ KUTULAR artık zeminden "kabarıyor": yumuşak derin gölge + ince kenar — */
.pcard,.panel-teaser,.kpi,.card,.trust,.filters,.chan{border-color:oklch(0.91 0.022 150);box-shadow:var(--shadow)}
.pcard{background:linear-gradient(180deg,#fff,oklch(0.992 0.006 150))}
.pcard:hover{box-shadow:var(--shadow-lg);transform:translateY(-6px)}

/* — BÖLÜM BANTLARI (.zone): belirgin nane/krem tonlu, yuvarlak, ferah — */
.zone{
  background:linear-gradient(180deg, oklch(0.955 0.038 150), oklch(0.986 0.016 108));
  border:1px solid oklch(0.9 0.032 150);border-radius:var(--radius-xl);
  padding:clamp(24px,3.2vw,44px);box-shadow:var(--shadow-sm), inset 0 1px 0 oklch(1 0 0/.7)}

/* — NEFES & HİYERARŞİ: bölümler arası boşluk + daha iri başlık — */
main{gap:clamp(42px,5.2vw,70px)}
.sec-head h2{font-size:clamp(1.7rem,2.9vw,2.5rem)}
.sec-head .eye{box-shadow:0 8px 20px -12px currentColor}

/* — HERO kartı zemine otursun: hafif iç ışık çizgisi — */
.hero-main{box-shadow:var(--shadow-lg), inset 0 0 0 1px oklch(1 0 0/.06)}
#recoRail{padding:.2rem .1rem .7rem}

/* =========================================================
   TASARIM YENİLEME v3 — KOYU YEŞİL ALANLAR (sidebar + kutular)
   "hep aynı düz yeşil" hissini kır: derinlik + yumuşak ışık + zonlar arası
   ton çeşitliliği. Marka emerald kimliği korunur.
   ========================================================= */

/* — SOL NAV (sidebar): belirgin parlak-üst → koyu-alt emerald gradyan + ışık — */
.sidebar{
  background:
    radial-gradient(100% 44% at 50% -6%, oklch(0.58 0.15 160/.7), transparent 62%),
    linear-gradient(180deg, oklch(0.40 0.11 162), oklch(0.21 0.055 168) 80%);
  box-shadow:inset -1px 0 0 oklch(1 0 0/.06)}
.navlink.active{box-shadow:inset 0 0 0 1px oklch(0.865 0.185 126/.28)}

/* — HERO: belirgin TEAL'e kayar (sidebar emerald'inden ayrışsın) + güçlü parıltı — */
.hero-main{
  background:
    radial-gradient(120% 100% at 86% -12%, oklch(0.62 0.16 175/.6), transparent 55%),
    radial-gradient(95% 95% at -6% 112%, oklch(0.74 0.18 150/.32), transparent 55%),
    linear-gradient(150deg, oklch(0.33 0.085 188), oklch(0.20 0.05 184))}

/* — İKİ YOL: buy EMERALD, earn belirgin TEAL-MAVİ → gözle görülür ayrışma — */
.path.buy{background:
   radial-gradient(85% 80% at 100% 0%, oklch(0.58 0.14 158/.5), transparent 60%),
   linear-gradient(150deg, oklch(0.50 0.13 160), oklch(0.25 0.07 162))}
.path.earn{background:
   radial-gradient(85% 80% at 0% 100%, oklch(0.64 0.13 205/.42), transparent 60%),
   linear-gradient(150deg, oklch(0.44 0.10 210), oklch(0.23 0.06 222))}

/* — KAZANÇ bölümü: belirgin ALTIN sıcaklığı (premium çapa) — */
.rank{background:
   radial-gradient(100% 85% at 100% -10%, oklch(0.72 0.13 84/.42), transparent 55%),
   radial-gradient(80% 70% at 0% 108%, oklch(0.52 0.11 150/.4), transparent 55%),
   linear-gradient(160deg, oklch(0.30 0.075 165), oklch(0.18 0.05 172))}

/* — TOPLULUK kanalları daha canlı (yeşil monotonluğu kırmaya devam) — */
.chan.wa{background:radial-gradient(80% 80% at 100% 0%, oklch(0.74 0.17 150/.42), transparent 60%), linear-gradient(150deg, oklch(0.62 0.15 150), oklch(0.40 0.11 158))}
