/* ===== TOKENS ===== */
:root {
  --navy-950: #04111f;
  --navy-900: #0a1a2e;
  --navy-800: #0f2545;
  --navy-700: #1a3a6b;
  --navy-600: #234a85;
  --blue:     #2563eb;
  --blue-h:   #1d4ed8;
  --blue-l:   #60a5fa;
  --gold:     #c8a84b;
  --gold-l:   #f0c96a;

  --ok:       #059669;
  --ok-bg:    #ecfdf5;
  --ok-b:     #6ee7b7;
  --warn:     #d97706;
  --warn-bg:  #fffbeb;
  --warn-b:   #fcd34d;
  --bad:      #dc2626;
  --bad-bg:   #fff1f2;
  --bad-b:    #fca5a5;
  --sel:      #2563eb;
  --sel-bg:   #eff6ff;
  --sel-b:    #93c5fd;

  --bg:       #eef2f7;
  --surface:  #ffffff;
  --s2:       #f7f9fc;
  --border:   #e1e8f0;
  --border-d: #c8d5e5;

  --tx:       #0c1524;
  --tx2:      #4a5568;
  --tx3:      #8a9ab8;

  --sh0: 0 1px 3px rgba(0,0,0,.06);
  --sh1: 0 4px 16px -2px rgba(0,0,0,.1);
  --sh2: 0 12px 40px -8px rgba(0,0,0,.14);
  --sh3: 0 24px 60px -12px rgba(0,0,0,.2);

  --r-xs: 4px;
  --r-sm: 8px;
  --r:    14px;
  --r-lg: 20px;
  --r-xl: 28px;
}

/* ===== RESET ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  background:var(--bg);
  color:var(--tx);
  line-height:1.6;
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
}
body.app-shell-loading{
  overflow:hidden;
}
body.app-shell-loading > *{
  visibility:hidden;
}
body.app-shell-loading::before{
  content:'';
  position:fixed;
  top:50%;
  left:50%;
  width:44px;
  height:44px;
  margin:-38px 0 0 -22px;
  border-radius:50%;
  border:3px solid rgba(37,99,235,.18);
  border-top-color:var(--blue);
  animation:app-shell-spin .8s linear infinite;
  z-index:10001;
}
body.app-shell-loading::after{
  content:attr(data-app-shell-message);
  position:fixed;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  padding-top:60px;
  background:linear-gradient(180deg,rgba(238,242,247,.96),rgba(238,242,247,.98));
  color:var(--tx2);
  font-size:.92rem;
  font-weight:700;
  letter-spacing:-.01em;
  z-index:10000;
}
@keyframes app-shell-spin{
  to{transform:rotate(360deg)}
}
a{text-decoration:none;color:inherit}
img{max-width:100%}
button{cursor:pointer;font-family:inherit}
input,textarea,select{font-family:inherit}

/* ===== NAVBAR ===== */
.navbar{
  background:rgba(10,18,35,.96);
  border-bottom:1px solid rgba(255,255,255,.07);
  position:sticky;top:0;z-index:1000;
  box-shadow:0 1px 0 rgba(255,255,255,.04), 0 8px 40px rgba(0,0,0,.55);
  backdrop-filter:blur(20px);
}
.navbar::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,#1d4ed8,#3b82f6,#60a5fa,#3b82f6,#1d4ed8);
}
.navbar-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:68px;max-width:1320px;margin:0 auto;padding:0 2rem;
}
.nav-logo{display:flex;align-items:center;gap:.8rem;text-decoration:none;min-width:0}
.nav-logo > div:last-child{min-width:0}
.nav-logo-mark{
  width:38px;height:38px;
  background:linear-gradient(135deg,#1d4ed8,#3b82f6);
  border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  font-size:1.05rem;font-weight:900;color:#fff;letter-spacing:-1px;
  box-shadow:0 0 0 1px rgba(255,255,255,.1), 0 4px 20px rgba(37,99,235,.55);
  transition:box-shadow .2s;
}
.nav-logo:hover .nav-logo-mark{box-shadow:0 0 0 1px rgba(255,255,255,.2),0 6px 28px rgba(37,99,235,.75)}
.nav-logo-text{
  font-size:1.12rem;font-weight:900;color:#f8fafc;letter-spacing:-.5px;line-height:1;
}
.nav-logo-text span{color:#60a5fa}
.nav-logo-sub{font-size:.6rem;color:rgba(255,255,255,.28);font-weight:600;letter-spacing:.6px;text-transform:uppercase;margin-top:3px}
.nav-right{display:flex;align-items:center;gap:.6rem}
.nav-user{
  display:flex;align-items:center;gap:.55rem;
  padding:.32rem .8rem .32rem .32rem;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.09);
  border-radius:100px;
  transition:all .2s;
}
.nav-user:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.18)}
.nav-avatar{
  width:28px;height:28px;
  background:linear-gradient(135deg,#1d4ed8,#60a5fa);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:.75rem;font-weight:900;color:#fff;
  box-shadow:0 0 0 2px rgba(96,165,250,.3);
}
.nav-user-name{
  font-size:.8rem;font-weight:700;color:rgba(255,255,255,.75);letter-spacing:-.01em;
  max-width:220px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}

/* ── Yoğunluk trafik widget ── */
.traffic-widget{
  display:flex;align-items:center;gap:.45rem;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.1);
  border-radius:var(--r-sm);
  padding:.38rem .65rem .38rem .5rem;
  flex-shrink:0;
  transition:background .18s;
}
.traffic-widget:hover{background:rgba(255,255,255,.1)}
.tw-icon{display:flex;align-items:center;flex-shrink:0;opacity:.8}
.tw-chart{display:flex;align-items:flex-end;line-height:0}
.tw-meta{display:flex;flex-direction:column;gap:1px;min-width:0}
.tw-val{font-size:.82rem;font-weight:900;letter-spacing:-.03em;line-height:1}
.tw-unit{font-size:.58rem;font-weight:700;color:rgba(255,255,255,.35);text-transform:uppercase;letter-spacing:.4px}
.tw-level{
  font-size:.58rem;font-weight:800;
  padding:.1rem .38rem;border-radius:100px;
  text-transform:uppercase;letter-spacing:.3px;
  margin-top:1px;display:inline-block;
}

