/* ================================
   BASE TOKENS (senin palet)
================================ */
:root{
  --bg-body:#09090b;
  --bg-card:#121214;
  --bg-sidebar:#0c0c0e;
  --border-subtle:#27272a;

  --text-primary:#f4f4f5;
  --text-secondary:#a1a1aa;

  --accent-gold:#d4af37;
  --accent-gold-dim:rgba(212,175,55,.1);

  --btn-primary:#f4f4f5;
  --btn-primary-text:#09090b;

  --success:#10b981;
  --danger:#ef4444;

  --stroke:rgba(255,255,255,.10);
  --shadow:0 20px 70px rgba(0,0,0,.65);
  --r:18px;

  --orbA:rgba(212,175,55,.55);
  --orbB:rgba(255,255,255,.20);
  --orbC:rgba(212,175,55,.28);
}

*{box-sizing:border-box;margin:0;padding:0;outline:none;}
html,body{height:100%;}
body{
  font-family:'Inter',sans-serif;
  background:var(--bg-body);
  color:var(--text-primary);
  overflow-x:hidden;
}

/* italic helper */
.serif-italic{
  font-family:'Playfair Display',serif;
  font-style:italic;
  font-weight:600;
  color:var(--accent-gold);
}

/* ================================
   BOOT / LOADING OVERLAY (KİLİT)
================================ */
.boot-lock{
  overflow:hidden !important;
  pointer-events:none !important;
  user-select:none !important;
}

.boot-overlay{
  position:fixed; inset:0;
  background:rgba(0,0,0,.86);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  z-index:999999;
  display:grid;
  place-items:center;
  pointer-events:auto; /* overlay tutsun */
}

.boot-overlay.hide{
  opacity:0;
  transition:opacity .28s ease;
}

.boot-card{
  width:min(420px, 88vw);
  border:1px solid rgba(255,255,255,.10);
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  border-radius:18px;
  box-shadow:0 30px 90px rgba(0,0,0,.55);
  padding:22px;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:10px;
}

