.beer-search{min-height:100vh;padding:.5rem;max-width:100%}.search-header{text-align:center;margin-bottom:1rem;padding:.5rem 0}.search-title-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;max-width:600px;margin:0 auto}.search-header-actions{display:flex;gap:.5rem;align-items:center}.btn-brewery-list{padding:.6rem .9rem;background:#e0f2fe;color:#0c4a6e;border:1px solid #93c5fd;border-radius:10px;font-weight:700;cursor:pointer;transition:background-color .2s,transform .2s;font-size:.85rem;white-space:nowrap}.btn-brewery-list:hover{background:#bfdbfe}.btn-brewery-list:active{transform:scale(.98)}.btn-establishment-list{padding:.6rem .9rem;background:#ede9fe;color:#4c1d95;border:1px solid #c4b5fd;border-radius:10px;font-weight:700;cursor:pointer;transition:background-color .2s,transform .2s;font-size:.85rem;white-space:nowrap}.btn-establishment-list:hover{background:#ddd6fe}.btn-establishment-list:active{transform:scale(.98)}.btn-add-beer{padding:.6rem 1rem;background:#10b981;color:#000;border:none;border-radius:10px;font-weight:700;cursor:pointer;transition:background-color .2s,transform .2s;font-size:.9rem;white-space:nowrap}.btn-add-beer:hover{background:#059669}.btn-add-beer:active{transform:scale(.98)}.search-header h1{font-size:1.75rem;color:#f59e0b;margin-bottom:.25rem}.search-subtitle{color:#6b7280;font-size:.95rem}.search-container{margin-bottom:1rem;position:sticky;top:0;background:#f9fafb;padding:.25rem 0 .75rem;z-index:10}.search-input-wrapper{position:relative;max-width:600px;margin:0 auto}.search-input{width:100%;padding:1rem 3rem 1rem 1rem;font-size:1rem;border:2px solid #e5e7eb;border-radius:12px;background:#fff;transition:border-color .2s,box-shadow .2s;-webkit-appearance:none;-moz-appearance:none;appearance:none}.search-input:focus{outline:none;border-color:#f59e0b;box-shadow:0 0 0 3px #f59e0b1a}.clear-button{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:#e5e7eb;color:#6b7280;border:none;border-radius:50%;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.2rem;padding:0;transition:background-color .2s}.clear-button:hover{background:#d1d5db}.search-status{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-top:1rem;color:#6b7280;font-size:.9rem}.spinner{width:1rem;height:1rem;border:2px solid #e5e7eb;border-top-color:#f59e0b;border-radius:50%;animation:spin .6s linear infinite}.search-results{max-width:600px;margin:0 auto}.results-count{font-size:.85rem;color:#6b7280;margin-bottom:.75rem;padding:0 .25rem}.search-scroll-sentinel{text-align:center;padding:1rem;color:#9ca3af;font-size:.9rem}.results-list{display:flex;flex-direction:column;gap:.75rem}.beer-result-card{background:#fff;border:2px solid #e5e7eb;border-radius:12px;padding:.5rem;transition:transform .2s,box-shadow .2s,border-color .2s;cursor:pointer;margin-bottom:.25rem}.beer-result-card:active{transform:scale(.98)}.beer-result-card:hover{border-color:#f59e0b;box-shadow:0 4px 12px #00000014}.beer-header{display:flex;justify-content:space-between;align-items:flex-start;gap:.75rem}.beer-name{font-size:1.1rem;color:#1f2937;margin:0;flex:1;line-height:1.3}.beer-has-notes{color:#f59e0b;font-size:.75rem;margin-left:.25rem;font-weight:bolder}.beer-abv{background:#f59e0b;color:#000;padding:.25rem .75rem;border-radius:8px;font-weight:700;font-size:.9rem;white-space:nowrap;flex-shrink:0}.beer-brewery{color:#4b5563;font-weight:600;font-size:.9rem;margin-bottom:.25rem}.beer-style{color:#6b7280;font-size:.85rem;display:flex;align-items:center;gap:.25rem}.beer-collaborators{color:#8b5cf6;font-size:.8rem;margin-bottom:.25rem;font-weight:500}.beer-notes{color:#6b7280;font-size:.85rem;margin-top:.75rem;padding-top:.75rem;border-top:1px solid #e5e7eb;font-style:italic}.brewery-group{margin-bottom:1.5rem}.brewery-name{font-size:1.25rem;color:#1f2937;margin:0 0 .75rem;padding-bottom:.5rem;border-bottom:3px solid #f59e0b}.beers-container{display:flex;flex-direction:column;gap:.75rem}.user-ratings{margin-top:.75rem;padding:.3rem;background:#f9fafb;border-radius:8px;border-left:4px solid #475670}.user-rating{display:flex;flex-direction:row;align-items:center;gap:.5rem;flex-wrap:wrap}.user-rating:not(:last-child){border-bottom:1px solid #e5e7eb;padding-bottom:.5rem;margin-bottom:.25rem}.rating-row{display:flex;align-items:center;width:100%;font-size:.8rem;gap:0}.username{font-weight:600;color:#374151;font-size:.9rem;white-space:nowrap;flex-basis:25%;text-align:left;display:flex;align-items:center}.rating-value{background:#fef3c7;color:#92400e;padding:.2rem .6rem;border-radius:6px;font-weight:700;font-size:.8rem;white-space:nowrap;width:fit-content}.rating-col{flex-basis:25%;display:flex;align-items:center;justify-content:center}.serving-style{background:#e0e7ff;color:#3730a3;padding:.2rem .4rem;border-radius:4px;font-weight:500;font-size:.75rem;white-space:nowrap;width:fit-content}.taster-badge{background:#fcd34d;color:#92400e;padding:.2rem .4rem;border-radius:4px;font-weight:600;font-size:.75rem;white-space:nowrap;width:fit-content}.style-col{flex-basis:25%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.2rem}.rating-date{color:#9ca3af;font-size:.75rem;white-space:nowrap;flex-basis:25%;text-align:right;display:flex;align-items:center;justify-content:flex-end}.no-results,.search-prompt{text-align:center;padding:1.5rem .75rem;color:#6b7280}.no-results-icon,.search-icon{font-size:3rem;display:block;margin-bottom:1rem;opacity:.5}.no-results p:first-of-type,.search-prompt p:first-of-type{font-size:1.1rem;color:#4b5563;margin-bottom:.5rem}.no-results-hint,.search-examples{font-size:.9rem;color:#9ca3af}@media (min-width: 768px){.beer-search{padding:2rem}.search-header h1{font-size:2.5rem}.search-subtitle{font-size:1rem}.search-container{padding:1rem 0 1.5rem}.beer-result-card{padding:1.5rem}.beer-name{font-size:1.4rem}}@media (min-width: 1024px){.beer-search{padding:2rem 3rem}.search-header h1{font-size:3rem}}@media (prefers-color-scheme: dark){.beer-search,.search-container{background:#1f2937}.search-input{background:#374151;border-color:#4b5563;color:#f9fafb}.search-input:focus{border-color:#f59e0b;box-shadow:0 0 0 3px #f59e0b33}.beer-result-card{background:#374151;border-color:#4b5563}.beer-result-card:hover{border-color:#f59e0b}.beer-name{color:#f9fafb}.beer-brewery{color:#d1d5db}.beer-style{color:#9ca3af}.beer-collaborators{color:#c4b5fd}.beer-notes{color:#9ca3af;border-top-color:#4b5563}.brewery-name{color:#f9fafb;border-bottom-color:#f59e0b}.user-ratings{background:#4b5563}.user-rating{border-bottom-color:#6b7280}.username{color:#f3f4f6}.serving-style{background:#312e81;color:#c4b5fd}.taster-badge{background:#78350f;color:#fef3c7}.rating-date{color:#9ca3af}.clear-button{background:#4b5563;color:#d1d5db}.clear-button:hover{background:#6b7280}.results-count{color:#9ca3af}.no-results p:first-of-type,.search-prompt p:first-of-type{color:#d1d5db}.autocomplete-dropdown{background:#374151;border-color:#4b5563}.autocomplete-option{color:#f9fafb;border-bottom-color:#4b5563}.autocomplete-option:hover{background:#1f2937}.autocomplete-create-new{color:#10b981}.collaborator-tag{background:#065f46;color:#d1fae5;border-color:#059669}.remove-collaborator{color:#d1fae5}.remove-collaborator:hover{background:#10b981;color:#fff}}.beer-details{min-height:100vh;padding:1rem;max-width:1200px;width:100%;margin:0 auto}.loading{display:flex;align-items:center;justify-content:center;gap:1rem;padding:3rem;text-align:center;color:#6b7280}.spinner{width:2rem;height:2rem;border:3px solid #e5e7eb;border-top-color:#f59e0b;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-container{padding:2rem}.error-message{background:#fee2e2;border:2px solid #fca5a5;border-radius:12px;padding:2rem;text-align:center;color:#991b1b}.error-message p{margin:.5rem 0}.error-message p:first-child{font-size:1.2rem;font-weight:600}.error-hint{font-size:.9rem;color:#b91c1c}.beer-details-container{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 2px 8px #00000014}.beer-header-section{border-bottom:3px solid #f59e0b;margin-bottom:1rem}.beer-title{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.beer-title h1{font-size:2.5rem;color:#1f2937;margin:0}.btn-edit{padding:.5rem;background:#f59e0b;color:#1f2937;border:none;border-radius:8px;font-size:1.1rem;cursor:pointer;transition:background-color .2s,transform .2s;min-width:44px;height:36px;display:flex;align-items:center;justify-content:center}.btn-edit:hover{background:#f59e0b;opacity:.9;transform:scale(1.05)}.btn-edit:active{transform:scale(.95)}.edit-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:100}.edit-modal{background:#fff;border-radius:12px;padding:2rem;max-width:500px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 10px 40px #0003}.edit-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid #e5e7eb}.edit-modal-header h2{font-size:1.5rem;color:#1f2937;margin:0}.close-button{background:none;border:none;font-size:1.5rem;color:#6b7280;cursor:pointer;padding:0;transition:color .2s}.close-button:hover{color:#1f2937}.edit-form{display:flex;flex-direction:column;gap:1rem}.form-group label{font-weight:600;color:#4b5563;font-size:.95rem}.form-group input,.form-group textarea,.form-group select{padding:.75rem;border:2px solid #e5e7eb;border-radius:6px;font-size:1rem;font-family:inherit;transition:border-color .2s}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:#f59e0b;box-shadow:0 0 0 3px #f59e0b1a}.autocomplete-wrapper input{width:100%;box-sizing:border-box}.autocomplete-dropdown{position:absolute;top:100%;left:0;right:0;background:#fff;border:2px solid #f59e0b;border-top:none;border-radius:0 0 6px 6px;max-height:300px;overflow-y:auto;z-index:10;box-shadow:0 4px 6px #0000001a}.establishment-autocomplete-dropdown{position:static;margin-top:.25rem;border-top:2px solid #f59e0b;border-radius:6px}.autocomplete-option{padding:.75rem;color:#4b5563;cursor:pointer;transition:background-color .2s;border-bottom:1px solid #e5e7eb}.autocomplete-option:hover{background:#f3f4f6;color:#1f2937}.autocomplete-create-new{font-style:italic;color:#b45309;font-weight:600;pointer-events:none}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1rem;padding-top:1rem;border-top:1px solid #e5e7eb}.btn-cancel{padding:.75rem 1.5rem;background:#e5e7eb;color:#4b5563;border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:background-color .2s}.btn-save{padding:.75rem 1.5rem;background:#10b981;color:#fff;border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:background-color .2s}.btn-save:hover:not(:disabled){background:#059669}.btn-save:disabled{background:#d1d5db;cursor:not-allowed}@media (prefers-color-scheme: dark){.edit-modal{background:#2d3748}.edit-modal-header{border-bottom-color:#4b5563}.edit-modal-header h2{color:#f9fafb}.close-button{color:#9ca3af}.close-button:hover{color:#f9fafb}.form-group label{color:#d1d5db}.form-group input,.form-group textarea,.form-group select{background:#1f2937;color:#f9fafb;border-color:#4b5563}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:#f59e0b;box-shadow:0 0 0 3px #f59e0b33}.field-hint{color:#9ca3af}.autocomplete-dropdown{background:#1f2937;border-color:#f59e0b}.autocomplete-option{color:#d1d5db;border-bottom-color:#4b5563}.autocomplete-option:hover{background:#374151;color:#f9fafb}.autocomplete-create-new{color:#fbbf24}.form-actions{border-top-color:#4b5563}.btn-cancel{background:#4b5563;color:#f9fafb}.btn-cancel:hover{background:#6b7280}}.brewery-info{margin-top:1rem}.brewery-name-large{font-size:1.5rem;color:#4b5563;margin:0 0 .5rem}.collaborators{color:#8b5cf6;font-weight:500;margin:.5rem 0 0}.beer-main-info{display:flex;flex-direction:column;gap:1rem;margin-bottom:1rem}.info-card{background:#f9fafb;padding:.5rem;border-radius:8px;border-left:4px solid #f59e0b}.info-card h3{color:#6b7280;font-size:.9rem;text-transform:uppercase;letter-spacing:.05em;margin:0 0 .75rem}.info-value{color:#1f2937;font-size:1rem;margin:0;line-height:1.6}.notes-info-section{margin-bottom:.5rem}.notes-info-section .info-value.notes{font-style:italic}.info-card-inline{display:flex;align-items:flex-start;gap:1rem;justify-content:space-between}.info-item{flex:1;display:flex;flex-direction:column;gap:.25rem}.info-item h3{margin:0!important}.info-item .info-value{margin:0}.ratings-section{margin-bottom:.5rem}.ratings-section h2{font-size:1.5rem;color:#1f2937;margin-bottom:1.5rem;padding-bottom:.75rem;border-bottom:2px solid #e5e7eb}.user-activity-card{background:#f9fafb;border:2px solid #e5e7eb;border-radius:8px;padding:.5rem;margin-bottom:.5rem}.user-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem;padding-bottom:.5rem;border-bottom:2px solid #e5e7eb;flex-wrap:nowrap}.user-header h3{margin:0;font-size:1.2rem;color:#1f2937;flex-shrink:0}.user-stats{display:flex;gap:.5rem;align-items:center;flex-shrink:0;margin-left:auto;height:2rem}.stat-badge{background:#dbeafe;color:#1e40af;padding:.25rem .6rem;border-radius:6px;font-weight:600;font-size:.8rem;white-space:nowrap;flex-shrink:0;height:2rem;display:flex;align-items:center}.btn-quick-checkin{padding:.4rem .8rem;background:#10b981;color:#fff;border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:background-color .2s;font-size:.85rem;white-space:nowrap;flex-shrink:0;height:2rem;display:flex;align-items:center}.btn-quick-checkin:hover:not(:disabled){background:#059669}.btn-quick-checkin:disabled{background:#d1d5db;cursor:not-allowed}.rating-actions{display:flex;gap:.5rem;padding:.5rem 0;border-bottom:2px solid #e5e7eb;margin-bottom:.5rem}.btn-add-rating{padding:.4rem .8rem;background:#3b82f6;color:#fff;border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:background-color .2s;font-size:.85rem;white-space:nowrap}.btn-add-rating:hover{background:#2563eb}.user-ratings{display:flex;flex-direction:column}.rating-item{background:#fff;padding:1rem;border-radius:6px;display:flex;gap:1rem;align-items:center}.rating-score-block{display:flex;flex-direction:column;align-items:center;min-width:60px;gap:.4rem}.rating-score{font-weight:700;font-size:1.1rem;color:#f59e0b}.rating-info{flex:1}.rating-item-actions{display:flex;align-items:center}.btn-edit-rating{padding:.35rem .7rem;background:#e5e7eb;color:#1f2937;border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:background-color .2s;font-size:.85rem;white-space:nowrap}.btn-edit-rating:hover{background:#d1d5db}.rating-info p{margin:.3rem 0;color:#4b5563;font-size:.9rem}.rating-area{display:inline}@media (max-width: 480px){.rating-area{display:block;padding-left:0}}.no-ratings{color:#9ca3af;font-style:italic;margin:1rem 0 0}.error-banner{background:#fee2e2;border:2px solid #fca5a5;color:#991b1b;padding:1rem;border-radius:6px;margin-top:1rem;text-align:center;font-weight:600}.metadata-section{background:#f9fafb;border-radius:8px;padding:.5rem;display:flex;gap:2rem;flex-wrap:wrap;justify-content:space-between}.metadata-item{display:flex;flex-direction:column;gap:.25rem}.metadata-item .label{font-size:.8rem;color:#6b7280;text-transform:uppercase;letter-spacing:.05em}.metadata-item .value{font-size:.9rem;color:#1f2937;font-weight:500}@media (prefers-color-scheme: dark){.beer-details{background:#1f2937}.beer-details-container{background:#374151;color:#f9fafb}.beer-title h1{color:#f9fafb}.brewery-name-large{color:#d1d5db}.info-card{background:#4b5563}.info-card h3{color:#9ca3af}.info-value{color:#f9fafb}.rating-card{background:#4b5563;border-color:#6b7280}.rating-card:hover{border-color:#f59e0b}.rater-name{color:#f9fafb}.rating-header{border-bottom-color:#6b7280}.rating-details p{color:#d1d5db}.rating-details strong{color:#f9fafb}.metadata-section{background:#4b5563}.metadata-item .label{color:#9ca3af}.metadata-item .value,.checkins-header h2{color:#f9fafb}.checkins-header{border-bottom-color:#6b7280}.btn-add-checkin{background:#d97706}.btn-add-checkin:hover{background:#b45309}.checkin-form{background:#4b5563;border-left-color:#f59e0b}.form-group label{color:#d1d5db}.form-group input,.form-group textarea,.form-group select{background:#1f2937;color:#f9fafb;border-color:#4b5563}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:#f59e0b;box-shadow:0 0 0 3px #f59e0b33}.user-activity-card{background:#4b5563;border-color:#6b7280}.user-header{border-bottom-color:#6b7280}.user-header h3{color:#f9fafb}.stat-badge{background:#1e3a8a;color:#bfdbfe}.btn-quick-checkin{background:#059669}.btn-quick-checkin:hover:not(:disabled){background:#047857}.rating-actions{border-bottom-color:#6b7280}.btn-add-rating{background:#2563eb}.btn-add-rating:hover{background:#1d4ed8}.rating-item{background:#374151;border-left-color:#f59e0b}.rating-info p{color:#d1d5db}.no-ratings{color:#9ca3af}.error-banner{background:#7f1d1d;border-color:#991b1b;color:#fecaca}.beer-header-section{border-bottom-color:#f59e0b}.ratings-section h2{color:#f9fafb;border-bottom-color:#6b7280}.error-message{background:#7f1d1d;border-color:#991b1b;color:#fecaca}.error-hint{color:#fca5a5}}@media (max-width: 768px){.beer-details{padding:.25rem;max-width:100%;margin:0}.beer-details-container{padding:.5rem}.beer-title{flex-direction:column;align-items:flex-start}.beer-title h1{font-size:1.75rem}.beer-abv-large{align-self:flex-start}.brewery-name-large{font-size:1.25rem}.user-stats{gap:.5rem}.rating-item{flex-direction:row;gap:.5rem}.metadata-section{gap:1rem}}.brewery-list{min-height:100vh;padding:1.5rem;max-width:1200px;width:100%;margin:0 auto}@media (max-width: 600px){.brewery-list{padding:0}}.brewery-list-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.5rem}.brewery-list-header h1{margin:0;color:#1f2937;font-size:2rem}.brewery-list-status{color:#6b7280;text-align:center}.brewery-list-error{background:#fee2e2;border:2px solid #fca5a5;color:#991b1b;padding:1rem;border-radius:8px;text-align:center}.brewery-scroll-sentinel{text-align:center;padding:1rem;color:#9ca3af;font-size:.9rem}.brewery-table-wrapper{overflow-x:auto}.brewery-table{width:100%;border-collapse:collapse;background:#fff;border:1px solid #e5e7eb;border-radius:10px;overflow:hidden}.brewery-table thead th{background:#f3f4f6;font-weight:700;text-transform:uppercase;font-size:.8rem;letter-spacing:.05em;color:#4b5563;padding:.25rem;text-align:center}.brewery-table thead th:first-child{text-align:left}.sortable-header{cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap}.sortable-header:hover{background:#e5e7eb}.brewery-table tbody td{padding:.25rem;border-top:1px solid #e5e7eb;vertical-align:top}.brewery-name-cell{font-weight:700;color:#1f2937}.brewery-count-cell,.brewery-abv-cell,.brewery-user-count-cell{font-weight:600;color:#374151;text-align:center}.user-total-list{display:flex;flex-wrap:wrap;gap:.4rem}.user-total-badge{background:#e0f2fe;color:#0c4a6e;border-radius:999px;padding:.2rem .6rem;font-size:.8rem;font-weight:600;white-space:nowrap}.user-total-empty{color:#9ca3af;font-style:italic}@media (prefers-color-scheme: dark){.brewery-list{background:#1f2937}.brewery-list-header h1{color:#f9fafb}.brewery-table{background:#374151;border-color:#4b5563}.brewery-table thead th{background:#4b5563;color:#e5e7eb}.brewery-table tbody td{border-top-color:#4b5563}.brewery-name-cell,.brewery-count-cell,.brewery-abv-cell,.brewery-user-count-cell{color:#f9fafb}.user-total-badge{background:#344470;color:#e0f2fe}.brewery-table .sortable-header:hover{background:#6b7280}}.establishment-list{min-height:100vh;padding:1.5rem;max-width:1200px;width:100%;margin:0 auto}.establishment-list-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.5rem}.establishment-list-header h1{margin:0;color:#1f2937;font-size:2rem}.btn-back{padding:.4rem .75rem;background:#f59e0b;color:#1f2937;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:background-color .2s,transform .2s}.establishment-list-status{color:#6b7280;text-align:center}.establishment-list-error{background:#fee2e2;border:2px solid #fca5a5;color:#991b1b;padding:1rem;border-radius:8px;text-align:center}.establishment-table-wrapper{overflow-x:auto}.establishment-table{width:100%;border-collapse:collapse;background:#fff;border:1px solid #e5e7eb;border-radius:10px;overflow:hidden}.establishment-table thead th{background:#f3f4f6;font-weight:700;text-transform:uppercase;font-size:.8rem;letter-spacing:.05em;color:#4b5563;padding:.75rem 1rem;text-align:center}.establishment-table thead th.sortable-header{cursor:pointer;-webkit-user-select:none;user-select:none}.establishment-table thead th.sortable-header:hover{background:#e5e7eb}.establishment-table thead th:first-child{text-align:left}.establishment-table tbody td{padding:.75rem 1rem;border-top:1px solid #e5e7eb;vertical-align:top}.establishment-name-cell{font-weight:700;color:#1f2937}.establishment-name{font-size:1rem;font-weight:700;color:#1f2937}.establishment-area{font-size:.85rem;font-weight:500;color:#6b7280;margin-top:.3rem}.establishment-user-cell{text-align:center;font-weight:600;color:#1f2937}@media (max-width: 600px){.establishment-list{padding:0}}@media (prefers-color-scheme: dark){.establishment-list{background:#1f2937}.establishment-list-header h1{color:#f9fafb}.establishment-table{background:#374151;border-color:#4b5563}.establishment-table thead th{background:#4b5563;color:#e5e7eb}.establishment-table thead th.sortable-header:hover{background:#6b7280}.establishment-table tbody td{border-top-color:#4b5563}.establishment-name-cell,.establishment-name{color:#f9fafb}.establishment-area{color:#9ca3af}.establishment-user-cell{color:#f9fafb}}.statistics{min-height:100vh;padding:1.5rem;max-width:1200px;margin:0 auto}@media (max-width: 600px){.statistics{padding:0}}.statistics-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.5rem}.statistics-header h1{margin:0;color:#1f2937;font-size:2rem}.btn-back{display:inline-block;padding:.25rem .5rem;background:#f59e0b;color:#1f2937;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:background-color .2s,transform .2s;font-size:.95rem}.btn-back:hover{opacity:.9;transform:translate(-3px)}.statistics-status{color:#6b7280;text-align:center}.statistics-error{background:#fee2e2;border:2px solid #fca5a5;color:#991b1b;padding:1rem;border-radius:8px;text-align:center}.statistics-total{margin-bottom:2rem;display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}.total-card{background:#ecfdf5;border:2px solid #86efac;border-radius:12px;padding:2rem;text-align:center}.total-card.establishments-card{background:#ede9fe;border-color:#c4b5fd}.total-card.establishments-card .total-label{color:#7c3aed}.total-card.establishments-card .total-value{color:#6d28d9}.total-card.breweries-card{background:#fef3c7;border-color:#fcd34d}.total-card.breweries-card .total-label{color:#d97706}.total-card.breweries-card .total-value{color:#b45309}.total-card.abv-card{background:#fce7f3;border-color:#fbcfe8}.total-card.abv-card .total-label{color:#be185d}.total-card.abv-card .total-value{color:#9f1239}.total-label{font-size:.95rem;font-weight:600;color:#16a34a;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}.total-value{font-size:3rem;font-weight:700;color:#15803d}.statistics-users-section{margin-bottom:1rem}.statistics-users-section h2{color:#1f2937;font-size:1.5rem;margin:0 0 1rem}.users-table-wrapper{overflow-x:auto}.users-table{width:100%;border-collapse:collapse;background:#fff;border:1px solid #e5e7eb;border-radius:10px;overflow:hidden}.users-table thead th{background:#f3f4f6;font-weight:700;text-transform:uppercase;font-size:.8rem;letter-spacing:.05em;color:#4b5563;padding:.5rem;text-align:center}.users-table tbody td{padding:.5rem;border-top:1px solid #e5e7eb;vertical-align:top;text-align:center}.users-table thead th:first-child,.users-table tbody td:first-child{text-align:left}.user-name-cell{font-weight:700;color:#1f2937}.user-count-cell{font-weight:600;color:#374151}.serving-style-table thead th{text-align:center}.serving-style-table thead th:first-child{text-align:left}.serving-style-table tbody td{text-align:center}.serving-style-table tbody td:first-child{text-align:left}.serving-style-table .total-cell{font-weight:700;border-left:2px solid #e5e7eb;background:#f9fafb}.year-table{min-width:100%}.year-table thead th{text-align:center;min-width:80px}.year-table thead th:first-child{text-align:left;min-width:80px;position:sticky;left:0;background:#f3f4f6;z-index:1}.year-table tbody td{text-align:center;min-width:80px}.year-table .year-cell{text-align:left;min-width:80px;position:sticky;left:0;background:#fff;font-weight:600;z-index:1;box-shadow:2px 0 4px #0000000d}.year-table .total-cell{font-weight:700;border-left:2px solid #e5e7eb;background:#f9fafb}.beer-style-table{min-width:100%}.beer-style-table thead th:nth-child(2){min-width:120px;text-align:left}.beer-style-table tbody td{padding:.5rem;border-top:1px solid #e5e7eb}.beer-style-table .style-name-cell{color:#374151;font-weight:500;min-width:120px;text-align:left}.beer-style-table .child-style{padding-left:1rem;color:#6b7280;font-weight:400}.beer-style-table .style-indent{color:#9ca3af;margin-right:.25rem}.beer-style-table .parent-style-label{font-size:.85rem;color:#9ca3af;font-weight:400;margin-left:.5rem}.beer-style-table .user-name-cell{font-weight:600;vertical-align:top;border-right:2px solid #e5e7eb}.beer-style-table .user-last-row td{border-bottom:3px solid #d1d5db}.overall-style-table{min-width:100%}.overall-style-table thead th{text-align:left}.overall-style-table thead th:nth-child(2),.overall-style-table thead th:nth-child(3){text-align:center;min-width:100px}.overall-style-table tbody td{padding:.5rem;border-top:1px solid #e5e7eb}.overall-style-table tbody td:nth-child(2),.overall-style-table tbody td:nth-child(3){text-align:center}.overall-style-table .style-name-cell{color:#374151;font-weight:500;min-width:150px}.overall-style-table .child-style{padding-left:1rem;color:#6b7280;font-weight:400}.overall-style-table .style-indent{color:#9ca3af;margin-right:.25rem}.no-data{text-align:center;color:#9ca3af;padding:2rem;font-style:italic}.establishment-statistics table th,.establishment-statistics table td,.brewery-statistics table th,.brewery-statistics table td{text-align:left}.establishment-statistics table thead th:nth-child(1),.establishment-statistics table td:nth-child(1),.brewery-statistics table thead th:nth-child(1),.brewery-statistics table td:nth-child(1){width:200px}@media (max-width: 768px){.statistics-total{grid-template-columns:1fr}.total-card{padding:.5rem}}@media (prefers-color-scheme: dark){.statistics{background:#1f2937}.statistics-header h1{color:#f9fafb}.total-card{background:#064e3b;border-color:#10b981}.total-card.establishments-card{background:#3f3f7f;border-color:#a78bfa}.total-card.establishments-card .total-label{color:#c4b5fd}.total-card.establishments-card .total-value{color:#e9d5ff}.total-card.breweries-card{background:#78350f;border-color:#fbbf24}.total-card.breweries-card .total-label{color:#fcd34d}.total-card.breweries-card .total-value{color:#fef3c7}.total-card.abv-card{background:#831843;border-color:#f472b6}.total-card.abv-card .total-label{color:#fbcfe8}.total-card.abv-card .total-value{color:#fce7f3}.total-label{color:#86efac}.total-value{color:#d1fae5}.statistics-users-section h2{color:#f9fafb}.users-table{background:#374151;border-color:#4b5563}.users-table thead th{background:#4b5563;color:#e5e7eb}.users-table tbody td{border-top-color:#4b5563}.user-name-cell{color:#f9fafb}.user-count-cell{color:#e5e7eb}.serving-style-table .total-cell,.year-table thead th:first-child{background:#4b5563}.year-table .year-cell{background:#374151}.year-table .total-cell{background:#4b5563}.beer-style-table .style-name-cell{color:#e5e7eb}.beer-style-table .child-style{color:#9ca3af}.beer-style-table .style-indent,.beer-style-table .parent-style-label{color:#6b7280}.beer-style-table .user-name-cell{border-right-color:#4b5563}.beer-style-table .user-last-row td{border-bottom-color:#c4862b}.overall-style-table .style-name-cell{color:#e5e7eb}.overall-style-table .child-style{color:#9ca3af}.overall-style-table .style-indent{color:#6b7280}.no-data{color:#9ca3af}}.year-details{padding:20px;max-width:1200px;margin:0 auto}.year-details-header{display:flex;align-items:center;gap:20px;margin-bottom:30px}.year-details-header h1{margin:0;color:#1f2937;font-size:2rem}.btn-back{padding:10px 16px;background-color:#f0f0f0;border:1px solid #ccc;border-radius:4px;cursor:pointer;font-size:14px;transition:background-color .2s}.btn-back:hover{background-color:#e0e0e0}.year-details-status,.year-details-error{padding:20px;border-radius:4px;font-size:16px;margin-bottom:20px}.year-details-status{background-color:#e3f2fd;color:#1976d2}.year-details-error{background-color:#ffebee;color:#c62828}.year-details-content{display:flex;flex-direction:column;gap:40px}.view-toggle{display:flex;gap:10px;margin-bottom:20px}.view-button{padding:10px 20px;background-color:#f0f0f0;border:2px solid #ddd;color:#1f2937;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .3s ease}.view-button:hover{background-color:#e8e8e8;border-color:#bbb}.view-button.active{background-color:#d4a574;color:#fff;border-color:#d4a574}.users-breakdown,.users-graphs{display:flex;flex-direction:column;gap:40px}.user-breakdown-section,.user-graph-section{background-color:#f9f9f9;border:1px solid #e0e0e0;border-radius:8px;padding:20px}.user-breakdown-section h2,.user-graph-section h2{margin:0 0 20px;font-size:20px;color:#333;border-bottom:2px solid #d4a574;padding-bottom:10px}.graph-container{width:100%;height:400px;margin-top:20px}.monthly-table-wrapper{overflow-x:auto}.monthly-table{width:100%;border-collapse:collapse;background-color:#fff}.monthly-table thead{background-color:#f5f5f5;border-bottom:2px solid #ddd}.monthly-table th{padding:12px 15px;text-align:left;font-weight:600;color:#333;border-right:1px solid #e0e0e0}.monthly-table th:last-child{border-right:none}.current-year-col{background-color:#f0f7ff}.previous-year-col{background-color:#f5f5f5}.difference-col{background-color:#fffef0}.monthly-table td{padding:12px 15px;border-bottom:1px solid #e0e0e0;border-right:1px solid #e0e0e0}.monthly-table td:last-child{border-right:none}.month-cell{font-weight:500;color:#555;min-width:120px}.count-cell{text-align:center;font-weight:500;color:#333;min-width:80px}.difference-cell{text-align:center;font-weight:500;min-width:100px}.difference-cell.positive{color:#2e7d32;background-color:#f1f8f6}.difference-cell.negative{color:#c62828;background-color:#ffebee}.difference-cell.neutral{color:#999}.total-row{background-color:#f9f9f9;border-top:2px solid #ddd;font-weight:700}.total-row td{background-color:#f5f5f5;padding:15px;font-weight:600}.no-data{padding:40px;text-align:center;color:#999;font-size:16px;background-color:#f9f9f9;border-radius:8px}@media (max-width: 768px){.year-details{margin:0}.year-details-header{flex-direction:column;align-items:flex-start}.year-details-header h1{font-size:22px}.monthly-table{font-size:14px}.monthly-table th,.monthly-table td{padding:8px 10px}.month-cell,.count-cell,.difference-cell{min-width:auto}}@media (prefers-color-scheme: dark){.year-details{background-color:#1f2937;color:#f9fafb}.year-details-header h1{color:#f9fafb}.btn-back{background-color:#374151;border-color:#4b5563;color:#f9fafb}.btn-back:hover{background-color:#4b5563}.view-button{background-color:#2d3748;color:#e2e8f0;border:2px solid #4a5568}.view-button:hover{background-color:#4a5568;border-color:#718096;color:#f7fafc}.view-button.active{background-color:#d4a574;color:#1a202c;border-color:#d4a574}.year-details-status{background-color:#1e3a8a;color:#f9fafb}.year-details-error{background-color:#b91c1c;color:#f9fafb}.user-breakdown-section{background-color:#374151;border-color:#4b5563}.user-breakdown-section h2{color:#f9fafb;border-bottom-color:#d4a574}.monthly-table{background-color:#1f2937}.monthly-table thead{background-color:#374151;border-bottom-color:#4b5563}.monthly-table th,.monthly-table td{border-color:#4b5563;color:#f9fafb}.monthly-table th.difference-col{color:#000}.month-cell,.count-cell{color:#f9fafb}.current-year-col{background-color:#1e3a8a}.previous-year-col{background-color:#374151}.difference-col{background-color:#f59e0b}.difference-cell.positive{color:#2e7d32;background-color:#1f2937}.difference-cell.negative{color:#c62828;background-color:#1f2937}.difference-cell.neutral{color:#999}.total-row{background-color:#374151;border-top-color:#4b5563}.total-row td{background-color:#1f2937}.user-graph-section{background-color:#2d3748;border:1px solid #4a5568}.user-breakdown-section h2,.user-graph-section h2{color:#e2e8f0;border-bottom:2px solid #d4a574}.no-data{background-color:#374151;color:#f9fafb}}.recent-ratings{min-height:100vh;padding:.5rem;max-width:100%}.recent-header{text-align:center;margin-bottom:1rem;padding:.5rem 0}.recent-title-row{display:flex;align-items:center;justify-content:center;gap:1rem;max-width:600px;margin:0 auto}.recent-header h1{font-size:1.75rem;color:#f59e0b;margin-bottom:.25rem}.recent-subtitle{color:#6b7280;font-size:.95rem}.recent-container{max-width:600px;margin:0 auto}.recent-results{display:flex;flex-direction:column}.recent-ratings .results-count{font-size:.85rem;color:#6b7280;margin-bottom:.75rem;padding:0 .25rem}.recent-ratings .beer-result-card{background:#fff;border:2px solid #e5e7eb;border-radius:12px;padding:.5rem;transition:transform .2s,box-shadow .2s,border-color .2s;cursor:pointer;margin-bottom:.75rem}.recent-ratings .beer-result-card:active{transform:scale(.98)}.recent-ratings .beer-result-card:hover{border-color:#f59e0b;box-shadow:0 4px 12px #00000014}.recent-ratings .beer-header{display:flex;justify-content:space-between;align-items:flex-start;gap:.75rem}.recent-ratings .beer-name{font-size:1.1rem;color:#1f2937;margin:0;flex:1;line-height:1.3}.recent-ratings .beer-has-notes{color:#f59e0b;font-size:.75rem;margin-left:.25rem;font-weight:bolder}.recent-ratings .beer-abv{background:#f59e0b;color:#000;padding:.25rem .75rem;border-radius:8px;font-weight:700;font-size:.9rem;white-space:nowrap;flex-shrink:0}.recent-ratings .beer-meta{display:flex;flex-direction:column;gap:.1rem;margin-top:.25rem}.recent-ratings .beer-brewery{color:#4b5563;font-weight:600;font-size:.9rem}.recent-ratings .beer-style{color:#6b7280;font-size:.85rem}.recent-ratings .beer-collaborators{color:#8b5cf6;font-size:.8rem;font-weight:500}.recent-ratings .user-ratings{margin-top:.75rem;padding:.3rem;background:#f9fafb;border-radius:8px;border-left:4px solid #475670}.recent-ratings .user-rating{display:flex;flex-direction:row;align-items:center;gap:.5rem;flex-wrap:wrap}.recent-ratings .user-rating:not(:last-child){border-bottom:1px solid #e5e7eb;padding-bottom:.5rem;margin-bottom:.25rem}.recent-ratings .user-rating.latest-rater{border-left:3px solid #f59e0b;padding-left:6px;border-radius:4px}.recent-ratings .user-rating.old-rating{padding-left:9px}.recent-ratings .rating-row{display:flex;align-items:center;width:100%;font-size:.8rem;gap:0}.recent-ratings .username{font-weight:600;color:#374151;font-size:.9rem;white-space:nowrap;flex-basis:25%;text-align:left;display:flex;align-items:center;gap:.25rem}.recent-ratings .latest-badge{color:#f59e0b;font-size:.85rem;line-height:1}.recent-ratings .rating-col{flex-basis:25%;display:flex;align-items:center;justify-content:center}.recent-ratings .rating-value{background:#fef3c7;color:#92400e;padding:.2rem .6rem;border-radius:6px;font-weight:700;font-size:.8rem;white-space:nowrap;width:fit-content}.recent-ratings .style-col{flex-basis:25%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.2rem}.recent-ratings .serving-style{background:#e0e7ff;color:#3730a3;padding:.2rem .4rem;border-radius:4px;font-weight:500;font-size:.75rem;white-space:nowrap;width:fit-content}.recent-ratings .taster-badge{background:#fcd34d;color:#92400e;padding:.2rem .4rem;border-radius:4px;font-weight:600;font-size:.75rem;white-space:nowrap;width:fit-content}.recent-ratings .rating-date{color:#9ca3af;font-size:.75rem;white-space:nowrap;flex-basis:25%;text-align:right;display:flex;align-items:center;justify-content:flex-end}.recent-ratings .loading,.recent-ratings .no-results{text-align:center;padding:1.5rem .75rem;color:#6b7280}@media (min-width: 768px){.recent-ratings{padding:1rem}}@media (prefers-color-scheme: dark){.recent-ratings{background:#1f2937}.recent-ratings .beer-result-card{background:#374151;border-color:#4b5563}.recent-ratings .beer-result-card:hover{border-color:#f59e0b}.recent-ratings .beer-name{color:#f9fafb}.recent-ratings .beer-brewery{color:#d1d5db}.recent-ratings .beer-style{color:#9ca3af}.recent-ratings .beer-collaborators{color:#c4b5fd}.recent-ratings .user-ratings{background:#4b5563}.recent-ratings .user-rating:not(:last-child){border-bottom-color:#6b7280}.recent-ratings .username{color:#f3f4f6}.recent-ratings .serving-style{background:#312e81;color:#c4b5fd}.recent-ratings .taster-badge{background:#78350f;color:#fef3c7}.recent-ratings .rating-date,.recent-ratings .results-count{color:#9ca3af}}.add-beer{min-height:100vh;padding:1rem;max-width:900px}.add-beer-header{text-align:center;margin-bottom:2rem}.add-beer-header h1{font-size:2rem;color:#f59e0b;margin-bottom:.5rem}.add-beer-subtitle{color:#6b7280;font-size:1rem}.add-beer-content{background:#fff;border-radius:16px;padding:2rem;box-shadow:0 4px 6px #0000001a}.add-beer-form{display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:600;color:#374151;font-size:.95rem}.form-group input[type=text],.form-group input[type=number],.form-group input[type=date],.form-group select,.form-group textarea{width:100%;padding:.75rem;font-size:1rem;border:2px solid #e5e7eb;border-radius:8px;background:#fff;transition:border-color .2s,box-shadow .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#f59e0b;box-shadow:0 0 0 3px #f59e0b1a}.form-group textarea{resize:vertical;font-family:inherit}.field-hint{color:#6b7280;font-size:.85rem}.autocomplete-wrapper{position:relative}.autocomplete-dropdown{position:absolute;top:100%;left:0;right:0;background:#fff;border:2px solid #10b981;border-top:none;border-radius:0 0 6px 6px;max-height:260px;overflow-y:auto;z-index:10;box-shadow:0 4px 6px #0000001a}.establishment-autocomplete-dropdown,.brewery-create-new-dropdown{position:static;margin-top:.25rem;border-top:2px solid #10b981;border-radius:6px}.autocomplete-option{padding:.75rem;color:#374151;cursor:pointer;transition:background-color .2s;border-bottom:1px solid #e5e7eb}.autocomplete-option:last-child{border-bottom:none}.autocomplete-option:hover{background:#ecfdf5}.autocomplete-create-new{font-style:italic;color:#059669;font-weight:600;pointer-events:none}.selected-collaborators{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.75rem}.collaborator-tag{display:inline-flex;align-items:center;gap:.5rem;background:#ecfdf5;color:#065f46;padding:.5rem .75rem;border-radius:8px;border:1px solid #10b981;font-size:.9rem;font-weight:500}.remove-collaborator{background:none;border:none;color:#065f46;cursor:pointer;font-size:1rem;font-weight:700;padding:0;width:1.25rem;height:1.25rem;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s,color .2s}.remove-collaborator:hover{background:#059669;color:#fff}.form-section{border-top:2px solid #e5e7eb;padding-top:1.5rem;margin-top:1rem}.form-section h3{font-size:1.25rem;color:#374151;margin-bottom:.5rem}.form-section-description{color:#6b7280;font-size:.9rem;margin-bottom:1rem}.user-checkboxes{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:1.5rem}.user-toggle-btn{padding:.625rem 1rem;font-size:.95rem;font-weight:600;border:2px solid #e5e7eb;border-radius:8px;background:#fff;color:#374151;cursor:pointer;transition:all .2s;flex:0 1 auto;white-space:nowrap}.user-toggle-btn:hover{border-color:#f59e0b;background:#fffbeb}.user-toggle-btn.selected{background:#f59e0b;color:#000;border-color:#f59e0b}.user-toggle-btn.selected:hover{background:#d97706;border-color:#d97706}.rating-user-form{display:flex;flex-direction:column;gap:1rem;background:#f9fafb;border:2px solid #e5e7eb;border-radius:12px;padding:1.5rem;margin-bottom:1rem}.rating-user-form h4{font-size:1.1rem;color:#f59e0b;margin-bottom:1rem;border-bottom:2px solid #f59e0b;padding-bottom:.5rem}.form-error{background:#fef2f2;color:#991b1b;padding:1rem;border-radius:8px;border:2px solid #fecaca;font-weight:500}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem;padding-top:1.5rem;border-top:2px solid #e5e7eb}.btn-cancel,.btn-save{padding:.75rem 2rem;font-size:1rem;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:background-color .2s,transform .2s}.btn-cancel{background:#e5e7eb;color:#374151}.btn-cancel:hover{background:#d1d5db}.btn-save{background:#10b981;color:#fff}.btn-save:hover{background:#059669}.btn-cancel:active,.btn-save:active{transform:scale(.98)}.btn-cancel:disabled,.btn-save:disabled{opacity:.5;cursor:not-allowed}@media (prefers-color-scheme: dark){.add-beer{background:#1f2937}.add-beer-subtitle{color:#9ca3af}.add-beer-content{background:#374151;box-shadow:0 4px 6px #0000004d}.form-group label{color:#f9fafb}.form-group input[type=text],.form-group input[type=number],.form-group input[type=date],.form-group select,.form-group textarea{background:#1f2937;border-color:#4b5563;color:#f9fafb}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#f59e0b;box-shadow:0 0 0 3px #f59e0b33}.autocomplete-dropdown{background:#374151;border-color:#4b5563}.autocomplete-option{color:#f9fafb;border-bottom-color:#4b5563}.autocomplete-option:hover{background:#1f2937}.autocomplete-create-new{color:#10b981}.collaborator-tag{background:#065f46;color:#d1fae5;border-color:#059669}.remove-collaborator{color:#d1fae5}.remove-collaborator:hover{background:#10b981;color:#fff}.form-section{border-top-color:#4b5563}.form-section h3{color:#f9fafb}.form-section-description{color:#9ca3af}.user-toggle-btn{background:#1f2937;color:#f9fafb;border-color:#4b5563}.user-toggle-btn:hover{background:#374151;border-color:#f59e0b}.user-toggle-btn.selected{background:#f59e0b;border-color:#f59e0b}.user-toggle-btn.selected:hover{background:#d97706;border-color:#d97706}.rating-user-form{background:#1f2937;border-color:#4b5563}.rating-user-form h4{color:#fbbf24;border-bottom-color:#fbbf24}.form-error{background:#7f1d1d;color:#fecaca;border-color:#991b1b}.form-actions{border-top-color:#4b5563}.btn-cancel{background:#4b5563;color:#f9fafb}.btn-cancel:hover{background:#6b7280}}@media (max-width: 768px){.add-beer-content{padding:1rem}.add-beer-header h1{font-size:1.5rem}.form-actions{flex-direction:column}.btn-cancel,.btn-save{width:100%}}@media (min-width: 1024px){.add-beer{width:900px;margin:0 auto}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--background-color);padding:20px}.login-box{background:var(--card-background);padding:40px;border-radius:12px;box-shadow:0 4px 12px #0000001a;width:100%;max-width:400px}.login-box h1{margin:0 0 8px;font-size:28px;text-align:center;color:var(--text-color)}.login-subtitle{margin:0 0 24px;text-align:center;color:var(--text-secondary);font-size:14px}.login-error{background:#fee;color:#c33;padding:12px;border-radius:6px;margin-bottom:20px;text-align:center;border:1px solid #fcc}.login-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-weight:500;color:var(--text-color);font-size:14px}.form-group input{padding:12px;border:1px solid var(--border-color);border-radius:6px;font-size:16px;background:var(--input-background, white);color:var(--text-color)}.form-group input:focus{outline:none;border-color:var(--primary-color, #007bff);box-shadow:0 0 0 3px #007bff1a}.form-group input:disabled{opacity:.6;cursor:not-allowed}.btn-login{padding:12px 24px;background:var(--primary-color, #007bff);color:#fff;border:none;border-radius:6px;font-size:16px;font-weight:500;cursor:pointer;transition:background-color .2s}.btn-login:hover:not(:disabled){background:var(--primary-hover, #0056b3)}.btn-login:disabled{opacity:.6;cursor:not-allowed}@media (prefers-color-scheme: dark){.login-box{background:#2a2a2a}.form-group input{background:#333;border-color:#444;color:#fff}.login-error{background:#4a1a1a;color:#faa;border-color:#6a2a2a}}.App{min-height:100vh;display:flex;flex-direction:column}.App-nav{border-bottom:1px solid #e5e7eb;background:#fff;position:sticky;top:0;z-index:50}.App-nav-inner{max-width:1200px;margin:0 auto;padding:.75rem 1.5rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}.App-nav-title{font-weight:700;color:#1f2937}.App-nav-links{display:flex;gap:.5rem;flex-wrap:wrap}.App-nav-icon-bar{display:block;width:30px;height:2px;background-color:#4b5563;margin:4px 0;border-radius:1px;transition:.3s}.App-nav-toggle{display:none;background:transparent;border:none;color:#4b5563;padding:.5rem .4rem;border-radius:8px;cursor:pointer;flex-direction:column;align-items:center;justify-content:center;gap:0}.App-nav-link{text-decoration:none;color:#4b5563;padding:.4rem .7rem;border-radius:8px;font-weight:600;border:1px solid transparent;background:transparent;cursor:pointer;font-size:1rem;font-family:inherit}.App-nav-link:hover{background:#fef3c7;color:#92400e}.App-nav-link.active{background:#f59e0b;color:#1f2937;border-color:#f59e0b}.App-nav-logout{background:transparent;border:1px solid #e5e7eb}.App-nav-logout:hover{background:#fee2e2;color:#991b1b;border-color:#fca5a5}.App-nav-user{color:#6b7280;padding:.4rem .7rem;font-size:.9rem;font-weight:500}@media (max-width: 720px){.App-nav-toggle{display:inline-flex;align-items:center;justify-content:center}.App-nav-links{display:none;position:absolute;top:100%;right:1.5rem;background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:.5rem;flex-direction:column;min-width:180px;box-shadow:0 10px 30px #0000001f;z-index:60}.App-nav-links.is-open{display:flex}}.App-footer{margin-top:auto;padding:1.5rem;text-align:center;border-top:1px solid #e5e7eb;color:#6b7280;font-size:.85rem}.status-ok{color:#10b981;font-weight:700}.status-error{color:#ef4444;font-weight:700}@media (prefers-color-scheme: dark){.App-nav{border-bottom-color:#4b5563;background:#1f2937}.App-nav-title{color:#f9fafb}.App-nav-link{color:#d1d5db}.App-nav-link:hover{background:#374151;color:#f9fafb}.App-nav-link.active{background:#f59e0b;color:#1f2937}.App-nav-logout{border-color:#4b5563}.App-nav-logout:hover{background:#7f1d1d;color:#fca5a5;border-color:#991b1b}.App-nav-user{color:#9ca3af}.App-nav-toggle{border-color:transparent;color:#d1d5db}.App-nav-icon-bar{background-color:#d1d5db}@media (max-width: 720px){.App-nav-links{background:#1f2937;border-color:#4b5563}}.App-footer{border-top-color:#4b5563;color:#9ca3af}}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#213547;background-color:#f9fafb;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box;margin:0;padding:0}body{min-height:100vh}h1,h2,h3,h4,h5,h6{line-height:1.2}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#f59e0b;color:#fff;cursor:pointer;transition:background-color .25s}button:hover{background-color:#d97706}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: dark){:root{color:#f9fafb;background-color:#1f2937}button{background-color:#f59e0b}button:hover{background-color:#d97706}}
