*{box-sizing:border-box}body{font-family:Inter,Arial,Helvetica,sans-serif;margin:0;background:#eef2f6;color:#172033}.app,.wrap{max-width:1180px;margin:28px auto;padding:0 16px}.card{background:#fff;border:1px solid #e6ebf2;border-radius:18px;box-shadow:0 12px 30px rgba(15,23,42,.07);padding:22px;margin-bottom:18px}h1,h2{margin:0;color:#0f172a}h1{font-size:30px}h2{font-size:20px}.muted{color:#64748b;margin:6px 0 0}.grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.full{grid-column:1/-1}label{display:block;font-weight:700;margin-bottom:6px;color:#334155}input,select,textarea{width:100%;padding:12px;border:1px solid #cfd8e3;border-radius:12px;font-size:15px;background:#fff;outline:none}input:focus,select:focus,textarea:focus{border-color:#0f766e;box-shadow:0 0 0 4px rgba(15,118,110,.12)}textarea{min-height:100px}.help{font-size:13px;color:#64748b}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;background:#0f766e;color:#fff;border:0;border-radius:12px;padding:11px 16px;font-weight:800;cursor:pointer;text-decoration:none;white-space:nowrap}.btn:hover{filter:brightness(.96)}.btn.secondary{background:#334155}.btn.danger{background:#b91c1c}.btn.light{background:#edf2f7;color:#111827}.alert{padding:13px;border-radius:12px;margin-bottom:14px}.alert.ok{background:#dcfce7;color:#166534}.alert.err{background:#fee2e2;color:#991b1b}.topbar{display:flex;gap:14px;justify-content:space-between;align-items:center;flex-wrap:wrap;margin-bottom:18px}.nav{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.nav-link{display:inline-flex;align-items:center;background:#fff;color:#0f172a;border:1px solid #dce3ec;border-radius:999px;padding:10px 14px;text-decoration:none;font-weight:800;box-shadow:0 6px 16px rgba(15,23,42,.05)}.nav-link:hover{background:#f8fafc}.nav-link.logout{background:#334155;color:#fff;border-color:#334155}.nav-user{color:#64748b;font-size:13px;padding:0 6px}.table{width:100%;border-collapse:separate;border-spacing:0;background:#fff;overflow:hidden}.table th,.table td{border-bottom:1px solid #e8edf4;padding:11px 10px;text-align:left;font-size:14px;vertical-align:middle}.table th{font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:#64748b;background:#f8fafc}.table tr:hover td{background:#fbfdff}.badge,.status{display:inline-block;padding:5px 9px;border-radius:999px;background:#e5e7eb;font-size:12px;font-weight:800}.badge.periodik{background:#dbeafe;color:#1e40af}.badge.takip{background:#ffedd5;color:#9a3412}.status{background:#ecfdf5;color:#047857}.actions{display:flex;gap:6px;flex-wrap:wrap}.print-area{background:#fff;padding:28px}.kv{display:grid;grid-template-columns:220px 1fr;border-bottom:1px solid #e5e7eb}.kv div{padding:9px}.kv div:first-child{font-weight:700;background:#f9fafb}.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:18px}.stat-card{background:#fff;border:1px solid #e6ebf2;border-radius:18px;padding:20px;box-shadow:0 10px 24px rgba(15,23,42,.06);position:relative;overflow:hidden}.stat-card:after{content:"";position:absolute;right:-28px;top:-28px;width:90px;height:90px;border-radius:50%;background:#e0f2fe}.stat-card.primary{background:linear-gradient(135deg,#0f766e,#14b8a6);color:#fff}.stat-card.primary .stat-label,.stat-card.primary .stat-sub{color:#d9fffb}.stat-card.primary:after{background:rgba(255,255,255,.18)}.stat-card.warning:after{background:#ffedd5}.stat-label{font-weight:800;color:#64748b}.stat-value{font-size:38px;font-weight:900;line-height:1.1;margin:8px 0}.stat-sub{font-size:13px;color:#64748b;font-weight:700}.dash-grid{display:grid;grid-template-columns:2fr 1fr;gap:18px}.card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px;flex-wrap:wrap}.day-list{display:flex;flex-direction:column;gap:12px}.day-row{display:grid;grid-template-columns:150px 1fr 90px;gap:12px;align-items:center}.day-name span{display:block;color:#64748b;font-size:12px;margin-top:2px}.bar{height:12px;background:#edf2f7;border-radius:999px;overflow:hidden}.bar span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,#0f766e,#22c55e)}.day-count{text-align:right}.day-count small{display:block;color:#64748b;font-weight:700}.mini-list{display:flex;flex-direction:column;gap:10px}.mini-list div{display:flex;justify-content:space-between;align-items:center;background:#f8fafc;border:1px solid #e6ebf2;border-radius:14px;padding:12px}.mini-list b{background:#0f766e;color:#fff;border-radius:999px;padding:4px 9px}@media(max-width:980px){.stat-grid,.dash-grid{grid-template-columns:1fr 1fr}.day-row{grid-template-columns:1fr}.day-count{text-align:left}}@media(max-width:720px){.grid,.stat-grid,.dash-grid{grid-template-columns:1fr}.kv{grid-template-columns:1fr}.table{display:block;overflow-x:auto;white-space:nowrap}.app,.wrap{margin:14px auto}.topbar{align-items:flex-start}.nav{width:100%}.nav-link{flex:1;justify-content:center}.day-row{gap:6px}}@media print{body{background:#fff}.no-print{display:none!important}.app,.wrap{max-width:none;margin:0}.card{box-shadow:none;border-radius:0}.print-area{padding:0}}
/* v3.2 logo entegrasyonu */
.topbar h1{display:flex;align-items:center;gap:12px}
.topbar h1:before{content:"";display:inline-block;width:44px;height:44px;background:url("logo.webp") center/contain no-repeat;flex:0 0 44px}
.login-logo{display:block;width:76px;height:76px;object-fit:contain;margin:0 auto 14px}
.print-title{display:flex;align-items:center;gap:14px;margin-bottom:18px}
.print-title img{width:58px;height:58px;object-fit:contain}
.print-title h1{margin:0}
@media(max-width:720px){.topbar h1:before{width:38px;height:38px;flex-basis:38px}}

/* v3.3 modern public form */
.public-form-body{background:radial-gradient(circle at top left,#e0f2fe 0,#eef2f6 34%,#eef2f6 100%)}
.form-shell{max-width:980px;margin:34px auto;padding:0 16px 34px}
.form-hero{display:flex;align-items:center;gap:18px;margin-bottom:20px;background:#fff;border:1px solid #e6ebf2;border-radius:26px;padding:22px;box-shadow:0 18px 45px rgba(15,23,42,.08);position:relative;overflow:hidden}
.form-hero:after{content:"";position:absolute;right:-42px;top:-42px;width:150px;height:150px;border-radius:50%;background:linear-gradient(135deg,rgba(15,118,110,.16),rgba(14,165,233,.12))}
.form-logo{width:78px;height:78px;object-fit:contain;flex:0 0 78px;position:relative;z-index:1}
.form-hero-text{position:relative;z-index:1}.form-hero h1{font-size:34px;margin:0}.form-hero p{margin:6px 0 0;color:#64748b;font-weight:600}
.form-card{background:#fff;border:1px solid #e6ebf2;border-radius:26px;box-shadow:0 18px 45px rgba(15,23,42,.08);padding:26px;margin-bottom:18px}
.form-section-title{font-size:18px;font-weight:900;color:#0f172a;margin:4px 0 16px;display:flex;align-items:center;gap:10px}.form-section-title:before{content:"";width:10px;height:28px;border-radius:999px;background:linear-gradient(180deg,#0f766e,#22c55e)}
.form-intro{background:#f8fafc;border:1px solid #e6ebf2;border-radius:18px;padding:15px 16px;margin-bottom:18px;color:#334155;line-height:1.45}.checkline{display:flex;gap:10px;align-items:flex-start;background:#f8fafc;border:1px solid #e6ebf2;border-radius:16px;padding:14px 15px;margin:6px 0}.checkline input{width:auto;margin-top:3px;flex:0 0 auto}.checkline label{margin:0;font-weight:700;color:#334155;line-height:1.45}
.submit-row{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-top:4px}.submit-note{font-size:13px;color:#64748b;font-weight:700}.btn.big{font-size:17px;padding:14px 26px;border-radius:16px;background:linear-gradient(135deg,#0f766e,#14b8a6);box-shadow:0 12px 24px rgba(15,118,110,.22)}
.form-footer{text-align:center;color:#64748b;font-size:13px;font-weight:700;margin-top:16px}.required-star{color:#dc2626}
@media(max-width:720px){.form-shell{margin:14px auto}.form-hero{align-items:flex-start;padding:18px;border-radius:22px}.form-logo{width:58px;height:58px;flex-basis:58px}.form-hero h1{font-size:25px}.form-card{padding:18px;border-radius:22px}.submit-row{display:block}.btn.big{width:100%;margin-top:12px}}


.intro-check {
  align-items: flex-start;
  gap: 12px;
  font-weight: 600;
}
.intro-check input {
  margin-top: 3px;
  flex: 0 0 auto;
}
.intro-check label {
  margin: 0;
  cursor: pointer;
}
