:root{--color-bg: #faf8f5;--color-surface: #ffffff;--color-text: #1a1a1a;--color-text-muted: #6b6b6b;--color-accent: #1a1a2e;--color-accent-hover: #2d2d4e;--color-border: #e8e2da;--color-error: #b91c1c;--color-error-bg: #fef2f2;--color-error-border: #fecaca;--color-success: #15803d;--shadow-card: 0 2px 8px rgba(0, 0, 0, .06);--shadow-pop: 0 4px 12px rgba(0, 0, 0, .08);--font-sans: "Inter", system-ui, -apple-system, sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--max-width: 480px;--header-height: 3.5rem;--nav-height: 4rem;--radius-sm: 4px;--radius-md: 8px}[data-theme=dark]{--color-bg: #0d1424;--color-surface: #161f33;--color-text: #eef1f8;--color-text-muted: #a3adc6;--color-accent: #3f5bd4;--color-accent-hover: #5570e8;--color-border: #2a3450;--color-error: #f87171;--color-error-bg: #2a1518;--color-error-border: #5b2526;--color-success: #4ade80;--shadow-card: 0 2px 10px rgba(0, 0, 0, .45);--shadow-pop: 0 6px 16px rgba(0, 0, 0, .55)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%}body{font-family:var(--font-sans);font-size:var(--font-size-base);color:var(--color-text);background-color:var(--color-bg);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:var(--color-accent);text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer;font-family:inherit}input,textarea,select{font-family:inherit;background-color:var(--color-surface);color:var(--color-text)}input::placeholder,textarea::placeholder{color:var(--color-text-muted)}img{max-width:100%;display:block}.page-layout{display:flex;flex-direction:column;min-height:100dvh;max-width:var(--max-width);margin:0 auto}.page-layout__content{flex:1;padding:var(--space-6) var(--space-4);padding-bottom:calc(var(--nav-height) + var(--space-6));overflow-y:auto}.header{position:sticky;top:0;z-index:10;height:var(--header-height);background-color:var(--color-bg);border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:center;padding:0 var(--space-4)}.header__brand{display:flex;align-items:center;gap:var(--space-2)}.header__logo{flex-shrink:0}.header__wordmark{font-size:var(--font-size-base);font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:var(--color-accent)}.bottom-nav{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:var(--max-width);height:var(--nav-height);background-color:var(--color-surface);border-top:1px solid var(--color-border);display:flex;z-index:10}.bottom-nav__tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-1);color:var(--color-text-muted);font-size:var(--font-size-xs);font-weight:500;text-decoration:none;letter-spacing:.03em;transition:color .15s}.bottom-nav__tab svg{width:1.375rem;height:1.375rem}.bottom-nav__tab:hover{color:var(--color-accent);text-decoration:none}.bottom-nav__tab--active{color:var(--color-accent)}.auth-page{min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-8) var(--space-6);max-width:var(--max-width);margin:0 auto}.auth-brand{display:flex;flex-direction:column;align-items:center;gap:var(--space-3);margin-bottom:var(--space-8)}.auth-brand__logo{opacity:.9}.auth-title{font-size:var(--font-size-xl);font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:var(--color-accent);margin-bottom:0}.auth-form{width:100%;display:flex;flex-direction:column;gap:var(--space-4)}.auth-form h2{font-size:var(--font-size-xl);font-weight:500;margin-bottom:var(--space-2)}.auth-form label{display:flex;flex-direction:column;gap:var(--space-2);font-size:var(--font-size-xs);font-weight:500;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.08em}.auth-form input{padding:var(--space-3) var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--font-size-base);color:var(--color-text);background-color:var(--color-surface);outline:none;transition:border-color .15s}.auth-form input:focus{border-color:var(--color-accent)}.auth-form button[type=submit]{margin-top:var(--space-2);padding:var(--space-3) var(--space-4);background-color:var(--color-accent);color:#fff;border:none;border-radius:var(--radius-sm);font-size:var(--font-size-base);font-weight:500;letter-spacing:.03em;transition:background-color .15s}.auth-form button[type=submit]:hover:not(:disabled){background-color:var(--color-accent-hover)}.auth-form button[type=submit]:disabled{opacity:.55;cursor:not-allowed}.auth-error{padding:var(--space-3) var(--space-4);background-color:var(--color-error-bg);border:1px solid var(--color-error-border);border-radius:var(--radius-sm);color:var(--color-error);font-size:var(--font-size-sm)}.auth-switch{text-align:center;font-size:var(--font-size-sm);color:var(--color-text-muted)}.account-email{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-bottom:var(--space-6)}.account-logout-btn{padding:var(--space-3) var(--space-6);background-color:transparent;color:var(--color-accent);border:1px solid var(--color-accent);border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:500;letter-spacing:.03em;transition:background-color .15s,color .15s}.account-logout-btn:hover{background-color:var(--color-accent);color:#fff}.account{display:flex;flex-direction:column;gap:var(--space-5)}.account__title{font-size:var(--font-size-2xl);font-weight:600}.account-card{display:flex;flex-direction:column;gap:var(--space-3);padding:var(--space-5);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md)}.account-card__title{font-size:var(--font-size-lg);font-weight:600}.account-card__email{font-size:var(--font-size-sm);color:var(--color-text-muted)}.account-card__hint{font-size:var(--font-size-sm);color:var(--color-text-muted);line-height:1.4}.account-card__actions{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-3)}.account-card__save{padding:var(--space-2) var(--space-5);border:none;border-radius:var(--radius-md);background-color:var(--color-accent);color:#fff;font-weight:600;cursor:pointer}.account-card__save:disabled{opacity:.6;cursor:not-allowed}.account-form{display:flex;flex-direction:column;gap:var(--space-3)}.account-form label{display:flex;flex-direction:column;gap:var(--space-1);font-size:var(--font-size-sm);font-weight:500}.account-form input{padding:var(--space-3);border:1.5px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-base);font-family:inherit}.account-form input:focus{outline:none;border-color:var(--color-accent)}.account-form button[type=submit]{margin-top:var(--space-2);padding:var(--space-3);border:none;border-radius:var(--radius-md);background-color:var(--color-accent);color:#fff;font-weight:600;cursor:pointer}.account-form button[type=submit]:disabled{opacity:.6;cursor:not-allowed}.account-success{color:var(--color-success);font-size:var(--font-size-sm);font-weight:500}.account-success--inline{align-self:flex-start}.new-brew-page{padding:var(--space-4) 0}.new-brew-page__title{font-size:var(--font-size-xl);font-weight:500;margin-bottom:var(--space-4)}.new-brew-page__hint{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-bottom:var(--space-6)}.new-brew-page__extracted{display:flex;flex-direction:column;gap:var(--space-2)}.new-brew-page__extracted-label{font-size:var(--font-size-xs);font-weight:500;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted)}.new-brew-page__coffee-name{font-size:var(--font-size-xl);font-weight:500}.new-brew-page__roaster{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-bottom:var(--space-4)}.new-brew-page__rescan{align-self:flex-start;margin-top:var(--space-4);padding:var(--space-2) var(--space-4);background-color:transparent;color:var(--color-text-muted);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--font-size-sm)}.label-capture__file-input{position:absolute;width:1px;height:1px;opacity:0;overflow:hidden}.label-capture__input-label{display:block;cursor:pointer}.label-capture__placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);height:200px;border:1.5px dashed var(--color-border);border-radius:var(--radius-md);color:var(--color-text-muted);font-size:var(--font-size-sm);transition:border-color .15s}.label-capture__placeholder:hover{border-color:var(--color-accent);color:var(--color-accent)}.label-capture__placeholder svg{width:2rem;height:2rem}.label-capture__preview{width:100%;max-height:280px;object-fit:cover;border-radius:var(--radius-md)}.label-capture__error{margin-top:var(--space-3);font-size:var(--font-size-sm);color:var(--color-error)}.label-capture__submit{width:100%;margin-top:var(--space-4);padding:var(--space-3) var(--space-4);background-color:var(--color-accent);color:#fff;border:none;border-radius:var(--radius-sm);font-size:var(--font-size-base);font-weight:500;transition:background-color .15s}.label-capture__submit:hover:not(:disabled){background-color:var(--color-accent-hover)}.label-capture__submit:disabled{opacity:.55;cursor:not-allowed}.label-capture__retake{width:100%;margin-top:var(--space-2);padding:var(--space-2) var(--space-4);background-color:transparent;color:var(--color-text-muted);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--font-size-sm)}.new-brew-page__skip{display:block;width:100%;margin-top:var(--space-3);padding:var(--space-2) var(--space-4);background-color:transparent;color:var(--color-text-muted);border:none;font-size:var(--font-size-sm);text-decoration:underline;text-underline-offset:2px}.coffee-form{display:flex;flex-direction:column;gap:var(--space-5);padding-top:var(--space-2)}.coffee-form__title{font-size:var(--font-size-xl);font-weight:500;margin-bottom:var(--space-2)}.coffee-form__field{display:flex;flex-direction:column;gap:var(--space-2)}.coffee-form__label{font-size:var(--font-size-xs);font-weight:500;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted)}.coffee-form__required{color:var(--color-error)}.coffee-form__input,.coffee-form__textarea,.coffee-form__select{padding:var(--space-3) var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--font-size-base);color:var(--color-text);background-color:var(--color-surface);outline:none;transition:border-color .15s;width:100%}.coffee-form__input:focus,.coffee-form__textarea:focus,.coffee-form__select:focus{border-color:var(--color-accent)}.coffee-form__input--error,.coffee-form__input--error:focus{border-color:var(--color-error)}.coffee-form__textarea{resize:vertical;min-height:80px}.coffee-form__select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236b6b6b' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-3) center;padding-right:calc(var(--space-3) + 1.25rem);cursor:pointer}.coffee-form__actions{display:flex;gap:var(--space-3);padding-top:var(--space-2)}.coffee-form__back{flex:0 0 auto;padding:var(--space-3) var(--space-4);background-color:transparent;color:var(--color-text-muted);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--font-size-sm);transition:border-color .15s,color .15s}.coffee-form__back:hover{border-color:var(--color-accent);color:var(--color-accent)}.coffee-form__submit{flex:1;padding:var(--space-3) var(--space-4);background-color:var(--color-accent);color:#fff;border:none;border-radius:var(--radius-sm);font-size:var(--font-size-base);font-weight:500;letter-spacing:.03em;transition:background-color .15s}.coffee-form__submit:hover:not(:disabled){background-color:var(--color-accent-hover)}.coffee-form__submit:disabled{opacity:.55;cursor:not-allowed}.field-error{font-size:var(--font-size-xs);color:var(--color-error);margin-top:var(--space-1)}.country-select{position:relative}.country-select__chips{display:flex;flex-wrap:wrap;gap:var(--space-2);list-style:none;margin-bottom:var(--space-2)}.country-select__chip{display:flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);background-color:var(--color-accent);color:#fff;border-radius:9999px;font-size:var(--font-size-xs);font-weight:500}.country-select__chip-remove{display:flex;align-items:center;justify-content:center;width:1rem;height:1rem;background:none;border:none;color:#ffffffbf;font-size:1rem;line-height:1;padding:0;transition:color .1s}.country-select__chip-remove:hover{color:#fff}.country-select__input{width:100%;padding:var(--space-3) var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--font-size-base);color:var(--color-text);background-color:var(--color-surface);outline:none;transition:border-color .15s}.country-select__input:focus{border-color:var(--color-accent)}.country-select__input--error{border-color:var(--color-error)}.country-select__dropdown{position:absolute;top:100%;left:0;right:0;z-index:20;list-style:none;background-color:var(--color-surface);border:1px solid var(--color-border);border-top:none;border-radius:0 0 var(--radius-sm) var(--radius-sm);max-height:220px;overflow-y:auto;box-shadow:var(--shadow-pop)}.country-select__option{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);font-size:var(--font-size-sm);cursor:pointer;transition:background-color .1s}.country-select__option:hover{background-color:var(--color-bg)}.country-select__option--selected{background-color:var(--color-bg);font-weight:500}.country-select__option-check{width:1rem;color:var(--color-accent);font-size:var(--font-size-sm);flex-shrink:0}.method-selector{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-2)}.method-selector__card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-2);background-color:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:border-color .15s,background-color .15s,color .15s;color:var(--color-text-muted);min-height:80px}.method-selector__card:hover{border-color:var(--color-accent);color:var(--color-accent)}.method-selector__card--selected{border-color:var(--color-accent);background-color:var(--color-accent);color:#fff}.method-selector__card{position:relative}.method-selector__tick{position:absolute;top:var(--space-1);right:var(--space-1);display:flex;align-items:center;justify-content:center;width:1.1rem;height:1.1rem;border-radius:50%;background-color:#fff;color:var(--color-accent);font-size:.7rem;font-weight:700;line-height:1}.method-selector__bulk{display:flex;justify-content:flex-end;margin-bottom:var(--space-2)}.method-selector__bulk-btn{background:none;border:none;padding:0;cursor:pointer;color:var(--color-accent);font-size:var(--font-size-sm);font-weight:600}.method-selector__icon{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem}.method-selector__icon svg{width:100%;height:100%}.method-selector__label{font-size:var(--font-size-xs);font-weight:500;text-align:center;line-height:1.2;letter-spacing:.02em}.brew-form{display:flex;flex-direction:column;gap:var(--space-5);padding-top:var(--space-2)}.brew-form__title{font-size:var(--font-size-xl);font-weight:500;margin-bottom:var(--space-2)}.brew-form__field{display:flex;flex-direction:column;gap:var(--space-2)}.brew-form__label{font-size:var(--font-size-xs);font-weight:500;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted)}.brew-form__required{color:var(--color-error)}.brew-form__input,.brew-form__select{padding:var(--space-3) var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--font-size-base);color:var(--color-text);background-color:var(--color-surface);outline:none;transition:border-color .15s;width:100%}.brew-form__input:focus,.brew-form__select:focus{border-color:var(--color-accent)}.brew-form__input--error{border-color:var(--color-error)}.brew-form__select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236b6b6b' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-3) center;padding-right:calc(var(--space-3) + 1.25rem);cursor:pointer}.brew-form__select--placeholder{color:var(--color-text-muted)}.brew-form__ratio-header{display:flex;align-items:baseline;justify-content:space-between;gap:var(--space-3)}.brew-form__ratio-display{font-size:var(--font-size-sm);font-weight:500;color:var(--color-accent);white-space:nowrap}.brew-form__slider{width:100%;accent-color:var(--color-accent);height:2rem;cursor:pointer}.brew-form__ratio-range{display:flex;justify-content:space-between;font-size:var(--font-size-xs);color:var(--color-text-muted);margin-top:calc(-1 * var(--space-1))}.brew-form__actions{display:flex;gap:var(--space-3);padding-top:var(--space-2)}.brew-form__back{flex:0 0 auto;padding:var(--space-3) var(--space-4);background-color:transparent;color:var(--color-text-muted);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--font-size-sm);transition:border-color .15s,color .15s}.brew-form__back:hover{border-color:var(--color-accent);color:var(--color-accent)}.brew-form__submit{flex:1;padding:var(--space-3) var(--space-4);background-color:var(--color-accent);color:#fff;border:none;border-radius:var(--radius-sm);font-size:var(--font-size-base);font-weight:500;letter-spacing:.03em;transition:background-color .15s}.brew-form__submit:hover:not(:disabled){background-color:var(--color-accent-hover)}.brew-form__submit:disabled{opacity:.55;cursor:not-allowed}.brew-result{display:flex;flex-direction:column;gap:var(--space-5);padding-top:var(--space-2)}.brew-result__summary{display:flex;justify-content:space-between;align-items:flex-end}.brew-result__temp{display:flex;flex-direction:column;gap:var(--space-1)}.brew-result__temp-value{font-size:3rem;font-weight:600;line-height:1;color:var(--color-accent);letter-spacing:-.02em}.brew-result__temp-label{font-size:var(--font-size-xs);font-weight:500;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted)}.brew-result__grind{display:flex;flex-direction:column;align-items:flex-end;gap:var(--space-1);padding-bottom:var(--space-1)}.brew-result__grind-value{font-size:var(--font-size-lg);font-weight:500;color:var(--color-text);text-transform:capitalize;text-align:right}.brew-result__grind-microns{font-size:var(--font-size-sm);color:var(--color-text-muted)}.brew-result__grind-label{font-size:var(--font-size-xs);font-weight:500;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted)}.brew-result__ratio-rec{font-size:var(--font-size-sm);color:var(--color-text-muted);padding:var(--space-3) var(--space-4);background-color:var(--color-surface);border:1px solid var(--color-border);border-left:3px solid var(--color-accent);border-radius:var(--radius-sm);line-height:1.5}.brew-result__table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm);table-layout:fixed}.brew-result__th{padding:var(--space-2) var(--space-2);font-size:var(--font-size-xs);font-weight:500;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);border-bottom:1.5px solid var(--color-border);text-align:left}.brew-result__th--num{text-align:right;width:3.5rem}.brew-result__th:first-child{width:1.75rem}.brew-result__row+.brew-result__row .brew-result__td{border-top:1px solid var(--color-border)}.brew-result__td{padding:var(--space-3) var(--space-2);vertical-align:top;color:var(--color-text)}.brew-result__td--num{text-align:right;color:var(--color-text-muted);white-space:nowrap}.brew-result__action{display:block;font-weight:500}.brew-result__step-notes{display:block;font-size:var(--font-size-xs);color:var(--color-text-muted);margin-top:var(--space-1);line-height:1.4}.brew-result__guided-btn{padding:var(--space-3) var(--space-4);background-color:transparent;color:var(--color-accent);border:1.5px solid var(--color-accent);border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:500;letter-spacing:.03em;transition:background-color .15s,color .15s}.brew-result__guided-btn:hover{background-color:var(--color-accent);color:#fff}.brew-result__guided{display:flex;flex-direction:column;gap:var(--space-4);padding:var(--space-5);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md)}.brew-result__guided-header{display:flex;align-items:center;justify-content:space-between}.brew-result__step-counter{font-size:var(--font-size-xs);font-weight:500;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted)}.brew-result__guided-exit{font-size:var(--font-size-xs);font-weight:500;color:var(--color-text-muted);background:none;border:none;text-decoration:underline;text-underline-offset:2px;padding:0}.brew-result__guided-action{font-size:var(--font-size-2xl);font-weight:500;color:var(--color-accent);line-height:1.2}.brew-result__guided-amounts{display:flex;gap:var(--space-6)}.brew-result__guided-amount{display:flex;flex-direction:column;gap:var(--space-1)}.brew-result__guided-amount-value{font-size:var(--font-size-xl);font-weight:600}.brew-result__guided-amount-label{font-size:var(--font-size-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.06em}.brew-result__guided-notes{font-size:var(--font-size-sm);color:var(--color-text-muted);line-height:1.5}.brew-result__timer{display:flex;align-items:center;gap:var(--space-4)}.brew-result__timer-value{font-size:2.5rem;font-weight:600;letter-spacing:-.02em;font-variant-numeric:tabular-nums;min-width:4rem}.brew-result__timer-start{padding:var(--space-2) var(--space-4);background-color:var(--color-accent);color:#fff;border:none;border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:500;transition:background-color .15s}.brew-result__timer-start:hover:not(:disabled){background-color:var(--color-accent-hover)}.brew-result__timer-start:disabled{opacity:.55;cursor:not-allowed}.brew-result__next-btn{width:100%;padding:var(--space-3) var(--space-4);background-color:var(--color-accent);color:#fff;border:none;border-radius:var(--radius-sm);font-size:var(--font-size-base);font-weight:500;letter-spacing:.03em;transition:background-color .15s}.brew-result__next-btn:hover{background-color:var(--color-accent-hover)}.brew-result__actions{display:flex;flex-direction:column;gap:var(--space-3);padding-top:var(--space-2)}.brew-result__save{width:100%;padding:var(--space-3) var(--space-4);background-color:var(--color-accent);color:#fff;border:none;border-radius:var(--radius-sm);font-size:var(--font-size-base);font-weight:500;letter-spacing:.03em;transition:background-color .15s}.brew-result__save:hover{background-color:var(--color-accent-hover)}.brew-result__start-over{width:100%;padding:var(--space-3) var(--space-4);background-color:transparent;color:var(--color-text-muted);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--font-size-sm);transition:border-color .15s,color .15s}.brew-result__start-over:hover{border-color:var(--color-accent);color:var(--color-accent)}.new-brew-page__generating{margin-top:var(--space-3);font-size:var(--font-size-sm);color:var(--color-text-muted);text-align:center}.new-brew-page__error{margin-top:var(--space-3);padding:var(--space-3) var(--space-4);background-color:var(--color-error-bg);border:1px solid var(--color-error-border);border-radius:var(--radius-sm);color:var(--color-error);font-size:var(--font-size-sm)}.plan-detail{display:flex;flex-direction:column;gap:var(--space-5);padding-top:var(--space-2)}.plan-detail__header{display:flex;flex-direction:column;gap:var(--space-1)}.plan-detail__back{align-self:flex-start;background:none;border:none;padding:0;font-size:var(--font-size-sm);color:var(--color-text-muted);text-decoration:underline;text-underline-offset:2px;margin-bottom:var(--space-2)}.plan-detail__back:hover{color:var(--color-accent)}.plan-detail__title{font-size:var(--font-size-xl);font-weight:500}.plan-detail__roaster,.plan-detail__loading{font-size:var(--font-size-sm);color:var(--color-text-muted)}.plan-detail__error{padding:var(--space-3) var(--space-4);background-color:var(--color-error-bg);border:1px solid var(--color-error-border);border-radius:var(--radius-sm);color:var(--color-error);font-size:var(--font-size-sm)}.plan-detail__stub{padding:var(--space-4);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);display:flex;flex-direction:column;gap:var(--space-2)}.plan-detail__stub-label{font-size:var(--font-size-xs);font-weight:500;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted)}.plan-detail__stub-hint{font-size:var(--font-size-sm);color:var(--color-text-muted)}.home{padding-top:var(--space-2)}.home__cta{display:flex;align-items:center;justify-content:center;gap:var(--space-2);width:100%;padding:var(--space-3) var(--space-4);background-color:var(--color-accent);color:#fff;border-radius:var(--radius-sm);font-size:var(--font-size-base);font-weight:500;letter-spacing:.03em;transition:background-color .15s}.home__cta:hover{background-color:var(--color-accent-hover);text-decoration:none}.home__cta-icon{width:1.125rem;height:1.125rem}.home__loading,.home__empty{margin-top:var(--space-5);font-size:var(--font-size-sm);color:var(--color-text-muted)}.home__error{margin-top:var(--space-5);padding:var(--space-3) var(--space-4);background-color:var(--color-error-bg);border:1px solid var(--color-error-border);border-radius:var(--radius-sm);color:var(--color-error);font-size:var(--font-size-sm)}.home__section{margin-top:var(--space-6)}.home__section-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:var(--space-3)}.home__section-title{font-size:var(--font-size-lg);font-weight:500}.home__see-all{font-size:var(--font-size-sm);color:var(--color-accent);flex-shrink:0}.home__row{list-style:none;display:flex;gap:var(--space-3);overflow-x:auto;scroll-snap-type:x proximity;scroll-padding-inline:var(--space-4);-webkit-overflow-scrolling:touch;scrollbar-width:none;margin:0 calc(-1 * var(--space-4));padding:0 var(--space-4) var(--space-1)}.home__row::-webkit-scrollbar{display:none}.home__row>li{flex:0 0 9.5rem;scroll-snap-align:start;display:flex}.home__row .plan-card{min-height:6.5rem}.home__row .plan-card__meta{margin-top:auto}.saved-plans{padding-top:var(--space-2)}.saved-plans__title{font-size:var(--font-size-xl);font-weight:500;margin-bottom:var(--space-5)}.saved-plans__loading,.saved-plans__error{font-size:var(--font-size-sm);color:var(--color-text-muted)}.saved-plans__error{padding:var(--space-3) var(--space-4);background-color:var(--color-error-bg);border:1px solid var(--color-error-border);border-radius:var(--radius-sm);color:var(--color-error)}.saved-plans__empty{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);padding:var(--space-8) var(--space-4);text-align:center}.saved-plans__empty-text{font-size:var(--font-size-base);font-weight:500;color:var(--color-text)}.saved-plans__empty-hint{font-size:var(--font-size-sm);color:var(--color-text-muted)}.saved-plans__list{list-style:none;display:flex;flex-direction:column;gap:var(--space-3)}.plan-card{width:100%;display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-4);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);text-align:left;transition:border-color .15s,box-shadow .15s}.plan-card:hover{border-color:var(--color-accent);box-shadow:var(--shadow-card)}.plan-card__main{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3)}.plan-card__info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.125rem}.plan-card__coffee{font-size:var(--font-size-base);font-weight:500;color:var(--color-text);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.plan-card__roaster{font-size:var(--font-size-xs);color:var(--color-text-muted);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.plan-card__icons{flex-shrink:0;display:flex;align-items:center;gap:var(--space-2)}.plan-card__origin{font-size:1.25rem;line-height:1}.plan-card__method{flex-shrink:0;width:1.5rem;height:1.5rem;color:var(--color-text-muted)}.plan-card__method svg{width:100%;height:100%}.plan-card__meta{display:flex;align-items:center;justify-content:space-between}.plan-card__date{font-size:var(--font-size-xs);color:var(--color-text-muted)}.plan-card__rating{font-size:var(--font-size-sm);letter-spacing:.05em;color:var(--color-accent)}.bean-rating{display:flex;gap:var(--space-2);align-items:center}.bean-rating--readonly{pointer-events:none;gap:var(--space-1)}.bean-rating--readonly svg{width:13px;height:16px}.bean-rating__bean{display:flex;align-items:center;justify-content:center;background:none;border:none;padding:var(--space-1);cursor:pointer;color:var(--color-border);border-radius:var(--radius-sm);transition:color .15s,background-color .15s}.bean-rating__bean:hover,.bean-rating__bean:focus-visible{color:var(--color-accent);background-color:transparent;outline:2px solid var(--color-accent);outline-offset:1px}.bean-rating__bean--filled{color:var(--color-accent)}.bean-rating--readonly .bean-rating__bean{padding:0;cursor:default}.plan-detail__rating{padding:var(--space-4);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);display:flex;flex-direction:column;gap:var(--space-3)}.plan-detail__rating-label{font-size:var(--font-size-xs);font-weight:500;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted)}.plan-detail__rating-feedback{font-size:var(--font-size-xs);color:var(--color-text-muted);min-height:1em}.plan-detail__title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-3)}.plan-detail__share-btn{flex-shrink:0;background:none;border:none;padding:var(--space-1);color:var(--color-text-muted);cursor:pointer;line-height:0;transition:color .15s ease}.plan-detail__share-btn:hover{color:var(--color-accent)}.plan-detail__share-feedback{font-size:var(--font-size-xs);color:var(--color-text-muted)}.shared-plan{padding:var(--space-4) 0;max-width:480px;margin:0 auto}.shared-plan__header{padding:var(--space-4);margin-bottom:var(--space-4)}.shared-plan__brand{font-size:var(--font-size-xs);font-weight:500;text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-muted);margin-bottom:var(--space-2)}.shared-plan__title{font-size:var(--font-size-xl);font-weight:500;color:var(--color-text);margin-bottom:var(--space-1)}.shared-plan__roaster{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-bottom:var(--space-2)}.shared-plan__method{font-size:var(--font-size-sm);font-weight:500;color:var(--color-accent)}.shared-plan__loading,.shared-plan__error{padding:var(--space-4);text-align:center;color:var(--color-text-muted)}.plan-detail__feedback{margin-top:var(--space-4)}.feedback-form{padding:var(--space-4);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);display:flex;flex-direction:column;gap:var(--space-3)}.feedback-form__label{font-size:var(--font-size-xs);font-weight:500;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted)}.feedback-form__textarea{width:100%;padding:var(--space-3);font-family:inherit;font-size:var(--font-size-sm);color:var(--color-text);background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);resize:vertical;line-height:1.5;box-sizing:border-box}.feedback-form__textarea:focus{outline:none;border-color:var(--color-accent)}.feedback-form__footer{display:flex;align-items:center;gap:var(--space-3)}.feedback-form__submit{padding:var(--space-2) var(--space-4);font-size:var(--font-size-sm);font-weight:500;color:var(--color-bg);background-color:var(--color-accent);border:none;border-radius:var(--radius-sm);cursor:pointer;transition:opacity .15s ease}.feedback-form__submit:disabled{opacity:.6;cursor:not-allowed}.feedback-form__submit:hover:not(:disabled){opacity:.85}.feedback-form__feedback{font-size:var(--font-size-xs);color:var(--color-text-muted)}.placeholder-page{padding:var(--space-4) 0}.placeholder-page h2{font-size:var(--font-size-xl);font-weight:500;margin-bottom:var(--space-2)}.placeholder-page p{color:var(--color-text-muted);font-size:var(--font-size-sm)}.reveal{opacity:0;transform:translateY(12px);transition:opacity .5s ease,transform .5s ease}.reveal--visible{opacity:1;transform:none}@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}.landing{min-height:100dvh;max-width:var(--max-width);margin:0 auto;padding:0 var(--space-5) var(--space-8);display:flex;flex-direction:column}.landing__topbar{display:flex;align-items:center;justify-content:space-between;height:var(--header-height)}.landing__brand{display:flex;align-items:center;gap:var(--space-2)}.landing__brand-logo{color:var(--color-accent)}.landing__wordmark{font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:var(--color-accent);font-size:var(--font-size-sm)}.landing__wordmark--muted{color:var(--color-text-muted)}.landing__signin{font-size:var(--font-size-sm);font-weight:500;color:var(--color-accent);text-decoration:none}.landing__signin:hover{text-decoration:underline}.landing__hero{display:flex;flex-direction:column;align-items:center;text-align:center;padding:var(--space-6) 0 var(--space-8)}.landing__headline{font-size:2.25rem;line-height:1.1;font-weight:600;letter-spacing:-.02em;color:var(--color-text)}.landing__subhead{margin-top:var(--space-4);font-size:var(--font-size-base);line-height:1.5;color:var(--color-text-muted);max-width:34ch}.landing__hero-media{margin:var(--space-8) 0;width:100%;aspect-ratio:5 / 4;display:flex;align-items:center;justify-content:center;background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.landing__hero-illustration{width:70%;height:auto;color:var(--color-accent)}.landing__hero-photo{width:100%;height:100%;object-fit:cover;display:block}.landing__cta-group{display:flex;flex-direction:column;align-items:center;gap:var(--space-3);width:100%}.landing__cta{display:inline-flex;align-items:center;justify-content:center;width:100%;padding:var(--space-4);background-color:var(--color-accent);color:#fff;border:none;border-radius:var(--radius-md);font-size:var(--font-size-base);font-weight:600;letter-spacing:.01em;text-decoration:none;transition:background-color .15s}.landing__cta:hover{background-color:var(--color-accent-hover)}.landing__cta-secondary{font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-muted);text-decoration:none}.landing__cta-secondary:hover{color:var(--color-accent)}.landing__features{display:flex;flex-direction:column;gap:var(--space-8);padding:var(--space-6) 0}.landing__feature{display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--space-3);padding:var(--space-6) var(--space-4)}.landing__feature-icon{display:flex;align-items:center;justify-content:center;width:3rem;height:3rem;border-radius:50%;background-color:var(--color-surface);border:1px solid var(--color-border);color:var(--color-accent)}.landing__feature-icon svg{width:1.5rem;height:1.5rem}.landing__feature-title{font-size:var(--font-size-xl);font-weight:600;color:var(--color-text)}.landing__feature-body{font-size:var(--font-size-base);line-height:1.5;color:var(--color-text-muted);max-width:36ch}.landing__closing{display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--space-4);padding:var(--space-8) var(--space-4);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md)}.landing__closing-title{font-size:var(--font-size-2xl);font-weight:600;color:var(--color-text)}.landing__closing-body{font-size:var(--font-size-base);line-height:1.5;color:var(--color-text-muted);max-width:32ch}.landing__footer{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);padding-top:var(--space-8);margin-top:auto}.landing__footer-meta{font-size:var(--font-size-xs);color:var(--color-text-muted)}.toggle{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);cursor:pointer}.toggle__text{display:flex;flex-direction:column;gap:var(--space-1)}.toggle__label{font-weight:500;color:var(--color-text)}.toggle__description{font-size:var(--font-size-sm);color:var(--color-text-muted);line-height:1.4}.toggle__switch{flex-shrink:0;position:relative;width:3rem;height:1.75rem;border:none;border-radius:999px;background-color:var(--color-border);cursor:pointer;transition:background-color .15s;padding:0}.toggle__switch--on{background-color:var(--color-accent)}.toggle__switch:disabled{opacity:.5;cursor:not-allowed}.toggle__thumb{position:absolute;top:.2rem;left:.2rem;width:1.35rem;height:1.35rem;border-radius:50%;background-color:#fff;transition:transform .15s}.toggle__switch--on .toggle__thumb{transform:translate(1.25rem)}.onboarding{min-height:100dvh;display:flex;flex-direction:column;gap:var(--space-6);padding:var(--space-8) var(--space-6);max-width:var(--max-width);margin:0 auto}.onboarding__section{display:flex;flex-direction:column;gap:var(--space-3)}.onboarding__heading{font-size:var(--font-size-lg);font-weight:600}.onboarding__sub{font-size:var(--font-size-sm);color:var(--color-text-muted);line-height:1.4}.onboarding__actions{display:flex;flex-direction:column;gap:var(--space-3);margin-top:auto}.onboarding__cta{width:100%;padding:var(--space-4);border:none;border-radius:var(--radius-md);background-color:var(--color-accent);color:#fff;font-size:var(--font-size-base);font-weight:600;cursor:pointer}.onboarding__cta:disabled{opacity:.6;cursor:not-allowed}.onboarding__skip{width:100%;padding:var(--space-2);border:none;background:none;color:var(--color-text-muted);font-size:var(--font-size-sm);cursor:pointer}
