:root{
  --grad:linear-gradient(135deg,#7c3aed,#9333ea);
  --grad-soft:linear-gradient(135deg,#8b5cf6,#7c3aed);
  --purple:#7c3aed;
  --purple-ink:#6d28d9;
  --ink:#14142b;
  --muted:#6b6b87;
  --muted2:#9090aa;
  --bg:#f1f0fa;
  --line:#ecebf6;
  --gold:#f5b301;
  --gold2:#f59e0b;
  --green:#16b86a;
  --red:#f43f5e;
}
*{margin:0;padding:0;box-sizing:border-box;font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Arial,sans-serif;-webkit-tap-highlight-color:transparent;}
html,body{height:100%;overflow:hidden;}
body{background:#e7e6f3;color:var(--ink);font-size:14px;line-height:1.4;overscroll-behavior-y:none;}

/* ===== APP SHELL (phone frame on desktop, fullscreen on mobile) ===== */
.app{
  position:relative;max-width:480px;margin:0 auto;height:100vh;height:100dvh;
  background:var(--bg);overflow:hidden;display:flex;flex-direction:column;
  box-shadow:0 0 60px rgba(20,20,60,.12);
}
.screen{display:none;flex:1;min-height:0;flex-direction:column;animation:fade .25s ease;}
.screen.active{display:flex;}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}

/* scrollable content area; leaves room for tabbar */
.scroll{flex:1;min-height:0;overflow-y:auto;scrollbar-gutter:stable;-webkit-overflow-scrolling:touch;padding:0 16px calc(94px + env(safe-area-inset-bottom));}
body.logged-out .scroll{padding-bottom:24px;}
.screen.auth .scroll{display:flex;flex-direction:column;}

/* ===== GENERIC ===== */
.muted{color:var(--muted);}
.row{display:flex;align-items:center;}
.between{justify-content:space-between;}
.gap8{gap:8px;}.gap12{gap:12px;}
.section-title{font-size:16px;font-weight:800;margin:18px 2px 10px;display:flex;align-items:center;justify-content:space-between;}
.section-title .link{font-size:12.5px;font-weight:700;color:var(--purple);cursor:pointer;}
.card{background:#fff;border-radius:18px;padding:14px;box-shadow:0 4px 18px rgba(20,20,60,.05);}

/* ===== TOP HEADER (home) ===== */
.home-head{display:flex;align-items:flex-start;justify-content:space-between;padding:18px 16px 6px;}
.home-head .hi{font-size:13px;color:var(--muted);}
.home-head h1{font-size:21px;font-weight:800;margin-top:1px;display:flex;align-items:center;gap:6px;}
.home-clinic{display:inline-flex;align-items:center;gap:6px;margin-top:7px;font-size:12px;font-weight:700;color:var(--purple);background:#f1e7ff;padding:4px 11px;border-radius:20px;}
.home-clinic i{font-size:10.5px;}
.head-actions{display:flex;align-items:center;gap:10px;}
.bell{position:relative;width:42px;height:42px;border-radius:14px;background:#fff;border:none;display:flex;align-items:center;justify-content:center;font-size:16px;color:var(--ink);box-shadow:0 4px 14px rgba(20,20,60,.06);cursor:pointer;}
.bell .dot{position:absolute;top:8px;right:9px;width:9px;height:9px;background:var(--red);border-radius:50%;border:2px solid #fff;}
.head-avatar{width:46px;height:46px;border-radius:50%;object-fit:cover;border:2px solid #fff;box-shadow:0 4px 14px rgba(20,20,60,.12);}

/* ===== SUBPAGE HEADER ===== */
.subhead{display:flex;align-items:center;gap:12px;padding:16px;}
.subhead h2{font-size:18px;font-weight:800;flex:1;text-align:center;}
.iconbtn{width:42px;height:42px;border-radius:14px;background:#fff;border:none;display:flex;align-items:center;justify-content:center;font-size:16px;color:var(--ink);box-shadow:0 4px 14px rgba(20,20,60,.06);cursor:pointer;flex-shrink:0;}
.pts-chip{display:inline-flex;align-items:center;gap:6px;background:var(--grad);color:#fff;font-weight:800;font-size:13px;padding:9px 13px;border-radius:14px;box-shadow:0 6px 16px rgba(124,58,237,.35);flex-shrink:0;}
.pts-chip i{color:#ffe08a;}
.subhead .iconbtn.ghost{visibility:hidden;}

/* ===== POINTS HERO ===== */
.hero{background:var(--grad);border-radius:24px;padding:20px;color:#fff;position:relative;overflow:hidden;box-shadow:0 14px 30px rgba(124,58,237,.32);}
.hero:before{content:"";position:absolute;width:180px;height:180px;border-radius:50%;background:rgba(255,255,255,.10);top:-60px;right:-40px;}
.hero:after{content:"";position:absolute;width:120px;height:120px;border-radius:50%;background:rgba(255,255,255,.07);bottom:-50px;left:-30px;}
.hero .top{display:flex;justify-content:space-between;align-items:flex-start;position:relative;z-index:1;}
.hero .lbl{font-size:12.5px;opacity:.9;}
.hero .pts{font-size:40px;font-weight:800;line-height:1.05;margin:4px 0 0;display:flex;align-items:center;gap:8px;}
.hero .pts .coin{font-size:22px;}
.hero .pts-sub{font-size:13px;opacity:.9;}
.medal{width:84px;height:84px;flex-shrink:0;border-radius:20px;background:linear-gradient(135deg,#ffd24d,#f59e0b);display:flex;flex-direction:column;align-items:center;justify-content:center;box-shadow:0 8px 20px rgba(245,158,11,.45);position:relative;}
.medal .crown{font-size:30px;line-height:1;filter:drop-shadow(0 2px 2px rgba(0,0,0,.15));}
.medal .mtxt{font-size:9.5px;font-weight:800;color:#7a4b00;margin-top:3px;letter-spacing:.3px;text-transform:uppercase;}
.hero .next{position:relative;z-index:1;margin-top:18px;}
.hero .next .small{font-size:12px;opacity:.9;}
.hero .next .remain{font-size:18px;font-weight:800;margin-top:1px;}
.progress{position:relative;margin-top:14px;}
.progress .track{height:10px;background:rgba(255,255,255,.28);border-radius:20px;overflow:hidden;}
.progress .fill{height:100%;width:0;background:linear-gradient(90deg,#ffd24d,#f59e0b);border-radius:20px;transition:width .8s cubic-bezier(.34,1.2,.64,1);}
.progress .bubble{position:absolute;top:-24px;transform:translateX(-50%);background:#fff;color:var(--purple);font-size:11px;font-weight:800;padding:2px 8px;border-radius:20px;box-shadow:0 4px 10px rgba(0,0,0,.15);transition:left .8s cubic-bezier(.34,1.2,.64,1);}
.progress .ends{display:flex;justify-content:space-between;font-size:11px;opacity:.9;margin-top:7px;}

/* ===== QUICK ACTIONS ===== */
.quick{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:16px;}
.quick .q{background:#fff;border-radius:18px;padding:12px 6px;text-align:center;cursor:pointer;box-shadow:0 4px 14px rgba(20,20,60,.05);transition:transform .15s;}
.quick .q:active{transform:scale(.95);}
.q .qi{width:42px;height:42px;border-radius:14px;margin:0 auto 7px;display:flex;align-items:center;justify-content:center;font-size:17px;}
.q .qt{font-size:11px;font-weight:700;color:var(--ink);}
.bg-purple{background:#f1e7ff;color:#8b3dff;}
.bg-pink{background:#ffe8f2;color:#ec4899;}
.bg-blue{background:#e6f0ff;color:#2563eb;}
.bg-green{background:#e3fbef;color:#16b86a;}
.bg-orange{background:#fff2dc;color:#f59e0b;}
.bg-red{background:#ffeef0;color:#f43f5e;}
.bg-teal{background:#e0f7f5;color:#0d9488;}

/* ===== APPOINTMENT CARD ===== */
.appt{display:flex;align-items:center;gap:12px;cursor:pointer;}
.appt .ai{width:52px;height:52px;border-radius:16px;background:#f1e7ff;color:#8b3dff;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;}
.appt .info{flex:1;min-width:0;}
.appt .info strong{font-size:14px;font-weight:800;display:block;}
.appt .info .doc{font-size:12px;color:var(--muted);margin-top:1px;}
.appt .info .dt{font-size:12px;color:var(--purple);font-weight:700;margin-top:4px;display:flex;align-items:center;gap:5px;}
.tag{font-size:10.5px;font-weight:800;padding:4px 9px;border-radius:20px;white-space:nowrap;}
.tag-green{background:#e3fbef;color:#16b86a;}
.tag-orange{background:#fff2dc;color:#f59e0b;}
.tag-grey{background:#f0f0f6;color:#9090aa;}
.tag-purple{background:#f1e7ff;color:#8b3dff;}

/* ===== TRANSACTION / LIST ROWS ===== */
.list{display:flex;flex-direction:column;}
.txn{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--line);}
.txn:last-child{border-bottom:none;}
.txn .ti{width:44px;height:44px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0;}
.txn .tc{flex:1;min-width:0;}
.txn .tc strong{font-size:13.5px;font-weight:700;display:block;}
.txn .tc .sub{font-size:11.5px;color:var(--muted2);margin-top:1px;}
.txn .amt{font-weight:800;font-size:14px;white-space:nowrap;}
.txn .amt .when{display:block;font-size:10.5px;color:var(--muted2);font-weight:600;text-align:right;margin-top:2px;}
.plus{color:var(--green);}
.minus{color:var(--red);}

/* ===== CAMPAIGN BANNER ===== */
.promo{background:linear-gradient(135deg,#efe7ff,#f7f1ff);border-radius:22px;padding:18px;position:relative;overflow:hidden;margin-top:6px;}
.promo .eyebrow{font-size:10.5px;font-weight:800;letter-spacing:.6px;color:var(--purple);text-transform:uppercase;}
.promo h3{font-size:17px;font-weight:800;margin:6px 0;max-width:62%;}
.promo p{font-size:12px;color:var(--muted);max-width:62%;}
.promo .tooth{position:absolute;right:-6px;bottom:-6px;font-size:78px;filter:drop-shadow(0 6px 10px rgba(124,58,237,.25));}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;border:none;cursor:pointer;font-weight:800;border-radius:14px;transition:transform .15s,opacity .2s;}
.btn:active{transform:scale(.97);}
.btn-primary{background:var(--grad);color:#fff;font-size:13px;padding:11px 16px;box-shadow:0 8px 18px rgba(124,58,237,.32);}
.btn-block{width:100%;padding:14px;font-size:14px;border-radius:16px;}
.btn-ghost{background:#fff;color:var(--purple);border:1.5px solid #e3d8ff;font-size:13px;padding:10px 14px;}
.btn-wa{background:linear-gradient(135deg,#25d366,#1ebe57);color:#fff;}
.btn[disabled]{opacity:.45;cursor:not-allowed;box-shadow:none;}
.promo .btn{margin-top:12px;}

/* ===== KAYDIRMALI KAMPANYALAR ===== */
.camp-carousel{position:relative;margin-top:6px;}
.camp-track{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;gap:12px;scrollbar-width:none;-webkit-overflow-scrolling:touch;padding:2px;}
.camp-track::-webkit-scrollbar{display:none;}
.camp-slide{flex:0 0 100%;scroll-snap-align:center;border-radius:22px;padding:18px;position:relative;overflow:hidden;min-height:128px;box-sizing:border-box;}
.camp-slide .eyebrow{font-size:10.5px;font-weight:800;letter-spacing:.6px;color:var(--purple);text-transform:uppercase;}
.camp-slide h3{font-size:17px;font-weight:800;margin:6px 0;max-width:66%;line-height:1.25;}
.camp-slide p{font-size:12px;color:var(--muted);max-width:66%;}
.camp-slide .tag-soon{display:inline-block;margin-top:10px;background:#fff;color:var(--purple);font-size:10.5px;font-weight:800;padding:5px 11px;border-radius:999px;box-shadow:0 4px 10px rgba(124,58,237,.14);}
.camp-emoji{position:absolute;right:-4px;bottom:-8px;font-size:74px;filter:drop-shadow(0 6px 10px rgba(124,58,237,.22));}
.camp-dots{display:flex;justify-content:center;gap:6px;margin-top:11px;}
.camp-dot{width:7px;height:7px;border-radius:50%;background:#d9cffb;transition:width .25s,background .25s;cursor:pointer;}
.camp-dot.on{width:20px;background:var(--purple);}

/* ===== FILTER TABS ===== */
.tabs{display:flex;gap:8px;overflow-x:auto;padding:4px 0 2px;scrollbar-width:none;}
.tabs::-webkit-scrollbar{display:none;}
.tab{flex-shrink:0;padding:9px 16px;border-radius:20px;border:none;background:#fff;color:var(--muted);font-size:12.5px;font-weight:700;cursor:pointer;box-shadow:0 2px 8px rgba(20,20,60,.04);}
.tab.active{background:var(--grad);color:#fff;box-shadow:0 6px 14px rgba(124,58,237,.3);}

/* ===== REWARD CARDS ===== */
.reward{display:flex;align-items:center;gap:14px;margin-bottom:12px;}
.reward .rimg{width:62px;height:62px;border-radius:18px;display:flex;align-items:center;justify-content:center;font-size:30px;flex-shrink:0;}
.reward .rc{flex:1;min-width:0;}
.reward .rc h4{font-size:14px;font-weight:800;line-height:1.25;}
.reward .rc .cost{font-size:13px;font-weight:800;color:var(--purple);margin-top:5px;display:flex;align-items:center;gap:5px;}
.reward .rc .cost i{color:var(--gold);}
.reward .ral{display:flex;flex-direction:column;align-items:flex-end;gap:8px;}
.btn-al{background:var(--grad);color:#fff;font-size:12.5px;font-weight:800;padding:9px 18px;border-radius:13px;border:none;cursor:pointer;box-shadow:0 6px 14px rgba(124,58,237,.3);}
.btn-al[disabled]{opacity:.4;box-shadow:none;cursor:not-allowed;}
.chev{color:var(--muted2);font-size:14px;}
.hint-row{display:flex;align-items:center;gap:12px;background:#fff;border-radius:18px;padding:14px;margin-top:6px;cursor:pointer;box-shadow:0 4px 14px rgba(20,20,60,.05);}
.hint-row .hi{width:42px;height:42px;border-radius:50%;background:#f1e7ff;color:#8b3dff;display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0;}
.hint-row p{flex:1;font-size:12.5px;color:var(--muted);}

/* ===== TOTAL POINTS SUMMARY ===== */
.pts-summary{background:var(--grad);border-radius:22px;padding:18px 20px;color:#fff;display:flex;justify-content:space-between;align-items:center;box-shadow:0 12px 26px rgba(124,58,237,.3);position:relative;overflow:hidden;}
.pts-summary:after{content:"";position:absolute;width:130px;height:130px;border-radius:50%;background:rgba(255,255,255,.1);right:-40px;top:-40px;}
.pts-summary .lbl{font-size:12.5px;opacity:.9;}
.pts-summary .big{font-size:34px;font-weight:800;margin-top:2px;}
.pts-summary .ic{font-size:40px;position:relative;z-index:1;}
.mini-stats{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:12px;}
.mini{background:#fff;border-radius:16px;padding:13px;box-shadow:0 4px 14px rgba(20,20,60,.05);}
.mini .v{font-size:19px;font-weight:800;}
.mini .v.green{color:var(--green);}
.mini .v.red{color:var(--red);}
.mini .l{font-size:11px;color:var(--muted2);margin-top:2px;}

/* ===== INVITE ===== */
.invite-hero{text-align:center;padding:6px 0 2px;}
.invite-hero . binicon{font-size:42px;}
.invite-hero h3{font-size:18px;font-weight:800;margin-top:8px;}
.invite-hero p{font-size:12.5px;color:var(--muted);margin-top:5px;padding:0 10px;}
.qr-card{background:#fff;border-radius:22px;padding:20px;text-align:center;box-shadow:0 6px 20px rgba(20,20,60,.06);margin-top:14px;}
.qr-holder{width:190px;height:190px;margin:0 auto;border-radius:16px;overflow:hidden;border:1px solid var(--line);padding:10px;background:#fff;}
.qr-card .qr-name{font-size:13px;font-weight:800;margin-top:12px;}
.qr-card .qr-id{font-size:11.5px;color:var(--muted2);margin-top:2px;}
.link-box{display:flex;align-items:center;gap:8px;background:#f5f4fc;border:1.5px dashed #d9d2f2;border-radius:14px;padding:11px 13px;margin-top:14px;}
.link-box .lk{flex:1;min-width:0;font-size:12.5px;color:var(--purple-ink);font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.link-box button{border:none;background:var(--purple);color:#fff;width:36px;height:36px;border-radius:10px;cursor:pointer;font-size:14px;flex-shrink:0;}
.steps{margin-top:6px;}
.step{display:flex;align-items:center;gap:13px;padding:11px 0;}
.step .n{width:30px;height:30px;border-radius:50%;background:var(--grad);color:#fff;font-weight:800;font-size:13px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.step p{font-size:13px;}
.step p strong{font-weight:800;}

/* ===== EMPTY / GENERIC INFO ROWS ===== */
.info-row{display:flex;align-items:center;gap:13px;padding:14px 0;border-bottom:1px solid var(--line);}
.info-row:last-child{border-bottom:none;}
.info-row .ii{width:38px;height:38px;border-radius:12px;background:#f4f2fc;color:var(--purple);display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0;}
.info-row .ic{flex:1;min-width:0;}
.info-row .ic .k{font-size:11px;color:var(--muted2);}
.info-row .ic .vv{font-size:13.5px;font-weight:700;margin-top:1px;}
.name-edit-input{font-size:13.5px;font-weight:700;margin-top:1px;width:100%;border:none;border-bottom:2px solid var(--purple);background:transparent;outline:none;padding:0 0 2px;color:inherit;font-family:inherit;}

/* ===== PROFILE ===== */
.profile-card{background:var(--grad);border-radius:24px;padding:18px;color:#fff;box-shadow:0 14px 30px rgba(124,58,237,.32);position:relative;overflow:hidden;}
.profile-card:before{content:"";position:absolute;width:160px;height:160px;border-radius:50%;background:rgba(255,255,255,.1);top:-70px;right:-40px;}
.profile-top{display:flex;align-items:center;gap:14px;position:relative;z-index:1;}
.profile-top .pav{position:relative;flex-shrink:0;}
.profile-top .pav img{width:64px;height:64px;border-radius:50%;border:3px solid rgba(255,255,255,.5);object-fit:cover;}
.profile-top .pav .cam{position:absolute;bottom:-2px;right:-2px;width:24px;height:24px;border-radius:50%;background:#fff;color:var(--purple);border:none;font-size:11px;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 2px 6px rgba(0,0,0,.2);}
.profile-top h3{font-size:18px;font-weight:800;}
.profile-top .mem{font-size:12.5px;opacity:.95;margin-top:3px;display:inline-flex;align-items:center;gap:5px;background:rgba(255,255,255,.18);padding:3px 10px;border-radius:20px;font-weight:700;}
.profile-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;margin-top:16px;background:rgba(255,255,255,.18);border-radius:16px;overflow:hidden;position:relative;z-index:1;}
.profile-stats .ps{background:transparent;padding:12px 4px;text-align:center;}
.profile-stats .ps .v{font-size:16px;font-weight:800;}
.profile-stats .ps .l{font-size:9.5px;opacity:.9;margin-top:2px;}
.qa-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.qa{display:flex;align-items:center;gap:10px;background:#fff;border-radius:16px;padding:13px;cursor:pointer;box-shadow:0 4px 14px rgba(20,20,60,.05);transition:transform .15s;}
.qa:active{transform:scale(.97);}
.qa .qai{width:38px;height:38px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0;}
.qa .qat{font-size:12.5px;font-weight:700;}
.menu-card{background:#fff;border-radius:18px;overflow:hidden;box-shadow:0 4px 14px rgba(20,20,60,.05);}
.menu-item{display:flex;align-items:center;gap:13px;padding:15px 16px;border-bottom:1px solid var(--line);cursor:pointer;}
.menu-item:last-child{border-bottom:none;}
.menu-item .mi{width:36px;height:36px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0;}
.menu-item .mt{flex:1;font-size:14px;font-weight:600;}
.menu-item .chev{color:var(--muted2);}
.menu-item.danger .mt{color:var(--red);}

/* notification toggles */
.toggle-row{display:flex;justify-content:space-between;align-items:center;padding:13px 0;border-bottom:1px solid var(--line);}
.toggle-row:last-child{border-bottom:none;}
.toggle-row .tl strong{font-size:13.5px;display:block;}
.toggle-row .tl span{font-size:11px;color:var(--muted2);}
.switch{width:44px;height:26px;background:#e0def0;border-radius:20px;position:relative;cursor:pointer;transition:background .2s;flex-shrink:0;}
.switch.on{background:var(--grad);}
.switch:after{content:"";position:absolute;width:20px;height:20px;background:#fff;border-radius:50%;top:3px;left:3px;transition:left .2s;box-shadow:0 1px 4px rgba(0,0,0,.2);}
.switch.on:after{left:21px;}

/* ===== BOTTOM TABBAR ===== */
.tabbar{
  position:fixed;bottom:0;left:50%;transform:translateX(-50%);
  width:100%;max-width:480px;background:#fff;display:flex;justify-content:space-around;
  padding:8px 6px calc(8px + env(safe-area-inset-bottom));
  box-shadow:0 -6px 24px rgba(20,20,60,.08);border-top:1px solid #f0eff8;z-index:50;
}
body.logged-out .tabbar{display:none;}
.tabbar .t{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;background:none;border:none;cursor:pointer;color:var(--muted2);font-size:10px;font-weight:700;padding:6px 0;}
.tabbar .t i{font-size:18px;}
.tabbar .t.active{color:var(--purple);}

/* ===== LOGIN ===== */
.auth .scroll{justify-content:center;padding:24px;}
.auth-logo{text-align:center;margin-bottom:22px;}
.auth-logo .badge{width:78px;height:78px;border-radius:22px;background:var(--grad);display:flex;align-items:center;justify-content:center;font-size:36px;color:#fff;margin:0 auto 14px;box-shadow:0 12px 26px rgba(124,58,237,.35);}
.auth-logo h1{font-size:23px;font-weight:800;}
.auth-logo h1 span{color:var(--purple);}
.auth-logo p{font-size:13px;color:var(--muted);margin-top:6px;}
.field{margin-bottom:14px;}
.field label{display:block;font-size:12.5px;font-weight:700;color:#4b4b6b;margin-bottom:6px;}
.field .inp{display:flex;align-items:center;gap:9px;background:#fff;border:1.5px solid #e8e6f4;border-radius:14px;padding:13px 14px;transition:border-color .2s;}
.field .inp:focus-within{border-color:var(--purple);}
.field .inp i{color:var(--muted2);font-size:14px;}
.field .inp input{border:none;outline:none;font-size:14px;width:100%;background:none;color:var(--ink);}
.auth-row{display:flex;justify-content:flex-end;margin:-4px 0 16px;}
.auth-row a{font-size:12.5px;color:var(--purple);font-weight:700;cursor:pointer;}
.auth-note{margin-top:20px;background:#f3f0fc;border-radius:14px;padding:13px 14px;font-size:12px;color:var(--muted);display:flex;gap:10px;align-items:flex-start;}
.auth-note i{color:var(--purple);font-size:15px;margin-top:1px;}

/* ===== TOAST ===== */
.toast{
  position:fixed;left:50%;bottom:calc(100px + env(safe-area-inset-bottom));transform:translate(-50%,80px);
  background:#130d35;color:#fff;padding:12px 18px;border-radius:14px;font-size:13px;font-weight:700;
  display:flex;align-items:center;gap:9px;box-shadow:0 10px 30px rgba(20,20,60,.3);
  opacity:0;transition:transform .3s cubic-bezier(.34,1.56,.64,1),opacity .3s;z-index:200;pointer-events:none;max-width:90%;
}
.toast.show{transform:translate(-50%,0);opacity:1;}
.toast i{color:#a855f7;}
.toast.err i{color:#fb7185;}

/* ===== SHEET (detail popups) ===== */
.sheet-overlay{position:fixed;inset:0;background:rgba(9,8,32,.5);display:none;align-items:flex-end;justify-content:center;z-index:150;}
.sheet-overlay.open{display:flex;}
.sheet{background:#fff;width:100%;max-width:480px;border-radius:24px 24px 0 0;padding:8px 18px calc(22px + env(safe-area-inset-bottom));animation:sheetUp .3s cubic-bezier(.34,1.4,.64,1);max-height:84vh;overflow-y:auto;}
@keyframes sheetUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.sheet .grip{width:44px;height:5px;border-radius:5px;background:#e0def0;margin:6px auto 14px;}
.bday-selects{display:grid;grid-template-columns:1fr 1.4fr 1.1fr;gap:10px;}
.bday-selects label{display:block;font-size:11px;color:var(--muted2);margin-bottom:6px;font-weight:700;}
.bday-select{width:100%;padding:13px 12px;border:1.5px solid var(--line);border-radius:14px;font-size:16px;font-weight:700;background:#fff;color:#1a1830;font-family:inherit;cursor:pointer;}
.bday-select:focus{border-color:var(--purple);outline:none;}
.refer-label{display:block;font-size:11px;color:var(--muted2);margin:14px 0 6px;font-weight:700;}
.refer-input{width:100%;padding:13px 14px;border:1.5px solid var(--line);border-radius:14px;font-size:16px;font-weight:600;background:#fff;color:#1a1830;font-family:inherit;}
.refer-input:focus{border-color:var(--purple);outline:none;}
.sheet h3{font-size:17px;font-weight:800;margin-bottom:4px;}
.sheet-icon{width:64px;height:64px;border-radius:20px;display:flex;align-items:center;justify-content:center;font-size:30px;margin:0 auto 10px;}
/* notifications */
.notif-head{display:flex;align-items:center;justify-content:space-between;margin:2px 0 10px;}
.notif-head .mark{font-size:11.5px;font-weight:700;color:var(--purple);cursor:pointer;flex-shrink:0;}
.notif-empty{text-align:center;color:var(--muted2);font-size:13px;padding:26px 0;}
.notif{display:flex;gap:12px;align-items:flex-start;padding:13px 2px;border-bottom:1px solid var(--line);position:relative;}
.notif:last-child{border-bottom:none;}
.notif .ni{width:42px;height:42px;border-radius:13px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;}
.notif .nc{flex:1;min-width:0;}
.notif .nc strong{font-size:13.5px;display:block;margin-bottom:2px;}
.notif .nc p{font-size:12px;color:var(--muted);line-height:1.45;}
.notif .nt{font-size:10.5px;color:var(--muted2);margin-top:4px;display:block;}
.notif.unread:after{content:"";position:absolute;right:2px;top:19px;width:8px;height:8px;border-radius:50%;background:var(--purple);}

@media(min-width:481px){
  body{padding:0;}
  .app{margin-top:0;height:100vh;height:100dvh;border-radius:0;}
}

/* ===== GOOGLE İŞLETME / DEĞERLENDİRME ===== */
.google-card{padding:0;overflow:hidden;}
.google-card .google-map{display:block;width:100%;height:160px;border:0;}
.google-card .google-map-link{display:flex;align-items:center;justify-content:center;gap:8px;height:96px;text-decoration:none;font-size:13px;font-weight:700;color:#fff;background:linear-gradient(135deg,#4285F4,#34a853);}
.google-card .google-map-link i{font-size:18px;}
.google-card .google-body{padding:14px;}
.google-head{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--ink);}
.google-head i{color:#4285F4;font-size:16px;}
.google-desc{font-size:12px;color:var(--muted);line-height:1.5;margin:8px 0 12px;}
.google-desc strong{color:var(--gold2);}
.btn-google{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;border:none;border-radius:11px;padding:12px;font-size:13px;font-weight:700;color:#fff;background:var(--grad);cursor:pointer;}
.btn-google:active{transform:scale(.98);}
.btn-google i{font-size:14px;}
.google-done{display:flex;align-items:center;gap:8px;font-size:12.5px;font-weight:600;color:var(--green);background:#e6f9f0;border-radius:10px;padding:11px 12px;line-height:1.4;}
.google-done i{font-size:15px;}

/* ===== İLK GİRİŞ ZORUNLU ŞİFRE DEĞİŞTİRME ===== */
.patient-setpass-overlay{position:fixed;inset:0;z-index:9998;display:none;align-items:center;justify-content:center;background:linear-gradient(135deg,#2d2d4e,#4c1d95);padding:24px;}
.patient-setpass-overlay.show{display:flex;}
.setpass-card{width:100%;max-width:340px;background:#fff;border-radius:20px;padding:28px 24px;text-align:center;box-shadow:0 24px 60px rgba(0,0,0,.35);}
.setpass-icon{width:54px;height:54px;border-radius:50%;background:linear-gradient(135deg,#9333ea,#7c3aed);color:#fff;display:flex;align-items:center;justify-content:center;font-size:22px;margin:0 auto 14px;}
.setpass-card h2{font-size:18px;color:#2d2d4e;margin-bottom:6px;}
.setpass-card p{font-size:12.5px;color:#8a8aa6;line-height:1.5;margin-bottom:16px;}
.setpass-card input{width:100%;padding:12px 14px;border:1px solid #e5e7f3;border-radius:11px;font-size:14px;color:#14142b;outline:none;margin-bottom:10px;}
.setpass-card input:focus{border-color:#9333ea;}
.setpass-card .sp-error{min-height:16px;font-size:12px;color:#e11d48;font-weight:600;margin-bottom:8px;}
