/* ───────────────────────────────────────────────────────────
   T15 User Dashboard — app shell + all menu views
   Editorial × premium health. Depends on tokens.css
   ─────────────────────────────────────────────────────────── */

.db { display: grid; grid-template-columns: 256px 1fr; min-height: 100vh; }

/* ── SIDEBAR ── */
.db-side { background: var(--color-black); color: var(--color-white); display: flex; flex-direction: column; position: sticky; top: 0; height: 100vh; }
.db-side-logo { display: flex; align-items: center; gap: 10px; padding: 24px 24px 28px; font-family: var(--font-display); font-weight: 700; font-size: 18px; letter-spacing: -0.02em; }
.db-side-logo .m { width: 28px; height: 28px; background: var(--color-primary); border-radius: 50%; display: grid; place-items: center; font-family: var(--font-body); font-size: 13px; font-weight: 800; }
.db-nav { flex: 1; padding: 0 14px; overflow-y: auto; }
.db-nav-group { margin-bottom: 22px; }
.db-nav-group .gl-lbl { font-size: 10px; text-transform: uppercase; letter-spacing: 0.12em; color: rgba(255,255,255,.38); font-weight: 700; padding: 0 12px; margin-bottom: 8px; }
.db-nav a { display: flex; align-items: center; gap: 12px; padding: 10px 12px; border-radius: var(--r-1); font-size: 14px; font-weight: 500; color: rgba(255,255,255,.72); margin-bottom: 2px; transition: all .14s ease; cursor: pointer; }
.db-nav a svg { opacity: .8; flex-shrink: 0; }
.db-nav a:hover { background: rgba(255,255,255,.07); color: var(--color-white); }
.db-nav a.on { background: var(--color-primary); color: var(--color-white); }
.db-nav a.on svg { opacity: 1; }
.db-nav a .badge { margin-left: auto; font-size: 11px; font-weight: 700; background: var(--color-secondary); color: var(--color-black); border-radius: var(--r-pill); padding: 1px 8px; }
.db-upgrade { margin: 14px; padding: 18px; background: linear-gradient(160deg, var(--primary-600), var(--primary-900)); border-radius: 0; }
.db-upgrade .t { font-family: var(--font-display); font-size: 17px; font-weight: 600; margin-bottom: 6px; }
.db-upgrade p { font-size: 12px; color: rgba(255,255,255,.78); line-height: 1.5; margin-bottom: 14px; }
.db-upgrade .b { display: block; text-align: center; background: var(--color-white); color: var(--color-primary); font-size: 13px; font-weight: 700; padding: 10px; border-radius: var(--r-1); cursor: pointer; }
.db-side-user { display: flex; align-items: center; gap: 12px; padding: 16px 20px; border-top: 1px solid rgba(255,255,255,.1); }
.db-side-user .av { width: 38px; height: 38px; border-radius: 50%; background: center/cover var(--color-bg-soft); flex-shrink: 0; }
.db-side-user .nm { font-size: 13.5px; font-weight: 600; }
.db-side-user .em { font-size: 11px; color: rgba(255,255,255,.5); }

/* ── MAIN ── */
.db-main { min-width: 0; }
.db-top { position: sticky; top: 0; z-index: 20; background: rgba(255,255,255,.92); backdrop-filter: blur(10px); border-bottom: 1px solid var(--color-line); padding: 18px 40px; display: flex; align-items: center; gap: 20px; }
.db-top h1 { font-family: var(--font-display); font-size: 24px; font-weight: 600; letter-spacing: -0.01em; }
.db-top h1 .day { color: var(--color-ink-3); font-weight: 500; }
.db-top-actions { margin-left: auto; display: flex; align-items: center; gap: 12px; }
.db-search { width: 240px; height: 42px; border: 1.5px solid var(--color-line); border-radius: var(--r-pill); display: flex; align-items: center; gap: 10px; padding: 0 16px; background: var(--color-white); }
.db-search svg { color: var(--color-ink-3); }
.db-search input { border: none; outline: none; flex: 1; min-width: 0; font-size: 13.5px; font-family: var(--font-body); background: transparent; }
.db-icon-btn { width: 42px; height: 42px; border-radius: 50%; border: 1.5px solid var(--color-line); display: grid; place-items: center; color: var(--color-ink-2); background: var(--color-white); position: relative; }
.db-icon-btn:hover { background: var(--color-bg-soft); }
.db-icon-btn .dot { position: absolute; top: 9px; right: 10px; width: 8px; height: 8px; border-radius: 50%; background: var(--color-secondary-deep); border: 2px solid var(--color-white); }

