.loading-spinner{border:3px solid #E8DCC8;border-top:3px solid #8C7851;border-radius:50%;width:50px;height:50px;animation:spin 1s linear infinite;margin:0 auto}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:1.5rem}.loading-container p{color:#8c7851;font-size:1.125rem}.btn-primary{background-color:#8c7851;color:#fff;padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-primary:hover{background-color:#6b5d4f;transform:translateY(-1px);box-shadow:0 4px 12px #6b5d4f33}.btn-primary:disabled{background-color:#d4c4a8;cursor:not-allowed;transform:none}.action-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-bottom:3rem}.action-card{background-color:#fff;border:2px solid #E8DCC8;border-radius:12px;padding:2rem;cursor:pointer;transition:all .2s;text-align:center}.action-card:hover{border-color:#8c7851;transform:translateY(-4px);box-shadow:0 8px 20px #6b5d4f26}.action-card-icon{font-size:3rem;margin-bottom:1rem}.action-card h3{color:#6b5d4f;font-size:1.25rem;font-weight:600;margin:0 0 .5rem}.action-card p{color:#8c7851;font-size:.938rem;margin:0}.empty-state{text-align:center;padding:4rem 2rem;background-color:#f5f1e8;border-radius:12px;border:2px dashed #D4C4A8}.empty-state-icon{font-size:4rem;margin-bottom:1.5rem;opacity:.6}.empty-state h3{color:#6b5d4f;font-size:1.5rem;font-weight:600;margin:0 0 1rem}.empty-state p{color:#8c7851;font-size:1.063rem;margin:0 0 2rem}.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;padding:2rem;text-align:center}.error-container h2{color:#6b5d4f;font-size:1.5rem;margin:0 0 1rem}.error-container p{color:#8c7851;font-size:1.063rem;margin:0 0 2rem;max-width:500px}@media(max-width:768px){.action-cards{grid-template-columns:1fr;gap:1rem}.action-card{padding:1.5rem}.empty-state{padding:3rem 1.5rem}.loading-container{min-height:50vh}}*{box-sizing:border-box;margin:0;padding:0}:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6;font-weight:400;color:#213547;background-color:#f5f5f5;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh}#root{width:100%;min-height:100vh}.navigation{background-color:#fff;border-bottom:1px solid #E8DCC8;padding:1rem 0;position:sticky;top:0;z-index:100}.navigation .nav-container{max-width:1200px;margin:0 auto;padding:0 2rem;display:flex;justify-content:space-between;align-items:center}.nav-left{display:flex;align-items:center;gap:2rem}.navigation .nav-logo{font-size:1.5rem;font-weight:600;color:#6b5d4f;margin:0}.nav-links{display:flex;gap:.5rem}.nav-link{padding:.5rem 1rem;background-color:transparent;color:#8c7851;border:none;border-radius:6px;font-size:.938rem;font-weight:500;cursor:pointer;transition:all .2s}.nav-link:hover{background-color:#f5f1e8;color:#6b5d4f}.nav-link.active{background-color:#8c7851;color:#fff}.nav-link.active:hover{background-color:#6b5d4f}.nav-link-primary{padding:.5rem 1.25rem;background-color:#8c7851;color:#fff;border:none;border-radius:6px;font-size:.938rem;font-weight:500;cursor:pointer;transition:all .2s}.nav-link-primary:hover{background-color:#6b5d4f;transform:translateY(-1px)}.nav-actions{display:flex;align-items:center;gap:1.5rem}.user-menu{position:relative}.user-info{display:flex;align-items:center;gap:.75rem;padding:.5rem 1rem;background-color:transparent;border:1px solid #E8DCC8;border-radius:8px;cursor:pointer;transition:all .2s}.user-info:hover{background-color:#f5f1e8;border-color:#d4c4a8}.user-avatar{width:36px;height:36px;border-radius:50%;border:2px solid #D4C4A8}.user-name{font-weight:500;color:#6b5d4f}.dropdown-arrow{font-size:.75rem;color:#8c7851;margin-left:.25rem}.user-dropdown{position:absolute;top:calc(100% + .5rem);right:0;background-color:#fff;border:1px solid #E8DCC8;border-radius:8px;box-shadow:0 4px 12px #6b5d4f1a;min-width:160px;z-index:1000;overflow:hidden}.dropdown-item{width:100%;padding:.75rem 1rem;background-color:transparent;color:#6b5d4f;border:none;text-align:left;font-size:.938rem;cursor:pointer;transition:background-color .2s}.dropdown-item:hover{background-color:#f5f1e8}.dropdown-item.logout{color:#d9534f}.dropdown-item.logout:hover{background-color:#ffebee}@media(max-width:768px){.navigation .nav-container{padding:0 1rem}.nav-left{gap:1rem}.navigation .nav-logo{font-size:1.25rem}.nav-links{gap:.25rem}.nav-link{padding:.5rem .75rem;font-size:.875rem}.user-name{display:none}.dropdown-arrow{margin-left:0}.user-info{padding:.5rem}}.navigation-skeleton{position:sticky;top:0;z-index:100;background-color:#fff;border-bottom:1px solid #E8DCC8;padding:1rem 0;animation:pulse 1.5s ease-in-out infinite}.navigation-skeleton .nav-container{max-width:1200px;margin:0 auto;padding:0 2rem;display:flex;justify-content:space-between;align-items:center}.navigation-skeleton .nav-left{display:flex;align-items:center;gap:2rem}.skeleton-logo{width:150px;height:24px;background-color:#e8dcc8;border-radius:4px}.skeleton-links{display:flex;gap:1rem}.skeleton-link{width:60px;height:36px;background-color:#f5f1e8;border-radius:6px}.skeleton-user-menu{width:120px;height:40px;background-color:#e8dcc8;border-radius:20px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}@media(max-width:768px){.navigation-skeleton .nav-container{padding:0 1rem}.skeleton-logo{width:100px}.skeleton-links{gap:.25rem}.skeleton-link{width:50px;height:32px}.skeleton-user-menu{width:40px}}.app-layout{min-height:100vh;display:flex;flex-direction:column}:root{--color-cream: #F5F1E8;--color-soft-gray: #E8E4DC;--color-charcoal: #2B2B2B;--color-black: #1A1A1A;--color-gray: #6B6B6B;--color-white: #FEFDFB}.landing{background-color:var(--color-cream);min-height:100vh}.landing-nav{background-color:var(--color-white);border-bottom:1px solid var(--color-soft-gray);padding:1.5rem 0;position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background-color:#fefdfbf2}.nav-container{max-width:1200px;margin:0 auto;padding:0 2rem;display:flex;justify-content:space-between;align-items:center}.nav-logo{font-size:1.5rem;font-weight:400;letter-spacing:.5px;color:var(--color-black);margin:0}.nav-links{display:flex;gap:2rem;align-items:center}.nav-link{color:var(--color-gray);text-decoration:none;font-size:.95rem;transition:color .3s ease;font-weight:400}.nav-link:hover{color:var(--color-black)}.nav-link-primary{background-color:var(--color-charcoal);color:var(--color-white);padding:.75rem 1.5rem;border-radius:4px;text-decoration:none;font-size:.95rem;transition:all .3s ease;font-weight:400}.nav-link-primary:hover{background-color:var(--color-black);transform:translateY(-1px)}.hero{padding:8rem 2rem;text-align:center;background-color:var(--color-cream)}.hero-content{max-width:800px;margin:0 auto}.hero-title{font-size:5rem;font-weight:300;letter-spacing:-1px;color:var(--color-black);margin:0 0 1.5rem;line-height:1.1}.hero-subtitle{font-size:1.4rem;color:var(--color-gray);margin:0 0 3rem;font-weight:300;line-height:1.6}.hero-cta{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.btn-primary,.btn-primary-large{background-color:var(--color-charcoal);color:var(--color-white);padding:1rem 2.5rem;border-radius:4px;text-decoration:none;font-size:1rem;transition:all .3s ease;display:inline-block;font-weight:400;border:2px solid var(--color-charcoal)}.btn-primary:hover,.btn-primary-large:hover{background-color:var(--color-black);border-color:var(--color-black);transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.btn-primary-large{padding:1.25rem 3rem;font-size:1.1rem}.btn-secondary{background-color:transparent;color:var(--color-charcoal);padding:1rem 2.5rem;border-radius:4px;text-decoration:none;font-size:1rem;transition:all .3s ease;display:inline-block;font-weight:400;border:2px solid var(--color-charcoal)}.btn-secondary:hover{background-color:var(--color-charcoal);color:var(--color-white);transform:translateY(-2px)}.features{padding:6rem 2rem;background-color:var(--color-white)}.features-container{max-width:1200px;margin:0 auto}.section-title{font-size:2.5rem;font-weight:300;text-align:center;color:var(--color-black);margin:0 0 4rem;letter-spacing:-.5px}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:3rem}.feature-card{text-align:center;padding:2rem 1rem}.feature-icon{font-size:3rem;margin-bottom:1.5rem}.feature-title{font-size:1.3rem;font-weight:400;color:var(--color-black);margin:0 0 1rem}.feature-description{font-size:1rem;color:var(--color-gray);line-height:1.7;margin:0;font-weight:300}.how-it-works{padding:6rem 2rem;background-color:var(--color-soft-gray)}.how-container{max-width:1200px;margin:0 auto}.steps-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:3rem;margin-top:4rem}.step{text-align:center;padding:2rem;background-color:var(--color-white);border-radius:8px;transition:transform .3s ease}.step:hover{transform:translateY(-4px)}.step-number{font-size:3rem;font-weight:200;color:var(--color-gray);margin-bottom:1rem;letter-spacing:2px}.step-title{font-size:1.5rem;font-weight:400;color:var(--color-black);margin:0 0 1rem}.step-description{font-size:1rem;color:var(--color-gray);line-height:1.7;margin:0;font-weight:300}.cta-section{padding:6rem 2rem;background-color:var(--color-charcoal);text-align:center}.cta-container{max-width:700px;margin:0 auto}.cta-title{font-size:2.5rem;font-weight:300;color:var(--color-white);margin:0 0 1rem;letter-spacing:-.5px}.cta-description{font-size:1.2rem;color:var(--color-soft-gray);margin:0 0 2.5rem;font-weight:300;line-height:1.7}.cta-section .btn-primary-large{background-color:var(--color-white);color:var(--color-charcoal);border-color:var(--color-white)}.cta-section .btn-primary-large:hover{background-color:var(--color-cream);border-color:var(--color-cream)}.landing-footer{padding:3rem 2rem;background-color:var(--color-black);text-align:center}.footer-container{max-width:1200px;margin:0 auto}.footer-text{color:var(--color-gray);margin:0;font-size:.95rem;font-weight:300}@media(max-width:768px){.hero-title{font-size:3rem}.hero-subtitle{font-size:1.1rem}.nav-links{gap:1rem}.nav-link{display:none}.section-title{font-size:2rem}.features-grid,.steps-grid{grid-template-columns:1fr;gap:2rem}.cta-title{font-size:2rem}.cta-description{font-size:1rem}}.profile{min-height:100vh;background-color:#f5f1e8}.profile-main{padding:3rem 2rem}.profile-container{max-width:1200px;margin:0 auto}.profile-header{margin-bottom:3rem}.profile-header h1{font-size:2.5rem;color:#6b5d4f;margin:0 0 .5rem}.profile-header p{font-size:1.125rem;color:#8c7851;margin:0}.quick-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-bottom:3rem}.action-card{background-color:#fff;border:2px solid #E8DCC8;border-radius:12px;padding:2rem;text-align:center;cursor:pointer;transition:all .3s ease}.action-card:hover{border-color:#d4c4a8;transform:translateY(-4px);box-shadow:0 8px 20px #6b5d4f14}.action-card-primary{background:linear-gradient(135deg,#8c7851,#6b5d4f);color:#fff;border-color:#8c7851}.action-card-primary:hover{transform:translateY(-4px);box-shadow:0 8px 20px #6b5d4f33}.action-icon{font-size:3rem;margin-bottom:1rem}.action-card-primary .action-icon{filter:grayscale(1) brightness(2)}.action-card h3{font-size:1.25rem;margin:0 0 .5rem;color:#6b5d4f}.action-card-primary h3{color:#fff}.action-card p{margin:0;color:#8c7851;font-size:.875rem}.action-card-primary p{color:#ffffffe6}.recent-shots{background-color:#fff;border-radius:12px;padding:2rem;border:1px solid #E8DCC8}.recent-shots h2{font-size:1.75rem;color:#6b5d4f;margin:0 0 1.5rem}.empty-state{text-align:center;padding:4rem 2rem}.empty-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.empty-state p{color:#8c7851;margin:0 0 2rem;font-size:1rem}.profile-loading{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background-color:#f5f1e8;color:#6b5d4f}.profile-loading p{font-size:1.125rem;color:#8c7851}.profile-error{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background-color:#f5f1e8;padding:2rem;text-align:center}.profile-error h2{color:#6b5d4f;font-size:2rem;margin:0 0 1rem}.profile-error p{color:#8c7851;margin:0 0 2rem;font-size:1.125rem}@media(max-width:768px){.profile-main{padding:2rem 1rem}.profile-header h1{font-size:2rem}.quick-actions{grid-template-columns:1fr}}.report-modal-backdrop{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.report-modal{background:var(--background, #fff);border-radius:8px;width:100%;max-width:480px;box-shadow:0 4px 24px #0003;overflow:hidden}.report-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border, #e5e5e5)}.report-modal-header h2{font-size:1.125rem;margin:0}.report-modal-close{background:none;border:none;font-size:1.5rem;line-height:1;cursor:pointer;color:var(--text-muted, #666);padding:0 .25rem}.report-modal-form{padding:1.25rem;display:flex;flex-direction:column;gap:1rem}.report-field{display:flex;flex-direction:column;gap:.375rem}.report-field label{font-size:.875rem;font-weight:600}.report-field-hint{font-weight:400;color:var(--text-muted, #888)}.report-field select,.report-field textarea{border:1px solid var(--border, #ccc);border-radius:6px;padding:.5rem .75rem;font-size:.9375rem;font-family:inherit;background:var(--background, #fff);color:var(--text, #111);resize:vertical}.report-field select:focus,.report-field textarea:focus{outline:2px solid var(--primary, #6f4e37);outline-offset:1px}.report-error{color:#c0392b;font-size:.875rem;margin:0}.report-modal-actions{display:flex;gap:.75rem;justify-content:flex-end}.report-cancel-button{background:none;border:1px solid var(--border, #ccc);border-radius:6px;padding:.5rem 1rem;font-size:.9375rem;cursor:pointer;color:var(--text, #111)}.report-submit-button{background:var(--primary, #6f4e37);color:#fff;border:none;border-radius:6px;padding:.5rem 1rem;font-size:.9375rem;cursor:pointer;transition:opacity .15s}.report-submit-button:disabled{opacity:.6;cursor:not-allowed}.report-modal-success{padding:2rem 1.25rem;text-align:center;color:var(--text-muted, #555)}.shots-page{min-height:100vh;background-color:#f5f1e8}.shots-main{padding:1rem 0;background-color:#f5f1e8}.shots-feed{max-width:640px;margin:0 auto;padding:0 1rem}.shots-header{margin-bottom:3rem}.shots-header .header-content{display:flex;justify-content:space-between;align-items:center;gap:2rem}.shots-header .header-text h1{font-size:2.5rem;color:#6b5d4f;margin:0 0 .5rem}.shots-header .header-text p{font-size:1.125rem;color:#8c7851;margin:0}.btn-new-shot-floating{position:fixed;bottom:2rem;right:2rem;width:60px;height:60px;background-color:#8c7851;color:#fff;border:none;border-radius:50%;font-size:2rem;font-weight:300;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 16px #6b5d4f4d;z-index:1000;display:flex;align-items:center;justify-content:center;line-height:1}.btn-new-shot-floating:hover{background-color:#6b5d4f;transform:scale(1.1);box-shadow:0 6px 20px #6b5d4f66}.controls-section{margin-bottom:2rem}.controls-container{background-color:#fff;border-radius:12px;padding:1.5rem;border:1px solid #E8DCC8;display:flex;flex-wrap:wrap;gap:2rem;align-items:center}.control-group{display:flex;align-items:center;gap:.75rem}.control-group label{font-weight:500;color:#6b5d4f;font-size:.938rem}.control-select{padding:.5rem 1rem;border:2px solid #E8DCC8;border-radius:6px;font-size:.938rem;color:#6b5d4f;background-color:#fff;cursor:pointer;transition:border-color .2s}.control-select:focus{outline:none;border-color:#8c7851}.results-count{margin-left:auto;font-size:.938rem;color:#8c7851;font-weight:500}.gallery-section{margin-bottom:3rem}.coffee-shot-gallery{width:100%}.gallery-feed{display:flex;flex-direction:column;gap:1.5rem}.coffee-shot-card{background-color:#fff;border-radius:0;overflow:hidden;border:1px solid #E8DCC8;margin-bottom:1.5rem}.card-image{width:100%;height:0;padding-bottom:100%;position:relative;overflow:hidden;background-color:#f5f1e8}.card-image img,.card-image video{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover}.card-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;border-bottom:1px solid #E8DCC8}.user-info{display:flex;align-items:center;gap:.75rem}.machine-icon{width:40px;height:40px;border-radius:50%;background-color:#f5f1e8;display:flex;align-items:center;justify-content:center;font-size:1.25rem}.machine-details h3{font-size:.938rem;color:#6b5d4f;margin:0;font-weight:600}.machine-details .date{font-size:.813rem;color:#8c7851}.delete-button-icon{background:none;border:none;color:#8c7851;font-size:2rem;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;transition:color .2s;line-height:1}.delete-button-icon:hover{color:#d9534f}.card-content{padding:1rem}.card-content .rating{font-size:1.125rem;color:#f5a623;margin-bottom:.75rem}.shot-info{display:flex;flex-direction:column;gap:.5rem}.shot-info .beans{color:#6b5d4f;font-size:.938rem;margin:0}.shot-info .beans strong{font-weight:600}.shot-stats{display:flex;align-items:center;gap:.5rem;color:#8c7851;font-size:.875rem;flex-wrap:wrap}.shot-stats .stat strong{color:#6b5d4f;font-weight:600}.shot-stats .stat-divider{color:#d4c4a8}.empty-state h3{font-size:1.5rem;color:#6b5d4f;margin:0 0 .5rem}.empty-state p{color:#8c7851;margin:0;font-size:1rem}.loading{text-align:center;padding:4rem 2rem;color:#8c7851;font-size:1.125rem}.shots-loading{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background-color:#f5f1e8;color:#6b5d4f}.shots-loading p{font-size:1.125rem;color:#8c7851}.loading-more{display:flex;justify-content:center;padding:2rem 0}.loading-more .loading-spinner{width:32px;height:32px;border:3px solid #E8DCC8;border-top-color:#8c7851;border-radius:50%;animation:spin 1s linear infinite}.end-of-feed{text-align:center;padding:2rem 0 3rem;color:#8c7851;font-size:1rem}.end-of-feed p{margin:0}.shots-error{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background-color:#f5f1e8;padding:2rem;text-align:center}.shots-error h2{color:#6b5d4f;font-size:2rem;margin:0 0 1rem}.shots-error p{color:#8c7851;margin:0 0 2rem;font-size:1.125rem}@media(max-width:768px){.shots-main{padding:0}.shots-feed{max-width:100%;padding:0}.coffee-shot-card{border-radius:0;border-left:none;border-right:none}.btn-new-shot-floating{bottom:1rem;right:1rem;width:56px;height:56px;font-size:1.75rem}}.beans-search{width:100%}.beans-select__control{border:2px solid #E8DCC8!important;border-radius:8px!important;min-height:48px}.beans-select__control:hover{border-color:#8c7851!important}.beans-select__control--is-focused{border-color:#8c7851!important;box-shadow:0 0 0 3px #8c78511a!important}.beans-select__placeholder{color:#b8a98f}.beans-select__input-container,.beans-select__single-value{color:#6b5d4f}.beans-select__menu{border:2px solid #E8DCC8;border-radius:8px;box-shadow:0 4px 12px #6b5d4f1a;z-index:100}.beans-select__menu-list{padding:0;max-height:300px}.beans-select__option{padding:.875rem 1rem;cursor:pointer;color:#6b5d4f;transition:background-color .2s}.beans-select__option--is-focused{background-color:#f5f1e8!important}.beans-select__option--is-selected{background-color:#e8dcc8!important;color:#6b5d4f!important}.beans-select__indicator-separator{background-color:#e8dcc8}.beans-select__dropdown-indicator{color:#8c7851}.beans-select__clear-indicator{color:#8c7851;cursor:pointer}.beans-select__clear-indicator:hover{color:#6b5d4f}.beans-select__loading-indicator{color:#8c7851}.beans-search .no-options{padding:2rem 1rem;text-align:center;color:#8c7851}.beans-search .no-options p{margin:0 0 .5rem;font-size:.938rem}.beans-search .no-options .hint{font-size:.813rem;color:#b8a98f;font-style:italic}.selected-roaster-chip{display:flex;align-items:center;justify-content:space-between;padding:.5rem .75rem;background-color:#f5f1e8;border:2px solid #E8DCC8;border-radius:8px;margin-bottom:.5rem}.selected-roaster-chip-name{font-weight:500;color:#6b5d4f;font-size:.938rem}.selected-roaster-chip-close{background:none;border:none;color:#8c7851;font-size:1.25rem;cursor:pointer;padding:0 .25rem;line-height:1;transition:color .2s}.selected-roaster-chip-close:hover{color:#6b5d4f}.selected-roaster-chip-close:disabled{opacity:.5;cursor:not-allowed}.selected-beans{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background-color:#f5f1e8;border:2px solid #E8DCC8;border-radius:8px;margin-top:.5rem}.selected-beans-info{display:flex;flex-direction:column}.selected-beans-name{font-weight:500;color:#6b5d4f}.selected-beans-roaster{font-size:.875rem;color:#8c7851}.selected-beans-clear{padding:.375rem .75rem;background-color:transparent;color:#8c7851;border:1px solid #8C7851;border-radius:4px;font-size:.813rem;cursor:pointer;transition:all .2s}.selected-beans-clear:hover{background-color:#8c7851;color:#fff}.beans-select__menu-list::-webkit-scrollbar{width:8px}.beans-select__menu-list::-webkit-scrollbar-track{background:#f5f1e8;border-radius:0 8px 8px 0}.beans-select__menu-list::-webkit-scrollbar-thumb{background:#d4c4a8;border-radius:4px}.beans-select__menu-list::-webkit-scrollbar-thumb:hover{background:#8c7851}.new-shot-page{min-height:100vh;background-color:#f5f1e8}.new-shot-main{padding:2rem;max-width:800px;margin:0 auto}.new-shot-container{background-color:#fff;border-radius:12px;padding:2rem;box-shadow:0 2px 8px #6b5d4f1a}.new-shot-header{margin-bottom:2rem;text-align:center}.new-shot-header h1{color:#6b5d4f;font-size:2rem;font-weight:600;margin:1rem 0 .5rem}.new-shot-header p{color:#8c7851;font-size:1.063rem;margin:0}.back-button{background-color:transparent;color:#8c7851;border:1px solid #E8DCC8;padding:.625rem 1.25rem;border-radius:8px;font-size:.938rem;font-weight:500;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:.5rem;margin-bottom:1rem}.back-button:hover:not(:disabled){background-color:#f5f1e8;border-color:#d4c4a8}.back-button:disabled{opacity:.5;cursor:not-allowed}.new-shot-form-wrapper{margin-top:2rem}.coffee-shot-form{background-color:#fff;border-radius:12px;padding:2rem;border:1px solid #E8DCC8}.coffee-shot-form h2{font-size:1.5rem;color:#6b5d4f;margin:0 0 1.5rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;font-weight:500;color:#6b5d4f;margin-bottom:.5rem;font-size:.938rem}.form-group input[type=text],.form-group input[type=number],.form-group input[type=file]{width:100%;padding:.75rem;border:2px solid #E8DCC8;border-radius:8px;font-size:1rem;color:#6b5d4f;transition:border-color .2s}.form-group input[type=text]:focus,.form-group input[type=number]:focus{outline:none;border-color:#8c7851}.form-group input[type=range]{width:100%;height:8px;background:#e8dcc8;border-radius:4px;outline:none}.form-group input[type=range]::-webkit-slider-thumb{appearance:none;width:20px;height:20px;background:#8c7851;border-radius:50%;cursor:pointer}.form-group input[type=range]::-moz-range-thumb{width:20px;height:20px;background:#8c7851;border-radius:50%;cursor:pointer;border:none}.image-preview{margin-top:1rem;border-radius:8px;overflow:hidden;max-width:400px}.rating-display{font-size:1.5rem;color:#f5a623;margin-top:.5rem}.submit-button{width:100%;padding:.875rem;background:linear-gradient(135deg,#8c7851,#6b5d4f);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s ease}.submit-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #6b5d4f33}.submit-button:disabled{opacity:.6;cursor:not-allowed}@media(max-width:768px){.new-shot-main{padding:1rem}.new-shot-container{padding:1.5rem}.new-shot-header h1{font-size:1.5rem}.new-shot-header p{font-size:.938rem}}.shop-page{min-height:100vh;background-color:#f5f1e8}.shop-main{padding:3rem 2rem;min-height:calc(100vh - 80px);display:flex;align-items:center;justify-content:center}.shop-container{max-width:900px;margin:0 auto}.coming-soon-content{background-color:#fff;border-radius:12px;padding:4rem 3rem;border:1px solid #E8DCC8;text-align:center}.coming-soon-icon{font-size:5rem;margin-bottom:2rem;opacity:.8}.coming-soon-content h1{font-size:3rem;color:#6b5d4f;margin:0 0 1rem;font-weight:600}.coming-soon-subtitle{font-size:1.25rem;color:#8c7851;margin:0 0 2.5rem;font-style:italic}.shop-description{max-width:600px;margin:0 auto 3rem}.shop-description p{color:#6b5d4f;font-size:1.063rem;line-height:1.7;margin:0 0 1rem}.shop-description p:last-child{margin-bottom:0}.coming-soon-features{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:2rem;margin-top:3rem;padding-top:3rem;border-top:2px solid #E8DCC8}.feature-item{padding:1.5rem;background-color:#f5f1e8;border-radius:12px;transition:all .3s ease}.feature-item:hover{transform:translateY(-4px);box-shadow:0 8px 20px #6b5d4f14}.feature-icon{font-size:2.5rem;margin-bottom:1rem}.feature-item h3{font-size:1.25rem;color:#6b5d4f;margin:0 0 .5rem;font-weight:600}.feature-item p{font-size:.938rem;color:#8c7851;margin:0;line-height:1.5}.shop-loading{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background-color:#f5f1e8;color:#6b5d4f}.shop-loading p{font-size:1.125rem;color:#8c7851}.shop-error{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background-color:#f5f1e8;padding:2rem;text-align:center}.shop-error h2{color:#6b5d4f;font-size:2rem;margin:0 0 1rem}.shop-error p{color:#8c7851;margin:0 0 2rem;font-size:1.125rem}.btn-primary{display:inline-block;padding:.75rem 2rem;background:linear-gradient(135deg,#8c7851,#6b5d4f);color:#fff;border:none;border-radius:8px;font-weight:500;cursor:pointer;transition:all .3s ease;text-decoration:none;font-size:1rem}@media(max-width:768px){.shop-main{padding:2rem 1rem}.coming-soon-content{padding:3rem 2rem}.coming-soon-content h1{font-size:2rem}.coming-soon-subtitle{font-size:1.063rem}.coming-soon-features{grid-template-columns:1fr;gap:1.5rem}}.machine-search{width:100%}.machine-select__control{border:2px solid #E8DCC8!important;border-radius:8px!important;min-height:48px}.machine-select__control:hover{border-color:#8c7851!important}.machine-select__control--is-focused{border-color:#8c7851!important;box-shadow:0 0 0 3px #8c78511a!important}.machine-select__placeholder{color:#b8a98f}.machine-select__input-container,.machine-select__single-value{color:#6b5d4f}.machine-select__menu{border:2px solid #E8DCC8;border-radius:8px;box-shadow:0 4px 12px #6b5d4f1a;z-index:100}.machine-select__menu-list{padding:0;max-height:300px}.machine-select__option{padding:.875rem 1rem;cursor:pointer;color:#6b5d4f;transition:background-color .2s}.machine-select__option--is-focused{background-color:#f5f1e8!important}.machine-select__option--is-selected{background-color:#e8dcc8!important;color:#6b5d4f!important}.machine-select__indicator-separator{background-color:#e8dcc8}.machine-select__dropdown-indicator{color:#8c7851}.machine-select__clear-indicator{color:#8c7851;cursor:pointer}.machine-select__clear-indicator:hover{color:#6b5d4f}.machine-select__loading-indicator{color:#8c7851}.no-options{padding:2rem 1rem;text-align:center;color:#8c7851}.no-options p{margin:0 0 1rem;font-size:.938rem}.not-found-button{padding:.625rem 1.25rem;background-color:transparent;color:#8c7851;border:2px solid #8C7851;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s;font-size:.875rem;font-family:inherit}.not-found-button:hover{background-color:#8c7851;color:#fff}.machine-select__menu-list::-webkit-scrollbar{width:8px}.machine-select__menu-list::-webkit-scrollbar-track{background:#f5f1e8;border-radius:0 8px 8px 0}.machine-select__menu-list::-webkit-scrollbar-thumb{background:#d4c4a8;border-radius:4px}.machine-select__menu-list::-webkit-scrollbar-thumb:hover{background:#8c7851}.grinder-search{width:100%}.grinder-select__control{border:2px solid #E8DCC8!important;border-radius:8px!important;min-height:48px}.grinder-select__control:hover{border-color:#8c7851!important}.grinder-select__control--is-focused{border-color:#8c7851!important;box-shadow:0 0 0 3px #8c78511a!important}.grinder-select__placeholder{color:#b8a98f}.grinder-select__input-container,.grinder-select__single-value{color:#6b5d4f}.grinder-select__menu{border:2px solid #E8DCC8;border-radius:8px;box-shadow:0 4px 12px #6b5d4f1a;z-index:100}.grinder-select__menu-list{padding:0;max-height:300px}.grinder-select__option{padding:.875rem 1rem;cursor:pointer;color:#6b5d4f;transition:background-color .2s}.grinder-select__option--is-focused{background-color:#f5f1e8!important}.grinder-select__option--is-selected{background-color:#e8dcc8!important;color:#6b5d4f!important}.grinder-select__indicator-separator{background-color:#e8dcc8}.grinder-select__dropdown-indicator{color:#8c7851}.grinder-select__clear-indicator{color:#8c7851;cursor:pointer}.grinder-select__clear-indicator:hover{color:#6b5d4f}.grinder-select__loading-indicator{color:#8c7851}.grinder-search .no-options{padding:2rem 1rem;text-align:center;color:#8c7851}.grinder-search .no-options p{margin:0 0 .5rem;font-size:.938rem}.selected-brand-chip{display:flex;align-items:center;justify-content:space-between;padding:.5rem .75rem;background-color:#f5f1e8;border:2px solid #E8DCC8;border-radius:8px;margin-bottom:.5rem}.selected-brand-chip-name{font-weight:500;color:#6b5d4f;font-size:.938rem}.selected-brand-chip-close{background:none;border:none;color:#8c7851;font-size:1.25rem;cursor:pointer;padding:0 .25rem;line-height:1;transition:color .2s}.selected-brand-chip-close:hover{color:#6b5d4f}.selected-brand-chip-close:disabled{opacity:.5;cursor:not-allowed}.add-brand-only-button{display:block;width:100%;margin-top:.5rem;padding:.625rem 1rem;background-color:transparent;color:#8c7851;border:1px dashed #8C7851;border-radius:6px;font-size:.875rem;cursor:pointer;transition:all .2s;text-align:center}.add-brand-only-button:hover{background-color:#f5f1e8;border-color:#6b5d4f;color:#6b5d4f}.add-brand-only-button:disabled{opacity:.5;cursor:not-allowed}.grinder-select__menu-list::-webkit-scrollbar{width:8px}.grinder-select__menu-list::-webkit-scrollbar-track{background:#f5f1e8;border-radius:0 8px 8px 0}.grinder-select__menu-list::-webkit-scrollbar-thumb{background:#d4c4a8;border-radius:4px}.grinder-select__menu-list::-webkit-scrollbar-thumb:hover{background:#8c7851}.settings-page{min-height:100vh;background-color:#f5f1e8}.settings-main{padding:3rem 2rem}.settings-container{max-width:800px;margin:0 auto}.settings-header h1{font-size:2.5rem;color:#6b5d4f;margin:0 0 .5rem}.settings-header p{font-size:1.125rem;color:#8c7851;margin:0 0 2rem}.tabs{display:flex;gap:.5rem;margin-bottom:2rem;border-bottom:2px solid #E8DCC8}.tab{padding:.75rem 1.5rem;background:transparent;border:none;color:#8c7851;font-size:1rem;font-weight:500;cursor:pointer;border-bottom:3px solid transparent;margin-bottom:-2px;transition:all .2s}.tab:hover{color:#6b5d4f;background-color:#e8dcc84d}.tab.active{color:#6b5d4f;border-bottom-color:#8c7851}.tab-content{margin-top:2rem}.empty-state{text-align:center;padding:4rem 2rem;background-color:#fff;border-radius:12px;border:1px solid #E8DCC8}.empty-state p{color:#8c7851;margin:0 0 1.5rem;font-size:1.125rem}.btn-primary{padding:.75rem 1.5rem;background:linear-gradient(135deg,#8c7851,#6b5d4f);color:#fff;border:none;border-radius:8px;font-weight:500;cursor:pointer;transition:all .3s ease;font-size:1rem}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 20px #6b5d4f33}.btn-secondary{padding:.5rem 1rem;background-color:transparent;color:#8c7851;border:1px solid #E8DCC8;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s;font-size:.938rem}.btn-secondary:hover{background-color:#f5f1e8;border-color:#d4c4a8}.add-machine-section{margin-bottom:2rem}.add-machine-card{background-color:#fff;border:2px solid #E8DCC8;border-radius:12px;padding:1.5rem;margin-bottom:1.5rem}.add-machine-card h3{font-size:1.25rem;color:#6b5d4f;margin:0 0 1rem}.add-machine-actions{display:flex;gap:.75rem;margin-top:1rem}.adding-machine{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;gap:1rem}.adding-machine .loading-spinner{width:32px;height:32px}.adding-machine p{color:#8c7851;margin:0;font-size:.938rem}.machines-list h2{font-size:1.75rem;color:#6b5d4f;margin:0 0 1.5rem}.machines-grid{display:flex;flex-direction:column;gap:1rem}.machine-card{background-color:#fff;border:2px solid #E8DCC8;border-radius:12px;padding:1.5rem;display:flex;justify-content:space-between;align-items:center;transition:all .2s}.machine-card:hover{border-color:#d4c4a8;box-shadow:0 2px 8px #6b5d4f14}.machine-info{flex:1}.machine-name{font-weight:600;font-size:1.063rem;color:#6b5d4f;margin:0 0 .25rem;display:flex;align-items:center;gap:.5rem}.primary-badge{padding:.25rem .75rem;background-color:#8c7851;color:#fff;border-radius:6px;font-size:.75rem;font-weight:500}.machine-nickname{font-size:.938rem;color:#8c7851;margin:.25rem 0 0}.machine-actions{display:flex;gap:.5rem}.btn-outline-primary{padding:.5rem 1rem;background-color:transparent;color:#8c7851;border:2px solid #8C7851;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s;font-size:.875rem}.btn-outline-primary:hover{background-color:#8c7851;color:#fff}.btn-outline-danger{padding:.5rem 1rem;background-color:transparent;color:#d9534f;border:2px solid #D9534F;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s;font-size:.875rem}.btn-outline-danger:hover:not(:disabled){background-color:#d9534f;color:#fff}.btn-outline-danger:disabled{opacity:.5;cursor:not-allowed}.modal-backdrop{position:fixed;inset:0;background-color:#6b5d4f80;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-dialog{background-color:#fff;border-radius:12px;padding:2rem;max-width:400px;width:90%;box-shadow:0 8px 24px #6b5d4f33}.modal-dialog h3{font-size:1.25rem;color:#6b5d4f;margin:0 0 1.5rem}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.5rem}.btn-danger{padding:.625rem 1.25rem;background-color:#d9534f;color:#fff;border:none;border-radius:8px;font-weight:500;cursor:pointer;transition:all .3s ease;font-size:.938rem}.btn-danger:hover{background-color:#c9302c;transform:translateY(-1px);box-shadow:0 4px 12px #d9534f4d}.settings-loading{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background-color:#f5f1e8;color:#6b5d4f}.loading-spinner{width:48px;height:48px;border:4px solid #E8DCC8;border-top-color:#8c7851;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{to{transform:rotate(360deg)}}.settings-loading p{font-size:1.125rem;color:#8c7851}.success-message{background-color:#d4edda;color:#155724;border:1px solid #C3E6CB;border-radius:8px;padding:1rem;margin-bottom:1.5rem;font-size:.938rem;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.error-message{background-color:#fff3cd;color:#856404;border:1px solid #FFE69C;border-radius:8px;padding:1rem;margin-bottom:1.5rem;font-size:.938rem}@media(max-width:768px){.settings-main{padding:2rem 1rem}.settings-header h1{font-size:2rem}.machine-card{flex-direction:column;align-items:flex-start;gap:1rem}.machine-actions{width:100%;justify-content:flex-end}.modal-dialog{padding:1.5rem}}.terms-page{min-height:100vh;padding:2rem 1rem;background:var(--background, #fff);color:var(--text, #111)}.terms-container{max-width:720px;margin:0 auto}.terms-container h1{font-size:2rem;margin-bottom:.25rem}.terms-version{color:var(--text-muted, #666);font-size:.875rem;margin-bottom:2rem}.terms-container h2{font-size:1.125rem;margin-top:1.75rem;margin-bottom:.5rem}.terms-container ul{padding-left:1.5rem;margin:.5rem 0}.terms-container li{margin-bottom:.4rem;line-height:1.5}.terms-container p{line-height:1.6;margin-bottom:.5rem}.terms-container a{color:var(--primary, #6f4e37);text-decoration:underline}.terms-actions{margin-top:2.5rem;padding-top:1.5rem;border-top:1px solid var(--border, #e5e5e5);display:flex;flex-direction:column;align-items:flex-start;gap:.75rem}.terms-accept-button{background:var(--primary, #6f4e37);color:#fff;border:none;border-radius:6px;padding:.75rem 1.5rem;font-size:1rem;cursor:pointer;transition:opacity .15s}.terms-accept-button:disabled{opacity:.6;cursor:not-allowed}.terms-error{color:#c0392b;font-size:.875rem}.terms-accepted-notice{color:var(--text-muted, #666);font-size:.875rem}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{background:linear-gradient(135deg,#6b4423,#3e2723);color:#fff;padding:3rem 2rem;text-align:center;box-shadow:0 4px 6px #0000001a}.app-header h1{margin:0;font-size:3rem;font-weight:700;margin-bottom:.5rem}.tagline{margin:0;font-size:1.2rem;opacity:.9}.app-main{flex:1;max-width:1200px;margin:0 auto;padding:2rem;width:100%}.upload-section{margin-bottom:3rem}.toggle-form-button{background:#6b4423;color:#fff;border:none;padding:1rem 2rem;font-size:1.1rem;border-radius:8px;cursor:pointer;transition:all .3s ease;font-weight:600}.toggle-form-button:hover{background:#8b5a3c;transform:translateY(-2px);box-shadow:0 4px 8px #0003}.coffee-shot-form{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 4px 12px #0000001a;margin-top:1.5rem;max-width:600px;margin-left:auto;margin-right:auto}.coffee-shot-form h2{margin-top:0;color:#3e2723;margin-bottom:1.5rem}.form-group{margin-bottom:1.5rem;text-align:left}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:#3e2723}.form-group input[type=text],.form-group input[type=number],.form-group input[type=file]{width:100%;padding:.75rem;border:2px solid #e0e0e0;border-radius:6px;font-size:1rem;transition:border-color .3s ease}.form-group input:focus{outline:none;border-color:#6b4423}.form-group input:disabled{background:#f5f5f5;cursor:not-allowed}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.image-preview{margin-top:1rem;border-radius:8px;overflow:hidden;max-width:300px}.image-preview img{width:100%;height:auto;display:block}.rating-display{font-size:2rem;color:gold;margin-top:.5rem}input[type=range]{width:100%;height:8px;border-radius:4px;background:#e0e0e0;outline:none}input[type=range]::-webkit-slider-thumb{appearance:none;width:20px;height:20px;border-radius:50%;background:#6b4423;cursor:pointer}input[type=range]::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:#6b4423;cursor:pointer;border:none}.submit-button{width:100%;background:#6b4423;color:#fff;border:none;padding:1rem;font-size:1.1rem;border-radius:8px;cursor:pointer;font-weight:600;transition:all .3s ease;margin-top:1rem}.submit-button:hover:not(:disabled){background:#8b5a3c;transform:translateY(-2px);box-shadow:0 4px 8px #0003}.submit-button:disabled{background:#ccc;cursor:not-allowed}.coffee-shot-gallery h2{color:#3e2723;margin-bottom:1.5rem;text-align:center}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;margin-top:1.5rem}.coffee-shot-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 4px 12px #0000001a;transition:all .3s ease}.coffee-shot-card:hover{transform:translateY(-4px);box-shadow:0 8px 16px #00000026}.card-image{width:100%;height:250px;overflow:hidden;background:#f5f5f5}.card-image img{width:100%;height:100%;object-fit:cover}.card-content{padding:1.5rem}.card-content .rating{font-size:1.5rem;color:gold;margin-bottom:.5rem}.card-content h3{margin:0 0 .5rem;color:#3e2723;font-size:1.3rem}.card-content .beans{color:#666;margin:0 0 1rem;font-style:italic}.shot-details{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin:1rem 0;padding:1rem 0;border-top:1px solid #e0e0e0;border-bottom:1px solid #e0e0e0}.detail{text-align:center}.detail .label{display:block;font-size:.85rem;color:#666;margin-bottom:.25rem}.detail .value{display:block;font-weight:700;font-size:1.1rem;color:#3e2723}.card-footer{display:flex;justify-content:space-between;align-items:center;margin-top:1rem}.card-footer .date{color:#999;font-size:.9rem}.delete-button{background:#d32f2f;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.9rem;transition:all .3s ease}.delete-button:hover{background:#b71c1c}.loading,.empty-state{text-align:center;padding:3rem;color:#666}.empty-state h3{color:#3e2723;margin-bottom:.5rem}.app-footer{background:#3e2723;color:#fff;text-align:center;padding:2rem;margin-top:3rem}.app-footer p{margin:0;opacity:.9}@media(max-width:768px){.app-header h1{font-size:2rem}.gallery-grid,.form-row{grid-template-columns:1fr}}
