/* =============================================
   KAMYON GARAJI — Global Stiller
   ============================================= */
*, *::before, *::after { box-sizing: border-box; }
body { font-family: 'Segoe UI', system-ui, sans-serif; color: #222; }
a { text-decoration: none; }

/* ---- Footer linkleri ---- */
.footer-link { color: rgba(255,255,255,.55); text-decoration: none; transition: color .15s; }
.footer-link:hover { color: #FFC107; }

/* ---- Panel Sidebar ---- */
.panel-sidebar { background: #1a1a2e; border-radius: 12px; }
.panel-sidebar .nav-link { color: rgba(255,255,255,.6); border-radius: 8px; margin-bottom: 3px; padding: 9px 12px; font-size: .87rem; transition: all .15s; }
.panel-sidebar .nav-link:hover  { background: rgba(255,255,255,.07); color: #fff; }
.panel-sidebar .nav-link.active { background: rgba(255,193,7,.15); color: #FFC107 !important; }
.panel-sidebar .nav-link i { width: 18px; }

/* ---- Admin Sidebar ---- */
.admin-sidebar .nav-link { border-radius: 6px; padding: 8px 12px; font-size: .88rem; }
.admin-sidebar .nav-link:hover  { background: rgba(255,255,255,.1); }
.admin-sidebar .nav-link.active { background: rgba(255,193,7,.2); color: #FFC107 !important; }

/* ---- Defter / Talep kartları ---- */
.defter-card { border-left: 3px solid #FFC107 !important; }
.talep-card  { border-left: 3px solid #3498db !important; }

/* ---- Firma profil doğrulandı rozeti ---- */
.verified-badge { color: #2196F3; font-size: .75rem; }

/* ---- Sayfa içeriği (statik sayfalar) ---- */
.page-content h2 { font-size: 1.4rem; font-weight: 700; margin-top: 1.5rem; }
.page-content p  { line-height: 1.9; color: #555; }
.page-content ul { line-height: 2;   color: #555; }

/* ---- Garaj TV ---- */
body.tv-mode { background: #000; color: #fff; overflow: hidden; height: 100vh; }
.tv-container { display: flex; flex-direction: column; height: 100vh; }
.tv-header { background: linear-gradient(90deg,#0a0a14,#1a1a2e); padding: 12px 20px; display: flex; align-items: center; gap: 20px; border-bottom: 3px solid #FFC107; flex-shrink: 0; }
.tv-logo  { font-size: 1.4rem; font-weight: 700; color: #FFC107; }
.tv-city  { font-size: 1.1rem; color: #aaa; }
.tv-clock { margin-left: auto; font-size: 1.4rem; font-weight: 700; font-variant-numeric: tabular-nums; color: #FFC107; }
.tv-ticker { background: #FFC107; color: #000; padding: 4px 16px; font-size: .85rem; font-weight: 600; white-space: nowrap; overflow: hidden; flex-shrink: 0; animation: tv-ticker 60s linear infinite; }
@keyframes tv-ticker { from { transform: translateX(100%); } to { transform: translateX(-100%); } }
.ticker-item { margin-right: 40px; }
.tv-body { display: grid; grid-template-columns: 1fr 1.2fr 1fr; gap: 12px; padding: 12px; flex: 1; min-height: 0; }
.tv-panel { background: rgba(255,255,255,.05); border-radius: 12px; border: 1px solid rgba(255,255,255,.1); display: flex; flex-direction: column; overflow: hidden; }
.tv-panel-header { background: rgba(255,193,7,.15); border-bottom: 1px solid rgba(255,193,7,.3); padding: 10px 16px; font-weight: 700; font-size: .95rem; flex-shrink: 0; }
.tv-list { overflow-y: auto; flex: 1; }
.tv-list::-webkit-scrollbar { width: 4px; }
.tv-list::-webkit-scrollbar-thumb { background: rgba(255,255,255,.2); border-radius: 2px; }
.tv-item { padding: 10px 16px; border-bottom: 1px solid rgba(255,255,255,.07); }
.tv-item.active { background: rgba(255,193,7,.12); }
.tv-route { font-size: 1rem; font-weight: 600; margin-bottom: 4px; }
.tv-meta  { display: flex; gap: 12px; font-size: .8rem; color: #aaa; flex-wrap: wrap; }
.tv-meta .price { color: #2ecc71; font-weight: 600; }
.tv-time  { font-size: .75rem; color: #666; margin-top: 4px; }
.tv-ad    { border-radius: 8px; overflow: hidden; background: #111; }
.tv-ad img { width: 100%; max-height: 280px; object-fit: cover; }
.tv-footer { background: #111; border-top: 2px solid #FFC107; padding: 8px 20px; display: flex; justify-content: space-between; align-items: center; font-size: .85rem; color: #888; flex-shrink: 0; }
