:root{--color-primary: #7A1E2D;--color-primary-hover: #621826;--color-primary-light: rgba(122, 30, 45, .08);--color-primary-rgb: 122, 30, 45;--color-accent: #D4A373;--color-accent-hover: #C49363;--color-accent-light: rgba(212, 163, 115, .12);--color-accent-rgb: 212, 163, 115;--color-bg: #FAF8F6;--color-surface: #FFFFFF;--color-surface-hover: #F5F2EF;--color-surface-raised: #FFFFFF;--color-nav: #FFFFFF;--color-nav-border: #E4E0DC;--color-text: #2B2B2B;--color-text-secondary: #5A5A5A;--color-text-muted: #736E69;--color-text-inverse: #FFFFFF;--color-border: #E4E0DC;--color-border-light: #F0ECE8;--color-border-focus: #7A1E2D;--color-input-bg: #FFFFFF;--color-input-border: #E4E0DC;--color-input-focus-bg: #FFFFFF;--color-input-placeholder: #8A8580;--color-btn-primary-bg: #7A1E2D;--color-btn-primary-text: #FFFFFF;--color-btn-primary-hover: #621826;--color-btn-secondary-bg: #F5F2EF;--color-btn-secondary-text: #2B2B2B;--color-btn-secondary-border: #E4E0DC;--color-btn-secondary-hover: #EBE7E3;--color-success: #2D7A45;--color-success-bg: #EBF5EE;--color-success-border: #C8E6D0;--color-danger: #C94040;--color-danger-bg: #FDF0F0;--color-danger-border: #F0C8C8;--color-warning: #B8860B;--color-warning-bg: #FFF8E6;--color-warning-border: #F0E0A0;--color-info: #2E6B9E;--color-info-bg: #EBF3FA;--color-info-border: #C0D8EE;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06);--shadow-md: 0 4px 12px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 30px rgba(0, 0, 0, .12);--shadow-card: 0 1px 3px rgba(0, 0, 0, .04), 0 1px 2px rgba(0, 0, 0, .06);--shadow-card-hover: 0 4px 16px rgba(0, 0, 0, .1);--color-overlay: rgba(0, 0, 0, .4);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-full: 9999px;--font-body: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-heading: "Playfair Display", Georgia, "Times New Roman", serif;--transition-fast: .15s ease;--transition-base: .2s ease;--wine-red: #F5E6E6;--wine-white: #F5F0E0;--wine-rose: #F5E0EA;--wine-sparkling: #E0EAF5;--wine-dessert: #EDE0F5;--wine-fortified: #E0F5E6;--badge-admin-bg: var(--color-primary);--badge-admin-text: #FFFFFF;--badge-somm-bg: rgba(212, 163, 115, .15);--badge-somm-text: #A67C4A;--badge-plan-free-bg: rgba(138, 133, 128, .12);--badge-plan-free-text: #8A8580;--badge-plan-basic-bg: rgba(212, 163, 115, .15);--badge-plan-basic-text: #A67C4A;--badge-plan-premium-bg: rgba(122, 30, 45, .1);--badge-plan-premium-text: var(--color-primary);--drink-overdue-bg: #FDF0F0;--drink-overdue-text: #C94040;--drink-overdue-border: #F0C8C8;--drink-soon-bg: #FFF8E6;--drink-soon-text: #B8860B;--drink-soon-border: #F0E0A0;--drink-inwindow-bg: #EBF5EE;--drink-inwindow-text: #2D7A45;--drink-inwindow-border: #C8E6D0;--drink-notready-bg: #EBF3FA;--drink-notready-text: #2E6B9E;--drink-notready-border: #C0D8EE;--bottom-nav-height: 64px}[data-theme=dark]{--color-primary: #B89263;--color-primary-hover: #CBA474;--color-primary-light: rgba(184, 146, 99, .12);--color-primary-rgb: 184, 146, 99;--color-accent: #B89263;--color-accent-hover: #CBA474;--color-accent-light: rgba(184, 146, 99, .1);--color-accent-rgb: 184, 146, 99;--color-bg: #121212;--color-surface: #1C1C1E;--color-surface-hover: #252527;--color-surface-raised: #242426;--color-nav: #1A1A1C;--color-nav-border: #2A2A2A;--color-text: #F3EDE9;--color-text-secondary: #C9C3BF;--color-text-muted: #8A8580;--color-text-inverse: #121212;--color-border: #2A2A2A;--color-border-light: #222222;--color-border-focus: #B89263;--color-input-bg: #1C1C1E;--color-input-border: #2A2A2A;--color-input-focus-bg: #222224;--color-input-placeholder: #5A5550;--color-btn-primary-bg: #B89263;--color-btn-primary-text: #121212;--color-btn-primary-hover: #CBA474;--color-btn-secondary-bg: #252527;--color-btn-secondary-text: #C9C3BF;--color-btn-secondary-border: #3A3A3A;--color-btn-secondary-hover: #333335;--color-success: #6B9E78;--color-success-bg: #142d1c;--color-success-border: #1e4a2a;--color-danger: #E07060;--color-danger-bg: #2d1414;--color-danger-border: #5a2020;--color-warning: #e0a060;--color-warning-bg: #2d1e10;--color-warning-border: #5a3a10;--color-info: #7aade0;--color-info-bg: #14202d;--color-info-border: #1e3a5a;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .2);--shadow-md: 0 4px 12px rgba(0, 0, 0, .3);--shadow-lg: 0 8px 30px rgba(0, 0, 0, .4);--shadow-card: 0 1px 3px rgba(0, 0, 0, .2);--shadow-card-hover: 0 4px 16px rgba(0, 0, 0, .35);--color-overlay: rgba(0, 0, 0, .65);--wine-red: #2d1414;--wine-white: #2d2510;--wine-rose: #2d1420;--wine-sparkling: #14202d;--wine-dessert: #1f1430;--wine-fortified: #142d18;--badge-admin-bg: #5A1521;--badge-admin-text: #F3EDE9;--badge-somm-bg: rgba(184, 146, 99, .2);--badge-somm-text: #B89263;--badge-plan-free-bg: rgba(154, 148, 132, .2);--badge-plan-free-text: #9A9484;--badge-plan-basic-bg: rgba(184, 146, 99, .2);--badge-plan-basic-text: #B89263;--badge-plan-premium-bg: rgba(184, 146, 99, .15);--badge-plan-premium-text: #B89263;--drink-overdue-bg: #2d1414;--drink-overdue-text: #E07060;--drink-overdue-border: #5a2020;--drink-soon-bg: #2d1e10;--drink-soon-text: #e0a060;--drink-soon-border: #5a3a10;--drink-inwindow-bg: #142d1c;--drink-inwindow-text: #6B9E78;--drink-inwindow-border: #1e4a2a;--drink-notready-bg: #14202d;--drink-notready-text: #7aade0;--drink-notready-border: #1e3a5a}*{box-sizing:border-box}body{margin:0;font-family:var(--font-body);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--color-bg);color:var(--color-text);touch-action:manipulation;overflow-x:hidden;transition:background-color var(--transition-base),color var(--transition-base);line-height:1.5}h1,h2,h3{font-family:var(--font-heading);color:var(--color-text);line-height:1.25}h1{font-size:1.75rem;font-weight:600;margin:0 0 1rem}h2{font-size:1.35rem;font-weight:600;margin:0 0 1rem}h3{font-size:1.1rem;font-weight:600;margin:0 0 .5rem}p{margin:0 0 .75rem;line-height:1.6}input,select,textarea{font-family:var(--font-body);font-size:16px;box-sizing:border-box}a{color:var(--color-primary);transition:color var(--transition-fast)}a:hover{color:var(--color-primary-hover)}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;gap:1rem}.page-header h1{margin:0}.back-link{color:var(--color-primary);text-decoration:none;display:inline-flex;align-items:center;gap:.35rem;margin-bottom:.75rem;font-size:.9rem;font-weight:500;padding:.25rem 0;transition:color var(--transition-fast)}.back-link:hover{color:var(--color-primary-hover);text-decoration:none}.empty-state{text-align:center;padding:3rem 1.5rem;background:var(--color-surface);border-radius:var(--radius-md);border:2px dashed var(--color-border);color:var(--color-text-muted)}.empty-state p{margin-bottom:1rem}.producer{color:var(--color-text-secondary);margin:0;font-size:.9rem}.filters-bar{display:flex;gap:.75rem;margin:1.25rem 0;flex-wrap:wrap}.filters-bar input,.filters-bar select{padding:.75rem;border:1px solid var(--color-input-border);border-radius:var(--radius-sm);font-size:16px;background:var(--color-input-bg);color:var(--color-text);min-height:44px;transition:border-color var(--transition-fast)}.filters-bar input:focus,.filters-bar select:focus{outline:none;border-color:var(--color-border-focus)}.filters-bar input{flex:1;min-width:0}.search-input{flex:2;min-width:0;padding:.75rem;border:1px solid var(--color-input-border);border-radius:var(--radius-sm);font-size:16px;min-height:44px;background:var(--color-input-bg);color:var(--color-text);transition:border-color var(--transition-fast)}.search-input:focus{outline:none;border-color:var(--color-border-focus)}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}@media(max-width:768px){h1{font-size:1.4rem}.page-header{flex-direction:column;align-items:flex-start;gap:.75rem;margin-bottom:1.25rem}.page-header .header-actions{display:flex;flex-wrap:wrap;gap:.5rem;width:100%}.page-header .header-actions .btn{flex:1;min-width:100px;text-align:center;white-space:nowrap}.page-header .header-actions .btn-more{flex:none;min-width:unset}.grid-2{grid-template-columns:1fr}.filters-bar{flex-direction:column}}.notif-bell{position:relative;flex-shrink:0}.notif-trigger{background:transparent;border:none;cursor:pointer;padding:.45rem;border-radius:var(--radius-sm);color:var(--color-text-secondary);display:flex;align-items:center;justify-content:center;position:relative;transition:background .2s,color .2s;min-height:38px;min-width:38px}.notif-trigger:hover{background:var(--color-primary-light);color:var(--color-text)}.notif-icon{width:20px;height:20px}.notif-badge{position:absolute;top:2px;right:2px;background:var(--color-danger);color:#fff;font-size:.65rem;font-weight:700;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 3px;line-height:1;pointer-events:none}.notif-dropdown{position:absolute;top:calc(100% + 6px);right:0;width:320px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:300;overflow:hidden}.notif-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-bottom:1px solid var(--color-border);font-size:.875rem;font-weight:600;color:var(--color-text)}.notif-mark-all{background:transparent;border:none;cursor:pointer;color:var(--color-primary);font-size:.8rem;padding:.2rem .4rem;border-radius:3px;transition:background .15s}.notif-mark-all:hover{background:var(--color-primary-light)}.notif-list{max-height:360px;overflow-y:auto}.notif-empty{padding:1.5rem 1rem;text-align:center;color:var(--color-text-muted);font-size:.875rem}.notif-item{display:flex;align-items:flex-start;gap:.5rem;padding:.75rem 1rem;border-bottom:1px solid var(--color-border);transition:background .15s}.notif-item:last-child{border-bottom:none}.notif-item.unread{background:var(--color-primary-light)}.notif-item.clickable{cursor:pointer}.notif-item.clickable:hover{background:var(--color-surface-hover)}.notif-item.unread.clickable:hover{background:var(--color-primary-light)}.notif-dot{width:7px;height:7px;min-width:7px;border-radius:50%;background:var(--color-primary);margin-top:5px}.notif-body{flex:1;min-width:0}.notif-title{font-size:.875rem;font-weight:600;color:var(--color-text);margin-bottom:.2rem}.notif-item:not(.unread) .notif-title{font-weight:500;color:var(--color-text-secondary)}.notif-msg{font-size:.825rem;color:var(--color-text-muted);line-height:1.4;word-break:break-word}.notif-time{font-size:.75rem;color:var(--color-text-muted);margin-top:.3rem}@media(max-width:768px){.notif-dropdown{position:fixed;top:auto;right:.5rem;left:.5rem;width:auto}}.support-modal-form{display:flex;flex-direction:column;gap:14px}.support-modal-form label{display:flex;flex-direction:column;gap:4px;font-size:.875rem;font-weight:500;color:var(--color-text-secondary)}.support-modal-form input,.support-modal-form select,.support-modal-form textarea{padding:8px 10px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.9rem;font-family:inherit;background:var(--color-input-bg);color:var(--color-text);resize:vertical}.support-modal-form textarea{min-height:120px}.char-count{font-size:.75rem;color:var(--color-text-muted);text-align:right}.support-modal-error{color:var(--color-danger);font-size:.875rem;margin:0}.support-modal-success{padding:8px 0 16px;line-height:1.6;color:var(--color-text)}.support-modal-success p{margin:0 0 8px}.layout{min-height:100vh;display:flex;flex-direction:column}.navbar{background:var(--color-nav);border-bottom:1px solid var(--color-nav-border);position:sticky;top:0;z-index:200;padding-top:env(safe-area-inset-top)}.navbar-inner{display:flex;align-items:center;padding:.5rem 1.25rem;max-width:1440px;margin:0 auto;width:100%;gap:.5rem}.navbar-brand{flex-shrink:0}.brand-link{display:flex;align-items:center;gap:.6rem;text-decoration:none;color:var(--color-text)}.brand-logo-img{height:64px;width:auto;display:block}.navbar-links{display:flex;align-items:center;gap:.15rem;flex:1;margin-left:1rem;flex-wrap:wrap}.nav-link{color:var(--color-text-secondary);text-decoration:none;padding:.45rem .75rem;border-radius:var(--radius-sm);transition:background var(--transition-fast),color var(--transition-fast);font-size:.9rem;font-weight:500;white-space:nowrap}.nav-link:hover{background:var(--color-primary-light);color:var(--color-text)}.nav-link.active{background:var(--color-primary-light);color:var(--color-primary);font-weight:600}.nav-link--admin{opacity:.7;font-size:.82rem!important}.nav-link--somm{font-size:.87rem!important;color:var(--color-accent)!important}.nav-link--somm:hover{background:var(--color-accent-light)!important}.nav-link--somm.active{background:var(--color-accent-light)!important;color:var(--color-accent)!important}.nav-premium-star{font-size:.6rem;color:var(--color-accent);margin-left:.25rem;vertical-align:super;font-weight:700}.navbar-divider{width:1px;height:1.4rem;background:var(--color-border);margin:0 .35rem;flex-shrink:0}.navbar-right{display:flex;align-items:center;gap:.5rem;margin-left:auto;flex-shrink:0}.user-info{color:var(--color-text-secondary);font-size:.875rem;white-space:nowrap}.badge{padding:.15rem .5rem;border-radius:var(--radius-full);font-size:.68rem;font-weight:700;margin-left:.35rem;vertical-align:middle;display:inline-block}.badge--admin{background:var(--badge-admin-bg);color:var(--badge-admin-text)}.badge--somm{background:var(--badge-somm-bg);color:var(--badge-somm-text)}.badge--mod{background:#d1fae5;color:#065f46}.badge--plan{font-weight:600}.badge--plan-free{background:var(--badge-plan-free-bg);color:var(--badge-plan-free-text)}.badge--plan-supporter{background:var(--badge-plan-basic-bg);color:var(--badge-plan-basic-text)}.badge--plan-patron{background:var(--badge-plan-premium-bg);color:var(--badge-plan-premium-text)}.btn-icon-nav{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-sm);color:var(--color-text-secondary);background:transparent;border:none;cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast);text-decoration:none}.btn-icon-nav:hover,.btn-icon-nav.active{background:var(--color-primary-light);color:var(--color-primary)}.theme-toggle{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-sm);color:var(--color-text-secondary);background:transparent;border:none;cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.theme-toggle:hover{background:var(--color-primary-light);color:var(--color-primary)}.btn-logout{background:transparent;color:var(--color-danger);border:1px solid var(--color-danger);padding:.35rem .75rem;border-radius:var(--radius-sm);cursor:pointer;font-size:.82rem;font-weight:500;font-family:var(--font-body);transition:background var(--transition-fast),color var(--transition-fast);white-space:nowrap;min-height:34px}.btn-logout:hover{background:var(--color-danger);color:#fff}.main-content{flex:1;padding:1.5rem 2rem;max-width:1400px;width:100%;margin:0 auto;padding-bottom:calc(1.5rem + env(safe-area-inset-bottom));padding-left:calc(2rem + env(safe-area-inset-left));padding-right:calc(2rem + env(safe-area-inset-right));overflow-x:hidden;box-sizing:border-box}.hamburger{display:none;background:none;border:none;cursor:pointer;padding:.5rem;border-radius:var(--radius-sm);transition:background var(--transition-fast);min-height:44px;min-width:44px;align-items:center;justify-content:center;margin-left:auto}.hamburger:hover{background:var(--color-primary-light)}.hamburger-icon{display:flex;flex-direction:column;gap:5px;width:20px}.hamburger-icon span{display:block;height:2px;background:var(--color-text-secondary);border-radius:2px;transition:transform .25s,opacity .25s;transform-origin:center}.hamburger-icon.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}.hamburger-icon.open span:nth-child(2){opacity:0;transform:scaleX(0)}.hamburger-icon.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.mobile-menu{background:var(--color-surface);border-top:1px solid var(--color-border);max-height:calc(100vh - 60px);overflow-y:auto;padding-bottom:calc(var(--bottom-nav-height) + env(safe-area-inset-bottom))}.mobile-menu-section{padding:.5rem 0;border-bottom:1px solid var(--color-border-light)}.mobile-menu-label{padding:.4rem 1.25rem;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted)}.mobile-menu-link{display:block;padding:.75rem 1.25rem;color:var(--color-text-secondary);text-decoration:none;font-size:.95rem;font-weight:500;transition:background var(--transition-fast)}.mobile-menu-link:hover{background:var(--color-primary-light)}.mobile-menu-link.active{color:var(--color-primary);background:var(--color-primary-light);font-weight:600}.mobile-menu-footer{padding:.75rem 1.25rem}.mobile-menu-user{margin-bottom:.75rem}.mobile-menu-actions{display:flex;align-items:center;gap:.75rem}.mobile-menu-actions .btn-logout{flex:1;background:var(--color-danger);color:#fff;border:none;font-size:.95rem;font-weight:600;padding:.6rem 1rem;min-height:44px}.mobile-notif-bell,.bottom-nav{display:none}@media(max-width:768px){.navbar-links,.navbar-right,.hamburger{display:none}.mobile-notif-bell{display:flex;margin-left:auto}.navbar-inner{padding:.5rem 1rem}.brand-logo-img{height:56px}.main-content{padding:1rem;padding-bottom:calc(var(--bottom-nav-height) + 1rem + env(safe-area-inset-bottom));padding-left:calc(1rem + env(safe-area-inset-left));padding-right:calc(1rem + env(safe-area-inset-right))}.bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;height:var(--bottom-nav-height);background:var(--color-nav);border-top:1px solid var(--color-nav-border);z-index:200;padding-bottom:env(safe-area-inset-bottom);box-shadow:0 -2px 10px #0000000f}[data-theme=dark] .bottom-nav{box-shadow:0 -2px 10px #0000004d}.bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.2rem;color:var(--color-text-muted);text-decoration:none;font-size:.68rem;font-weight:500;background:none;border:none;cursor:pointer;padding:.4rem 0;transition:color var(--transition-fast);font-family:var(--font-body);-webkit-tap-highlight-color:transparent}.bottom-nav-item:hover{color:var(--color-text-secondary)}.bottom-nav-item.active{color:var(--color-primary)}.bottom-nav-item svg{flex-shrink:0}}.install-prompt{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:.6rem 1.25rem;background:var(--color-primary);color:#fff;font-size:.9rem;font-weight:500}.install-prompt-text{flex:0 1 auto}.install-prompt-actions{display:flex;align-items:center;gap:.5rem}.install-prompt .btn-sm{padding:.35rem .9rem;min-height:auto;font-size:.85rem;background:#fff;color:var(--color-primary);border:none;border-radius:var(--radius-sm);font-weight:600;cursor:pointer}.install-prompt .btn-sm:hover{opacity:.9}.install-prompt-dismiss{background:none;border:none;color:#fffc;font-size:1.3rem;cursor:pointer;padding:0 .25rem;line-height:1}.install-prompt-dismiss:hover{color:#fff}.btn{padding:.7rem 1.4rem;border:none;border-radius:var(--radius-sm);font-size:.95rem;font-family:var(--font-body);cursor:pointer;transition:all var(--transition-base);font-weight:600;min-height:44px;display:inline-flex;align-items:center;justify-content:center;text-decoration:none;line-height:1.2;gap:.4rem;letter-spacing:.01em}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-btn-primary-bg);color:var(--color-btn-primary-text)}.btn-primary:hover:not(:disabled){background:var(--color-btn-primary-hover);box-shadow:var(--shadow-md)}.btn-secondary{background:var(--color-btn-secondary-bg);color:var(--color-btn-secondary-text);border:1px solid var(--color-btn-secondary-border)}.btn-secondary:hover:not(:disabled){background:var(--color-btn-secondary-hover);border-color:var(--color-border)}.btn-success{background:var(--color-success);color:#fff;font-weight:600}.btn-success:hover:not(:disabled){opacity:.9;box-shadow:var(--shadow-md)}.btn-danger{background:transparent;color:var(--color-danger);border:1px solid var(--color-danger)}.btn-danger:hover:not(:disabled){background:var(--color-danger);color:#fff}.btn-danger:disabled{opacity:.4;cursor:not-allowed}.btn-warning{background:transparent;color:var(--color-warning, #e67e22);border:1px solid var(--color-warning, #e67e22)}.btn-warning:hover:not(:disabled){background:var(--color-warning, #e67e22);color:#fff}.btn-warning:disabled{opacity:.4;cursor:not-allowed}.btn-small{padding:.4rem .9rem;font-size:.875rem;min-height:36px}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:1.5rem;box-shadow:var(--shadow-card);transition:box-shadow var(--transition-base),border-color var(--transition-base)}.form-group{margin-bottom:1.25rem}.form-group label{display:block;margin-bottom:.4rem;font-weight:500;color:var(--color-text-secondary);font-size:.9rem}.form-group input:not([type=checkbox]),.form-group textarea,.form-group select{width:100%;padding:.7rem .85rem;border:1px solid var(--color-input-border);border-radius:var(--radius-sm);font-size:16px;font-family:var(--font-body);min-height:44px;background:var(--color-input-bg);color:var(--color-text);transition:border-color var(--transition-fast),background var(--transition-fast)}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--color-input-placeholder)}.form-group select option{background:var(--color-surface);color:var(--color-text)}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--color-border-focus);background:var(--color-input-focus-bg);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.1)}.form-actions{display:flex;gap:1rem;margin-top:1.5rem}.alert{padding:.85rem 1rem;border-radius:var(--radius-sm);margin-bottom:1rem;font-size:.9rem;line-height:1.5}.alert-error{background:var(--color-danger-bg);color:var(--color-danger);border:1px solid var(--color-danger-border)}.alert-success{background:var(--color-success-bg);color:var(--color-success);border:1px solid var(--color-success-border)}.alert-info{background:var(--color-info-bg);color:var(--color-info);border:1px solid var(--color-info-border)}.back-link{color:var(--color-primary);text-decoration:none;display:inline-flex;align-items:center;gap:.3rem;font-weight:500;font-size:.88rem;min-height:44px;transition:color var(--transition-fast)}.back-link:hover{color:var(--color-primary-hover)}.page-subtitle{color:var(--color-text-muted);margin:.25rem 0 0;font-size:.88rem}.empty-state{text-align:center;padding:3rem;background:var(--color-surface);border-radius:var(--radius-md);color:var(--color-text-muted)}.loading{text-align:center;padding:3rem;color:var(--color-text-muted)}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--color-overlay);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.modal-box{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.75rem;width:100%;max-width:440px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg)}.modal-box--wide{max-width:600px}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.modal-header h2{margin:0}.modal-close-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--color-text-muted);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast);flex-shrink:0}.modal-close-btn:hover{background:var(--color-surface-hover);color:var(--color-text)}.modal-box h2,.modal-box h3{color:var(--color-text)}@media(max-width:768px){.grid-2,.grid-3{grid-template-columns:1fr}.form-actions{flex-direction:column}.form-actions .btn{width:100%}.card{padding:1rem}.modal-box{padding:1.25rem;margin:0;border-radius:var(--radius-md)}}.cellar-accent-border{border-left:4px solid var(--cellar-color, transparent);padding-left:.75rem}.text-muted-sm{font-size:.9rem;color:var(--color-text-muted);margin-bottom:1.25rem}.grape-count{font-weight:400;font-size:.82rem;color:var(--color-primary);margin-left:.25rem}.skip-link{position:absolute;top:0;left:50%;transform:translate(-50%,-100%);padding:.6rem 1rem;background:var(--color-primary);color:var(--color-text-inverse);text-decoration:none;font-weight:600;border-radius:0 0 var(--radius-sm, 6px) var(--radius-sm, 6px);box-shadow:var(--shadow-md, 0 4px 12px rgba(0, 0, 0, .08));z-index:1000;transition:transform .18s}.skip-link:focus{transform:translate(-50%);outline:2px solid var(--color-accent);outline-offset:2px}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;border-radius:inherit}#main-content:focus,#main-content:focus-visible{outline:none}