/* ── Ajans Premium Müşteri Seçici ── */
.client-picker{position:relative}
.client-picker-btn{
  display:flex;align-items:center;gap:.75rem;
  width:100%;padding:.75rem 1rem;
  background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-sm);
  cursor:pointer;transition:all .18s;text-align:left;font-family:inherit;
}
.client-picker-btn:hover,.client-picker-btn.open{border-color:var(--blue);box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.cp-avatar{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,#7c3aed,#a855f7);display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:900;color:#fff;flex-shrink:0}
.cp-info{flex:1;min-width:0}
.cp-name{font-size:.88rem;font-weight:800;color:var(--tx);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cp-sub{font-size:.72rem;color:var(--tx3)}
.cp-arrow{color:var(--tx3);font-size:.7rem;flex-shrink:0;transition:transform .18s}
.client-picker-btn.open .cp-arrow{transform:rotate(180deg)}
.client-picker-dropdown{
  position:absolute;top:calc(100% + 6px);left:0;right:0;z-index:500;
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r);
  box-shadow:var(--sh2);max-height:280px;overflow-y:auto;display:none;
}
.client-picker-dropdown.visible{display:block}
.cp-option{
  display:flex;align-items:center;gap:.75rem;
  padding:.75rem 1rem;cursor:pointer;transition:background .15s;border-bottom:1px solid var(--border);
}
.cp-option:last-child{border-bottom:none}
.cp-option:hover,.cp-option.selected{background:rgba(37,99,235,.06)}
.cp-option.selected .cp-name{color:var(--blue)}
.cp-search{
  padding:.55rem .9rem;border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:.5rem;
  position:sticky;top:0;background:var(--surface);z-index:1;
}
.cp-search input{flex:1;border:none;outline:none;font-size:.84rem;background:transparent;font-family:inherit}
.cp-empty{padding:1.5rem;text-align:center;font-size:.82rem;color:var(--tx3)}

/* Profil sekmeleri */
.prof-tab{
  display:inline-flex;align-items:center;justify-content:center;
  padding:.38rem .85rem;border-radius:var(--r-sm);font-size:.8rem;font-weight:700;
  border:1.5px solid var(--border);background:transparent;color:var(--tx3);cursor:pointer;
  transition:all .15s;
}
.prof-tab.active{background:var(--blue);border-color:var(--blue);color:#fff}
.prof-tab:hover:not(.active){border-color:var(--border-d);color:var(--tx)}

/* ===== NAV ŞEHİR SEÇİCİ ===== */
.nav-loc-wrapper{position:relative}

.nav-loc-btn{
  display:flex;align-items:center;gap:.5rem;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.14);
  border-radius:100px;
  padding:.36rem 1rem .36rem .65rem;
  cursor:pointer;color:#fff;
  transition:background .18s,border-color .18s,box-shadow .18s;
  white-space:nowrap;max-width:100%;
}
.nav-loc-btn:hover{
  background:rgba(255,255,255,.13);
  border-color:rgba(255,255,255,.25);
}
.nav-loc-btn.has-city{
  background:rgba(37,99,235,.25);
  border-color:rgba(96,165,250,.5);
  box-shadow:0 0 0 3px rgba(37,99,235,.12);
}
.nav-loc-btn.needs-district{
  background:rgba(245,158,11,.2);
  border-color:rgba(251,191,36,.48);
  box-shadow:0 0 0 3px rgba(245,158,11,.14);
}
.nav-loc-btn.open{
  background:rgba(37,99,235,.3);
  border-color:rgba(96,165,250,.65);
  box-shadow:0 0 0 3px rgba(37,99,235,.18);
}
.nav-loc-btn.needs-district.open{
  background:rgba(245,158,11,.24);
  border-color:rgba(251,191,36,.54);
  box-shadow:0 0 0 3px rgba(245,158,11,.18);
}
.nav-loc-pin{font-size:.88rem;line-height:1;flex-shrink:0}
.nav-loc-labels{display:flex;flex-direction:column;line-height:1.2;text-align:left;min-width:0}
.nav-loc-city-lbl{
  font-size:.8rem;font-weight:800;color:#f1f5f9;
  display:block;overflow:hidden;text-overflow:ellipsis;
  letter-spacing:.01em;
}
.nav-loc-dist-lbl{
  font-size:.65rem;font-weight:600;color:rgba(147,197,253,.8);margin-top:.1rem;
  display:block;overflow:hidden;text-overflow:ellipsis;
}
.nav-loc-chevron{
  display:flex;align-items:center;justify-content:center;
  width:14px;height:14px;margin-left:.1rem;flex-shrink:0;
  color:rgba(255,255,255,.5);
  transition:transform .2s ease;
}
.nav-loc-btn.open .nav-loc-chevron{transform:rotate(180deg)}

/* Dropdown paneli */
.nav-loc-dropdown{
  position:absolute;
  top:calc(100% + 10px);
  left:50%;
  transform:translateX(-50%) translateY(0);
  background:#0f1e3a;
  border:1px solid rgba(255,255,255,.13);
  border-radius:18px;
  padding:0;
  width:min(420px,calc(100vw - 1.5rem));
  min-width:min(320px,calc(100vw - 1.5rem));
  max-width:420px;
  box-shadow:0 20px 60px rgba(0,0,0,.6),0 4px 16px rgba(0,0,0,.3);
  z-index:2000;
  overflow:hidden;
  opacity:1;visibility:visible;
  transition:opacity .18s ease,transform .18s ease,visibility .18s;
}
.nav-loc-dropdown::before{
  content:'';position:absolute;top:-6px;left:50%;transform:translateX(-50%);
  width:12px;height:6px;
  background:#0f1e3a;
  clip-path:polygon(50% 0%,0% 100%,100% 100%);
}
.nav-loc-dropdown.hidden{
  opacity:0;
  transform:translateX(-50%) translateY(-8px);
  pointer-events:none;
  visibility:hidden;
}
.nav-dd-header{
  display:flex;align-items:center;justify-content:space-between;
  gap:1rem;
  padding:.72rem 1rem .65rem;
  border-bottom:1px solid rgba(255,255,255,.07);
}
.nav-dd-header-copy{
  display:block;
  margin-top:.16rem;
  font-size:.75rem;
  line-height:1.45;
  color:rgba(226,232,240,.66);
}
.nav-dd-header-title{
  font-size:.7rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  color:rgba(255,255,255,.4);
}
.nav-dd-clear{
  display:inline-flex;align-items:center;justify-content:center;
  min-height:34px;
  font-size:.72rem;font-weight:800;color:rgba(191,219,254,.88);
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.08);
  cursor:pointer;padding:.42rem .72rem;
  border-radius:999px;transition:color .15s,background .15s,border-color .15s;
  white-space:nowrap;
}
.nav-dd-clear:hover{
  color:#fff;
  background:rgba(37,99,235,.22);
  border-color:rgba(96,165,250,.32);
}
.nav-dd-body{padding:1rem 1.1rem 1.1rem}
.nav-dd-overview{
  display:flex;justify-content:space-between;align-items:flex-start;
  gap:1rem;
  padding:1rem 1.05rem;
  margin-bottom:1rem;
  border-radius:18px;
  background:
    radial-gradient(circle at top right,rgba(96,165,250,.2),transparent 36%),
    linear-gradient(135deg,rgba(37,99,235,.18),rgba(15,23,42,.12));
  border:1px solid rgba(96,165,250,.2);
}
.page-agency .nav-dd-overview{
  background:
    radial-gradient(circle at top right,rgba(168,85,247,.24),transparent 36%),
    linear-gradient(135deg,rgba(124,58,237,.18),rgba(15,23,42,.12));
  border-color:rgba(168,85,247,.22);
}
.nav-dd-overview-main{min-width:0}
.nav-dd-kicker{
  display:inline-flex;align-items:center;gap:.35rem;
  margin-bottom:.4rem;
  font-size:.64rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;
  color:rgba(191,219,254,.88);
}
.nav-dd-kicker::before{
  content:'';
  width:8px;height:8px;border-radius:999px;
  background:linear-gradient(135deg,#60a5fa,#93c5fd);
  box-shadow:0 0 0 5px rgba(96,165,250,.14);
}
.page-agency .nav-dd-kicker{color:rgba(233,213,255,.9)}
.page-agency .nav-dd-kicker::before{
  background:linear-gradient(135deg,#a855f7,#d8b4fe);
  box-shadow:0 0 0 5px rgba(168,85,247,.14);
}
.nav-dd-overview-title{
  font-size:1rem;
  font-weight:900;
  letter-spacing:-.03em;
  color:#fff;
  line-height:1.15;
}
.nav-dd-overview-copy{
  margin-top:.32rem;
  font-size:.78rem;
  line-height:1.62;
  color:rgba(226,232,240,.76);
}
.nav-dd-stats{
  display:flex;
  gap:.5rem;
  flex-wrap:wrap;
  justify-content:flex-end;
  flex-shrink:0;
}
.nav-dd-stat{
  min-width:82px;
  padding:.6rem .72rem;
  border-radius:14px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.08);
}
.nav-dd-stat strong{
  display:block;
  font-size:1rem;
  font-weight:900;
  color:#fff;
  line-height:1;
}
.nav-dd-stat span{
  display:block;
  margin-top:.24rem;
  font-size:.62rem;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:rgba(226,232,240,.6);
}
.nav-dd-section{margin-bottom:1rem}
.nav-dd-section:last-child{margin-bottom:0}
.nav-dd-section+.nav-dd-section{
  padding-top:1rem;
  border-top:1px solid rgba(255,255,255,.07);
}
.nav-dd-label{
  display:flex;align-items:center;gap:.35rem;
  font-size:.64rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;
  color:rgba(255,255,255,.3);margin-bottom:.55rem;
}
.nav-dd-step{
  display:inline-flex;align-items:center;justify-content:center;
  width:18px;height:18px;border-radius:999px;
  background:rgba(96,165,250,.16);
  border:1px solid rgba(96,165,250,.22);
  color:#bfdbfe;
  font-size:.66rem;font-weight:800;
}
.page-agency .nav-dd-step{
  background:rgba(168,85,247,.16);
  border-color:rgba(168,85,247,.24);
  color:#e9d5ff;
}
.nav-dd-label-dot{
  width:5px;height:5px;border-radius:50%;background:rgba(96,165,250,.6);flex-shrink:0;
}
.page-agency .nav-dd-label-dot{background:rgba(168,85,247,.72)}
.nav-dd-pills{display:flex;flex-wrap:wrap;gap:.45rem}
.nav-dd-options{align-items:stretch}
.nav-dd-pill{
  display:flex;flex-direction:column;align-items:flex-start;justify-content:center;
  gap:.18rem;
  min-width:116px;
  padding:.72rem .84rem;border-radius:18px;
  border:1.5px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.04);color:rgba(255,255,255,.7);
  font-size:.77rem;font-weight:700;cursor:pointer;
  transition:all .14s;white-space:nowrap;
  text-align:left;
}
.nav-dd-pill:hover{
  border-color:rgba(96,165,250,.45);color:#bfdbfe;
  background:rgba(37,99,235,.15);
  transform:translateY(-1px);
}
.nav-dd-pill.active{
  background:var(--blue);border-color:var(--blue);color:#fff;
  box-shadow:0 2px 10px rgba(37,99,235,.4);
}
.nav-dd-pill.is-district{
  min-width:104px;
  padding:.62rem .78rem;
}
.nav-dd-pill-title{
  display:block;
  max-width:100%;
  overflow:hidden;
  text-overflow:ellipsis;
  font-size:.8rem;
  font-weight:800;
  color:#f8fafc;
}
.nav-dd-pill-meta{
  display:block;
  max-width:100%;
  overflow:hidden;
  text-overflow:ellipsis;
  font-size:.66rem;
  font-weight:700;
  color:rgba(191,219,254,.72);
}
.nav-dd-pill.active .nav-dd-pill-meta{color:rgba(255,255,255,.82)}
.page-agency .nav-dd-pill:hover{
  border-color:rgba(168,85,247,.45);
  color:#f3e8ff;
  background:rgba(124,58,237,.16);
}
.page-agency .nav-dd-pill-meta{color:rgba(233,213,255,.74)}
.nav-dd-empty{
  width:100%;
  padding:.9rem .95rem;
  border-radius:16px;
  border:1px dashed rgba(148,163,184,.26);
  background:rgba(15,23,42,.16);
  color:rgba(226,232,240,.72);
  font-size:.77rem;
  line-height:1.6;
}
.nav-dd-empty strong{
  display:block;
  margin-bottom:.2rem;
  color:#f8fafc;
  font-size:.8rem;
  font-weight:800;
}
/* Ajans teması için mor aktif pill */
.page-agency .nav-dd-pill.active{
  background:linear-gradient(135deg,#7c3aed,#a855f7);
  border-color:#7c3aed;
  box-shadow:0 2px 10px rgba(124,58,237,.4);
}
.page-agency .nav-loc-btn.has-city,.page-agency .nav-loc-btn.open{
  background:rgba(124,58,237,.25);
  border-color:rgba(168,85,247,.5);
  box-shadow:0 0 0 3px rgba(124,58,237,.15);
}
.page-agency .nav-loc-btn.needs-district{
  background:rgba(245,158,11,.2);
  border-color:rgba(251,191,36,.44);
  box-shadow:0 0 0 3px rgba(245,158,11,.14);
}
.page-agency .nav-loc-btn.needs-district.open{
  background:rgba(245,158,11,.24);
  border-color:rgba(251,191,36,.52);
  box-shadow:0 0 0 3px rgba(245,158,11,.18);
}

/* ===== UTILITY CLASSES ===== */
.glass{
  background:rgba(255,255,255,.82);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border:1px solid rgba(255,255,255,.2);
}
.premium-card{
  background:var(--surface);
  border-radius:var(--r);
  border:1px solid var(--border);
  box-shadow:0 4px 16px rgba(0,0,0,.08);
  transition:all .2s;
}
.premium-card:hover{
  transform:translateY(-2px);
  box-shadow:0 12px 32px rgba(0,0,0,.12);
  border-color:#d1d5db;
}
.gradient-text{
  background:linear-gradient(135deg,var(--blue),#3b82f6);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}
.skeleton{
  display:inline-block;
  background:linear-gradient(90deg,var(--s2) 0%,var(--border) 50%,var(--s2) 100%);
  background-size:200% 100%;
  animation:skeleton-pulse 2s infinite;
  border-radius:var(--r-sm);
}
@keyframes skeleton-pulse{
  0%{background-position:200% 0}
  100%{background-position:-200% 0}
}
.DropTarget{outline:2px dashed var(--blue);outline-offset:2px;border-radius:var(--r)}

@media(max-width:640px){
  .nav-dd-header{
    flex-direction:column;
    align-items:flex-start;
  }
  .nav-dd-clear{
    width:100%;
    justify-content:center;
  }
  .nav-dd-overview{
    flex-direction:column;
    gap:.8rem;
  }
  .nav-dd-stats{
    width:100%;
    justify-content:flex-start;
  }
  .nav-dd-stat{
    flex:1 1 calc(50% - .25rem);
    min-width:0;
  }
  .nav-dd-pill,
  .nav-dd-pill.is-district{
    flex:1 1 calc(50% - .25rem);
    min-width:0;
  }
}
.admin-chip{
  background:linear-gradient(135deg,#7c3aed,#a855f7);
  color:#fff;font-size:.65rem;font-weight:700;
  padding:.2rem .55rem;border-radius:100px;
  letter-spacing:.4px;text-transform:uppercase;
}

/* ===== BUTTONS ===== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.45rem;
  padding:.6rem 1.25rem;border-radius:var(--r-sm);
  font-size:.875rem;font-weight:700;border:none;outline:none;
  transition:all .18s ease;white-space:nowrap;min-height:44px;
  position:relative;user-select:none;-webkit-tap-highlight-color:transparent;
}
.btn:disabled{opacity:.45;cursor:not-allowed}
.btn:active:not(:disabled){transform:translateY(1px);filter:brightness(.96)}
.btn-primary{
  background:linear-gradient(135deg,var(--blue) 0%,#3b82f6 100%);
  color:#fff;box-shadow:0 4px 16px rgba(37,99,235,.35);
}
.btn-primary:hover:not(:disabled){
  background:linear-gradient(135deg,#1d4ed8 0%,#2563eb 100%);
  transform:translateY(-2px);box-shadow:0 8px 28px rgba(37,99,235,.45);
}
.btn-ghost{
  background:rgba(255,255,255,.08);color:#fff;border:1px solid rgba(255,255,255,.12);
  box-shadow:0 0 0 0 rgba(255,255,255,.1);
  backdrop-filter:blur(4px);transition:all .18s ease;
}
.btn-ghost:hover:not(:disabled){
  background:rgba(255,255,255,.15);border-color:rgba(255,255,255,.25);
  box-shadow:0 0 16px rgba(255,255,255,.15);
}
.btn-outline{
  background:transparent;color:var(--blue);border:2px solid var(--blue);
  transition:all .18s ease;
}
.btn-outline:hover:not(:disabled){
  background:var(--blue);color:#fff;
  box-shadow:0 4px 14px rgba(37,99,235,.35);transform:translateY(-1px);
}
.btn-danger{
  background:linear-gradient(135deg,var(--bad) 0%,#ef4444 100%);
  color:#fff;box-shadow:0 4px 16px rgba(220,38,38,.35);
}
.btn-danger:hover:not(:disabled){
  background:linear-gradient(135deg,#b91c1c 0%,#dc2626 100%);
  transform:translateY(-2px);box-shadow:0 8px 28px rgba(220,38,38,.45);
}
.btn-success{
  background:linear-gradient(135deg,var(--ok) 0%,#10b981 100%);
  color:#fff;box-shadow:0 4px 16px rgba(5,150,105,.35);
}
.btn-success:hover:not(:disabled){
  background:linear-gradient(135deg,#047857 0%,#059669 100%);
  transform:translateY(-2px);box-shadow:0 8px 28px rgba(5,150,105,.45);
}
.btn-warning{
  background:linear-gradient(135deg,var(--warn) 0%,#f59e0b 100%);
  color:#fff;box-shadow:0 4px 16px rgba(217,119,6,.35);
}
.btn-warning:hover:not(:disabled){
  background:linear-gradient(135deg,#b45309 0%,#d97706 100%);
  transform:translateY(-2px);box-shadow:0 8px 28px rgba(217,119,6,.45);
}
.btn-sm{padding:.38rem .85rem;font-size:.8rem;min-height:40px}
.btn-lg{padding:.8rem 1.75rem;font-size:1rem;min-height:48px}
.btn-xl{padding:1rem 2.25rem;font-size:1.05rem;border-radius:var(--r);min-height:52px}
.btn-block{width:100%}

/* ===== FORMS ===== */
.form-group{margin-bottom:1.25rem}
.form-label{
  display:block;font-size:.75rem;font-weight:700;color:var(--tx2);
  margin-bottom:.6rem;text-transform:uppercase;letter-spacing:.4px;
}
.form-control{
  width:100%;padding:.75rem 1rem;min-height:44px;
  border:1.5px solid var(--border);border-radius:var(--r-sm);
  font-size:.93rem;color:var(--tx);background:var(--surface);
  transition:border-color .18s,box-shadow .18s,background .18s;outline:none;
  -webkit-tap-highlight-color:transparent;
}
.form-control:hover:not(:focus){
  border-color:#cbd5e1;background:var(--s2);
}
.form-control:focus{
  border-color:var(--blue);
  box-shadow:0 0 0 3px rgba(37,99,235,.15),inset 0 1px 2px rgba(37,99,235,.08);
  background:var(--surface);
}
.form-control[readonly]{
  background:var(--bg);color:var(--tx2);cursor:default;border-color:var(--border);
}
.form-control::placeholder{color:var(--tx3);font-weight:500}
textarea.form-control{resize:vertical;min-height:100px;padding:1rem}
select.form-control{padding-right:2.5rem;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%234a5568' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3E%3C/svg%3E");background-position:right .75rem center;background-repeat:no-repeat;background-size:1.5em 1.5em;padding-right:2.5rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}

/* ===== CARDS ===== */
.card{
  background:var(--surface);border-radius:var(--r);
  box-shadow:var(--sh1);border:1px solid var(--border);
  transition:transform .2s,box-shadow .2s,border-color .2s;
}
.card:hover{transform:translateY(-2px);box-shadow:var(--sh2);border-color:#d1d5db}
.card-header{
  padding:1.25rem 1.5rem;border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  background:linear-gradient(to right,transparent,rgba(96,165,250,.04));
}
.card-body{padding:1.5rem}
.card-footer{padding:1rem 1.5rem;border-top:1px solid var(--border);background:var(--s2)}

/* ===== STAT CARDS ===== */
.stat-card{
  background:var(--surface);border-radius:var(--r);
  padding:1.5rem;border:1px solid var(--border);box-shadow:var(--sh1);
  display:flex;align-items:flex-start;gap:1rem;
  transition:transform .2s,box-shadow .2s;
}
.stat-card:hover{transform:translateY(-2px);box-shadow:var(--sh2)}
.stat-icon{
  width:52px;height:52px;border-radius:var(--r-sm);
  display:flex;align-items:center;justify-content:center;font-size:1.4rem;flex-shrink:0;
}
.stat-label{font-size:.72rem;color:var(--tx3);font-weight:700;text-transform:uppercase;letter-spacing:.5px}
.stat-value{font-size:2rem;font-weight:900;color:var(--tx);line-height:1.1;margin-top:.2rem}

/* ===== BADGES ===== */
.badge{
  display:inline-flex;align-items:center;gap:.3rem;
  padding:.22rem .65rem;border-radius:100px;
  font-size:.72rem;font-weight:700;letter-spacing:.3px;
}
.badge-available{background:var(--ok-bg);color:var(--ok);border:1px solid var(--ok-b)}
.badge-pending{background:var(--warn-bg);color:var(--warn);border:1px solid var(--warn-b)}
.badge-occupied{background:var(--bad-bg);color:var(--bad);border:1px solid var(--bad-b)}
.badge-approved{background:#ecfdf5;color:#059669;border:1px solid #6ee7b7}
.badge-rejected{background:#fff1f2;color:#dc2626;border:1px solid #fca5a5}
.badge-draft{background:#f8fafc;color:#64748b;border:1px solid #cbd5e1}
.badge-cancelled{background:#f1f5f9;color:#94a3b8;border:1px solid #e2e8f0}

/* ===========================
   BILLBOARD CARD - PREMIUM
   =========================== */
.billboard-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(210px,1fr));
  gap:1.5rem;
}
.clp-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(115px,1fr));
  gap:1.25rem;
}

.bb-card{
  display:flex;flex-direction:column;align-items:center;
  cursor:pointer;
  user-select:none;
}
.bb-card.locked{cursor:not-allowed}
.bb-card.locked .bb-structure{opacity:.65}
.bb-card:not(.locked){cursor:pointer}

/* Billboard yapısı */
.bb-structure{
  display:flex;flex-direction:column;align-items:center;width:100%;
  filter:drop-shadow(0 10px 28px rgba(0,0,0,.3));
  transition:filter .38s, transform .42s cubic-bezier(.22,1,.36,1);
  will-change:transform;
}
.bb-card:hover .bb-structure{
  transform:translateY(-8px);
  filter:drop-shadow(0 24px 44px rgba(0,0,0,.38));
}
.bb-card.locked .bb-structure{opacity:.6}
.bb-structure.is-billboard-plus .bb-top-bar{width:96%}
.bb-structure.is-reklam-panosu{gap:0}
.bb-plus-panels{
  width:100%;
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:6px;
}

/* ── Üst yatay silindirik boru ── */
.bb-top-bar{
  width:88%;
  height:clamp(13px,2.2vw,20px);
  position:relative;z-index:4;flex-shrink:0;
  /* Güçlü silindirik alüminyum gradyanı */
  background:linear-gradient(to bottom,
    #ffffff 0%,
    #e8f0f6 6%,
    #ccdae6 16%,
    #a6bece 30%,
    #8aacbe 44%,
    #7498ac 52%,
    #8aacbe 60%,
    #a8c2d0 74%,
    #ccdae6 88%,
    #e8f0f6 96%,
    #f8fbfd 100%
  );
  border-radius:999px;
  box-shadow:
    0 6px 18px rgba(0,0,0,.5),
    0 2px 5px rgba(0,0,0,.35),
    inset 0 3px 7px rgba(255,255,255,.75),
    inset 0 -3px 7px rgba(0,0,0,.42),
    inset 0 1px 2px rgba(255,255,255,.9);
}
/* Boru uçlarından sarkan direk bağlantı braketi */
.bb-top-bar::before,
.bb-top-bar::after{
  content:'';
  position:absolute;
  top:52%;
  width:clamp(13px,2.2vw,20px);
  height:clamp(9px,1.5vw,14px);
  background:linear-gradient(to bottom,
    #b2c6d4 0%,
    #98b4c4 45%,
    #7a9eb2 100%
  );
  border-radius:0 0 5px 5px;
  box-shadow:
    inset 0 -1px 3px rgba(0,0,0,.28),
    inset 1px 0 2px rgba(255,255,255,.2),
    0 3px 6px rgba(0,0,0,.35);
}
.bb-top-bar::before{left:0}
.bb-top-bar::after{right:0}

.bb-rp-light-rail{
  width:102%;
  height:clamp(9px,1.5vw,13px);
  position:relative;
  z-index:5;
  border-radius:999px;
  background:linear-gradient(to bottom,
    #f8fbfd 0%,
    #dce7ef 18%,
    #b8cad7 46%,
    #90a8b9 70%,
    #dce7ef 100%
  );
  box-shadow:
    0 5px 16px rgba(0,0,0,.38),
    inset 0 2px 4px rgba(255,255,255,.72),
    inset 0 -2px 4px rgba(0,0,0,.24);
}
.bb-rp-light-rail::after{
  content:'';
  position:absolute;
  left:8%;
  right:8%;
  top:100%;
  height:22px;
  background:radial-gradient(ellipse 50% 100% at 50% 0%,rgba(255,236,184,.34),rgba(255,236,184,0) 70%);
  pointer-events:none;
}
.bb-rp-light-posts{
  width:78%;
  display:flex;
  justify-content:space-between;
  padding:0 4%;
  margin-top:-1px;
  position:relative;
  z-index:4;
}
.bb-rp-light-post{
  width:clamp(4px,.75vw,7px);
  height:clamp(12px,2vw,18px);
  border-radius:2px;
  background:linear-gradient(to right,#7b92a4,#d7e3eb,#7b92a4);
  box-shadow:0 2px 6px rgba(0,0,0,.26);
}

/* ── Panel — koyu antrasit metal çerçeve ── */
.bb-panel{
  width:100%;
  aspect-ratio:5/2;
  border-radius:2px;
  /* Referanstaki koyu antrasit RAL 7016 benzeri çerçeve */
  border:7px solid #3a4855;
  position:relative;overflow:hidden;
  transition:box-shadow .3s, border-color .22s;
  /* Çerçevenin metalik ön yüz derinliği */
  box-shadow:
    inset 0 2px 0 rgba(255,255,255,.11),
    inset 0 -2px 0 rgba(0,0,0,.25),
    inset 2px 0 0 rgba(255,255,255,.07),
    inset -2px 0 0 rgba(0,0,0,.18),
    0 4px 14px rgba(0,0,0,.22);
}
.bb-structure.is-billboard-plus .bb-panel{
  aspect-ratio:4/3;
}
.bb-structure.is-reklam-panosu .bb-panel{
  width:94%;
  aspect-ratio:4.9/1.75;
  border-width:6px;
  border-radius:4px;
  box-shadow:
    inset 0 2px 0 rgba(255,255,255,.12),
    inset 0 -2px 0 rgba(0,0,0,.24),
    0 8px 20px rgba(0,0,0,.18);
}
/* Panel yüzeyi — hafif köşe yansıma + alt derinleşme */
.bb-panel::before{
  content:'';position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    linear-gradient(138deg,
      rgba(255,255,255,.28) 0%,
      rgba(255,255,255,.1) 22%,
      transparent 48%
    ),
    linear-gradient(to bottom,
      transparent 55%,
      rgba(0,0,0,.08) 100%
    );
}
/* Panel iç kenarlık ince ışık çizgisi */
.bb-panel::after{
  content:'';position:absolute;inset:3px;z-index:2;pointer-events:none;
  border:1px solid rgba(255,255,255,.28);
  border-radius:1px;
  box-shadow:inset 0 1px 2px rgba(255,255,255,.22);
}

/* Durum bazlı panel yüzey rengi — çerçeve sabit antrasit */
.bb-panel.available{
  background:linear-gradient(155deg,#eefbf3 0%,#d4f7e2 55%,#b8efd0 100%);
  border-color:#3a4855;
  box-shadow:
    inset 0 2px 0 rgba(255,255,255,.14),inset 0 -2px 0 rgba(0,0,0,.25),
    inset 2px 0 0 rgba(255,255,255,.08),inset -2px 0 0 rgba(0,0,0,.18),
    0 5px 16px rgba(0,0,0,.18);
}
.bb-panel.pending{
  background:linear-gradient(155deg,#fefff0 0%,#fdf8cc 55%,#faeea8 100%);
  border-color:#3a4855;
  box-shadow:
    inset 0 2px 0 rgba(255,255,255,.14),inset 0 -2px 0 rgba(0,0,0,.25),
    inset 2px 0 0 rgba(255,255,255,.08),inset -2px 0 0 rgba(0,0,0,.18),
    0 5px 16px rgba(0,0,0,.18);
}
.bb-panel.occupied{
  background:linear-gradient(155deg,#fff5f5 0%,#fde4e4 55%,#facccc 100%);
  border-color:#3a4855;
  box-shadow:
    inset 0 2px 0 rgba(255,255,255,.14),inset 0 -2px 0 rgba(0,0,0,.25),
    inset 2px 0 0 rgba(255,255,255,.08),inset -2px 0 0 rgba(0,0,0,.18),
    0 5px 16px rgba(0,0,0,.18);
}
.bb-panel.selected{
  background:linear-gradient(155deg,#f0f5ff 0%,#dde9ff 55%,#c4d8ff 100%);
  border-color:#2563eb;
  box-shadow:
    inset 0 2px 0 rgba(255,255,255,.14),inset 0 -2px 0 rgba(0,0,0,.22),
    inset 2px 0 0 rgba(255,255,255,.08),inset -2px 0 0 rgba(0,0,0,.16),
    0 5px 16px rgba(37,99,235,.22),
    0 0 0 3px rgba(37,99,235,.26);
}
.bb-panel.no-week{
  background:linear-gradient(155deg,#f4f6f9,#eaecf2);
  border-color:#3a4855;
  box-shadow:
    inset 0 2px 0 rgba(255,255,255,.1),inset 0 -2px 0 rgba(0,0,0,.18),
    0 3px 10px rgba(0,0,0,.12);
  cursor:default;
}

/* Üst durum çizgisi */
.bb-stripe{
  position:absolute;top:0;left:0;right:0;
  height:4px;z-index:3;
}
.available .bb-stripe{background:linear-gradient(to right,var(--ok),#34d399)}
.pending   .bb-stripe{background:linear-gradient(to right,var(--warn),#fbbf24)}
.occupied  .bb-stripe{background:linear-gradient(to right,var(--bad),#f87171)}
.selected  .bb-stripe{background:linear-gradient(to right,var(--sel),#60a5fa)}

/* Panel içeriği */
.bb-panel-body{
  position:absolute;inset:0;z-index:4;
  display:flex;flex-direction:column;
  justify-content:space-between;
  padding:.55rem .7rem .45rem;
}
.bb-structure.is-billboard-plus .bb-panel-body{
  padding:.48rem .48rem .4rem;
}
.bb-structure.is-reklam-panosu .bb-panel-body{
  padding:.48rem .62rem .38rem;
}
.bb-loc-name{
  font-size:.68rem;font-weight:800;color:rgba(0,0,0,.58);
  line-height:1.2;text-transform:uppercase;letter-spacing:.3px;
  max-width:100%;overflow:hidden;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;
  text-shadow:0 1px 2px rgba(255,255,255,.75);
}
.bb-structure.is-billboard-plus .bb-loc-name{
  font-size:.6rem;
  line-height:1.18;
}
.bb-panel-copy-spacer{
  min-height:1.8rem;
}
.bb-plus-copy{
  font-size:.58rem;
  font-weight:900;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:rgba(0,0,0,.54);
  line-height:1.2;
  text-shadow:0 1px 2px rgba(255,255,255,.72);
}
.bb-bottom{display:flex;align-items:center;justify-content:space-between;gap:.25rem}
.bb-face-label{
  font-size:.65rem;font-weight:700;color:rgba(0,0,0,.48);
  background:rgba(255,255,255,.62);
  padding:.1rem .35rem;border-radius:4px;
  backdrop-filter:blur(2px);
}
.bb-face-label-secondary{
  color:#35506b;
}
.bb-status-pill{
  display:inline-flex;align-items:center;gap:.25rem;
  font-size:.6rem;font-weight:800;text-transform:uppercase;letter-spacing:.5px;
  padding:.15rem .45rem;border-radius:100px;
  background:rgba(255,255,255,.68);backdrop-filter:blur(4px);
  max-width:100%;overflow:hidden;
}
.bb-status-pill .bb-status-dot{flex-shrink:0}
.available .bb-status-pill{color:var(--ok)}
.pending   .bb-status-pill{color:var(--warn)}
.occupied  .bb-status-pill{color:var(--bad)}
.selected  .bb-status-pill{color:var(--sel)}
.no-week   .bb-status-pill{color:var(--tx3)}

.bb-status-dot{width:5px;height:5px;border-radius:50%}
.available .bb-status-dot{background:var(--ok)}
.pending   .bb-status-dot{background:var(--warn);animation:blink 1.8s ease infinite}
.occupied  .bb-status-dot{background:var(--bad)}
.selected  .bb-status-dot{background:var(--sel)}

/* Seçim işareti */
.bb-check{
  position:absolute;top:6px;right:8px;z-index:5;
  background:var(--sel);color:#fff;
  width:20px;height:20px;border-radius:50%;
  display:none;align-items:center;justify-content:center;
  font-size:.75rem;font-weight:900;
  box-shadow:0 2px 10px rgba(37,99,235,.5);
}
.selected .bb-check{display:flex}

/* ── Direkler — gümüş alüminyum kare profil ── */
.bb-supports{
  display:flex;justify-content:space-between;
  width:88%;
  position:relative;
}
.bb-supports-plus{
  width:96%;
  justify-content:space-between;
  padding:0 8%;
}
.bb-supports-reklam-panosu{
  width:78%;
  justify-content:space-between;
  padding:0 4%;
  margin-top:-1px;
}
.bb-supports::before{display:none}
.bb-pole{
  position:relative;
  width:clamp(13px,2.2vw,18px);
  height:clamp(40px,6.5vw,66px);
  /* Kare/dikdörtgen alüminyum profil — referansla uyumlu açık gümüş */
  background:linear-gradient(to right,
    #8ea4b4 0%,
    #a8bece 10%,
    #c0d2de 22%,
    #d6e4ee 36%,
    #e6f0f6 46%,
    #f0f6fa 50%,
    #e4eef6 54%,
    #ccdae6 64%,
    #b4c8d6 76%,
    #a0b6c6 88%,
    #8ea4b4 100%
  );
  border-radius:2px 2px 2px 2px;
  box-shadow:
    3px 0 10px rgba(0,0,0,.4),
    -1px 0 4px rgba(0,0,0,.22),
    inset 0 1px 0 rgba(255,255,255,.55),
    inset 0 -1px 0 rgba(0,0,0,.25);
  flex-shrink:0;
}
/* Direk alt taban flanşı */
.bb-pole::after{
  content:'';
  position:absolute;
  bottom:-1px;left:-4px;right:-4px;
  height:7px;
  background:linear-gradient(to right,
    #7a96a8 0%,
    #9ab4c4 28%,
    #b8cede 50%,
    #9ab4c4 72%,
    #7a96a8 100%
  );
  border-radius:1px 1px 3px 3px;
  box-shadow:0 4px 10px rgba(0,0,0,.48),inset 0 1px 0 rgba(255,255,255,.25);
}
.bb-pole::before{display:none}
.bb-supports-reklam-panosu .bb-pole{
  height:clamp(46px,7vw,72px);
  width:clamp(12px,1.9vw,16px);
}

/* ── Taban ── */
.bb-base{
  position:relative;
  width:62%;height:12px;
  background:linear-gradient(to right,
    #8090a0 0%,
    #9eaebe 14%,
    #c0d0de 32%,
    #dce8f2 50%,
    #bcccd8 68%,
    #9aaebe 86%,
    #8090a0 100%
  );
  border-radius:3px 3px 5px 5px;
  box-shadow:
    0 7px 20px rgba(0,0,0,.52),
    0 1px 0 rgba(255,255,255,.32) inset,
    0 -1px 0 rgba(0,0,0,.38) inset;
  flex-shrink:0;
}
.bb-structure.is-billboard-plus .bb-base{
  width:74%;
}
.bb-base::after{
  content:'';
  position:absolute;
  bottom:-10px;left:50%;
  transform:translateX(-50%);
  width:180%;height:20px;
  background:radial-gradient(ellipse 80% 50% at 50% 0%,rgba(0,0,0,.3) 0%,transparent 100%);
  pointer-events:none;
}
.bb-footings{
  width:82%;
  display:flex;
  justify-content:space-between;
  padding:0 2%;
  position:relative;
}
.bb-footing{
  position:relative;
  width:clamp(34px,8vw,52px);
  height:clamp(14px,2.4vw,18px);
  border-radius:3px 3px 6px 6px;
  background:linear-gradient(to bottom,#d9dde2 0%,#b8bfc8 54%,#8b939d 100%);
  box-shadow:
    0 8px 14px rgba(0,0,0,.22),
    inset 0 1px 0 rgba(255,255,255,.48),
    inset 0 -1px 0 rgba(0,0,0,.15);
}
.bb-footing::after{
  content:'';
  position:absolute;
  left:50%;
  transform:translateX(-50%);
  bottom:-10px;
  width:180%;
  height:18px;
  background:radial-gradient(ellipse 50% 55% at 50% 0%,rgba(0,0,0,.22) 0%,transparent 100%);
  pointer-events:none;
}

/* Alt bilgi kartı */
.bb-info{
  width:100%;margin-top:.55rem;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--r-sm);
  padding:.55rem .7rem;
  text-align:center;
  transition:all .2s;
  box-shadow:var(--sh0);
  display:flex;flex-direction:column;gap:.3rem;align-items:center;
}
.bb-card:hover .bb-info{
  border-color:var(--blue);
  box-shadow:0 0 0 3px rgba(37,99,235,.08);
}
.bb-info-status{
  display:inline-flex;align-items:center;gap:.3rem;
  font-size:.65rem;font-weight:800;text-transform:uppercase;letter-spacing:.45px;
  color:var(--tx2);
}
.bb-info-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.bb-info-dot.available{background:var(--ok)}
.bb-info-dot.pending{background:var(--warn)}
.bb-info-dot.occupied{background:var(--bad)}
.bb-info-dot.selected{background:var(--sel)}
.bb-info-dot.no-week{background:var(--tx3)}
/* Eski tenant satırı (artık kullanılmıyor, geriye dönük uyumluluk) */
.bb-info-tenant{
  font-size:.68rem;font-weight:700;color:var(--bad);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  max-width:100%;
}
/* Dolu olduğunda info-status içindeki firma adı */
.bb-info-tenant-name{
  color:var(--bad);font-weight:800;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  max-width:120px;display:inline-block;vertical-align:bottom;
}
.bb-info-model{
  font-size:.68rem;
  font-weight:700;
  color:var(--tx3);
  letter-spacing:.02em;
}
.bb-info-price{
  font-size:.88rem;font-weight:800;color:var(--blue);
}
.bb-info-week{font-size:.7rem;font-weight:500;color:var(--tx3)}

/* ===== LOCATION GROUP — premium çerçeve ===== */
.location-group{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  overflow:hidden;
  box-shadow:0 2px 8px rgba(0,0,0,.05),0 0 0 0 transparent;
  transition:box-shadow .2s;
}
.location-group + .location-group{
  margin-top:1.1rem;
}
/* Eski separator tamamen kaldırıldı */
.location-group + .location-group::before{ display:none }

.location-header{
  display:flex;align-items:center;gap:.85rem;
  padding:.85rem 1.1rem;
  background:var(--surface);
  border-bottom:1px solid var(--border);
  position:relative;
}
/* Sol vurgu çizgisi */
.location-header::after{
  content:'';
  position:absolute;left:0;top:0;bottom:0;width:3px;
  background:linear-gradient(180deg,#60a5fa,#2563eb);
  border-radius:0 2px 2px 0;
}
/* Sağ üst köşe dekor dot — kaldırıldı */
.location-header::before{ display:none }

.loc-index{
  width:30px;height:30px;min-width:30px;
  background:var(--sel-bg);
  color:var(--blue);
  font-size:.68rem;font-weight:900;letter-spacing:.02em;
  border-radius:var(--r-sm);
  border:1px solid var(--sel-b);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.loc-num{display:none}
.loc-title{flex:1;min-width:0}
.loc-title h4{
  font-size:.88rem;font-weight:800;color:var(--tx);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  letter-spacing:-.01em;
}
.loc-title p{font-size:.68rem;color:var(--tx3);margin-top:.12rem;letter-spacing:.01em}
.loc-badges{display:flex;gap:.3rem;flex-wrap:nowrap;flex-shrink:0;align-items:center}
/* Street view button */
.btn-sv{
  display:inline-flex;align-items:center;gap:.28rem;
  padding:.28rem .6rem;font-size:.68rem;font-weight:700;
  border:1px solid var(--border);border-radius:var(--r-sm);
  background:var(--bg);color:var(--tx3);cursor:pointer;
  transition:all .18s;white-space:nowrap;text-decoration:none;flex-shrink:0;
}
.btn-sv:hover{border-color:var(--blue);color:var(--blue);background:rgba(37,99,235,.05)}
.btn-sv-fallback{opacity:.92}
.btn-sv-icon{font-size:.78rem;line-height:1;flex-shrink:0}
.btn-sv-label{font-size:inherit;line-height:1}

/* Billboard/CLP grid — çerçeve içi zemin */
.location-group .billboard-grid,
.location-group .clp-grid{
  padding:.85rem;
  background:var(--s2);
}

/* CLP 2-sütun lokasyon düzeni — her ekran boyutunda 2 kolon */
.locs-clp-2col{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:1rem;
}
.locs-clp-2col .location-group{margin-bottom:0}

/* Dar kolonlarda header kompakt */
.locs-clp-2col .location-header{
  padding:.6rem .75rem;
  gap:.5rem;
  flex-wrap:wrap;
}
.locs-clp-2col .loc-index{
  width:24px;height:24px;min-width:24px;
  font-size:.58rem;border-radius:6px;
}
.locs-clp-2col .loc-title h4{font-size:.78rem}
.locs-clp-2col .loc-title p{font-size:.6rem}
.locs-clp-2col .traffic-widget{display:none}
.locs-clp-2col .loc-badges{
  order:3;flex-basis:100%;gap:.2rem;
  margin-left:calc(24px + .5rem);
  flex-wrap:wrap;
}
.locs-clp-2col .loc-badges .badge{font-size:.57rem;padding:.12rem .38rem}
.locs-clp-2col .btn-sv{font-size:.6rem;padding:.18rem .42rem}

/* CLP grid — 2 kart yan yana */
.locs-clp-2col .clp-grid{
  grid-template-columns:repeat(2,1fr);
  gap:.6rem;
  padding:.6rem;
}

/* CLP kart — 2-col kompakt */
.locs-clp-2col .clp-pole{height:clamp(14px,2.5vw,24px)}
.locs-clp-2col .clp-foot{width:55%;height:6px}
/* Şekil üstü: sadece konum adı + durum; etiketler gizli */
.locs-clp-2col .clp-panel-body{padding:.3rem .34rem .26rem}
.locs-clp-2col .clp-type-badge{display:none}
.locs-clp-2col .clp-loc-name{font-size:.5rem;-webkit-line-clamp:3;letter-spacing:.1px}
.locs-clp-2col .clp-face-label{display:none}
.locs-clp-2col .clp-status-pill{
  font-size:.42rem;padding:.07rem .22rem;letter-spacing:.15px;
  flex-shrink:0;width:100%;text-align:center;justify-content:center;
}
/* Info bölümü */
.locs-clp-2col .clp-info{padding:.28rem .34rem;gap:.12rem;margin-top:.2rem}
.locs-clp-2col .clp-info>*{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}
.locs-clp-2col .clp-info-face{font-size:.66rem}
.locs-clp-2col .clp-info-price{font-size:.72rem}
.locs-clp-2col .clp-info-loc,.locs-clp-2col .clp-info-type,
.locs-clp-2col .clp-info-size,.locs-clp-2col .clp-info-status,
.locs-clp-2col .clp-info-tenant{font-size:.52rem}

@media(max-width:980px){
  .locs-clp-2col{grid-template-columns:1fr}
}

/* ===== ŞEHİR / İLÇE FİLTRE ÇUBUĞU ===== */
.city-filter-wrap{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--r);
  padding:.85rem 1.25rem;
  margin-bottom:1rem;
  display:flex;flex-direction:column;gap:.6rem;
  box-shadow:var(--sh0);
}
.city-filter-row{
  display:flex;align-items:center;gap:.6rem;flex-wrap:wrap;
}
.city-filter-row .filter-label{
  font-size:.72rem;font-weight:700;color:var(--tx3);
  text-transform:uppercase;letter-spacing:.4px;
  white-space:nowrap;min-width:60px;
}
.filter-pill-group{
  display:flex;gap:.35rem;flex-wrap:wrap;
}
.filter-pill{
  display:inline-flex;align-items:center;
  padding:.3rem .75rem;border-radius:100px;
  border:1.5px solid var(--border-d);
  background:var(--bg);color:var(--tx2);
  font-size:.78rem;font-weight:700;
  cursor:pointer;transition:all .15s;white-space:nowrap;
}
.filter-pill:hover{border-color:var(--blue);color:var(--blue);background:rgba(37,99,235,.05)}
.filter-pill.active{
  background:var(--blue);color:#fff;
  border-color:var(--blue);
  box-shadow:0 2px 8px rgba(37,99,235,.28);
}

/* Büyük şehir seçim butonu */
.filter-pill-lg{
  font-size:.92rem;padding:.55rem 1.4rem;border-radius:var(--r-sm);
  font-weight:800;
}

/* Şehir seçim prompt ekranı */
.city-select-prompt{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--r);
  padding:2.5rem 2rem;
  text-align:center;
  box-shadow:var(--sh0);
}
.city-select-icon{font-size:2.6rem;margin-bottom:.75rem}
.city-select-prompt h4{font-size:1.05rem;font-weight:800;color:var(--tx);margin-bottom:.4rem}
.city-select-prompt p{font-size:.86rem;color:var(--tx3);margin-bottom:1.5rem}
.city-prompt-pills{display:flex;flex-wrap:wrap;gap:.65rem;justify-content:center}

/* ===== ŞEHİR BÖLÜM BAŞLIĞI ===== */
.city-section-header{
  display:flex;align-items:center;gap:.75rem;
  margin:1.75rem 0 .85rem;
  padding-bottom:.55rem;
  border-bottom:2px solid var(--border);
}
.city-section-header:first-child{margin-top:0}
.city-section-name{
  font-size:1rem;font-weight:900;color:var(--tx);
  letter-spacing:-.02em;
}

/* Street view modal frame */
.sv-frame{
  width:100%;height:400px;border:none;border-radius:var(--r-sm);
  background:#0f172a;
}

/* ===== BİRLEŞİK KONTROL ÇUBUĞU ===== */
.inventory-toolbar{
  margin-bottom:.9rem;
  padding:.72rem .78rem;
  border:1px solid rgba(37,99,235,.1);
  border-radius:20px;
  background:
    linear-gradient(180deg,rgba(255,255,255,.98),rgba(247,250,252,.98)),
    radial-gradient(circle at top right,rgba(37,99,235,.08),transparent 38%);
  box-shadow:0 14px 26px rgba(15,23,42,.05),inset 0 1px 0 rgba(255,255,255,.88);
}
.inventory-toolbar-head{
  display:none;
}
.inventory-toolbar-copy{
  max-width:760px;
  display:flex;
  align-items:center;
  gap:.55rem;
  flex-wrap:wrap;
}
.inventory-eyebrow{
  display:inline-flex;
  align-items:center;
  gap:.35rem;
  padding:.22rem .48rem;
  border-radius:999px;
  background:rgba(37,99,235,.08);
  border:1px solid rgba(37,99,235,.12);
  font-size:.62rem;
  font-weight:800;
  color:var(--blue);
  text-transform:uppercase;
  letter-spacing:.38px;
}
.inventory-toolbar-copy h3{
  margin-top:0;
  font-size:.86rem;
  font-weight:900;
  color:var(--tx);
  letter-spacing:-.02em;
  line-height:1.2;
}
.inventory-toolbar-copy p{
  display:none;
}
.inventory-compact-row{
  display:grid;
  grid-template-columns:minmax(150px,220px) minmax(0,1fr);
  gap:.5rem;
  align-items:stretch;
}
.inventory-inline-week{
  display:grid;
  grid-template-columns:auto minmax(0,1fr);
  align-items:center;
  gap:.5rem;
  min-width:0;
  padding:.4rem .6rem;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:14px;
  box-shadow:var(--sh0);
  position:relative;
}
.inventory-inline-week .ctrl-label{
  width:auto;
  margin:0;
  flex-shrink:0;
  pointer-events:none;
}
.inventory-inline-week .ctrl-select{
  flex:1 1 auto;
  width:100%;
  border:none;
  background:#fff;
  padding:.28rem .3rem;
  min-width:0;
  box-shadow:none;
  appearance:auto;
  -webkit-appearance:menulist;
  min-height:34px;
  position:relative;
  z-index:1;
}
.inventory-inline-week .ctrl-select:focus{
  box-shadow:none;
}
.inventory-toggle-btn{
  width:100%;
  min-width:0;
  min-height:42px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:.75rem;
  padding:.42rem .68rem;
  border:1px solid var(--border);
  border-radius:14px;
  background:var(--surface);
  color:var(--tx);
  box-shadow:var(--sh0);
  transition:border-color .18s, box-shadow .18s, background .18s;
}
.inventory-toggle-btn:hover{
  border-color:var(--blue);
  background:#fff;
}
.inventory-toggle-btn.active{
  border-color:rgba(37,99,235,.35);
  box-shadow:0 0 0 3px rgba(37,99,235,.08);
}
.inventory-toggle-main{
  display:flex;
  align-items:center;
  gap:.55rem;
  min-width:0;
}
.inventory-toggle-icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:20px;
  height:20px;
  border-radius:8px;
  background:rgba(37,99,235,.08);
  color:var(--blue);
  flex-shrink:0;
}
.inventory-toggle-text{
  font-size:.82rem;
  font-weight:800;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.inventory-toggle-meta{
  display:flex;
  align-items:center;
  gap:.45rem;
  flex-shrink:0;
}
.inventory-toggle-count{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:18px;
  height:18px;
  padding:0 .35rem;
  border-radius:999px;
  background:rgba(37,99,235,.1);
  color:var(--blue);
  font-size:.65rem;
  font-weight:900;
}
.inventory-toggle-caret{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color:var(--tx3);
  transition:transform .18s ease;
}
.inventory-toggle-btn.active .inventory-toggle-caret{
  transform:rotate(180deg);
}
.inventory-panel{
  margin-top:.5rem;
  display:flex;
  flex-direction:column;
  gap:.45rem;
}
.inventory-panel .ctrl-bar{
  margin-bottom:0;
}
.ctrl-bar{
  display:flex;align-items:center;gap:0;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--r);
  box-shadow:0 2px 12px rgba(0,0,0,.06),inset 0 1px 0 rgba(255,255,255,.9);
  margin-bottom:1.75rem;
  overflow:hidden;
  flex-wrap:wrap;
}
.ctrl-section{
  display:flex;align-items:center;gap:.6rem;
  padding:.75rem 1.1rem;
  flex-shrink:0;
}
.ctrl-week{ flex:1;min-width:240px }
.ctrl-search{ flex:1;min-width:160px }
.ctrl-label{
  display:flex;align-items:center;gap:.35rem;
  font-size:.62rem;font-weight:800;color:var(--tx3);
  text-transform:uppercase;letter-spacing:.45px;
  white-space:nowrap;flex-shrink:0;
}
.ctrl-select{
  flex:1;min-width:0;
  padding:.34rem .6rem;
  border:1.5px solid var(--border);border-radius:var(--r-sm);
  font-size:.82rem;font-weight:600;color:var(--tx);
  background:var(--bg);outline:none;cursor:pointer;
  transition:border-color .18s,box-shadow .18s;
  font-family:inherit;
}
.ctrl-select-sm{min-width:110px;flex:none}
.ctrl-select:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.ctrl-input{
  flex:1;min-width:0;
  padding:.34rem .6rem;
  border:1.5px solid var(--border);border-radius:var(--r-sm);
  font-size:.82rem;color:var(--tx);
  background:var(--bg);outline:none;
  transition:border-color .18s,box-shadow .18s;
  font-family:inherit;
}
.ctrl-input:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.ctrl-input::placeholder{color:var(--tx3)}
.ctrl-divider{
  width:1px;height:36px;
  background:var(--border);flex-shrink:0;
  align-self:center;
}
.ctrl-right{
  display:flex;align-items:center;gap:1.25rem;
  padding:.75rem 1.1rem;margin-left:auto;
  flex-shrink:0;flex-wrap:wrap;
}
.ctrl-legend{display:flex;gap:.85rem;flex-wrap:wrap;align-items:center}
.cleg-item{display:flex;align-items:center;gap:.35rem;font-size:.75rem;font-weight:600;color:var(--tx2);white-space:nowrap}
.cleg-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.ctrl-summary{font-size:.78rem;font-weight:700;color:var(--tx3);white-space:nowrap}
.ctrl-bar-advanced,
.ctrl-bar-filters{
  background:transparent;
  border:none;
  box-shadow:none;
  border-radius:0;
  overflow:visible;
  gap:.5rem;
  margin-bottom:0;
}
.ctrl-bar-advanced{margin-bottom:.45rem}
.ctrl-bar-advanced .ctrl-section,
.ctrl-bar-filters .ctrl-section{
  display:flex;
  flex:1 1 150px;
  min-width:150px;
  align-items:flex-start;
  gap:.32rem;
  flex-wrap:wrap;
  padding:.52rem .68rem;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:14px;
  box-shadow:var(--sh0);
}
.ctrl-bar-advanced .ctrl-section.ctrl-search{flex:1.2 1 220px}
.ctrl-bar-advanced .ctrl-section.ctrl-week{flex:1 1 190px}
.ctrl-bar-advanced .ctrl-section.ctrl-sort{flex:.82 1 180px}
.ctrl-bar-filters .ctrl-section.ctrl-action{flex:.62 1 150px}
.ctrl-bar-advanced .ctrl-label,
.ctrl-bar-filters .ctrl-label{
  width:100%;
}
.ctrl-bar-advanced .ctrl-select,
.ctrl-bar-advanced .ctrl-input,
.ctrl-bar-filters .ctrl-select{
  width:100%;
  background:#fff;
}
.ctrl-bar-advanced .ctrl-divider,
.ctrl-bar-filters .ctrl-divider{display:none}
.ctrl-bar-filters .ctrl-right{
  flex:1.15 1 240px;
  min-width:240px;
  margin-left:0;
  padding:.58rem .74rem;
  border-radius:14px;
  background:linear-gradient(135deg,#04111f,#0d203d);
  border:1px solid rgba(96,165,250,.18);
  box-shadow:0 12px 24px rgba(4,17,31,.12);
}
.ctrl-bar-filters .ctrl-right .ctrl-legend{
  gap:.35rem .65rem;
}
.ctrl-bar-filters .ctrl-right .cleg-item{
  color:rgba(255,255,255,.76);
  font-size:.67rem;
}
.ctrl-bar-filters .ctrl-right .ctrl-summary{
  color:rgba(255,255,255,.86);
  white-space:normal;
  line-height:1.35;
  font-size:.72rem;
}
.ctrl-reset{
  width:100%;
  min-height:36px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.4rem;
  padding:.48rem .72rem;
  border-radius:12px;
  border:1px dashed var(--border-d);
  background:rgba(255,255,255,.82);
  color:var(--tx2);
  font-size:.72rem;
  font-weight:800;
  letter-spacing:.01em;
  transition:all .18s;
}
.ctrl-reset:hover{
  border-color:var(--blue);
  color:var(--blue);
  background:#fff;
}
.inventory-surface-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(170px,1fr));
  gap:1rem;
  align-items:flex-start;
}

/* Legacy (admin vb.) */
.week-bar{
  background:var(--surface);border-radius:var(--r);
  padding:1.1rem 1.5rem;
  border:1px solid var(--border);box-shadow:var(--sh0);
  margin-bottom:1.75rem;
  display:flex;align-items:center;gap:1rem;flex-wrap:wrap;
}
.week-bar label{font-size:.78rem;font-weight:700;color:var(--tx2);text-transform:uppercase;letter-spacing:.4px;white-space:nowrap}
.week-select{flex:1;min-width:240px;padding:.6rem 1rem;border:1.5px solid var(--border);border-radius:var(--r-sm);font-size:.9rem;font-weight:600;color:var(--tx);background:var(--surface);outline:none;cursor:pointer;transition:border-color .18s;font-family:inherit}
.week-select:focus{border-color:var(--blue)}
.legend{display:flex;gap:1.25rem;flex-wrap:wrap;align-items:center}
.legend-item{display:flex;align-items:center;gap:.4rem;font-size:.78rem;font-weight:600;color:var(--tx2)}
.legend-dot{width:9px;height:9px;border-radius:50%}
.legend-dot.a{background:var(--ok)}.legend-dot.p{background:var(--warn)}.legend-dot.o{background:var(--bad)}.legend-dot.s{background:var(--sel)}

/* ===== SCHEDULE TABS ===== */
.sched-tabs{
  display:flex;gap:.5rem;
  margin-bottom:1.5rem;
  border-bottom:2px solid var(--border);
  padding-bottom:0;
}
.sched-tab{
  display:flex;align-items:center;gap:.45rem;
  padding:.6rem 1.25rem;
  border:none;background:none;
  font-size:.88rem;font-weight:700;color:var(--tx3);
  cursor:pointer;border-radius:var(--r-sm) var(--r-sm) 0 0;
  border-bottom:3px solid transparent;
  margin-bottom:-2px;
  transition:color .15s,border-color .15s,background .15s;
  white-space:nowrap;
}
.sched-tab:hover{color:var(--tx);background:var(--s2)}
.sched-tab.active{
  color:var(--blue);
  border-bottom-color:var(--blue);
  background:rgba(37,99,235,.05);
}
.sched-tab-icon{font-size:.9rem}
.sched-tab-badge{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:20px;height:18px;padding:0 5px;
  border-radius:100px;
  font-size:.65rem;font-weight:800;
  background:var(--s2);color:var(--tx3);
  transition:background .15s,color .15s;
}
.sched-tab.active .sched-tab-badge{
  background:rgba(37,99,235,.12);color:var(--blue);
}

/* ===== FILTER BAR (admin) ===== */
.filter-bar{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:.85rem 1.25rem;margin-bottom:1.5rem;display:flex;gap:.85rem;flex-wrap:wrap;align-items:center}
.filter-bar input,.filter-bar select{padding:.45rem .85rem;border:1.5px solid var(--border);border-radius:var(--r-sm);font-size:.84rem;outline:none;transition:border-color .18s;font-family:inherit}
.filter-bar input:focus,.filter-bar select:focus{border-color:var(--blue)}
.filter-label{font-size:.75rem;font-weight:700;color:var(--tx3);text-transform:uppercase;letter-spacing:.3px}

@media(max-width:768px){
  .inventory-toolbar{
    padding:.62rem .65rem;
    border-radius:16px;
    margin-bottom:1rem;
  }
  .inventory-compact-row{
    grid-template-columns:minmax(120px,1fr) minmax(0,1.15fr);
    gap:.45rem;
  }
  .inventory-inline-week{
    padding:.34rem .52rem;
    border-radius:12px;
  }
  .inventory-inline-week .ctrl-select{
    min-height:36px;
    font-size:16px;
    padding:.22rem .22rem;
  }
  .inventory-toggle-btn{
    min-height:38px;
    padding:.36rem .56rem;
    border-radius:12px;
  }
  .inventory-toggle-text{font-size:.76rem}
  .inventory-toggle-icon{
    width:18px;
    height:18px;
    border-radius:7px;
  }
  .ctrl-bar{flex-direction:column;align-items:stretch}
  .ctrl-section{border-right:none;border-bottom:1px solid var(--border)}
  .ctrl-section:last-child{border-bottom:none}
  .ctrl-divider{width:100%;height:1px}
  .ctrl-right{justify-content:space-between}
  .ctrl-week,.ctrl-search{min-width:0}
  .ctrl-bar-advanced .ctrl-section,
  .ctrl-bar-filters .ctrl-section,
  .ctrl-bar-filters .ctrl-right{
    width:100%;
    min-width:0;
  }
  .inventory-surface-grid{
    grid-template-columns:repeat(auto-fill,minmax(145px,1fr));
    gap:.75rem;
  }
  /* Mobile touch targets */
  .btn{min-height:48px;padding:.65rem 1.25rem}
  .btn-sm{min-height:44px}
  .form-control{min-height:48px;padding:.8rem 1rem}
  select.form-control{padding:.8rem 2.5rem .8rem 1rem;font-size:16px}
  input[type=checkbox],input[type=radio]{width:20px;height:20px;cursor:pointer}
  /* Mobile modals — bottom sheet style */
  .modal-overlay{align-items:flex-end}
  .modal{
    max-height:85vh;border-radius:20px 20px 0 0;
    max-width:100%;width:100%;
    transform:translateY(100px) scale(1) opacity 0;
  }
  .modal-overlay.active .modal{
    transform:translateY(0) scale(1) opacity 1;
  }
  .modal-body{max-height:calc(85vh - 120px)}
}

/* ===== SELECTION BAR ===== */
.sel-bar{
  position:fixed;bottom:0;left:0;right:0;
  background:var(--navy-950);
  border-top:1px solid rgba(255,255,255,.08);
  padding:1rem 2rem;
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  z-index:500;
  transform:translateY(100%);
  transition:transform .28s cubic-bezier(.4,0,.2,1);
  box-shadow:0 -8px 40px rgba(0,0,0,.4);
}
.sel-bar.active{transform:translateY(0)}
.sel-bar-info{color:#fff}
.sel-count{font-size:1.5rem;font-weight:900;line-height:1}
.sel-amount{font-size:.82rem;color:rgba(255,255,255,.5);margin-top:.1rem}
.sel-actions{display:flex;gap:.75rem}

/* ===== TABS ===== */
/* Legacy tabs (admin panel vb.) */
.tabs{
  display:flex;gap:0;
  border-bottom:2px solid var(--border);
  margin-bottom:2rem;overflow-x:auto;
  -webkit-overflow-scrolling:touch;
}
.tab-btn{
  padding:.7rem 1.25rem;
  border:none;background:none;
  font-size:.875rem;font-weight:700;color:var(--tx3);
  cursor:pointer;border-bottom:3px solid transparent;margin-bottom:-2px;
  transition:color .18s,border-color .18s;
  white-space:nowrap;display:flex;align-items:center;gap:.45rem;
  font-family:inherit;
}
.tab-btn:hover{color:var(--blue)}
.tab-btn.active{color:var(--blue);border-bottom-color:var(--blue)}
.tab-count{
  background:var(--blue);color:#fff;
  font-size:.65rem;padding:.1rem .4rem;border-radius:100px;font-weight:800;
}

/* ===== FIRMA PANEL — PREMIUM TABS ===== */
.firm-tabs{
  display:flex;align-items:stretch;gap:.5rem;
  background:linear-gradient(145deg,rgba(4,17,31,.98),rgba(10,30,64,.96));
  border-radius:22px;
  padding:.6rem;
  margin-bottom:2rem;
  border:1px solid rgba(96,165,250,.16);
  box-shadow:0 16px 36px rgba(4,17,31,.22), inset 0 1px 0 rgba(255,255,255,.08);
  overflow-x:auto;overflow-y:hidden;
  -webkit-overflow-scrolling:touch;
  overscroll-behavior-x:contain;
  scroll-behavior:smooth;
  scrollbar-width:thin;
  scrollbar-color:rgba(96,165,250,.75) transparent;
}
.firm-tabs::-webkit-scrollbar{height:6px}
.firm-tabs::-webkit-scrollbar-track{background:transparent}
.firm-tabs::-webkit-scrollbar-thumb{
  background:linear-gradient(90deg,rgba(96,165,250,.7),rgba(37,99,235,.8));
  border-radius:3px;
}
.firm-tabs::-webkit-scrollbar-thumb:hover{background:linear-gradient(90deg,rgba(96,165,250,.9),rgba(37,99,235,.95))}
.firm-tab{
  display:flex;align-items:center;justify-content:center;gap:.55rem;
  flex:0 0 auto;
  min-height:48px;
  padding:.75rem 1.3rem;
  border:1px solid transparent;border-radius:16px;
  font-size:.85rem;font-weight:800;letter-spacing:-.01em;
  color:rgba(255,255,255,.65);
  background:rgba(255,255,255,.04);
  cursor:pointer;
  transition:all .22s cubic-bezier(.4,.0,.2,1);
  white-space:nowrap;
  font-family:inherit;
  position:relative;
  scroll-snap-align:start;
  -webkit-tap-highlight-color:transparent;
}
.firm-tab:hover:not(.active){
  color:#f8fafc;
  background:rgba(255,255,255,.09);
  border-color:rgba(255,255,255,.12);
}
.firm-tab.active{
  color:#fff;
  background:linear-gradient(135deg,#3b82f6 0%,#1e40af 100%);
  border-color:rgba(147,197,253,.4);
  box-shadow:0 12px 28px rgba(37,99,235,.38), inset 0 1px 0 rgba(255,255,255,.18);
}
.ftab-icon{
  display:flex;align-items:center;
  color:inherit;opacity:.84;
}
.firm-tab.active .ftab-icon{opacity:1}
.ftab-label{font-size:.84rem;line-height:1.15}
.ftab-badge{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:18px;height:18px;padding:0 5px;
  background:#ef4444;color:#fff;
  font-size:.65rem;font-weight:900;border-radius:100px;
  animation:pulse-badge .8s ease infinite alternate;
}
@keyframes pulse-badge{from{opacity:.8}to{opacity:1;box-shadow:0 0 6px #ef4444}}

/* ===== TABLE ===== */
.tbl-wrap{overflow-x:auto;border-radius:var(--r);border:1px solid var(--border);box-shadow:var(--sh0)}
table{width:100%;border-collapse:collapse;font-size:.86rem}
thead{background:var(--navy-900)}
th{
  padding:.85rem 1rem;text-align:left;
  font-size:.72rem;font-weight:700;color:rgba(255,255,255,.5);
  text-transform:uppercase;letter-spacing:.5px;
  border-bottom:1px solid rgba(255,255,255,.06);white-space:nowrap;
}
td{
  padding:.85rem 1rem;border-bottom:1px solid var(--border);
  color:var(--tx);vertical-align:middle;
}
tr:last-child td{border-bottom:none}
tbody tr:hover td{background:var(--s2)}
.td-co{font-weight:800}
.td-week{font-weight:700;color:var(--blue)}

/* ===== MODAL ===== */
.modal-overlay{
  position:fixed;inset:0;background:rgba(4,17,31,.7);
  z-index:2000;display:flex;align-items:center;justify-content:center;
  padding:1rem;opacity:0;visibility:hidden;
  transition:opacity .24s cubic-bezier(.4,.0,.2,1),visibility .24s;
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
}
.modal-overlay.active{opacity:1;visibility:visible}
.modal{
  background:var(--surface);border-radius:var(--r-lg);
  max-width:640px;width:100%;max-height:90vh;
  overflow:hidden;display:flex;flex-direction:column;
  box-shadow:0 25px 60px -12px rgba(0,0,0,.35),0 0 0 1px rgba(255,255,255,.1) inset;
  border:1px solid rgba(255,255,255,.1);
  transform:scale(.93) translateY(16px) opacity 0;
  transition:transform .3s cubic-bezier(.4,.0,.2,1),opacity .3s ease;
}
.modal-overlay.active .modal{transform:scale(1) translateY(0) opacity 1}
.modal-lg{max-width:820px}
.modal-header{
  padding:1.5rem 1.75rem;border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;
  background:linear-gradient(to right,var(--s2),var(--surface));
}
.modal-header h3{font-size:1.15rem;font-weight:800;letter-spacing:-.02em}
.modal-close{
  background:none;border:none;min-height:40px;min-width:40px;
  border-radius:var(--r-sm);
  display:flex;align-items:center;justify-content:center;
  font-size:1.25rem;color:var(--tx3);cursor:pointer;
  transition:background .15s,color .15s,-webkit-tap-highlight-color 0s;
  -webkit-tap-highlight-color:transparent;
}
.modal-close:hover{background:var(--border);color:var(--tx)}
.modal-close:active{background:#cbd5e1}
.modal-body{padding:1.75rem;overflow-y:auto;max-height:calc(90vh - 140px)}
.modal-body::-webkit-scrollbar{width:6px}
.modal-body::-webkit-scrollbar-track{background:transparent}
.modal-body::-webkit-scrollbar-thumb{background:rgba(0,0,0,.15);border-radius:3px}
.modal-body::-webkit-scrollbar-thumb:hover{background:rgba(0,0,0,.25)}
.modal-footer{
  padding:1.25rem 1.75rem;border-top:1px solid var(--border);
  display:flex;gap:.75rem;justify-content:flex-end;
  background:var(--s2);
}

/* ===== REQUEST CARDS ===== */
.req-card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r);margin-bottom:.85rem;overflow:hidden;
  box-shadow:var(--sh0);transition:box-shadow .2s;
}
.req-card:hover{box-shadow:var(--sh1)}
.req-card-head{
  padding:1rem 1.25rem;
  display:flex;align-items:center;gap:.85rem;flex-wrap:wrap;
  cursor:pointer;
  border-left:4px solid transparent;
  transition:background .15s;
}
.req-card-head:hover{background:var(--s2)}
.req-card.s-submitted .req-card-head{border-left-color:var(--warn)}
.req-card.s-approved  .req-card-head{border-left-color:var(--ok)}
.req-card.s-rejected  .req-card-head{border-left-color:var(--bad)}
.req-card.s-draft     .req-card-head{border-left-color:var(--tx3)}
.req-card-body{padding:1.25rem;display:none;border-top:1px solid var(--border)}
.req-card.open .req-card-body{display:block}
.week-chip{
  background:var(--navy-800);color:#fff;
  padding:.25rem .7rem;border-radius:100px;
  font-size:.73rem;font-weight:700;white-space:nowrap;
}

/* Request items list */
.req-items{display:flex;flex-direction:column;gap:.45rem}
.req-item{
  display:flex;align-items:center;gap:.65rem;
  padding:.55rem .85rem;
  background:var(--s2);border-radius:var(--r-sm);
  border:1px solid var(--border);font-size:.84rem;
}
.req-item-name{font-weight:700;flex:1}
.req-item-price{font-weight:800;color:var(--blue);white-space:nowrap}

/* Summary box */
.summary-box{
  background:var(--s2);border:1px solid var(--border);
  border-radius:var(--r-sm);padding:.9rem 1rem;
  display:flex;flex-direction:column;gap:.35rem;
}
.summary-row{display:flex;justify-content:space-between;align-items:center;font-size:.88rem}
.summary-total{
  display:flex;justify-content:space-between;align-items:center;
  font-size:1rem;font-weight:800;
  padding-top:.5rem;margin-top:.25rem;border-top:1px solid var(--border);
}

/* Payment workflow */
.payment-card{
  margin-bottom:1rem;
  background:linear-gradient(180deg,#ffffff 0%,#f7f9fc 100%);
  border:1px solid var(--border);
  border-radius:var(--r);
  padding:1rem 1.05rem;
  box-shadow:var(--sh0);
}
.payment-card-head{
  display:flex;align-items:flex-start;justify-content:space-between;gap:.85rem;flex-wrap:wrap;
  margin-bottom:.95rem;
}
.payment-card-title{font-size:.95rem;font-weight:800;color:var(--tx)}
.payment-card-sub{font-size:.76rem;color:var(--tx3);margin-top:.12rem}
.payment-state,
.payment-mini{
  display:inline-flex;align-items:center;justify-content:center;
  padding:.34rem .72rem;border-radius:999px;
  font-size:.72rem;font-weight:800;line-height:1.2;
  border:1px solid transparent;
}
.payment-state-awaiting_method,
.payment-mini-awaiting_method{background:#eef2ff;color:#4338ca;border-color:#c7d2fe}
.payment-state-awaiting_receipt,
.payment-mini-awaiting_receipt{background:#fffbeb;color:#b45309;border-color:#fde68a}
.payment-state-receipt_uploaded,
.payment-mini-receipt_uploaded{background:#ecfeff;color:#0f766e;border-color:#99f6e4}
.payment-state-open_account,
.payment-mini-open_account{background:#f5f3ff;color:#6d28d9;border-color:#ddd6fe}
.payment-state-credit_card_pending,
.payment-mini-credit_card_pending{background:#fff7ed;color:#c2410c;border-color:#fdba74}
.payment-state-credit_card_pending_activation,
.payment-mini-credit_card_pending_activation{background:#fff1f2;color:#be123c;border-color:#fda4af}
.payment-state-paid,
.payment-mini-paid{background:#ecfdf5;color:#166534;border-color:#86efac}
.payment-state-completed,
.payment-mini-completed{background:#ecfdf5;color:#166534;border-color:#86efac}
.payment-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:.75rem;
}
.payment-field{
  display:flex;flex-direction:column;gap:.2rem;
  padding:.75rem .82rem;
  background:rgba(255,255,255,.82);
  border:1px solid var(--border);
  border-radius:var(--r-sm);
}
.payment-field span{
  font-size:.68rem;font-weight:800;color:var(--tx3);
  text-transform:uppercase;letter-spacing:.4px;
}
.payment-field strong{
  font-size:.92rem;font-weight:800;color:var(--tx);
  line-height:1.35;word-break:break-word;
}
.payment-field-wide{grid-column:1 / -1}
.payment-field-emphasis{
  background:linear-gradient(180deg,#eff6ff 0%,#f8fbff 100%);
  border-color:#bfdbfe;
}
.payment-iban{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;letter-spacing:.04em}
.payment-note-box,
.payment-note-line{
  margin-top:.8rem;
  padding:.78rem .9rem;
  background:#eff6ff;
  border:1px solid #bfdbfe;
  border-radius:var(--r-sm);
  color:#1e3a8a;
  font-size:.82rem;
}
.payment-note-line{margin-top:0;margin-bottom:.8rem}
.payment-receipt-meta{
  margin-top:.9rem;
  padding:.9rem 1rem;
  border-radius:var(--r-sm);
  border:1px solid #a7f3d0;
  background:#ecfdf5;
  display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem;flex-wrap:wrap;
}
.payment-receipt-meta strong{color:#166534}
.payment-receipt-meta span{font-size:.8rem;color:#166534}
.payment-receipt-actions{display:flex;gap:.5rem;flex-wrap:wrap}
.payment-upload{margin-top:1rem}
.payment-upload-row{display:flex;gap:.65rem;align-items:center;flex-wrap:wrap}
.payment-upload-row .form-control{flex:1;min-width:220px}
.payment-upload-help{margin-top:.4rem;font-size:.72rem;color:var(--tx3)}
.payment-options{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:.85rem;
  margin-bottom:1rem;
}
.payment-option{
  border:1px solid var(--border);
  border-radius:var(--r-sm);
  padding:.95rem;
  background:#fff;
  display:flex;
  flex-direction:column;
  gap:.7rem;
  box-shadow:var(--sh0);
}
.payment-option-selected{
  border-color:#93c5fd;
  background:linear-gradient(180deg,#eff6ff 0%,#ffffff 100%);
}
.payment-option-disabled{
  opacity:.72;
}
.payment-option-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:.65rem;
}
.payment-option-title{
  font-size:.9rem;
  font-weight:800;
  color:var(--tx);
}
.payment-option-sub{
  font-size:.74rem;
  color:var(--tx3);
  margin-top:.16rem;
}
.payment-option-meta{
  display:flex;
  flex-wrap:wrap;
  gap:.45rem;
}
.payment-chip{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  padding:.25rem .58rem;
  font-size:.68rem;
  font-weight:800;
  border:1px solid #dbeafe;
  background:#eff6ff;
  color:#1d4ed8;
}
.payment-option-body{
  font-size:.8rem;
  color:var(--tx2);
  line-height:1.55;
}
.payment-option-actions{
  margin-top:auto;
  display:flex;
  justify-content:flex-end;
}
.payment-overview-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:.85rem;
  margin-bottom:1rem;
}
.payment-overview-card{
  padding:1rem;
  border-radius:var(--r-sm);
  border:1px solid var(--border);
  background:linear-gradient(180deg,#fff 0%,#f8fafc 100%);
  box-shadow:var(--sh0);
}
.payment-overview-label{
  font-size:.72rem;
  font-weight:800;
  color:var(--tx3);
  text-transform:uppercase;
  letter-spacing:.4px;
}
.payment-overview-value{
  font-size:1.15rem;
  font-weight:900;
  color:var(--tx);
  margin-top:.28rem;
}
.payment-overview-sub{
  margin-top:.24rem;
  font-size:.78rem;
  color:var(--tx2);
}
.payment-profile-summary{
  display:flex;
  flex-wrap:wrap;
  gap:.45rem;
}
.payment-info-list{
  display:flex;
  flex-direction:column;
  gap:.45rem;
  font-size:.8rem;
  color:var(--tx2);
}
.payment-info-list strong{color:var(--tx)}

/* Request history / approved cards */
.record-list{display:grid;gap:1rem}
.record-card{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r);
  padding:1.1rem 1.15rem;box-shadow:var(--sh0);
}
.record-card-head{
  display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;flex-wrap:wrap;
}
.record-card-main{min-width:0}
.record-card-kicker{
  font-size:.7rem;font-weight:800;color:var(--tx3);
  text-transform:uppercase;letter-spacing:.5px;
}
.record-card-title{
  margin-top:.18rem;font-size:1rem;font-weight:800;color:var(--tx);
  line-height:1.35;word-break:break-word;
}
.record-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.75rem;
  margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border);
}
.record-field{
  display:flex;flex-direction:column;gap:.22rem;
  background:var(--s2);border:1px solid var(--border);
  border-radius:var(--r-sm);padding:.72rem .82rem;
}
.record-field span{
  font-size:.68rem;font-weight:800;color:var(--tx3);
  text-transform:uppercase;letter-spacing:.45px;
}
.record-field strong{
  font-size:.92rem;font-weight:800;color:var(--tx);line-height:1.35;
  word-break:break-word;
}
.record-actions{margin-top:1rem}
.record-detail{margin-top:1rem}

/* ===== DASHBOARD HEADER ===== */
.dash-header{
  background:linear-gradient(135deg,#04111f 0%,#0a1e40 55%,#04111f 100%);
  padding:1.75rem 0;margin-bottom:2rem;
  position:relative;overflow:hidden;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.dash-header::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse 70% 80% at 85% 50%,rgba(37,99,235,.18) 0%,transparent 65%),
    radial-gradient(ellipse 30% 60% at 10% 50%,rgba(96,165,250,.06) 0%,transparent 60%);
}
.dash-header::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(37,99,235,.4),transparent);
}
.dash-header .container{position:relative}
.dash-title{font-size:1.45rem;font-weight:900;color:#f8fafc;line-height:1.2;letter-spacing:-.02em}
.dash-sub{font-size:.82rem;color:rgba(255,255,255,.35);margin-top:.3rem;letter-spacing:.02em}

/* Stats grid */
.stats-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(200px,1fr));
  gap:1rem;margin-bottom:2rem;
}

/* ===== ALERTS ===== */
.alert{
  padding:.9rem 1.1rem;border-radius:var(--r-sm);
  font-size:.87rem;font-weight:500;
  display:flex;align-items:flex-start;gap:.65rem;margin-bottom:1rem;
}
.alert-info{background:#eff6ff;color:#1e40af;border-left:3px solid #2563eb}
.alert-success{background:#ecfdf5;color:#166534;border-left:3px solid #059669}
.alert-warning{background:#fffbeb;color:#92400e;border-left:3px solid #d97706}
.alert-danger{background:#fff1f2;color:#991b1b;border-left:3px solid #dc2626}

/* ===== EMPTY STATE ===== */
.empty{text-align:center;padding:4rem 2rem;color:var(--tx3)}
.empty-icon{font-size:2.5rem;margin-bottom:1rem;opacity:.4}
.empty h4{font-size:1rem;color:var(--tx2);margin-bottom:.35rem}
.empty p{font-size:.875rem}

/* ===== TOAST ===== */
#toast-container{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:.6rem}
.toast{
  padding:.8rem 1.15rem;border-radius:var(--r-sm);
  font-size:.875rem;font-weight:600;
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  min-width:260px;max-width:380px;
  box-shadow:var(--sh2);animation:slideIn .25s ease;
}
.toast button{background:none;border:none;font-size:1rem;opacity:.6;cursor:pointer;color:inherit;flex-shrink:0}
.toast-success{background:#064e3b;color:#a7f3d0}
.toast-error{background:#7f1d1d;color:#fecaca}
.toast-warning{background:#78350f;color:#fde68a}
.toast-info{background:#1e3a8a;color:#bfdbfe}

/* ===== LOADER ===== */
.loader{display:flex;align-items:center;justify-content:center;padding:3rem;gap:.75rem;color:var(--tx3);font-size:.88rem}
.spinner{width:22px;height:22px;border:2.5px solid var(--border);border-top-color:var(--blue);border-radius:50%;animation:spin .65s linear infinite}
.spinner-sm{width:15px;height:15px;border-width:2px}

/* ===== LANDING PAGE ===== */
.hero{
  background:linear-gradient(135deg,var(--navy-950) 0%,var(--navy-800) 55%,#1a3a6b 100%);
  min-height:100vh;display:flex;align-items:center;
  position:relative;overflow:hidden;padding:6rem 0 5rem;
}
.hero::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse 60% 70% at 70% 45%,rgba(37,99,235,.18) 0%,transparent 70%),
    radial-gradient(ellipse 40% 60% at 20% 80%,rgba(200,168,75,.08) 0%,transparent 60%);
}
.hero-content{position:relative;z-index:1;max-width:640px}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:.5rem;
  background:rgba(37,99,235,.15);border:1px solid rgba(37,99,235,.3);
  color:var(--blue-l);font-size:.78rem;font-weight:700;
  padding:.35rem .85rem;border-radius:100px;margin-bottom:1.5rem;
  text-transform:uppercase;letter-spacing:.5px;
}
.hero h1{
  font-size:clamp(2.2rem,5vw,3.5rem);font-weight:900;color:#fff;
  line-height:1.12;margin-bottom:1.25rem;letter-spacing:-.5px;
}
.hero h1 em{font-style:normal;color:var(--blue-l)}
.hero-lead{
  font-size:1.05rem;color:rgba(255,255,255,.6);
  line-height:1.75;margin-bottom:2.25rem;max-width:520px;
}
.hero-cta{display:flex;gap:.85rem;flex-wrap:wrap}
.hero-stats{
  display:flex;gap:2.5rem;flex-wrap:wrap;
  margin-top:3rem;padding-top:2rem;
  border-top:1px solid rgba(255,255,255,.1);
}
.hero-stat .n{font-size:1.75rem;font-weight:900;color:#fff;line-height:1}
.hero-stat .l{font-size:.75rem;color:rgba(255,255,255,.45);margin-top:.2rem;text-transform:uppercase;letter-spacing:.5px}

/* Billboard decor */
.hero-decor{
  position:absolute;right:5%;top:50%;transform:translateY(-50%);
  display:flex;gap:3rem;align-items:flex-end;
  pointer-events:none;
}
.decor-bb{display:flex;flex-direction:column;align-items:center;opacity:.1}
.decor-panel{border:3px solid rgba(255,255,255,.7);border-radius:4px 4px 0 0}
.decor-pole{background:rgba(255,255,255,.5)}
.decor-base{background:rgba(255,255,255,.4);border-radius:3px}

/* Features */
.section{padding:5rem 0}
.section-sm{padding:3.5rem 0}
.section-hd{text-align:center;margin-bottom:3.5rem}
.section-hd h2{font-size:clamp(1.6rem,3vw,2.2rem);font-weight:900;letter-spacing:-.3px}
.section-hd p{font-size:1rem;color:var(--tx2);margin-top:.65rem;max-width:520px;margin-left:auto;margin-right:auto}
.section-eyebrow{
  font-size:.72rem;font-weight:800;color:var(--blue);
  text-transform:uppercase;letter-spacing:.8px;
  margin-bottom:.65rem;display:block;
}

.feat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:1.5rem}
.feat-card{
  background:var(--surface);border-radius:var(--r);
  padding:2rem;border:1px solid var(--border);box-shadow:var(--sh0);
  transition:transform .2s,box-shadow .2s;
}
.feat-card:hover{transform:translateY(-4px);box-shadow:var(--sh2)}
.feat-icon{
  width:52px;height:52px;border-radius:var(--r-sm);
  display:flex;align-items:center;justify-content:center;
  font-size:1.35rem;margin-bottom:1.25rem;
}
.feat-card h4{font-size:1rem;font-weight:800;margin-bottom:.5rem}
.feat-card p{font-size:.875rem;color:var(--tx2);line-height:1.65}

/* Process steps */
.steps{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:2rem;margin-top:3rem}
.step{text-align:center}
.step-num{
  width:52px;height:52px;border-radius:50%;
  background:linear-gradient(135deg,var(--blue),var(--blue-l));
  color:#fff;font-size:1.2rem;font-weight:900;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 1.1rem;
  box-shadow:0 6px 20px rgba(37,99,235,.35);
}
.step h4{font-size:.95rem;font-weight:800;margin-bottom:.4rem}
.step p{font-size:.84rem;color:var(--tx2);line-height:1.6}

/* CTA strip */
.cta-strip{
  background:linear-gradient(135deg,var(--navy-900),var(--navy-700));
  padding:5rem 0;text-align:center;
}
.cta-strip h2{color:#fff;font-size:clamp(1.6rem,3vw,2.2rem);font-weight:900;margin-bottom:.75rem}
.cta-strip p{color:rgba(255,255,255,.55);margin-bottom:2.25rem;font-size:1rem}

/* Price card */
.price-card{
  background:var(--surface);border-radius:var(--r-lg);
  padding:2rem;box-shadow:var(--sh2);border:1px solid var(--border);
  max-width:380px;
}
.price-main{text-align:center;padding-bottom:1.25rem;border-bottom:1px solid var(--border);margin-bottom:1.25rem}
.price-amount{font-size:2.8rem;font-weight:900;color:var(--tx)}
.price-period{font-size:.85rem;color:var(--tx3);margin-top:.2rem}
.price-features{display:flex;flex-direction:column;gap:.65rem}
.price-feat{display:flex;align-items:center;gap:.65rem;font-size:.875rem}
.price-feat-icon{color:var(--ok);font-size:1rem;flex-shrink:0}

/* Footer */
.footer{
  background:var(--navy-950);color:rgba(255,255,255,.3);
  padding:2rem 0;text-align:center;font-size:.82rem;
  border-top:1px solid rgba(255,255,255,.05);
}

/* AUTH */
.auth-page{
  min-height:100vh;display:flex;flex-direction:column;
  background:linear-gradient(135deg,var(--navy-950),var(--navy-800));
}
.auth-wrap{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem 1rem}
.auth-card{
  background:var(--surface);border-radius:var(--r-xl);
  padding:2.5rem;width:100%;max-width:460px;box-shadow:var(--sh3);
}
.auth-logo{text-align:center;margin-bottom:2rem}
.auth-logo-icon{
  width:58px;height:58px;
  background:linear-gradient(135deg,var(--blue),var(--blue-l));
  border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  font-size:1.5rem;margin:0 auto .85rem;
  box-shadow:0 8px 24px rgba(37,99,235,.4);
}
.auth-logo h2{font-size:1.5rem;font-weight:900;color:var(--tx)}
.auth-logo p{font-size:.875rem;color:var(--tx3);margin-top:.25rem}
.auth-divider{text-align:center;margin:1.5rem 0;position:relative;color:var(--tx3);font-size:.82rem}
.auth-divider::before{content:'';position:absolute;top:50%;left:0;right:0;height:1px;background:var(--border)}
.auth-divider span{background:var(--surface);padding:0 1rem;position:relative}
.auth-meta-row{display:flex;justify-content:flex-end;align-items:center;margin:-.25rem 0 1rem}
.auth-meta-link{color:var(--blue);font-size:.82rem;font-weight:700;text-decoration:none}
.auth-meta-link:hover{text-decoration:underline}
.auth-link{text-align:center;margin-top:1.5rem;font-size:.875rem;color:var(--tx2)}
.auth-link a{color:var(--blue);font-weight:700}
.auth-muted{font-size:.82rem;color:var(--tx3);line-height:1.65}
.auth-actions-stack{display:flex;flex-direction:column;gap:.75rem}
/* Google Sign-In button wrapper */
.google-btn-wrap{display:flex;flex-direction:column;align-items:center;gap:.55rem;margin-bottom:.25rem}
.google-btn-wrap #google-signin-btn{width:100%;display:flex;justify-content:center}
.google-btn-wrap #google-signin-btn iframe{border-radius:var(--r-sm) !important}
.google-btn-note{font-size:.75rem;color:var(--tx3);margin:0;text-align:center}
.test-accounts{
  margin-top:1.5rem;padding:.85rem;
  background:var(--s2);border-radius:var(--r-sm);border:1px solid var(--border);
  font-size:.75rem;color:var(--tx3);
}
.test-accounts .ta-title{font-weight:700;color:var(--tx2);margin-bottom:.35rem}
.test-accounts code{
  background:rgba(0,0,0,.06);padding:.05rem .3rem;
  border-radius:3px;font-family:monospace;font-size:.8rem;color:var(--tx);
}

/* Schedule (admin) */
.sched-loc{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;margin-bottom:1.25rem;box-shadow:var(--sh0)}
.sched-loc-head{
  padding:.85rem 1.25rem;
  background:var(--navy-900);color:#fff;
  display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;
}
.sched-loc-name{font-weight:800;font-size:.9rem}
.sched-loc-addr{font-size:.75rem;color:rgba(255,255,255,.4)}
.sched-boards{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1px;background:var(--border)}
.sched-board{padding:.85rem 1rem;background:var(--surface)}
.sched-board.occupied{background:var(--bad-bg)}
.sched-board.pending{background:var(--warn-bg)}
.sched-board.available{background:var(--ok-bg)}
.sched-board-name{font-size:.85rem;font-weight:800}
.sched-board-co{font-size:.72rem;color:var(--tx2);margin-top:.2rem;font-weight:600}

/* UTILS */
.container{max-width:1320px;margin:0 auto;padding:0 2rem}
.hidden{display:none!important}
.text-center{text-align:center}
.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}
.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}
.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}
.gap-2{gap:.5rem}.gap-4{gap:1rem}
.font-bold{font-weight:700}.font-black{font-weight:900}
.text-muted{color:var(--tx3)}.text-blue{color:var(--blue)}.text-ok{color:var(--ok)}
.bg-light{background:var(--s2)}
.w-full{width:100%}
.action-row{display:flex;gap:.5rem;flex-wrap:wrap}

/* ANIMATIONS */
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.4}}
@keyframes slideIn{from{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}
@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.fade-up{animation:fadeUp .3s ease forwards}

/* RESPONSIVE */
@media(max-width:1024px){
  .hero-decor{display:none}
}
@media(max-width:768px){
  .container{padding:0 1.25rem}
  .hero{padding:5rem 0 4rem}
  .hero h1{font-size:2.1rem}
  .billboard-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1rem}
  .clp-grid{grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:.9rem}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .form-row{grid-template-columns:1fr}
  .sel-bar{flex-direction:column;gap:.65rem;text-align:center;padding:.85rem 1.25rem}
  .tabs{gap:0}
  .tab-btn{padding:.6rem .9rem;font-size:.8rem}
  .modal{border-radius:var(--r) var(--r) 0 0;max-height:95vh}
  .modal-overlay{align-items:flex-end}
  th,td{padding:.65rem .75rem}
  .hero-stats{gap:1.5rem}
}
@media(max-width:480px){
  .billboard-grid{grid-template-columns:repeat(2,1fr);gap:.75rem}
  .clp-grid{grid-template-columns:repeat(3,1fr);gap:.6rem}
  .auth-wrap{padding:1rem .75rem}
  .auth-card{padding:1.15rem 1rem;border-radius:16px}
  .auth-logo{margin-bottom:1.1rem}
  .auth-logo-icon{
    width:46px;height:46px;
    font-size:1.2rem;
    margin:0 auto .55rem;
  }
  .auth-logo h2{font-size:1.2rem}
  .auth-logo p{font-size:.8rem}
  .auth-meta-row{margin-bottom:.85rem}
  .auth-divider{margin:1rem 0}
  .auth-link{margin-top:1rem;font-size:.82rem}
  .google-btn-note{font-size:.72rem}
  .test-accounts{display:none}
  .stats-grid{grid-template-columns:1fr}
  .feat-grid{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr 1fr}
}

/* ══════════════════════════════════════
   CLP RAKET KART — City Light Poster
   Gerçekçi dış mekan aydınlatmalı raket tasarımı
══════════════════════════════════════ */
.clp-card{
  display:flex;flex-direction:column;align-items:center;
  cursor:pointer;user-select:none;
  perspective:900px;
  perspective-origin:35% 20%;
}
.clp-card.locked{cursor:not-allowed}
.clp-card.locked .clp-structure{opacity:.6}

.clp-structure{
  display:flex;flex-direction:column;align-items:center;width:100%;
  transform:rotateX(5deg) rotateY(-14deg);
  transform-style:preserve-3d;
  transition:transform .45s cubic-bezier(.22,1,.36,1),filter .35s;
  filter:drop-shadow(0 14px 26px rgba(0,0,0,.35));
  will-change:transform;
}
.clp-card:hover .clp-structure{
  transform:rotateX(2deg) rotateY(-7deg) translateY(-12px) scale(1.03);
  filter:drop-shadow(0 30px 50px rgba(0,0,0,.5));
}

/* ── Panel sarmalayıcı (ön yüz + kapaklar birlikte) ── */
.clp-panel-wrap{
  position:relative;
  width:min(100%,94px);
  display:flex;flex-direction:column;align-items:center;
}

/* ── Panel üst/alt alüminyum kapakları ── */
.clp-cap{
  width:calc(100% + 6px);
  height:5px;
  background:linear-gradient(to right,
    #1e293b 0%,#334155 18%,#7b91a8 38%,#c8d8e8 50%,
    #94a3b8 62%,#475569 80%,#1e293b 100%
  );
  box-shadow:
    0 2px 6px rgba(0,0,0,.45),
    inset 0 1px 0 rgba(255,255,255,.3),
    inset 0 -1px 0 rgba(0,0,0,.25);
}
.clp-cap-top{
  border-radius:4px 4px 1px 1px;
  margin-bottom:-1px;z-index:2;
}
.clp-cap-bot{
  border-radius:1px 1px 4px 4px;
  margin-top:-1px;z-index:2;
  background:linear-gradient(to right,
    #1e293b 0%,#334155 18%,#64748b 38%,#94a3b8 50%,
    #64748b 62%,#475569 80%,#1e293b 100%
  );
}

/* ── Panel ön yüz ── */
.clp-panel{
  width:100%;
  aspect-ratio:3/4;
  border-radius:0;
  border:3px solid;
  position:relative;overflow:hidden;
  transition:box-shadow .3s;
  z-index:1;
}
/* Backlit iç aydınlatma yansıması + yüzey dokusu */
.clp-panel::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse 75% 55% at 50% 48%,rgba(255,255,255,.18) 0%,transparent 65%),
    linear-gradient(125deg,rgba(255,255,255,.3) 0%,rgba(255,255,255,.1) 20%,transparent 50%),
    linear-gradient(to bottom,transparent 45%,rgba(0,0,0,.12) 100%),
    repeating-linear-gradient(-45deg,transparent,transparent 12px,rgba(0,0,0,.018) 12px,rgba(0,0,0,.018) 13px);
  pointer-events:none;z-index:1;
}
/* Alüminyum iç çerçeve profili */
.clp-panel::after{
  content:'';position:absolute;inset:5px;
  border:1.5px solid rgba(255,255,255,.4);
  border-radius:1px;
  pointer-events:none;z-index:2;
  box-shadow:
    inset 0 1px 5px rgba(255,255,255,.45),
    inset 0 -1px 4px rgba(0,0,0,.2),
    inset 1px 0 4px rgba(255,255,255,.3),
    inset -1px 0 4px rgba(0,0,0,.15);
}

/* Durum renkleri — backlit LED parlaması dahil */
.clp-panel.available{
  border-color:#059669;
  background:
    radial-gradient(ellipse 60% 50% at 50% 50%,rgba(187,247,208,.6) 0%,transparent 70%),
    linear-gradient(160deg,#ecfdf5 0%,#bbf7d0 55%,#6ee7b7 100%);
  box-shadow:
    1px 1px 0 rgba(255,255,255,.7) inset,
    -2px 2px 0 #047857,
    -4px 4px 0 #065f46,
    -6px 8px 24px rgba(4,120,87,.25),
    0 0 28px rgba(5,150,105,.2);
}
.clp-panel.pending{
  border-color:#d97706;
  background:
    radial-gradient(ellipse 60% 50% at 50% 50%,rgba(253,230,138,.6) 0%,transparent 70%),
    linear-gradient(160deg,#fffbeb 0%,#fde68a 55%,#fbbf24 100%);
  box-shadow:
    1px 1px 0 rgba(255,255,255,.7) inset,
    -2px 2px 0 #b45309,
    -4px 4px 0 #92400e,
    -6px 8px 24px rgba(180,83,9,.25),
    0 0 24px rgba(217,119,6,.2);
}
.clp-panel.occupied{
  border-color:#dc2626;
  background:
    radial-gradient(ellipse 60% 50% at 50% 50%,rgba(254,205,211,.5) 0%,transparent 70%),
    linear-gradient(160deg,#fff1f2 0%,#fecdd3 55%,#fca5a5 100%);
  box-shadow:
    1px 1px 0 rgba(255,255,255,.7) inset,
    -2px 2px 0 #b91c1c,
    -4px 4px 0 #991b1b,
    -6px 8px 24px rgba(185,28,28,.25),
    0 0 22px rgba(220,38,38,.18);
}
.clp-panel.selected{
  border-color:#2563eb;
  background:
    radial-gradient(ellipse 60% 50% at 50% 50%,rgba(191,219,254,.65) 0%,transparent 70%),
    linear-gradient(160deg,#eff6ff 0%,#bfdbfe 55%,#93c5fd 100%);
  box-shadow:
    1px 1px 0 rgba(255,255,255,.7) inset,
    -2px 2px 0 #1d4ed8,
    -4px 4px 0 #1e40af,
    -6px 8px 24px rgba(29,78,216,.28),
    0 0 36px rgba(37,99,235,.3),
    0 0 0 3px rgba(37,99,235,.3);
}
.clp-panel.no-week{
  border-color:var(--border-d);
  background:linear-gradient(145deg,#f8fafc,#e2e8f0);
  box-shadow:
    1px 1px 0 rgba(255,255,255,.9) inset,
    -2px 2px 0 #94a3b8,
    -3px 6px 16px rgba(0,0,0,.1);
  cursor:default;
}

/* ── Panel içi ── */
.clp-panel-body{
  position:absolute;inset:0;z-index:2;
  display:flex;flex-direction:column;justify-content:space-between;
  padding:.55rem .65rem .5rem;
}
.clp-type-badge{
  display:inline-flex;align-items:center;gap:.25rem;
  background:rgba(0,0,0,.6);backdrop-filter:blur(6px);
  color:#fff;font-size:.52rem;font-weight:900;
  padding:.15rem .42rem;border-radius:4px;
  text-transform:uppercase;letter-spacing:.5px;align-self:flex-start;
  box-shadow:0 1px 4px rgba(0,0,0,.4);
  white-space:nowrap;
}
.clp-loc-name{
  font-size:.65rem;font-weight:800;color:rgba(0,0,0,.72);
  text-transform:uppercase;letter-spacing:.3px;line-height:1.25;
  text-shadow:0 1px 3px rgba(255,255,255,.65);
  overflow:hidden;display:-webkit-box;
  -webkit-line-clamp:3;-webkit-box-orient:vertical;
}
.clp-bottom{display:flex;align-items:center;justify-content:space-between;gap:.2rem}
.clp-face-label{
  font-size:.58rem;font-weight:700;color:rgba(0,0,0,.48);
  background:rgba(255,255,255,.58);padding:.1rem .32rem;
  border-radius:3px;backdrop-filter:blur(2px);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  flex:1;min-width:0;
}
.clp-status-pill{
  display:inline-flex;align-items:center;gap:.22rem;
  font-size:.54rem;font-weight:800;text-transform:uppercase;letter-spacing:.5px;
  padding:.14rem .42rem;border-radius:100px;
  background:rgba(255,255,255,.65);backdrop-filter:blur(4px);
  white-space:nowrap;flex-shrink:0;
}
.available .clp-status-pill{color:var(--ok)}
.pending   .clp-status-pill{color:var(--warn)}
.occupied  .clp-status-pill{color:var(--bad)}
.selected  .clp-status-pill{color:var(--sel)}
.clp-check{
  position:absolute;top:6px;right:7px;z-index:3;
  background:var(--sel);color:#fff;
  width:18px;height:18px;border-radius:50%;
  display:none;align-items:center;justify-content:center;
  font-size:.7rem;font-weight:900;
  box-shadow:0 2px 8px rgba(37,99,235,.55);
}
.clp-panel.selected .clp-check{display:flex}
.clp-stripe{position:absolute;top:0;left:0;right:0;height:3px;z-index:3}
.available .clp-stripe{background:linear-gradient(to right,var(--ok),#34d399)}
.pending   .clp-stripe{background:linear-gradient(to right,var(--warn),#fbbf24)}
.occupied  .clp-stripe{background:linear-gradient(to right,var(--bad),#f87171)}
.selected  .clp-stripe{background:linear-gradient(to right,var(--sel),#60a5fa)}

/* ── Montaj kolu — paneli direğe bağlayan yapısal braketi ── */
.clp-arm{
  width:42%;
  height:9px;
  background:linear-gradient(to right,
    #0f172a 0%,#1e293b 12%,#334155 25%,
    #94a3b8 44%,#d0dce8 52%,
    #7b91a8 60%,#334155 75%,#1e293b 88%,#0f172a 100%
  );
  border-radius:4px;
  box-shadow:
    0 4px 12px rgba(0,0,0,.58),
    inset 0 1px 0 rgba(255,255,255,.32),
    inset 0 -1px 0 rgba(0,0,0,.38),
    2px 0 5px rgba(0,0,0,.3);
  position:relative;
  flex-shrink:0;
}
/* Merkez civata/bağlantı noktası */
.clp-arm-bolt{
  position:absolute;
  top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:13px;height:13px;
  background:radial-gradient(circle at 35% 35%,
    #e2e8f0 0%,#94a3b8 35%,#475569 65%,#1e293b 100%
  );
  border-radius:50%;
  box-shadow:
    0 0 0 2px #334155,
    0 2px 7px rgba(0,0,0,.55),
    inset 0 1px 0 rgba(255,255,255,.4);
}
/* Civata ortasındaki somun izi */
.clp-arm-bolt::after{
  content:'';
  position:absolute;
  top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:5px;height:5px;
  background:linear-gradient(135deg,#1e293b,#475569);
  border-radius:1px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.2);
}

/* ── Direk ── */
.clp-pole-wrap{display:flex;justify-content:center;width:100%}
.clp-pole{
  position:relative;
  width:10px;
  height:clamp(24px,3.2vw,34px);
  background:linear-gradient(to right,
    #0f172a 0%,#1e293b 10%,#2d3f55 20%,
    #6a8299 36%,#c0d2e2 50%,
    #8fa5ba 64%,#3d5268 78%,
    #1e293b 90%,#0f172a 100%
  );
  border-radius:2px;
  box-shadow:
    4px 0 12px rgba(0,0,0,.6),
    -1px 0 4px rgba(0,0,0,.35),
    inset 0 1px 0 rgba(255,255,255,.35),
    inset 0 -1px 0 rgba(0,0,0,.4);
  flex-shrink:0;
}
/* Üst bağlantı manşonu */
.clp-pole::before{
  content:'';
  position:absolute;
  top:-2px;left:-3px;right:-3px;
  height:8px;
  background:linear-gradient(to right,
    #1e293b 0%,#475569 30%,#94a3b8 50%,#475569 70%,#1e293b 100%
  );
  border-radius:3px 3px 1px 1px;
  box-shadow:0 2px 7px rgba(0,0,0,.6),inset 0 1px 0 rgba(255,255,255,.28);
}
/* Alt taban flanşı */
.clp-pole::after{
  content:'';
  position:absolute;
  bottom:0;left:-4px;right:-4px;
  height:7px;
  background:linear-gradient(to right,
    #0f172a 0%,#334155 30%,#64748b 50%,#334155 70%,#0f172a 100%
  );
  border-radius:1px 1px 3px 3px;
  box-shadow:0 3px 8px rgba(0,0,0,.6),inset 0 1px 0 rgba(255,255,255,.15);
}

/* ── Taban ── */
.clp-foot{
  position:relative;
  width:62%;height:8px;
  background:linear-gradient(to right,
    #1e293b 0%,#2d3f55 15%,#7b91a8 38%,
    #d0dce8 50%,#94a3b8 62%,#475569 80%,#1e293b 100%
  );
  border-radius:4px 4px 6px 6px;
  box-shadow:
    0 6px 16px rgba(0,0,0,.5),
    3px 0 5px rgba(0,0,0,.3),
    inset 0 1px 0 rgba(255,255,255,.24),
    inset 0 -1px 0 rgba(0,0,0,.4);
}
/* Taban rayı — zemin bağlantı plakası */
.clp-foot-plate{
  position:absolute;
  bottom:-3px;left:-6px;right:-6px;
  height:5px;
  background:linear-gradient(to right,
    #0f172a 0%,#1e293b 20%,#475569 50%,#1e293b 80%,#0f172a 100%
  );
  border-radius:2px 2px 4px 4px;
  box-shadow:0 3px 10px rgba(0,0,0,.55),inset 0 1px 0 rgba(255,255,255,.12);
}
/* Zemin gölgesi */
.clp-foot::after{
  content:'';
  position:absolute;
  bottom:-12px;left:50%;
  transform:translateX(-50%);
  width:200%;height:20px;
  background:radial-gradient(ellipse 75% 45% at 50% 0%,rgba(0,0,0,.28) 0%,transparent 100%);
  pointer-events:none;
}
.clp-info{width:100%;margin-top:.45rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);padding:.5rem .65rem;text-align:center;transition:all .2s;box-shadow:var(--sh0);display:flex;flex-direction:column;gap:.25rem;align-items:center}
.clp-card:hover .clp-info{border-color:var(--blue);box-shadow:0 0 0 3px rgba(37,99,235,.08)}
.clp-info-status{display:inline-flex;align-items:center;gap:.3rem;font-size:.65rem;font-weight:800;text-transform:uppercase;letter-spacing:.45px;color:var(--tx2)}
.clp-info-tenant{font-size:.68rem;font-weight:700;color:var(--bad);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
.clp-info-price{font-size:.88rem;font-weight:800;color:var(--blue)}

/* ===== CLP — DOKUNMATIK CİHAZLARDA 3D TILT DEVRE DIŞI =====
   pointer:coarse  → mobil, tablet gibi dokunmatik ekranlar.
   Hover geçişi ve will-change kaldırılır; scroll sırasında
   inline style set/unset yarattığı sönme/flicker önlenir.
========================================================= */
@media(pointer:coarse){
  .clp-structure{
    transition:none;
    will-change:auto;
  }
  .clp-card:hover .clp-structure{
    transform:rotateX(5deg) rotateY(-14deg);
    filter:drop-shadow(0 14px 26px rgba(0,0,0,.35));
  }
}

/* ===== LOKASYON HEADER MOBİL ===== */
@media(max-width:640px){
  .location-header{
    padding:.72rem .85rem .72rem .85rem;
    gap:.6rem;
    flex-wrap:wrap;
    align-items:center;
  }
  .loc-index{
    width:26px;height:26px;min-width:26px;
    font-size:.62rem;border-radius:7px;
  }
  .loc-title h4{font-size:.82rem;line-height:1.3}
  .loc-title p{font-size:.64rem}

  /* Trafik widget mobilde gizle — çok yer kaplıyor */
  .traffic-widget{ display:none }

  /* Badge'ler — satır sonu wrapper */
  .loc-badges{
    order:3;flex-basis:100%;
    margin-left:calc(26px + .6rem);
    gap:.25rem;flex-wrap:nowrap;
  }
  .loc-badges .badge{font-size:.6rem;padding:.16rem .45rem}
  .btn-sv{font-size:.62rem;padding:.2rem .46rem}

  /* Grid padding mobilde biraz daha az */
  .location-group .billboard-grid,
  .location-group .clp-grid{padding:.7rem}

  /* CLP şekil üstü yazılar — mobil */
  .clp-panel-body{padding:.38rem .42rem .34rem}
  .clp-type-badge{font-size:.44rem;padding:.1rem .28rem;letter-spacing:.25px}
  .clp-loc-name{font-size:.56rem;-webkit-line-clamp:2;letter-spacing:.15px}
  .clp-face-label{font-size:.48rem;padding:.08rem .24rem}
  .clp-status-pill{font-size:.44rem;padding:.1rem .28rem;letter-spacing:.2px}
  /* Info bölümü */
  .clp-info{padding:.38rem .48rem;gap:.16rem}
  .clp-info>*{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}
  .clp-info-price{font-size:.78rem}
  .clp-info-face{font-size:.82rem}
  .clp-info-loc,.clp-info-type,.clp-info-size,.clp-info-status,.clp-info-tenant{font-size:.62rem}
  .clp-arm{height:7px;width:38%}
  .clp-arm-bolt{width:10px;height:10px}
}

@media(max-width:380px){
  .location-header{padding:.65rem .75rem;gap:.5rem}
  .loc-title h4{font-size:.78rem}
  .billboard-grid{grid-template-columns:1fr}
  .clp-grid{grid-template-columns:repeat(2,1fr);gap:.5rem}
  .loc-badges{margin-left:0}
  .location-group .billboard-grid,
  .location-group .clp-grid{padding:.55rem}
}

/* ===== FIRMA LOKASYON BARLARI ===== */
.page-company .location-group{
  position:relative;
  overflow:hidden;
  padding-bottom:0;
  box-shadow:0 2px 12px rgba(15,23,42,.07),0 0 0 0 transparent;
}
.page-company .location-group + .location-group{
  margin-top:1.1rem;
}
.page-company .location-group + .location-group::before,
.page-company .location-group + .location-group::after{
  display:none;
}
.page-company .location-header{
  display:grid;
  grid-template-columns:auto minmax(0,1fr) auto auto;
  align-items:center;
  gap:.7rem .85rem;
  padding:.85rem 1.05rem;
  background:#fff;
  border-bottom:1px solid var(--border);
  position:relative;
}
.page-company .location-header::after{
  content:'';
  position:absolute;left:0;top:0;bottom:0;width:3px;
  background:linear-gradient(180deg,#60a5fa,#2563eb);
  border-radius:0 2px 2px 0;
}
.page-company .location-header::before{ display:none }
.page-company .location-header > *{ position:relative;z-index:1 }
.page-company .loc-index{
  width:32px;height:32px;min-width:32px;
  border-radius:10px;
  background:var(--sel-bg);
  border:1px solid var(--sel-b);
  color:var(--blue);
  font-size:.68rem;font-weight:900;letter-spacing:.04em;
}
.page-company .loc-title{ min-width:0 }
.page-company .loc-title h4{
  font-size:.88rem;font-weight:800;color:var(--tx);
  letter-spacing:-.01em;line-height:1.3;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.page-company .loc-title p{
  margin-top:.18rem;font-size:.67rem;
  color:var(--tx3);letter-spacing:.01em;
}
.page-company .traffic-widget{
  background:var(--s2);
  border-color:var(--border);
}
.page-company .loc-badges{ justify-content:flex-end;gap:.3rem }
.page-company .loc-badges .badge{
  padding:.2rem .52rem;border-radius:999px;font-size:.64rem;
}
.page-company .btn-sv{
  padding:.28rem .6rem;border-radius:8px;
  border-color:var(--border);background:var(--bg);color:var(--tx3);
  font-size:.65rem;
}
.page-company .btn-sv:hover{
  border-color:var(--blue);color:var(--blue);background:rgba(37,99,235,.05);
}
.page-company .inventory-eyebrow{
  background:rgba(37,99,235,.08);
  border-color:rgba(37,99,235,.14);
  color:var(--blue);
}

/* ===== FIRMA PANELI MOBIL IYILESTIRMELERI ===== */
@media(max-width:768px){
  .page-company{overflow-x:hidden}
  .page-company .main{padding:1.35rem 0 5rem}
  .page-company .navbar-inner{
    height:auto;
    padding:.9rem 1.25rem 1rem;
    display:grid;
    grid-template-columns:minmax(0,1fr) auto;
    gap:.75rem .85rem;
    align-items:center;
  }
  .page-company .nav-logo-mark{width:34px;height:34px;border-radius:9px;font-size:1rem}
  .page-company .nav-logo-text{font-size:1rem}
  .page-company .nav-logo-sub{display:none}
  .page-company .nav-loc-wrapper{
    grid-row:2;
    grid-column:1/-1;
    width:100%;
    min-width:0;
  }
  .page-company .nav-loc-btn{
    width:100%;
    gap:.6rem;
    padding:.72rem .9rem;
    border-radius:16px;
  }
  .page-company .nav-loc-pin,
  .page-company .nav-loc-chevron{flex-shrink:0}
  .page-company .nav-loc-city-lbl{font-size:.82rem}
  .page-company .nav-loc-dist-lbl{font-size:.71rem}
  .page-company .nav-loc-dropdown{
    left:0;
    right:0;
    transform:none;
    width:100%;
    max-width:100%;
    min-width:0;
    padding:0;
    border-radius:18px;
  }
  .page-company .nav-dd-body{padding:1rem}
  .page-company .nav-dd-overview{padding:.92rem .95rem}
  .page-company .nav-right{
    grid-row:1;
    grid-column:2;
    justify-self:end;
    gap:.5rem;
    max-width:100%;
  }
  .page-company .nav-user{
    min-width:0;
    max-width:min(48vw,220px);
    padding:.28rem .6rem .28rem .28rem;
  }
  .page-company .nav-avatar{width:30px;height:30px}
  .page-company .nav-user-name{
    max-width:calc(48vw - 2.6rem);
    font-size:.78rem;
  }
  .page-company .nav-right .btn{
    min-height:40px;
    padding:.55rem .8rem;
    border-radius:12px;
  }
  .page-company .dash-header{
    padding:1.25rem 0 1.35rem;
    margin-bottom:1.5rem;
  }
  .page-company .dash-title{font-size:1.2rem}
  .page-company .dash-sub{font-size:.76rem;line-height:1.5}
  .page-company .firm-tabs{
    margin-bottom:1.35rem;
    padding:.35rem;
    border-radius:18px;
    gap:.3rem;
    scroll-padding-inline:.25rem;
  }
  .page-company .firm-tab{
    min-height:44px;
    padding:.7rem .95rem;
  }
  .page-company .ctrl-bar{
    border-radius:18px;
    margin-bottom:.85rem;
  }
  .page-company .inventory-toolbar{
    padding:.6rem .62rem;
    border-radius:16px;
  }
  .page-company .ctrl-section{
    width:100%;
    min-width:0;
    padding:.66rem .78rem;
    align-items:flex-start;
    flex-wrap:wrap;
  }
  .page-company .ctrl-label{
    width:100%;
    margin-bottom:.1rem;
  }
  .page-company .ctrl-select,
  .page-company .ctrl-input{
    width:100%;
    min-height:38px;
  }
  .page-company .ctrl-select-sm{flex:1;min-width:0}
  .page-company .ctrl-right{
    width:100%;
    margin-left:0;
    padding:.66rem .78rem .74rem;
    flex-direction:column;
    align-items:flex-start;
    gap:.45rem;
  }
  .page-company .ctrl-legend{gap:.35rem .55rem}
  .page-company .ctrl-summary{white-space:normal}
  .page-company .ctrl-bar-filters{margin-bottom:0}
  .page-company .location-group + .location-group{ margin-top:.9rem }
  .page-company .location-group + .location-group::after{ display:none }
  .page-company .location-header{
    grid-template-columns:auto minmax(0,1fr) auto;
    align-items:center;
    gap:.6rem .75rem;
    padding:.75rem .85rem;
    border-radius:0;
  }
  .page-company .loc-index{
    grid-column:1;grid-row:1;
    align-self:center;
    width:28px;height:28px;min-width:28px;
    border-radius:8px;font-size:.62rem;
  }
  .page-company .loc-title{ grid-column:2;grid-row:1 }
  .page-company .loc-title h4{font-size:.82rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .page-company .loc-title p{font-size:.64rem}
  .page-company .traffic-widget{ display:none }
  .page-company .loc-badges{
    grid-column:3;grid-row:1;
    justify-content:flex-end;gap:.25rem;flex-wrap:nowrap;
  }
  .page-company .loc-badges .badge{ min-height:auto;padding:.16rem .42rem;font-size:.6rem }
  .page-company .btn-sv{ min-height:auto;padding:.22rem .48rem;font-size:.62rem }
  .page-company .billboard-grid{
    grid-template-columns:repeat(auto-fill,minmax(140px,1fr));
    gap:.75rem;
  }
  .page-company .req-headbar{align-items:stretch}
  .page-company #req-filter{
    width:100%!important;
    min-height:44px;
  }
  .page-company .req-card-head{
    padding:.9rem 1rem;
    gap:.65rem;
  }
  .page-company .req-item{
    flex-wrap:wrap;
    align-items:flex-start;
    padding:.7rem .8rem;
  }
  .page-company .req-item-name{
    width:100%;
    line-height:1.45;
  }
  .page-company .req-item-price{margin-left:auto}
  .page-company .summary-row,
  .page-company .summary-total{
    gap:.35rem .8rem;
    flex-wrap:wrap;
  }
  .page-company .modal-body{padding:1.25rem}
  .page-company .modal-footer{
    flex-wrap:wrap;
    padding:1rem 1.25rem calc(1rem + env(safe-area-inset-bottom));
  }
  .page-company .modal-footer .btn{
    flex:1 1 calc(50% - .35rem);
    min-height:44px;
  }
  .page-company .profile-tab-row{flex-wrap:wrap}
  .page-company .prof-tab{
    flex:1 1 calc(50% - .2rem);
    min-height:42px;
    text-align:center;
  }
  .page-company .record-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .page-company .record-actions .btn,
  .page-company .action-row .btn{min-height:42px}
  .page-company .sel-actions{width:100%}
  .page-company .sel-actions .btn{
    flex:1 1 0;
    min-height:44px;
  }
}

@media(max-width:560px){
  .inventory-toggle-text{
    font-size:.72rem;
  }
  .inventory-toggle-btn{
    gap:.45rem;
  }
  .loc-badges .btn-sv-label{display:none}
  .loc-badges .btn-sv{padding:.22rem .46rem}
  .page-company .navbar-inner{
    padding:.8rem 1rem .95rem;
    gap:.7rem;
  }
  .page-company .nav-user{max-width:44vw}
  .page-company .nav-user-name{max-width:calc(44vw - 2.6rem)}
  .page-company .nav-right .btn{
    padding:.55rem .72rem;
    font-size:.78rem;
  }
  .page-company .inventory-toolbar{
    padding:.55rem .58rem;
  }
  .page-company .firm-tab{padding:.68rem .85rem}
  .page-company .ftab-label{font-size:.78rem}
  .page-company .record-grid{grid-template-columns:1fr}
  .page-company .record-actions .btn,
  .page-company .action-row .btn,
  .page-company .modal-footer .btn,
  .page-company .prof-tab{
    flex:1 1 100%;
    width:100%;
  }
  .page-company .nav-dd-pill,
  .page-company .nav-dd-pill.is-district{flex:1 1 calc(50% - .25rem)}
  .page-company .nav-dd-label{margin-bottom:.6rem}
  .page-company .empty{padding:3rem 1rem}
  .page-company .location-header{ padding:.72rem .8rem;gap:.55rem .7rem }
  .page-company .traffic-widget{ display:none }
  .page-company .loc-badges .badge{ font-size:.6rem;padding:.15rem .4rem }
  .page-company .btn-sv{ padding:.2rem .44rem;font-size:.62rem }
}

@media(max-width:640px){
  .page-company .firm-tabs{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    overflow:visible;
    scrollbar-width:none;
  }
  .page-company .firm-tabs::-webkit-scrollbar{display:none}
  .page-company .firm-tab{
    width:100%;
    white-space:normal;
    text-align:center;
    align-items:center;
    justify-content:center;
    padding:.82rem .78rem;
    border-radius:16px;
  }
  .page-company .ftab-label{
    white-space:normal;
    line-height:1.2;
  }
  .page-company .firm-tab:last-child{grid-column:1/-1}
}

@media(max-width:380px){
  .page-company .navbar-inner{grid-template-columns:minmax(0,1fr)}
  .page-company .firm-tabs{grid-template-columns:1fr}
  .page-company .firm-tab:last-child{grid-column:auto}
  .page-company .nav-right{
    grid-column:1;
    grid-row:2;
    width:100%;
    justify-content:space-between;
  }
  .page-company .nav-loc-wrapper{grid-row:3}
  .page-company .nav-user{
    flex:1 1 0;
    max-width:none;
  }
  .page-company .nav-user-name{max-width:100%}
  .page-company .nav-right .btn{flex:0 0 auto}
  .page-company .location-header{ padding:.65rem .75rem }
  .page-company .loc-title h4{font-size:.78rem}
  .page-company .loc-title p{font-size:.62rem}
  .page-company .loc-badges{ grid-column:1/-1;grid-row:2;margin-left:calc(28px + .6rem) }
  .page-company .billboard-grid{grid-template-columns:1fr}
}

/* ===== AJANS PANELI MOBIL IYILESTIRMELERI ===== */
@media(max-width:768px){
  .page-agency{overflow-x:hidden}
  .page-agency .main{padding:1.35rem 0 5rem}
  .page-agency .navbar-inner{
    height:auto;
    padding:.9rem 1.25rem 1rem !important;
    display:grid;
    grid-template-columns:minmax(0,1fr) auto;
    gap:.75rem .85rem;
    align-items:center;
  }
  .page-agency .nav-logo-mark{width:34px;height:34px;border-radius:9px;font-size:1rem}
  .page-agency .nav-logo-text{font-size:1rem}
  .page-agency .nav-logo-sub{display:none}
  .page-agency .nav-loc-wrapper{
    grid-row:2;
    grid-column:1/-1;
    width:100%;
    min-width:0;
  }
  .page-agency .nav-loc-btn{
    width:100%;
    gap:.6rem;
    padding:.72rem .9rem;
    border-radius:16px;
  }
  .page-agency .nav-loc-city-lbl{font-size:.82rem}
  .page-agency .nav-loc-dist-lbl{font-size:.71rem}
  .page-agency .nav-loc-dropdown{
    left:0;
    right:0;
    transform:none;
    width:100%;
    max-width:100%;
    min-width:0;
    border-radius:18px;
  }
  .page-agency .nav-dd-body{padding:1rem}
  .page-agency .nav-dd-overview{padding:.92rem .95rem}
  .page-agency .nav-right{
    grid-row:1;
    grid-column:2;
    justify-self:end;
    gap:.5rem;
    max-width:100%;
  }
  .page-agency .nav-user{
    min-width:0;
    max-width:min(48vw,220px);
    padding:.28rem .6rem .28rem .28rem;
  }
  .page-agency .nav-avatar{width:30px;height:30px}
  .page-agency .nav-user-name{
    max-width:calc(48vw - 2.6rem);
    font-size:.78rem;
  }
  .page-agency .nav-right .btn{
    min-height:40px;
    padding:.55rem .8rem;
    border-radius:12px;
  }
  .page-agency .dash-header{
    padding:1.25rem 0 1.35rem;
    margin-bottom:1.5rem;
  }
  .page-agency .dash-title{font-size:1.2rem}
  .page-agency .dash-sub{font-size:.76rem;line-height:1.5}
  .page-agency .firm-tabs{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    overflow:visible;
    gap:.35rem;
    padding:.35rem;
    border-radius:18px;
  }
  .page-agency .firm-tab{
    width:100%;
    white-space:normal;
    text-align:center;
    align-items:center;
    justify-content:center;
    padding:.78rem .6rem;
    border-radius:16px;
    font-size:.79rem;
  }
  .page-agency .ftab-label{
    white-space:normal;
    line-height:1.2;
  }
  .page-agency .ftab-icon{display:none}
}

@media(max-width:560px){
  .page-agency .navbar-inner{
    padding:.8rem 1rem .95rem !important;
    gap:.7rem;
  }
  .page-agency .nav-user{max-width:44vw}
  .page-agency .nav-user-name{max-width:calc(44vw - 2.6rem)}
  .page-agency .nav-right .btn{
    padding:.55rem .72rem;
    font-size:.78rem;
  }
}

@media(max-width:480px){
  .page-agency .firm-tabs{grid-template-columns:repeat(2,minmax(0,1fr))}
}

@media(max-width:380px){
  .page-agency .navbar-inner{grid-template-columns:minmax(0,1fr) !important}
  .page-agency .firm-tabs{grid-template-columns:repeat(2,minmax(0,1fr))}
  .page-agency .nav-right{
    grid-column:1;
    grid-row:2;
    width:100%;
    justify-content:space-between;
  }
  .page-agency .nav-loc-wrapper{grid-row:3}
  .page-agency .nav-user{
    flex:1 1 0;
    max-width:none;
  }
  .page-agency .nav-user-name{max-width:100%}
  .page-agency .nav-right .btn{flex:0 0 auto}
}

/* ===== ADMIN / AGENCY PANEL — LOKASYON KART STİLLERİ ===== */
.page-agency .inventory-eyebrow{
  background:rgba(124,58,237,.08);
  border-color:rgba(124,58,237,.16);
  color:#7c3aed;
}
.page-agency .ctrl-bar-filters .ctrl-right{
  background:linear-gradient(135deg,#1e0a3c,#3b0764);
  border-color:rgba(168,85,247,.2);
}
/* Admin ve Agency de aynı premium çerçeve sistemini kullanır */
@media(max-width:768px){
  .page-admin .location-group,
  .page-agency .location-group{
    border-radius:var(--r);
    box-shadow:0 1px 6px rgba(0,0,0,.06);
  }
  .page-admin .location-header,
  .page-agency .location-header{
    padding:.72rem .85rem;
    gap:.6rem;
  }
  .page-admin .loc-index,
  .page-agency .loc-index{
    width:26px;height:26px;min-width:26px;
    border-radius:7px;font-size:.62rem;
  }
  .page-admin .loc-title h4,
  .page-agency .loc-title h4{ font-size:.82rem }
  .page-admin .loc-title p,
  .page-agency .loc-title p{ font-size:.64rem }
  .page-admin .traffic-widget,
  .page-agency .traffic-widget{ display:none }
  .page-admin .loc-badges,
  .page-agency .loc-badges{ gap:.25rem;flex-wrap:nowrap }
  .page-admin .loc-badges .badge,
  .page-agency .loc-badges .badge{ font-size:.6rem;padding:.15rem .42rem }
  .page-admin .btn-sv,
  .page-agency .btn-sv{ font-size:.62rem;padding:.2rem .46rem }
  .page-admin .billboard-grid,
  .page-agency .billboard-grid{
    grid-template-columns:repeat(auto-fill,minmax(140px,1fr));
    gap:.75rem;
  }
}

/* ===== PWA INSTALL CARD ===== */
.pwa-install-card{
  position:fixed;
  top:calc(80px + env(safe-area-inset-top));
  left:12px;
  right:12px;
  z-index:980;
  max-width:420px;
  margin:0 auto;
  padding:1rem;
  border-radius:22px;
  background:rgba(255,255,255,.96);
  border:1px solid rgba(15,23,42,.08);
  box-shadow:0 24px 50px rgba(15,23,42,.16);
  backdrop-filter:blur(16px);
}
.pwa-install-head{
  display:flex;
  align-items:flex-start;
  gap:.9rem;
}
.pwa-install-icon{
  width:52px;
  height:52px;
  border-radius:14px;
  flex:0 0 52px;
  box-shadow:0 10px 24px rgba(37,99,235,.18);
}
.pwa-install-copy{min-width:0;padding-right:1.5rem}
.pwa-install-title{
  font-size:.95rem;
  font-weight:900;
  color:var(--tx);
  letter-spacing:-.02em;
}
.pwa-install-text{
  margin:.28rem 0 0;
  font-size:.8rem;
  line-height:1.5;
  color:var(--tx2);
}
.pwa-install-actions{
  display:flex;
  gap:.55rem;
  margin-top:.95rem;
}
.pwa-install-actions .btn{
  flex:1 1 0;
  justify-content:center;
}
.pwa-install-hint{
  display:none;
  margin-top:.85rem;
  padding:.72rem .82rem;
  border-radius:16px;
  background:#eff6ff;
  border:1px solid #bfdbfe;
  color:#1e3a8a;
  font-size:.76rem;
  line-height:1.45;
  font-weight:600;
}
.pwa-install-card.show-hint .pwa-install-hint{display:block}
.pwa-install-close{
  position:absolute;
  top:10px;
  right:10px;
  width:32px;
  height:32px;
  border:none;
  border-radius:999px;
  background:#f8fafc;
  color:var(--tx3);
  font-size:1.15rem;
  line-height:1;
}
.pwa-install-close:hover{background:#eef2f7;color:var(--tx)}

@media(min-width:921px){
  .pwa-install-card{display:none!important}
}

@media(max-width:520px){
  .pwa-install-card{
    top:calc(76px + env(safe-area-inset-top));
    border-radius:20px;
    padding:.92rem;
  }
  .pwa-install-head{gap:.8rem}
  .pwa-install-icon{
    width:48px;
    height:48px;
    border-radius:12px;
    flex-basis:48px;
  }
  .pwa-install-actions{
    flex-direction:column;
  }
}
