/* PERFECTRAY PORTAL — Design System */
@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400;500;600;700;800&display=swap');
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --teal:#00b8a8;--teal-dark:#008f83;--teal-darker:#006d63;
  --teal-light:#ebfaf9;--teal-mid:#b2ece8;
  --gray-dark:#212121;--gray-700:#374151;--gray-600:#4b5563;
  --gray-500:#6b7280;--gray-400:#9ca3af;--gray-200:#e5e7eb;
  --gray-100:#f3f4f6;--gray-50:#f7f7f7;--white:#ffffff;
  --red:#ef4444;--red-light:#fee2e2;--green:#16a34a;--green-light:#dcfce7;
  --shadow-md:0 4px 20px rgba(0,0,0,.09);--shadow-lg:0 8px 40px rgba(0,0,0,.14);
  --radius:16px;--radius-sm:10px;--radius-pill:9999px;
}
html{font-size:16px;scroll-behavior:smooth}
body{font-family:'Montserrat',sans-serif;background:linear-gradient(145deg,#e6faf8 0%,#f7f7f7 55%,#e6faf8 100%);min-height:100vh;color:var(--gray-dark);line-height:1.5}
.page-wrapper{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 16px}
.card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow-md);padding:44px 40px;width:100%;max-width:480px}
.card-wide{max-width:720px}

/* ---- LOGO fond alb, mai mare ---- */
.brand{text-align:center;margin-bottom:36px}
.brand-logo-wrap{display:inline-block;background:var(--white);border:2px solid var(--teal-mid);border-radius:var(--radius-sm);padding:14px 34px;margin-bottom:12px;box-shadow:0 2px 14px rgba(0,184,168,.15)}
.brand-logo-wrap img{height:58px;width:auto;display:block;object-fit:contain}
.brand-subtitle{font-size:13px;font-weight:500;color:var(--gray-500);letter-spacing:.4px;margin-top:4px}

/* Logo inline (topbar) — fond alb pe fundal teal */
.brand-inline{display:flex;align-items:center;gap:14px}
.brand-inline .logo-box{background:var(--white);border-radius:8px;padding:8px 18px;display:flex;align-items:center;box-shadow:0 2px 8px rgba(0,0,0,.12)}
.brand-inline .logo-box img{height:40px;width:auto;display:block;object-fit:contain}
.brand-inline .brand-text .brand-name{font-size:17px;font-weight:800;color:var(--white)}
.brand-inline .brand-text .brand-sub{font-size:11px;opacity:.85;color:var(--white)}

.section-title{font-size:21px;font-weight:800;color:var(--gray-dark);margin-bottom:6px;letter-spacing:-.2px}
.section-desc{font-size:14px;color:var(--gray-500);margin-bottom:28px;line-height:1.6}

