/* ════════════════════════════════════════════════════════════════════════════
   ObAi Widget — Stiller
   Modüler bölme: 2 Mayıs 2026
   ════════════════════════════════════════════════════════════════════════════ */

/* ── TEMEL ── */
.obai-widget{position:fixed;bottom:30px;right:30px;z-index:2147483647;font-family:'Poppins',sans-serif;display:flex;flex-direction:column;align-items:flex-end}
/* Phone-mode bottom: JS ile ölçülen mobile-bottom-nav yüksekliği + safe-area + boşluk.
   --obai-bn-h JS tarafından setlenir (yoksa 70px varsayılan = ortalama nav yükseklik). */
.obai-widget.phone-mode{bottom:calc(var(--obai-bn-h,70px) + env(safe-area-inset-bottom,0px) + 18px);right:14px}

/* ── TOGGLE ── */
.obai-toggle-wrapper{position:relative;width:76px;height:76px;cursor:pointer;perspective:1000px;transform-style:preserve-3d;animation:obai-float 4s ease-in-out infinite}
.obai-widget.phone-mode .obai-toggle-wrapper{width:60px;height:60px}
.obai-platform{position:absolute;bottom:-5px;left:5px;right:5px;height:18px;background:radial-gradient(ellipse at center,rgba(255,107,0,.8),transparent 70%);border-radius:50%;opacity:.7;filter:blur(4px);transition:.3s}
.obai-toggle-wrapper:hover .obai-platform{opacity:1;filter:blur(6px)}
.obai-toggle-btn{width:100%;height:100%;border-radius:50%;display:flex;justify-content:center;align-items:center;transition:all .3s cubic-bezier(.34,1.56,.64,1);position:relative;z-index:2;transform-style:preserve-3d}
.obai-toggle-wrapper:hover .obai-toggle-btn{transform:scale(1.08) translateZ(18px)}
@keyframes obai-float{0%{transform:translateY(0)}50%{transform:translateY(-10px)}100%{transform:translateY(0)}}

