*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--teal: #0D9488;--teal-light: #CCFBF1;--teal-dark: #0F766E;--teal-xlight: #F0FDFA;--bg: #F8FAFC;--surface: #FFFFFF;--border: #E2E8F0;--border-strong: #CBD5E1;--text: #0F172A;--text-2: #475569;--text-3: #94A3B8;--red: #EF4444;--amber: #F59E0B;--green: #22C55E;--wa-green: #25D366;--wa-green-dark: #128C7E;--shadow-sm: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 12px rgba(0,0,0,.08), 0 2px 4px rgba(0,0,0,.04);--shadow-lg: 0 10px 30px rgba(0,0,0,.1), 0 4px 8px rgba(0,0,0,.06);--radius: 12px;--radius-sm: 8px;--sidebar-w: 240px;--font: "DM Sans", sans-serif;--mono: "DM Mono", monospace}html,body,#root{height:100%}body{font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:99px}input,textarea,select{font-family:var(--font)}input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none}.app{display:flex;height:100%}.sidebar{width:var(--sidebar-w);min-height:100vh;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;top:0;left:0;z-index:100;transition:transform .25s ease}.sidebar-logo{padding:24px 20px 20px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--border)}.sidebar-logo-icon{width:36px;height:36px;background:var(--teal);border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar-logo-img{width:48px;height:28px;object-fit:contain;flex-shrink:0}.sidebar-logo-text{font-size:15px;font-weight:700;color:var(--text);line-height:1.2}.sidebar-logo-sub{font-size:11px;color:var(--text-3);font-weight:400}.sidebar-nav{flex:1;padding:12px 10px;display:flex;flex-direction:column;gap:2px}.nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);cursor:pointer;color:var(--text-2);font-size:14px;font-weight:500;transition:all .15s;border:none;background:none;width:100%;text-align:left}.nav-item:hover{background:var(--teal-xlight);color:var(--teal)}.nav-item.active{background:var(--teal-xlight);color:var(--teal);font-weight:600}.nav-item svg{width:18px;height:18px;flex-shrink:0}.sidebar-footer{padding:16px 10px;border-top:1px solid var(--border)}.sidebar-user{display:flex;align-items:center;gap:10px;margin-bottom:10px}.sidebar-avatar{width:32px;height:32px;border-radius:50%;background:var(--teal-xlight);display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar-avatar-letter{color:var(--teal);font-size:13px;font-weight:700}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{font-size:13px;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-user-role{font-size:12px;color:var(--text-3)}.main{margin-left:var(--sidebar-w);flex:1;min-height:100vh;display:flex;flex-direction:column}.topbar{background:var(--surface);border-bottom:1px solid var(--border);padding:0 28px;height:60px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50}.topbar-title{font-size:17px;font-weight:600;color:var(--text)}.topbar-actions{display:flex;align-items:center;gap:10px}.content{padding:28px;flex:1;max-width:1100px}.btn{display:inline-flex;align-items:center;gap:7px;padding:9px 16px;border-radius:var(--radius-sm);font-size:14px;font-weight:600;cursor:pointer;border:none;transition:all .15s;white-space:nowrap}.btn svg{width:16px;height:16px}.btn-primary{background:var(--teal);color:#fff}.btn-primary:hover{background:var(--teal-dark);transform:translateY(-1px);box-shadow:0 4px 12px #0d94884d}.btn-secondary{background:var(--surface);color:var(--text-2);border:1px solid var(--border)}.btn-secondary:hover{border-color:var(--teal);color:var(--teal);background:var(--teal-xlight)}.btn-wa{background:var(--wa-green);color:#fff;padding:13px 24px;font-size:15px;border-radius:10px}.btn-wa:hover{background:var(--wa-green-dark);transform:translateY(-1px);box-shadow:0 4px 16px #25d36659}.btn-ghost{background:none;border:none;color:var(--text-3);cursor:pointer;padding:6px 8px;border-radius:var(--radius-sm)}.btn-ghost:hover{background:var(--bg);color:var(--text-2)}.btn-danger{background:#fee2e2;color:var(--red);border:1px solid #FECACA}.btn-danger:hover{background:var(--red);color:#fff}.btn-lg{padding:12px 22px;font-size:15px;border-radius:10px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm)}.card-header{padding:18px 20px 0}.card-body{padding:20px}.card-title{font-size:13px;font-weight:600;color:var(--text-2);text-transform:uppercase;letter-spacing:.06em}.summary-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px}.summary-card{padding:20px}.summary-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:12px}.summary-icon svg{width:20px;height:20px}.summary-value{font-size:26px;font-weight:700;color:var(--text);margin:4px 0}.summary-delta{font-size:12px;color:var(--text-3)}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-size:13px;font-weight:600;color:var(--text-2)}.form-input{padding:9px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;color:var(--text);background:var(--surface);outline:none;transition:border-color .15s,box-shadow .15s;width:100%}.form-input:focus{border-color:var(--teal);box-shadow:0 0 0 3px #0d94881f}.form-input::placeholder{color:var(--text-3)}.form-input.mono{font-family:var(--mono)}.form-row{display:grid;gap:16px}.form-row-2{grid-template-columns:1fr 1fr}.form-row-3{grid-template-columns:1fr 1fr 1fr}.form-row-4{grid-template-columns:repeat(4,1fr)}.form-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:22px;margin-bottom:20px}.section-title{font-size:16px;font-weight:700;color:var(--text);margin-bottom:14px;display:flex;align-items:center;gap:8px}.section-title-icon{width:28px;height:28px;background:var(--teal-xlight);border-radius:8px;display:flex;align-items:center;justify-content:center}.section-title-icon svg{width:15px;height:15px;color:var(--teal)}.rx-table{width:100%;border-collapse:collapse;font-size:14px}.rx-table th{padding:10px 12px;background:var(--bg);font-size:12px;font-weight:600;color:var(--text-2);text-align:left;border-bottom:1px solid var(--border);letter-spacing:.04em}.rx-table td{padding:8px;border-bottom:1px solid var(--border)}.rx-table tr:last-child td{border-bottom:none}.rx-input{width:100%;padding:7px 9px;border:1px solid var(--border);border-radius:6px;font-family:var(--mono);font-size:14px;background:var(--bg);color:var(--text);outline:none;text-align:center;transition:border-color .15s}.rx-input:focus{border-color:var(--teal);background:var(--surface);box-shadow:0 0 0 2px #0d94881a}.finance-display{background:var(--bg);border-radius:var(--radius-sm);padding:16px 18px;border:1px solid var(--border)}.finance-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0}.finance-label{font-size:14px;color:var(--text-2)}.finance-value{font-size:15px;font-weight:600;font-family:var(--mono);color:var(--text)}.finance-value.balance{color:var(--red);font-size:18px}.finance-divider{height:1px;background:var(--border);margin:8px 0}.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:99px;font-size:12px;font-weight:600}.badge-teal{background:var(--teal-light);color:var(--teal-dark)}.badge-green{background:#dcfce7;color:#15803d}.badge-amber{background:#fef3c7;color:#b45309}.badge-red{background:#fee2e2;color:#b91c1c}.badge-gray{background:var(--bg);color:var(--text-3);border:1px solid var(--border)}.badge-blue{background:#dbeafe;color:#1d4ed8}.activity-list{padding:0 20px}.activity-item{display:flex;align-items:flex-start;gap:12px;padding:14px 0;border-bottom:1px solid var(--border)}.activity-item:last-child{border-bottom:none}.activity-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:6px}.activity-text{font-size:14px;font-weight:500;color:var(--text)}.activity-meta{font-size:12px;color:var(--text-3);margin-top:2px}.activity-time{font-size:11px;color:var(--text-3);flex-shrink:0;margin-top:4px}.search-wrap{position:relative;margin-bottom:24px}.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-3)}.search-icon svg{width:16px;height:16px}.search-input{width:100%;padding:11px 14px 11px 40px;background:var(--surface);border:1px solid var(--border);border-radius:10px;font-size:15px;color:var(--text);outline:none;transition:border-color .15s}.search-input:focus{border-color:var(--teal);box-shadow:0 0 0 3px #0d94881a}.search-results{background:var(--surface);border:1px solid var(--border);border-radius:10px;box-shadow:var(--shadow-md);overflow:hidden}.search-result-item{padding:12px 16px;cursor:pointer;transition:background .1s;border-bottom:1px solid var(--border)}.search-result-item:last-child{border-bottom:none}.search-result-item:hover{background:var(--teal-xlight)}.search-result-name{font-size:14px;font-weight:600;color:var(--text)}.search-result-phone{font-size:12px;color:var(--text-3);font-family:var(--mono);margin-top:2px}.inventory-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}.inventory-card{overflow:hidden;transition:box-shadow .2s,transform .2s}.inventory-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.inventory-img{height:130px;position:relative;overflow:hidden}.inventory-img-placeholder{width:100%;height:100%}.inventory-info{padding:14px 14px 12px}.inventory-brand{font-size:11px;font-weight:700;color:var(--text-3);letter-spacing:.08em;text-transform:uppercase}.inventory-model{font-size:14px;font-weight:700;color:var(--text);margin-top:2px}.inventory-color{font-size:12px;color:var(--text-2);margin-top:4px}.inventory-footer{display:flex;align-items:center;justify-content:space-between;margin-top:10px}.inventory-price{font-size:14px;font-weight:700;font-family:var(--mono);color:var(--text)}.stock-pill{font-size:11px;font-weight:700;padding:3px 9px;border-radius:99px}.stock-ok{background:#dcfce7;color:#15803d}.stock-low{background:#fef3c7;color:#b45309}.stock-out{background:#fee2e2;color:#b91c1c}.data-table{width:100%;border-collapse:collapse;font-size:14px}.data-table th{padding:11px 14px;text-align:left;font-size:11px;font-weight:700;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;background:var(--bg);border-bottom:1px solid var(--border)}.data-table td{padding:14px;border-bottom:1px solid var(--border);color:var(--text-2)}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:var(--teal-xlight)}.data-table .font-medium{font-weight:600;color:var(--text)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:200;display:flex;align-items:center;justify-content:center;padding:16px;animation:fadeIn .15s ease}.modal{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-lg);width:100%;max-width:560px;max-height:90vh;display:flex;flex-direction:column;animation:slideUp .2s ease}.modal-header{padding:20px 24px 0;display:flex;align-items:center;justify-content:space-between}.modal-title{font-size:17px;font-weight:700;color:var(--text)}.modal-body{padding:20px 24px;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:14px}.modal-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px}.tabs{display:flex;gap:2px;background:var(--bg);padding:4px;border-radius:var(--radius-sm);border:1px solid var(--border);margin-bottom:20px}.tab{flex:1;padding:8px 14px;font-size:13px;font-weight:600;border-radius:6px;border:none;background:none;cursor:pointer;color:var(--text-2);transition:all .15s;text-align:center}.tab.active{background:var(--surface);color:var(--teal);box-shadow:var(--shadow-sm)}.tab:hover:not(.active){color:var(--text)}.estado-en_laboratorio{background:#fef3c7;color:#b45309}.estado-listo{background:#dcfce7;color:#15803d}.estado-entregado{background:#dbeafe;color:#1d4ed8}.toast{position:fixed;bottom:24px;right:24px;padding:12px 18px;border-radius:10px;font-size:14px;font-weight:600;display:flex;align-items:center;gap:8px;box-shadow:var(--shadow-lg);z-index:999;animation:slideToast .25s ease}.toast svg{width:16px;height:16px}.toast.success{background:#ecfdf5;color:#065f46;border:1px solid #A7F3D0}.toast.error{background:#fef2f2;color:#991b1b;border:1px solid #FECACA}.toast.wa{background:#f0fff4;color:var(--wa-green-dark);border:1px solid #BBF7D0}.empty-state{text-align:center;padding:60px 20px}.empty-state-icon{color:var(--text-3);margin-bottom:16px}.empty-state-title{font-size:16px;font-weight:600;color:var(--text-2);margin-bottom:8px}.empty-state-sub{font-size:14px;color:var(--text-3)}.mobile-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--surface);border-top:1px solid var(--border);z-index:90}.mobile-nav-items{display:flex}.mobile-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px;background:none;border:none;cursor:pointer;color:var(--text-3);font-size:10px;font-weight:600;transition:color .15s}.mobile-nav-item svg{width:20px;height:20px}.mobile-nav-item.active{color:var(--teal)}.mobile-nav-label{font-size:10px}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg)}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:40px 36px;width:100%;max-width:400px;box-shadow:var(--shadow-lg)}.login-logo{display:flex;align-items:center;gap:12px;margin-bottom:32px}.login-logo-icon{width:44px;height:44px;background:var(--teal);border-radius:12px;display:flex;align-items:center;justify-content:center}.login-logo-img{width:74px;height:42px;object-fit:contain;flex-shrink:0}.login-title{font-size:22px;font-weight:700;color:var(--text)}.login-sub{font-size:13px;color:var(--text-3);margin-top:2px}.login-form{display:flex;flex-direction:column;gap:16px}.login-error{background:#fef2f2;color:#991b1b;border:1px solid #FECACA;border-radius:var(--radius-sm);padding:10px 14px;font-size:13px}@media print{.sidebar,.topbar,.mobile-nav,.no-print{display:none!important}.main{margin-left:0!important}.content{padding:0!important}body{background:#fff}}.exp-page{max-width:980px}.exp-topbar{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:20px}.exp-topbar h2{font-size:22px;font-weight:800;color:var(--text)}.exp-topbar p{font-size:13px;color:var(--text-3);margin-top:3px}.exp-actions{display:flex;gap:10px;flex-wrap:wrap}.exp-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:22px;margin-bottom:20px;box-shadow:var(--shadow-sm)}.exp-section-header{display:flex;align-items:center;gap:14px;margin-bottom:20px}.exp-section-icon{width:42px;height:42px;border-radius:12px;background:linear-gradient(135deg,#ccfbf1,#99f6e4);display:flex;align-items:center;justify-content:center;color:var(--teal-dark);flex-shrink:0}.exp-section-icon svg{width:20px;height:20px}.exp-section-header h3{margin:0;font-size:16px;font-weight:800;color:var(--text)}.exp-section-header p{margin:2px 0 0;font-size:12px;color:var(--text-3)}.input-error{border-color:var(--red)!important}.field-hint{font-size:12px;color:var(--text-3)}.field-hint.error{color:var(--red)}.exp-meta-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:16px}.exp-meta-grid>div,.exp-balance{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px;min-height:62px}.exp-meta-grid span,.exp-balance span{display:block;font-size:11px;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;font-weight:700}.exp-meta-grid strong,.exp-balance strong{display:block;margin-top:5px;font-size:14px;color:var(--text);overflow:hidden;text-overflow:ellipsis}.exp-balance strong{font-size:18px;font-family:var(--mono);color:var(--red)}.eye-cards{display:grid;grid-template-columns:1fr;gap:16px}.eye-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px;border-left:4px solid var(--teal)}.eye-card-title{font-size:14px;font-weight:800;color:var(--text);margin-bottom:14px}.eye-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.patient-search-area{position:relative;max-width:560px}.patient-results{position:absolute;top:47px;left:0;right:0;z-index:20}.patient-result-button{border:0;background:var(--surface);width:100%;text-align:left;display:flex;flex-direction:column}.selected-patient-edit{margin-top:14px;padding:14px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg)}.duplicate-patient-alert{grid-column:1 / -1;padding:10px 12px;border-radius:var(--radius-sm);border:1px solid #FDE68A;background:#fffbeb;color:#92400e;font-size:13px}.compact-tabs{max-width:430px;margin-bottom:14px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes slideToast{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@media (max-width: 768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main{margin-left:0}.topbar{padding:0 16px}.content{padding:16px 16px 80px}.summary-grid{grid-template-columns:1fr 1fr}.form-row-2,.form-row-3,.form-row-4{grid-template-columns:1fr}.inventory-grid{grid-template-columns:repeat(2,1fr)}.exp-topbar{align-items:flex-start;flex-direction:column}.exp-meta-grid{grid-template-columns:1fr 1fr}.eye-grid{grid-template-columns:1fr}.mobile-nav{display:block}.sidebar-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:99}}@media (max-width: 480px){.summary-grid{grid-template-columns:1fr}}@media (min-width: 1200px){.content{padding:32px 36px;max-width:1100px}}