.db-content { padding: 32px 40px 64px; max-width: 1180px; }

/* ── VIEW SWITCHING ── */
.db-view { display: none; }
.db-view.on { display: block; animation: dbIn .26s ease; }
@keyframes dbIn { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }

/* ── PAGE HEADER (sub-views) ── */
.db-phead { margin-bottom: 24px; }
.db-phead .kicker { display: inline-flex; align-items: center; gap: 10px; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.12em; color: var(--color-ink-3); margin-bottom: 12px; }
.db-phead .kicker .d { width: 6px; height: 6px; border-radius: 50%; background: var(--color-secondary-deep); }
.db-phead h2 { font-family: var(--font-display); font-size: 32px; font-weight: 700; letter-spacing: -0.02em; line-height: 1.05; }
.db-phead p { font-size: 14.5px; color: var(--color-ink-2); margin-top: 8px; max-width: 560px; }
.db-phead-row { display: flex; align-items: flex-end; justify-content: space-between; gap: 20px; flex-wrap: wrap; }

/* ── HERO ROW (overview) ── */
.db-hero { display: grid; grid-template-columns: 1.4fr 1fr; gap: 16px; margin-bottom: 16px; }
.db-score { background: var(--color-black); color: var(--color-white); border-radius: 0; padding: 30px 32px; display: grid; grid-template-columns: auto 1fr; gap: 32px; align-items: center; overflow: hidden; position: relative; }
.db-ring { width: 132px; height: 132px; position: relative; flex-shrink: 0; }
.db-ring svg { transform: rotate(-90deg); }
.db-ring .mid { position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; }
.db-ring .mid .n { font-family: var(--font-display); font-size: 40px; font-weight: 700; line-height: 1; }
.db-ring .mid .u { font-size: 10px; text-transform: uppercase; letter-spacing: 0.1em; opacity: .6; margin-top: 2px; }
.db-score .k { font-size: 11px; text-transform: uppercase; letter-spacing: 0.12em; color: var(--color-secondary); font-weight: 700; margin-bottom: 8px; }
.db-score h2 { font-family: var(--font-display); font-size: 26px; font-weight: 600; letter-spacing: -0.01em; line-height: 1.15; margin-bottom: 10px; }
.db-score p { font-size: 13.5px; color: rgba(255,255,255,.7); line-height: 1.5; max-width: 320px; margin-bottom: 16px; }
.db-score .delta { display: inline-flex; align-items: center; gap: 6px; font-size: 12.5px; font-weight: 600; color: #5BE0A0; }
.db-next { background: var(--color-white); border: 1px solid var(--color-line); border-radius: 0; padding: 26px; display: flex; flex-direction: column; }
.db-next .k { font-size: 11px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--color-ink-3); font-weight: 700; margin-bottom: 14px; }
.db-next .appt { display: flex; gap: 14px; align-items: flex-start; margin-bottom: auto; }
.db-next .appt .cal { width: 52px; flex-shrink: 0; border: 1px solid var(--color-line); border-radius: var(--r-1); text-align: center; overflow: hidden; }
.db-next .appt .cal .mo { background: var(--color-primary); color: var(--color-white); font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; padding: 3px 0; }
.db-next .appt .cal .dy { font-family: var(--font-display); font-size: 24px; font-weight: 700; padding: 5px 0; }
.db-next .appt .info .tt { font-family: var(--font-display); font-size: 16px; font-weight: 600; line-height: 1.25; margin-bottom: 3px; }
.db-next .appt .info .mt { font-size: 12.5px; color: var(--color-ink-2); }
.db-next .appt .info .mt b { color: var(--color-primary); }
.db-next .btn-row { display: flex; gap: 8px; margin-top: 18px; }

/* ── STATS STRIP ── */
.db-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--color-line); border: 1px solid var(--color-line); border-radius: 0; overflow: hidden; margin-bottom: 28px; }
.db-stat { background: var(--color-white); padding: 18px 22px; }
.db-stat .n { font-family: var(--font-display); font-size: 28px; font-weight: 700; letter-spacing: -0.02em; line-height: 1; }
.db-stat .n.pri { color: var(--color-primary); }
.db-stat .l { font-size: 11px; text-transform: uppercase; letter-spacing: 0.07em; color: var(--color-ink-3); font-weight: 700; margin-top: 7px; }
.db-stat .s { font-size: 11.5px; color: var(--color-success); font-weight: 600; margin-top: 4px; }