.boot-logo{
  width:54px;height:54px;border-radius:14px;
  display:grid;place-items:center;
  font-family:'Playfair Display',serif;
  font-weight:800;
  background:linear-gradient(135deg,#fff 0%,#bdbdbd 100%);
  color:#000;
  border:1px solid rgba(255,255,255,.10);
}
.boot-title{font-weight:700; letter-spacing:.2px;}
.boot-sub{color:rgba(255,255,255,.65); font-size:13px;}
.boot-spinner{
  width:26px;height:26px;border-radius:50%;
  border:2px solid rgba(255,255,255,.20);
  border-top-color: var(--accent-gold);
  animation: spin .8s linear infinite;
  margin-top:4px;
}
@keyframes spin{to{transform:rotate(360deg);}}

/* ================================
   LOGIN BACKGROUND EFFECTS
================================ */
.bg{position:fixed; inset:0; z-index:-1; overflow:hidden;}
.grid{
  position:absolute; inset:-20%;
  background:
    linear-gradient(to right, rgba(255,255,255,0.06) 1px, transparent 1px) 0 0 / 56px 56px,
    linear-gradient(to bottom, rgba(255,255,255,0.05) 1px, transparent 1px) 0 0 / 56px 56px;
  transform: rotate(10deg);
  opacity: .20;
}
.noise{
  position:absolute; inset:0;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='180' height='180' filter='url(%23n)' opacity='.35'/%3E%3C/svg%3E");
  opacity:.12;
  mix-blend-mode:overlay;
}
.orb{
  position:absolute;
  width:560px;height:560px;border-radius:50%;
  filter:blur(34px);
  opacity:.55;
}
.orb1{left:-200px; top:-220px;background:radial-gradient(circle at 30% 30%, var(--orbA), transparent 62%);}
.orb2{right:-220px; top:8%;background:radial-gradient(circle at 40% 40%, var(--orbB), transparent 60%);}
.orb3{left:18%; bottom:-260px;background:radial-gradient(circle at 45% 45%, var(--orbC), transparent 62%);}

/* ================================
   LOGIN LAYOUT (senin tasarım)
================================ */
.loginBody .wrap{
  min-height:100%;
  display:grid;
  grid-template-columns: 1fr 420px;
  gap:28px;
  align-items:center;
  justify-content:center;
  padding:min(7vh,64px) 18px;
  max-width:1100px;
  margin:0 auto;
}
.card{
  background:linear-gradient(180deg, rgba(255,255,255,0.06), rgba(255,255,255,0.03));
  border:1px solid var(--stroke);
  border-radius:var(--r);
  box-shadow:var(--shadow);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  padding:22px;
}
.head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px;}
.brand{display:flex;align-items:center;gap:12px;}
.logo{
  width:44px;height:44px;border-radius:10px;display:grid;place-items:center;
  font-family:'Playfair Display',serif;font-weight:800;
  background:linear-gradient(135deg,#fff 0%,#bdbdbd 100%);
  color:#000;border:1px solid rgba(255,255,255,.10);
  box-shadow:0 16px 46px rgba(0,0,0,.35);
}
.brandTop{font-weight:700;font-size:15px;line-height:1;}
.brandSub{color:var(--text-secondary);font-size:12px;margin-top:4px;}
.badge{
  font-size:12px;padding:8px 10px;border-radius:999px;
  border:1px solid rgba(212,175,55,.25);
  background:var(--accent-gold-dim);
  color:var(--accent-gold);
}
.title{margin:10px 0 4px;font-size:26px;letter-spacing:-.3px;font-weight:400;}
.desc{margin:0 0 16px;color:var(--text-secondary);}
.form{display:flex;flex-direction:column;gap:12px;}
.field{display:flex;flex-direction:column;gap:7px;}
.label{font-size:12px;color:var(--text-secondary);letter-spacing:.2px;}
.inputWrap{
  display:flex;align-items:center;gap:10px;
  border:1px solid var(--border-subtle);
  background:rgba(0,0,0,.22);
  border-radius:14px;
  padding:12px 12px;
  transition:.15s ease;
}
.inputWrap:focus-within{
  border-color: rgba(212,175,55,.55);
  box-shadow:0 0 0 4px rgba(212,175,55,.14);
}
.icon{opacity:.85;font-size:14px;width:18px;text-align:center;}
input{
  width:100%;border:none;background:transparent;
  color:var(--text-primary);font-size:14px;font-family:'Inter',sans-serif;
}
input::placeholder{color:rgba(255,255,255,.35);}
.row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:4px;}
.check{display:flex;gap:8px;align-items:center;color:var(--text-secondary);font-size:13px;}
.check input{width:16px;height:16px;accent-color:var(--accent-gold);}
.link{color:rgba(255,255,255,.90);text-decoration:none;font-size:13px;opacity:.9;}
.link:hover{opacity:1;text-decoration:underline;}
.btn{
  margin-top:6px;width:100%;
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  padding:12px 14px;border-radius:14px;
  border:1px solid rgba(255,255,255,.12);
  cursor:pointer;font-weight:700;
  color:var(--btn-primary-text);
  background:var(--btn-primary);
  box-shadow:0 16px 46px rgba(0,0,0,.35);
  transition: transform .12s ease, filter .12s ease;
}
.btn:hover{transform:translateY(-1px);filter:brightness(1.02);}
.btn:active{transform:translateY(0);}
.btn.secondary{
  background:transparent;color:var(--text-primary);
  border:1px solid var(--border-subtle);box-shadow:none;
}
.ghostBtn{
  border:none;background:transparent;color:rgba(255,255,255,.85);
  cursor:pointer;padding:6px 8px;border-radius:10px;
}
.ghostBtn:hover{background:rgba(255,255,255,.07);}
.divider{display:flex;align-items:center;gap:10px;margin:10px 0 2px;color:rgba(255,255,255,.45);font-size:12px;}
.divider::before,.divider::after{content:"";height:1px;flex:1;background:var(--border-subtle);}
.msg{min-height:18px;font-size:12px;color:rgba(255,255,255,.75);margin-top:4px;}
.msg.err{color:rgba(239,68,68,.95);}
.msg.ok{color:rgba(16,185,129,.95);}
.side{display:flex;justify-content:center;}
.sideCard{
  width:100%;
  background:rgba(255,255,255,.04);
  border:1px solid var(--border-subtle);
  border-radius:var(--r);
  padding:18px;
  box-shadow:0 14px 60px rgba(0,0,0,.45);
  backdrop-filter: blur(12px);
}
.kicker{color:rgba(255,255,255,.6);font-size:12px;letter-spacing:.18em;text-transform:uppercase;}
.sideTitle{font-size:22px;font-weight:600;margin:8px 0 12px;}
.list{margin:0;padding-left:18px;color:rgba(255,255,255,.72);}
.list li{margin:6px 0;}
.hint{display:flex;gap:10px;align-items:center;margin-top:14px;color:rgba(255,255,255,.68);font-size:13px;}
.dot{width:8px;height:8px;border-radius:50%;background:var(--accent-gold);box-shadow:0 0 0 5px rgba(212,175,55,.14);}