/* ── BADGE ── */
.obai-unread-badge{position:absolute;top:-2px;right:-2px;background:#ff4444;color:white;border-radius:50%;min-width:20px;height:20px;font-size:10px;font-weight:800;display:none;justify-content:center;align-items:center;z-index:10;border:2px solid #08080b;box-shadow:0 0 8px rgba(255,68,68,.8);padding:0 2px}
@keyframes obai-pop{0%{transform:scale(0)}70%{transform:scale(1.2)}100%{transform:scale(1)}}

/* ── BALON ── */
.obai-awareness-bubble{position:absolute;right:88px;top:8px;background:rgba(10,10,15,.97);border:1px solid #ff6b00;border-radius:14px;border-bottom-right-radius:0;padding:10px 15px;color:#f0f0f0;font-size:13px;line-height:1.45;width:max-content;max-width:260px;box-shadow:0 8px 24px rgba(255,107,0,.25);opacity:0;visibility:hidden;transform:translateX(16px) scale(.92);transition:all .45s cubic-bezier(.34,1.56,.64,1);pointer-events:none}
.obai-awareness-bubble.active{opacity:1;visibility:visible;transform:translateX(0) scale(1)}
.obai-awareness-bubble::after{content:'';position:absolute;right:-8px;bottom:-1px;width:0;height:0;border-left:10px solid #ff6b00;border-top:10px solid transparent}
.obai-widget.phone-mode .obai-awareness-bubble{right:72px;max-width:220px;font-size:12px;top:0}

/* ── SOHBET PENCERESİ ── */
.obai-chat-window{width:370px;height:570px;background:rgba(12,12,18,.97);backdrop-filter:blur(30px);border:1px solid #ff6b00;border-radius:22px;box-shadow:0 20px 60px rgba(0,0,0,.95),0 0 30px rgba(255,107,0,.08);display:flex;flex-direction:column;overflow:hidden;position:fixed;bottom:120px;right:24px;z-index:2147483647;opacity:0;visibility:hidden;pointer-events:none;transform:translateY(20px) scale(.94);transition:opacity .35s ease,transform .38s cubic-bezier(.34,1.56,.64,1),visibility .35s;transform-origin:bottom right}
.obai-chat-window.active{opacity:1;visibility:visible;pointer-events:all;transform:translateY(0) scale(1)}
.obai-widget.phone-mode .obai-chat-window{width:calc(100vw - 24px);max-width:420px;height:auto;min-height:280px;max-height:calc(var(--obai-vh,1vh)*82);right:12px;left:12px;bottom:calc(var(--obai-bn-h,70px) + env(safe-area-inset-bottom,0px) + 8px);transform:translateY(24px);border-radius:22px;position:fixed;box-shadow:0 18px 50px rgba(0,0,0,.92),0 0 24px var(--obai-tone-faint,rgba(255,107,0,.08));transition:bottom .2s ease,max-height .2s ease,opacity .35s ease,transform .38s cubic-bezier(.34,1.56,.64,1),visibility .35s}
/* Phone-mode active reset — 3-class spesifite .active 2-class kuralını ezdiği
   için ayrıca yazılmalı, aksi halde chat penceresi 24px aşağıda asılı kalır */
.obai-widget.phone-mode .obai-chat-window.active{transform:translateY(0) scale(1)}

/* ── HEADER ── */
.obai-header{background:linear-gradient(90deg,rgba(255,107,0,.12),rgba(0,0,0,.7));padding:12px 16px;border-bottom:1px solid rgba(255,107,0,.25);display:flex;align-items:center;gap:10px;flex-shrink:0;z-index:100;position:relative}
.obai-header-icon{width:40px;height:40px;background:#000;border-radius:50%;display:flex;justify-content:center;align-items:center;border:1px solid rgba(255,107,0,.6);overflow:hidden;flex-shrink:0;box-shadow:0 0 8px rgba(255,107,0,.35)}
.obai-widget.phone-mode .obai-header-icon{width:34px;height:34px}
.obai-header-info{flex:1}
.obai-header-name{font-size:14px;font-weight:800;color:white;line-height:1.2}
.obai-widget.phone-mode .obai-header-name{font-size:13px}
.obai-header-status{font-size:10.5px;color:#2ecc71;font-weight:600;display:flex;align-items:center;gap:4px;margin-top:2px}
.obai-header-status::before{content:'';display:inline-block;width:5px;height:5px;background:#2ecc71;border-radius:50%;box-shadow:0 0 4px #2ecc71}
.obai-header-actions{display:flex;align-items:center;gap:4px}
.obai-action-btn{cursor:pointer;color:#888;transition:.25s;width:36px;height:36px;display:flex;justify-content:center;align-items:center;border-radius:50%;border:none;background:transparent;font-size:16px;-webkit-tap-highlight-color:transparent;touch-action:manipulation}
.obai-action-btn svg{width:17px;height:17px;fill:currentColor}
.obai-action-btn:hover{color:white;background:rgba(255,255,255,.08)}
.obai-action-btn.new-chat:hover{color:#ff6b00;background:rgba(255,107,0,.12)}
/* Paket badge — kucuk, temiz */
.obai-paket-badge{font-size:9.5px;font-weight:700;padding:3px 9px;border-radius:20px;white-space:nowrap;margin-left:2px;letter-spacing:.3px}
.obai-paket-badge.free{color:#888;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1)}
.obai-paket-badge.pro{color:#f1c40f;background:rgba(241,196,15,.1);border:1px solid rgba(241,196,15,.3)}
.obai-paket-badge.ultra{color:#ff6b00;background:rgba(255,107,0,.1);border:1px solid rgba(255,107,0,.3)}
.obai-paket-badge.elite{color:#3498db;background:rgba(52,152,219,.1);border:1px solid rgba(52,152,219,.3)}

/* ── MESAJLAR ──
   scroll-behavior:auto — typewriter sürekli scrollTop yazıyor; smooth ile
   çakışıp scroll yarım kalıyordu. is-thinking yokken yine smooth gibi davransın
   diye .obai-messages.smooth-scroll class JS tarafında ekleniyor. */
.obai-messages{flex:1;padding:14px 14px 10px;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;gap:12px;scroll-behavior:auto;position:relative;z-index:10;min-height:80px;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}
.obai-messages.smooth-scroll{scroll-behavior:smooth}
.obai-messages::-webkit-scrollbar{width:3px}
.obai-messages::-webkit-scrollbar-thumb{background:rgba(255,107,0,.4);border-radius:4px}
.obai-msg{max-width:88%;padding:11px 14px;border-radius:14px;font-size:13px;line-height:1.6;word-wrap:break-word;will-change:transform,opacity}
.obai-widget.phone-mode .obai-msg{font-size:13px;padding:11px 14px;max-width:90%;line-height:1.55}
.obai-msg p{margin:0 0 6px}.obai-msg p:last-child{margin:0}
.obai-msg strong{color:#ffb380;font-weight:700}
.obai-msg em{color:#aaa;font-style:italic}
.obai-msg ul{padding-left:14px;margin:5px 0}
.obai-msg li{margin-bottom:4px}
/* Faz 1.2 — yön bazlı giriş animasyonu (AI sol, kullanıcı sağ) */
@keyframes obai-msg-in-ai{
    0%{opacity:0;transform:translate3d(-14px,6px,0) scale(.94);filter:blur(2px)}
    60%{opacity:1;filter:blur(0)}
    100%{opacity:1;transform:translate3d(0,0,0) scale(1);filter:blur(0)}
}
@keyframes obai-msg-in-user{
    0%{opacity:0;transform:translate3d(14px,6px,0) scale(.94);filter:blur(2px)}
    60%{opacity:1;filter:blur(0)}
    100%{opacity:1;transform:translate3d(0,0,0) scale(1);filter:blur(0)}
}
.obai-msg-ai{background:rgba(255,255,255,.05);color:#ddd;border:1px solid rgba(255,255,255,.09);align-self:flex-start;border-bottom-left-radius:4px;display:flex;flex-direction:column;gap:7px;animation:obai-msg-in-ai .42s cubic-bezier(.22,1,.36,1) both;transform-origin:0 100%}
.obai-msg-user{background:linear-gradient(135deg,#ff6b00,#d35400);color:white;font-weight:500;align-self:flex-end;border-bottom-right-radius:4px;box-shadow:0 4px 12px rgba(255,107,0,.25);animation:obai-msg-in-user .42s cubic-bezier(.22,1,.36,1) both;transform-origin:100% 100%}
/* Tonal mod: kullanıcı balonu da tier rengini takip etsin */
.obai-widget:not(.tier-pro) .obai-msg-user{background:linear-gradient(135deg,var(--obai-tone-grad-a),var(--obai-tone-grad-b));box-shadow:0 4px 12px var(--obai-tone-soft)}
.obai-ai-header{display:flex;align-items:center;gap:8px;border-bottom:1px dashed rgba(255,255,255,.07);padding-bottom:6px}
/* Faz 1.2 — Tier rozeti (PRO/ULTRA/ELITE küçük chip) */
.obai-tier-badge{
    margin-left:auto;font-size:8.5px;font-weight:800;letter-spacing:.7px;
    padding:2px 7px;border-radius:8px;color:#fff;text-transform:uppercase;
    background:linear-gradient(135deg,var(--obai-tone-grad-a),var(--obai-tone-grad-b));
    box-shadow:0 0 0 1px var(--obai-tone-soft) inset, 0 2px 8px var(--obai-tone-soft);
    opacity:0;transform:translateY(-4px) scale(.85);
    animation:obai-badge-in .55s cubic-bezier(.34,1.56,.64,1) .12s forwards;
    line-height:1;display:inline-flex;align-items:center;gap:3px;
}
.obai-tier-badge::before{content:"";width:5px;height:5px;border-radius:50%;background:#fff;box-shadow:0 0 6px rgba(255,255,255,.7);animation:obai-badge-pulse 1.6s ease-in-out infinite}
.obai-widget.tier-elite .obai-tier-badge{color:#1a1208;text-shadow:none}
.obai-widget.tier-elite .obai-tier-badge::before{background:#1a1208;box-shadow:0 0 6px rgba(0,0,0,.4)}
@keyframes obai-badge-in{
    0%{opacity:0;transform:translateY(-4px) scale(.85)}
    100%{opacity:1;transform:translateY(0) scale(1)}
}
@keyframes obai-badge-pulse{
    0%,100%{transform:scale(1);opacity:.85}
    50%{transform:scale(1.4);opacity:1}
}
/* Faz 1.2 — SplitType kelime reveal (geçmiş mesajlar/anlık AI yanıtları için) */
.obai-msg .ai-tc .obai-word{
    display:inline-block;opacity:0;transform:translateY(6px);
    animation:obai-word-in .38s cubic-bezier(.22,1,.36,1) both;
}
@keyframes obai-word-in{
    0%{opacity:0;transform:translateY(6px)}
    100%{opacity:1;transform:translateY(0)}
}
.obai-msg-icon{width:18px;height:18px;flex-shrink:0;overflow:hidden;border-radius:50%;background:#000;border:1px solid rgba(255,107,0,.5);display:flex;align-items:center;justify-content:center}
.obai-ai-title{font-weight:800;font-size:10px;color:#ff6b00;text-transform:uppercase;letter-spacing:.8px}
.obai-typing{display:none;gap:4px;padding:10px 14px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:14px;border-bottom-left-radius:4px;align-self:flex-start;width:fit-content}
.obai-dot{width:5px;height:5px;background:#ff6b00;border-radius:50%;animation:obai-bounce 1.4s infinite ease-in-out both}
.obai-dot:nth-child(1){animation-delay:-.32s}.obai-dot:nth-child(2){animation-delay:-.16s}
@keyframes obai-bounce{0%,80%,100%{transform:scale(0)}40%{transform:scale(1)}}

/* ── OVERLAY GENEL ── */
.obai-overlay{position:absolute;top:65px;left:0;right:0;bottom:0;background:#0c0c12;z-index:200;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:20px;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .25s ease,visibility .25s ease;overflow-y:auto}
.obai-overlay.active{opacity:1!important;visibility:visible!important;pointer-events:all!important}
.overlay-icon{font-size:44px;margin-bottom:12px}
.overlay-title{font-size:17px;font-weight:800;color:#ff6b00;margin:0 0 8px}
.overlay-desc{font-size:12.5px;color:#888;line-height:1.65;margin-bottom:22px;max-width:280px}
.overlay-btn{background:transparent;color:#2ecc71;border:1.5px solid #2ecc71;font-weight:700;padding:10px 20px;border-radius:50px;font-size:13px;cursor:pointer;transition:.25s;text-decoration:none;display:inline-block;font-family:inherit;margin:4px}
.overlay-btn:hover{background:#2ecc71;color:#000}
.lock-btn{background:linear-gradient(135deg,#ff6b00,#d35400);color:white;border:none;box-shadow:0 4px 14px rgba(255,107,0,.35)}
.lock-btn:hover{color:white;box-shadow:0 8px 22px rgba(255,107,0,.5)}

/* ── ZIYARETCI EKRANI — profesyonel ── */
#obaiVisitorScreen{background:radial-gradient(ellipse at 50% -10%,rgba(255,107,0,.09) 0%,#090910 55%),linear-gradient(180deg,#0a0a14,#09090f);overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;justify-content:flex-start}
#obaiVisitorScreen::before{content:'';position:absolute;top:-80px;left:50%;transform:translateX(-50%);width:280px;height:280px;background:radial-gradient(circle,rgba(255,107,0,.07),transparent 70%);border-radius:50%;pointer-events:none;animation:obai-vs-orb 6s ease-in-out infinite}
@keyframes obai-vs-orb{0%,100%{opacity:.6;transform:translateX(-50%) scale(1)}50%{opacity:1;transform:translateX(-50%) scale(1.15)}}
.obai-vs-inner{display:flex;flex-direction:column;align-items:center;width:100%;max-width:300px;margin:auto;padding:12px 4px 16px}
.obai-vs-av-wrap{position:relative;width:68px;height:68px;margin-bottom:16px;flex-shrink:0}
.obai-vs-av-ring{position:absolute;inset:-7px;border-radius:50%;border:1px solid transparent;background:conic-gradient(rgba(255,107,0,.7),rgba(255,107,0,.1),rgba(255,107,0,.7)) border-box;-webkit-mask:linear-gradient(#fff 0 0) padding-box,linear-gradient(#fff 0 0);-webkit-mask-composite:destination-out;mask-composite:exclude;animation:obai-vs-spin 5s linear infinite}
.obai-vs-av-dot{position:absolute;top:0;left:50%;width:7px;height:7px;background:#ff6b00;border-radius:50%;box-shadow:0 0 8px 2px rgba(255,107,0,.8);transform:translateX(-50%) translateY(-50%);animation:obai-vs-spin 5s linear infinite;transform-origin:0 42px}
@keyframes obai-vs-spin{to{transform:rotate(360deg)}}
.obai-vs-av-dot{position:absolute;top:-4px;left:50%;transform:translateX(-50%);width:7px;height:7px;background:#ff6b00;border-radius:50%;box-shadow:0 0 8px 2px rgba(255,107,0,.8);animation:obai-vs-spin 5s linear infinite;transform-origin:0 calc(34px + 7px)}
.obai-vs-av-inner{width:68px;height:68px;border-radius:50%;background:radial-gradient(circle at 35% 35%,#1a0a00,#060610);border:1.5px solid rgba(255,107,0,.35);overflow:hidden;display:flex;align-items:center;justify-content:center;box-shadow:0 0 0 6px rgba(255,107,0,.04),0 0 24px rgba(255,107,0,.1)}
.obai-vs-glow{position:absolute;bottom:-8px;left:50%;transform:translateX(-50%);width:50px;height:14px;background:radial-gradient(ellipse,rgba(255,107,0,.45),transparent 70%);filter:blur(5px);border-radius:50%}
.obai-vs-title{font-size:19px;font-weight:800;color:white;margin:0 0 4px;text-align:center;letter-spacing:-.3px}
.obai-vs-sub{font-size:11.5px;color:#666;margin:0 0 16px;text-align:center;line-height:1.5}
.obai-vs-list{width:100%;margin-bottom:16px;display:flex;flex-direction:column;gap:6px}
.obai-vs-item{display:flex;align-items:center;gap:10px;background:rgba(255,255,255,.025);border:1px solid rgba(255,255,255,.055);border-radius:10px;padding:9px 12px;transition:background .2s,border-color .2s,transform .2s}
.obai-vs-item:hover{background:rgba(255,107,0,.05);border-color:rgba(255,107,0,.18);transform:translateX(3px)}
.obai-vs-item-ic{width:26px;height:26px;background:rgba(255,107,0,.07);border:1px solid rgba(255,107,0,.18);border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:12px;flex-shrink:0}
.obai-vs-item-txt{font-size:12.5px;color:#bbb;font-weight:600;line-height:1.3}
.obai-vs-item-txt small{display:block;font-size:10px;color:#444;font-weight:400;margin-top:1px}
.obai-vs-cta{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:13px;background:linear-gradient(135deg,#ff6b00,#d35400);color:white;border:none;border-radius:13px;font-size:14px;font-weight:700;cursor:pointer;text-decoration:none;font-family:inherit;box-shadow:0 4px 18px rgba(255,107,0,.32),inset 0 1px 0 rgba(255,255,255,.15);transition:transform .2s,box-shadow .2s;margin-bottom:8px;position:relative;overflow:hidden}
.obai-vs-cta::before{content:'';position:absolute;top:0;left:-120%;width:60%;height:100%;background:linear-gradient(100deg,transparent,rgba(255,255,255,.22),transparent);animation:obai-vs-shimmer 2.8s ease-in-out infinite}
@keyframes obai-vs-shimmer{0%{left:-120%}60%,100%{left:160%}}
.obai-vs-cta:hover{transform:translateY(-2px);box-shadow:0 8px 26px rgba(255,107,0,.5),inset 0 1px 0 rgba(255,255,255,.2);color:white}
.obai-vs-cta:active{transform:translateY(0);box-shadow:0 2px 10px rgba(255,107,0,.3)}
.obai-vs-sec{display:flex;align-items:center;justify-content:center;gap:5px;width:100%;padding:10px;background:rgba(255,255,255,.04);color:#999;border:1px solid rgba(255,255,255,.09);border-radius:13px;font-size:12.5px;font-weight:600;text-decoration:none;font-family:inherit;transition:all .2s;margin-bottom:12px}
.obai-vs-sec:hover{background:rgba(255,255,255,.09);color:white;border-color:rgba(255,255,255,.2)}
.obai-vs-note{font-size:10px;color:#3a3a4a;text-align:center;letter-spacing:.2px}

/* ── TELEFON: ZIYARETCI EKRANI — TAM SIGAN TASARIM ── */
.obai-widget.phone-mode #obaiVisitorScreen{padding:0;justify-content:flex-start;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}
.obai-widget.phone-mode .obai-vs-inner{padding:12px 12px 12px;max-width:100%;width:100%;gap:0;margin:0 auto}
.obai-widget.phone-mode .obai-vs-av-wrap{width:44px;height:44px;margin-bottom:7px}
.obai-widget.phone-mode .obai-vs-av-inner{width:44px;height:44px}
.obai-widget.phone-mode .obai-vs-av-ring{inset:-4px}
.obai-widget.phone-mode .obai-vs-av-dot{width:5px;height:5px;transform-origin:0 28px}
.obai-widget.phone-mode .obai-vs-glow{width:36px;height:10px;bottom:-5px}
.obai-widget.phone-mode .obai-vs-title{font-size:15px;margin:0 0 2px;letter-spacing:-.2px}
.obai-widget.phone-mode .obai-vs-sub{display:none}
.obai-widget.phone-mode .obai-vs-list{flex-direction:row;gap:5px;margin-bottom:10px;margin-top:8px;width:100%}
.obai-widget.phone-mode .obai-vs-item{flex:1;min-width:0;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:7px 4px;gap:4px;border-radius:10px}
.obai-widget.phone-mode .obai-vs-item-ic{width:26px;height:26px;font-size:13px;flex-shrink:0}
.obai-widget.phone-mode .obai-vs-item-txt{font-size:10.5px;font-weight:700;line-height:1.2;color:#ccc}
.obai-widget.phone-mode .obai-vs-item-txt small{display:none}
.obai-widget.phone-mode .obai-vs-cta{padding:11px 10px;font-size:13px;border-radius:12px;margin-bottom:6px;width:100%}
.obai-widget.phone-mode .obai-vs-sec{padding:9px 10px;font-size:12px;border-radius:12px;margin-bottom:7px;width:100%}
.obai-widget.phone-mode .obai-vs-note{font-size:9.5px;margin-top:0}

/* ── STAGGERED ANIMASYON ── */
.obai-vs-el{opacity:0;transform:translateY(16px);transition:opacity .45s ease,transform .45s cubic-bezier(.34,1.4,.64,1)}
.obai-vs-el.obai-vs-in{opacity:1;transform:translateY(0)}
.obai-vs-av-el{opacity:0;transform:scale(.6) translateY(-8px);transition:opacity .5s ease,transform .5s cubic-bezier(.34,1.56,.64,1)}
.obai-vs-av-el.obai-vs-in{opacity:1;transform:scale(1) translateY(0)}

/* ── ONBOARDING ── */
.onb-chips{display:flex;flex-wrap:wrap;gap:7px;justify-content:center;margin-bottom:16px}
.onb-chip{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);color:#ccc;padding:7px 14px;border-radius:50px;font-size:12px;cursor:pointer;transition:.2s;font-family:inherit}
.onb-chip:hover,.onb-chip.sel{background:rgba(255,107,0,.15);border-color:#ff6b00;color:#ff6b00}
.onb-step-indicator{display:flex;gap:6px;margin-bottom:18px}
.onb-dot{width:7px;height:7px;border-radius:50%;background:rgba(255,255,255,.2);transition:.25s}
.onb-dot.active{background:#ff6b00;transform:scale(1.2)}
.onb-dot.done{background:rgba(255,107,0,.55)}
.onb-question{font-size:14px;font-weight:700;color:white;margin-bottom:14px}

/* ── DURDUR ── */
.obai-stop-btn-wrapper{position:absolute;bottom:70px;left:50%;transform:translateX(-50%) translateY(12px);opacity:0;visibility:hidden;transition:all .25s;z-index:60}
.obai-stop-btn-wrapper.active{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.obai-stop-btn{background:rgba(18,18,24,.96);border:1px solid rgba(255,107,0,.45);color:#ddd;padding:5px 13px;border-radius:50px;font-size:11px;font-weight:600;display:flex;align-items:center;gap:5px;cursor:pointer;box-shadow:0 4px 16px rgba(0,0,0,.7);transition:.2s;font-family:inherit}
.obai-stop-btn:hover{background:rgba(255,107,0,.18);color:white}
.obai-stop-btn svg{width:9px;height:9px;fill:currentColor}

/* ── DISCLAIMER + INPUT ── */
.obai-disclaimer{background:rgba(0,0,0,.6);border-top:1px solid rgba(255,255,255,.04);padding:6px 14px;font-size:10px;color:#555;text-align:center;flex-shrink:0;z-index:30}
.obai-disclaimer strong{color:#ff6b00;font-weight:600}
.obai-input-area{padding:11px 13px;background:rgba(8,8,14,.9);position:relative;z-index:30;display:flex;gap:8px;align-items:center;border-top:1px solid rgba(255,255,255,.05)}
.obai-input{flex:1;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.15);color:white;padding:10px 16px;border-radius:50px;font-size:13px;outline:none;font-family:'Poppins',sans-serif;transition:.35s}
.obai-input:focus{border-color:#ff6b00;background:rgba(0,0,0,.85);box-shadow:0 0 12px rgba(255,107,0,.22)}
.obai-input:disabled{opacity:.45;cursor:not-allowed}
.obai-widget.phone-mode .obai-input{font-size:12.5px;padding:9px 14px}
.obai-send-btn{width:40px;height:40px;border-radius:50%;background:#ff6b00;border:none;display:flex;justify-content:center;align-items:center;cursor:pointer;transition:all .28s cubic-bezier(.34,1.56,.64,1);flex-shrink:0}
.obai-send-btn:hover:not(:disabled){background:white;transform:scale(1.08);box-shadow:0 4px 14px rgba(255,107,0,.45)}
.obai-send-btn:disabled{opacity:.45;cursor:not-allowed;background:#555}
.obai-send-btn svg{width:16px;height:16px;fill:white;transform:translateX(2px);transition:.2s}
.obai-send-btn:hover svg{fill:#000}

/* ── YAZMA ANIMASYONU ── */
@keyframes obai-mstalk{0%,100%{transform:scaleY(1)}50%{transform:scaleY(1.18) translateY(-1.5px)}}
.is-thinking #obai-mustache2{animation:obai-mstalk .28s infinite ease-in-out}

/* ════════════════════════════════════════════════════════════════════════════
   FAZ 1.4 — TONAL MOD (Pakete göre renk teması)
   ----------------------------------------------------------------------------
   Tier sınıfı .obai-widget üzerine JS tarafından eklenir:
     .tier-free  → Mavi    (#3498db)  Ücretsiz
     .tier-pro   → Turuncu (#ff6b00)  Pro     — mevcut brand
     .tier-ultra → Mor     (#9b59b6)  Ultra
     .tier-elite → Altın   (#f1c40f)  Elite
   Brand turuncusu varsayılan kalır; sadece pencere kenarı, glow, gradient
   ve buton accent renkleri tier'a göre değişir. Avatar SVG turuncu kalmaya
   devam eder (kimlik). Smooth geçiş için tüm tonal yüzeylerde transition.
   ════════════════════════════════════════════════════════════════════════════ */

.obai-widget {
    --obai-tone        : #ff6b00;
    --obai-tone-soft   : rgba(255,107,0,.22);
    --obai-tone-glow   : rgba(255,107,0,.45);
    --obai-tone-faint  : rgba(255,107,0,.08);
    --obai-tone-grad-a : #ff6b00;
    --obai-tone-grad-b : #d35400;
}
.obai-widget.tier-free {
    --obai-tone        : #3498db;
    --obai-tone-soft   : rgba(52,152,219,.22);
    --obai-tone-glow   : rgba(52,152,219,.42);
    --obai-tone-faint  : rgba(52,152,219,.08);
    --obai-tone-grad-a : #3498db;
    --obai-tone-grad-b : #2271a8;
}
.obai-widget.tier-pro {
    --obai-tone        : #ff6b00;
    --obai-tone-soft   : rgba(255,107,0,.22);
    --obai-tone-glow   : rgba(255,107,0,.45);
    --obai-tone-faint  : rgba(255,107,0,.08);
    --obai-tone-grad-a : #ff6b00;
    --obai-tone-grad-b : #d35400;
}
.obai-widget.tier-ultra {
    --obai-tone        : #9b59b6;
    --obai-tone-soft   : rgba(155,89,182,.24);
    --obai-tone-glow   : rgba(155,89,182,.45);
    --obai-tone-faint  : rgba(155,89,182,.09);
    --obai-tone-grad-a : #b06ac9;
    --obai-tone-grad-b : #7d3c98;
}
.obai-widget.tier-elite {
    --obai-tone        : #f1c40f;
    --obai-tone-soft   : rgba(241,196,15,.26);
    --obai-tone-glow   : rgba(241,196,15,.45);
    --obai-tone-faint  : rgba(241,196,15,.09);
    --obai-tone-grad-a : #f1c40f;
    --obai-tone-grad-b : #b8930a;
}

/* Tonal yüzeyler — tier değişiminde smooth renk geçişi.
   ÖNEMLİ: transition-property kullanmıyoruz çünkü .obai-chat-window'un baz
   transition'ı (opacity/transform/visibility) açılış animasyonu için kritik.
   Bunun yerine her yüzeye uzun-form transition ekliyoruz, baz değerlerle
   birleşik kalsın. */
.obai-widget .obai-platform,
.obai-widget .obai-awareness-bubble,
.obai-widget .obai-header,
.obai-widget .obai-input,
.obai-widget .obai-send-btn,
.obai-widget .obai-header-icon {
    transition: border-color .55s cubic-bezier(.4,0,.2,1),
                background     .55s cubic-bezier(.4,0,.2,1),
                box-shadow     .55s cubic-bezier(.4,0,.2,1),
                color          .55s cubic-bezier(.4,0,.2,1);
}
/* .obai-chat-window — performans odaklı transition.
   Eski sürümde 12+ layout property aynı anda animate ediliyordu (width/height/
   top/bottom/left/right/max-w/max-h/...) → her property için browser tween,
   reflow + repaint döngüsü sürekli tetikleniyor → kasma. Yeni: sadece opacity/
   transform/visibility GPU-friendly + border-radius. Layout (width/height/inset)
   .26s linear, browser tek geçişte hesaplar. will-change ile compositor hint. */
.obai-widget .obai-chat-window {
    transition: opacity .28s ease,
                transform .32s cubic-bezier(.34,1.56,.64,1),
                visibility .28s,
                border-color .35s ease,
                box-shadow .35s ease,
                border-radius .26s cubic-bezier(.4,0,.2,1),
                width .26s cubic-bezier(.4,0,.2,1),
                height .26s cubic-bezier(.4,0,.2,1),
                max-width .26s cubic-bezier(.4,0,.2,1),
                max-height .26s cubic-bezier(.4,0,.2,1),
                inset .26s cubic-bezier(.4,0,.2,1);
    transform-origin: bottom right;
    contain: layout style;
}
/* Fullscreen geçişi sırasında compositor'a hint ver — bittiğinde JS sıfırlar */
.obai-widget.is-fs-transition .obai-chat-window {
    will-change: width, height, inset, transform;
}
/* Kısa anlık "açılıyor" parıltısı — fullscreen sınıfı eklenir/kaldırılırken */
.obai-widget.fullscreen .obai-chat-window::before {
    content: '';
    position: absolute;
    inset: 0;
    pointer-events: none;
    background: radial-gradient(circle at 90% 95%,
        var(--obai-tone-soft, rgba(255,107,0,.35)) 0%,
        transparent 55%);
    opacity: 0;
    animation: obaiFsGlow .7s ease-out forwards;
    z-index: 1;
    border-radius: inherit;
}
@keyframes obaiFsGlow {
    0% { opacity: 0; transform: scale(.7); }
    35% { opacity: .6; }
    100% { opacity: 0; transform: scale(1.4); }
}
.obai-widget.phone-mode .obai-chat-window {
    transition: bottom .2s ease,
                max-height .2s ease,
                opacity .35s ease,
                transform .38s cubic-bezier(.34,1.56,.64,1),
                visibility .35s,
                border-color .55s cubic-bezier(.4,0,.2,1),
                box-shadow .55s cubic-bezier(.4,0,.2,1);
}

/* Toggle platform glow */
.obai-widget .obai-platform {
    background: radial-gradient(ellipse at center, var(--obai-tone-glow), transparent 70%);
}

/* Awareness bubble — tier-aware kenar */
.obai-widget:not(.tier-pro) .obai-awareness-bubble {
    border-color: var(--obai-tone);
    box-shadow: 0 8px 24px var(--obai-tone-soft);
}
.obai-widget:not(.tier-pro) .obai-awareness-bubble::after {
    border-left-color: var(--obai-tone);
}

/* Sohbet penceresi kenarı + glow */
.obai-widget:not(.tier-pro) .obai-chat-window {
    border-color: var(--obai-tone);
    box-shadow: 0 20px 60px rgba(0,0,0,.95), 0 0 30px var(--obai-tone-faint);
}

/* Header gradient + alt kenar */
.obai-widget:not(.tier-pro) .obai-header {
    background: linear-gradient(90deg, var(--obai-tone-faint), rgba(0,0,0,.7));
    border-bottom-color: var(--obai-tone-soft);
}
.obai-widget:not(.tier-pro) .obai-header-icon {
    border-color: var(--obai-tone);
    box-shadow: 0 0 8px var(--obai-tone-soft);
}

/* Input focus */
.obai-widget:not(.tier-pro) .obai-input:focus {
    border-color: var(--obai-tone);
    box-shadow: 0 0 12px var(--obai-tone-soft);
}

/* Send butonu */
.obai-widget:not(.tier-pro) .obai-send-btn {
    background: var(--obai-tone);
}
.obai-widget:not(.tier-pro) .obai-send-btn:hover:not(:disabled) {
    box-shadow: 0 4px 14px var(--obai-tone-glow);
}

/* Elite için altın parıltı — sadece bu tier'da hafif animasyonlu glow */
@keyframes obai-elite-pulse {
    0%, 100% { box-shadow: 0 20px 60px rgba(0,0,0,.95), 0 0 30px rgba(241,196,15,.10); }
    50%      { box-shadow: 0 20px 60px rgba(0,0,0,.95), 0 0 38px rgba(241,196,15,.22); }
}
.obai-widget.tier-elite .obai-chat-window.active {
    animation: obai-elite-pulse 4.5s ease-in-out infinite;
}

/* Ultra için mor halo */
.obai-widget.tier-ultra .obai-toggle-wrapper::before {
    content: '';
    position: absolute;
    inset: -6px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(155,89,182,.18), transparent 70%);
    pointer-events: none;
    animation: obai-float 4s ease-in-out infinite;
}

/* ════════════════════════════════════════════════════════════════════════════
   FAZ 1.5 — TAM EKRAN MODU (masaüstü + mobil)
   ----------------------------------------------------------------------------
   .obai-widget.fullscreen sınıfı eklendiğinde sohbet penceresi tüm viewport'u
   kaplar, hem masaüstünde hem mobilde. Mesaj alanı genişler, header
   sabitlenir. ESC ile veya butonla çıkış. Transition smooth.
   ════════════════════════════════════════════════════════════════════════════ */

/* ÖNEMLİ: .obai-widget'ta will-change/transform var (idle float animasyonu hazırlığı).
   Bu container-block oluşturduğu için içindeki position:fixed chat-window
   viewport'a değil widget'a bağlanıyor. Fullscreen'de widget'ın transform/
   will-change'ini sıfırlıyoruz ki chat-window gerçekten viewport'u kaplasın. */
.obai-widget.fullscreen {
    transform: none !important;
    will-change: auto !important;
    inset: 0 !important;
    bottom: 0 !important;
    right: 0 !important;
    width: 100vw !important;
    height: 100vh !important;
    max-width: 100vw !important;
}
.obai-widget.fullscreen .obai-chat-window {
    width: 100vw !important;
    max-width: 100vw !important;
    height: 100vh !important;
    max-height: 100vh !important;
    border-radius: 0 !important;
    border-left: none !important;
    border-right: none !important;
    border-top: none !important;
    bottom: 0 !important;
    top: 0 !important;
    right: 0 !important;
    left: 0 !important;
    transform: none !important;
}
/* Tam ekran modunda toggle ve çevre öğeler gizlensin */
.obai-widget.fullscreen .obai-toggle-wrapper,
.obai-widget.fullscreen .obai-awareness-bubble {
    display: none !important;
}
/* Tam ekran modunda mesaj alanı + input form genişlesin */
.obai-widget.fullscreen .obai-messages {
    max-width: 880px;
    margin: 0 auto;
    width: 100%;
    padding: 24px 32px 12px;
}
.obai-widget.fullscreen .obai-input-area {
    max-width: 880px;
    margin: 0 auto;
    width: 100%;
    padding: 16px 32px 22px;
}
.obai-widget.fullscreen .obai-disclaimer {
    max-width: 880px;
    margin: 0 auto;
    width: 100%;
}
/* Tam ekran header iç padding artsın (ferahlık) */
.obai-widget.fullscreen .obai-header {
    padding: 14px 24px;
}
/* Buton ikonu durumuna göre döner — JS yenisini değiştirmiyor, CSS rotation kullanıyoruz */
.obai-widget.fullscreen .obai-action-btn#obaiFullscreenBtn svg {
    transform: scale(.9) rotate(180deg);
}
.obai-action-btn#obaiFullscreenBtn svg {
    transition: transform .35s cubic-bezier(.34,1.56,.64,1);
}
/* Mobilde tam ekran — bottom-nav offset'i devre dışı */
@media (max-width: 768px) {
    .obai-widget.fullscreen.phone-mode .obai-chat-window {
        bottom: 0 !important;
        top: 0 !important;
        max-height: 100vh !important;
        max-height: 100dvh !important;
    }
    .obai-widget.fullscreen .obai-messages,
    .obai-widget.fullscreen .obai-input-area,
    .obai-widget.fullscreen .obai-disclaimer {
        padding-left: 16px;
        padding-right: 16px;
    }
}
/* ────────────────────────────────────────────────────────────────────────────
   Tam ekran scroll lock (Faz 1.5.3 — iOS Safari uyumlu)
   overflow:hidden TEK BAŞINA YETMEZ (özellikle iOS). position:fixed trick:
   body sabitlenir, top:-scrollY ile mevcut konum korunur, kapanışta JS geri
   yükler. width:100% scrollbar boşluğu compansate eder. overscroll-behavior
   widget içi scroll'un dışarı taşmasını engeller (hem iOS hem masaüstü).
   ──────────────────────────────────────────────────────────────────────────── */
body.obai-fullscreen-lock {
    position: fixed !important;
    left: 0 !important;
    right: 0 !important;
    width: 100% !important;
    overflow: hidden !important;
    overscroll-behavior: none !important;
    /* touch-action:none kaldırıldı — chat içi scroll'u da bloke ediyordu.
       Body sabitlemek scroll'u zaten durduruyor; touch-action override fullscreen
       widget içinde aşağıda tekrar açılıyor. */
}
/* Tam ekran chat içinde dikey scroll mutlaka açık — body kilidi etkilemesin */
.obai-widget.fullscreen .obai-chat-window,
.obai-widget.fullscreen .obai-messages,
.obai-widget.fullscreen .obai-msg-area {
    overscroll-behavior: contain;
    -webkit-overflow-scrolling: touch;
    touch-action: pan-y !important;
}

/* ──────────────────────────────────────────────────────────────────────────
   Mobil tam ekran: alt menüyü ve sayfa header'ını animasyonla gizle
   phone-* sayfalar farklı sınıf kullanıyor (.mbn / .mobile-bottom-nav /
   .bottom-nav). Tam ekrana alındığında hepsi aşağı kayar, header yukarı
   kayar. Kapanışta geri döner.
   ────────────────────────────────────────────────────────────────────────── */
.mobile-bottom-nav,
.mbn,
.bottom-nav {
    transition: transform .35s cubic-bezier(.65,.05,.36,1),
                opacity   .25s ease;
    will-change: transform;
}
body.obai-fullscreen-lock .mobile-bottom-nav,
body.obai-fullscreen-lock .mbn,
body.obai-fullscreen-lock .bottom-nav {
    transform: translateY(110%) !important;
    opacity: 0 !important;
    pointer-events: none !important;
}
/* Sayfa header'ı (üstte fixed olanlar) tam ekran modunda yukarı kayar.
   header tag, .top-bar, .site-header, .page-header gibi yaygın seçicileri kapsar. */
body.obai-fullscreen-lock > header,
body.obai-fullscreen-lock .top-bar,
body.obai-fullscreen-lock .site-header,
body.obai-fullscreen-lock .page-header,
body.obai-fullscreen-lock .mobile-header,
body.obai-fullscreen-lock .header-fixed,
body.obai-fullscreen-lock .progress-bar,
body.obai-fullscreen-lock .h-search-wrap,
body.obai-fullscreen-lock .h-search,
body.obai-fullscreen-lock .h-logo,
body.obai-fullscreen-lock .h-drop,
body.obai-fullscreen-lock .campaign-banner,
body.obai-fullscreen-lock .promo-banner {
    transform: translateY(-110%) !important;
    opacity: 0 !important;
    pointer-events: none !important;
    transition: transform .35s cubic-bezier(.65,.05,.36,1),
                opacity   .25s ease !important;
}
/* ObAi widget her şeyin üstünde olmalı — fullscreen modunda max int z-index */
.obai-widget.fullscreen {
    z-index: 2147483647 !important;
}
.obai-widget.fullscreen .obai-chat-window {
    z-index: 2147483647 !important;
}

/* ════════════════════════════════════════════════════════════════════════════
   FAZ 1.5.4 — Normal sohbet (tam ekran DEĞİL) açıkken sayfa header/arama
   çubuğu sönükleşsin. phone-kesfet, phone-magaza, phone-mesajlar gibi tüm
   phone-* sayfalarda <header> içinde logo + arama bar var. Sohbet açılınca
   üzerinde duruyor ve görsel çakışma yapıyor. body.obai-chat-open class'ı
   açılışta JS tarafından eklenir, kapanışta kaldırılır.
   Tam ekran moduna girildiğinde zaten obai-fullscreen-lock devreye giriyor.
   ════════════════════════════════════════════════════════════════════════════ */
body.obai-chat-open header,
body.obai-chat-open .h-search-wrap,
body.obai-chat-open .h-search,
body.obai-chat-open .h-logo,
body.obai-chat-open .h-drop,
body.obai-chat-open .top-bar,
body.obai-chat-open .site-header,
body.obai-chat-open .page-header,
body.obai-chat-open .mobile-header,
body.obai-chat-open .header-fixed,
body.obai-chat-open .campaign-banner,
body.obai-chat-open .promo-banner {
    opacity: 0 !important;
    pointer-events: none !important;
    transition: opacity .25s ease !important;
}
/* Tam ekran sırasında çift kuralın çakışmasını önle — fullscreen-lock zaten
   transform translateY(-110%) ile gizliyor, opacity:0 ona da uyumlu kalıyor. */
body.obai-fullscreen-lock.obai-chat-open header,
body.obai-fullscreen-lock.obai-chat-open .h-search-wrap {
    opacity: 0 !important;
}

/* ════════════════════════════════════════════════════════════════════════════
   FAZ 1.5 EK — Tam ekran header avatarı düzeltme
   Tam ekran modunda header padding büyüyor, ama avatar 40px sabit kalıyor —
   bu da oransızlık yaratıyor. Avatar'ı 52px yap, çerçeveyi kalınlaştır,
   metin (ObAi/v2.3/Bağlantı Şifreli) düzenini ferahlat.
   ════════════════════════════════════════════════════════════════════════════ */
/* Faz 1.5.2 — Tam ekran header avatar yenilendi
   Eski SVG (göz+bıyık) 52px'te pikselleşip siyah görünüyordu.
   Yeni: turuncu gradient daire + "OB" monogram + parıltı animasyonu. */
.obai-widget.fullscreen .obai-header-icon{
    width:54px;height:54px;
    background: radial-gradient(circle at 32% 30%,
        var(--obai-tone-bright, #ffa44d) 0%,
        var(--obai-tone, #ff6b00) 55%,
        var(--obai-tone-deep, #c2410c) 100%);
    border:2px solid rgba(255,245,230,.85);
    box-shadow:
        0 4px 16px var(--obai-tone-soft, rgba(255,107,0,.55)),
        inset 0 2px 6px rgba(255,255,255,.35),
        inset 0 -3px 8px rgba(0,0,0,.18);
    position:relative;
    overflow:hidden;
}
.obai-widget.fullscreen .obai-header-icon svg,
.obai-widget.fullscreen .obai-header-icon .obai-svg-avatar{
    display:none !important;
}
.obai-widget.fullscreen .obai-header-icon::before{
    content:'OB';
    position:absolute;inset:0;
    display:flex;align-items:center;justify-content:center;
    color:#fff;font-weight:900;font-size:18px;letter-spacing:-.6px;
    font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
    text-shadow:0 1px 2px rgba(0,0,0,.4),0 0 8px rgba(255,255,255,.25);
    z-index:2;
}
.obai-widget.fullscreen .obai-header-icon::after{
    content:'';position:absolute;
    top:-30%;left:-30%;width:160%;height:160%;
    background:radial-gradient(circle,rgba(255,255,255,.45),transparent 45%);
    animation:obaiHeaderGlow 3.2s ease-in-out infinite;
    pointer-events:none;
}
@keyframes obaiHeaderGlow{
    0%,100%{opacity:.45;transform:translate(15%,-25%)}
    50%{opacity:.9;transform:translate(-15%,20%)}
}
.obai-widget.fullscreen .obai-header-name{
    font-size:17px;line-height:1.2;
}
.obai-widget.fullscreen .obai-header-info > div:first-child span{
    font-size:11px !important;
}
.obai-widget.fullscreen .obai-header-status{
    font-size:11.5px;margin-top:2px;
}
.obai-widget.fullscreen .obai-paket-badge{
    font-size:10.5px;padding:4px 12px;
}

/* ════════════════════════════════════════════════════════════════════════════
   FAZ 1.5 EK — KVKK modal (class tabanlı, tam ekran üstüne çıkar)
   z-index widget ile aynı (max int) + DOM'da widget'tan sonra olduğu için üstte.
   Açılış: opacity 0→1 + box scale .94→1, kapanış tersi.
   ════════════════════════════════════════════════════════════════════════════ */
.obai-kvkk-modal{
    position:fixed;inset:0;z-index:2147483647;
    background:rgba(0,0,0,.92);
    backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
    display:flex;align-items:center;justify-content:center;padding:20px;box-sizing:border-box;
    opacity:0;visibility:hidden;pointer-events:none;
    transition:opacity .3s ease, visibility .3s ease;
    font-family:Poppins,sans-serif;
}
.obai-kvkk-modal.active{
    opacity:1;visibility:visible;pointer-events:all;
}
.obai-kvkk-box{
    background:#0f0f16;border:1px solid var(--obai-tone-soft, rgba(255,107,0,.45));
    border-radius:20px;width:100%;max-width:480px;max-height:90vh;
    overflow-y:auto;padding:24px 20px 20px;position:relative;
    box-shadow:0 24px 60px rgba(0,0,0,.9), 0 0 30px var(--obai-tone-soft, rgba(255,107,0,.25));
    transform:translateY(14px) scale(.94);opacity:0;
    transition:transform .42s cubic-bezier(.34,1.56,.64,1) .05s, opacity .3s ease .05s;
}
.obai-kvkk-modal.active .obai-kvkk-box{
    transform:translateY(0) scale(1);opacity:1;
}
.obai-kvkk-close{
    position:absolute;top:14px;right:16px;background:transparent;border:none;
    color:#777;font-size:22px;cursor:pointer;line-height:1;padding:4px 8px;border-radius:8px;
    transition:color .2s ease, background .2s ease;
}
.obai-kvkk-close:hover{color:#fff;background:rgba(255,255,255,.06)}
.obai-kvkk-title{
    font-size:17px;font-weight:800;color:var(--obai-tone, #ff6b00);
    margin-bottom:16px;text-align:center;padding-right:24px;
}
.obai-kvkk-body{font-size:12.5px;color:#aaa;line-height:1.75}
.obai-kvkk-card{border-radius:11px;padding:12px 14px;margin-bottom:10px;border:1px solid}
.obai-kvkk-card-h{font-weight:700;font-size:11.5px;margin-bottom:6px}
.obai-kvkk-card.orange{background:rgba(255,107,0,.07);border-color:rgba(255,107,0,.22)}
.obai-kvkk-card.orange .obai-kvkk-card-h{color:#ff6b00}
.obai-kvkk-card.green{background:rgba(46,204,113,.06);border-color:rgba(46,204,113,.22)}
.obai-kvkk-card.green .obai-kvkk-card-h{color:#2ecc71}
.obai-kvkk-card.gray{background:rgba(255,255,255,.03);border-color:rgba(255,255,255,.09)}
.obai-kvkk-card.gray .obai-kvkk-card-h{color:#ccc}
.obai-kvkk-card strong{color:#fff}
.obai-kvkk-card.gray strong{color:#ffb380}
.obai-kvkk-ok{
    width:100%;margin-top:16px;
    background:var(--obai-tone-faint, rgba(255,107,0,.15));
    border:1px solid var(--obai-tone-soft, rgba(255,107,0,.4));
    color:var(--obai-tone, #ff6b00);
    padding:13px;border-radius:12px;font-size:13px;font-weight:700;
    cursor:pointer;font-family:inherit;
    transition:transform .15s ease, background .25s ease, color .25s ease;
}
.obai-kvkk-ok:hover{
    background:var(--obai-tone-soft, rgba(255,107,0,.28));
    color:#fff;
}
.obai-kvkk-ok:active{transform:scale(.97)}

/* ════════════════════════════════════════════════════════════════════════════
   FAZ 1.5 EK — Ayarlar modal animasyon hooks (JS DOM'a ekledikten sonra
   .active class koyar; CSS bu transition'ı sağlar). z-index widget ile aynı.
   ════════════════════════════════════════════════════════════════════════════ */
#obaiSettingsModal{
    opacity:0;
    transition:opacity .3s ease;
}
#obaiSettingsModal.active{opacity:1}
#obaiSettingsModal > div{
    transform:translateY(14px) scale(.94);opacity:0;
    transition:transform .42s cubic-bezier(.34,1.56,.64,1) .05s, opacity .3s ease .05s;
}
#obaiSettingsModal.active > div{transform:translateY(0) scale(1);opacity:1}

/* ════════════════════════════════════════════════════════════════════════════
   FAZ 1.3 — GERİ BİLDİRİM (👍/👎)
   ----------------------------------------------------------------------------
   AI mesajının altında, mesaj tamamlandıktan sonra fade-in ile beliren küçük
   buton çubuğu. Tıklamada anime'siz ölçek pop + ripple, oy verildikten sonra
   diğer buton söner ve seçili olan tier rengiyle vurgulanır.
   ════════════════════════════════════════════════════════════════════════════ */
.obai-fb-bar{
    display:flex;gap:6px;margin-top:4px;align-items:center;
    opacity:0;transform:translateY(4px);
    animation:obai-fb-in .42s cubic-bezier(.22,1,.36,1) .25s forwards;
}
@keyframes obai-fb-in{
    0%{opacity:0;transform:translateY(4px)}
    100%{opacity:1;transform:translateY(0)}
}
.obai-fb-btn{
    position:relative;overflow:hidden;
    width:24px;height:24px;border-radius:7px;border:1px solid rgba(255,255,255,.08);
    background:rgba(255,255,255,.03);color:#888;cursor:pointer;
    display:inline-flex;align-items:center;justify-content:center;
    transition:transform .18s ease, background .25s ease, color .25s ease, border-color .25s ease;
    -webkit-tap-highlight-color:transparent;padding:0;
}
.obai-fb-btn svg{width:13px;height:13px;display:block;transition:transform .25s cubic-bezier(.34,1.56,.64,1)}
.obai-fb-btn:hover{background:var(--obai-tone-faint);color:var(--obai-tone);border-color:var(--obai-tone-soft);transform:translateY(-1px)}
.obai-fb-btn:hover svg{transform:scale(1.15)}
.obai-fb-btn:active{transform:scale(.92)}
.obai-fb-btn.is-down svg{transform:scaleY(-1)}
.obai-fb-btn:hover.is-down svg{transform:scaleY(-1) scale(1.15)}
/* Seçili (oy verildi) durumu — tier rengiyle dolu */
.obai-fb-btn.is-voted{
    background:linear-gradient(135deg,var(--obai-tone-grad-a),var(--obai-tone-grad-b));
    color:#fff;border-color:transparent;
    box-shadow:0 4px 12px var(--obai-tone-soft);
    animation:obai-fb-pop .55s cubic-bezier(.34,1.56,.64,1);
}
.obai-widget.tier-elite .obai-fb-btn.is-voted{color:#1a1208}
@keyframes obai-fb-pop{
    0%{transform:scale(1)}
    25%{transform:scale(1.35)}
    50%{transform:scale(.92)}
    75%{transform:scale(1.08)}
    100%{transform:scale(1)}
}
/* Diğer buton söner (oy verildikten sonra) */
.obai-fb-btn.is-faded{opacity:.35;pointer-events:none;filter:grayscale(1)}
/* Ripple — tıklama anında dış çember */
.obai-fb-ripple{
    position:absolute;inset:0;border-radius:7px;pointer-events:none;
    border:2px solid var(--obai-tone);opacity:.7;
    animation:obai-fb-ripple .7s cubic-bezier(.22,1,.36,1) forwards;
}
@keyframes obai-fb-ripple{
    0%{transform:scale(.4);opacity:.85}
    100%{transform:scale(1.9);opacity:0}
}
/* Teşekkür mini-toast — buton barının yanında belirir */
.obai-fb-thanks{
    font-size:10px;color:var(--obai-tone);font-weight:600;
    margin-left:4px;letter-spacing:.3px;
    opacity:0;transform:translateX(-4px);
    animation:obai-fb-thanks-in .45s cubic-bezier(.22,1,.36,1) .15s forwards;
}
@keyframes obai-fb-thanks-in{
    0%{opacity:0;transform:translateX(-4px)}
    100%{opacity:1;transform:translateX(0)}
}

/* ════════════════════════════════════════════════════════════════════════════
   FAZ 1.6 — SAYFA TARAMA ANİMASYONU
   Hook çağrısı yapılırken sayfada bir "tarama" görseli çalışır:
     • Tüm sayfayı yukarıdan aşağıya gezen ince ışık çizgisi
     • Çizginin altında yumuşak ışıltı izi (trail)
     • Sağ üst köşede mini "analiz ediliyor" rozeti
     • Tamam olunca kısa flash + bubble açılır
   pointer-events:none — tarama sırasında kullanıcı tıklamaya devam edebilir
   prefers-reduced-motion — animasyon devre dışı (rozetin sadece statik halı görünür)
   ════════════════════════════════════════════════════════════════════════════ */
.obai-scan-overlay{
    position:fixed;inset:0;
    z-index:2147483646; /* widget'tan 1 alt — modaller üstte kalsın */
    pointer-events:none;
    opacity:0;
    transition:opacity .25s ease;
}
.obai-scan-overlay.active{opacity:1}

/* Yatay tarama çizgisi (yukarıdan aşağıya) — radar-sweep tarzı linear */
.obai-scan-line{
    position:absolute;left:0;right:0;
    top:0;height:3px;
    background:linear-gradient(90deg,
        transparent 0%,
        var(--obai-tone, #ff6b00) 15%,
        #fff 50%,
        var(--obai-tone, #ff6b00) 85%,
        transparent 100%);
    box-shadow:
        0 0 20px var(--obai-tone, #ff6b00),
        0 0 40px var(--obai-tone-soft, rgba(255,107,0,.55)),
        0 4px 30px var(--obai-tone-soft, rgba(255,107,0,.35));
    transform:translateY(0);
    will-change:transform;
}
.obai-scan-overlay.active .obai-scan-line{
    animation:obai-scan-sweep var(--obai-scan-dur,1200ms) linear forwards;
}

/* Çizgi altında yumuşak ışıltı izi (ışıkla beraber gelir, perde gibi) */
.obai-scan-trail{
    position:absolute;left:0;right:0;
    top:0;height:180px;
    background:linear-gradient(180deg,
        var(--obai-tone-soft, rgba(255,107,0,.45)) 0%,
        rgba(255,107,0,.18) 40%,
        rgba(255,107,0,.04) 75%,
        transparent 100%);
    transform:translateY(-180px);
    will-change:transform;
    mix-blend-mode:screen;
}
.obai-scan-overlay.active .obai-scan-trail{
    animation:obai-scan-sweep-trail var(--obai-scan-dur,1200ms) linear forwards;
}

/* Sağ üst köşede HUD rozeti */
.obai-scan-hud{
    position:absolute;top:16px;right:16px;
    display:flex;align-items:center;gap:8px;
    padding:7px 13px;
    background:rgba(0,0,0,.78);
    border:1px solid var(--obai-tone, #ff6b00);
    border-radius:20px;
    color:#fff;font:600 12px -apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
    box-shadow:0 4px 14px rgba(0,0,0,.5),0 0 0 1px var(--obai-tone-soft, rgba(255,107,0,.3));
    transform:translateX(20px);opacity:0;
    transition:transform .35s cubic-bezier(.34,1.56,.64,1), opacity .25s ease;
    backdrop-filter:blur(10px);
}
.obai-scan-overlay.active .obai-scan-hud{
    transform:translateX(0);opacity:1;
}
.obai-scan-hud-dot{
    width:8px;height:8px;border-radius:50%;
    background:var(--obai-tone, #ff6b00);
    box-shadow:0 0 8px var(--obai-tone, #ff6b00);
    animation:obai-scan-pulse 1s ease-in-out infinite;
}

/* Bitirme flash */
.obai-scan-flash{
    position:absolute;inset:0;
    background:radial-gradient(circle at 50% 50%,
        var(--obai-tone-soft, rgba(255,107,0,.45)) 0%,
        transparent 60%);
    opacity:0;pointer-events:none;
}
.obai-scan-overlay.complete .obai-scan-flash{
    animation:obai-scan-flash .55s ease-out forwards;
}

@keyframes obai-scan-sweep{
    0%   {transform:translateY(0)}
    100% {transform:translateY(100vh)}
}
@keyframes obai-scan-sweep-trail{
    0%   {transform:translateY(-180px)}
    100% {transform:translateY(100vh)}
}
@keyframes obai-scan-pulse{
    0%,100%{transform:scale(1);opacity:1}
    50%    {transform:scale(1.4);opacity:.55}
}
@keyframes obai-scan-flash{
    0%   {opacity:0;transform:scale(.85)}
    40%  {opacity:.85}
    100% {opacity:0;transform:scale(1.15)}
}

/* Hareket azaltma — animasyon yerine sadece HUD rozeti gösterilir */
@media (prefers-reduced-motion: reduce){
    .obai-scan-overlay.active .obai-scan-line,
    .obai-scan-overlay.active .obai-scan-trail{
        animation:none;display:none;
    }
    .obai-scan-overlay.complete .obai-scan-flash{animation:none;display:none}
    .obai-scan-grid,.obai-scan-radar,.obai-scan-points{display:none}
    .obai-scan-btn-pulse{animation:none}
}

/* ════════════════════════════════════════════════════════════════════════════
   FAZ 1.6.1 — Manuel tarama butonu (input area)
   ════════════════════════════════════════════════════════════════════════════ */
.obai-scan-btn{
    width:36px;height:36px;border-radius:50%;
    background:linear-gradient(135deg,
        var(--obai-tone, #ff6b00) 0%,
        var(--obai-tone-deep, #c2410c) 100%);
    border:1px solid var(--obai-tone-bright, #ffa44d);
    color:#fff;cursor:pointer;
    display:flex;align-items:center;justify-content:center;
    flex-shrink:0;margin-right:8px;
    position:relative;
    box-shadow:0 2px 8px var(--obai-tone-soft, rgba(255,107,0,.45)),
        inset 0 1px 2px rgba(255,255,255,.2);
    transition:transform .25s cubic-bezier(.34,1.56,.64,1),
        box-shadow .3s ease, opacity .25s ease;
    overflow:visible;
}
.obai-scan-btn svg{
    width:18px;height:18px;fill:#fff;position:relative;z-index:2;
    filter:drop-shadow(0 1px 1px rgba(0,0,0,.35));
}
.obai-scan-btn:hover{
    transform:translateY(-1px) scale(1.05);
    box-shadow:0 4px 14px var(--obai-tone-soft, rgba(255,107,0,.65)),
        inset 0 1px 2px rgba(255,255,255,.25);
}
.obai-scan-btn:active{transform:scale(.95)}
.obai-scan-btn:disabled{opacity:.55;cursor:not-allowed;transform:none}
.obai-scan-btn-pulse{
    position:absolute;inset:-3px;border-radius:50%;
    border:2px solid var(--obai-tone, #ff6b00);
    opacity:0;pointer-events:none;
    animation:obai-scan-btn-pulse 2.4s ease-out infinite;
    animation-delay:1s;
}
.obai-scan-btn.scanning .obai-scan-btn-pulse{
    animation:obai-scan-btn-pulse-fast .9s ease-out infinite;
}
@keyframes obai-scan-btn-pulse{
    0%,80%,100%{opacity:0;transform:scale(.92)}
    35%{opacity:.55;transform:scale(1.1)}
    65%{opacity:0;transform:scale(1.32)}
}
@keyframes obai-scan-btn-pulse-fast{
    0%{opacity:.7;transform:scale(.92)}
    100%{opacity:0;transform:scale(1.4)}
}

/* ════════════════════════════════════════════════════════════════════════════
   FAZ 1.6.2 — Şık tarama animasyonu eklemeleri (radar grid + data points)
   ════════════════════════════════════════════════════════════════════════════ */
.obai-scan-grid{
    position:absolute;inset:0;pointer-events:none;
    background-image:
        linear-gradient(var(--obai-tone-soft, rgba(255,107,0,.16)) 1px, transparent 1px),
        linear-gradient(90deg, var(--obai-tone-soft, rgba(255,107,0,.16)) 1px, transparent 1px);
    background-size:48px 48px;
    opacity:0;
    mask-image:radial-gradient(ellipse 70% 55% at 50% 50%, #000 30%, transparent 80%);
    -webkit-mask-image:radial-gradient(ellipse 70% 55% at 50% 50%, #000 30%, transparent 80%);
    transition:opacity .35s ease;
}
.obai-scan-overlay.active .obai-scan-grid{opacity:.85}
.obai-scan-overlay.complete .obai-scan-grid{opacity:0}

.obai-scan-radar{
    position:absolute;left:50%;top:50%;
    width:240px;height:240px;
    transform:translate(-50%,-50%);
    pointer-events:none;
    border-radius:50%;
    border:1px solid var(--obai-tone-soft, rgba(255,107,0,.4));
    box-shadow:inset 0 0 60px var(--obai-tone-soft, rgba(255,107,0,.18));
    opacity:0;
    transition:opacity .35s ease;
}
.obai-scan-overlay.active .obai-scan-radar{opacity:1}
.obai-scan-overlay.complete .obai-scan-radar{opacity:0}
.obai-scan-radar::before,
.obai-scan-radar::after{
    content:'';position:absolute;inset:0;border-radius:50%;
    border:1px solid var(--obai-tone-soft, rgba(255,107,0,.35));
}
.obai-scan-radar::before{
    inset:25%;
    animation:obai-radar-ring 2s ease-out infinite;
}
.obai-scan-radar::after{
    inset:50%;
    animation:obai-radar-ring 2s ease-out infinite;
    animation-delay:.4s;
}
@keyframes obai-radar-ring{
    0%{transform:scale(.4);opacity:1}
    100%{transform:scale(2.6);opacity:0}
}

.obai-scan-points{
    position:absolute;inset:0;pointer-events:none;opacity:0;
    transition:opacity .35s ease;
}
.obai-scan-overlay.active .obai-scan-points{opacity:1}
.obai-scan-overlay.complete .obai-scan-points{opacity:0}
.obai-scan-point{
    position:absolute;width:8px;height:8px;border-radius:50%;
    background:var(--obai-tone-bright, #ffa44d);
    box-shadow:0 0 12px var(--obai-tone, #ff6b00),
        0 0 4px #fff;
    transform:scale(0);
    animation:obai-point-pop .8s cubic-bezier(.34,1.56,.64,1) forwards;
}
.obai-scan-point::after{
    content:attr(data-tag);
    position:absolute;left:14px;top:-4px;white-space:nowrap;
    font:600 10px -apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
    color:#fff;background:rgba(0,0,0,.78);
    border:1px solid var(--obai-tone, #ff6b00);
    padding:2px 7px;border-radius:6px;
    opacity:0;transform:translateX(-6px);
    animation:obai-point-tag .5s ease-out .25s forwards;
    backdrop-filter:blur(6px);
}
@keyframes obai-point-pop{
    0%{transform:scale(0);opacity:0}
    60%{transform:scale(1.3);opacity:1}
    100%{transform:scale(1);opacity:1}
}
@keyframes obai-point-tag{
    0%{opacity:0;transform:translateX(-6px)}
    100%{opacity:.95;transform:translateX(0)}
}

/* AI'dan gelen analiz mesajı için özel chip — sıradan AI mesajından ayırt edilebilsin */
.obai-msg.ai.scan-result{
    border-left:3px solid var(--obai-tone, #ff6b00) !important;
    padding-left:10px !important;
    background:linear-gradient(90deg,
        var(--obai-tone-soft, rgba(255,107,0,.12)) 0%,
        transparent 80%) !important;
}
.obai-msg.ai.scan-result::before{
    content:'🔍 Sayfa Analizi';
    display:inline-block;
    font:700 10px -apple-system,BlinkMacSystemFont,sans-serif;
    color:var(--obai-tone, #ff6b00);
    margin-bottom:6px;
    letter-spacing:.5px;
    text-transform:uppercase;
}
.obai-msg.ai.scan-result .obai-msg-text{display:block;margin-top:4px}
