<?php require_once __DIR__.'/config.php'; $logged=!empty($_SESSION['uid']); ?>
<!DOCTYPE html>
<html lang="tr">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width,initial-scale=1,viewport-fit=cover">
<title>AforHealth OS</title>
<meta name="description" content="AI destekli kişisel sağlık yönetim sistemi">
<meta name="theme-color" content="#06060e">
<meta name="apple-mobile-web-app-capable" content="yes">
<meta name="apple-mobile-web-app-status-bar-style" content="black-translucent">
<link rel="manifest" href="pwa_config/manifest.json">
<link href="https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,400&display=swap" rel="stylesheet">
<script src="https://unpkg.com/lucide@latest"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/lottie-web/5.12.2/lottie.min.js"></script>
<link rel="stylesheet" href="style.css">

<style>
/* ═══════════════════════════════════════════════════════════
   GLOBAL RESET & FOUNDATION
═══════════════════════════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --c-bg:#06060e;
  --c-surface:rgba(255,255,255,.038);
  --c-border:rgba(255,255,255,.07);
  --c-text:#fff;
  --c-muted:rgba(255,255,255,.4);
  --c-dim:rgba(255,255,255,.22);
  --c-green:#4fd88a;
  --c-cyan:#38c4f0;
  --c-purple:#a855f7;
  --c-pink:#ec4899;
  --c-red:#ff5e7a;
  --c-yellow:#fbbf24;
  --ff:'Plus Jakarta Sans',sans-serif;
  --r-sm:12px;--r-md:16px;--r-lg:20px;--r-xl:24px;--r-2xl:32px;
  --ease-spring:cubic-bezier(.34,1.56,.64,1);
  --ease-out:cubic-bezier(.4,0,.2,1);
}
html,body{width:100%;height:100%;overflow:hidden;background:var(--c-bg);font-family:var(--ff);-webkit-font-smoothing:antialiased}

/* ── Critical visibility system ── */
.hidden{display:none!important}
.view{
  position:fixed;inset:0;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  background:var(--c-bg);
  opacity:1;
  transition:opacity .3s var(--ease-out);
}
.view.hidden{display:none!important}

/* ── Shared glass ── */
.glass{
  background:rgba(255,255,255,.042);
  border:1px solid rgba(255,255,255,.075);
  backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
}
.glass-dark{
  background:rgba(0,0,0,.45);
  border:1px solid rgba(255,255,255,.06);
  backdrop-filter:blur(28px);-webkit-backdrop-filter:blur(28px);
}

/* ── Shared button types ── */
.btn-glow{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:14px 24px;border:none;border-radius:var(--r-lg);cursor:pointer;
  background:linear-gradient(135deg,var(--c-green),var(--c-cyan) 60%,#5eadf7);
  background-size:200% 200%;
  color:#06060e;font-family:var(--ff);font-size:14px;font-weight:800;
  letter-spacing:.02em;
  box-shadow:0 4px 28px rgba(79,216,138,.3),inset 0 1px 0 rgba(255,255,255,.2);
  transition:transform .2s,box-shadow .25s,background-position .45s;
  position:relative;overflow:hidden;
}
.btn-glow:hover{transform:translateY(-2px);box-shadow:0 8px 40px rgba(79,216,138,.45),inset 0 1px 0 rgba(255,255,255,.25);background-position:right center}
.btn-glow:active{transform:scale(.975)}

.btn-glass{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:12px 20px;border:1px solid rgba(255,255,255,.1);border-radius:var(--r-md);cursor:pointer;
  background:rgba(255,255,255,.06);color:rgba(255,255,255,.75);
  font-family:var(--ff);font-size:13px;font-weight:600;
  transition:all .25s var(--ease-out);
}
.btn-glass:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.16);color:#fff;transform:translateY(-1px)}
.btn-glass:active{transform:scale(.975)}

.btn-danger{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:13px 20px;border:1px solid rgba(255,94,122,.25);border-radius:var(--r-md);cursor:pointer;
  background:rgba(255,94,122,.08);color:#ff8fa3;
  font-family:var(--ff);font-size:13px;font-weight:700;
  transition:all .25s var(--ease-out);
}
.btn-danger:hover{background:rgba(255,94,122,.15);border-color:rgba(255,94,122,.4);transform:translateY(-1px)}

/* ── Progress bar ── */
.progress-track{height:4px;background:rgba(255,255,255,.07);border-radius:99px;overflow:hidden}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--c-green),var(--c-cyan));border-radius:99px;transition:width .45s var(--ease-out)}

/* ── Lucide icon sizing helpers ── */
[data-lucide]{display:inline-block;vertical-align:middle}
.icon-xs [data-lucide]{width:14px;height:14px}
.icon-sm [data-lucide]{width:16px;height:16px}
.icon-md [data-lucide]{width:20px;height:20px}

/* ══════════════════════════════════════════════════════════
   AUTH SCREEN
══════════════════════════════════════════════════════════ */
#v-auth{
  align-items:center;justify-content:center;
  overflow:hidden auto;
  background:var(--c-bg);
}

/* mesh gradient bg */
#v-auth::before{
  content:'';position:absolute;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(ellipse 80% 60% at 10% 0%,  rgba(79,216,138,.14) 0%,transparent 60%),
    radial-gradient(ellipse 60% 50% at 90% 100%,rgba(56,196,240,.12) 0%,transparent 55%),
    radial-gradient(ellipse 50% 40% at 80% 20%,  rgba(168,85,247,.1)  0%,transparent 50%),
    radial-gradient(ellipse 40% 60% at 20% 80%,  rgba(236,72,153,.08) 0%,transparent 50%);
  animation:mesh-shift 20s ease-in-out infinite alternate;
}
@keyframes mesh-shift{
  0%  {opacity:.8}
  100%{opacity:1;filter:hue-rotate(15deg)}
}

/* dot grid */
#v-auth::after{
  content:'';position:absolute;inset:0;z-index:0;pointer-events:none;
  background-image:radial-gradient(rgba(255,255,255,.055) 1px,transparent 1px);
  background-size:26px 26px;
  animation:grid-in 3s ease-out forwards;
}
@keyframes grid-in{from{opacity:0}to{opacity:1}}

