*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{--primary:#1A6B3C;--primary-dark:#0F4A28;--primary-light:#E8F5EE;--primary-mid:#A8D5BA;--accent:#0A4F8C;--accent-light:#E8F1FA;--warning:#E8A020;--warning-light:#FEF3E2;--text:#1C2B22;--text-muted:#4A6A55;--text-hint:#8AABB8;--bg:#F0F5F2;--white:#FFFFFF;--border:rgba(26,107,60,0.12);--shadow-sm:0 2px 8px rgba(26,107,60,0.08);--shadow-md:0 4px 20px rgba(26,107,60,0.14);--radius:16px;--radius-sm:10px;--radius-pill:50px}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;background:var(--bg);color:var(--text);font-size:15px;line-height:1.6;min-height:100vh}
.screen{display:none}.screen.active{display:block}
.login-wrap{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1.5rem;background:linear-gradient(145deg,#0F4A28 0%,#1A6B3C 55%,#228B4E 100%);position:relative;overflow:hidden;flex:1}
.login-card{background:var(--white);border-radius:var(--radius);padding:2.5rem 2rem;width:100%;max-width:400px;box-shadow:var(--shadow-md);position:relative;z-index:1}
.login-header{text-align:center;margin-bottom:2rem}
.login-logo-wrap{width:60px;height:60px;background:var(--primary-light);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;border:2px solid var(--primary-mid)}
.login-logo-wrap svg{width:28px;height:28px;stroke:var(--primary);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.login-institution{font-size:10px;font-weight:700;color:var(--text-hint);letter-spacing:.12em;text-transform:uppercase;margin-bottom:5px}
.login-title{font-size:22px;font-weight:700;color:var(--text)}
.form-group{margin-bottom:1.1rem}
.form-group label{display:block;font-size:11px;font-weight:700;color:var(--text-muted);margin-bottom:6px;letter-spacing:.06em;text-transform:uppercase}
.form-group input{width:100%;padding:12px 14px;font-size:15px;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--white);color:var(--text);outline:none;transition:border-color .2s,box-shadow .2s;font-family:inherit}
.form-group input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(26,107,60,.12)}
.btn-login{width:100%;padding:14px;background:var(--primary);color:white;border:none;border-radius:var(--radius-sm);font-size:15px;font-weight:600;cursor:pointer;margin-top:.5rem;transition:background .2s;font-family:inherit}
.btn-login:hover{background:var(--primary-dark)}.btn-login:disabled{background:var(--text-hint);cursor:default}
.login-help{text-align:center;margin-top:1.25rem;font-size:13px;color:var(--text-hint)}
.login-help strong{color:var(--primary);font-weight:700}
.error-msg{background:#FEE8E8;color:#B02020;border-radius:var(--radius-sm);padding:10px 14px;font-size:13px;margin:.75rem 0;display:none;border-left:3px solid #B02020}
.portal-wrap{max-width:560px;margin:0 auto;padding:1rem 1rem 4rem;width:100%}
.portal-header{background:linear-gradient(135deg,var(--primary-dark),var(--primary));border-radius:var(--radius);padding:1.25rem 1.5rem;margin-bottom:1rem;display:flex;align-items:flex-start;justify-content:space-between;box-shadow:var(--shadow-md)}
.portal-header-left .logo-sm{font-size:10px;font-weight:700;color:rgba(255,255,255,.55);letter-spacing:.1em;text-transform:uppercase;margin-bottom:6px}
.patient-name{font-size:20px;font-weight:700;color:white}.patient-sub{font-size:13px;color:rgba(255,255,255,.7);margin-top:2px}
.btn-logout{font-size:12px;color:rgba(255,255,255,.75);background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-pill);padding:5px 14px;cursor:pointer;font-family:inherit;white-space:nowrap}
.btn-logout:hover{background:rgba(255,255,255,.22);color:white}
.start-card{background:linear-gradient(135deg,var(--accent),#0d6ebd);border-radius:var(--radius);padding:1.25rem 1.5rem;margin-bottom:1rem;box-shadow:var(--shadow-sm)}
.start-label{font-size:10px;font-weight:700;color:rgba(255,255,255,.7);letter-spacing:.1em;text-transform:uppercase;margin-bottom:4px}
.start-date{font-size:22px;font-weight:700;color:white}.start-schema{font-size:13px;color:rgba(255,255,255,.8);margin-top:3px}
.countdown-badge{display:inline-block;background:rgba(255,255,255,.2);color:white;border-radius:var(--radius-pill);font-size:12px;font-weight:600;padding:4px 14px;margin-top:10px}
.no-date-card{background:var(--warning-light);border-radius:var(--radius);border-left:4px solid var(--warning);padding:1rem 1.25rem;margin-bottom:1rem;font-size:14px;color:#7A4A00}
.no-date-card .nd-label{font-weight:600;margin-bottom:4px}
.section-label{font-size:10px;font-weight:700;color:var(--text-hint);letter-spacing:.1em;text-transform:uppercase;margin:1.25rem 0 .6rem}
.timeline{background:var(--white);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm)}
.tl-item{display:flex;align-items:flex-start;gap:12px;padding:14px 1.5rem;border-bottom:1px solid var(--bg);transition:background .15s}
.tl-item:last-child{border-bottom:none}.tl-item:hover{background:var(--bg)}
.tl-icon{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
.tl-icon.done{background:var(--primary-light)}.tl-icon.active{background:var(--accent-light)}.tl-icon.pending{background:var(--bg)}
.tl-content{flex:1}.tl-step{font-size:14px;font-weight:600}
.tl-step.done{color:var(--text-muted)}.tl-step.active{color:var(--accent)}.tl-step.pending{color:var(--text-hint)}
.tl-detail{font-size:12px;color:var(--text-hint);margin-top:2px}.tl-date{font-size:12px;color:var(--text-hint);flex-shrink:0;padding-top:3px}
.info-card{background:var(--white);border-radius:var(--radius);padding:1rem 1.5rem;margin-top:1rem;box-shadow:var(--shadow-sm)}
.info-row{display:flex;justify-content:space-between;align-items:center;padding:9px 0;border-bottom:1px solid var(--bg);font-size:14px}
.info-row:last-child{border-bottom:none}.info-key{color:var(--text-muted)}.info-val{color:var(--text);font-weight:600;text-align:right;max-width:55%}
.contact-bar{background:var(--primary-light);border-radius:var(--radius-sm);padding:12px 1.25rem;margin-top:1rem;font-size:13px;color:var(--primary);text-align:center;border:1px solid var(--primary-mid)}
.contact-bar strong{color:var(--primary-dark);font-weight:700}
@media(max-width:480px){.portal-header{flex-direction:column;gap:10px}.login-card{padding:2rem 1.5rem}}

/* Stap visuele feedback */
.tl-item { cursor: default; transition: background 0.2s; }
.tl-icon.done { background: #E8F5EE; border: 2px solid #1A6B3C; }
.tl-icon.active { background: #E8F1FA; border: 2px solid #0A4F8C; animation: pulse 2s infinite; }
.tl-icon.pending { background: #F5F5F5; border: 2px solid #ddd; }
.tl-step.done { color: #1A6B3C; text-decoration: line-through; text-decoration-color: #A8D5BA; }
.tl-step.active { color: #0A4F8C; font-weight: 700; }
.tl-step.pending { color: #9AABB8; }
.tl-detail.done { color: #A8D5BA; }
.tl-detail.active { color: #4A6A55; }
.tl-detail.pending { color: #C5D5DE; }
@keyframes pulse { 0%,100% { box-shadow: 0 0 0 0 rgba(10,79,140,0.2); } 50% { box-shadow: 0 0 0 6px rgba(10,79,140,0); } }