/* Forms */
.form-group{margin-bottom:18px}
label{display:block;font-size:11px;font-weight:700;color:var(--gray-600);margin-bottom:6px;text-transform:uppercase;letter-spacing:.6px}
label .required{color:var(--red);margin-left:2px}
input[type=text],input[type=email],input[type=tel],input[type=password],select,textarea{width:100%;padding:11px 16px;border:1.5px solid var(--gray-200);border-radius:var(--radius-sm);font-size:14px;font-family:'Montserrat',sans-serif;font-weight:500;color:var(--gray-dark);background:var(--white);transition:border-color .2s,box-shadow .2s;outline:none}
input:focus,select:focus,textarea:focus{border-color:var(--teal);box-shadow:0 0 0 3px rgba(0,184,168,.13)}
input::placeholder{color:var(--gray-400);font-weight:400}
input.code-input{font-size:22px;font-weight:800;letter-spacing:6px;text-align:center;text-transform:uppercase;font-family:'Courier New',monospace;padding:14px}
.file-upload-wrapper{position:relative}
.file-upload-label{display:flex;align-items:center;gap:12px;padding:13px 16px;border:2px dashed var(--gray-200);border-radius:var(--radius-sm);cursor:pointer;transition:border-color .2s,background .2s;font-weight:normal}
.file-upload-label:hover{border-color:var(--teal);background:var(--teal-light)}
.file-upload-label.has-file{border-color:var(--teal);background:var(--teal-light);border-style:solid}
.file-upload-label .file-icon{font-size:20px}
.file-upload-label .file-text{flex:1;font-size:12px;color:var(--gray-600)}
.file-upload-label .file-text strong{display:block;font-size:13px;font-weight:700;color:var(--gray-dark);margin-bottom:2px}
input[type=file]{position:absolute;width:1px;height:1px;opacity:0;overflow:hidden}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:11px 24px;border:none;border-radius:var(--radius-pill);font-family:'Montserrat',sans-serif;font-size:14px;font-weight:700;cursor:pointer;text-decoration:none;transition:all .2s;white-space:nowrap}
.btn-primary{background:var(--teal);color:var(--white);box-shadow:0 4px 16px rgba(0,184,168,.28)}
.btn-primary:hover{background:var(--teal-dark);transform:translateY(-1px)}
.btn-secondary{background:var(--gray-100);color:var(--gray-700)}
.btn-secondary:hover{background:var(--gray-200)}
.btn-outline{background:transparent;border:2px solid var(--teal);color:var(--teal)}
.btn-outline:hover{background:var(--teal-light)}
.btn-danger{background:var(--red-light);color:var(--red)}
.btn-danger:hover{background:#fecaca}
.btn-ghost{background:transparent;border:1.5px solid rgba(255,255,255,.4);color:var(--white)}
.btn-ghost:hover{background:rgba(255,255,255,.18)}
.btn-sms{background:#fff7ed;color:#c2410c;border:1.5px solid #fed7aa}
.btn-sms:hover{background:#ffedd5}
.btn-email{background:#eff6ff;color:#1d4ed8;border:1.5px solid #bfdbfe}
.btn-email:hover{background:#dbeafe}
.btn-full{width:100%}
.btn:disabled{opacity:.6;cursor:not-allowed;transform:none!important}
.btn .spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;display:none}
.btn.loading .spinner{display:block}
.btn.loading .btn-text{opacity:.7}
.btn-sm{padding:6px 14px;font-size:12px}
.btn-xs{padding:4px 10px;font-size:11px}

/* Alerts */
.alert{padding:12px 16px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;margin-bottom:16px;display:none;align-items:flex-start;gap:10px;line-height:1.5}
.alert.show{display:flex}
.alert-icon{font-size:15px;flex-shrink:0;margin-top:1px}
.alert-error{background:var(--red-light);color:#991b1b;border-left:3px solid var(--red)}
.alert-success{background:var(--green-light);color:#166534;border-left:3px solid var(--green)}
.alert-info{background:var(--teal-light);color:var(--teal-darker);border-left:3px solid var(--teal)}

/* Download cards */
.download-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:20px}
@media(max-width:500px){.download-grid{grid-template-columns:1fr}}
.download-card{border:1.5px solid var(--gray-200);border-radius:var(--radius-sm);padding:24px 16px;text-align:center;transition:border-color .2s,box-shadow .2s,transform .2s}
.download-card:hover{border-color:var(--teal);box-shadow:0 4px 16px rgba(0,184,168,.12);transform:translateY(-2px)}
.download-card.unavailable{opacity:.4;pointer-events:none}
.download-card .dc-icon{font-size:38px;margin-bottom:10px}
.download-card .dc-title{font-weight:800;font-size:15px;color:var(--gray-dark);margin-bottom:4px}
.download-card .dc-desc{font-size:12px;color:var(--gray-400);margin-bottom:14px;line-height:1.5}
.download-card .btn{font-size:13px;padding:9px 16px;width:100%;margin-bottom:8px}
.download-card .btn:last-child{margin-bottom:0}

.patient-info-bar{background:var(--teal-light);border:1px solid var(--teal-mid);border-radius:var(--radius-sm);padding:16px 20px;margin-bottom:20px}
.patient-info-bar .pi-name{font-size:17px;font-weight:800;color:var(--gray-dark)}
.patient-info-bar .pi-type{font-size:13px;color:var(--teal-dark);font-weight:600;margin-top:3px}
.patient-info-bar .pi-code{font-size:12px;color:var(--gray-500);margin-top:4px}

.security-note{background:var(--teal-light);border:1px solid var(--teal-mid);border-radius:var(--radius-sm);padding:12px 16px;font-size:13px;font-weight:500;color:var(--teal-darker);margin-top:16px;display:flex;align-items:flex-start;gap:8px;line-height:1.5}
.divider{display:flex;align-items:center;gap:12px;margin:20px 0;color:var(--gray-400);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}
.divider::before,.divider::after{content:'';flex:1;height:1px;background:var(--gray-200)}

.badge{display:inline-flex;align-items:center;gap:3px;padding:3px 10px;border-radius:var(--radius-pill);font-size:11px;font-weight:700}
.badge-green{background:var(--green-light);color:#166534}
.badge-red{background:var(--red-light);color:#991b1b}
.badge-teal{background:var(--teal-light);color:var(--teal-darker)}
.badge-gray{background:var(--gray-100);color:var(--gray-600)}

/* Modal */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);display:none;align-items:center;justify-content:center;z-index:10000;padding:16px}
.modal-overlay.show{display:flex}
.modal-box{background:var(--white);border-radius:var(--radius);width:100%;box-shadow:var(--shadow-lg);max-height:92vh;overflow-y:auto}
.pdf-modal-box{max-width:960px;display:flex;flex-direction:column}
.pdf-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--gray-200);position:sticky;top:0;background:var(--white);z-index:1}
.pdf-modal-header h3{font-size:15px;font-weight:700;color:var(--gray-dark)}
#pdfIframe{width:100%;height:78vh;border:none;display:block}

/* Loader */
.loader-overlay{position:fixed;inset:0;background:rgba(255,255,255,.88);display:none;flex-direction:column;align-items:center;justify-content:center;z-index:9999;gap:16px}
.loader-overlay.show{display:flex}
.loader-overlay p{color:var(--gray-600);font-size:14px;font-weight:600}
.spinner-lg{width:46px;height:46px;border:4px solid var(--teal-mid);border-top-color:var(--teal);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* Admin layout */
.admin-page{background:var(--gray-50);min-height:100vh}
.top-bar{background:linear-gradient(135deg,var(--teal-darker),var(--teal));padding:14px 28px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}
.top-bar .tb-right{display:flex;align-items:center;gap:12px}
.top-bar .tb-user{font-size:13px;font-weight:600;color:rgba(255,255,255,.9)}
.admin-content{max-width:1400px;margin:0 auto;padding:28px 24px}
.table-card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow-md);overflow:hidden}
.table-card-header{padding:18px 24px;border-bottom:1px solid var(--gray-200);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}
.table-card-header h2{font-size:16px;font-weight:800;color:var(--gray-dark)}
.search-input{padding:9px 16px;border:1.5px solid var(--gray-200);border-radius:var(--radius-pill);font-size:13px;font-family:'Montserrat',sans-serif;font-weight:500;width:240px;outline:none;transition:border-color .2s}
.search-input:focus{border-color:var(--teal)}
.table-wrapper{overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:13px}
th{background:var(--gray-50);padding:11px 14px;text-align:left;font-weight:700;font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--gray-500);border-bottom:2px solid var(--gray-200);white-space:nowrap}
td{padding:11px 14px;border-bottom:1px solid var(--gray-100);vertical-align:middle}
tr:hover td{background:#f0faf9}
.action-btns{display:flex;gap:5px;flex-wrap:wrap}
.pagination{display:flex;align-items:center;justify-content:center;gap:6px;padding:16px}
.pg-btn{padding:6px 14px;border:1.5px solid var(--gray-200);border-radius:var(--radius-pill);background:var(--white);font-size:13px;font-family:'Montserrat',sans-serif;font-weight:600;cursor:pointer;transition:all .2s;color:var(--gray-700)}
.pg-btn:hover:not(:disabled){border-color:var(--teal);color:var(--teal)}
.pg-btn:disabled{opacity:.4;cursor:not-allowed}
.pg-btn.active{background:var(--teal);color:var(--white);border-color:var(--teal)}
.empty-state{text-align:center;padding:52px 20px;color:var(--gray-400)}
.empty-state .es-icon{font-size:42px;margin-bottom:12px}

/* Upload modal */
.upload-modal-box{max-width:580px}
.upload-modal-header{background:linear-gradient(135deg,var(--teal-darker),var(--teal));border-radius:var(--radius) var(--radius) 0 0;padding:20px 28px;color:var(--white)}
.upload-modal-header h2{font-size:17px;font-weight:800;margin:0 0 3px}
.upload-modal-header p{font-size:12px;opacity:.85;margin:0}
.upload-modal-body{padding:28px}

/* Success modal */
.success-modal-box{max-width:460px;text-align:center;padding:36px}
.success-modal-box .success-icon{font-size:52px;margin-bottom:14px}
.success-modal-box h3{font-size:20px;font-weight:800;color:var(--gray-dark);margin-bottom:8px}
.credentials-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:16px 0 18px}
.cred-box{background:var(--teal-light);border:1.5px solid var(--teal-mid);border-radius:var(--radius-sm);padding:14px 12px}
.cred-box .cb-label{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:1.2px;color:var(--teal-dark);margin-bottom:6px}
.cred-box .cb-value{font-size:15px;font-weight:800;color:var(--teal-darker);font-family:'Courier New',monospace;letter-spacing:2px;word-break:break-all}
.notif-row{display:flex;gap:8px;justify-content:center;margin-bottom:14px}
.progress-wrapper{margin-bottom:16px;display:none}
.pw-header{display:flex;justify-content:space-between;font-size:12px;font-weight:600;color:var(--gray-600);margin-bottom:6px}
.progress-track{background:var(--gray-200);border-radius:4px;height:8px;overflow:hidden}
.progress-fill{background:linear-gradient(90deg,var(--teal-darker),var(--teal));height:100%;width:0%;transition:width .3s;border-radius:4px}
@media(max-width:600px){.card{padding:28px 20px}.page-wrapper{padding:16px}.admin-content{padding:16px 12px}}