@media (max-width:980px){
  .loginBody .wrap{grid-template-columns:1fr;max-width:520px;}
  .side{display:none;}
}

/* ================================
   DASHBOARD (minimal ama premium)
================================ */
.app-wrapper{
  min-height:100vh;
  display:grid;
  grid-template-columns: 280px 1fr;
}

.sidebar{
  background: rgba(255,255,255,0.02);
  border-right:1px solid var(--border-subtle);
  padding:18px 16px;
  display:flex;
  flex-direction:column;
  gap:18px;
}

.brand{display:flex;align-items:center;gap:10px;}
.logo-icon{
  width:44px;height:44px;border-radius:12px;
  display:grid;place-items:center;
  font-weight:900;
  background:linear-gradient(135deg,#fff 0%,#bdbdbd 100%);
  color:#000;
}
.brand-name{font-weight:700; letter-spacing:.2px;}

.menu{display:flex;flex-direction:column;gap:10px;margin-top:6px;}
.menu-item{
  display:flex;align-items:center;gap:12px;
  padding:12px 12px;
  border-radius:12px;
  text-decoration:none;
  color:rgba(255,255,255,.82);
  border:1px solid transparent;
}
.menu-item:hover{background:rgba(255,255,255,.04); border-color: rgba(255,255,255,.06);}
.menu-item.active{
  background: rgba(212,175,55,.08);
  border-color: rgba(212,175,55,.22);
  color:#fff;
}
.menu-item i{width:18px;text-align:center;opacity:.9}

.user-card{
  margin-top:auto;
  display:flex;align-items:center;gap:12px;
  padding:12px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.03);
}
.avatar{width:38px;height:38px;border-radius:12px;}
.user-meta{display:flex;flex-direction:column;gap:2px;}
.user-meta .name{font-weight:700;font-size:13px;}
.user-meta .role{color:var(--text-secondary);font-size:12px;}

.logout-link{
  margin-top:12px;
  display:flex;align-items:center;gap:10px;
  text-decoration:none;
  color:rgba(255,255,255,.75);
  padding:10px 12px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.08);
}
.logout-link:hover{background:rgba(255,255,255,.04);}

.content-area{padding:18px 20px;}
.top-bar{
  display:flex;align-items:flex-start;justify-content:space-between;gap:16px;
  margin-bottom:16px;
}
.welcome-text h1{font-size:22px;font-weight:600;}
.welcome-text p{color:var(--text-secondary);margin-top:6px;}
.actions{display:flex;gap:10px;}

.btn-primary,.btn-secondary{
  border:none;cursor:pointer;
  padding:10px 14px;border-radius:12px;
  font-weight:700;
}
.btn-primary{
  background:var(--btn-primary);
  color:var(--btn-primary-text);
}
.btn-secondary{
  background:rgba(255,255,255,.06);
  color:rgba(255,255,255,.85);
  border:1px solid rgba(255,255,255,.08);
}

.workspace{
  border:1px solid rgba(255,255,255,.06);
  border-radius:18px;
  background:rgba(255,255,255,.02);
  padding:16px;
}

.control-panel{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  margin-bottom:12px;
}
.tabs{display:flex;gap:10px;}
.tab{
  padding:10px 12px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.03);
  color:rgba(255,255,255,.80);
  cursor:pointer;
}
.tab.active{
  border-color: rgba(212,175,55,.35);
  background: rgba(212,175,55,.10);
  color:#fff;
}

.select-group{
  display:flex;align-items:center;gap:10px;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.03);
}
.select-group select{
  background:transparent;border:none;color:#fff;
}

.editor-container{
  display:grid;
  grid-template-columns: 1fr 74px 1fr;
  gap:12px;
  align-items:stretch;
}

.editor-pane{
  border:1px solid rgba(255,255,255,.08);
  background:rgba(0,0,0,.18);
  border-radius:18px;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  min-height:420px;
}
.pane-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 14px;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.counter{color:var(--text-secondary);font-size:12px;}
textarea{
  flex:1;
  width:100%;
  border:none;
  resize:none;
  background:transparent;
  color:#fff;
  padding:14px;
  font-size:14px;
  line-height:1.5;
}
.pane-footer{
  padding:12px 14px;
  border-top:1px solid rgba(255,255,255,.06);
  display:flex;justify-content:flex-end;
}

