*{box-sizing:border-box}
:root{--bg:#eef4ff;--card:#ffffff;--text:#111827;--muted:#64748b;--line:#d9e2f2;--brand:#3469b7;--brand-dark:#2e5fa7;--brand-light:#5f8dd2;--danger:#dc2626;--success:#166534;--shadow:0 14px 34px rgba(29,48,87,.12)}
html,body{margin:0;padding:0;font-family:Inter,Arial,sans-serif;background:var(--bg);color:var(--text)}
body{min-height:100vh}
body.sidebar-open,body.modal-open{overflow:hidden}
a{color:inherit}
img,video{max-width:100%;display:block}
button,input,select,textarea{font:inherit}
.app-shell{display:flex;min-height:100vh;position:relative}
.app-shell.with-sidebar{background:linear-gradient(90deg,var(--brand) 0 290px,var(--bg) 290px 100%)}
.sidebar{width:290px;background:linear-gradient(180deg,var(--brand) 0%,var(--brand-dark) 100%);color:#fff;padding:26px 22px calc(34px + env(safe-area-inset-bottom));display:block;box-shadow:inset -1px 0 0 rgba(255,255,255,.12);height:100dvh;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}
.sidebar{position:relative}
.sidebar-mobile-logo-slot{display:none}.sidebar-mobile-logo{display:block;max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;filter:drop-shadow(0 8px 24px rgba(15,23,42,.18))}
.sidebar-inner{display:flex;flex-direction:column;min-height:100%;gap:18px}.brand{font-size:22px;font-weight:400;letter-spacing:.2px;margin-bottom:0}
.user-card{display:flex;flex-direction:column;gap:6px;padding:16px;border-radius:20px;background:rgba(255,255,255,.12);margin-bottom:18px;backdrop-filter:blur(6px)}
.user-card strong{font-size:17px}.user-card span{font-size:13px;color:#dbeafe;text-transform:capitalize}
.nav-links{display:flex;flex-direction:column;gap:18px;min-width:0}
.nav-section{display:flex;flex-direction:column;gap:8px}
.nav-section-title{font-size:12px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:#f8fafc;padding:0 8px 6px;border-bottom:1px solid rgba(255,255,255,.28)}
.nav-links a,.logout-link{text-decoration:none;color:#eef6ff;padding:12px 14px;border-radius:16px;transition:.2s;background:rgba(255,255,255,.05);border:1px solid transparent;word-break:break-word}
.nav-links a:hover,.logout-link:hover,.nav-links a:focus-visible,.logout-link:focus-visible,.nav-links a.active{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.24);outline:none}
.logout-link{display:block;text-align:center;font-weight:700;background:rgba(255,255,255,.14);backdrop-filter:blur(6px);box-shadow:0 12px 28px rgba(8,15,35,.18)}
.mobile-nav-toggle,.sidebar-overlay{display:none}
.sidebar::-webkit-scrollbar{width:10px}
.sidebar::-webkit-scrollbar-thumb{background:rgba(255,255,255,.28);border-radius:999px}
.main-content{flex:1;padding:28px;min-width:0}
.page-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:22px;gap:16px;flex-wrap:wrap}.page-head h1{margin:0 0 8px;font-size:30px;color:#12233f}.page-head p{margin:0;color:#51627e;line-height:1.6;max-width:900px}
.card{background:var(--card);border-radius:24px;padding:22px;box-shadow:var(--shadow);min-width:0;border:1px solid rgba(52,105,183,.08)}
.main-content .card + .card{margin-top:18px}
.card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px;gap:12px;flex-wrap:wrap}.card-head h2{margin:0;font-size:20px;color:#173159}
.hero-card{display:flex;justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap}
.stats-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px;margin-bottom:22px}.stats-grid-mini{margin-top:-4px}
.stat-card{background:var(--card);border-radius:22px;padding:22px;box-shadow:var(--shadow);border:1px solid rgba(52,105,183,.08);min-width:0}.stat-card span{display:block;color:var(--muted);font-size:14px;margin-bottom:10px}.stat-card strong{font-size:32px;color:#12233f;line-height:1.1}
.inline-link{font-size:18px;color:var(--brand-dark);text-decoration:none}
.grid-two{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:18px}
.stack-form{display:flex;flex-direction:column;gap:12px}.stack-form label{font-weight:700;color:#334155;font-size:14px}
.stack-form input,.stack-form select,.stack-form textarea{width:100%;border:1px solid #c9d7eb;border-radius:16px;padding:14px 16px;font-size:15px;background:#fff;color:#0f172a;outline:none;min-width:0}.stack-form input:focus,.stack-form select:focus,.stack-form textarea:focus{border-color:var(--brand);box-shadow:0 0 0 4px rgba(52,105,183,.12)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:0;border-radius:16px;padding:14px 18px;font-weight:800;cursor:pointer;text-decoration:none;white-space:normal;text-align:center;line-height:1.3}.btn.primary{background:var(--brand);color:#fff}.btn.dark{background:#173159;color:#fff}.btn.muted{background:#e6edf8;color:#173159}.btn.danger{background:var(--danger);color:#fff}.btn.big{min-height:58px;font-size:16px}.btn.huge{min-height:64px;padding:18px 26px;font-size:18px}.btn.compact{padding:10px 14px;border-radius:12px;font-size:13px}.full-btn{width:100%}
.button-row{display:flex;gap:12px;flex-wrap:wrap;align-items:center}.top-gap{margin-top:18px}.top-card-gap{margin-top:18px}
.table-wrap{overflow:auto;border:1px solid #dce6f4;border-radius:18px;max-width:100%}.table-wrap.max-h{max-height:560px}table{width:100%;min-width:720px;border-collapse:collapse;background:#fff}th,td{padding:14px;border-bottom:1px solid #e6edf8;text-align:left;font-size:14px;color:#0f172a;vertical-align:top;word-break:break-word}th{background:#f7faff;position:sticky;top:0;z-index:1}
.status-pill{display:inline-flex;padding:6px 12px;border-radius:999px;font-weight:700;text-transform:capitalize}.status-pill.active{background:#dcfce7;color:#166534}.status-pill.completed{background:#e2e8f0;color:#334155}
.mini-list{display:flex;flex-direction:column;gap:12px;min-width:0}.mini-item{display:flex;justify-content:space-between;gap:12px;background:#f7faff;padding:14px 16px;border-radius:16px;color:#0f172a;min-width:0}.mini-item span{color:var(--muted);font-size:13px}.stacked-item{flex-direction:column;align-items:flex-start}.stacked-item span{font-size:13px}.large-list{max-height:480px;overflow:auto}
.alert{padding:16px 18px;border-radius:18px;margin-bottom:18px;font-weight:700}.alert.success{background:#dcfce7;color:#166534}.alert.error{background:#fee2e2;color:#991b1b}
.login-wrap{display:flex;min-height:100vh;align-items:center;justify-content:center;padding:30px}.login-card{width:min(100%,540px);background:#fff;padding:32px;border-radius:30px;box-shadow:0 30px 70px rgba(15,23,42,.15)}
html.login-page,body.login-page{min-height:100%;overflow-x:hidden;overflow-y:auto;overscroll-behavior:auto}
.login-page{position:static;inset:auto;width:auto;height:auto;min-height:100%;overflow-x:hidden;overflow-y:auto;overscroll-behavior:auto;-webkit-overflow-scrolling:touch;touch-action:auto}
.login-page .app-shell{position:relative;inset:auto;min-height:100vh;height:auto;overflow:visible}
.login-page .main-content{display:block;padding:0;overflow:visible;height:auto}
.login-page .login-wrap{width:100%;min-height:100vh;height:auto;padding:18px 16px 28px;overflow:visible;align-items:flex-start;justify-content:center}
.login-page .login-card{margin:0 auto;width:min(100%,640px);max-height:none}
.title-block h1{margin:12px 0 8px;font-size:34px;color:#0f172a}.title-block p{margin:0 0 22px;color:#475569;line-height:1.6}.badge{display:inline-flex;padding:8px 14px;border-radius:999px;background:#dbeafe;color:#1d4ed8;font-weight:800}.badge-line{display:inline-flex;padding:10px 16px;border-radius:999px;background:#ddeafd;color:#2454a6;font-weight:800;margin-bottom:16px}
.test-box{margin-top:18px;background:#f8fafc;border-radius:18px;padding:16px;color:#334155;display:grid;gap:6px}
.center-card{text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:flex-start}
.qr-box{width:264px;min-height:264px;border-radius:24px;background:#fff;display:flex;align-items:center;justify-content:center;margin:18px auto 0;padding:12px;box-shadow:inset 0 0 0 1px #e2e8f0}.qr-box-large{width:min(100%,380px);min-height:380px;padding:18px;background:#f8fbff}.qr-box img{max-width:100%;height:auto}
.qr-meta{margin-top:14px;color:#475569}.countdown{margin-top:14px;font-size:18px;font-weight:800;color:#2454a6}.qr-focus-card{gap:10px}.qr-color-panel{width:100%;max-width:420px;background:#f7faff;border:1px solid #d9e5f7;border-radius:18px;padding:14px 16px;margin-top:8px;text-align:left}.qr-color-row{display:flex;align-items:center;gap:12px}.qr-color-row input{width:58px;height:42px;padding:4px;border-radius:12px}.qr-modal[hidden]{display:none !important}.qr-modal{position:fixed;inset:0;z-index:10000}.qr-modal-backdrop{position:absolute;inset:0;background:rgba(15,23,42,.28)}.qr-modal-screen{position:relative;z-index:1;min-height:100dvh;min-height:100vh;width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:28px 18px 34px;text-align:center}.qr-modal-close{position:fixed;right:18px;top:18px;width:58px;height:58px;border-radius:999px;border:0;background:rgba(15,23,42,.88);color:#fff;font-size:38px;line-height:1;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 16px 34px rgba(15,23,42,.28);cursor:pointer;z-index:2}.qr-modal-head{width:min(100%,560px);margin:0 auto 14px}.qr-modal-head h2{font-size:clamp(28px,5vw,42px);margin:8px 0 6px;color:#0f172a}.qr-modal-head p{margin:0;color:#334155;font-size:18px;font-weight:600}.qr-modal-meta{font-size:18px;font-weight:700;color:#1e293b}.qr-modal-box{margin-top:18px;margin-bottom:0;background:rgba(255,255,255,.96);box-shadow:0 18px 60px rgba(15,23,42,.16)}.qr-modal-countdown{font-size:26px;color:#0f172a;margin-top:18px}.qr-modal .badge-line{background:rgba(255,255,255,.66);color:#0f172a}
.personnel-grid,.review-grid,.driver-grid,.admin-grid,.audio-grid{align-items:start}.grid-form,.trip-start-form{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:14px}.form-full{grid-column:1/-1}
.top-note{color:#51627e;line-height:1.6}
.vehicle-card{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:14px}.vehicle-card.single-column{grid-template-columns:1fr}.vehicle-card>div{background:#f7faff;padding:16px;border-radius:18px;display:flex;flex-direction:column;gap:8px;min-width:0}.label-chip{display:inline-flex;align-self:flex-start;padding:7px 12px;border-radius:999px;background:#dbeafe;color:#1d4ed8;font-weight:800;font-size:12px}
.soft-line{border:0;border-top:1px solid #e2e8f0;margin:8px 0}
.review-listing{display:grid;gap:18px}.review-card{display:grid;gap:16px}.review-head{display:flex;justify-content:space-between;gap:18px;align-items:flex-start;flex-wrap:wrap}.review-head h2{margin:0 0 8px;font-size:20px}.review-head p{margin:0 0 6px;color:#475569}.rating-badge{padding:12px 16px;border-radius:16px;background:#fff7ed;color:#c2410c;font-weight:800;white-space:nowrap}.review-text{line-height:1.7;color:#1f2937;background:#f8fafc;border-radius:18px;padding:16px}.review-media{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.media-link img,.video-wrap video,.media-thumb img,.media-thumb video{width:100%;height:260px;object-fit:cover;border-radius:18px;border:1px solid #e2e8f0;background:#000}.video-wrap small{display:block;margin-top:8px;color:#475569}.media-thumb{position:relative;border:0;padding:0;background:transparent;cursor:pointer}.media-chip{position:absolute;right:12px;bottom:12px;background:rgba(15,23,42,.82);color:#fff;padding:6px 10px;border-radius:999px;font-size:12px;font-weight:700}
.quick-links-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.quick-link-card{display:flex;flex-direction:column;gap:8px;padding:18px;border-radius:18px;background:#f8fafc;text-decoration:none;color:#0f172a;border:1px solid #e2e8f0;min-width:0}.quick-link-card span{color:#64748b;font-size:14px}
.filter-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.compact-form{gap:10px}.soft-panel{background:#f8fafc;box-shadow:none;border:1px solid #e2e8f0}.manager-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:14px;align-items:start}
.media-modal[hidden]{display:none !important}
.media-modal{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;padding:18px}.media-modal-backdrop{position:absolute;inset:0;background:rgba(2,6,23,.82)}.media-modal-content{position:relative;z-index:1;width:min(100%,960px);background:#0f172a;border-radius:28px;padding:22px;box-shadow:0 24px 70px rgba(0,0,0,.35)}.media-modal-content img,.media-modal-content video{width:100%;max-height:75vh;object-fit:contain;border-radius:18px;background:#000}.modal-close{position:absolute;right:18px;top:18px;width:42px;height:42px;border-radius:999px;border:0;background:#fff;color:#0f172a;font-size:28px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;line-height:1}
.live-badge{display:inline-flex;align-items:center;justify-content:center;padding:12px 16px;border-radius:999px;background:#dcfce7;color:#166534;font-weight:800}.live-trip-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.live-trip-card{padding:18px;border-radius:22px;background:#f8fafc;border:1px solid #e2e8f0;min-width:0}.live-trip-top{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-bottom:8px}.live-trip-route{font-weight:700;color:#0f172a;margin:10px 0}.live-trip-metrics{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.live-trip-metrics div{padding:12px;border-radius:16px;background:#fff;border:1px solid #e2e8f0}.live-trip-metrics span{display:block;color:#64748b;font-size:12px;margin-bottom:4px}.live-trip-metrics strong{font-size:18px}.compact-reviews{gap:12px}.compact-review-row{display:flex;justify-content:space-between;gap:14px;align-items:center;padding:16px;background:#f8fafc;border-radius:18px}.review-manager-card .review-media{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}
.scanner-stats{grid-template-columns:repeat(4,minmax(0,1fr))}.audio-card audio{width:100%}.audio-preview-box{display:flex;flex-direction:column;gap:12px;padding:16px;border-radius:18px;background:#f8fafc;border:1px solid #e2e8f0}.inline-check{display:flex;align-items:center;gap:10px;font-weight:700;color:#334155}.inline-check input{width:auto}
.reader-box{width:100%;min-height:320px;border:2px dashed #c8d7ee;border-radius:24px;overflow:hidden;background:#0f172a}.reader-box-large{min-height:560px;border-style:solid;border-color:#d6e1f3;background:#0b1220}.reader-box section{border-radius:24px;overflow:hidden}
.scan-result{margin-top:16px;padding:16px;border-radius:18px;font-weight:800}.scan-result.idle{background:#e8eef8;color:#334155}.scan-result.success{background:#dcfce7;color:#166534}.scan-result.error{background:#fee2e2;color:#991b1b}
.manual-box{margin-top:20px;display:flex;flex-direction:column;gap:10px}.manual-box label{font-weight:700}.subtle-box{background:#f7faff;border:1px solid #d9e6f8;border-radius:18px;padding:14px 16px}.subtle-box summary{cursor:pointer;font-weight:800;color:#173159;list-style:none;display:flex;align-items:center;justify-content:space-between;gap:12px}.subtle-box summary::-webkit-details-marker{display:none}.subtle-box[open] summary{margin-bottom:14px}.review-summary-bar{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}.review-count-badge{display:inline-flex;align-items:center;justify-content:center;padding:10px 14px;border-radius:999px;background:#ddeafd;color:#214889;font-weight:800}.empty-state{padding:20px;border-radius:18px;background:#f7faff;border:1px dashed #c8d8f2;color:#51627e}
.scanner-page-head{margin-bottom:16px}.scanner-focus-card{display:grid;gap:16px}.scanner-route-strip{display:grid;grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);gap:12px;align-items:center}.scanner-route-box{background:#f7faff;border:1px solid #dbe4f4;border-radius:20px;padding:18px 20px;min-width:0}.scanner-route-box span{display:block;color:var(--muted);font-size:13px;margin-bottom:6px}.scanner-route-box strong{font-size:24px;color:#153260;word-break:break-word}.scanner-arrow{display:flex;align-items:center;justify-content:center;font-size:34px;font-weight:900;color:var(--brand-dark);background:transparent;border:0;padding:0}.scanner-bottom-bar{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}.scanner-seat-box{background:#f7faff;border:1px solid #dbe4f4;border-radius:20px;padding:16px 18px;display:flex;flex-direction:column;gap:6px}.scanner-seat-box span{color:var(--muted);font-size:13px}.scanner-seat-box strong{font-size:34px;color:#153260}.scanner-seat-box small{color:#51627e}
.info-box{padding:14px 16px;border-radius:16px;background:#f8fafc;border:1px solid #e2e8f0;color:#334155;line-height:1.7}.info-box code{background:#eef2ff;border-radius:8px;padding:2px 6px}.muted-text{color:#64748b}

@media (max-width:1200px){.stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-two,.grid-form,.trip-start-form,.vehicle-card,.review-media,.manager-grid,.quick-links-grid,.live-trip-grid,.filter-grid{grid-template-columns:1fr}.scanner-route-strip{grid-template-columns:1fr}.scanner-arrow{transform:rotate(90deg);justify-self:center}.live-trip-metrics{grid-template-columns:1fr 1fr 1fr}}
@media (max-width:980px){.app-shell.with-sidebar{background:var(--bg)}.mobile-nav-toggle{display:inline-flex;position:fixed;left:14px;top:14px;z-index:1002;width:48px;height:48px;border-radius:14px;border:0;background:var(--brand);color:#fff;font-size:24px;align-items:center;justify-content:center;box-shadow:var(--shadow)}.sidebar-overlay{display:block;position:fixed;inset:0;background:rgba(15,23,42,.45);opacity:0;pointer-events:none;transition:.2s;z-index:1000}.sidebar-overlay.is-open{opacity:1;pointer-events:auto}.sidebar{position:fixed;left:0;top:0;bottom:0;transform:translateX(-100%);transition:.22s ease;z-index:1001;max-width:88vw;width:min(88vw,320px);padding-top:86px;padding-bottom:28px;overflow-y:auto}.sidebar.is-open{transform:translateX(0)}.sidebar-mobile-logo-slot{display:flex;align-items:center;justify-content:center;position:absolute;top:14px;left:76px;right:22px;height:56px;padding:8px 12px;border-radius:20px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);backdrop-filter:blur(8px)}.sidebar-mobile-logo{width:100%;height:100%}.sidebar .brand-logo{display:none}.sidebar .brand-block{padding-top:4px}.main-content{width:100%;padding:78px 18px 18px}.page-head h1{font-size:24px}.reader-box-large{min-height:420px}.scanner-bottom-bar{align-items:stretch}.scanner-seat-box,.scanner-bottom-bar .button-row{width:100%}}
@media (max-width:720px){.stats-grid,.scanner-stats{grid-template-columns:1fr}.hero-card,.review-head,.compact-review-row,.page-head{flex-direction:column;align-items:flex-start}.table-wrap{border-radius:16px}.card{padding:18px;border-radius:22px}.button-row{width:100%}.button-row .btn,.button-row a{flex:1 1 auto}.scanner-route-box strong{font-size:20px}.scanner-seat-box strong{font-size:30px}.qr-box-large{min-height:320px;width:min(100%,330px)}.reader-box-large{min-height:360px}.qr-color-row{align-items:flex-start;flex-direction:column}.qr-modal-screen{padding:76px 16px 30px}.qr-modal-close{right:14px;top:14px;width:52px;height:52px;font-size:34px}.qr-modal-head h2{font-size:34px}.qr-modal-head p,.qr-modal-meta{font-size:16px}.qr-modal-countdown{font-size:22px}}

/* Personnel page refinements */
.top-actions{justify-content:flex-end}.compact-top-gap{margin-top:20px}.personnel-stats-grid{margin-bottom:20px}.quick-menu-card{height:100%}.quick-menu-grid{display:grid;grid-template-columns:1fr;gap:12px}.quick-menu-item{display:block;text-decoration:none;background:#f7faff;border:1px solid #d9e5f7;border-radius:18px;padding:16px 18px;color:#173159;transition:.2s}.quick-menu-item strong{display:block;font-size:16px;margin-bottom:4px}.quick-menu-item span{display:block;color:#475569;line-height:1.45}.quick-menu-item:hover,.quick-menu-item:focus-visible{transform:translateY(-1px);box-shadow:0 10px 24px rgba(36,84,166,.08);outline:none}.danger-soft{background:#fff5f5;border-color:#ffd0d0;color:#8f1d1d}.stack-list{display:flex;flex-direction:column;gap:12px}.summary-row{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;padding:14px 16px;background:#f8fbff;border:1px solid #deebfb;border-radius:18px}.summary-side{display:flex;flex-direction:column;align-items:flex-end;gap:6px}.mini-meta{font-size:13px;color:#64748b}.empty-note{padding:18px;border:1px dashed #d5e3f7;border-radius:18px;color:#475569;background:#f8fbff}.qr-refresh-btn{margin-top:18px;min-width:min(100%,340px)}.large-table-wrap table td:last-child{min-width:220px;white-space:normal}.personnel-grid .card{height:100%}@media (max-width:720px){.top-actions{width:100%;justify-content:stretch}.top-actions .btn,.top-actions a{flex:1 1 100%}.summary-row{flex-direction:column}.summary-side{align-items:flex-start;width:100%}.large-table-wrap table td:last-child{min-width:180px}}


/* Driver scanner modal */
.scanner-management-grid{align-items:start}
.scanner-summary-list{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
.scanner-summary-list .mini-item{height:100%}
.scanner-modal[hidden]{display:none !important}
.scanner-modal{position:fixed;inset:0;z-index:9998}
.scanner-modal-backdrop{position:absolute;inset:0;background:rgba(2,6,23,.72);backdrop-filter:blur(3px)}
.scanner-modal-dialog{position:relative;z-index:1;min-height:100dvh;width:100%;display:flex;flex-direction:column;justify-content:space-between;gap:18px;padding:22px;background:linear-gradient(180deg,#eef4ff 0%,#dbe8ff 100%)}
.scanner-modal-top{padding:8px 72px 0 8px}
.scanner-trip-line{display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap;font-size:clamp(24px,3vw,40px);font-weight:900;color:#10213e;text-align:center}
.scanner-trip-line span{color:var(--brand-dark);font-size:1.05em}
.scanner-trip-subline{text-align:center;color:#385277;font-weight:700;margin-top:10px;font-size:14px}
.scanner-modal-reader{flex:1;min-height:52vh;max-width:min(100%,920px);margin:0 auto;width:100%;border-width:3px;box-shadow:0 24px 70px rgba(16,33,62,.16)}
.scanner-modal-bottom{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;flex-wrap:wrap}
.scanner-seat-box-modal{background:#fff;border-color:#cddcf5;box-shadow:0 16px 40px rgba(26,54,104,.12)}
.scanner-modal-actions{justify-content:flex-end}
.scanner-modal-close{position:absolute;right:18px;top:18px;width:58px;height:58px;border-radius:999px;border:0;background:#fff;color:#0f172a;font-size:40px;line-height:1;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 16px 40px rgba(15,23,42,.18)}

/* Panel lists side-by-side */
.mini-list.large-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;align-content:start}
.review-listing.compact-reviews{grid-template-columns:repeat(2,minmax(0,1fr))}
.stack-list.review-summary-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.summary-row{height:100%}

@media (max-width:1200px){
  .scanner-summary-list{grid-template-columns:1fr}
  .mini-list.large-list,.review-listing.compact-reviews,.stack-list.review-summary-list{grid-template-columns:1fr}
}
@media (max-width:720px){
  .scanner-modal-dialog{padding:16px 16px 20px}
  .scanner-modal-top{padding-right:60px}
  .scanner-trip-line{font-size:24px;gap:10px}
  .scanner-modal-reader{min-height:44vh}
  .scanner-modal-bottom{align-items:stretch}
  .scanner-seat-box-modal,.scanner-modal-actions{width:100%}
  .scanner-modal-actions .btn{flex:1 1 auto}
  .scanner-modal-close{right:12px;top:12px;width:52px;height:52px;font-size:34px}
}

/* 2026-04-11 refinements */
html,body{overflow-x:hidden;max-width:100%}
.sidebar{overflow-x:hidden}
.nav-links a,.logout-link{display:block}
.nav-section-logout{margin-top:auto;padding-top:6px}
.qr-modal,.scanner-modal{overflow:hidden}
.qr-modal-screen,.scanner-modal-dialog{max-height:100dvh;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}
.qr-modal-screen{padding-bottom:110px}
.qr-box,.reader-box,.qr-modal-box,.scanner-modal-reader{max-width:100%}
.qr-refresh-btn{position:fixed;left:50%;bottom:max(16px,calc(env(safe-area-inset-bottom) + 12px));transform:translateX(-50%);z-index:3;width:min(calc(100% - 32px),360px);margin-top:0}

.review-accordion{padding:0;overflow:hidden}
.review-accordion + .review-accordion{margin-top:18px}
.review-accordion-summary{list-style:none;cursor:pointer;padding:20px 22px;display:flex;align-items:center;justify-content:space-between;gap:16px}
.review-accordion-summary::-webkit-details-marker{display:none}
.review-accordion-summary:hover{background:#f8fbff}
.review-accordion-summary-main{display:flex;flex-direction:column;gap:6px;min-width:0}
.review-accordion-summary-main h2,.review-accordion-summary-main h3{margin:0;font-size:20px;color:#173159}
.review-accordion-summary-main p{margin:0;color:#51627e;line-height:1.5;word-break:break-word}
.review-accordion-summary-side{display:flex;flex-direction:column;align-items:flex-end;gap:10px;flex-shrink:0}
.review-accordion-toggle{display:inline-flex;align-items:center;justify-content:center;padding:10px 14px;border-radius:999px;background:#e8f0fd;color:#214889;font-weight:800;font-size:13px;white-space:nowrap}
.review-accordion[open] .review-accordion-toggle{background:#173159;color:#fff}
.review-accordion-body{padding:0 22px 22px}
.review-accordion-body > .review-text:first-child{margin-top:0}
.review-accordion-body .manager-grid,.review-accordion-body .button-row{margin-top:18px}
.review-status-text{display:inline-flex;align-items:center;justify-content:center;padding:8px 12px;border-radius:999px;background:#eff6ff;color:#1d4ed8;font-weight:700;font-size:13px}
.review-status-text.pending{background:#fff7ed;color:#c2410c}
.review-status-text.muted{background:#f1f5f9;color:#475569}
.review-summary-link{display:flex;text-decoration:none;color:inherit}
.review-summary-link .summary-row{width:100%}
.compact-review-row-link{display:block;text-decoration:none;color:inherit}
.compact-review-row-link .compact-review-row{height:100%;transition:.2s}
.compact-review-row-link:hover .compact-review-row,.review-summary-link:hover .summary-row{transform:translateY(-1px);box-shadow:0 12px 26px rgba(36,84,166,.08)}
.personnel-info-card .info-box + .info-box{margin-top:12px}
.review-detail-stack{display:flex;flex-direction:column;gap:14px}
.review-detail-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.review-detail-item{padding:14px 16px;border-radius:18px;background:#f8fbff;border:1px solid #deebfb}
.review-detail-item span{display:block;color:#64748b;font-size:13px;margin-bottom:4px}
.review-detail-item strong{display:block;color:#173159;word-break:break-word}

@media (max-width:720px){
  .qr-modal-screen{padding:76px 14px 104px}
  .qr-box-large{width:min(100%,280px);min-height:280px}
  .reader-box-large{min-height:320px}
  .scanner-modal-reader{min-height:38vh;max-height:44vh}
  .review-accordion-summary{padding:18px}
  .review-accordion-summary,.review-accordion-summary-side{align-items:flex-start}
  .review-accordion-summary{flex-direction:column}
  .review-accordion-summary-side{width:100%}
  .review-accordion-toggle{width:100%}
  .review-accordion-body{padding:0 18px 18px}
  .review-detail-grid{grid-template-columns:1fr}
}

/* 2026-04-11 detail, live and report improvements */
.login-logo{display:block;width:min(100%,220px);height:auto;margin:0 auto 16px}
.live-trip-link,.live-mini-link,.detail-link-row{text-decoration:none;color:inherit}
.live-trip-link:hover,.live-trip-link:focus-visible,.live-mini-link:hover,.detail-link-row:hover{transform:translateY(-1px);box-shadow:0 14px 28px rgba(36,84,166,.10);outline:none}
.detail-hero{background:linear-gradient(180deg,#ffffff 0%,#f7fbff 100%)}
.detail-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;flex-wrap:wrap}
.detail-title-row h2{margin:0;color:#173159;font-size:28px}
.detail-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}
.detail-box{background:#f8fbff;border:1px solid #dceafb;border-radius:20px;padding:16px 18px}
.detail-box span{display:block;color:#64748b;font-size:13px;margin-bottom:6px}
.detail-box strong{display:block;color:#173159;word-break:break-word}
.detail-stack-list{display:flex;flex-direction:column;gap:12px}
.detail-list-row{display:block;background:#f8fbff;border:1px solid #deebfb;border-radius:18px;padding:14px 16px;color:#173159}
.detail-list-row strong{display:block;margin-bottom:4px}
.detail-list-row span{display:block;color:#52637e;line-height:1.5;white-space:pre-line}
.report-group-list{display:flex;flex-direction:column;gap:18px}
.report-group-card .report-group-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap}
.report-group-card h2{margin:4px 0 6px;font-size:24px}
.report-group-card h2 a{text-decoration:none;color:#173159}
.report-group-card p{margin:0;color:#52637e}
.report-group-actions{display:flex;gap:10px;flex-wrap:wrap}
.report-summary-grid{grid-template-columns:repeat(4,minmax(0,1fr))}
.button-row-wrap{flex-wrap:wrap}
@media (max-width:980px){.detail-grid,.report-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:720px){.detail-title-row h2{font-size:22px}.detail-grid,.report-summary-grid{grid-template-columns:1fr}.report-group-card .report-group-head,.report-group-actions{width:100%}.report-group-actions .btn{flex:1 1 auto}}


/* 2026-04-11 management modals and professional cards */
.management-shell{display:flex;flex-direction:column;gap:18px}
.management-toolbar{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap}
.management-toolbar .button-row{margin:0}
.management-stat-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}
.management-section{display:flex;flex-direction:column;gap:14px}
.management-section-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;flex-wrap:wrap}
.management-section-head h2{margin:0;color:#173159;font-size:24px}
.management-section-head p{margin:4px 0 0;color:#5b6b84}
.management-card-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}
.management-card{background:#fff;border:1px solid #dbe7f8;border-radius:24px;padding:18px;box-shadow:0 12px 28px rgba(32,67,129,.08);display:flex;flex-direction:column;gap:14px;min-width:0}
.management-card:hover{box-shadow:0 16px 36px rgba(32,67,129,.11)}
.management-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.management-card-head h3{margin:0;color:#173159;font-size:20px;line-height:1.25}
.management-card-head p{margin:6px 0 0;color:#607089;line-height:1.5}
.management-card-body{display:flex;flex-direction:column;gap:12px}
.management-card-meta{display:flex;flex-wrap:wrap;gap:8px}
.management-card-actions{margin-top:auto;display:flex;gap:10px;flex-wrap:wrap}
.management-card-actions > *{margin:0}
.management-card-actions form{display:inline-flex}
.meta-chip{display:inline-flex;align-items:center;justify-content:center;padding:8px 12px;border-radius:999px;background:#eef4ff;color:#214889;font-weight:700;font-size:13px;max-width:100%;text-align:center}
.meta-chip.soft{background:#f8fbff;color:#52637e;border:1px solid #dbe7f8}
.meta-chip.success{background:#ecfdf3;color:#166534}
.meta-chip.warning{background:#fff7ed;color:#c2410c}
.meta-chip.danger{background:#fff1f2;color:#be123c}
.info-stack{display:flex;flex-direction:column;gap:10px}
.info-row{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;padding:12px 14px;border-radius:18px;background:#f8fbff;border:1px solid #e0ebfa}
.info-row span{display:block;color:#66768f;font-size:13px}
.info-row strong{display:block;color:#173159;text-align:right;word-break:break-word}
.empty-state-card{padding:26px;border:1px dashed #c9daf4;border-radius:24px;background:#f8fbff;color:#586982;text-align:center}
.app-modal{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;padding:20px}
.app-modal[hidden]{display:none !important}
.app-modal-backdrop{position:absolute;inset:0;background:rgba(15,23,42,.62);backdrop-filter:blur(4px)}
.app-modal-dialog{position:relative;z-index:1;width:min(100%,860px);max-height:min(92dvh,960px);background:#fff;border-radius:28px;box-shadow:0 28px 80px rgba(15,23,42,.28);display:flex;flex-direction:column;overflow:hidden}
.app-modal-dialog.narrow{width:min(100%,620px)}
.app-modal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:22px 24px 18px;border-bottom:1px solid #e3ebf8}
.app-modal-header h2{margin:0;color:#173159;font-size:24px}
.app-modal-header p{margin:6px 0 0;color:#607089;line-height:1.5}
.app-modal-close{border:0;background:#edf3fe;color:#173159;width:46px;height:46px;border-radius:999px;font-size:28px;line-height:1;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0}
.app-modal-content{padding:22px 24px 24px;overflow:auto}
.modal-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.modal-form-grid .full{grid-column:1 / -1}
.form-section-title{margin:4px 0 0;color:#173159;font-size:18px}
.form-help{margin:0;color:#607089;line-height:1.5}
.stack-form .button-row.modal-actions{margin-top:18px}
.management-inline-note{padding:16px 18px;border-radius:20px;background:#f8fbff;border:1px solid #dde8f9;color:#52637e;line-height:1.6}
.input-surface{background:#fff}
.route-stop-grid{display:grid;grid-template-columns:2fr 1.3fr;gap:18px}
.card-link-title{text-decoration:none;color:#173159}
.card-link-title:hover{text-decoration:underline}
@media (max-width:1180px){.management-card-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.management-stat-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.route-stop-grid{grid-template-columns:1fr}}
@media (max-width:720px){.management-toolbar,.management-section-head,.management-card-head,.info-row{flex-direction:column}.management-card-grid,.management-stat-grid,.modal-form-grid{grid-template-columns:1fr}.app-modal{padding:12px}.app-modal-dialog{width:100%;max-height:94dvh;border-radius:24px}.app-modal-header,.app-modal-content{padding-left:18px;padding-right:18px}.management-card-actions{flex-direction:column}.management-card-actions form,.management-card-actions .btn{width:100%}.management-card-actions .btn,.management-card-actions button{justify-content:center}.info-row strong{text-align:left}}

/* 2026-04-11 dashboard simplification */
.compact-dashboard-head{margin-bottom:18px}
.dashboard-focus-grid{display:grid;grid-template-columns:minmax(0,1.55fr) minmax(320px,.85fr);gap:18px;align-items:start}
.focus-main-card{min-height:100%}
.dashboard-side-card{height:100%}
.quick-link-side-card{display:flex;flex-direction:column;gap:16px}
.quick-action-stack{display:flex;flex-direction:column;gap:12px}
.quick-link-card.large{padding:18px 20px;border-radius:20px;background:#f8fbff;border:1px solid #deebfb;box-shadow:none}
.quick-link-card.large strong{font-size:17px;color:#173159}
.quick-link-card.large span{line-height:1.55}
.quick-link-card.large:hover,.quick-link-card.large:focus-visible{transform:translateY(-1px);box-shadow:0 12px 28px rgba(36,84,166,.08);outline:none}
.panel-mini-stats{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.panel-mini-stat{background:#f7faff;border:1px solid #d9e5f7;border-radius:18px;padding:14px 16px}
.panel-mini-stat span{display:block;color:#64748b;font-size:13px;margin-bottom:6px}
.panel-mini-stat strong{display:block;color:#173159;font-size:20px;word-break:break-word}
.info-box{padding:14px 16px;border-radius:18px;background:#f8fbff;border:1px solid #deebfb;color:#334155;line-height:1.55}
.dashboard-start-form .info-box{grid-column:1/-1}
.full-width-mobile form{margin:0}

@media (max-width:1200px){
  .dashboard-focus-grid{grid-template-columns:1fr}
}
@media (max-width:720px){
  .panel-mini-stats{grid-template-columns:1fr}
  .compact-dashboard-head h1{font-size:28px}
}

/* 2026-04-11 report rows visual upgrade */
.report-row-board{border:1px solid #dce7f8;border-radius:22px;overflow:hidden;background:#f8fbff}
.report-row-board-head,.report-row-board-row{display:grid;grid-template-columns:minmax(170px,1.3fr) minmax(120px,.8fr) minmax(100px,.7fr) minmax(180px,1.3fr) minmax(150px,1fr) minmax(190px,1.3fr);gap:0}
.report-row-board-head{background:#edf4ff;border-bottom:1px solid #dce7f8}
.report-row-board-head > div{padding:14px 16px;font-size:13px;font-weight:800;letter-spacing:.02em;color:#2a4b83}
.report-row-board-body{display:flex;flex-direction:column}
.report-row-board-row{background:#fff;border-bottom:1px solid #e6eefb;color:#173159;text-decoration:none}
.report-row-board-row:last-child{border-bottom:0}
.report-row-board-link{display:grid}
.report-row-board-link:hover,.report-row-board-link:focus-visible{background:#f7fbff;outline:none}
.report-board-cell{padding:15px 16px;display:flex;flex-direction:column;gap:4px;justify-content:center;min-width:0}
.report-board-cell + .report-board-cell{border-left:1px solid #edf2fb}
.report-board-cell span{display:none;color:#64748b;font-size:12px;font-weight:700;letter-spacing:.02em}
.report-board-cell strong{display:block;color:#173159;font-size:15px;line-height:1.4;word-break:break-word}
.report-board-cell small{display:block;color:#607089;font-size:12px;line-height:1.5}
@media (max-width:1100px){.report-row-board-head,.report-row-board-row{grid-template-columns:minmax(160px,1.2fr) minmax(110px,.75fr) minmax(90px,.65fr) minmax(170px,1.1fr) minmax(140px,.95fr) minmax(170px,1.1fr)}}
@media (max-width:860px){.report-row-board{background:transparent;border:0;overflow:visible}.report-row-board-head{display:none}.report-row-board-body{gap:12px}.report-row-board-row,.report-row-board-link{grid-template-columns:repeat(2,minmax(0,1fr));gap:0;background:#fff;border:1px solid #dce7f8;border-radius:20px;box-shadow:0 10px 26px rgba(36,84,166,.08)}.report-board-cell{padding:14px;border-left:0}.report-board-cell:nth-child(odd){border-right:1px solid #edf2fb}.report-board-cell:nth-child(n+3){border-top:1px solid #edf2fb}.report-board-cell span{display:block}.report-board-cell strong{font-size:14px}}
@media (max-width:520px){.report-row-board-row,.report-row-board-link{grid-template-columns:1fr}.report-board-cell{padding:14px 15px}.report-board-cell:nth-child(odd){border-right:0}.report-board-cell + .report-board-cell{border-top:1px solid #edf2fb}}


.status-pill.cancelled{background:#fee2e2;color:#b91c1c}
.padded-empty-note{padding:18px}
.inline-link-strong{font-weight:800;color:#1d4ed8;text-decoration:none}
.inline-link-strong:hover,.inline-link-strong:focus-visible{text-decoration:underline}
.report-inline-banner{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 18px;border-radius:20px;background:#f7fbff;border:1px solid #dce7f8}
.compact-inline-actions{justify-content:flex-end}
.trip-lock-box{width:100%;max-width:520px;background:linear-gradient(180deg,#eef6ff 0%,#dce9ff 100%);border:1px solid #c7dafc;border-radius:24px;padding:22px 20px;display:flex;flex-direction:column;gap:10px;text-align:center;box-shadow:0 12px 32px rgba(36,84,166,.10)}
.trip-lock-box strong{font-size:24px;color:#163d7a;letter-spacing:.02em}
.trip-lock-box span{font-size:18px;font-weight:700;color:#173159}
.trip-lock-box small{font-size:14px;color:#475569}
.qr-blocked-state{display:flex;align-items:center;justify-content:center;padding:24px}
.qr-block-message{width:min(100%,420px);display:flex;flex-direction:column;gap:12px;padding:24px;border-radius:24px;background:linear-gradient(180deg,#eef6ff 0%,#dce9ff 100%);border:1px solid #c7dafc;box-shadow:0 12px 32px rgba(36,84,166,.10)}
.qr-block-message strong{font-size:26px;color:#163d7a}
.qr-block-message span{font-size:17px;line-height:1.6;color:#173159;font-weight:700}
.modern-login-wrap{padding:24px 16px;min-height:100vh;background:radial-gradient(circle at top,#dbeafe 0%,#eef4ff 32%,#f8fbff 100%)}
.modern-login-card{width:min(100%,640px);padding:28px 24px;border-radius:28px;box-shadow:0 24px 60px rgba(36,84,166,.12);border:1px solid #e1ebfb}
.centered-login-block{text-align:center;gap:10px;margin-bottom:14px}
.large-login-logo{width:min(100%,260px);margin:0 auto 10px}
.login-heading{margin:0;color:#153e75;font-size:clamp(28px,4vw,40px)}
.login-form-grid{max-width:100%;gap:18px}
.login-form-grid label{font-weight:800;color:#153e75;margin-bottom:8px;display:block}
.login-form-grid input{height:58px;font-size:18px;border-radius:18px;border:1px solid #d3e0f6;background:#fff}
.login-form-grid .btn{min-height:58px;font-size:18px}
@media (max-width:980px){.report-inline-banner{flex-direction:column;align-items:flex-start}.compact-inline-actions{width:100%}.compact-inline-actions .btn,.compact-inline-actions form{width:100%}.compact-inline-actions form button{width:100%}.modern-login-card{padding:34px 22px;border-radius:28px}.large-login-logo{width:min(100%,220px)}}
@media (max-width:720px){.trip-lock-box strong{font-size:22px}.trip-lock-box span{font-size:17px}.qr-block-message strong{font-size:22px}.qr-block-message span{font-size:16px}.login-heading{font-size:30px}.login-form-grid input{font-size:17px;height:56px}.modern-login-wrap{padding:22px 14px}}

/* 2026-04-11 personnel list, branding and account improvements */
.brand-block{display:flex;align-items:center;gap:12px;font-weight:800;line-height:1.25}
.brand-logo{width:46px;height:46px;object-fit:contain;border-radius:14px;background:rgba(255,255,255,.14);padding:6px;flex-shrink:0}
.sidebar .brand-block{align-items:center;gap:14px;padding:8px 0 2px}
.sidebar .brand-block span{font-size:clamp(18px,1.25vw,24px);font-weight:800;line-height:1.2;word-break:break-word}
.personnel-search-form{display:flex;align-items:center;gap:10px;flex-wrap:wrap;max-width:100%}
.personnel-search-form input{min-width:min(240px,100%);flex:1 1 220px;height:48px;border-radius:16px;border:1px solid #d6e3f7;background:#fff;padding:0 14px}
.personnel-board .report-row-board-head,.personnel-board .report-row-board-row{grid-template-columns:minmax(180px,1.25fr) minmax(95px,.65fr) minmax(150px,.95fr) minmax(150px,.95fr) minmax(110px,.75fr) minmax(170px,1fr)}
.compact-inline-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.branding-preview-card{display:flex;align-items:center;gap:16px;padding:18px;border-radius:22px;background:#f8fbff;border:1px solid #dce8fa}
.branding-preview-card strong{display:block;color:#173159;font-size:18px;margin-bottom:4px}
.branding-preview-card p{margin:0;color:#607089;line-height:1.5}
.settings-logo-preview{width:92px;height:92px;object-fit:contain;border-radius:22px;background:#fff;border:1px solid #dce8fa;padding:10px;box-shadow:0 10px 24px rgba(36,84,166,.08)}
.checkbox-inline{display:inline-flex;align-items:center;gap:10px;color:#173159;font-weight:600}
.settings-grid{align-items:start}
.account-grid,.personnel-detail-grid{align-items:start}
.account-detail-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
@media (max-width:980px){.branding-preview-card{align-items:flex-start}.personnel-board .report-row-board-head,.personnel-board .report-row-board-row{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media (max-width:720px){.brand-block{font-size:18px}.brand-logo{width:42px;height:42px;border-radius:12px}.sidebar-mobile-logo-slot{left:72px;right:18px;height:54px}.sidebar .brand-block span{font-size:17px}.personnel-search-form{width:100%}.personnel-search-form input,.personnel-search-form .btn{width:100%}.branding-preview-card{flex-direction:column;text-align:center}.settings-logo-preview{width:84px;height:84px}.account-detail-grid{grid-template-columns:1fr}}

.stack-form input[type=color]{padding:8px 10px;height:56px;max-width:180px;cursor:pointer}


/* 2026-04-11 personnel profile photo and cleaner QR card */
.personnel-qr-clean-card{gap:18px;padding-top:28px}
.personnel-qr-identity{display:flex;flex-direction:column;align-items:center;gap:10px;text-align:center}
.personnel-qr-identity h2{margin:0;font-size:clamp(28px,4vw,44px);color:#0f172a}
.personnel-qr-identity p{margin:0;color:#334155;font-size:18px;font-weight:600}
.personnel-photo-wrap{width:92px;height:92px;border-radius:999px;background:linear-gradient(180deg,#dbeafe 0%,#bfdbfe 100%);display:flex;align-items:center;justify-content:center;overflow:hidden;border:4px solid rgba(255,255,255,.88);box-shadow:0 16px 34px rgba(15,23,42,.12);color:#1d4ed8;font-weight:900;font-size:30px}
.personnel-photo-wrap.large{width:120px;height:120px;font-size:38px}
.personnel-photo-wrap.modal-photo{width:104px;height:104px;margin:0 auto 12px;font-size:34px}
.personnel-photo-wrap img,.profile-photo-large img,.detail-photo-inline img{width:100%;height:100%;object-fit:cover}
.qr-inline-controls{width:100%;display:grid;grid-template-columns:minmax(0,1fr) minmax(240px,320px);gap:14px;align-items:stretch}
.qr-inline-color-card{background:#f7faff;border:1px solid #d9e5f7;border-radius:22px;padding:16px 18px;display:flex;align-items:center;justify-content:space-between;gap:14px;text-align:left;min-height:84px}
.qr-inline-color-card label{font-weight:800;color:#173159}
.qr-inline-color-card input{width:64px;height:48px;padding:4px;border-radius:14px;border:1px solid #c9d7eb;background:#fff;flex:0 0 auto}
.qr-inline-open-btn{width:100%;min-height:84px}
.qr-inline-note{width:100%;font-size:15px;color:#51627e;line-height:1.55;text-align:left}
.compact-lock-box{width:100%;max-width:520px;text-align:left}
.personnel-qr-modal-head{text-align:center}
.profile-photo-settings{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.profile-photo-large{width:124px;height:124px;border-radius:999px;background:linear-gradient(180deg,#dbeafe 0%,#bfdbfe 100%);display:flex;align-items:center;justify-content:center;overflow:hidden;color:#1d4ed8;font-weight:900;font-size:38px;box-shadow:0 16px 34px rgba(15,23,42,.12)}
.profile-photo-copy{display:flex;flex-direction:column;gap:6px;min-width:0;flex:1}
.profile-photo-copy strong{font-size:22px;color:#173159}
.profile-photo-copy p{margin:0;color:#51627e;line-height:1.6}
.checkbox-inline{display:inline-flex;align-items:center;gap:10px;flex-wrap:wrap;color:#334155;font-weight:700}
.checkbox-inline input{width:18px;height:18px}
.detail-box-photo{display:flex;flex-direction:column;gap:10px}
.detail-photo-inline{width:80px;height:80px;border-radius:999px;background:linear-gradient(180deg,#dbeafe 0%,#bfdbfe 100%);display:flex;align-items:center;justify-content:center;overflow:hidden;color:#1d4ed8;font-weight:900;font-size:24px}
@media (max-width:720px){
  .qr-inline-controls{grid-template-columns:1fr}
  .qr-inline-color-card{min-height:auto;padding:14px 16px}
  .personnel-photo-wrap.large{width:104px;height:104px;font-size:32px}
  .profile-photo-settings{flex-direction:column;align-items:flex-start}
}

.live-announcement-admin-grid {
    align-items: start;
}

.live-recorder-box {
    display: grid;
    gap: 12px;
    padding: 16px;
    border: 1px solid rgba(59, 130, 246, 0.12);
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.75);
}

.live-recorder-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.announcement-audio-preview {
    width: 100%;
}

.live-target-mode-stack {
    display: grid;
    gap: 10px;
}

.radio-card,
.trip-check-card {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px 16px;
    border-radius: 18px;
    border: 1px solid rgba(15, 23, 42, 0.08);
    background: #fff;
}

.radio-card input,
.trip-check-card input {
    margin: 0;
}

.live-trip-selection-box {
    display: grid;
    gap: 12px;
}

.live-trip-check-grid {
    display: grid;
    gap: 10px;
}

.trip-check-card span {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.trip-check-card small,
.live-announcement-history-row small {
    color: #64748b;
}

.live-announcement-history-row {
    align-items: flex-start;
}

.live-announcement-history-row audio {
    width: 100%;
    margin-top: 8px;
}

.driver-live-announcement {
    position: fixed;
    left: 16px;
    right: 16px;
    bottom: 16px;
    z-index: 1200;
}

.driver-live-announcement-card {
    max-width: 620px;
    margin: 0 auto;
    background: #0f172a;
    color: #fff;
    border-radius: 24px;
    box-shadow: 0 22px 50px rgba(15, 23, 42, 0.35);
    padding: 18px 18px 16px;
}

.driver-live-announcement-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 6px 12px;
    border-radius: 999px;
    background: rgba(96, 165, 250, 0.18);
    color: #bfdbfe;
    font-weight: 700;
    font-size: 13px;
    margin-bottom: 10px;
}

.driver-live-announcement-card h3 {
    margin: 0 0 8px;
    font-size: 24px;
    color: #fff;
}

.driver-live-announcement-card p {
    margin: 0 0 10px;
    color: rgba(255, 255, 255, 0.82);
}

.driver-live-announcement-card .top-note {
    color: rgba(255, 255, 255, 0.8);
    margin-top: 10px;
}

.driver-live-announcement-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

@media (max-width: 768px) {
    .live-recorder-actions,
    .driver-live-announcement-actions {
        flex-direction: column;
    }

    .driver-live-announcement {
        left: 12px;
        right: 12px;
        bottom: 12px;
    }

    .driver-live-announcement-card h3 {
        font-size: 20px;
    }
}

.personnel-qr-modal-head{padding-top:4px}
.qr-modal-meta,.qr-modal-countdown{max-width:min(100%,560px);text-align:center;line-height:1.3;padding-left:8px;padding-right:8px}

@media (max-width: 640px){
  .qr-modal-screen{justify-content:flex-start;padding-top:88px;padding-bottom:24px}
  .qr-modal-head{margin-bottom:8px}
  .personnel-qr-modal-head .badge-line{margin-bottom:10px}
  .qr-modal-head h2{font-size:26px;line-height:1.08;margin:4px 0 2px}
  .qr-modal-head p{font-size:14px}
  .qr-modal-meta{font-size:14px;margin-top:0}
  .qr-modal-box{margin-top:0}
  .qr-modal-countdown{font-size:18px;margin-top:8px;margin-bottom:4px}
}

@media (max-width: 480px){
  .qr-box-large{width:min(100%,248px);min-height:248px;padding:12px}
  .qr-modal-screen{padding-left:12px;padding-right:12px}
}

.inline-audio-setting{display:grid;gap:12px;padding:14px 16px;border:1px solid rgba(15,23,42,.08);border-radius:18px;background:#fff}.inline-audio-setting audio{width:100%}

/* 2026-04-11 QR modal fit and no-scroll layout */
.qr-modal{overflow:hidden}
.qr-modal-screen{
  --qr-render-size: 300px;
  min-height:100dvh;
  min-height:100vh;
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
  align-items:center;
  padding:18px 18px max(20px, env(safe-area-inset-bottom));
  overflow:hidden !important;
  overscroll-behavior:contain;
  gap:8px;
}
.qr-modal-head{
  width:min(100%,520px);
  margin:0 auto;
  padding-top:max(6px, env(safe-area-inset-top));
  flex:0 0 auto;
}
.personnel-qr-modal-head .badge-line{margin-bottom:8px}
.qr-modal-head h2{
  font-size:clamp(22px,4vw,30px);
  line-height:1.08;
  margin:0 0 4px;
}
.qr-modal-head p{font-size:15px;margin:0}
.qr-modal-body{
  width:min(100%,520px);
  flex:1 1 auto;
  min-height:0;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:flex-start;
  gap:10px;
  padding-top:4px;
}
.qr-modal-meta,
.qr-modal-countdown,
.qr-refresh-btn{width:min(100%,420px)}
.qr-modal-meta{
  margin-top:0;
  font-size:15px;
  font-weight:700;
}
.qr-modal-box.qr-box-large{
  width:min(100%, calc(var(--qr-render-size) + 28px));
  min-height:calc(var(--qr-render-size) + 28px);
  padding:12px;
  margin:0;
  border-radius:26px;
}
.qr-modal-box img{
  width:var(--qr-render-size) !important;
  max-width:100% !important;
  height:auto !important;
}
.qr-modal-countdown{
  margin-top:0;
  margin-bottom:0;
  font-size:22px;
  font-weight:900;
}
.qr-refresh-btn{
  position:static;
  left:auto;
  bottom:auto;
  transform:none;
  z-index:auto;
  display:inline-flex;
  justify-content:center;
  margin-top:2px;
  min-height:58px;
}
@media (max-width:640px){
  .qr-modal-screen{padding:14px 12px max(18px, env(safe-area-inset-bottom));gap:8px}
  .personnel-qr-modal-head .badge-line{margin-bottom:8px}
  .qr-modal-head h2{font-size:24px;margin:0 0 2px}
  .qr-modal-head p{font-size:14px}
  .qr-modal-meta{font-size:14px}
  .qr-modal-countdown{font-size:18px}
  .qr-refresh-btn{min-height:54px;font-size:16px}
}

/* 2026-04-11 live announcement delete actions */
.card-head-split{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.inline-danger-form{margin:0}
.live-announcement-history-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap}
.live-announcement-history-top > div{min-width:0;flex:1 1 260px}
@media (max-width:720px){
  .card-head-split,.live-announcement-history-top{align-items:stretch}
  .inline-danger-form,.inline-danger-form .btn{width:100%}
}

@media (max-width:640px){.login-page .login-wrap{padding:14px 12px 24px}.login-page .login-card{padding:24px 20px;border-radius:24px}.login-page .title-block h1{font-size:30px}.login-page .large-login-logo{max-width:150px}.login-page .stack-form input,.login-page .stack-form select,.login-page .stack-form textarea{padding:13px 14px}}


.vehicle-audio-settings-form {
    gap: 18px;
}

.vehicle-audio-setting {
    padding: 16px 18px;
    border: 1px solid rgba(15, 23, 42, 0.08);
    border-radius: 18px;
    background: rgba(248, 250, 252, 0.96);
}

.vehicle-audio-setting-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 14px;
    align-items: center;
    margin-top: 10px;
}

.vehicle-audio-setting-row strong {
    min-width: 54px;
    text-align: right;
    font-size: 1rem;
}

.vehicle-audio-setting input[type="range"] {
    width: 100%;
}

/* 2026-04-12 report sheet tables */
.report-sheet-wrap{border:1px solid #22324a;border-radius:12px;background:#fff;overflow:hidden}
.report-sheet-title{padding:14px 18px;border-bottom:2px solid #22324a;text-align:center;font-weight:800;font-size:18px;letter-spacing:.03em;color:#101828;background:#fff}
.report-sheet-table-wrap{overflow:auto;background:#fff}
.report-sheet-table{width:100%;min-width:860px;border-collapse:collapse;background:#fff}
.report-sheet-table th,.report-sheet-table td{border:1px solid #22324a;padding:11px 10px;font-size:13px;line-height:1.45;text-align:center;vertical-align:middle;color:#101828}
.report-sheet-table th{background:#f8fafc;font-weight:800;position:static}
.report-sheet-table td.text-left-cell,.report-sheet-table th.text-left-cell{text-align:left}
.report-sheet-table small{display:block;font-size:11px;color:#475467;line-height:1.4;margin-top:3px}
.report-sheet-actions{display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap}
.sheet-link{display:inline-flex;align-items:center;justify-content:center;padding:7px 10px;border:1px solid #22324a;border-radius:8px;background:#fff;color:#101828;text-decoration:none;font-size:12px;font-weight:700;line-height:1.2}
.sheet-link:hover,.sheet-link:focus-visible{text-decoration:none;background:#f3f4f6;outline:none}
.sheet-link.muted{background:#eef2ff}
.sheet-link.danger{background:#fff1f2;color:#b42318;cursor:pointer}
.report-sheet-actions form{margin:0}
.report-sheet-actions .sheet-link{min-width:56px}
.compact-sheet-table{min-width:640px}
@media (max-width:860px){.report-sheet-title{font-size:15px;padding:12px 14px}.report-sheet-table{min-width:700px}.report-sheet-table th,.report-sheet-table td{padding:10px 8px;font-size:12px}.report-sheet-actions{flex-direction:column}.report-sheet-actions .sheet-link,.report-sheet-actions form{width:100%}.report-sheet-actions form .sheet-link{width:100%}}


.modern-login-card{overflow:visible;scrollbar-width:none}
.login-guide-section{margin-top:22px;padding-top:18px;border-top:1px solid #e2ebfb}
.login-guide-head{display:flex;flex-direction:column;gap:6px;margin-bottom:10px}
.login-guide-kicker{display:inline-flex;align-self:flex-start;padding:6px 12px;border-radius:999px;background:#e8f0fd;color:#1d4f91;font-weight:800;font-size:12px;letter-spacing:.02em;text-transform:uppercase}
.login-guide-head h2{margin:0;color:#153e75;font-size:clamp(22px,3vw,30px)}
.login-guide-head p{margin:0;color:#51627e;line-height:1.45;font-size:14px}
.login-guide-chip-row{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}
.login-guide-chip{display:inline-flex;align-items:center;justify-content:center;padding:6px 10px;border-radius:999px;background:#f3f7ff;border:1px solid #d8e5fb;color:#214889;font-weight:700;font-size:11px}
.login-guide-accordion{display:flex;flex-direction:column;gap:8px}
.login-guide-item{border:1px solid #dce7fb;border-radius:18px;background:#fbfdff;overflow:hidden;box-shadow:0 8px 22px rgba(36,84,166,.05)}
.login-guide-summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px 14px}
.login-guide-summary::-webkit-details-marker{display:none}
.login-guide-item[open] .login-guide-summary{background:#f7faff}
.login-guide-summary-main{display:flex;align-items:flex-start;gap:10px;min-width:0}
.login-guide-icon{width:34px;height:34px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;background:#e8f0fd;flex-shrink:0;font-size:17px}
.login-guide-title-wrap{display:flex;flex-direction:column;gap:4px;min-width:0}
.login-guide-title{font-size:15px;font-weight:800;line-height:1.32;color:#173159}
.login-guide-subtitle{font-size:11px;color:#6b7b93;font-weight:700}
.login-guide-toggle{display:inline-flex;align-items:center;justify-content:center;min-width:50px;padding:7px 10px;border-radius:999px;background:#e8f0fd;color:#214889;font-size:11px;font-weight:800;flex-shrink:0}
.login-guide-item[open] .login-guide-toggle{background:#173159;color:#fff}
.login-guide-item[open] .login-guide-toggle::before{content:'Kapat'}
.login-guide-item:not([open]) .login-guide-toggle::before{content:'Aç'}
.login-guide-content{padding:0 14px 14px}
.login-guide-answer{color:#30435f;line-height:1.58;font-size:13px}
.login-guide-answer p{margin:0 0 8px}
.login-guide-answer p:last-child{margin-bottom:0}
.login-guide-answer ul{margin:0;padding-left:16px;display:grid;gap:5px}
.login-guide-answer li{margin:0}
@media (max-width:980px){.modern-login-card{padding:26px 20px}.login-guide-section{margin-top:16px;padding-top:14px}.login-guide-item{border-radius:16px}}
@media (max-width:720px){.modern-login-card{padding:20px 14px;border-radius:22px}.login-guide-head h2{font-size:21px}.login-guide-head p{font-size:13px;line-height:1.4}.login-guide-chip-row{gap:5px}.login-guide-chip{padding:5px 8px;font-size:10px}.login-guide-accordion{gap:7px}.login-guide-item{border-radius:16px}.login-guide-summary{padding:11px 12px;gap:9px}.login-guide-icon{width:30px;height:30px;border-radius:10px;font-size:15px}.login-guide-title{font-size:14px}.login-guide-subtitle{font-size:10px}.login-guide-toggle{min-width:46px;padding:6px 8px;font-size:10px}.login-guide-content{padding:0 12px 12px}.login-guide-answer{font-size:12px;line-height:1.52}.login-guide-answer ul{padding-left:15px;gap:5px}}
@media (max-width:420px){.modern-login-wrap{padding:12px 8px}.modern-login-card{padding:18px 12px;border-radius:20px}.login-guide-head{gap:4px;margin-bottom:8px}.login-guide-head p,.login-guide-chip-row{display:none}.login-guide-summary{padding:10px 11px}.login-guide-title{font-size:13px}.login-guide-answer{font-size:12px}.login-heading{font-size:26px}.login-form-grid input{height:50px;font-size:16px}.login-form-grid .btn{min-height:50px;font-size:16px}.large-login-logo{width:min(100%,160px)}}

/* 2026-05-20 yazılımcı paneli + çok firma */
.developer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin:18px 0}.developer-card{display:flex;flex-direction:column;gap:8px;padding:18px;border:1px solid rgba(15,23,42,.08);border-radius:20px;background:#fff;text-decoration:none;color:#172033;box-shadow:0 14px 34px rgba(15,23,42,.07)}.developer-card strong{font-size:17px}.developer-card span{color:#667085;line-height:1.45}.developer-wide-card{max-width:900px}.status-badge{display:inline-flex;align-items:center;justify-content:center;padding:6px 10px;border-radius:999px;background:#eef2ff;color:#273b7a;font-weight:800;font-size:12px}.status-active,.status-approved{background:#e8fff2;color:#057647}.status-pending{background:#fff7e6;color:#b54708}.status-suspended,.status-rejected{background:#fff1f3;color:#b42318}.inline-action-form{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin:4px 0}.inline-action-form input{min-width:140px}.backup-file-list{display:grid;gap:10px}.backup-file-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border:1px solid #e5e7eb;border-radius:14px;background:#f8fafc}.company-register-card{margin-top:18px;padding:18px;border:1px solid rgba(29,78,216,.16);border-radius:22px;background:linear-gradient(180deg,#f8fbff,#fff);box-shadow:0 12px 30px rgba(29,78,216,.08)}.company-register-head{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}.company-register-head h2{margin:0;color:#173159}.company-register-head p{margin:0;color:#60718a;line-height:1.45}.company-register-form{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.company-register-form .form-full{grid-column:1/-1}@media(max-width:720px){.developer-grid,.company-register-form{grid-template-columns:1fr}.backup-file-row{align-items:flex-start;flex-direction:column}.inline-action-form input,.inline-action-form button{width:100%}}
.developer-log-box{background:#0f172a;color:#e5e7eb;border-radius:14px;padding:16px;overflow:auto;max-height:360px;font-size:12px;line-height:1.55;white-space:pre-wrap}

/* 2026-05-20 v6 firma başvuru görünürlüğü */
.stat-card-link{text-decoration:none;color:inherit;transition:transform .18s ease,box-shadow .18s ease}
.stat-card-link:hover,.stat-card-link:focus-visible{transform:translateY(-1px);box-shadow:0 16px 34px rgba(15,23,42,.10);outline:none}
.top-card-gap{margin-top:18px}

/* v8 kurumsal mobil arayüz ve grafik iyileştirmeleri */
:root{
  --pro-bg:#f3f7ff;
  --pro-surface:rgba(255,255,255,.88);
  --pro-ink:#0f172a;
  --pro-soft:#eef6ff;
  --pro-accent:#2563eb;
  --pro-accent-2:#06b6d4;
  --pro-green:#16a34a;
  --pro-orange:#f97316;
  --pro-shadow:0 22px 60px rgba(15,23,42,.12);
}
body{background:radial-gradient(circle at top left,#dcecff 0,#f6f9ff 32%,#eef4ff 100%)}
.app-shell.with-sidebar{background:linear-gradient(90deg,#0f2a4f 0 292px,var(--pro-bg) 292px 100%)}
.sidebar{background:linear-gradient(180deg,#0b2447 0%,#102f58 54%,#081827 100%);padding-left:18px;padding-right:18px;box-shadow:18px 0 60px rgba(15,23,42,.18)}
.brand-block{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:24px;padding:12px;display:flex;align-items:center;gap:12px}
.brand-logo{width:48px;height:48px;object-fit:contain;border-radius:16px;background:#fff;padding:7px;box-shadow:0 16px 36px rgba(0,0,0,.18)}
.user-card{background:linear-gradient(135deg,rgba(255,255,255,.14),rgba(255,255,255,.07));border:1px solid rgba(255,255,255,.14);box-shadow:0 18px 42px rgba(0,0,0,.14)}
.nav-links a,.logout-link{position:relative;display:flex;align-items:center;gap:10px;background:transparent;border-color:rgba(255,255,255,.08);font-weight:750}
.nav-links a::before{content:"";width:9px;height:9px;border-radius:999px;background:rgba(255,255,255,.28);box-shadow:0 0 0 5px rgba(255,255,255,.04)}
.nav-links a.active,.nav-links a:hover,.nav-links a:focus-visible{background:linear-gradient(135deg,rgba(96,165,250,.26),rgba(14,165,233,.14));border-color:rgba(147,197,253,.34);transform:translateX(2px)}
.nav-links a.active::before{background:#7dd3fc;box-shadow:0 0 0 5px rgba(125,211,252,.16)}
.main-content{background:linear-gradient(180deg,rgba(255,255,255,.42),rgba(255,255,255,0));}
.page-head{padding:18px 20px;border-radius:28px;background:linear-gradient(135deg,rgba(255,255,255,.92),rgba(239,246,255,.78));border:1px solid rgba(37,99,235,.12);box-shadow:0 16px 45px rgba(15,23,42,.08)}
.page-head h1{letter-spacing:-.03em}.page-head p{color:#51627e}
.card,.stat-card{border:1px solid rgba(37,99,235,.10);box-shadow:0 20px 55px rgba(15,23,42,.09);background:rgba(255,255,255,.92);backdrop-filter:blur(10px)}
.stat-card{position:relative;overflow:hidden}.stat-card::after{content:"";position:absolute;right:-22px;top:-30px;width:92px;height:92px;border-radius:999px;background:linear-gradient(135deg,rgba(37,99,235,.16),rgba(6,182,212,.08));pointer-events:none}.stat-card strong{position:relative;letter-spacing:-.04em}.stat-card span{position:relative;font-weight:800;color:#4b5f80}.pro-stat-card em{display:block;margin-top:9px;font-style:normal;font-size:12px;line-height:1.35;color:#718096;position:relative}.stat-card-link{text-decoration:none;transition:.2s}.stat-card-link:hover{transform:translateY(-2px)}
.mobile-insight-grid{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(320px,.8fr);gap:18px}.insight-card{display:grid;grid-template-columns:minmax(0,1fr) minmax(260px,380px);align-items:center;gap:18px;overflow:hidden}.gradient-insight-card{background:linear-gradient(135deg,#0f2a4f,#194f90 52%,#0ea5e9);color:#fff;border:0}.gradient-insight-card h2,.gradient-insight-card p{color:#fff}.gradient-insight-card p{opacity:.84}.insight-kicker{display:inline-flex;padding:7px 12px;border-radius:999px;background:rgba(255,255,255,.16);color:inherit;font-weight:900;font-size:12px;letter-spacing:.04em;text-transform:uppercase}.insight-card h2{margin:10px 0 8px;font-size:clamp(22px,3vw,32px);letter-spacing:-.03em;color:#10243f}.insight-card p{margin:0;line-height:1.55;color:#64748b}.wave-chart{width:100%;height:auto;filter:drop-shadow(0 12px 24px rgba(15,23,42,.16))}.wave-chart polyline{transition:stroke-dashoffset 1.2s cubic-bezier(.2,.8,.2,1)}.chart-card{min-height:100%}.bar-list{display:grid;gap:12px}.bar-item{display:grid;gap:7px}.bar-label{display:flex;justify-content:space-between;gap:10px;color:#42526e;font-weight:800}.bar-label strong{color:#0f172a}.bar-track{height:12px;border-radius:999px;background:#e7effb;overflow:hidden}.bar-track i{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--pro-accent),var(--pro-accent-2),var(--pro-green));box-shadow:0 8px 18px rgba(37,99,235,.18);min-width:8%}.compact-bars .bar-track{height:10px}.report-wave-card{background:linear-gradient(135deg,#fff,#f7fbff);border-color:rgba(37,99,235,.12)}
.mobile-app-header,.mobile-bottom-nav{display:none}
.auth-switch{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:6px;margin:18px 0 14px;border-radius:20px;background:#edf5ff;border:1px solid rgba(37,99,235,.12)}.auth-switch-btn{border:0;border-radius:16px;padding:14px 16px;background:transparent;color:#45607f;font-weight:900;cursor:pointer}.auth-switch-btn.active{background:linear-gradient(135deg,#2563eb,#0ea5e9);color:#fff;box-shadow:0 14px 26px rgba(37,99,235,.22)}.auth-panels{position:relative}.auth-panel[hidden]{display:none!important}.auth-panel.active{animation:authFade .22s ease}.auth-panel-head{display:grid;gap:6px;margin:2px 0 14px}.auth-panel-head h2{margin:0;color:#15365d;font-size:24px}.auth-panel-head p{margin:0;color:#64748b;line-height:1.45}.compact-register-card{margin-top:0;box-shadow:none;background:transparent;border:0;padding:0}.company-register-form{grid-template-columns:1fr}.company-register-form .modal-form-grid{grid-column:1/-1}@keyframes authFade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
.login-page .modern-login-wrap{background:radial-gradient(circle at top,#bfdbfe 0,#e0f2fe 28%,#f8fbff 62%,#eef4ff 100%)}.login-page .modern-login-card{border:1px solid rgba(37,99,235,.14);box-shadow:0 28px 70px rgba(15,23,42,.14);background:rgba(255,255,255,.92);backdrop-filter:blur(12px)}.login-heading{letter-spacing:-.04em}.login-logo.large-login-logo{filter:drop-shadow(0 18px 28px rgba(15,23,42,.12))}.login-guide-section{background:linear-gradient(180deg,#f8fbff,#fff);border:1px solid rgba(37,99,235,.10);border-radius:24px;padding:16px;margin-top:18px}.login-guide-item{box-shadow:0 10px 26px rgba(15,23,42,.06)}
@media (max-width:1200px){.mobile-insight-grid{grid-template-columns:1fr}.insight-card{grid-template-columns:1fr}.wave-chart{max-width:560px}}
@media (max-width:980px){
  .app-shell.with-sidebar{background:linear-gradient(180deg,#ecf5ff,#f7fbff)}
  .main-content{padding:86px 14px calc(88px + env(safe-area-inset-bottom));}
  .mobile-nav-toggle{display:none!important}
  .mobile-app-header{display:flex;position:fixed;left:12px;right:12px;top:10px;z-index:980;align-items:center;justify-content:space-between;padding:10px 12px;border-radius:24px;background:rgba(255,255,255,.86);border:1px solid rgba(37,99,235,.12);box-shadow:0 18px 46px rgba(15,23,42,.12);backdrop-filter:blur(18px)}
  .mobile-app-brand{display:flex;align-items:center;gap:10px;min-width:0}.mobile-app-brand img{width:42px;height:42px;border-radius:15px;background:#fff;object-fit:contain;padding:6px;box-shadow:0 8px 20px rgba(15,23,42,.12)}.mobile-app-brand strong{display:block;font-size:15px;color:#10243f;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:52vw}.mobile-app-brand span{display:block;font-size:12px;color:#64748b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:52vw}.mobile-top-menu-btn{width:42px;height:42px;border:0;border-radius:15px;background:#0f2a4f;color:#fff;font-size:22px;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 12px 26px rgba(15,42,79,.24)}
  .sidebar{max-width:86vw;width:min(86vw,330px);border-top-right-radius:30px;border-bottom-right-radius:30px;padding-top:22px}.sidebar-mobile-logo-slot{display:none}.sidebar .brand-logo{display:block}.sidebar .brand-block{padding-top:12px}.sidebar-overlay{backdrop-filter:blur(2px)}
  .mobile-bottom-nav{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));position:fixed;left:10px;right:10px;bottom:max(10px,env(safe-area-inset-bottom));z-index:970;padding:8px;border-radius:26px;background:rgba(15,42,79,.92);border:1px solid rgba(255,255,255,.18);box-shadow:0 22px 60px rgba(15,23,42,.24);backdrop-filter:blur(18px)}.mobile-bottom-item{border:0;background:transparent;color:#dbeafe;text-decoration:none;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;min-height:54px;border-radius:20px;font-weight:800}.mobile-bottom-item span{font-size:18px;line-height:1}.mobile-bottom-item small{font-size:10px;line-height:1;white-space:nowrap}.mobile-bottom-item.active{background:linear-gradient(135deg,#2563eb,#0ea5e9);color:#fff;box-shadow:0 12px 24px rgba(37,99,235,.22)}.mobile-bottom-menu{cursor:pointer}.mobile-bottom-menu:active,.mobile-bottom-item:active{transform:translateY(1px)}
  .page-head{border-radius:24px;padding:18px 16px}.page-head h1{font-size:25px}.page-head .button-row{width:100%;display:grid;grid-template-columns:1fr;gap:10px}.page-head .button-row .btn{width:100%}.stats-grid,.management-stat-grid{gap:12px}.pro-stat-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.pro-stat-card{padding:18px;border-radius:22px}.pro-stat-card strong{font-size:30px}.pro-stat-card em{font-size:11px}.card{border-radius:24px}.table-wrap,.report-sheet-table-wrap{border-radius:18px}.insight-card{padding:18px}.insight-card h2{font-size:23px}.chart-card{padding:18px}.login-page .main-content{padding:0}.login-page .mobile-app-header,.login-page .mobile-bottom-nav{display:none}
}
@media (max-width:720px){
  .main-content{padding-left:12px;padding-right:12px}.pro-stat-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.stat-card{padding:17px}.stat-card strong{font-size:28px}.stat-card span{font-size:12px}.mobile-insight-grid{gap:12px}.insight-card{border-radius:24px}.bar-label{font-size:13px}.auth-switch{position:sticky;top:8px;z-index:5;margin-top:14px}.auth-switch-btn{padding:13px 10px;font-size:15px}.auth-panel-head h2{font-size:21px}.company-register-head h2{font-size:21px}.company-register-head p,.auth-panel-head p{font-size:13px}.service-checkbox-row{display:grid;grid-template-columns:1fr;gap:7px}.login-form-grid{gap:13px}.login-form-grid input{height:54px}.login-page .login-card{width:min(100%,560px)}.login-guide-section{padding:12px;border-radius:20px}.login-guide-item{box-shadow:none}.developer-grid{grid-template-columns:1fr}.developer-card{border-radius:22px;padding:16px}.report-visual-grid{margin-top:12px}
}
@media (max-width:420px){
  .mobile-bottom-nav{left:6px;right:6px;padding:6px;border-radius:22px}.mobile-bottom-item{min-height:50px;border-radius:17px}.mobile-bottom-item small{font-size:9px}.mobile-app-header{left:8px;right:8px;top:8px;border-radius:21px}.mobile-app-brand img,.mobile-top-menu-btn{width:38px;height:38px;border-radius:13px}.pro-stat-grid{gap:10px}.stat-card{padding:15px 13px}.stat-card strong{font-size:25px}.pro-stat-card em{display:none}.insight-card h2{font-size:21px}.wave-chart{min-height:82px}.auth-switch{gap:6px;padding:5px}.auth-switch-btn{border-radius:14px;padding:12px 8px}.login-page .login-wrap{padding:10px 8px 24px}.login-page .login-card{border-radius:24px}.login-guide-section{margin-top:12px}.login-guide-accordion{gap:6px}
}

/* v9: Kurumsal ikonlu menü ve yasal footer */
.nav-links a::before{display:none!important}
.nav-links a,.logout-link{gap:12px!important;align-items:center!important}
.nav-icon{width:34px;height:34px;min-width:34px;border-radius:13px;display:inline-flex;align-items:center;justify-content:center;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.12);box-shadow:inset 0 1px 0 rgba(255,255,255,.12);font-size:17px;line-height:1}
.nav-label{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:normal;line-height:1.25}
.nav-links a.active .nav-icon,.nav-links a:hover .nav-icon,.nav-links a:focus-visible .nav-icon{background:rgba(125,211,252,.22);border-color:rgba(125,211,252,.32)}
.logout-link .nav-icon{background:rgba(248,113,113,.13);border-color:rgba(248,113,113,.2)}
.site-footer{margin-top:34px;padding:22px;border-radius:28px;background:linear-gradient(135deg,rgba(15,42,79,.94),rgba(15,118,110,.88));color:#eaf6ff;display:grid;grid-template-columns:minmax(0,1.4fr) minmax(0,1fr) auto;align-items:center;gap:18px;box-shadow:0 20px 55px rgba(15,23,42,.14);border:1px solid rgba(255,255,255,.16)}
.site-footer-brand{display:flex;align-items:center;gap:13px;min-width:0}.site-footer-brand img{width:48px;height:48px;border-radius:16px;background:#fff;object-fit:contain;padding:7px;box-shadow:0 12px 26px rgba(15,23,42,.18)}.site-footer-brand strong{display:block;font-size:16px;letter-spacing:.01em}.site-footer-brand span{display:block;font-size:13px;color:#cfe8ff;margin-top:3px;line-height:1.35}
.site-footer-links{display:flex;align-items:center;justify-content:center;gap:10px;flex-wrap:wrap}.site-footer-links a{color:#f8fbff;text-decoration:none;font-weight:800;font-size:13px;padding:10px 12px;border-radius:999px;background:rgba(255,255,255,.09);border:1px solid rgba(255,255,255,.12);transition:.18s}.site-footer-links a:hover,.site-footer-links a:focus-visible{background:rgba(255,255,255,.18);outline:none;transform:translateY(-1px)}.site-footer-copy{font-size:12px;color:#d7eeff;text-align:right;white-space:nowrap}
.public-page .main-content{max-width:1180px;margin:0 auto}.public-hero-card{background:linear-gradient(135deg,#eff6ff,#f0fdfa);border:1px solid #dbeafe;box-shadow:0 18px 50px rgba(15,23,42,.08)}.public-hero-card p{max-width:780px;color:#475569;line-height:1.65}.eyebrow{display:inline-flex;align-items:center;gap:8px;background:#e0f2fe;color:#075985;border:1px solid #bae6fd;border-radius:999px;padding:7px 11px;font-size:12px;font-weight:900;letter-spacing:.06em;text-transform:uppercase;margin-bottom:10px}.public-content-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin-top:18px}.public-info-card{position:relative;overflow:hidden}.public-info-card::after{content:"";position:absolute;right:-34px;top:-34px;width:110px;height:110px;border-radius:999px;background:rgba(14,165,233,.08)}.public-card-icon{width:48px;height:48px;border-radius:18px;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#dbeafe,#ccfbf1);font-size:24px;margin-bottom:12px}.public-info-card h2,.public-wide-card h2,.legal-card h2{color:#0f2a4f}.public-info-card p,.legal-card p{color:#475569;line-height:1.7}.inline-action{display:inline-flex;align-items:center;gap:8px;margin-top:6px;color:#0f766e;font-weight:900;text-decoration:none}.inline-action::after{content:"→"}.public-wide-card{margin-top:18px}.feature-pill-row{display:flex;flex-wrap:wrap;gap:10px}.feature-pill-row span{display:inline-flex;padding:10px 13px;border-radius:999px;background:#f1f5f9;border:1px solid #e2e8f0;color:#334155;font-weight:800;font-size:13px}.legal-card{max-width:940px;margin:18px auto 0;padding:28px}.legal-card h2{font-size:20px;margin:24px 0 8px}.legal-card h2:first-child{margin-top:0}
@media (max-width:980px){.site-footer{grid-template-columns:1fr;text-align:left;margin:28px 0 90px;padding:18px;border-radius:24px}.site-footer-links{justify-content:flex-start}.site-footer-copy{text-align:left;white-space:normal}.public-content-grid{grid-template-columns:1fr}.public-page .main-content{padding-left:14px;padding-right:14px}.legal-card{padding:20px}.nav-icon{width:32px;height:32px;min-width:32px;border-radius:12px}.sidebar .nav-links a,.sidebar .logout-link{padding:12px!important}}
@media (max-width:520px){.site-footer-brand{align-items:flex-start}.site-footer-brand img{width:42px;height:42px;border-radius:14px}.site-footer-links a{width:100%;justify-content:center;text-align:center}.public-hero-card .btn{width:100%;justify-content:center}.legal-card h2{font-size:18px}.legal-card p{font-size:14px}.feature-pill-row span{width:100%;justify-content:center}}

/* v10: Seflink uyumlu ikincil menü görünümü */
.nav-submenu{border:1px solid rgba(255,255,255,.08);border-radius:18px;background:rgba(255,255,255,.035);overflow:hidden}
.nav-submenu-summary{list-style:none;display:flex;align-items:center;gap:12px;padding:12px 14px;cursor:pointer;color:#eef6ff;font-weight:800;user-select:none;transition:.2s}
.nav-submenu-summary::-webkit-details-marker{display:none}
.nav-submenu-summary:hover,.nav-submenu[open]>.nav-submenu-summary{background:linear-gradient(135deg,rgba(96,165,250,.22),rgba(14,165,233,.10));color:#fff}
.nav-submenu-caret{margin-left:auto;width:24px;height:24px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:rgba(255,255,255,.10);transition:.2s;font-size:15px;line-height:1}
.nav-submenu[open] .nav-submenu-caret{transform:rotate(180deg);background:rgba(125,211,252,.18)}
.nav-submenu-links{display:flex;flex-direction:column;gap:7px;padding:7px 7px 10px 14px;border-top:1px solid rgba(255,255,255,.08)}
.nav-submenu-links a{padding:10px 12px 10px 10px!important;border-radius:14px!important;background:rgba(255,255,255,.04)!important;font-size:13px;line-height:1.25}
.nav-submenu-links a .nav-icon{width:28px;height:28px;min-width:28px;border-radius:10px;font-size:14px}
.nav-submenu-links .nav-label{min-width:0;overflow-wrap:anywhere}
.nav-submenu .nav-submenu{background:rgba(255,255,255,.025);border-radius:15px}
.nav-submenu .nav-submenu .nav-submenu-summary{padding:10px 12px;font-size:13px}
@media (max-width:980px){.nav-submenu{border-radius:18px}.nav-submenu-summary{min-height:50px}.nav-submenu-links{gap:6px;padding-left:12px}.nav-submenu-links a{min-height:46px}}

/* v11 - Kurumsal görünüm, ikon ayrımı, yatay footer ve iletişim formu */
.nav-links a,.nav-submenu-summary{letter-spacing:-.015em}
.nav-icon{background:linear-gradient(135deg,rgba(96,165,250,.24),rgba(14,165,233,.11));border-color:rgba(125,211,252,.24);font-size:18px}
.nav-links a:nth-child(3n+1) .nav-icon,.nav-submenu:nth-child(3n+1)>.nav-submenu-summary .nav-icon{background:linear-gradient(135deg,rgba(45,212,191,.22),rgba(59,130,246,.13))}
.nav-links a:nth-child(3n+2) .nav-icon,.nav-submenu:nth-child(3n+2)>.nav-submenu-summary .nav-icon{background:linear-gradient(135deg,rgba(251,191,36,.22),rgba(249,115,22,.12))}
.nav-links a:nth-child(3n) .nav-icon,.nav-submenu:nth-child(3n)>.nav-submenu-summary .nav-icon{background:linear-gradient(135deg,rgba(167,139,250,.22),rgba(14,165,233,.11))}
.nav-submenu-links a .nav-icon{font-size:15px;background:rgba(255,255,255,.09)}
.nav-submenu-summary{min-height:54px}
.nav-submenu[open]{box-shadow:inset 0 1px 0 rgba(255,255,255,.08),0 12px 26px rgba(2,6,23,.12)}
.nav-submenu-links{background:rgba(4,20,39,.22)}

.pro-site-footer{grid-template-columns:minmax(260px,1.15fr) minmax(260px,.9fr) minmax(330px,1.1fr);grid-template-areas:"brand services links" "copy copy copy";align-items:center;background:radial-gradient(circle at left top,rgba(37,99,235,.42),transparent 34%),linear-gradient(135deg,#081827,#0f2a4f 54%,#0f766e);border-radius:30px;padding:22px 24px;gap:16px 22px}
.pro-site-footer .site-footer-brand{grid-area:brand}.site-footer-services{grid-area:services;display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap}.site-footer-services span{display:inline-flex;align-items:center;justify-content:center;min-height:34px;padding:8px 12px;border-radius:999px;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.12);color:#e0f2fe;font-size:12px;font-weight:900;white-space:nowrap}.pro-site-footer .site-footer-links{grid-area:links;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.pro-site-footer .site-footer-links a{display:flex;align-items:center;justify-content:center;gap:6px;min-height:42px;padding:9px 10px;border-radius:15px;text-align:center;line-height:1.2;white-space:normal}.pro-site-footer .site-footer-copy{grid-area:copy;text-align:center;padding-top:2px;border-top:1px solid rgba(255,255,255,.12);padding-top:12px;white-space:normal;color:#bdddf7}

.contact-layout-grid{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(300px,.8fr);gap:18px;margin-top:18px;align-items:start}.contact-form-card{padding:26px;border-radius:28px;overflow:hidden;position:relative}.contact-form-card::before{content:"";position:absolute;right:-70px;top:-70px;width:180px;height:180px;border-radius:999px;background:rgba(14,165,233,.10);pointer-events:none}.contact-form-head{display:flex;align-items:flex-start;gap:14px;margin-bottom:16px}.contact-form-head h2{margin:0;color:#0f2a4f;font-size:25px}.contact-form-head p{margin:4px 0 0;color:#64748b;line-height:1.55}.contact-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.contact-form-grid .form-full{grid-column:1/-1}.contact-form-grid input,.contact-form-grid textarea{background:#f8fbff;border:1px solid #dbeafe;border-radius:16px}.contact-form-grid textarea{resize:vertical;min-height:150px}.contact-info-stack{display:grid;gap:14px}.contact-side-card{min-height:0}.contact-topic-card{margin-top:18px}.contact-hero-card{background:radial-gradient(circle at right top,rgba(14,165,233,.18),transparent 40%),linear-gradient(135deg,#eef6ff,#f7fffb)}

@media (min-width:981px){
  .login-page .modern-login-wrap{min-height:100vh;align-items:center;justify-content:center;padding:42px;background:radial-gradient(circle at 18% 20%,rgba(14,165,233,.22),transparent 28%),radial-gradient(circle at 82% 10%,rgba(37,99,235,.18),transparent 28%),linear-gradient(135deg,#f8fbff 0%,#ecf5ff 48%,#f7fffb 100%)}
  .login-page .modern-login-card{width:min(1180px,calc(100vw - 64px));display:grid;grid-template-columns:minmax(320px,.9fr) minmax(440px,1.1fr);gap:18px 24px;padding:26px;border-radius:34px;background:rgba(255,255,255,.86);box-shadow:0 34px 90px rgba(15,23,42,.16);border:1px solid rgba(37,99,235,.16)}
  .login-page .centered-login-block{grid-column:1;grid-row:1;margin:0;align-self:stretch;display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-end;text-align:left;min-height:270px;padding:28px;border-radius:28px;color:#fff;background:radial-gradient(circle at 20% 16%,rgba(125,211,252,.35),transparent 35%),linear-gradient(145deg,#0b2447,#0f3b69 62%,#0f766e);overflow:hidden;position:relative}
  .login-page .centered-login-block::after{content:"QR";position:absolute;right:22px;top:8px;font-size:78px;font-weight:1000;letter-spacing:-.08em;color:rgba(255,255,255,.07)}
  .login-page .centered-login-block .login-logo{width:168px;max-height:112px;object-fit:contain;background:rgba(255,255,255,.92);border-radius:24px;padding:10px;margin-bottom:auto;box-shadow:0 18px 38px rgba(2,6,23,.18)}
  .login-page .centered-login-block .login-heading{color:#fff;text-align:left;font-size:clamp(34px,3vw,52px);line-height:.95;margin-top:24px;text-shadow:0 12px 28px rgba(2,6,23,.22)}
  .login-page .auth-switch{grid-column:2;grid-row:1;align-self:start;margin:0;background:#eef6ff;border-color:#dbeafe;box-shadow:inset 0 1px 0 rgba(255,255,255,.65)}
  .login-page .auth-panels{grid-column:2;grid-row:2;align-self:start;background:#fff;border:1px solid #e5eefb;border-radius:28px;padding:22px;box-shadow:0 18px 44px rgba(15,23,42,.08)}
  .login-page .login-guide-section{grid-column:1;grid-row:2;margin:0;border-radius:28px;padding:18px;background:linear-gradient(180deg,#fff,#f8fbff);box-shadow:0 18px 44px rgba(15,23,42,.07)}
  .login-page .login-guide-accordion{max-height:480px;overflow:auto;padding-right:4px}
  .login-page .login-guide-item{box-shadow:none;border-color:#e6eef8}
  .login-page .login-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.login-page .login-form-grid .form-full{grid-column:1/-1}.login-page .login-form-grid .full-btn{min-height:54px}
  .public-page .main-content{padding-top:34px}.public-hero-card{padding:34px;border-radius:34px;display:flex;align-items:center;justify-content:space-between;gap:24px}.public-hero-card h1{font-size:clamp(32px,3vw,48px);letter-spacing:-.04em}.public-content-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}.public-info-card{border-radius:28px;padding:24px;box-shadow:0 20px 50px rgba(15,23,42,.08)}
}

@media (max-width:980px){
  .pro-site-footer{grid-template-columns:1fr;grid-template-areas:"brand" "services" "links" "copy";margin:28px 0 calc(92px + env(safe-area-inset-bottom));padding:18px;border-radius:24px;text-align:left}.site-footer-services{justify-content:flex-start}.pro-site-footer .site-footer-links{grid-template-columns:repeat(3,minmax(0,1fr));gap:7px}.pro-site-footer .site-footer-links a{min-height:44px;font-size:11px;padding:8px 6px;border-radius:14px}.pro-site-footer .site-footer-copy{text-align:left}.contact-layout-grid{grid-template-columns:1fr}.contact-form-card{padding:20px;border-radius:24px}.contact-form-grid{grid-template-columns:1fr}.contact-form-head h2{font-size:22px}
}
@media (max-width:520px){
  .site-footer-brand{align-items:center}.site-footer-brand img{width:42px;height:42px}.site-footer-services{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));width:100%;gap:6px}.site-footer-services span{font-size:10px;padding:7px 6px}.pro-site-footer .site-footer-links{grid-template-columns:repeat(3,minmax(0,1fr));width:100%}.pro-site-footer .site-footer-links a{width:auto!important;font-size:10px;gap:3px;padding:7px 4px}.contact-form-head{gap:10px}.contact-form-head .public-card-icon{width:42px;height:42px;border-radius:15px;font-size:20px}
}

/* v12 - Kurumsal public arayüz ve profesyonel sayfa düzeni */
.app-shell:not(.with-sidebar){display:block;min-height:100vh;background:linear-gradient(180deg,#edf6ff 0%,#f8fbff 48%,#eef7f4 100%)}
.app-shell:not(.with-sidebar) .main-content{padding:0;max-width:none;width:100%}
.public-site-header{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;gap:18px;max-width:1220px;margin:0 auto;padding:18px 22px;background:rgba(255,255,255,.78);border:1px solid rgba(37,99,235,.10);border-top:0;border-radius:0 0 28px 28px;box-shadow:0 18px 50px rgba(15,23,42,.08);backdrop-filter:blur(16px)}
.public-site-brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:#0f2a4f;font-weight:1000;font-size:22px;letter-spacing:-.03em}.public-site-brand img{width:54px;height:54px;object-fit:contain;border-radius:16px;background:#fff;box-shadow:0 12px 28px rgba(15,23,42,.08)}
.public-site-nav{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}.public-site-nav a{text-decoration:none;color:#29405f;font-weight:900;font-size:14px;padding:10px 13px;border-radius:999px;transition:.18s}.public-site-nav a:hover,.public-site-nav a:focus-visible{background:#eaf3ff;outline:none}.public-site-nav .public-nav-cta{color:#fff;background:linear-gradient(135deg,#2563eb,#0ea5e9);box-shadow:0 14px 30px rgba(37,99,235,.22)}
.public-home-page .main-content{background:radial-gradient(circle at 16% 18%,rgba(14,165,233,.16),transparent 28%),radial-gradient(circle at 84% 12%,rgba(15,118,110,.12),transparent 28%),linear-gradient(180deg,#eff7ff 0%,#f8fbff 54%,#f3fbf7 100%)}
.landing-shell{width:min(1220px,calc(100% - 44px));margin:0 auto;padding:40px 0 28px}.landing-hero{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(420px,.78fr);gap:28px;align-items:stretch;min-height:620px}.landing-copy{position:relative;overflow:hidden;border-radius:38px;padding:44px;display:flex;flex-direction:column;justify-content:center;background:radial-gradient(circle at 20% 18%,rgba(125,211,252,.30),transparent 34%),radial-gradient(circle at 80% 86%,rgba(45,212,191,.20),transparent 32%),linear-gradient(145deg,#08203d 0%,#0f3b69 58%,#0f766e 100%);box-shadow:0 34px 90px rgba(15,23,42,.18);color:#fff}.landing-copy::after{content:"";position:absolute;right:-90px;top:-110px;width:280px;height:280px;border:42px solid rgba(255,255,255,.07);border-radius:60px;transform:rotate(18deg)}
.landing-eyebrow{display:inline-flex;align-items:center;width:max-content;max-width:100%;padding:9px 13px;border-radius:999px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.20);font-weight:1000;font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:#dff6ff}.landing-copy h1{position:relative;margin:18px 0 16px;font-size:clamp(36px,4.5vw,64px);line-height:.95;letter-spacing:-.06em;max-width:760px}.landing-lead{position:relative;margin:0;color:#dbeafe;font-size:18px;line-height:1.7;max-width:700px}.landing-action-row{position:relative;display:flex;gap:12px;flex-wrap:wrap;margin-top:28px}.landing-action-row .btn{min-height:54px;border-radius:18px}.landing-action-row .btn.muted{background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.20)}
.landing-stat-strip{position:relative;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:32px}.landing-stat-strip div{padding:16px;border-radius:22px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.16);backdrop-filter:blur(8px)}.landing-stat-strip strong{display:block;font-size:18px;color:#fff}.landing-stat-strip span{display:block;margin-top:5px;font-size:13px;color:#d5f3ff;line-height:1.35}
.operation-flow-card{position:relative;display:grid;grid-template-columns:1fr 32px 1fr 32px 1fr;gap:12px;align-items:center;margin-top:26px;padding:18px;border-radius:26px;background:rgba(255,255,255,.95);color:#0f2a4f;box-shadow:0 22px 50px rgba(2,6,23,.14)}.flow-step span{width:32px;height:32px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;background:#dbeafe;color:#1d4ed8;font-weight:1000;margin-bottom:8px}.flow-step strong{display:block;font-size:15px}.flow-step small{display:block;margin-top:4px;color:#64748b;line-height:1.35}.flow-line{height:3px;border-radius:999px;background:linear-gradient(90deg,#60a5fa,#14b8a6)}
.landing-auth-card{border-radius:38px;background:rgba(255,255,255,.94);border:1px solid rgba(37,99,235,.13);box-shadow:0 34px 90px rgba(15,23,42,.15);padding:24px;align-self:stretch;display:flex;flex-direction:column;gap:16px;backdrop-filter:blur(14px)}.auth-brand-compact{display:flex;align-items:center;gap:12px;padding:14px;border-radius:24px;background:linear-gradient(135deg,#f8fbff,#eef7ff);border:1px solid #e2edf9}.auth-brand-compact img{width:72px;height:58px;object-fit:contain;background:#fff;border-radius:18px;padding:6px;box-shadow:0 10px 24px rgba(15,23,42,.08)}.auth-brand-compact strong{display:block;color:#0f2a4f;font-size:22px;letter-spacing:-.04em}.auth-brand-compact span{display:block;margin-top:3px;color:#64748b;font-size:13px;font-weight:800}.landing-auth-card .auth-panels{background:#fff;border:1px solid #e5eefb;border-radius:28px;padding:20px;box-shadow:0 16px 44px rgba(15,23,42,.07);overflow:auto}.landing-auth-card .auth-switch{margin:0}.landing-auth-card .login-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.landing-auth-card .login-form-grid .form-full{grid-column:1/-1}.landing-auth-card .company-register-card{background:transparent;border:0;padding:0;box-shadow:none}.landing-auth-card .modal-form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.service-checkbox-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-top:4px}.checkbox-inline{display:flex!important;align-items:center;gap:8px;padding:10px 12px;border:1px solid #dbeafe;border-radius:15px;background:#f8fbff;color:#334155;font-size:13px;font-weight:800}.checkbox-inline input{width:auto;min-width:16px}
.service-showcase{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;margin-top:24px}.service-card{position:relative;overflow:hidden;border-radius:30px;padding:26px;background:#fff;border:1px solid rgba(37,99,235,.10);box-shadow:0 22px 60px rgba(15,23,42,.09)}.service-card::after{content:"";position:absolute;right:-42px;top:-42px;width:126px;height:126px;border-radius:999px;background:rgba(37,99,235,.08)}.service-card span{width:58px;height:58px;border-radius:20px;display:inline-flex;align-items:center;justify-content:center;font-size:28px;margin-bottom:16px}.service-card-blue span{background:#dbeafe}.service-card-green span{background:#ccfbf1}.service-card-orange span{background:#ffedd5}.service-card h2{margin:0 0 9px;color:#0f2a4f;font-size:22px;letter-spacing:-.03em}.service-card p{margin:0;color:#52627a;line-height:1.65}.pro-guide-section{margin-top:24px;border-radius:34px;padding:26px;background:rgba(255,255,255,.92);border:1px solid rgba(37,99,235,.10);box-shadow:0 24px 70px rgba(15,23,42,.10)}.pro-guide-head{max-width:840px}.pro-guide-head h2{font-size:clamp(28px,3vw,42px);letter-spacing:-.045em}.pro-guide-section .login-guide-accordion{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;max-height:none;overflow:visible}.pro-guide-section .login-guide-item{height:max-content;border-radius:20px}
.public-page .main-content{max-width:1220px;margin:0 auto;padding:34px 22px 0}.public-page .page-head{position:relative;overflow:hidden;min-height:230px;align-items:center;padding:36px;border-radius:36px;background:radial-gradient(circle at right top,rgba(14,165,233,.18),transparent 38%),linear-gradient(135deg,#ffffff,#eff6ff 60%,#f0fdfa);border:1px solid rgba(37,99,235,.12);box-shadow:0 24px 70px rgba(15,23,42,.10)}.public-page .page-head::after{content:"";position:absolute;right:32px;bottom:-46px;width:180px;height:180px;border-radius:48px;background:rgba(37,99,235,.07);transform:rotate(18deg)}.public-page .page-head h1{font-size:clamp(34px,4vw,54px);line-height:1;letter-spacing:-.055em;color:#0f2a4f}.public-page .page-head p{font-size:17px;line-height:1.75;color:#475569}.public-page .card{box-shadow:0 20px 58px rgba(15,23,42,.08)}.contact-layout-grid{grid-template-columns:minmax(0,1.1fr) minmax(330px,.72fr)}.legal-card{max-width:1000px;background:linear-gradient(180deg,#fff,#fbfdff);border-radius:32px}.legal-card h2{padding-top:4px;border-top:1px solid #e7eef9}.legal-card h2:first-child{border-top:0}.contact-form-card{background:linear-gradient(180deg,#fff,#f8fbff)}
.pro-site-footer{width:min(1220px,calc(100% - 44px));margin:30px auto 0!important;grid-template-columns:minmax(260px,1.1fr) minmax(280px,.95fr) minmax(340px,1.05fr);border-radius:34px;background:radial-gradient(circle at 14% 10%,rgba(56,189,248,.30),transparent 32%),linear-gradient(135deg,#06182c,#0d3560 56%,#0f766e);box-shadow:0 26px 80px rgba(15,23,42,.16)}.site-footer-brand strong{font-size:19px}.site-footer-services span{gap:6px}.pro-site-footer .site-footer-links a{font-size:12px}.public-home-page .pro-site-footer{margin-bottom:0!important}
.nav-links a,.logout-link,.nav-submenu-summary{display:flex;align-items:center;gap:12px}.nav-icon{width:34px;height:34px;min-width:34px;border-radius:14px;display:inline-flex;align-items:center;justify-content:center;background:rgba(255,255,255,.14);box-shadow:inset 0 1px 0 rgba(255,255,255,.16);font-size:18px}.nav-label{min-width:0}.nav-submenu{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:18px;overflow:hidden}.nav-submenu-summary{cursor:pointer;list-style:none;padding:12px 14px;color:#eef6ff;font-weight:900}.nav-submenu-summary::-webkit-details-marker{display:none}.nav-submenu-caret{margin-left:auto;opacity:.8}.nav-submenu[open] .nav-submenu-caret{transform:rotate(180deg)}.nav-submenu-links{display:grid;gap:7px;padding:0 8px 10px 44px}.nav-submenu-links a{padding:10px 12px!important;border-radius:14px!important;background:rgba(255,255,255,.06)}
@media (min-width:981px){.sidebar{background:radial-gradient(circle at 30% 5%,rgba(125,211,252,.18),transparent 26%),linear-gradient(180deg,#0a2342 0%,#0d3560 52%,#071d33 100%)}.app-shell.with-sidebar{background:linear-gradient(90deg,#0a2342 0 290px,#eef4ff 290px 100%)}}
@media (max-width:1100px){.landing-hero{grid-template-columns:1fr;min-height:0}.landing-auth-card{max-width:none}.pro-guide-section .login-guide-accordion{grid-template-columns:1fr}.service-showcase{grid-template-columns:1fr}.operation-flow-card{grid-template-columns:1fr}.flow-line{height:26px;width:3px;justify-self:center;background:linear-gradient(180deg,#60a5fa,#14b8a6)}.contact-layout-grid{grid-template-columns:1fr}}
@media (max-width:980px){.public-site-header{width:calc(100% - 24px);margin:0 12px;padding:12px 12px;border-radius:0 0 22px 22px}.public-site-brand img{width:46px;height:46px}.public-site-brand span{font-size:18px}.public-site-nav{gap:5px}.public-site-nav a{font-size:12px;padding:8px 9px}.landing-shell{width:calc(100% - 24px);padding:22px 0 20px}.landing-copy{padding:28px;border-radius:30px}.landing-copy h1{font-size:38px}.landing-lead{font-size:16px}.landing-stat-strip{grid-template-columns:1fr}.landing-auth-card{border-radius:30px;padding:16px}.landing-auth-card .auth-panels{border-radius:24px;padding:16px;max-height:none}.landing-auth-card .login-form-grid,.landing-auth-card .modal-form-grid,.service-checkbox-row{grid-template-columns:1fr}.public-page .main-content{padding:22px 14px 0}.public-page .page-head{min-height:0;padding:26px;border-radius:30px}.pro-site-footer{width:calc(100% - 24px);grid-template-columns:1fr;grid-template-areas:"brand" "services" "links" "copy";padding:18px;border-radius:26px;margin-bottom:calc(92px + env(safe-area-inset-bottom))!important}.pro-site-footer .site-footer-links{grid-template-columns:repeat(3,minmax(0,1fr));width:100%}.site-footer-services{justify-content:flex-start}}
@media (max-width:560px){.public-site-header{align-items:flex-start;gap:10px}.public-site-nav{width:100%;justify-content:flex-start;overflow-x:auto;flex-wrap:nowrap;padding-bottom:2px}.public-site-nav a{white-space:nowrap}.landing-copy{padding:22px;border-radius:26px}.landing-copy h1{font-size:31px}.landing-action-row{display:grid;grid-template-columns:1fr;width:100%}.landing-action-row .btn{width:100%}.auth-brand-compact{align-items:center}.auth-brand-compact img{width:62px;height:50px}.auth-brand-compact strong{font-size:19px}.landing-auth-card .auth-switch-btn{font-size:14px}.service-card{border-radius:24px;padding:20px}.pro-guide-section{border-radius:26px;padding:16px}.pro-guide-head h2{font-size:25px}.public-page .page-head h1{font-size:31px}.public-page .page-head p{font-size:15px}.pro-site-footer .site-footer-links{grid-template-columns:1fr}.site-footer-services{grid-template-columns:1fr!important}.site-footer-services span{justify-content:flex-start}.contact-form-head{flex-direction:column}}

/* v13 - Mobil öncelikli ana sayfa düzeltmesi
   Desktop landing korunur; mobilde ilk ekranda sadece kompakt logo + giriş/kayıt formu görünür. */
@media (max-width: 760px){
  body.public-home-page{background:linear-gradient(180deg,#eef7ff 0%,#f8fbff 58%,#f3fbf8 100%)}
  .public-home-page .public-site-header{display:none!important}
  .public-home-page .landing-shell{width:100%;padding:0 0 18px;margin:0}
  .public-home-page .landing-hero{display:flex!important;flex-direction:column;gap:0;min-height:0!important;align-items:stretch;padding:0 13px 0}
  .public-home-page .landing-copy{display:none!important}
  .public-home-page .landing-auth-card{order:1;width:100%;margin:0 auto 22px;padding:18px 16px 20px;border-radius:0 0 30px 30px;border-top:0;background:rgba(255,255,255,.96);box-shadow:0 18px 48px rgba(15,23,42,.10);gap:18px;backdrop-filter:blur(10px)}
  .public-home-page .auth-brand-compact{padding:14px 16px;border-radius:28px;background:linear-gradient(135deg,#f8fbff 0%,#eef7ff 100%);box-shadow:inset 0 1px 0 rgba(255,255,255,.9)}
  .public-home-page .auth-brand-compact img{width:78px;height:70px;border-radius:22px;padding:8px;flex:0 0 auto}
  .public-home-page .auth-brand-compact strong{font-size:24px;line-height:1.12;letter-spacing:-.05em}
  .public-home-page .auth-brand-compact span{font-size:16px;line-height:1.25;color:#64748b;margin-top:6px}
  .public-home-page .landing-auth-card .auth-switch{height:62px;padding:6px;border-radius:28px;background:#edf6ff;border:1px solid #d8e8fb;box-shadow:inset 0 1px 0 rgba(255,255,255,.75)}
  .public-home-page .landing-auth-card .auth-switch-btn{border-radius:22px;font-size:17px;font-weight:1000;min-height:50px}
  .public-home-page .landing-auth-card .auth-panels{padding:18px 17px;border-radius:28px;box-shadow:0 14px 34px rgba(15,23,42,.07);border-color:#dfeafa;background:#fff;overflow:visible}
  .public-home-page .auth-panel-head{gap:8px}
  .public-home-page .auth-panel-head h2,
  .public-home-page .company-register-head h2{font-size:28px;line-height:1.08;letter-spacing:-.04em;margin-bottom:2px}
  .public-home-page .auth-panel-head p,
  .public-home-page .company-register-head p{font-size:17px;line-height:1.45;color:#64748b}
  .public-home-page .login-guide-kicker{font-size:14px;padding:7px 12px;border-radius:999px;letter-spacing:.03em}
  .public-home-page .landing-auth-card .login-form-grid,
  .public-home-page .landing-auth-card .modal-form-grid,
  .public-home-page .service-checkbox-row{display:grid;grid-template-columns:1fr!important;gap:15px}
  .public-home-page .landing-auth-card label{font-size:16px;margin-bottom:7px;color:#0f2a4f;font-weight:950}
  .public-home-page .landing-auth-card input,
  .public-home-page .landing-auth-card select,
  .public-home-page .landing-auth-card textarea{min-height:62px;border-radius:22px;font-size:17px;padding:15px 17px}
  .public-home-page .landing-auth-card textarea{min-height:110px}
  .public-home-page .landing-auth-card .btn{min-height:64px;border-radius:23px;font-size:18px;font-weight:1000}
  .public-home-page .company-register-card{margin-top:0!important}
  .public-home-page .checkbox-inline{font-size:14px;border-radius:18px;padding:13px 14px}
  .public-home-page .service-showcase{width:100%;padding:0 13px;margin:0 auto 18px;grid-template-columns:1fr!important;gap:14px}
  .public-home-page .service-card{border-radius:28px;padding:26px 22px;min-height:0;background:#fff!important;border:1px solid #e3edf9;box-shadow:0 16px 40px rgba(15,23,42,.08);overflow:hidden;position:relative}
  .public-home-page .service-card::after{content:"";position:absolute;right:-34px;top:-42px;width:124px;height:124px;border-radius:999px;background:#eef5ff;z-index:0}
  .public-home-page .service-card > *{position:relative;z-index:1}
  .public-home-page .service-card span{width:64px;height:64px;border-radius:22px;background:#e7f1ff;display:inline-flex;align-items:center;justify-content:center;font-size:32px;margin-bottom:18px}
  .public-home-page .service-card h2{font-size:29px;line-height:1.08;letter-spacing:-.05em;margin:0 0 10px;color:#0f2a4f}
  .public-home-page .service-card p{font-size:16px;line-height:1.55;color:#64748b;margin:0}
  .public-home-page .pro-guide-section{width:calc(100% - 26px);margin:0 auto 18px;padding:18px 16px;border-radius:28px;background:#fff;box-shadow:0 14px 36px rgba(15,23,42,.07)}
  .public-home-page .pro-guide-head h2{font-size:25px;line-height:1.12}
  .public-home-page .pro-guide-head p{font-size:14px;line-height:1.55}
  .public-home-page .login-guide-chip-row{display:flex;overflow-x:auto;flex-wrap:nowrap;padding-bottom:3px}
  .public-home-page .login-guide-chip{white-space:nowrap}
  .public-home-page .pro-site-footer{width:calc(100% - 26px);margin:8px auto calc(18px + env(safe-area-inset-bottom))!important;border-radius:28px}
}

@media (max-width: 390px){
  .public-home-page .landing-hero{padding-left:10px;padding-right:10px}
  .public-home-page .landing-auth-card{padding-left:13px;padding-right:13px;border-radius:0 0 26px 26px}
  .public-home-page .auth-brand-compact{padding:12px;border-radius:24px;gap:10px}
  .public-home-page .auth-brand-compact img{width:68px;height:62px}
  .public-home-page .auth-brand-compact strong{font-size:21px}
  .public-home-page .auth-brand-compact span{font-size:14px}
  .public-home-page .auth-panel-head h2,
  .public-home-page .company-register-head h2{font-size:25px}
  .public-home-page .auth-panel-head p,
  .public-home-page .company-register-head p{font-size:15px}
  .public-home-page .landing-auth-card input,
  .public-home-page .landing-auth-card select,
  .public-home-page .landing-auth-card textarea{min-height:58px}
  .public-home-page .service-showcase{padding-left:10px;padding-right:10px}
  .public-home-page .service-card h2{font-size:25px}
}

/* v14: Panelde public footer gizleme ve iletişim mesajları yönetimi */
.with-sidebar .pro-site-footer,
.with-sidebar .site-footer{display:none!important}
.inline-filter-form{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.inline-filter-form input,.inline-filter-form select{border:1px solid #cbd8ea;border-radius:13px;padding:10px 12px;background:#fff;color:#0f172a;min-height:42px}.inline-filter-form input{min-width:260px}.muted-text{color:#64748b;margin:8px 0 18px}.message-list{display:flex;flex-direction:column;gap:14px}.contact-message-card{background:linear-gradient(180deg,#fff,#f8fbff);border:1px solid #dce7f6;border-radius:22px;padding:18px;box-shadow:0 12px 30px rgba(15,23,42,.08);border-left-width:6px}.status-left-new{border-left-color:#2563eb}.status-left-read{border-left-color:#64748b}.status-left-closed{border-left-color:#16a34a}.contact-message-head{display:flex;justify-content:space-between;gap:14px;align-items:flex-start;flex-wrap:wrap}.contact-message-head h3{margin:10px 0 6px;color:#10233f;font-size:20px}.contact-message-head p{margin:0;color:#52637a;line-height:1.5}.contact-message-head time{color:#64748b;font-size:13px;font-weight:800;background:#eef5ff;border-radius:999px;padding:8px 11px;white-space:nowrap}.contact-message-body{margin-top:14px;padding:15px;border-radius:16px;background:#fff;border:1px solid #e3ebf7;color:#1f2937;line-height:1.65}.inline-action-form{display:inline}.status-new{background:#dbeafe;color:#1d4ed8}.status-read{background:#e2e8f0;color:#334155}.status-closed{background:#dcfce7;color:#166534}
@media(max-width:720px){.inline-filter-form{width:100%;display:grid;grid-template-columns:1fr 1fr}.inline-filter-form input{min-width:0;grid-column:1/-1}.contact-message-card{padding:15px;border-radius:20px}.contact-message-head h3{font-size:18px}.contact-message-head time{width:100%;text-align:center}.contact-message-card .button-row{display:grid;grid-template-columns:1fr}.contact-message-card .btn{width:100%}}

/* v16: Personel yemekhane/malzeme kamera ile QR tarama ekranları */
.personnel-scan-head .button-row{align-items:center}.personnel-camera-card{max-width:720px;margin-inline:auto;background:linear-gradient(180deg,#fff,#f8fbff);border:1px solid #dce8f7;box-shadow:0 22px 58px rgba(15,23,42,.10)}.personnel-camera-card h2{font-size:clamp(24px,3vw,34px);letter-spacing:-.045em;color:#102a4d;margin:8px 0}.personnel-camera-card p{color:#52637a;line-height:1.65}.personnel-qr-reader{width:min(100%,460px);min-height:320px;margin:18px auto 12px;border-radius:28px;overflow:hidden;background:radial-gradient(circle at center,rgba(37,99,235,.12),transparent 48%),linear-gradient(135deg,#0b2340,#0f3b66);border:1px solid rgba(37,99,235,.22);box-shadow:inset 0 1px 0 rgba(255,255,255,.18),0 20px 45px rgba(15,23,42,.16);display:flex;align-items:center;justify-content:center;position:relative}.personnel-qr-reader::before{content:"Kamera bekleniyor";position:absolute;color:rgba(255,255,255,.75);font-weight:900;letter-spacing:.02em}.personnel-qr-reader.is-active::before{display:none}.personnel-qr-reader video{border-radius:24px!important;object-fit:cover!important}.personnel-qr-reader img{display:none!important}.personnel-qr-reader__scan_region,.personnel-qr-reader__dashboard{border:0!important}.personnel-scan-actions{justify-content:center;margin-top:14px}.personnel-scan-actions .btn{min-width:190px}.personnel-scan-result-card{max-width:680px;margin-inline:auto}.material-receive-grid{align-items:start}.material-detail-card{background:linear-gradient(180deg,#fff,#f8fbff)}
@media(max-width:760px){.personnel-scan-head{display:block!important}.personnel-scan-head .button-row{margin-top:12px}.personnel-scan-head .button-row .btn{width:100%}.personnel-camera-card{border-radius:28px;padding:18px 15px;margin-top:8px}.personnel-camera-card h2{font-size:25px;line-height:1.12}.personnel-qr-reader{width:100%;min-height:300px;border-radius:24px;margin:16px 0 12px}.personnel-scan-actions{display:grid;grid-template-columns:1fr;gap:10px}.personnel-scan-actions .btn{width:100%;min-width:0}.material-receive-grid{display:grid;grid-template-columns:1fr!important}.material-receive-grid .btn{width:100%}}
@media(max-width:390px){.personnel-qr-reader{min-height:260px}.personnel-camera-card{padding:15px 12px}.personnel-camera-card h2{font-size:23px}}

/* V17 - Personel QR tarama temiz modal düzeni */
.scan-clean-shell{
  min-height:calc(100dvh - 180px);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:18px 0 42px;
}
.scan-clean-entry-card{
  width:min(100%,520px);
  margin-inline:auto;
  padding:34px 24px;
  text-align:center;
  background:linear-gradient(180deg,#ffffff,#f8fbff);
  border:1px solid #dce8f7;
  box-shadow:0 24px 70px rgba(15,23,42,.12);
}
.scan-clean-icon{
  width:84px;
  height:84px;
  margin:0 auto 16px;
  border-radius:26px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:38px;
  background:linear-gradient(135deg,#eaf3ff,#ffffff);
  border:1px solid #dce8f7;
  box-shadow:0 16px 38px rgba(15,23,42,.09);
}
.scan-clean-entry-card h1{
  margin:0 0 8px;
  color:#102a4d;
  font-size:clamp(28px,4vw,38px);
  letter-spacing:-.045em;
}
.scan-clean-entry-card p{
  margin:0 auto 20px;
  max-width:360px;
  color:#64748b;
  line-height:1.55;
}
.scan-clean-primary,
.scan-clean-secondary{
  width:min(100%,360px);
  margin-inline:auto;
}
.scan-clean-secondary{margin-top:10px}
.personnel-scan-modal{
  background:rgba(9,24,44,.92);
  backdrop-filter:blur(12px);
}
.personnel-scan-modal .qr-modal-backdrop{
  background:radial-gradient(circle at top,rgba(56,189,248,.20),transparent 42%),rgba(4,17,31,.88);
}
.personnel-scan-modal-screen{
  position:relative;
  z-index:1;
  min-height:100dvh;
  width:100%;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:14px;
  padding:78px 16px max(22px, env(safe-area-inset-bottom));
  text-align:center;
  overflow:hidden;
}
.personnel-scan-close{
  width:54px;
  height:54px;
  right:16px;
  top:max(14px, env(safe-area-inset-top));
  font-size:36px;
}
.scan-modal-title{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:12px;
  color:#fff;
  margin-bottom:2px;
}
.scan-modal-icon{
  width:50px;
  height:50px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:18px;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.18);
  font-size:26px;
}
.scan-modal-title h2{
  margin:0;
  color:#fff;
  font-size:clamp(24px,5vw,36px);
  letter-spacing:-.04em;
}
.personnel-qr-reader-modal{
  width:min(100%,520px);
  height:min(64dvh,520px);
  min-height:320px;
  margin:0;
  border-radius:32px;
  background:linear-gradient(135deg,#071d36,#0b3e67);
  border:1px solid rgba(255,255,255,.24);
  box-shadow:0 28px 90px rgba(0,0,0,.34), inset 0 1px 0 rgba(255,255,255,.20);
}
.personnel-qr-reader-modal::before{
  content:"Kamera";
  color:rgba(255,255,255,.72);
}
.personnel-scan-modal .scan-result{
  width:min(100%,520px);
  min-height:48px;
  display:flex;
  align-items:center;
  justify-content:center;
  margin:0;
  padding:12px 16px;
  border-radius:18px;
  font-weight:900;
  background:rgba(255,255,255,.10);
  color:#fff;
  border:1px solid rgba(255,255,255,.16);
}
.personnel-scan-modal .scan-result.success{
  background:rgba(22,163,74,.22);
  border-color:rgba(134,239,172,.30);
}
.personnel-scan-modal .scan-result.error{
  background:rgba(220,38,38,.22);
  border-color:rgba(252,165,165,.35);
}
.scan-modal-stop{
  width:min(100%,320px);
  background:rgba(255,255,255,.13)!important;
  color:#fff!important;
  border:1px solid rgba(255,255,255,.20);
}
.clean-result-card{
  max-width:680px;
  margin:18px auto 42px;
}
@media(max-width:760px){
  .scan-clean-shell{min-height:calc(100dvh - 140px);padding:10px 0 28px}
  .scan-clean-entry-card{border-radius:30px;padding:28px 18px}
  .scan-clean-icon{width:76px;height:76px;border-radius:24px;font-size:34px}
  .personnel-scan-modal-screen{justify-content:flex-start;padding-top:82px;gap:12px}
  .personnel-qr-reader-modal{height:min(58dvh,430px);min-height:300px;border-radius:26px}
  .scan-modal-title h2{font-size:28px}
}
@media(max-width:390px){
  .personnel-qr-reader-modal{height:min(54dvh,360px);min-height:260px}
  .scan-modal-title{gap:8px}
  .scan-modal-icon{width:44px;height:44px;border-radius:16px;font-size:22px}
}

/* v18 - Personel ana ekran modül QR kısayolları */
.personnel-module-shortcuts{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:12px;
    margin-top:16px;
}
.personnel-module-shortcut{
    min-height:86px;
    border:1px solid rgba(15,23,42,.10);
    border-radius:22px;
    background:linear-gradient(145deg,rgba(255,255,255,.96),rgba(248,250,252,.90));
    box-shadow:0 14px 34px rgba(15,23,42,.10);
    padding:14px 12px;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    gap:4px;
    color:#0f172a;
    text-decoration:none;
    text-align:center;
    transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.personnel-module-shortcut:hover,
.personnel-module-shortcut:focus{
    transform:translateY(-2px);
    box-shadow:0 18px 42px rgba(15,23,42,.14);
    border-color:rgba(37,99,235,.26);
}
.personnel-module-shortcut-icon{
    width:38px;
    height:38px;
    border-radius:16px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    background:rgba(37,99,235,.10);
    font-size:20px;
    line-height:1;
}
.personnel-module-shortcut strong{
    font-size:13px;
    letter-spacing:.07em;
    font-weight:900;
}
.personnel-module-shortcut small{
    color:#64748b;
    font-weight:700;
    font-size:12px;
}
@media (max-width:640px){
    .personnel-module-shortcuts{gap:10px;margin-top:14px;}
    .personnel-module-shortcut{min-height:78px;border-radius:20px;padding:12px 8px;}
    .personnel-module-shortcut-icon{width:34px;height:34px;border-radius:14px;font-size:18px;}
}

/* v19 - Personel malzeme geçmişi ve yemekhane değerlendirme */
.rating-legend-row,
.rating-choice-row{
    display:grid;
    grid-template-columns:repeat(5,minmax(0,1fr));
    gap:8px;
    align-items:stretch;
}
.rating-chip,
.rating-choice{
    border:1px solid rgba(15,23,42,.10);
    border-radius:16px;
    padding:10px 6px;
    text-align:center;
    background:#fff;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    gap:3px;
    min-width:0;
    box-shadow:0 10px 24px rgba(15,23,42,.05);
}
.rating-chip b,
.rating-number{
    width:30px;
    height:30px;
    border-radius:999px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    font-weight:900;
    color:#fff;
    background:#64748b;
}
.rating-chip small,
.rating-choice small{
    font-size:11px;
    line-height:1.1;
    white-space:normal;
    color:#475569;
    font-weight:700;
}
.rating-chip.r1 b,.rating-choice.rating-1 .rating-number{background:#ef4444;}
.rating-chip.r2 b,.rating-choice.rating-2 .rating-number{background:#f97316;}
.rating-chip.r3 b,.rating-choice.rating-3 .rating-number{background:#eab308;}
.rating-chip.r4 b,.rating-choice.rating-4 .rating-number{background:#22c55e;}
.rating-chip.r5 b,.rating-choice.rating-5 .rating-number{background:#0ea5e9;}
.rating-choice{cursor:pointer;transition:.18s ease;position:relative;}
.rating-choice input{position:absolute;opacity:0;pointer-events:none;}
.rating-choice:has(input:checked){border-color:#2563eb;background:linear-gradient(180deg,#eff6ff,#ffffff);box-shadow:0 12px 30px rgba(37,99,235,.18);transform:translateY(-1px);}
.rating-question{border:1px solid rgba(15,23,42,.08);border-radius:20px;padding:14px;background:#f8fafc;margin-bottom:10px;}
.rating-question-title{display:flex;flex-direction:column;gap:3px;margin-bottom:10px;}
.rating-question-title strong{font-size:15px;color:#0f172a;}
.rating-question-title small{color:#64748b;}
.cafeteria-review-card{max-width:880px;margin-inline:auto;}
.cafeteria-review-head{display:flex;justify-content:space-between;gap:16px;padding-bottom:12px;border-bottom:1px solid rgba(15,23,42,.08);margin-bottom:14px;}
.cafeteria-review-head h2{margin:4px 0;font-size:24px;}
.review-average-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:12px;}
.review-average-card{background:#f8fafc;border:1px solid rgba(15,23,42,.08);border-radius:18px;padding:14px;display:grid;gap:10px;}
.review-average-card strong{display:block;color:#0f172a;}
.review-average-card small{display:block;color:#64748b;margin-top:3px;}
.review-score-pill{justify-self:start;background:#111827;color:#fff;border-radius:999px;padding:4px 10px;font-weight:900;}
.review-bar{height:8px;border-radius:999px;background:#e5e7eb;overflow:hidden;}
.review-bar i{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,#ef4444,#eab308,#22c55e,#0ea5e9);}
.compact-option-edit{align-items:end;}
.form-action-end{display:flex;align-items:end;}
.material-history-list{display:grid;gap:10px;max-height:620px;overflow:auto;padding-right:4px;}
.material-history-item{display:block;text-decoration:none;color:inherit;border:1px solid rgba(15,23,42,.08);border-radius:18px;padding:13px;background:#fff;box-shadow:0 10px 24px rgba(15,23,42,.04);}
.material-history-item.active{border-color:#2563eb;background:#eff6ff;}
.material-history-item strong{display:block;color:#0f172a;}
.material-history-item span,.material-history-item small{display:block;color:#64748b;margin-top:3px;}
.material-summary-card{border:1px solid rgba(37,99,235,.18);background:linear-gradient(135deg,#eff6ff,#ffffff);border-radius:20px;padding:14px;margin-bottom:14px;display:grid;gap:4px;}
.material-summary-card strong{font-size:18px;color:#0f172a;}
.material-summary-card span,.material-summary-card small{color:#475569;}
.material-chain-timeline{position:relative;display:grid;gap:12px;}
.timeline-item{display:grid;grid-template-columns:20px 1fr;gap:10px;position:relative;}
.timeline-dot{width:13px;height:13px;border-radius:999px;background:#94a3b8;margin-top:12px;box-shadow:0 0 0 4px #f1f5f9;}
.timeline-item.mine .timeline-dot{background:#2563eb;box-shadow:0 0 0 4px #dbeafe;}
.timeline-content{border:1px solid rgba(15,23,42,.08);border-radius:18px;background:#fff;padding:12px;box-shadow:0 10px 24px rgba(15,23,42,.04);}
.timeline-item.mine .timeline-content{border-color:rgba(37,99,235,.25);background:#f8fbff;}
.timeline-top{display:flex;justify-content:space-between;gap:10px;align-items:flex-start;}
.timeline-top strong{color:#0f172a;}
.timeline-top span{color:#64748b;font-size:12px;white-space:nowrap;}
.timeline-content p{margin:8px 0 4px;color:#334155;}
.timeline-content small{color:#64748b;}
.personnel-module-utility-shortcuts{margin-top:8px;}
.personnel-module-shortcut.utility{background:linear-gradient(180deg,#fff,#f8fafc);border-style:dashed;}
.empty-state.compact{border:1px dashed rgba(15,23,42,.18);border-radius:18px;padding:18px;text-align:center;color:#64748b;display:grid;gap:5px;}
.empty-state.compact strong{color:#0f172a;}
@media (max-width: 720px){
    .rating-legend-row,.rating-choice-row{grid-template-columns:repeat(5,minmax(48px,1fr));gap:5px;}
    .rating-chip,.rating-choice{border-radius:12px;padding:8px 3px;}
    .rating-chip b,.rating-number{width:26px;height:26px;font-size:13px;}
    .rating-chip small,.rating-choice small{font-size:9.5px;letter-spacing:-.2px;}
    .cafeteria-review-head h2{font-size:20px;}
    .timeline-top{flex-direction:column;gap:2px;}
    .timeline-top span{white-space:normal;}
}

/* v20 Malzemelerim / personel detay çok modüllü rapor görünümü */
.material-title-list,
.material-report-list,
.mini-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.material-title-item,
.material-report-title,
.mini-list-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    padding: 14px 16px;
    border: 1px solid rgba(15, 23, 42, .08);
    border-radius: 18px;
    background: linear-gradient(135deg, #ffffff 0%, #f8fafc 100%);
    color: inherit;
    text-decoration: none;
    box-shadow: 0 10px 24px rgba(15, 23, 42, .05);
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.material-title-item:hover,
.material-title-item.active,
.material-report-title:hover,
.mini-list-item.clickable:hover {
    transform: translateY(-1px);
    border-color: rgba(37, 99, 235, .28);
    box-shadow: 0 14px 32px rgba(37, 99, 235, .10);
}
.material-title-item strong,
.material-report-title strong,
.mini-list-item strong {
    display: block;
    color: #0f172a;
    font-size: 15px;
    line-height: 1.25;
}
.material-title-item span,
.material-report-title span,
.mini-list-item span,
.mini-list-item small,
.material-report-meta small {
    display: block;
    color: #64748b;
    font-size: 12px;
    line-height: 1.35;
    margin-top: 3px;
}
.material-report-meta {
    text-align: right;
    flex: 0 0 auto;
}
.rich-material-summary {
    background: radial-gradient(circle at top left, rgba(14, 165, 233, .12), transparent 34%), linear-gradient(135deg, #f8fafc 0%, #ffffff 100%);
    border: 1px solid rgba(14, 165, 233, .15);
}
.material-flow-graph {
    display: flex;
    gap: 10px;
    overflow-x: auto;
    padding: 12px 4px 18px;
    margin: 12px 0 8px;
    scroll-snap-type: x mandatory;
}
.material-flow-node {
    position: relative;
    flex: 0 0 190px;
    scroll-snap-align: start;
    padding: 14px 14px 14px 44px;
    border-radius: 18px;
    background: linear-gradient(135deg, #eef2ff 0%, #ffffff 100%);
    border: 1px solid rgba(79, 70, 229, .16);
    box-shadow: 0 12px 26px rgba(79, 70, 229, .09);
}
.material-flow-node:not(:last-child)::after {
    content: '›';
    position: absolute;
    right: -10px;
    top: 50%;
    transform: translateY(-50%);
    width: 22px;
    height: 22px;
    display: grid;
    place-items: center;
    border-radius: 999px;
    background: #fff;
    color: #2563eb;
    border: 1px solid rgba(37, 99, 235, .18);
    box-shadow: 0 8px 18px rgba(15, 23, 42, .08);
    z-index: 2;
}
.material-flow-node.mine {
    background: linear-gradient(135deg, #dcfce7 0%, #ffffff 100%);
    border-color: rgba(34, 197, 94, .25);
}
.flow-step {
    position: absolute;
    left: 12px;
    top: 14px;
    width: 24px;
    height: 24px;
    display: grid;
    place-items: center;
    border-radius: 999px;
    color: #fff;
    background: linear-gradient(135deg, #2563eb, #7c3aed);
    font-weight: 800;
    font-size: 12px;
}
.material-flow-node strong {
    display: block;
    font-size: 13px;
    color: #0f172a;
    line-height: 1.3;
}
.material-flow-node small {
    display: block;
    margin-top: 5px;
    color: #64748b;
    font-size: 11px;
}
.subsection-title {
    margin: 16px 0 10px;
    font-size: 15px;
    color: #0f172a;
}
.personnel-module-card .card-head h2 {
    font-size: 17px;
}
.personnel-module-stats .detail-box {
    min-height: 94px;
}
.mini-list-item {
    align-items: flex-start;
    flex-direction: column;
}
.mini-list-item.clickable {
    cursor: pointer;
}
.compact-report-board .report-row-board-row {
    border-radius: 16px;
    margin-bottom: 8px;
}
.admin-material-flow .material-flow-node {
    flex-basis: 220px;
}
@media (max-width: 720px) {
    .material-title-item,
    .material-report-title {
        align-items: flex-start;
        flex-direction: column;
    }
    .material-report-meta {
        text-align: left;
    }
    .material-flow-node {
        flex-basis: 82vw;
        max-width: 320px;
    }
    .personnel-module-stats {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

/* v23 - Operasyon / Güvenlik / İSG / Tesis QR paketleri */
.service-card-link{text-decoration:none;color:inherit;display:block;position:relative;overflow:hidden}.service-card-link small{display:inline-flex;margin-top:12px;font-weight:800;color:rgba(255,255,255,.88);font-size:13px}.service-card-purple{background:linear-gradient(135deg,#4f46e5,#7c3aed)!important;color:#fff!important}.service-card-dark{background:linear-gradient(135deg,#0f172a,#1e3a8a)!important;color:#fff!important}.service-card-red{background:linear-gradient(135deg,#b91c1c,#f97316)!important;color:#fff!important}.service-card-teal{background:linear-gradient(135deg,#0f766e,#0891b2)!important;color:#fff!important}.service-card-purple p,.service-card-dark p,.service-card-red p,.service-card-teal p{color:rgba(255,255,255,.9)!important}
.service-detail-hero{max-width:1180px;margin:28px auto;padding:44px;border-radius:34px;background:linear-gradient(135deg,#082f49,#0f766e);color:#fff;display:grid;grid-template-columns:minmax(0,1.25fr) minmax(300px,.75fr);gap:28px;box-shadow:0 28px 80px rgba(15,23,42,.18);position:relative;overflow:hidden}.service-detail-hero:before{content:"";position:absolute;inset:-30% -20% auto auto;width:480px;height:480px;background:rgba(255,255,255,.12);border-radius:50%}.service-detail-copy,.service-detail-panel{position:relative}.service-detail-copy h1{font-size:clamp(32px,4vw,58px);line-height:1.03;margin:18px 0}.service-detail-copy p{font-size:19px;line-height:1.7;color:rgba(255,255,255,.88)}.service-detail-panel{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);border-radius:28px;padding:24px;align-self:center}.service-detail-panel h2{margin-top:0}.service-detail-feature-list{display:flex;flex-direction:column;gap:10px}.service-detail-feature-list span{background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.18);border-radius:16px;padding:12px 14px;font-weight:800}.service-detail-grid{max-width:1180px;margin:0 auto 40px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}.service-detail-card h2{margin-top:0;color:#0f2f55}.service-detail-card p,.service-detail-card li{line-height:1.7}.service-detail-card ul{margin:0;padding-left:20px}.service-chip-tabs{display:flex;gap:10px;flex-wrap:wrap}.service-chip-tab{display:inline-flex;align-items:center;gap:6px;padding:11px 14px;border-radius:999px;background:#eef6ff;color:#12365d;text-decoration:none;font-weight:800;border:1px solid #dbeafe}.service-chip-tab.active{background:linear-gradient(135deg,#2563eb,#06b6d4);color:#fff;border-color:transparent;box-shadow:0 12px 28px rgba(37,99,235,.22)}.operation-report-cards .stat-card.warning{background:linear-gradient(135deg,#fff7ed,#fee2e2);border-color:#fed7aa}.operation-values-mini{display:flex;flex-wrap:wrap;gap:6px;margin-top:7px}.operation-values-mini span{background:#f1f5f9;border:1px solid #e2e8f0;border-radius:999px;padding:4px 8px;font-size:12px;color:#334155}.form-button-cell{display:flex;align-items:flex-end}.operation-qr-print-card .qr-box{margin:auto}.operation-scan-entry .scan-module-mini-list{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin:14px 0}.operation-scan-entry .scan-module-mini-list span{background:#eef6ff;border:1px solid #dbeafe;border-radius:999px;padding:7px 10px;font-weight:800;color:#0f3764;font-size:13px}.operation-point-card h1{font-size:clamp(28px,4vw,46px);line-height:1.08}.operation-status-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(135px,1fr));gap:9px}.operation-status-options label{display:flex;align-items:center;gap:8px;background:#f8fafc;border:1px solid #dbeafe;border-radius:16px;padding:11px;cursor:pointer;font-weight:800}.operation-status-options input{width:auto!important}.operation-status-options label:has(input:checked){background:linear-gradient(135deg,#dbeafe,#ecfeff);border-color:#60a5fa}.operation-record-form input[type=file]{background:#fff;border:1px dashed #94a3b8}.public-detail-page .app-main{background:linear-gradient(180deg,#eff6ff,#fff)}
@media (max-width: 820px){.service-detail-hero{grid-template-columns:1fr;margin:12px;border-radius:28px;padding:24px}.service-detail-copy h1{font-size:34px}.service-detail-copy p{font-size:16px}.service-detail-grid{grid-template-columns:1fr;margin:0 12px 32px}.service-detail-panel{padding:18px}.service-chip-tabs{overflow:auto;flex-wrap:nowrap;padding-bottom:5px}.service-chip-tab{white-space:nowrap}.operation-status-options{grid-template-columns:1fr 1fr}.operation-filter-form{grid-template-columns:1fr!important}.form-button-cell{display:block}.form-button-cell .btn{width:100%}}


/* v24: Ana sayfa paket kartlarında kısa açıklamaları kesin görünür yap */
.package-service-card .package-short-desc,
.public-home-page .package-service-card .package-short-desc{
  display:block!important;
  visibility:visible!important;
  opacity:1!important;
  height:auto!important;
  max-height:none!important;
  overflow:visible!important;
  margin:10px 0 0!important;
  color:#64748b!important;
  font-size:16px!important;
  line-height:1.55!important;
}
.package-service-card small,
.public-home-page .package-service-card small{
  display:inline-flex!important;
  align-items:center;
  justify-content:center;
  width:max-content;
  max-width:100%;
  margin-top:14px!important;
  padding:9px 12px;
  border-radius:999px;
  background:#eef6ff;
  color:#17406f!important;
  font-size:12px!important;
  font-weight:900;
  line-height:1.2;
}
@media (max-width:760px){
  .public-home-page .package-service-card{
    min-height:0!important;
    padding-bottom:24px!important;
  }
  .public-home-page .package-service-card .package-short-desc{
    font-size:17px!important;
    line-height:1.52!important;
    margin-top:12px!important;
  }
  .public-home-page .package-service-card small{
    width:100%;
    min-height:42px;
    margin-top:16px!important;
  }
}

/* v25: Ana sayfadaki temel modülleri de detay sayfasına bağla */
.base-service-card{
  text-decoration:none!important;
  color:inherit!important;
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.base-service-card:hover,
.base-service-card:focus-visible{
  transform:translateY(-3px);
  box-shadow:0 28px 74px rgba(15,23,42,.14)!important;
  border-color:rgba(37,99,235,.22)!important;
  outline:none;
}
.base-service-card small,
.public-home-page .base-service-card small{
  display:inline-flex!important;
  align-items:center;
  justify-content:center;
  width:max-content;
  max-width:100%;
  margin-top:14px!important;
  padding:9px 12px;
  border-radius:999px;
  background:#eef6ff;
  color:#17406f!important;
  border:1px solid #dbeafe;
  font-size:12px!important;
  font-weight:900;
  line-height:1.2;
}
.base-service-card p,
.public-home-page .base-service-card p{
  display:block!important;
  visibility:visible!important;
  opacity:1!important;
}
.service-detail-card li + li{margin-top:7px}
@media (max-width:760px){
  .public-home-page .base-service-card small{
    width:100%;
    min-height:42px;
    margin-top:16px!important;
  }
}


/* v26: Footer hizmet modülü etiketlerini tamamen kaldır.
   Çok modüllü yapıda yalnızca 3 modül göstermek eksik durduğu için footer daha sade bırakıldı. */
.pro-site-footer{grid-template-columns:minmax(260px,1.1fr) minmax(340px,1.05fr)!important;grid-template-areas:"brand links" "copy copy"!important;}
.pro-site-footer .site-footer-services{display:none!important;}
.pro-site-footer .site-footer-links{grid-area:links!important;}
.pro-site-footer .site-footer-copy{grid-area:copy!important;}
@media (max-width:980px){.pro-site-footer{grid-template-columns:1fr!important;grid-template-areas:"brand" "links" "copy"!important;}.pro-site-footer .site-footer-links{grid-template-columns:repeat(3,minmax(0,1fr));}}
@media (max-width:560px){.pro-site-footer .site-footer-links{grid-template-columns:1fr!important;}}

/* v30 - Personel QR işlem seçimi ve görev odaklı tarama */
.qr-operation-menu-head p{max-width:760px}.operation-module-select-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:18px;margin-top:18px}.operation-module-select-card{position:relative;display:flex;flex-direction:column;gap:10px;min-height:210px;padding:24px;border-radius:28px;background:linear-gradient(145deg,#fff,#eef6ff);border:1px solid rgba(15,56,99,.10);box-shadow:0 22px 55px rgba(15,56,99,.10);text-decoration:none;color:#0b2c52;overflow:hidden}.operation-module-select-card:before{content:"";position:absolute;right:-36px;top:-42px;width:128px;height:128px;border-radius:999px;background:rgba(42,133,255,.08)}.operation-module-select-card:hover{transform:translateY(-2px);box-shadow:0 28px 70px rgba(15,56,99,.16)}.operation-module-select-card.is-empty{opacity:.78}.operation-module-select-icon{width:62px;height:62px;border-radius:20px;display:grid;place-items:center;background:#eaf3ff;font-size:28px}.operation-module-select-card strong{font-size:1.45rem;line-height:1.15}.operation-module-select-card small{font-size:1rem;line-height:1.45;color:#5f6f84}.operation-module-select-card em{margin-top:auto;display:inline-flex;align-self:flex-start;padding:8px 12px;border-radius:999px;background:#e9f2ff;color:#1d528b;font-style:normal;font-weight:800}.operation-selected-module-card{background:linear-gradient(135deg,#0b2c52,#116b78);color:#fff;border:0}.operation-selected-module-card .badge-line{background:rgba(255,255,255,.16);color:#fff}.operation-selected-module-card p{color:rgba(255,255,255,.83)}.operation-selected-module-card .btn.muted{background:rgba(255,255,255,.14);color:#fff;border-color:rgba(255,255,255,.22)}.operation-point-select-list{display:grid;gap:14px}.operation-point-select-card{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:14px;align-items:center;padding:18px;border-radius:24px;background:#fff;border:1px solid rgba(15,56,99,.10);box-shadow:0 18px 46px rgba(15,56,99,.08);text-decoration:none;color:#0b2c52}.operation-point-select-card:hover{transform:translateY(-1px);box-shadow:0 22px 60px rgba(15,56,99,.14)}.operation-point-select-icon{width:50px;height:50px;border-radius:17px;display:grid;place-items:center;background:#eef6ff;font-size:24px}.operation-point-select-body{min-width:0}.operation-point-select-body strong{display:block;font-size:1.15rem;line-height:1.25}.operation-point-select-body small{display:block;margin-top:4px;color:#627286;font-weight:700}.operation-point-select-body em{display:block;margin-top:8px;color:#718096;font-style:normal;line-height:1.35}.operation-point-select-meta{display:flex;flex-direction:column;align-items:flex-end;gap:2px;padding-left:8px}.operation-point-select-meta b{min-width:36px;height:36px;border-radius:14px;display:grid;place-items:center;background:#0f6bdc;color:#fff}.operation-point-select-meta small{font-size:.78rem;color:#7b8aa0;white-space:nowrap}.operation-specific-scan-entry .badge-line{margin-left:auto;margin-right:auto}.scan-task-description,.scan-modal-task-note{background:#f2f7ff;border:1px solid rgba(15,56,99,.10);border-radius:18px;padding:12px 14px;color:#4b5d73;line-height:1.45}.operation-scan-modal-title{align-items:flex-start}.operation-scan-modal-title div{min-width:0}.operation-scan-modal-title h2{margin:0}.operation-scan-modal-title p{margin:4px 0 0;color:#6b7a90;font-weight:700}.operation-confirm-card{background:linear-gradient(145deg,#ffffff,#f4f9ff)}
@media (max-width:720px){.operation-module-select-grid{grid-template-columns:1fr;gap:14px}.operation-module-select-card{min-height:0;padding:20px;border-radius:24px}.operation-module-select-card strong{font-size:1.28rem}.operation-module-select-card small{font-size:.94rem}.operation-point-select-card{grid-template-columns:auto 1fr;align-items:flex-start;border-radius:22px;padding:15px}.operation-point-select-meta{grid-column:2;align-items:flex-start;flex-direction:row;padding-left:0}.operation-point-select-meta b{width:auto;min-width:32px;height:28px;border-radius:10px;font-size:.9rem}.operation-point-select-meta small{align-self:center}.operation-specific-scan-entry h1{font-size:1.7rem}.personnel-scan-modal-screen .scan-modal-task-note{margin-bottom:10px}}

/* v31: profesyonel filtre selectleri, hesap menüsü ve bildirim detay görünümleri */
.main-content select,
.sidebar select,
.card select,
.operation-filter-form select {
    width: 100%;
    min-height: 48px;
    appearance: none;
    -webkit-appearance: none;
    border: 1px solid rgba(88, 119, 154, .22);
    border-radius: 16px;
    background-color: rgba(255,255,255,.96);
    background-image:
        linear-gradient(45deg, transparent 50%, #163a66 50%),
        linear-gradient(135deg, #163a66 50%, transparent 50%);
    background-position:
        calc(100% - 22px) 21px,
        calc(100% - 16px) 21px;
    background-size: 6px 6px, 6px 6px;
    background-repeat: no-repeat;
    color: #102b4d;
    font-weight: 700;
    padding: 13px 48px 13px 16px;
    box-shadow: inset 0 1px 0 rgba(255,255,255,.8), 0 10px 24px rgba(15, 42, 75, .06);
    transition: border-color .18s ease, box-shadow .18s ease, transform .18s ease;
}
.main-content select:focus,
.card select:focus,
.operation-filter-form select:focus {
    outline: none;
    border-color: rgba(37, 99, 235, .58);
    box-shadow: 0 0 0 4px rgba(37,99,235,.10), 0 14px 30px rgba(15, 42, 75, .10);
}
.modern-filter-card {
    background: linear-gradient(145deg, rgba(255,255,255,.98), rgba(239,247,255,.92));
    border: 1px solid rgba(125,154,190,.18);
}
.modern-filter-form > div {
    position: relative;
}
.modern-filter-form label {
    color: #214568;
    font-size: .86rem;
    font-weight: 800;
    letter-spacing: .01em;
}
.modern-filter-form input[type="date"],
.modern-filter-form input[type="text"] {
    min-height: 48px;
    border-radius: 16px;
    border: 1px solid rgba(88,119,154,.22);
    background: rgba(255,255,255,.96);
    box-shadow: inset 0 1px 0 rgba(255,255,255,.8), 0 10px 24px rgba(15,42,75,.05);
}
.operation-record-table .record-title-link {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: #0c3d75;
    text-decoration: none;
    border-bottom: 1px dashed rgba(12,61,117,.28);
}
.operation-record-table .record-title-link::after {
    content: "Detay";
    font-size: .72rem;
    color: #2563eb;
    background: rgba(37,99,235,.08);
    border: 1px solid rgba(37,99,235,.12);
    padding: 3px 7px;
    border-radius: 999px;
}
.operation-record-table .record-title-link:hover {
    color: #2563eb;
    border-bottom-color: rgba(37,99,235,.55);
}
.operation-record-photo-card {
    overflow: hidden;
}
.operation-record-photo-link {
    display: block;
    border-radius: 22px;
    overflow: hidden;
    background: #eef5ff;
    border: 1px solid rgba(98, 135, 175, .20);
}
.operation-record-photo-link img {
    display: block;
    width: 100%;
    max-height: 520px;
    object-fit: contain;
    background: #f6f9fd;
}
.operation-record-detail-grid {
    align-items: start;
}
.operation-record-detail-card .card-head,
.operation-record-values-card .card-head {
    margin-bottom: 14px;
}
.record-detail-list {
    display: grid;
    gap: 10px;
}
.record-detail-list > div,
.record-value-item {
    padding: 14px 16px;
    border-radius: 18px;
    background: rgba(241,247,255,.75);
    border: 1px solid rgba(106,137,172,.14);
}
.record-detail-list span,
.record-value-item span {
    display: block;
    color: #60738a;
    font-size: .84rem;
    font-weight: 800;
    margin-bottom: 5px;
}
.record-detail-list strong,
.record-value-item strong {
    color: #0d2f57;
    font-size: 1rem;
}
.record-detail-text {
    margin-top: 18px;
    padding: 16px;
    border-radius: 20px;
    background: linear-gradient(145deg, rgba(255,255,255,.98), rgba(244,248,253,.94));
    border: 1px solid rgba(106,137,172,.14);
}
.record-detail-text h3 {
    margin: 0 0 8px;
    color: #102f57;
}
.record-detail-text p {
    margin: 0;
    color: #4d6074;
    line-height: 1.65;
}
.record-values-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
    gap: 12px;
}
@media (max-width: 760px) {
    .operation-record-table .record-title-link {
        flex-wrap: wrap;
    }
    .operation-record-photo-link img {
        max-height: 380px;
    }
    .record-detail-list > div,
    .record-value-item {
        padding: 12px 14px;
    }
}

/* v33 - QR işlem kayıtları sıkışık tablo yerine profesyonel kart liste */
.operation-records-card .card-head small{
    color:#60738a;
    line-height:1.45;
}
.operation-record-list{
    display:flex;
    flex-direction:column;
    gap:14px;
}
.operation-record-item{
    display:grid;
    grid-template-columns:minmax(0,1fr) auto;
    gap:16px;
    padding:18px;
    border:1px solid rgba(106,137,172,.16);
    border-radius:24px;
    background:linear-gradient(145deg,rgba(255,255,255,.98),rgba(244,249,255,.92));
    box-shadow:0 14px 34px rgba(15,42,75,.055);
}
.operation-record-topline{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:10px;
    margin-bottom:10px;
}
.operation-record-date{
    display:inline-flex;
    align-items:center;
    padding:7px 10px;
    border-radius:999px;
    background:#eef6ff;
    color:#244a72;
    font-weight:800;
    font-size:.82rem;
}
.operation-record-title{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:14px;
    text-decoration:none;
    color:#0d2f57;
    font-size:1.14rem;
    font-weight:900;
    line-height:1.25;
}
.operation-record-title span{
    min-width:0;
    overflow-wrap:anywhere;
}
.operation-record-title em{
    font-style:normal;
    flex-shrink:0;
    color:#2563eb;
    background:rgba(37,99,235,.09);
    border:1px solid rgba(37,99,235,.13);
    border-radius:999px;
    padding:7px 10px;
    font-size:.76rem;
    font-weight:900;
}
.operation-record-title:hover span{
    color:#2563eb;
}
.operation-record-desc{
    margin:8px 0 14px;
    color:#53677d;
    line-height:1.55;
    overflow-wrap:anywhere;
}
.operation-record-meta-grid{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:10px;
}
.operation-record-meta-grid > div{
    padding:12px 13px;
    border-radius:18px;
    background:#f8fbff;
    border:1px solid rgba(106,137,172,.13);
    min-width:0;
}
.operation-record-meta-grid span,
.operation-record-meta-grid small{
    display:block;
    color:#60738a;
    font-size:.78rem;
    font-weight:800;
    line-height:1.35;
}
.operation-record-meta-grid strong{
    display:block;
    margin-top:4px;
    color:#102f57;
    line-height:1.35;
    overflow-wrap:anywhere;
}
.operation-record-values-mini{
    margin-top:12px;
}
.operation-record-actions{
    display:flex;
    flex-direction:column;
    gap:9px;
    align-items:stretch;
    justify-content:center;
    min-width:118px;
}
.operation-photo-link,
.operation-detail-link{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:42px;
    padding:10px 13px;
    border-radius:16px;
    text-decoration:none;
    font-weight:900;
    text-align:center;
    white-space:nowrap;
}
.operation-photo-link{
    background:#eef6ff;
    color:#17426d;
    border:1px solid #dbeafe;
}
.operation-detail-link{
    background:linear-gradient(135deg,#2563eb,#06b6d4);
    color:#fff;
    box-shadow:0 12px 24px rgba(37,99,235,.18);
}
@media (max-width: 760px){
    .operation-record-item{
        grid-template-columns:1fr;
        padding:14px;
        border-radius:22px;
        gap:12px;
    }
    .operation-record-topline{
        align-items:flex-start;
        flex-wrap:wrap;
    }
    .operation-record-title{
        align-items:flex-start;
        flex-direction:column;
        gap:8px;
        font-size:1.06rem;
    }
    .operation-record-title em{
        width:100%;
        text-align:center;
    }
    .operation-record-meta-grid{
        grid-template-columns:1fr;
    }
    .operation-record-actions{
        display:grid;
        grid-template-columns:1fr 1fr;
        min-width:0;
    }
    .operation-record-actions .operation-detail-link:only-child{
        grid-column:1 / -1;
    }
    .operation-photo-link,
    .operation-detail-link{
        white-space:normal;
    }
}

/* v35 - Personel detay modül izinleri ve kayıt kartları */
.personnel-clickable-stats .detail-box{ text-decoration:none; color:inherit; transition:.18s ease; }
.personnel-clickable-stats .clickable-stat{ position:relative; overflow:hidden; border:1px solid rgba(51,111,190,.18); }
.personnel-clickable-stats .clickable-stat:after{ content:'›'; position:absolute; right:18px; top:50%; transform:translateY(-50%); color:#2d6bc6; font-size:30px; font-weight:900; opacity:.45; }
.personnel-clickable-stats .clickable-stat:hover{ transform:translateY(-2px); box-shadow:0 16px 42px rgba(15,44,85,.12); border-color:rgba(51,111,190,.35); }
.personnel-clickable-stats .clickable-stat.highlight{ background:linear-gradient(135deg,#f5fbff,#e9f4ff); }
.permission-toggle-grid{ display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:14px; }
.permission-toggle-card{ display:grid; grid-template-columns:auto 1fr auto; gap:12px; align-items:center; padding:16px; border-radius:22px; border:1px solid rgba(20,54,95,.12); background:linear-gradient(135deg,#ffffff,#f6fbff); box-shadow:0 10px 28px rgba(15,44,85,.06); cursor:pointer; transition:.18s ease; }
.permission-toggle-card input[type="checkbox"], .permission-toggle-card input[type="hidden"]{ position:absolute; opacity:0; pointer-events:none; width:1px; height:1px; }
.permission-toggle-card .permission-icon{ width:48px; height:48px; border-radius:17px; display:flex; align-items:center; justify-content:center; background:#eaf4ff; font-size:24px; }
.permission-toggle-card .permission-body{ display:flex; flex-direction:column; gap:3px; min-width:0; }
.permission-toggle-card .permission-body strong{ color:#0b2e57; font-weight:900; line-height:1.15; }
.permission-toggle-card .permission-body small{ color:#66758c; line-height:1.35; }
.permission-toggle-card .permission-state{ min-width:76px; height:36px; padding:4px; border-radius:999px; background:#edf3fb; display:flex; align-items:center; justify-content:center; font-size:12px; font-weight:900; }
.permission-toggle-card .permission-state em,.permission-toggle-card .permission-state b{ font-style:normal; display:none; }
.permission-toggle-card.is-open{ border-color:rgba(31,145,92,.28); background:linear-gradient(135deg,#ffffff,#f0fff7); }
.permission-toggle-card.is-open .permission-state{ background:#dff8ea; color:#137447; }
.permission-toggle-card.is-open .permission-state em{ display:block; }
.permission-toggle-card.is-closed{ border-color:rgba(190,55,55,.22); background:linear-gradient(135deg,#fff,#fff5f5); }
.permission-toggle-card.is-closed .permission-state{ background:#fee2e2; color:#b42318; }
.permission-toggle-card.is-closed .permission-state b{ display:block; }
.permission-toggle-card:hover{ transform:translateY(-2px); box-shadow:0 16px 42px rgba(15,44,85,.10); }
.permission-toggle-grid.readonly .permission-toggle-card{ cursor:default; }
.personnel-record-list{ display:flex; flex-direction:column; gap:14px; }
.personnel-record-link{ text-decoration:none; color:inherit; display:flex; justify-content:space-between; align-items:center; gap:14px; }
.operation-record-title-inline{ display:block; margin:6px 0 4px; color:#0b2e57; font-size:18px; font-weight:900; line-height:1.25; }
.inline-detail-link{ flex:0 0 auto; }
.personnel-record-detail-card .record-detail-list{ margin-top:0; }
@media (max-width: 780px){
  .permission-toggle-grid{ grid-template-columns:1fr; }
  .permission-toggle-card{ grid-template-columns:auto 1fr; }
  .permission-toggle-card .permission-state{ grid-column:1 / -1; justify-self:stretch; width:100%; }
  .personnel-record-link{ align-items:flex-start; }
  .inline-detail-link{ align-self:center; }
  .personnel-clickable-stats .clickable-stat:after{ right:12px; font-size:24px; }
}

/* v37 - Personel detay izin kartları ve modül sayım düzeltmeleri */
.personnel-module-permission-form .permission-toggle-card{
    user-select:none;
    -webkit-tap-highlight-color:transparent;
}
.personnel-module-permission-form .permission-toggle-card:focus{
    outline:3px solid rgba(37,99,235,.25);
    outline-offset:3px;
}
.personnel-module-permission-form .permission-toggle-card .permission-state{
    position:relative;
}
.personnel-module-permission-form .permission-toggle-card .permission-state::before{
    content:'';
    width:16px;
    height:16px;
    border-radius:999px;
    background:#fff;
    box-shadow:0 2px 7px rgba(15,44,85,.18);
    margin-right:6px;
}
.personnel-module-permission-form .permission-toggle-card.is-open .permission-state::before{ background:#19a35b; }
.personnel-module-permission-form .permission-toggle-card.is-closed .permission-state::before{ background:#dc2626; }
.personnel-permission-card .card-head small::after{
    content:' Kartlara dokununca durum anında değişir; en alttaki kaydet butonu ile uygulanır.';
    display:block;
    margin-top:5px;
    color:#507198;
    font-weight:700;
}
.personnel-record-detail-card .button-row .btn,
.personnel-module-records-card .operation-detail-link{ white-space:nowrap; }