/* ── SECTIONS ── */
.db-sec { margin-bottom: 30px; }
.db-sec-head { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 14px; }
.db-sec-head h3 { font-family: var(--font-display); font-size: 20px; font-weight: 600; letter-spacing: -0.01em; }
.db-sec-head a { font-size: 13px; font-weight: 600; color: var(--color-primary); cursor: pointer; }
.db-sec-head a:hover { text-decoration: underline; text-underline-offset: 3px; }
.db-cols { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.db-card { background: var(--color-white); border: 1px solid var(--color-line); border-radius: 0; padding: 22px 24px; }
.db-card.flush { padding: 0; overflow: hidden; }

/* trackers */
.db-track { display: flex; align-items: center; gap: 16px; padding: 14px 0; border-bottom: 1px solid var(--color-line); }
.db-track:first-of-type { padding-top: 0; }
.db-track:last-child { border-bottom: none; padding-bottom: 0; }
.db-track .ico { width: 40px; height: 40px; border-radius: 50%; background: var(--color-primary-soft); color: var(--color-primary); display: grid; place-items: center; flex-shrink: 0; }
.db-track .ico.pink { background: var(--color-secondary-soft); color: var(--color-secondary-deep); }
.db-track .b { flex: 1; min-width: 0; }
.db-track .b .n { font-size: 14.5px; font-weight: 600; color: var(--color-ink-1); }
.db-track .b .bar { height: 6px; border-radius: 99px; background: var(--color-bg-soft); margin-top: 7px; overflow: hidden; }
.db-track .b .bar i { display: block; height: 100%; border-radius: 99px; background: var(--color-primary); }
.db-track .b .bar i.pink { background: var(--color-secondary-deep); }
.db-track .val { font-family: var(--font-display); font-size: 18px; font-weight: 700; color: var(--color-ink-1); white-space: nowrap; }
.db-track .val span { font-size: 11px; color: var(--color-ink-3); font-weight: 600; font-family: var(--font-body); }

/* appointments (compact) */
.db-appt-row { display: flex; gap: 14px; align-items: center; padding: 14px 0; border-bottom: 1px solid var(--color-line); }
.db-appt-row:first-of-type { padding-top: 0; }
.db-appt-row:last-child { border-bottom: none; padding-bottom: 0; }
.db-appt-row .av { width: 44px; height: 44px; border-radius: 50%; background: center/cover var(--color-bg-soft); flex-shrink: 0; }
.db-appt-row .b { flex: 1; min-width: 0; }
.db-appt-row .b .nm { font-size: 14.5px; font-weight: 600; }
.db-appt-row .b .mt { font-size: 12.5px; color: var(--color-ink-2); margin-top: 2px; }
.db-appt-row .tag { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em; padding: 4px 9px; border-radius: var(--r-pill); flex-shrink: 0; }
.db-appt-row .tag.online { background: #E7F7EF; color: var(--color-success); }
.db-appt-row .tag.clinic { background: var(--color-primary-soft); color: var(--color-primary); }
.db-appt-row .tag.done { background: var(--neutral-100); color: var(--color-ink-2); }

/* experts */
.db-experts { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
.db-expert { background: var(--color-white); border: 1px solid var(--color-line); border-radius: 0; padding: 18px; transition: box-shadow .15s ease; cursor: pointer; display: block; }
.db-expert:hover { box-shadow: var(--shadow-1); }
.db-expert .av { width: 56px; height: 56px; border-radius: 50%; background: center/cover var(--color-bg-soft); margin-bottom: 12px; }
.db-expert .nm { font-family: var(--font-display); font-size: 15px; font-weight: 600; line-height: 1.2; letter-spacing: -0.005em; }
.db-expert .sp { font-size: 11.5px; color: var(--color-secondary-deep); font-weight: 600; margin-top: 3px; }
.db-expert .loc { font-size: 12px; color: var(--color-ink-3); margin-top: 8px; display: flex; align-items: center; gap: 5px; }

/* reading */
.db-read { display: flex; gap: 14px; padding: 14px 0; border-bottom: 1px solid var(--color-line); }
.db-read:first-of-type { padding-top: 0; }
.db-read:last-child { border-bottom: none; padding-bottom: 0; }
.db-read .thumb { width: 88px; height: 64px; border-radius: var(--r-1); background: center/cover var(--color-bg-soft); flex-shrink: 0; }
.db-read .b .cat { font-size: 10px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--color-primary); font-weight: 700; margin-bottom: 4px; }
.db-read .b .tt { font-family: var(--font-display); font-size: 15.5px; font-weight: 600; line-height: 1.3; letter-spacing: -0.005em; }
.db-read .b .mt { font-size: 12px; color: var(--color-ink-3); margin-top: 5px; }

/* ── TABS ── */
.db-tabs { display: flex; gap: 4px; border-bottom: 1px solid var(--color-line); margin-bottom: 22px; overflow-x: auto; scrollbar-width: none; }
.db-tabs::-webkit-scrollbar { display: none; }
.db-tab { padding: 12px 16px; font-size: 14px; font-weight: 600; color: var(--color-ink-2); border-bottom: 2px solid transparent; margin-bottom: -1px; white-space: nowrap; cursor: pointer; display: inline-flex; align-items: center; gap: 8px; }
.db-tab:hover { color: var(--color-ink-1); }
.db-tab.on { color: var(--color-primary); border-bottom-color: var(--color-primary); }
.db-tab .c { font-size: 11px; font-weight: 700; background: var(--color-bg-soft); border-radius: var(--r-pill); padding: 1px 8px; color: var(--color-ink-2); }
.db-tab.on .c { background: var(--color-primary-soft); color: var(--color-primary); }
.db-tabpanel { display: none; }
.db-tabpanel.on { display: block; animation: dbIn .24s ease; }

/* ── SAĞLIK VERİLERİM ── */
.db-bioage { background: var(--color-black); color: var(--color-white); border-radius: 0; padding: 28px 30px; display: grid; grid-template-columns: 1fr 1.3fr; gap: 36px; align-items: center; margin-bottom: 16px; }
.db-bioage .lead .k { font-size: 11px; text-transform: uppercase; letter-spacing: 0.12em; color: var(--color-secondary); font-weight: 700; margin-bottom: 12px; }
.db-bioage .lead .big { font-family: var(--font-display); font-size: 72px; font-weight: 700; line-height: 1; letter-spacing: -0.03em; }
.db-bioage .lead .big span { font-size: 22px; opacity: .55; }
.db-bioage .lead .sub { font-size: 13.5px; color: rgba(255,255,255,.65); margin-top: 8px; line-height: 1.5; }
.db-bioage .bars { display: flex; flex-direction: column; gap: 14px; }
.db-bioage .bk { display: grid; grid-template-columns: 130px 1fr 42px; gap: 14px; align-items: center; }
.db-bioage .bk .l { font-size: 12.5px; color: rgba(255,255,255,.8); }
.db-bioage .bk .bar { height: 7px; border-radius: 99px; background: rgba(255,255,255,.14); overflow: hidden; }
.db-bioage .bk .bar i { display: block; height: 100%; border-radius: 99px; background: var(--color-secondary); }
.db-bioage .bk .v { font-size: 12.5px; font-weight: 700; text-align: right; font-variant-numeric: tabular-nums; }

/* lab panels */
.db-labs { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.db-lab { background: var(--color-white); border: 1px solid var(--color-line); border-radius: 0; padding: 20px 22px; }
.db-lab-head { display: flex; align-items: center; gap: 12px; margin-bottom: 16px; }
.db-lab-head .ic { width: 38px; height: 38px; border-radius: 50%; background: var(--color-primary-soft); color: var(--color-primary); display: grid; place-items: center; flex-shrink: 0; }
.db-lab-head .t { font-family: var(--font-display); font-size: 16px; font-weight: 600; }
.db-lab-head .d { font-size: 11.5px; color: var(--color-ink-3); margin-top: 1px; }
.db-marker { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 11px 0; border-bottom: 1px solid var(--color-line); }
.db-marker:last-child { border-bottom: none; padding-bottom: 0; }
.db-marker .nm { font-size: 13px; color: var(--color-ink-1); font-weight: 500; }
.db-marker .rt { display: flex; align-items: center; gap: 10px; }
.db-marker .vv { font-family: var(--font-display); font-size: 15px; font-weight: 700; font-variant-numeric: tabular-nums; }
.db-marker .st { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em; padding: 3px 8px; border-radius: var(--r-pill); }
.db-marker .st.ok { background: #E7F7EF; color: var(--color-success); }
.db-marker .st.low { background: #FFF3E0; color: #B26A00; }
.db-marker .st.high { background: var(--color-secondary-soft); color: var(--color-secondary-deep); }
.db-lab-foot { margin-top: 14px; font-size: 12px; color: var(--color-ink-3); display: flex; align-items: center; gap: 6px; }

/* trend card with sparkline */
.db-trend { background: var(--color-white); border: 1px solid var(--color-line); border-radius: 0; padding: 20px 22px; }
.db-trend .th { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 4px; }
.db-trend .th .t { font-size: 13px; font-weight: 600; color: var(--color-ink-2); }
.db-trend .th .v { font-family: var(--font-display); font-size: 24px; font-weight: 700; letter-spacing: -0.01em; }
.db-trend .delta { font-size: 12px; font-weight: 700; }
.db-trend .delta.up { color: var(--color-success); }
.db-trend .delta.down { color: var(--color-secondary-deep); }
.db-trend svg { width: 100%; height: 56px; margin-top: 10px; overflow: visible; }

/* devices */
.db-device { display: flex; align-items: center; gap: 14px; padding: 14px 0; border-bottom: 1px solid var(--color-line); }
.db-device:first-of-type { padding-top: 0; }
.db-device:last-child { border-bottom: none; padding-bottom: 0; }
.db-device .ic { width: 42px; height: 42px; border-radius: var(--r-1); background: var(--color-bg-soft); display: grid; place-items: center; color: var(--color-ink-2); flex-shrink: 0; }
.db-device .b { flex: 1; min-width: 0; }
.db-device .b .n { font-size: 14px; font-weight: 600; }
.db-device .b .s { font-size: 12px; color: var(--color-ink-3); margin-top: 1px; }
.db-device .conn { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em; color: var(--color-success); display: inline-flex; align-items: center; gap: 6px; }
.db-device .conn::before { content: ''; width: 7px; height: 7px; border-radius: 50%; background: var(--color-success); }
.db-device .conn.off { color: var(--color-ink-3); }
.db-device .conn.off::before { background: var(--color-ink-3); }

/* ── RANDEVULARIM (full cards) ── */
.db-appt { display: grid; grid-template-columns: 64px 1fr auto; gap: 18px; align-items: center; background: var(--color-white); border: 1px solid var(--color-line); border-radius: 0; padding: 18px 22px; margin-bottom: 10px; transition: box-shadow .15s ease; }
.db-appt:hover { box-shadow: var(--shadow-1); }
.db-appt .cal { width: 64px; border: 1px solid var(--color-line); border-radius: var(--r-1); text-align: center; overflow: hidden; }
.db-appt .cal .mo { background: var(--color-primary); color: var(--color-white); font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; padding: 4px 0; }
.db-appt .cal.past .mo { background: var(--neutral-300); color: var(--color-ink-1); }
.db-appt .cal .dy { font-family: var(--font-display); font-size: 26px; font-weight: 700; padding: 6px 0 3px; }
.db-appt .cal .tm { font-size: 11px; color: var(--color-ink-3); padding-bottom: 6px; font-weight: 600; }
.db-appt .who { display: flex; align-items: center; gap: 14px; min-width: 0; }
.db-appt .who .av { width: 46px; height: 46px; border-radius: 50%; background: center/cover var(--color-bg-soft); flex-shrink: 0; }
.db-appt .who .nm { font-family: var(--font-display); font-size: 17px; font-weight: 600; letter-spacing: -0.005em; }
.db-appt .who .mt { font-size: 13px; color: var(--color-ink-2); margin-top: 2px; display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.db-appt .who .tag { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em; padding: 3px 8px; border-radius: var(--r-pill); }
.db-appt .who .tag.online { background: #E7F7EF; color: var(--color-success); }
.db-appt .who .tag.clinic { background: var(--color-primary-soft); color: var(--color-primary); }
.db-appt .acts { display: flex; gap: 8px; flex-shrink: 0; }
.db-empty { text-align: center; padding: 56px 24px; border: 1px dashed var(--color-line); border-radius: 0; color: var(--color-ink-3); }
.db-empty .ic { width: 56px; height: 56px; border-radius: 50%; background: var(--color-bg-soft); display: grid; place-items: center; margin: 0 auto 16px; color: var(--color-ink-3); }
.db-empty .t { font-family: var(--font-display); font-size: 18px; font-weight: 600; color: var(--color-ink-1); margin-bottom: 6px; }
.db-empty p { font-size: 13.5px; max-width: 320px; margin: 0 auto 18px; line-height: 1.5; }

/* ── ARAÇLARIM ── */
.db-toolgrid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.db-tool { background: var(--color-white); border: 1px solid var(--color-line); border-radius: 0; padding: 22px; display: flex; flex-direction: column; transition: box-shadow .15s ease; cursor: pointer; }
.db-tool:hover { box-shadow: var(--shadow-1); }
.db-tool .top { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 16px; }
.db-tool .ic { width: 46px; height: 46px; border-radius: 50%; background: var(--color-primary-soft); color: var(--color-primary); display: grid; place-items: center; }
.db-tool .ic.pink { background: var(--color-secondary-soft); color: var(--color-secondary-deep); }
.db-tool .state { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; padding: 4px 9px; border-radius: var(--r-pill); }
.db-tool .state.active { background: #E7F7EF; color: var(--color-success); }
.db-tool .state.new { background: var(--color-secondary-soft); color: var(--color-secondary-deep); }
.db-tool .nm { font-family: var(--font-display); font-size: 18px; font-weight: 600; letter-spacing: -0.01em; line-height: 1.2; margin-bottom: 5px; }
.db-tool .ds { font-size: 12.5px; color: var(--color-ink-2); line-height: 1.5; margin-bottom: 16px; flex: 1; }
.db-tool .meter { margin-bottom: 14px; }
.db-tool .meter .row { display: flex; justify-content: space-between; font-size: 11.5px; margin-bottom: 6px; }
.db-tool .meter .row .l { color: var(--color-ink-3); font-weight: 600; text-transform: uppercase; letter-spacing: 0.05em; }
.db-tool .meter .row .r { font-weight: 700; color: var(--color-primary); }
.db-tool .meter .bar { height: 6px; border-radius: 99px; background: var(--color-bg-soft); overflow: hidden; }
.db-tool .meter .bar i { display: block; height: 100%; border-radius: 99px; background: var(--color-primary); }
.db-tool .go { font-size: 13px; font-weight: 700; color: var(--color-primary); display: inline-flex; align-items: center; gap: 6px; }

/* ── KAYDEDİLENLER ── */
.db-saved-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.db-saved { background: var(--color-white); border: 1px solid var(--color-line); border-radius: 0; overflow: hidden; transition: box-shadow .15s ease; cursor: pointer; display: block; }
.db-saved:hover { box-shadow: var(--shadow-1); }
.db-saved .img { aspect-ratio: 16/10; background: center/cover var(--color-bg-soft); position: relative; }
.db-saved .bm { position: absolute; top: 12px; right: 12px; width: 32px; height: 32px; border-radius: 50%; background: rgba(255,255,255,.92); display: grid; place-items: center; color: var(--color-primary); }
.db-saved .bd { padding: 16px 18px; }
.db-saved .cat { font-size: 10px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--color-primary); font-weight: 700; margin-bottom: 6px; }
.db-saved .tt { font-family: var(--font-display); font-size: 16px; font-weight: 600; line-height: 1.25; letter-spacing: -0.005em; }
.db-saved .mt { font-size: 12px; color: var(--color-ink-3); margin-top: 8px; }

/* ── PROGRAMLARIM ── */
.db-prog { background: var(--color-white); border: 1px solid var(--color-line); border-radius: 0; padding: 0; overflow: hidden; margin-bottom: 14px; display: grid; grid-template-columns: 200px 1fr; }
.db-prog .cover { background: center/cover var(--color-bg-soft); position: relative; min-height: 180px; }
.db-prog .cover .badge { position: absolute; top: 14px; left: 14px; font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; padding: 5px 10px; border-radius: var(--r-pill); background: var(--color-white); color: var(--color-primary); }
.db-prog .bd { padding: 24px 26px; display: flex; flex-direction: column; }
.db-prog .cat { font-size: 11px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--color-secondary-deep); font-weight: 700; margin-bottom: 8px; }
.db-prog .tt { font-family: var(--font-display); font-size: 21px; font-weight: 600; letter-spacing: -0.01em; line-height: 1.2; margin-bottom: 6px; }
.db-prog .by { font-size: 13px; color: var(--color-ink-2); margin-bottom: 16px; }
.db-prog .pmeter { margin-bottom: 16px; max-width: 460px; }
.db-prog .pmeter .row { display: flex; justify-content: space-between; font-size: 12px; margin-bottom: 7px; }
.db-prog .pmeter .row .l { color: var(--color-ink-3); font-weight: 600; }
.db-prog .pmeter .row .r { font-weight: 700; color: var(--color-ink-1); }
.db-prog .pmeter .bar { height: 8px; border-radius: 99px; background: var(--color-bg-soft); overflow: hidden; }
.db-prog .pmeter .bar i { display: block; height: 100%; border-radius: 99px; background: var(--color-primary); }
.db-prog .foot { display: flex; align-items: center; gap: 12px; margin-top: auto; }
.db-prog .nextmod { font-size: 13px; color: var(--color-ink-2); }
.db-prog .nextmod b { color: var(--color-ink-1); font-weight: 600; }

/* ── AYARLAR ── */
.db-set { display: grid; grid-template-columns: 200px 1fr; gap: 36px; align-items: start; }
.db-set-nav { position: sticky; top: 96px; display: flex; flex-direction: column; gap: 2px; }
.db-set-nav a { padding: 10px 14px; border-radius: var(--r-1); font-size: 14px; font-weight: 500; color: var(--color-ink-2); cursor: pointer; }
.db-set-nav a:hover { background: var(--color-bg-soft); color: var(--color-ink-1); }
.db-set-nav a.on { background: var(--color-primary-soft); color: var(--color-primary); font-weight: 600; }
.db-set-main { min-width: 0; max-width: 640px; }
.db-set-card { background: var(--color-white); border: 1px solid var(--color-line); border-radius: 0; padding: 26px 28px; margin-bottom: 16px; }
.db-set-card h4 { font-family: var(--font-display); font-size: 18px; font-weight: 600; letter-spacing: -0.01em; margin-bottom: 4px; }
.db-set-card .sub { font-size: 13px; color: var(--color-ink-3); margin-bottom: 20px; }
.db-set-profile { display: flex; align-items: center; gap: 18px; margin-bottom: 24px; }
.db-set-profile .av { width: 72px; height: 72px; border-radius: 50%; background: center/cover var(--color-bg-soft); flex-shrink: 0; }
.db-field { margin-bottom: 16px; }
.db-field.row2 { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.db-label { display: block; font-size: 12.5px; font-weight: 600; color: var(--color-ink-1); margin-bottom: 7px; }
.db-input, .db-select { width: 100%; height: 48px; border: 1.5px solid var(--color-line); border-radius: var(--r-1); padding: 0 14px; font-size: 14.5px; font-family: var(--font-body); color: var(--color-ink-1); background: var(--color-white); transition: border-color .15s ease; }
.db-input:focus, .db-select:focus { outline: none; border-color: var(--color-primary); }
.db-set-row { display: flex; align-items: center; justify-content: space-between; gap: 18px; padding: 16px 0; border-bottom: 1px solid var(--color-line); }
.db-set-row:last-child { border-bottom: none; padding-bottom: 0; }
.db-set-row:first-child { padding-top: 0; }
.db-set-row .info .n { font-size: 14px; font-weight: 600; color: var(--color-ink-1); }
.db-set-row .info .s { font-size: 12.5px; color: var(--color-ink-3); margin-top: 2px; max-width: 380px; line-height: 1.45; }
.db-switch { width: 46px; height: 27px; border-radius: 99px; background: var(--neutral-300); position: relative; flex-shrink: 0; transition: background .2s ease; cursor: pointer; }
.db-switch::after { content: ''; position: absolute; top: 3px; left: 3px; width: 21px; height: 21px; border-radius: 50%; background: var(--color-white); box-shadow: var(--shadow-1); transition: transform .2s ease; }
.db-switch.on { background: var(--color-primary); }
.db-switch.on::after { transform: translateX(19px); }
.db-plan { background: linear-gradient(160deg, var(--primary-600), var(--primary-900)); color: var(--color-white); border-radius: 0; padding: 24px 26px; display: flex; align-items: center; justify-content: space-between; gap: 20px; flex-wrap: wrap; }
.db-plan .t { font-family: var(--font-display); font-size: 20px; font-weight: 600; margin-bottom: 4px; }
.db-plan p { font-size: 13px; color: rgba(255,255,255,.8); }
.db-danger { color: var(--color-danger); font-weight: 600; font-size: 14px; cursor: pointer; }
.db-danger:hover { text-decoration: underline; text-underline-offset: 3px; }


/* ── ÖDEME & FATURA ── */
.db-pay { display: flex; align-items: center; gap: 16px; padding: 16px 0; border-bottom: 1px solid var(--color-line); }
.db-pay:first-of-type { padding-top: 0; }
.db-pay:last-child { border-bottom: none; padding-bottom: 0; }
.db-pay .brand { width: 48px; height: 32px; border: 1px solid var(--color-line); display: grid; place-items: center; font-family: var(--font-display); font-weight: 700; font-size: 12px; letter-spacing: 0.02em; flex-shrink: 0; }
.db-pay .brand.visa { color: #1a1f71; }
.db-pay .brand.mc { color: #eb001b; }
.db-pay .b { flex: 1; min-width: 0; }
.db-pay .b .n { font-size: 14px; font-weight: 600; display: flex; align-items: center; gap: 10px; }
.db-pay .b .s { font-size: 12.5px; color: var(--color-ink-3); margin-top: 2px; }
.db-pay .def { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; padding: 3px 8px; border-radius: var(--r-pill); background: var(--color-primary-soft); color: var(--color-primary); }
.db-pay .acts { display: flex; gap: 8px; flex-shrink: 0; }
.db-addcard { width: 100%; margin-top: 16px; height: 48px; border: 1.5px dashed var(--color-line); background: var(--color-white); display: flex; align-items: center; justify-content: center; gap: 10px; font-size: 14px; font-weight: 600; color: var(--color-ink-2); cursor: pointer; }
.db-addcard:hover { border-color: var(--color-primary); color: var(--color-primary); }
.db-inv-sum { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--color-line); border: 1px solid var(--color-line); margin-bottom: 20px; }
.db-inv-sum .c { background: var(--color-white); padding: 16px 18px; }
.db-inv-sum .c .n { font-family: var(--font-display); font-size: 24px; font-weight: 700; letter-spacing: -0.02em; }
.db-inv-sum .c .l { font-size: 11px; text-transform: uppercase; letter-spacing: 0.07em; color: var(--color-ink-3); font-weight: 700; margin-top: 6px; }
.db-inv-table { width: 100%; border-collapse: collapse; }
.db-inv-table th { text-align: left; font-size: 10px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--color-ink-3); font-weight: 700; padding: 0 0 12px; border-bottom: 1px solid var(--color-line); }
.db-inv-table th.r, .db-inv-table td.r { text-align: right; }
.db-inv-table td { padding: 14px 0; border-bottom: 1px solid var(--color-line); font-size: 13.5px; color: var(--color-ink-1); vertical-align: middle; }
.db-inv-table tr:last-child td { border-bottom: none; }
.db-inv-table .desc { font-weight: 600; }
.db-inv-table .date { color: var(--color-ink-2); font-variant-numeric: tabular-nums; white-space: nowrap; }
.db-inv-table .amt { font-family: var(--font-display); font-weight: 700; font-variant-numeric: tabular-nums; }
.db-inv-st { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em; padding: 3px 9px; border-radius: var(--r-pill); background: #E7F7EF; color: var(--color-success); }
.db-inv-dl { font-size: 12.5px; font-weight: 600; color: var(--color-primary); display: inline-flex; align-items: center; gap: 6px; cursor: pointer; }
.db-inv-dl:hover { text-decoration: underline; text-underline-offset: 3px; }
@media (max-width: 620px) { .db-inv-sum { grid-template-columns: 1fr; } .db-inv-table .hide-sm { display: none; } }

@media (max-width: 1080px) {
  .db { grid-template-columns: 1fr; }
  .db-side { position: relative; height: auto; flex-direction: row; align-items: center; flex-wrap: wrap; }
  .db-nav, .db-upgrade { display: none; }
  .db-side-user { margin-left: auto; border-top: none; }
  .db-hero, .db-cols, .db-bioage, .db-set { grid-template-columns: 1fr; }
  .db-stats, .db-experts, .db-labs, .db-toolgrid, .db-saved-grid { grid-template-columns: 1fr 1fr; }
  .db-set-nav { position: relative; top: auto; flex-direction: row; flex-wrap: wrap; }
}
@media (max-width: 620px) {
  .db-content, .db-top { padding-left: 20px; padding-right: 20px; }
  .db-search { display: none; }
  .db-score { grid-template-columns: 1fr; text-align: center; justify-items: center; }
  .db-stats, .db-experts, .db-labs, .db-toolgrid, .db-saved-grid { grid-template-columns: 1fr; }
  .db-appt { grid-template-columns: 1fr; gap: 14px; }
  .db-prog { grid-template-columns: 1fr; }
}