.btn-text-only{
  border:none;background:transparent;cursor:pointer;
  color:rgba(255,255,255,.85);
  font-weight:700;
}
.btn-text-only:hover{text-decoration:underline;}

.action-divider{
  display:flex;
  align-items:center;
  justify-content:center;
}
.magic-button{
  width:58px;height:58px;border-radius:18px;
  border:1px solid rgba(212,175,55,.25);
  background: rgba(212,175,55,.12);
  color: var(--accent-gold);
  cursor:pointer;
  display:grid;place-items:center;
}
.magic-button.loading{opacity:.8}
.trust-badge{color:rgba(16,185,129,.95);font-size:12px;display:flex;gap:6px;align-items:center;}
.empty-state{
  flex:1;
  display:flex;
  flex-direction:column;
  gap:10px;
  align-items:center;
  justify-content:center;
  color:rgba(255,255,255,.65);
}
.output-text{white-space:pre-wrap;}

/* detector */
.detector-container{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap:12px;
}
.detector-input,.detector-result{
  border:1px solid rgba(255,255,255,.08);
  background:rgba(0,0,0,.18);
  border-radius:18px;
  overflow:hidden;
}
.detector-input .pane-footer{justify-content:flex-start;}
.detector-result{padding:14px;}
.detector-result-content{
  display:none;
  width:100%;
  flex-direction:column;
  align-items:center;
  gap:12px;
}
.gauge{
  width:180px;height:180px;border-radius:50%;
  background: conic-gradient(var(--success) calc(var(--p, 0) * 1%), rgba(255,255,255,.10) 0);
  display:grid;place-items:center;
}
.gauge-inner{
  width:132px;height:132px;border-radius:50%;
  background:rgba(0,0,0,.35);
  border:1px solid rgba(255,255,255,.08);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:4px;
}
.gauge-score{font-size:28px;font-weight:800;}
.gauge-label{color:rgba(255,255,255,.70);font-size:12px;}
.analysis-details{width:100%;max-width:360px;}
.detail-row{display:flex;justify-content:space-between;color:rgba(255,255,255,.85);font-size:13px;}
.progress-bar{
  width:100%;
  height:10px;
  border-radius:999px;
  background:rgba(255,255,255,.08);
  overflow:hidden;
  margin-top:8px;
}
.progress-fill{height:100%;width:0%;border-radius:999px;transition:width .25s ease;}

.settings-layout{
  display:grid;
  grid-template-columns: 220px 1fr;
  gap:14px;
}
.settings-menu{
  border:1px solid rgba(255,255,255,.08);
  background:rgba(0,0,0,.18);
  border-radius:18px;
  padding:12px;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.settings-menu a{
  text-decoration:none;
  color:rgba(255,255,255,.78);
  padding:10px 12px;
  border-radius:12px;
}
.settings-menu a.active{
  background: rgba(212,175,55,.10);
  border:1px solid rgba(212,175,55,.22);
  color:#fff;
}
.settings-content{
  border:1px solid rgba(255,255,255,.08);
  background:rgba(0,0,0,.18);
  border-radius:18px;
  padding:14px;
}
.setting-section{padding:12px;border:1px solid rgba(255,255,255,.06);border-radius:14px;background:rgba(255,255,255,.02);margin-bottom:12px;}
.section-title{margin-bottom:10px;}
.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:10px;}
.form-input{
  padding:12px 12px;border-radius:12px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(0,0,0,.25);
  color:#fff;
}
.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;color:rgba(255,255,255,.85);}
.toggle-switch{
  width:46px;height:26px;border-radius:999px;
  background:rgba(255,255,255,.10);
  position:relative;
  border:1px solid rgba(255,255,255,.10);
}
.toggle-switch::after{
  content:"";
  width:20px;height:20px;border-radius:50%;
  background:#fff;
  position:absolute;top:50%;left:3px;transform:translateY(-50%);
  transition:left .18s ease;
}
.toggle-switch.checked{background:rgba(16,185,129,.22);border-color:rgba(16,185,129,.25);}
.toggle-switch.checked::after{left:23px;}

@media (max-width: 980px){
  .app-wrapper{grid-template-columns:1fr;}
  .sidebar{position:sticky;top:0;z-index:10;}
  .editor-container{grid-template-columns:1fr; }
  .action-divider{display:none;}
  .detector-container{grid-template-columns:1fr;}
  .settings-layout{grid-template-columns:1fr;}
}