.layout{min-height:100vh;display:flex;flex-direction:column}.layout-header{background:var(--bg-card);padding:1rem 1.5rem;box-shadow:var(--shadow);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem}.layout-title{margin:0;font-size:1.35rem;font-weight:700;color:var(--primary)}.layout-user{display:flex;align-items:center;gap:1rem}.layout-email{color:var(--text-muted);font-size:.9rem}.layout-main{flex:1;padding:1.5rem;max-width:900px;margin:0 auto;width:100%}@media (max-width: 640px){.layout-header{padding:.75rem 1rem}.layout-title{font-size:1.15rem}.layout-email{font-size:.8rem}.layout-main{padding:1rem}.btn{min-height:44px;padding:.6rem 1rem}.btn-small{min-height:44px;min-width:44px;padding:.5rem .75rem}}.app-loading{display:flex;align-items:center;justify-content:center;min-height:100vh;color:var(--text-muted)}.btn{padding:.5rem 1rem;border-radius:var(--radius);font-weight:500;border:none;transition:background .2s,color .2s}.btn-ghost{background:transparent;color:var(--text-muted)}.btn-ghost:hover{background:var(--primary-light);color:var(--primary)}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-hover)}.btn-danger{background:#fef2f2;color:var(--danger)}.btn-danger:hover{background:#fee2e2}.btn-small{padding:.35rem .65rem;font-size:.85rem}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1.5rem;background:linear-gradient(160deg,var(--bg-main) 0%,var(--primary-light) 100%)}.auth-card{background:var(--bg-card);border-radius:16px;padding:2rem;width:100%;max-width:380px;box-shadow:var(--shadow-md)}.auth-title{margin:0 0 .25rem;font-size:1.5rem;color:var(--primary);text-align:center}.auth-subtitle{margin:0 0 1.5rem;color:var(--text-muted);text-align:center;font-size:.95rem}.auth-form label{display:block;margin-bottom:1rem;font-size:.9rem;font-weight:500;color:var(--text)}.auth-form input{width:100%;margin-top:.35rem;padding:.65rem .9rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-input);font-size:1rem}.auth-form input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.auth-error{background:#fef2f2;color:var(--danger);padding:.6rem .9rem;border-radius:var(--radius);margin-bottom:1rem;font-size:.9rem}.auth-submit{width:100%;padding:.75rem;margin-top:.5rem;font-size:1rem}.auth-footer{margin:1.25rem 0 0;text-align:center;color:var(--text-muted);font-size:.9rem}@media (max-width: 640px){.auth-page{padding:2rem 1rem 1rem;align-items:flex-start}.auth-card{padding:1.5rem}.auth-form input{padding:.75rem 1rem;font-size:16px}.auth-submit{min-height:48px}.auth-footer{padding:.5rem 0}}.expiry-dot{display:inline-block;border-radius:50%;flex-shrink:0}.expiry-dot--sm{width:10px;height:10px}.expiry-dot--md{width:14px;height:14px}.expiry-dot--expired{background:var(--danger)}.expiry-dot--soon{background:var(--expiry-soon)}.expiry-dot--ok{background:var(--success)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1e293b66;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:var(--bg-card);border-radius:16px;box-shadow:var(--shadow-md);max-width:440px;width:100%;max-height:90vh;overflow-y:auto}.modal-title{margin:0;padding:1.25rem 1.5rem .5rem;font-size:1.25rem;color:var(--text)}.drug-form{padding:0 1.5rem 1.5rem}.drug-form label{display:block;margin-bottom:1rem;font-size:.9rem;font-weight:500;color:var(--text)}.drug-form input,.drug-form textarea{width:100%;margin-top:.35rem;padding:.6rem .85rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-input);font-size:1rem}.drug-form input:focus,.drug-form textarea:focus{outline:none;border-color:var(--primary)}.drug-form textarea{resize:vertical;min-height:60px}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.25rem;padding-top:1rem;border-top:1px solid var(--border)}@media (max-width: 640px){.modal-overlay{padding:.5rem;align-items:flex-end}.modal-content{max-height:85vh;border-radius:16px 16px 0 0}.modal-title{padding:1rem 1rem .5rem}.drug-form{padding:0 1rem 1rem}.drug-form input,.drug-form textarea{font-size:16px;padding:.75rem 1rem;min-height:48px}.modal-actions .btn{min-height:48px;padding:.65rem 1.25rem}}.drug-list-toolbar{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:1rem;align-items:center}.drug-search{flex:1;min-width:200px;padding:.6rem 1rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-input);font-size:1rem}.drug-search:focus{outline:none;border-color:var(--primary)}.drug-list-actions{display:flex;gap:.5rem;align-items:center}.drug-legend{display:flex;gap:1.25rem;margin-bottom:1rem;font-size:.85rem;color:var(--text-muted)}.drug-legend span{display:flex;align-items:center;gap:.4rem}.drug-list-error{background:#fef2f2;color:var(--danger);padding:.75rem 1rem;border-radius:var(--radius);margin-bottom:1rem}.drug-list-loading,.drug-list-empty{color:var(--text-muted);text-align:center;padding:2rem}.drug-table-wrap{overflow-x:auto;background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow)}.drug-table{width:100%;border-collapse:collapse}.drug-table th,.drug-table td{padding:.75rem .85rem;text-align:left;border-bottom:1px solid var(--border)}.drug-table th{font-weight:600;color:var(--text-muted);font-size:.85rem;white-space:nowrap}.drug-table tbody tr:hover{background:var(--bg-input)}.drug-table td{vertical-align:middle}.drug-name{font-weight:500}.drug-note{max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.drug-table .btn-small{margin-right:.25rem}.drug-table th:first-child,.drug-table td:first-child{width:2.5rem}.drug-table th:nth-child(2),.drug-table td:nth-child(2){width:2rem}@media (max-width: 768px){.drug-list-toolbar{flex-direction:column;align-items:stretch}.drug-search{min-width:0}.drug-list-actions{flex-wrap:wrap}.drug-list-actions .btn{min-height:44px}.drug-legend{flex-wrap:wrap;gap:.75rem}.drug-table-wrap{overflow:visible}.drug-table thead{display:none}.drug-table tbody tr{display:flex;flex-wrap:wrap;align-items:flex-start;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:.75rem;padding:.75rem 1rem;box-shadow:var(--shadow);gap:0 1rem}.drug-table tbody tr:hover{background:var(--bg-card)}.drug-table td{display:flex;align-items:center;padding:.4rem 0;border:none;gap:.5rem}.drug-table td:before{content:attr(data-label);font-weight:600;color:var(--text-muted);font-size:.8rem;min-width:6.5rem;flex-shrink:0}.drug-table td:first-child,.drug-table td:nth-child(2),.drug-table td.drug-name{order:0}.drug-table td:first-child:before,.drug-table td:nth-child(2):before{content:none;min-width:0}.drug-table td:first-child{padding-right:.25rem;min-height:44px;justify-content:center}.drug-table td.drug-name{flex:1 1 auto;min-width:0;font-size:1rem}.drug-table td:not(:first-child):not(:nth-child(2)):not(.drug-name):not(:last-child){order:1;width:100%}.drug-table td:last-child{order:2;width:100%;flex-wrap:wrap;gap:.5rem;padding-top:.5rem;border-top:1px solid var(--border);margin-top:.25rem}.drug-table td:last-child:before{width:100%;margin-bottom:.25rem}.drug-table .drug-note{max-width:none;white-space:normal}.drug-table .btn-small{min-height:44px;padding:.5rem .75rem}}:root{--bg-main: #f0f4f8;--bg-card: #ffffff;--bg-input: #f8fafc;--primary: #2563eb;--primary-hover: #1d4ed8;--primary-light: #dbeafe;--accent: #3b82f6;--text: #1e293b;--text-muted: #64748b;--border: #e2e8f0;--danger: #dc2626;--warning: #ea580c;--expiry-soon: #eab308;--success: #16a34a;--radius: 12px;--shadow: 0 1px 3px rgba(37, 99, 235, .08);--shadow-md: 0 4px 12px rgba(37, 99, 235, .12);--font: "Manrope", -apple-system, BlinkMacSystemFont, sans-serif}*{box-sizing:border-box}body{margin:0;font-family:var(--font);background:var(--bg-main);color:var(--text);min-height:100vh;-webkit-font-smoothing:antialiased}#root{min-height:100vh}button{font-family:inherit;cursor:pointer}input,textarea{font-family:inherit}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}@supports (padding: env(safe-area-inset-bottom)){body{padding-bottom:env(safe-area-inset-bottom)}}@media (pointer: coarse){button,.btn{min-height:44px}button:not(.btn-small),.btn:not(.btn-small){min-width:44px}input:not([type=checkbox]),textarea,.drug-search{min-height:44px}}