/* orbs */
.auth-orbs{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.auth-orb{position:absolute;border-radius:50%;filter:blur(72px);will-change:transform}
.auth-orb-1{width:440px;height:440px;background:radial-gradient(circle,rgba(79,216,138,.22),transparent 70%);top:-160px;left:-120px;animation:orb1 17s ease-in-out infinite}
.auth-orb-2{width:380px;height:380px;background:radial-gradient(circle,rgba(56,196,240,.18),transparent 70%);bottom:-140px;right:-90px;animation:orb2 21s ease-in-out infinite}
.auth-orb-3{width:300px;height:300px;background:radial-gradient(circle,rgba(168,85,247,.14),transparent 70%);top:38%;left:60%;animation:orb3 14s ease-in-out infinite}
.auth-orb-4{width:220px;height:220px;background:radial-gradient(circle,rgba(236,72,153,.12),transparent 70%);top:12%;right:8%;animation:orb4 24s ease-in-out infinite}
@keyframes orb1{0%,100%{transform:translate(0,0) scale(1)}35%{transform:translate(32px,-42px) scale(1.07)}70%{transform:translate(-18px,24px) scale(.95)}}
@keyframes orb2{0%,100%{transform:translate(0,0) scale(1)}42%{transform:translate(-38px,30px) scale(1.1)}72%{transform:translate(20px,-20px) scale(.97)}}
@keyframes orb3{0%,100%{transform:translate(0,0) scale(1)}55%{transform:translate(-26px,-32px) scale(1.1)}}
@keyframes orb4{0%,100%{transform:translate(0,0)}35%{transform:translate(18px,28px)}70%{transform:translate(-12px,-8px)}}

/* scanline */
.auth-scanline{position:absolute;left:0;right:0;height:1px;z-index:1;pointer-events:none;background:linear-gradient(90deg,transparent,rgba(79,216,138,.4),rgba(56,196,240,.45),rgba(168,85,247,.35),transparent);animation:scan 6s linear infinite;opacity:.55}
@keyframes scan{0%{top:-2px;opacity:0}5%{opacity:.55}95%{opacity:.35}100%{top:100%;opacity:0}}

/* particles */
.auth-particle{position:absolute;border-radius:50%;pointer-events:none;animation:p-rise linear infinite}
@keyframes p-rise{0%{transform:translateY(0) translateX(0) scale(1);opacity:0}10%{opacity:1}90%{opacity:.5}100%{transform:translateY(-110vh) translateX(var(--dx)) scale(.2);opacity:0}}

/* wrap */
.auth-wrap{position:relative;z-index:2;width:100%;max-width:420px;padding:40px 20px 32px}

/* ── Logo ── */
.auth-logo-zone{text-align:center;margin-bottom:40px}
.logo-ring-wrap{width:80px;height:80px;margin:0 auto 22px;position:relative}
.logo-ring-svg{width:80px;height:80px;position:absolute;inset:0}
.lr-track{fill:none;stroke:rgba(79,216,138,.1);stroke-width:1.5}
.lr-glow{fill:none;stroke:rgba(79,216,138,.08);stroke-width:7;stroke-dasharray:200;stroke-dashoffset:200;stroke-linecap:round;animation:ring-draw 1.8s .2s cubic-bezier(.4,0,.2,1) forwards;filter:blur(5px)}
.lr-main{fill:none;stroke:url(#ring-grad);stroke-width:1.5;stroke-dasharray:200;stroke-dashoffset:200;stroke-linecap:round;animation:ring-draw 1.5s .35s cubic-bezier(.4,0,.2,1) forwards}
.lr-spin{fill:none;stroke:rgba(56,196,240,.45);stroke-width:1;stroke-dasharray:32 168;stroke-linecap:round;animation:spin 3.2s linear infinite;transform-origin:40px 40px}
@keyframes ring-draw{to{stroke-dashoffset:0}}
@keyframes spin{to{transform:rotate(360deg)}}
.logo-dot-wrap{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}
.logo-dot{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--c-green),var(--c-cyan) 50%,var(--c-purple));display:flex;align-items:center;justify-content:center;color:#06060e;animation:dot-pop .6s 1s both var(--ease-spring),dot-pulse 2.8s 2s ease-in-out infinite}
.logo-dot svg{width:20px;height:20px;stroke:#06060e;fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}
@keyframes dot-pop{from{transform:scale(0) rotate(-90deg);opacity:0}to{transform:scale(1) rotate(0);opacity:1}}
@keyframes dot-pulse{0%,100%{box-shadow:0 0 0 0 rgba(79,216,138,.4),0 0 22px rgba(79,216,138,.2)}50%{box-shadow:0 0 0 10px rgba(79,216,138,.0),0 0 34px rgba(79,216,138,.38)}}
.logo-orbit{position:absolute;inset:0;animation:orbit-spin 4.5s linear infinite}
.logo-orbit-dot{position:absolute;top:2px;left:50%;transform:translateX(-50%);width:6px;height:6px;border-radius:50%;background:linear-gradient(135deg,var(--c-green),var(--c-cyan));box-shadow:0 0 8px rgba(79,216,138,.9);opacity:0;animation:orb-dot-in .4s 2s ease forwards}
@keyframes orbit-spin{to{transform:rotate(360deg)}}
@keyframes orb-dot-in{to{opacity:1}}

.auth-logo-title{font-size:28px;font-weight:900;letter-spacing:-.7px;background:linear-gradient(135deg,#fff,rgba(255,255,255,.72));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;opacity:0;animation:fade-up .65s 1.1s both}
.auth-logo-sub{font-size:11px;color:var(--c-dim);font-weight:700;letter-spacing:.16em;text-transform:uppercase;margin-top:7px;opacity:0;animation:fade-up .65s 1.2s both}
@keyframes fade-up{from{opacity:0;transform:translateY(14px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}

/* ── Card ── */
.auth-card-wrap{position:relative;opacity:0;animation:fade-up .7s 1.35s both}
@property --beam-angle{syntax:'<angle>';initial-value:0deg;inherits:false}
.auth-beam{position:absolute;inset:-1px;border-radius:25px;z-index:0;background:conic-gradient(from var(--beam-angle),transparent 0deg,rgba(79,216,138,0) 55deg,rgba(79,216,138,.6) 88deg,rgba(56,196,240,.8) 100deg,rgba(168,85,247,.55) 116deg,rgba(79,216,138,0) 148deg,transparent 360deg);animation:beam-rot 4.5s linear infinite;-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;padding:1px}
@keyframes beam-rot{to{--beam-angle:360deg}}

.auth-card{position:relative;z-index:1;background:rgba(255,255,255,.038);border:1px solid rgba(255,255,255,.07);border-radius:24px;padding:28px 26px 26px;backdrop-filter:blur(32px);-webkit-backdrop-filter:blur(32px);overflow:hidden}
.auth-card::before{content:'';position:absolute;top:0;left:8%;right:8%;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.16),rgba(79,216,138,.32),rgba(255,255,255,.16),transparent)}
.auth-card::after{content:'';position:absolute;bottom:-40px;left:15%;right:15%;height:80px;background:radial-gradient(ellipse,rgba(79,216,138,.05),transparent 70%);pointer-events:none}

/* ── Tabs ── */
.auth-tab-row{display:flex;background:rgba(0,0,0,.4);border:1px solid rgba(255,255,255,.065);border-radius:14px;padding:4px;gap:3px;margin-bottom:24px}
.auth-tab{flex:1;padding:10px 0;border:none;background:transparent;color:rgba(255,255,255,.35);font-family:var(--ff);font-size:13px;font-weight:700;border-radius:11px;cursor:pointer;transition:all .32s var(--ease-out);position:relative;overflow:hidden;letter-spacing:.01em}
.auth-tab.active{color:#fff;background:linear-gradient(135deg,rgba(79,216,138,.17),rgba(56,196,240,.1));box-shadow:0 0 0 1px rgba(79,216,138,.26),inset 0 1px 0 rgba(255,255,255,.09)}
.auth-tab:not(.active):hover{color:rgba(255,255,255,.65);background:rgba(255,255,255,.045)}
.auth-tab-ink{position:absolute;bottom:4px;left:0;right:0;height:2px;border-radius:2px;background:linear-gradient(90deg,var(--c-green),var(--c-cyan));transform:scaleX(0);transition:transform .35s var(--ease-out);transform-origin:left}
.auth-tab.active .auth-tab-ink{transform:scaleX(1)}

/* ── Alert ── */
#auth-alert{overflow:hidden;max-height:0;opacity:0;margin-bottom:0;transition:max-height .35s var(--ease-out),opacity .3s,margin .3s,padding .3s;background:rgba(255,94,122,.08);border:1px solid rgba(255,94,122,.2);border-radius:12px;color:#ff8fa3;font-size:13px;font-weight:500;padding:0 14px}
#auth-alert.show{max-height:80px;opacity:1;margin-bottom:18px;padding:11px 14px}
#auth-alert.success-msg{background:rgba(79,216,138,.08);border-color:rgba(79,216,138,.25);color:#6ee7a8}

/* ── Form slide ── */
.auth-form{transition:opacity .28s,transform .28s var(--ease-out)}
.auth-form.out-left{opacity:0;transform:translateX(-24px);pointer-events:none}
.auth-form.out-right{opacity:0;transform:translateX(24px);pointer-events:none}

/* ── Fields ── */
.auth-field{margin-bottom:12px;position:relative}
.auth-field-inner{position:relative}
.auth-field-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);display:flex;align-items:center;pointer-events:none;color:var(--c-dim);transition:color .22s,transform .22s}
.auth-field-icon svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.auth-field-inner:focus-within .auth-field-icon{color:var(--c-green);transform:translateY(-50%) scale(1.12)}

.auth-inp{width:100%;background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.07);border-radius:13px;padding:14px 14px 14px 44px;color:#fff;font-family:var(--ff);font-size:14px;font-weight:500;outline:none;transition:border-color .25s,background .25s,box-shadow .25s;-webkit-appearance:none}
.auth-inp::placeholder{color:rgba(255,255,255,.22);font-weight:400}
.auth-inp:hover{border-color:rgba(255,255,255,.12);background:rgba(255,255,255,.055)}
.auth-inp:focus{border-color:rgba(79,216,138,.45);background:rgba(79,216,138,.035);box-shadow:0 0 0 3px rgba(79,216,138,.1),0 0 22px rgba(79,216,138,.06)}
.auth-inp:-webkit-autofill{-webkit-box-shadow:0 0 0 999px #0e1418 inset;-webkit-text-fill-color:#fff}

.auth-field-label{position:absolute;left:44px;top:50%;transform:translateY(-50%);font-size:14px;color:rgba(255,255,255,.24);font-weight:400;pointer-events:none;transition:all .22s var(--ease-out)}
.auth-inp:focus~.auth-field-label,.auth-inp:not(:placeholder-shown)~.auth-field-label{top:5px;font-size:10px;left:14px;color:rgba(79,216,138,.85);letter-spacing:.05em;font-weight:700}

/* ── Button loading ── */
.auth-btn{width:100%;margin-top:8px;padding:15px;border:none;border-radius:14px;background:linear-gradient(135deg,var(--c-green),var(--c-cyan) 60%,#5eadf7);background-size:200% 200%;color:#06060e;font-family:var(--ff);font-size:14px;font-weight:800;cursor:pointer;letter-spacing:.02em;position:relative;overflow:hidden;transition:transform .2s,box-shadow .22s,background-position .45s;box-shadow:0 4px 28px rgba(79,216,138,.3),inset 0 1px 0 rgba(255,255,255,.22);display:flex;align-items:center;justify-content:center;gap:8px}
.auth-btn:hover{transform:translateY(-2px);box-shadow:0 8px 40px rgba(79,216,138,.45),inset 0 1px 0 rgba(255,255,255,.28);background-position:right center}
.auth-btn:active{transform:scale(.975)}
.auth-btn-shine{position:absolute;inset:0;background:linear-gradient(105deg,transparent 35%,rgba(255,255,255,.38) 50%,transparent 65%);transform:translateX(-100%);pointer-events:none}
.auth-btn:hover .auth-btn-shine{animation:btn-shine .7s ease}
@keyframes btn-shine{to{transform:translateX(110%)}}
.auth-btn-ripple{position:absolute;border-radius:50%;background:rgba(255,255,255,.32);transform:scale(0);animation:ripple .65s linear;pointer-events:none}
@keyframes ripple{to{transform:scale(4);opacity:0}}
.auth-btn-spinner{display:none;width:18px;height:18px;border:2.5px solid rgba(6,6,14,.25);border-top-color:#06060e;border-radius:50%;animation:spin .7s linear infinite}
.auth-btn.loading .auth-btn-spinner{display:block}
.auth-btn.loading .auth-btn-text{display:none}

/* staggered field entrance */
.auth-form .auth-field{opacity:0;transform:translateY(10px)}
.auth-form.form-entered .auth-field:nth-child(1){animation:field-in .45s .05s both}
.auth-form.form-entered .auth-field:nth-child(2){animation:field-in .45s .13s both}
.auth-form.form-entered .auth-field:nth-child(3){animation:field-in .45s .21s both}
.auth-form.form-entered .auth-btn-wrap{animation:field-in .45s .29s both;opacity:0}
@keyframes field-in{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}

/* ══════════════════════════════════════════════════════════
   ONBOARDING SCREEN
══════════════════════════════════════════════════════════ */
#v-onboard{
  background:var(--c-bg);
  align-items:center;justify-content:center;
  padding:0 16px;
}
#v-onboard::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse 70% 40% at 50% 0%,rgba(79,216,138,.1) 0%,transparent 60%),
    radial-gradient(ellipse 50% 40% at 10% 90%,rgba(56,196,240,.08) 0%,transparent 55%);
}
.onboard-wrap{position:relative;z-index:1;width:100%;max-width:480px;padding:20px 0}

.onboard-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;padding:0 2px}
.onboard-title{font-size:17px;font-weight:800;color:#fff;display:flex;align-items:center;gap:8px}
.onboard-title svg{width:20px;height:20px;stroke:var(--c-green);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.onboard-counter{font-size:12px;font-weight:700;color:var(--c-green);background:rgba(79,216,138,.1);border:1px solid rgba(79,216,138,.2);padding:4px 10px;border-radius:99px}

.ob-progress-wrap{margin-bottom:14px}
.ob-progress-track{height:5px;background:rgba(255,255,255,.07);border-radius:99px;overflow:hidden;position:relative}
.ob-progress-fill{height:100%;background:linear-gradient(90deg,var(--c-green),var(--c-cyan));border-radius:99px;transition:width .5s var(--ease-out);position:relative}
.ob-progress-fill::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);animation:shimmer 2s linear infinite}
@keyframes shimmer{0%{transform:translateX(-100%)}100%{transform:translateX(200%)}}

.ob-card{
  position:relative;
  background:rgba(255,255,255,.042);
  border:1px solid rgba(255,255,255,.075);
  border-radius:28px;padding:28px 22px 24px;
  backdrop-filter:blur(28px);-webkit-backdrop-filter:blur(28px);
  min-height:360px;display:flex;flex-direction:column;justify-content:space-between;
  overflow:hidden;
  animation:card-appear .4s var(--ease-spring);
}
@keyframes card-appear{from{opacity:0;transform:translateY(18px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}
.ob-card::before{content:'';position:absolute;top:0;left:5%;right:5%;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.14),rgba(79,216,138,.25),rgba(255,255,255,.14),transparent)}

.ob-q{font-size:17px;font-weight:700;color:#fff;line-height:1.45;margin-bottom:20px}
.ob-q-num{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:8px;background:linear-gradient(135deg,rgba(79,216,138,.25),rgba(56,196,240,.15));border:1px solid rgba(79,216,138,.3);font-size:11px;font-weight:800;color:var(--c-green);margin-right:10px;flex-shrink:0}

/* radio options */
.ob-options{display:flex;flex-direction:column;gap:8px}
.ob-opt{
  display:flex;align-items:center;gap:12px;
  padding:13px 16px;border-radius:14px;cursor:pointer;
  border:1px solid rgba(255,255,255,.07);
  background:rgba(255,255,255,.03);
  transition:all .2s var(--ease-out);position:relative;overflow:hidden;
}
.ob-opt:hover{background:rgba(255,255,255,.065);border-color:rgba(255,255,255,.13);transform:translateX(3px)}
.ob-opt.selected{background:rgba(79,216,138,.1);border-color:rgba(79,216,138,.35);box-shadow:0 0 0 1px rgba(79,216,138,.15) inset}
.ob-opt-check{width:20px;height:20px;border-radius:50%;border:1.5px solid rgba(255,255,255,.2);flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all .2s}
.ob-opt.selected .ob-opt-check{background:var(--c-green);border-color:var(--c-green)}
.ob-opt.selected .ob-opt-check::after{content:'';width:7px;height:4px;border-left:2px solid #06060e;border-bottom:2px solid #06060e;transform:rotate(-45deg) translate(1px,-1px);display:block}
.ob-opt-label{font-size:14px;font-weight:500;color:rgba(255,255,255,.8)}
.ob-opt.selected .ob-opt-label{color:#fff;font-weight:600}

/* text input */
.ob-inp{width:100%;background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.08);border-radius:13px;padding:14px 16px;color:#fff;font-family:var(--ff);font-size:14px;font-weight:500;outline:none;transition:border-color .25s,box-shadow .25s;-webkit-appearance:none}
.ob-inp:focus{border-color:rgba(79,216,138,.45);box-shadow:0 0 0 3px rgba(79,216,138,.1)}
.ob-inp::placeholder{color:rgba(255,255,255,.2)}

/* nav row */
.ob-nav{display:flex;gap:10px;margin-top:20px}
.ob-nav .btn-glass{flex:1}
.ob-nav .btn-glow{flex:2}

/* ══════════════════════════════════════════════════════════
   APP — SHELL
══════════════════════════════════════════════════════════ */
#v-app{background:var(--c-bg);padding-bottom:0}
#v-app::before{
  content:'';position:fixed;top:0;left:0;right:0;height:50vh;pointer-events:none;z-index:0;
  background:radial-gradient(ellipse 90% 50% at 50% -10%,rgba(79,216,138,.06) 0%,transparent 70%);
}

/* ── Header ── */
.app-header{
  position:relative;z-index:10;
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 18px;padding-top:calc(12px + env(safe-area-inset-top));
  background:rgba(6,6,14,.85);
  border-bottom:1px solid rgba(255,255,255,.055);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  flex-shrink:0;
}
.header-orb{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,rgba(79,216,138,.25),rgba(56,196,240,.18));border:1px solid rgba(79,216,138,.25);display:flex;align-items:center;justify-content:center}
.header-orb svg{width:16px;height:16px;stroke:var(--c-green);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.logo-text{font-size:17px;font-weight:900;background:linear-gradient(135deg,#fff,rgba(255,255,255,.7));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

.hdr-right{display:flex;align-items:center;gap:10px}
.cal-badge{display:flex;align-items:center;gap:5px;background:rgba(251,191,36,.1);border:1px solid rgba(251,191,36,.2);border-radius:99px;padding:5px 10px;font-size:12px;font-weight:700;color:#fde68a}
.cal-badge svg{width:13px;height:13px;stroke:#fbbf24;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.hdr-avatar{width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}
.hdr-avatar:hover{background:rgba(255,255,255,.12);transform:scale(1.05)}
.hdr-avatar svg{width:16px;height:16px;stroke:rgba(255,255,255,.7);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

/* ── Main content area ── */
.app-main{
  flex:1;overflow:hidden auto;
  padding:0;position:relative;z-index:1;
  /* account for bottom nav */
  padding-bottom:80px;
}

/* ── Pages ── */
.page{display:none;padding:18px 16px;animation:page-in .38s var(--ease-out)}
.page.active{display:block}
@keyframes page-in{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}

.page-title{font-size:18px;font-weight:800;color:#fff;display:flex;align-items:center;gap:9px;margin-bottom:18px}
.page-title svg{width:20px;height:20px;stroke:var(--c-green);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

/* ── Stat cards ── */
.stat-card{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.07);
  border-radius:var(--r-xl);
  padding:16px 12px;
  display:flex;flex-direction:column;align-items:center;gap:5px;
  transition:transform .2s,box-shadow .2s;
  position:relative;overflow:hidden;
}
.stat-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.3)}
.stat-card::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent)}
.stat-card svg{width:20px;height:20px;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.stat-val{font-size:22px;font-weight:800;color:#fff;line-height:1}
.stat-lbl{font-size:11px;font-weight:600;color:var(--c-dim);letter-spacing:.04em}

/* ── Home greeting card ── */
.home-card{
  background:rgba(255,255,255,.042);
  border:1px solid rgba(255,255,255,.075);
  border-radius:var(--r-xl);padding:20px 18px;margin-bottom:16px;
  position:relative;overflow:hidden;
}
.home-card::before{content:'';position:absolute;top:-40px;right:-40px;width:120px;height:120px;border-radius:50%;background:radial-gradient(circle,rgba(79,216,138,.12),transparent 70%);pointer-events:none}
.home-card-name{font-size:20px;font-weight:800;color:#fff;margin-bottom:4px}
.home-card-sub{font-size:13px;color:var(--c-muted);font-weight:400;line-height:1.5}

/* ── Plan box ── */
.plan-section{margin-top:16px}
.plan-section-title{font-size:13px;font-weight:700;color:var(--c-green);text-transform:uppercase;letter-spacing:.1em;margin-bottom:10px;display:flex;align-items:center;gap:6px}
.plan-section-title svg{width:14px;height:14px;stroke:var(--c-green);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.plan-item{display:flex;align-items:center;gap:12px;padding:13px 14px;background:rgba(255,255,255,.035);border:1px solid rgba(255,255,255,.065);border-radius:14px;margin-bottom:8px;cursor:pointer;transition:all .2s var(--ease-out)}
.plan-item:hover{background:rgba(255,255,255,.06);transform:translateX(3px)}
.plan-item-icon{width:36px;height:36px;border-radius:11px;background:rgba(79,216,138,.12);border:1px solid rgba(79,216,138,.2);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.plan-item-icon svg{width:16px;height:16px;stroke:var(--c-green);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.plan-item-info{flex:1;min-width:0}
.plan-item-name{font-size:14px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.plan-item-meta{font-size:12px;color:var(--c-dim);margin-top:1px}
.plan-item-badge{font-size:11px;font-weight:700;padding:4px 9px;border-radius:99px;background:rgba(79,216,138,.1);border:1px solid rgba(79,216,138,.2);color:var(--c-green);flex-shrink:0}

/* ── Scanner ── */
.scan-preview{
  width:100%;aspect-ratio:4/3;border-radius:18px;overflow:hidden;
  background:rgba(255,255,255,.03);
  border:1px dashed rgba(255,255,255,.1);
  display:flex;align-items:center;justify-content:center;
  position:relative;
}
.scan-preview::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at center,rgba(79,216,138,.05),transparent 70%);pointer-events:none}
#scan-ph{display:flex;flex-direction:column;align-items:center;gap:8px}
#scan-ph svg{width:44px;height:44px;stroke:rgba(255,255,255,.2);fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
#scan-ph p{font-size:13px;color:rgba(255,255,255,.28);font-weight:500}

/* corner brackets on scan zone */
.scan-preview::after{
  content:'';position:absolute;inset:12px;pointer-events:none;
  border:none;
  background:
    linear-gradient(var(--c-green),var(--c-green)) top left/22px 2px no-repeat,
    linear-gradient(var(--c-green),var(--c-green)) top left/2px 22px no-repeat,
    linear-gradient(var(--c-green),var(--c-green)) top right/22px 2px no-repeat,
    linear-gradient(var(--c-green),var(--c-green)) top right/2px 22px no-repeat,
    linear-gradient(var(--c-green),var(--c-green)) bottom left/22px 2px no-repeat,
    linear-gradient(var(--c-green),var(--c-green)) bottom left/2px 22px no-repeat,
    linear-gradient(var(--c-green),var(--c-green)) bottom right/22px 2px no-repeat,
    linear-gradient(var(--c-green),var(--c-green)) bottom right/2px 22px no-repeat;
  opacity:.5;
}

/* voice box */
.voice-pulse{width:48px;height:48px;border-radius:50%;background:rgba(255,94,122,.12);border:2px solid rgba(255,94,122,.3);display:flex;align-items:center;justify-content:center;margin:0 auto;animation:vpulse 1.2s ease-in-out infinite;position:relative}
.voice-pulse::before{content:'';position:absolute;inset:-8px;border-radius:50%;border:1px solid rgba(255,94,122,.2);animation:vpulse-ring 1.2s ease-in-out infinite}
@keyframes vpulse{0%,100%{transform:scale(1)}50%{transform:scale(1.08);background:rgba(255,94,122,.2)}}
@keyframes vpulse-ring{0%,100%{transform:scale(1);opacity:.5}50%{transform:scale(1.3);opacity:0}}

/* scan result */
.scan-result-card{
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);
  border-radius:var(--r-xl);padding:18px;margin-top:12px;
  animation:card-appear .4s var(--ease-spring);
}
.scan-macro-row{display:flex;gap:8px;margin:12px 0}
.macro-chip{flex:1;padding:10px 8px;border-radius:12px;text-align:center;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07)}
.macro-chip-val{font-size:16px;font-weight:800;color:#fff;display:block}
.macro-chip-lbl{font-size:10px;font-weight:600;color:var(--c-dim);text-transform:uppercase;letter-spacing:.06em;display:block;margin-top:2px}

/* ── Analytics ── */
.log-card{
  background:rgba(255,255,255,.038);border:1px solid rgba(255,255,255,.07);
  border-radius:var(--r-xl);padding:16px;
  display:flex;gap:14px;align-items:flex-start;
  animation:card-appear .4s var(--ease-spring);
}
.log-thumb{width:52px;height:52px;border-radius:12px;background:rgba(56,196,240,.08);border:1px solid rgba(56,196,240,.15);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.log-thumb svg{width:22px;height:22px;stroke:var(--c-cyan);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.log-name{font-size:14px;font-weight:700;color:#fff}
.log-cal{font-size:12px;color:var(--c-dim);margin-top:3px}
.log-time{font-size:11px;color:rgba(255,255,255,.2);margin-top:4px}

/* ── Profile ── */
.profile-avatar{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,rgba(79,216,138,.2),rgba(56,196,240,.15));border:2px solid rgba(79,216,138,.3);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.profile-avatar svg{width:26px;height:26px;stroke:var(--c-green);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.pf-chip{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);border-radius:13px;padding:12px 14px}
.pf-chip-label{font-size:11px;font-weight:600;color:var(--c-dim);text-transform:uppercase;letter-spacing:.07em;margin-bottom:3px;display:flex;align-items:center;gap:5px}
.pf-chip-label svg{width:12px;height:12px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.pf-chip-val{font-size:15px;font-weight:700;color:#fff}

/* ── Bottom Nav ── */
.bottom-nav{
  position:fixed;bottom:0;left:0;right:0;z-index:50;
  display:flex;
  background:rgba(6,6,14,.9);
  border-top:1px solid rgba(255,255,255,.07);
  backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  padding-bottom:env(safe-area-inset-bottom);
}
.bnav{
  flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;
  padding:10px 4px 10px;border:none;background:transparent;cursor:pointer;
  color:rgba(255,255,255,.28);font-family:var(--ff);font-size:10px;font-weight:600;
  letter-spacing:.03em;
  transition:color .22s,transform .15s;
  position:relative;
}
.bnav svg{width:21px;height:21px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;transition:transform .25s var(--ease-spring)}
.bnav:hover{color:rgba(255,255,255,.5)}
.bnav:hover svg{transform:scale(1.1) translateY(-1px)}
.bnav.active{color:var(--c-green)}
.bnav.active svg{transform:scale(1.05) translateY(-1px)}
.bnav-dot{position:absolute;top:8px;width:3px;height:3px;border-radius:50%;background:var(--c-green);opacity:0;transform:scale(0);transition:all .25s var(--ease-spring)}
.bnav.active .bnav-dot{opacity:1;transform:scale(1)}

/* ── Timer Modal ── */
.modal-overlay{
  position:fixed;inset:0;z-index:100;
  display:flex;align-items:center;justify-content:center;
  background:rgba(0,0,0,.75);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  animation:overlay-in .25s var(--ease-out);
}
@keyframes overlay-in{from{opacity:0}to{opacity:1}}
.modal-overlay.hidden{display:none!important}
.timer-display{font-size:64px;font-weight:900;color:#fff;letter-spacing:-.04em;font-variant-numeric:tabular-nums;text-align:center;line-height:1;margin:16px 0;background:linear-gradient(135deg,#fff,rgba(255,255,255,.7));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

/* scale-in for modal content */
.scale-in{animation:scale-in .35s var(--ease-spring)}
@keyframes scale-in{from{transform:scale(.88);opacity:0}to{transform:scale(1);opacity:1}}

/* ── Loading / Success overlays ── */
#loader,#success-overlay{background:rgba(6,6,14,.92)}
#load-txt,#success-txt{font-family:var(--ff)}

/* ── Shared utility ── */
.w-full{width:100%}
.mb-3{margin-bottom:12px}
.mb-4{margin-bottom:16px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.flex{display:flex}
.items-center{align-items:center}
.gap-2{gap:8px}
.gap-3{gap:12px}
.gap-4{gap:16px}
.space-y-3>*+*{margin-top:12px}
.text-center{text-align:center}
.font-bold{font-weight:700}
.font-semibold{font-weight:600}
.text-sm{font-size:13px}
.text-xs{font-size:11px}
.text-lg{font-size:18px}
.text-white{color:#fff}
.text-gray-400{color:rgba(255,255,255,.45)}
.text-gray-500{color:rgba(255,255,255,.3)}
.text-gray-600{color:rgba(255,255,255,.18)}
.text-accent{color:var(--c-green)}
.text-cyan{color:var(--c-cyan)}
.text-pink{color:var(--c-pink)}
.text-yellow-400{color:var(--c-yellow)}
.hidden{display:none!important}
.px-1{padding-left:4px;padding-right:4px}
.p-4{padding:16px}
.p-5{padding:20px}
.p-6{padding:24px}
.p-8{padding:32px}
.px-6{padding-left:24px;padding-right:24px}
.px-8{padding-left:32px;padding-right:32px}
.mt-2{margin-top:8px}
.mt-3{margin-top:12px}
.mt-4{margin-top:16px}
.mt-6{margin-top:24px}
.mr-2{margin-right:8px}
.mb-1{margin-bottom:4px}
.mb-2{margin-bottom:8px}
.mx-4{margin-left:16px;margin-right:16px}
.max-w-sm{max-width:384px}
.rounded-2xl{border-radius:var(--r-xl)}
.rounded-3xl{border-radius:var(--r-2xl)}
.justify-center{justify-content:center}
.justify-between{justify-content:space-between}

/* scrollbar */
::-webkit-scrollbar{width:0;height:0}
</style>
</head>
<body>

<!-- ══════════════ AUTH SCREEN ══════════════ -->
<section id="v-auth" class="view <?=$logged?'hidden':''?>">

  <div class="auth-orbs">
    <div class="auth-orb auth-orb-1"></div>
    <div class="auth-orb auth-orb-2"></div>
    <div class="auth-orb auth-orb-3"></div>
    <div class="auth-orb auth-orb-4"></div>
  </div>
  <div class="auth-scanline"></div>
  <div id="auth-particles"></div>

  <div class="auth-wrap">

    <!-- Logo -->
    <div class="auth-logo-zone">
      <div class="logo-ring-wrap">
        <svg class="logo-ring-svg" viewBox="0 0 80 80" xmlns="http://www.w3.org/2000/svg">
          <defs>
            <linearGradient id="ring-grad" x1="0%" y1="0%" x2="100%" y2="100%">
              <stop offset="0%"   stop-color="#4fd88a"/>
              <stop offset="50%"  stop-color="#38c4f0"/>
              <stop offset="100%" stop-color="#a855f7"/>
            </linearGradient>
          </defs>
          <circle cx="40" cy="40" r="35" class="lr-track"/>
          <circle cx="40" cy="40" r="35" class="lr-glow" transform="rotate(-90 40 40)"/>
          <circle cx="40" cy="40" r="35" class="lr-main" transform="rotate(-90 40 40)"/>
          <circle cx="40" cy="40" r="32" class="lr-spin" transform="rotate(-90 40 40)"/>
        </svg>
        <div class="logo-dot-wrap">
          <div class="logo-dot">
            <svg viewBox="0 0 24 24">
              <path d="M20.84 4.61a5.5 5.5 0 00-7.78 0L12 5.67l-1.06-1.06a5.5 5.5 0 00-7.78 7.78l1.06 1.06L12 21.23l7.78-7.78 1.06-1.06a5.5 5.5 0 000-7.78z"/>
            </svg>
          </div>
          <div class="logo-orbit"><div class="logo-orbit-dot"></div></div>
        </div>
      </div>
      <h1 class="auth-logo-title">AforHealth</h1>
      <p class="auth-logo-sub">Yapay Zeka Sağlık Koçu</p>
    </div>

    <!-- Card -->
    <div class="auth-card-wrap">
      <div class="auth-beam"></div>
      <div class="auth-card">

        <!-- Tabs -->
        <div class="auth-tab-row">
          <button class="auth-tab active" id="t-login" onclick="authTab('login')">
            <span>Giriş Yap</span>
            <div class="auth-tab-ink"></div>
          </button>
          <button class="auth-tab" id="t-reg" onclick="authTab('reg')">
            <span>Kayıt Ol</span>
            <div class="auth-tab-ink"></div>
          </button>
        </div>

        <div id="auth-alert"></div>

        <!-- Login form -->
        <form id="f-login" class="auth-form form-entered" onsubmit="return doLogin(event)">
          <div class="auth-field">
            <div class="auth-field-inner">
              <span class="auth-field-icon">
                <svg viewBox="0 0 24 24"><rect x="2" y="4" width="20" height="16" rx="2"/><path d="m2 7 10 7 10-7"/></svg>
              </span>
              <input type="email" id="l-e" class="auth-inp" placeholder=" " required autocomplete="email">
              <label class="auth-field-label">E-posta adresi</label>
            </div>
          </div>
          <div class="auth-field">
            <div class="auth-field-inner">
              <span class="auth-field-icon">
                <svg viewBox="0 0 24 24"><rect x="3" y="11" width="18" height="11" rx="2"/><path d="M7 11V7a5 5 0 0 1 10 0v4"/></svg>
              </span>
              <input type="password" id="l-p" class="auth-inp" placeholder=" " required autocomplete="current-password">
              <label class="auth-field-label">Şifre</label>
            </div>
          </div>
          <div class="auth-btn-wrap">
            <button type="submit" class="auth-btn" id="bl" onclick="addRipple(event)">
              <div class="auth-btn-spinner"></div>
              <span class="auth-btn-text">Giriş Yap</span>
              <span class="auth-btn-shine"></span>
            </button>
          </div>
        </form>

        <!-- Register form — starts hidden -->
        <form id="f-reg" class="auth-form hidden" onsubmit="return doRegister(event)">
          <div class="auth-field">
            <div class="auth-field-inner">
              <span class="auth-field-icon">
                <svg viewBox="0 0 24 24"><circle cx="12" cy="8" r="4"/><path d="M4 20c0-4 3.6-7 8-7s8 3 8 7"/></svg>
              </span>
              <input type="text" id="r-n" class="auth-inp" placeholder=" " required autocomplete="name">
              <label class="auth-field-label">Ad Soyad</label>
            </div>
          </div>
          <div class="auth-field">
            <div class="auth-field-inner">
              <span class="auth-field-icon">
                <svg viewBox="0 0 24 24"><rect x="2" y="4" width="20" height="16" rx="2"/><path d="m2 7 10 7 10-7"/></svg>
              </span>
              <input type="email" id="r-e" class="auth-inp" placeholder=" " required autocomplete="email">
              <label class="auth-field-label">E-posta adresi</label>
            </div>
          </div>
          <div class="auth-field">
            <div class="auth-field-inner">
              <span class="auth-field-icon">
                <svg viewBox="0 0 24 24"><rect x="3" y="11" width="18" height="11" rx="2"/><path d="M7 11V7a5 5 0 0 1 10 0v4"/></svg>
              </span>
              <input type="password" id="r-p" class="auth-inp" placeholder=" " required minlength="6" autocomplete="new-password">
              <label class="auth-field-label">Şifre (min 6 karakter)</label>
            </div>
          </div>
          <div class="auth-btn-wrap">
            <button type="submit" class="auth-btn" id="br" onclick="addRipple(event)">
              <div class="auth-btn-spinner"></div>
              <span class="auth-btn-text">Hesap Oluştur</span>
              <span class="auth-btn-shine"></span>
            </button>
          </div>
        </form>

      </div><!-- /auth-card -->
    </div><!-- /auth-card-wrap -->

  </div><!-- /auth-wrap -->
</section>

<!-- ══════════════ ONBOARDING ══════════════ -->
<section id="v-onboard" class="view hidden">
  <div style="flex:1;overflow:hidden auto;display:flex;align-items:center;justify-content:center;padding:20px 16px">
    <div class="onboard-wrap">
      <div class="onboard-header">
        <h2 class="onboard-title">
          <svg viewBox="0 0 24 24"><path d="M9 11l3 3L22 4"/><path d="M21 12v7a2 2 0 01-2 2H5a2 2 0 01-2-2V5a2 2 0 012-2h11"/></svg>
          Sağlık Anketi
        </h2>
        <span id="ob-counter" class="onboard-counter">1 / 30</span>
      </div>

      <div class="ob-progress-wrap">
        <div class="ob-progress-track">
          <div id="ob-bar" class="ob-progress-fill" style="width:3.3%"></div>
        </div>
      </div>

      <div id="ob-container" class="ob-card"></div>
    </div>
  </div>
</section>

<!-- ══════════════ APP ══════════════ -->
<section id="v-app" class="view hidden">

  <!-- Header -->
  <header class="app-header">
    <div class="flex items-center gap-2">
      <div class="header-orb">
        <svg viewBox="0 0 24 24"><path d="M20.84 4.61a5.5 5.5 0 00-7.78 0L12 5.67l-1.06-1.06a5.5 5.5 0 00-7.78 7.78l1.06 1.06L12 21.23l7.78-7.78 1.06-1.06a5.5 5.5 0 000-7.78z"/></svg>
      </div>
      <span class="logo-text">AforHealth</span>
    </div>
    <div class="hdr-right">
      <span id="hdr-cal" class="cal-badge">
        <svg viewBox="0 0 24 24"><path d="M8.5 14.5A2.5 2.5 0 0011 12c0-1.38-.5-2-1-3-1.072-2.143-.224-4.054 2-6 .5 2.5 2 4.9 4 6.5 2 1.6 3 3.5 3 5.5a7 7 0 11-14 0c0-1.153.433-2.294 1-3a2.5 2.5 0 002.5 2.5z"/></svg>
        <span id="hdr-cal-val">0</span>
      </span>
      <button onclick="nav('profile')" class="hdr-avatar">
        <svg viewBox="0 0 24 24"><circle cx="12" cy="8" r="4"/><path d="M4 20c0-4 3.6-7 8-7s8 3 8 7"/></svg>
      </button>
    </div>
  </header>

  <!-- Pages -->
  <main class="app-main">

    <!-- HOME -->
    <div id="p-home" class="page active">
      <div class="home-card">
        <div class="home-card-name">Merhaba, <span id="d-name"></span></div>
        <div class="home-card-sub" id="d-coach">Bugünkü sağlık planını oluşturmak için hazır mısın?</div>
      </div>

      <div class="grid-3 mb-4">
        <div class="stat-card">
          <svg viewBox="0 0 24 24" style="stroke:var(--c-cyan)"><path d="M4 6h16M4 12h16M4 18h7"/><circle cx="17" cy="18" r="2"/><path d="M17 16V12"/></svg>
          <span class="stat-val" id="st-sc">0</span>
          <span class="stat-lbl">Tarama</span>
        </div>
        <div class="stat-card">
          <svg viewBox="0 0 24 24" style="stroke:var(--c-pink)"><path d="M8.5 14.5A2.5 2.5 0 0011 12c0-1.38-.5-2-1-3-1.072-2.143-.224-4.054 2-6 .5 2.5 2 4.9 4 6.5 2 1.6 3 3.5 3 5.5a7 7 0 11-14 0c0-1.153.433-2.294 1-3a2.5 2.5 0 002.5 2.5z"/></svg>
          <span class="stat-val" id="st-cal">0</span>
          <span class="stat-lbl">kcal</span>
        </div>
        <div class="stat-card">
          <svg viewBox="0 0 24 24" style="stroke:var(--c-green)"><rect x="3" y="4" width="18" height="18" rx="2"/><path d="M16 2v4M8 2v4M3 10h18"/><path d="M9 15l2 2 4-4"/></svg>
          <span class="stat-val" id="st-pl">0</span>
          <span class="stat-lbl">Plan</span>
        </div>
      </div>

      <button onclick="genPlan()" class="btn-glow w-full mb-4" id="btn-gen">
        <svg viewBox="0 0 24 24" style="width:18px;height:18px;stroke:#06060e;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round"><path d="M12 3L13.9 8.1L19 9L14.9 13L16.2 18L12 15.3L7.8 18L9.1 13L5 9L10.1 8.1L12 3z"/></svg>
        <span>Günlük Plan Oluştur</span>
      </button>

      <div id="plan-box"></div>
    </div>

    <!-- SCANNER -->
    <div id="p-scanner" class="page">
      <h2 class="page-title">
        <svg viewBox="0 0 24 24"><path d="M15 3h4a2 2 0 012 2v4M9 3H5a2 2 0 00-2 2v4M15 21h4a2 2 0 002-2v-4M9 21H5a2 2 0 01-2-2v-4"/><circle cx="12" cy="12" r="3"/></svg>
        Yemek Tarayıcı
      </h2>

      <div class="glass p-6 rounded-2xl text-center mb-4">
        <div id="scan-zone" class="scan-preview">
          <div id="scan-ph">
            <svg viewBox="0 0 24 24"><path d="M18 8h1a4 4 0 010 8h-1"/><path d="M2 8h16v9a4 4 0 01-4 4H6a4 4 0 01-4-4V8z"/><line x1="6" y1="1" x2="6" y2="4"/><line x1="10" y1="1" x2="10" y2="4"/><line x1="14" y1="1" x2="14" y2="4"/></svg>
            <p>Fotoğraf yükle veya sesle kaydet</p>
          </div>
          <img id="scan-img" class="hidden" style="width:100%;height:100%;object-fit:cover;border-radius:16px">
        </div>
        <input type="file" id="f-photo" accept="image/*" capture="environment" class="hidden" onchange="previewPhoto(this)">
        <div class="grid-2 mt-4" style="gap:10px">
          <button onclick="document.getElementById('f-photo').click()" class="btn-glass">
            <svg viewBox="0 0 24 24" style="width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round"><rect x="3" y="3" width="18" height="18" rx="2"/><circle cx="8.5" cy="8.5" r="1.5"/><path d="M21 15l-5-5L5 21"/></svg>
            Fotoğraf
          </button>
          <button onclick="startVoice()" id="btn-voice" class="btn-glass">
            <svg viewBox="0 0 24 24" style="width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round"><path d="M12 1a3 3 0 00-3 3v8a3 3 0 006 0V4a3 3 0 00-3-3z"/><path d="M19 10v2a7 7 0 01-14 0v-2M12 19v4M8 23h8"/></svg>
            Sesli Kayıt
          </button>
        </div>
        <button onclick="doScan()" id="btn-scan" class="btn-glow w-full mt-3 hidden">
          <svg viewBox="0 0 24 24" style="width:16px;height:16px;stroke:#06060e;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round"><circle cx="11" cy="11" r="8"/><path d="m21 21-4.35-4.35"/></svg>
          <span>Analiz Et</span>
        </button>
      </div>

      <div id="voice-box" class="hidden glass p-4 rounded-2xl mb-4 text-center">
        <div class="voice-pulse mb-2">
          <svg viewBox="0 0 24 24" style="width:20px;height:20px;stroke:var(--c-red);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round"><path d="M12 1a3 3 0 00-3 3v8a3 3 0 006 0V4a3 3 0 00-3-3z"/><path d="M19 10v2a7 7 0 01-14 0v-2"/></svg>
        </div>
        <p class="text-sm text-gray-300" id="voice-text">Dinleniyor...</p>
        <button onclick="stopVoice()" class="btn-glass mt-3">
          <svg viewBox="0 0 24 24" style="width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round"><rect x="3" y="3" width="18" height="18" rx="2"/></svg>
          Durdur ve Analiz Et
        </button>
      </div>

      <div id="scan-result"></div>
    </div>

    <!-- ANALYTICS -->
    <div id="p-analytics" class="page">
      <h2 class="page-title">
        <svg viewBox="0 0 24 24"><line x1="18" y1="20" x2="18" y2="10"/><line x1="12" y1="20" x2="12" y2="4"/><line x1="6" y1="20" x2="6" y2="14"/><line x1="2" y1="20" x2="22" y2="20"/></svg>
        Analitik
      </h2>
      <div id="logs-box" class="space-y-3"></div>
    </div>

    <!-- PROFILE -->
    <div id="p-profile" class="page">
      <h2 class="page-title">
        <svg viewBox="0 0 24 24"><circle cx="12" cy="8" r="4"/><path d="M4 20c0-4 3.6-7 8-7s8 3 8 7"/></svg>
        Profil
      </h2>
      <div class="glass p-5 rounded-2xl mb-4">
        <div class="flex items-center gap-4 mb-4">
          <div class="profile-avatar">
            <svg viewBox="0 0 24 24"><circle cx="12" cy="8" r="4"/><path d="M4 20c0-4 3.6-7 8-7s8 3 8 7"/></svg>
          </div>
          <div>
            <div class="font-bold text-white" id="pf-name">—</div>
            <div class="text-xs text-gray-500" id="pf-email">—</div>
          </div>
        </div>
        <div id="pf-grid" class="grid-2"></div>
      </div>
      <button onclick="showOnboarding()" class="btn-glass w-full mb-3">
        <svg viewBox="0 0 24 24" style="width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round"><path d="M11 4H4a2 2 0 00-2 2v14a2 2 0 002 2h14a2 2 0 002-2v-7"/><path d="M18.5 2.5a2.121 2.121 0 013 3L12 15l-4 1 1-4 9.5-9.5z"/></svg>
        Anketi Güncelle
      </button>
      <button onclick="doLogout()" class="btn-danger w-full">
        <svg viewBox="0 0 24 24" style="width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round"><path d="M9 21H5a2 2 0 01-2-2V5a2 2 0 012-2h4"/><polyline points="16 17 21 12 16 7"/><line x1="21" y1="12" x2="9" y2="12"/></svg>
        Çıkış Yap
      </button>
    </div>

  </main>

  <!-- Bottom Nav -->
  <nav class="bottom-nav">
    <button class="bnav active" onclick="nav('home',this)" data-page="home">
      <div class="bnav-dot"></div>
      <svg viewBox="0 0 24 24"><path d="M3 9l9-7 9 7v11a2 2 0 01-2 2H5a2 2 0 01-2-2z"/><polyline points="9 22 9 12 15 12 15 22"/></svg>
      <span>Ana Sayfa</span>
    </button>
    <button class="bnav" onclick="nav('scanner',this)" data-page="scanner">
      <div class="bnav-dot"></div>
      <svg viewBox="0 0 24 24"><path d="M15 3h4a2 2 0 012 2v4M9 3H5a2 2 0 00-2 2v4M15 21h4a2 2 0 002-2v-4M9 21H5a2 2 0 01-2-2v-4"/><circle cx="12" cy="12" r="3"/></svg>
      <span>Tarayıcı</span>
    </button>
    <button class="bnav" onclick="nav('analytics',this)" data-page="analytics">
      <div class="bnav-dot"></div>
      <svg viewBox="0 0 24 24"><line x1="18" y1="20" x2="18" y2="10"/><line x1="12" y1="20" x2="12" y2="4"/><line x1="6" y1="20" x2="6" y2="14"/><line x1="2" y1="20" x2="22" y2="20"/></svg>
      <span>Analitik</span>
    </button>
    <button class="bnav" onclick="nav('profile',this)" data-page="profile">
      <div class="bnav-dot"></div>
      <svg viewBox="0 0 24 24"><circle cx="12" cy="8" r="4"/><path d="M4 20c0-4 3.6-7 8-7s8 3 8 7"/></svg>
      <span>Profil</span>
    </button>
  </nav>
</section>

<!-- ══════════════ TIMER MODAL ══════════════ -->
<div id="timer-modal" class="modal-overlay hidden">
  <div class="glass p-8 rounded-3xl text-center max-w-sm w-full mx-4 scale-in">
    <div style="width:52px;height:52px;border-radius:16px;background:rgba(79,216,138,.12);border:1px solid rgba(79,216,138,.25);display:flex;align-items:center;justify-content:center;margin:0 auto 14px">
      <svg viewBox="0 0 24 24" style="width:22px;height:22px;stroke:var(--c-green);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round"><circle cx="12" cy="12" r="10"/><polyline points="12 6 12 12 16 14"/></svg>
    </div>
    <h4 class="font-bold text-lg text-white" id="tm-name">Egzersiz</h4>
    <p class="text-sm text-gray-400 mb-4" id="tm-info">3 set × 12 tekrar</p>
    <div id="tm-time" class="timer-display">00:30</div>
    <p class="text-sm mt-2 mb-6" id="tm-st" style="color:var(--c-yellow)">Dinlenme süresi</p>
    <div style="display:flex;gap:10px;justify-content:center">
      <button onclick="tmToggle()" id="tm-btn" class="btn-glow px-8">
        <svg viewBox="0 0 24 24" id="tm-ico" style="width:16px;height:16px;stroke:#06060e;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round"><polygon points="5 3 19 12 5 21 5 3"/></svg>
        <span id="tm-btn-txt">Başla</span>
      </button>
      <button onclick="tmClose()" class="btn-glass px-6">
        <svg viewBox="0 0 24 24" style="width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round"><line x1="18" y1="6" x2="6" y2="18"/><line x1="6" y1="6" x2="18" y2="18"/></svg>
      </button>
    </div>
    <div class="progress-track mt-6"><div id="tm-bar" class="progress-fill" style="width:100%"></div></div>
  </div>
</div>

<!-- ══════════════ LOADING OVERLAY ══════════════ -->
<div id="loader" class="modal-overlay hidden">
  <div class="text-center">
    <div id="lottie-load" style="width:100px;height:100px;margin:0 auto"></div>
    <p class="text-gray-400 text-sm mt-2" id="load-txt">Yükleniyor...</p>
  </div>
</div>

<!-- ══════════════ SUCCESS OVERLAY ══════════════ -->
<div id="success-overlay" class="modal-overlay hidden">
  <div class="text-center">
    <div id="lottie-success" style="width:120px;height:120px;margin:0 auto"></div>
    <p class="text-white font-semibold text-lg mt-2" id="success-txt">Başarılı!</p>
  </div>
</div>

<script src="onboarding.js"></script>
<script src="app.js"></script>
<script>
/* ══ Auth tab switch ══ */
let _authTab = 'login';
function authTab(tab) {
  if (tab === _authTab) return;
  const login = document.getElementById('f-login');
  const reg   = document.getElementById('f-reg');
  const tL    = document.getElementById('t-login');
  const tR    = document.getElementById('t-reg');
  const outCls = tab === 'reg' ? 'out-left' : 'out-right';
  const cur    = tab === 'reg' ? login : reg;
  const nxt    = tab === 'reg' ? reg   : login;

  cur.classList.remove('form-entered');
  cur.classList.add(outCls);

  setTimeout(() => {
    cur.classList.add('hidden');
    cur.classList.remove(outCls, 'form-entered');
    nxt.classList.remove('hidden', 'out-left', 'out-right', 'form-entered');
    requestAnimationFrame(() => requestAnimationFrame(() => nxt.classList.add('form-entered')));
  }, 290);

  tL.classList.toggle('active', tab === 'login');
  tR.classList.toggle('active', tab === 'reg');
  _authTab = tab;
  hideAuthAlert();
}

/* ══ Ripple ══ */
function addRipple(e) {
  const btn  = e.currentTarget;
  const rect = btn.getBoundingClientRect();
  const size = Math.max(rect.width, rect.height);
  const rip  = document.createElement('span');
  rip.className = 'auth-btn-ripple';
  Object.assign(rip.style, {
    width:  size + 'px', height: size + 'px',
    left:   (e.clientX - rect.left - size / 2) + 'px',
    top:    (e.clientY - rect.top  - size / 2) + 'px'
  });
  btn.appendChild(rip);
  setTimeout(() => rip.remove(), 700);
}

/* ══ Alerts ══ */
function showAuthAlert(msg, type = 'error') {
  const el = document.getElementById('auth-alert');
  el.textContent = msg;
  el.className = type === 'success' ? 'show success-msg' : 'show';
}
function hideAuthAlert() {
  document.getElementById('auth-alert').className = '';
}

/* ══ Particles ══ */
(function spawnParticles() {
  const container = document.getElementById('auth-particles');
  if (!container) return;
  Object.assign(container.style, { position:'absolute', inset:0, pointerEvents:'none', overflow:'hidden', zIndex:1 });
  const colors = ['rgba(79,216,138,.75)','rgba(56,196,240,.7)','rgba(168,85,247,.6)','rgba(236,72,153,.5)','rgba(255,255,255,.4)'];
  for (let i = 0; i < 32; i++) {
    const p    = document.createElement('div');
    p.className = 'auth-particle';
    const size = Math.random() * 4.5 + 1.5;
    const dur  = Math.random() * 20 + 12;
    const del  = Math.random() * 16;
    const dx   = (Math.random() - 0.5) * 180;
    const col  = colors[Math.floor(Math.random() * colors.length)];
    Object.assign(p.style, {
      width: size+'px', height: size+'px',
      left: Math.random()*100+'%', bottom:'-10px',
      background: col,
      boxShadow: `0 0 ${size*3}px ${col}`,
      '--dx': dx+'px',
      animationDuration: dur+'s',
      animationDelay: del+'s',
    });
    container.appendChild(p);
  }
})();

/* ══ DOMContentLoaded ══ */
document.addEventListener('DOMContentLoaded', () => {
  // Init Lucide icons
  if (window.lucide) lucide.createIcons();

  // PWA service worker
  if ('serviceWorker' in navigator) {
    navigator.serviceWorker.register('pwa_config/sw.js').catch(() => {});
  }

  <?php if($logged):?>
  if (typeof initApp === 'function') initApp();
  <?php endif;?>
});
</script>
</body>
</html>