:root{--color-primary: #8B7D6B;--color-primary-dark: #6d6254;--color-black: #2a2a2a;--color-white: #ffffff;--color-background: #ebe4db;--color-text: #2a2a2a;--color-text-light: #5a5550;--color-text-lighter: #8a8580;--color-border: #d4cdc4;--color-shadow: rgba(42, 42, 42, .06);--z-base: 0;--z-sticky: 100;--z-navigation: 1000;--z-drawer: 5000;--z-modal: 8000;--z-toast: 9000;--z-mobile-menu: 10000;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--spacing-3xl: 4rem;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--radius-xl: 12px;--radius-2xl: 16px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px rgba(0, 0, 0, .15);--shadow-bottom: 0 -4px 24px rgba(0, 0, 0, .15);--font-family-base: "Sawarabi Mincho", serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-md: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 2rem;--font-size-4xl: 2.5rem;--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--breakpoint-mobile: 768px;--breakpoint-tablet: 1024px;--breakpoint-desktop: 1280px}.sticky-bottom-bar{position:fixed;bottom:0;left:0;right:0;background:var(--color-text);box-shadow:var(--shadow-bottom);z-index:var(--z-sticky);animation:slideUp var(--transition-slow)}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal-overlay{position:fixed;inset:0;background:#00000080;z-index:var(--z-modal);display:flex;align-items:center;justify-content:center;padding:var(--spacing-lg)}.modal-content{background:var(--color-white);border-radius:var(--radius-xl);max-width:600px;width:90%;max-height:90vh;overflow:auto;box-shadow:var(--shadow-xl)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-lg);border-bottom:1px solid var(--color-border)}.modal-body{padding:var(--spacing-lg)}.modal-footer{display:flex;gap:var(--spacing-md);justify-content:flex-end;padding:var(--spacing-lg);border-top:1px solid var(--color-border)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);border:none;border-radius:var(--radius-lg);font-family:var(--font-family-base);font-size:var(--font-size-md);font-weight:600;cursor:pointer;transition:all var(--transition-base)}.btn-primary{background:var(--color-primary);color:var(--color-white)}.btn-primary:hover{background:var(--color-primary-dark)}.btn-secondary{background:var(--color-background);color:var(--color-text);border:2px solid var(--color-border)}.btn-secondary:hover{background:var(--color-white);border-color:var(--color-primary)}.card{background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-sm)}.loading{display:flex;align-items:center;justify-content:center;padding:var(--spacing-2xl);color:var(--color-text-light);font-size:var(--font-size-lg)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-3xl) var(--spacing-lg);text-align:center;color:var(--color-text-light)}.empty-state h2{margin:var(--spacing-md) 0;color:var(--color-text)}.empty-state p{margin-bottom:var(--spacing-lg);color:var(--color-text-lighter)}*{margin:0;padding:0;box-sizing:border-box}html,body{overflow-x:hidden;max-width:100vw}body{font-family:Sawarabi Mincho,serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--color-background);color:var(--color-text);line-height:1.8;font-size:16px}.breadcrumb-nav{display:flex;align-items:center;gap:.5rem;padding:1rem 0;font-size:.9rem;color:var(--color-text-lighter)}.breadcrumb-link{background:none;border:none;color:var(--color-primary);cursor:pointer;font-family:Sawarabi Mincho,serif;font-size:.9rem;padding:0;text-decoration:none;transition:color .2s}.breadcrumb-link:hover{color:var(--color-primary-dark);text-decoration:underline}.breadcrumb-separator{color:var(--color-text-lighter)}.breadcrumb-current{color:var(--color-text);font-weight:500}#root{min-height:100vh}button{font-family:inherit;cursor:pointer;border:none;outline:none;transition:all .2s ease}input,textarea{font-family:inherit}a{color:var(--color-primary);text-decoration:none;transition:color .2s ease}a:hover{color:var(--color-primary-dark)}.icon{display:inline-flex;align-items:center;justify-content:center;vertical-align:middle}.icon-svg,.icon-png{object-fit:contain;flex-shrink:0}.icon-emoji{line-height:1;flex-shrink:0}.toast-notification{position:fixed;top:80px;left:50%;transform:translate(-50%);z-index:10000;animation:slideDown .3s ease-out,fadeOut .3s ease-in 2.7s}.toast-content{background:#2d5016;color:#fff;padding:16px 24px;border-radius:8px;box-shadow:0 4px 12px #00000026;display:flex;align-items:center;gap:12px;font-size:15px;font-weight:500}.toast-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:#fff3;border-radius:50%;font-size:14px}.toast-message{white-space:nowrap}@keyframes slideDown{0%{opacity:0;transform:translate(-50%) translateY(-20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@media(max-width:768px){.toast-notification{top:60px;left:16px;right:16px;transform:none}.toast-content{padding:12px 16px;font-size:14px}}.home-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--color-background);padding:2rem;position:relative;overflow:hidden}.home-container:before{content:"";position:absolute;inset:0;background-image:url(/hero-bg.jpg);background-size:cover;background-position:center;filter:blur(8px);transform:scale(1.1);z-index:0}.home-container:after{content:"";position:absolute;inset:0;background:#ebe4dbb3;z-index:1}.home-content{max-width:480px;width:100%;position:relative;z-index:2}.home-branding{text-align:center;margin-bottom:4rem}.home-branding .logo{width:100%;max-width:280px;height:auto;margin:0 auto;display:block}.access-form-card{background:var(--color-white);border:1px solid var(--color-border);padding:3rem 2.5rem;margin-bottom:2rem}.access-form-card h2{font-size:1.5rem;margin-bottom:.75rem;color:var(--color-text);text-align:center;font-weight:400;letter-spacing:.02em}.form-description{text-align:center;color:var(--color-text-light);margin-bottom:2.5rem;font-size:.9rem;line-height:1.6}.access-form{display:flex;flex-direction:column;gap:1.25rem}.code-input{width:100%;padding:1rem;border:1px solid var(--color-border);background:var(--color-white);color:var(--color-text);font-size:1.2rem;text-align:center;font-family:Courier New,monospace;font-weight:500;letter-spacing:.2em;transition:all .2s}.code-input:focus{outline:none;border-color:var(--color-primary);background:var(--color-background)}.code-input:disabled{opacity:.5;cursor:not-allowed}.submit-button{width:100%;background:var(--color-text);color:var(--color-white);border:none;padding:1rem;font-size:.95rem;font-weight:400;cursor:pointer;transition:all .3s;letter-spacing:.1em;text-transform:uppercase;font-family:Sawarabi Mincho,serif}.submit-button:hover:not(:disabled){background:var(--color-primary-dark);transform:translateY(-1px)}.submit-button:disabled{opacity:.5;cursor:not-allowed}.error-message{background:#f8f0f0;color:#8b4040;padding:.875rem;border:1px solid #e8d8d8;text-align:center;font-size:.9rem}.help-text{margin-top:2.5rem;text-align:center;padding-top:2rem;border-top:1px solid var(--color-border)}.help-text p{color:var(--color-text-lighter);font-size:.85rem;margin:.5rem 0;line-height:1.6}.help-text p:first-child{font-weight:400;color:var(--color-text-light)}.admin-link{text-align:center;margin-top:2rem}.admin-button{background:transparent;color:var(--color-text-light);border:1px solid var(--color-border);padding:.75rem 1.5rem;cursor:pointer;font-size:.85rem;font-weight:400;transition:all .2s;font-family:Sawarabi Mincho,serif;letter-spacing:.05em}.admin-button:hover{background:var(--color-white);border-color:var(--color-text);color:var(--color-text)}@media(max-width:768px){.home-branding .logo{max-width:220px}.tagline{font-size:.85rem}.access-form-card{padding:2rem 1.5rem}.code-input{font-size:1.1rem}}.cart-icon-wrapper{position:relative;display:flex;align-items:center}.cart-icon-button{position:relative;background:transparent;border:none;color:var(--color-text-light);cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;transition:all .2s;border-radius:6px}.cart-icon-button:hover{background:var(--color-background);color:var(--color-text)}.cart-badge{position:absolute;top:2px;right:2px;background:var(--color-primary);color:#fff;font-size:.7rem;font-weight:600;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 4px;box-shadow:0 2px 4px #0003}.cart-dropdown{position:absolute;top:calc(100% + .5rem);right:0;background:var(--color-white);border:1px solid var(--color-border);border-radius:12px;box-shadow:0 8px 32px #00000026;min-width:350px;max-width:400px;z-index:1000;animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.cart-dropdown-header{padding:1rem 1.25rem;border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;align-items:center}.cart-dropdown-header h3{font-size:1.1rem;font-weight:500;color:var(--color-text);margin:0}.cart-item-count{font-size:.9rem;color:var(--color-text-light)}.cart-items-list{max-height:400px;overflow-y:auto;padding:.5rem 0}.cart-item{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem 1.25rem;border-bottom:1px solid var(--color-background);transition:background .2s}.cart-item:hover{background:var(--color-background)}.cart-item:last-child{border-bottom:none}.cart-item-info{flex:1;min-width:0}.cart-item-name{font-size:.95rem;font-weight:500;color:var(--color-text);margin-bottom:.25rem}.cart-item-details{font-size:.85rem;color:var(--color-text-light);margin-bottom:.25rem}.cart-item-quantity{font-size:.85rem;color:var(--color-text-light)}.cart-item-remove{background:transparent;border:none;color:var(--color-text-light);cursor:pointer;padding:.25rem;font-size:1rem;line-height:1;transition:all .2s;border-radius:4px}.cart-item-remove:hover{background:#fee;color:#c00}.cart-dropdown-footer{padding:1rem 1.25rem;border-top:1px solid var(--color-border)}.cart-total{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;font-size:1.1rem;font-weight:500;color:var(--color-text)}.cart-total-price{color:var(--color-primary);font-weight:600;font-size:1.25rem}.cart-checkout-btn{width:100%;background:var(--color-text);color:var(--color-white);border:none;padding:.875rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;font-family:Sawarabi Mincho,serif}.cart-checkout-btn:hover{background:var(--color-primary);transform:translateY(-2px);box-shadow:0 4px 12px #0003}.cart-empty{padding:2rem 1.25rem;text-align:center}.cart-empty p{color:var(--color-text-light);margin:0;font-size:.95rem}@media(max-width:768px){.cart-dropdown{min-width:300px;max-width:calc(100vw - 2rem);right:-1rem}}.favorites-filter{position:relative;width:100%;max-width:300px}.filter-toggle{width:100%;display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;background:#fff;border:1px solid #e5e7eb;border-radius:8px;cursor:pointer;transition:all .2s;font-family:Sawarabi Mincho,serif;font-size:.95rem}.filter-toggle:hover{border-color:var(--color-primary);box-shadow:0 2px 8px #0000000d}.filter-icon{font-size:1.1rem}.filter-label{flex:1;text-align:left;color:var(--color-text)}.expand-icon{font-size:.75rem;color:var(--color-text-light);transition:transform .2s}.expand-icon.expanded{transform:rotate(180deg)}.filter-dropdown{position:absolute;top:calc(100% + .5rem);left:0;right:0;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 4px 12px #0000001a;z-index:1001;max-height:350px;overflow-y:auto}.filter-section{padding:.5rem;border-bottom:1px solid #f3f4f6}.filter-section:last-child{border-bottom:none}.filter-dropdown .section-title{padding:.15rem .75rem;font-size:.65rem;font-weight:400;color:var(--color-text-light);text-transform:none;letter-spacing:0;opacity:.7;margin:0;text-align:left}.filter-dropdown .section-title:after{display:none}.filter-option{width:100%;display:flex;align-items:center;gap:.75rem;padding:.75rem;background:transparent;border:none;border-radius:6px;cursor:pointer;transition:all .2s;font-family:Sawarabi Mincho,serif;font-size:.95rem;text-align:left}.filter-option:hover{background:#f9fafb}.filter-option.active{background:#f0f9ff;color:var(--color-primary)}.option-icon{font-size:1.1rem;min-width:1.5rem}.option-label{flex:1;color:var(--color-text)}.filter-option.active .option-label{font-weight:500;color:var(--color-primary)}.option-count{font-size:.85rem;color:var(--color-text-light);margin-left:auto}.profile-option{position:relative}.profile-checkbox{font-size:1.2rem;color:var(--color-primary)}.profile-color{width:12px;height:12px;border-radius:50%;flex-shrink:0}.profile-emoji{margin-right:.25rem}@media(max-width:768px){.favorites-filter{max-width:none}.filter-dropdown{max-height:300px}}.favorites-drawer-overlay{position:fixed;inset:0;background:#0006;z-index:999;animation:fadeIn .3s}.favorites-drawer{position:fixed;top:0;right:0;bottom:0;width:600px;max-width:90vw;background:var(--color-white);box-shadow:-4px 0 24px #00000026;z-index:1000;display:flex;flex-direction:column;animation:slideInRight .3s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}.favorites-drawer-header{padding:1.5rem 2rem;border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between;background:var(--color-white)}.favorites-drawer-header h2{font-size:1.5rem;font-weight:400;color:var(--color-text);margin:0}.drawer-close-btn{background:transparent;border:none;font-size:1.5rem;color:var(--color-text-light);cursor:pointer;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s}.drawer-close-btn:hover{background:var(--color-background);color:var(--color-text)}.favorites-tabs{display:flex;flex-wrap:wrap;border-bottom:2px solid var(--color-border);background:var(--color-white);gap:.5rem;padding:.5rem 1.5rem}.tab-button{background:transparent;border:none;border-bottom:3px solid transparent;padding:1rem 1.25rem;cursor:pointer;display:flex;align-items:center;gap:.5rem;white-space:nowrap;transition:all .2s;font-family:Sawarabi Mincho,serif;color:var(--color-text-light)}.tab-button:hover{background:var(--color-background);color:var(--color-text)}.tab-button.active{color:var(--color-text);border-bottom-color:var(--color-text);font-weight:500}.tab-icon{font-size:1.25rem;line-height:1}.tab-label{font-size:.95rem}.tab-count{background:var(--color-background);color:var(--color-text);padding:.2rem .5rem;border-radius:10px;font-size:.8rem;font-weight:600;min-width:24px;text-align:center}.tab-button.active .tab-count{background:var(--color-text);color:var(--color-white)}.favorites-drawer-content{flex:1;overflow-y:auto;padding:1.5rem}.current-tab-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--color-border)}.current-icon{font-size:1.75rem;line-height:1}.current-tab-header h3{flex:1;font-size:1.25rem;font-weight:400;color:var(--color-text);margin:0}.current-count{color:var(--color-text-light);font-size:.9rem}.favorites-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem}.favorite-thumbnail{aspect-ratio:1;border-radius:8px;overflow:hidden;cursor:pointer;transition:all .2s;background:var(--color-white);border:1px solid var(--color-border)}.favorite-thumbnail:hover{transform:scale(1.05);box-shadow:0 4px 12px #00000026;z-index:1}.favorite-thumbnail img{width:100%;height:100%;object-fit:cover;display:block}.more-indicator{aspect-ratio:1;border-radius:8px;background:var(--color-text);color:var(--color-white);display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:600;border:1px solid var(--color-border)}.empty-drawer-state{text-align:center;padding:4rem 2rem;color:var(--color-text-light)}.empty-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.empty-drawer-state p{margin:.5rem 0;font-size:1rem}.empty-hint{font-size:.9rem;opacity:.7}.favorites-drawer-footer{padding:1.5rem 2rem;border-top:1px solid var(--color-border);background:var(--color-white)}.full-page-button{width:100%;background:var(--color-text);color:var(--color-white);border:none;padding:1rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s;font-family:Sawarabi Mincho,serif;display:flex;align-items:center;justify-content:center;gap:.5rem}.full-page-button:hover{background:var(--color-primary-dark);transform:translateY(-1px);box-shadow:0 4px 12px #00000026}@media(max-width:768px){.favorites-drawer-overlay,.favorites-drawer{display:none!important}}.favorites-filter-container{padding:1rem 2rem;border-bottom:1px solid var(--color-border);background:#f9fafb}.favorites-filter-container .favorites-filter{max-width:none}.slideshow-container{position:fixed;inset:0;background:#fff;z-index:10000;display:flex;align-items:center;justify-content:center}.slideshow-images{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}.slideshow-image{position:absolute;max-width:calc(100vw - 100px);max-height:calc(100vh - 100px);width:auto;height:auto;object-fit:contain;opacity:0;pointer-events:none}.slideshow-image.active{opacity:1;z-index:2}.slideshow-image.previous{z-index:1}.slideshow-close{position:absolute;top:1.5rem;right:1.5rem;background:#0009;color:#fff;border:none;border-radius:50%;width:36px;height:36px;font-size:1.2rem;cursor:pointer;z-index:100;display:flex;align-items:center;justify-content:center;transition:background .3s,transform .2s;opacity:.7}.slideshow-close:hover{background:#000c;transform:scale(1.05);opacity:1}.slideshow-controls{position:absolute;bottom:2rem;left:2rem;display:flex;align-items:center;gap:1rem;background:#0009;padding:.5rem 1.25rem;border-radius:50px;z-index:100;opacity:.7;transition:opacity .3s}.slideshow-controls:hover{opacity:1}.control-btn{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.6);border-radius:50%;width:36px;height:36px;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s}.control-btn:hover{background:#ffffff1a;border-color:#fff;transform:scale(1.05)}.slide-counter{color:#fff;font-size:.9rem;font-family:Sawarabi Mincho,serif;min-width:70px;text-align:center}.slideshow-hints{position:absolute;bottom:.75rem;left:50%;transform:translate(-50%);display:flex;gap:1.5rem;color:#0006;font-size:.75rem;font-family:Sawarabi Mincho,serif;z-index:100}@media(max-width:768px){.slideshow-image{max-width:calc(100vw - 40px);max-height:calc(100vh - 120px)}.slideshow-close{top:.5rem;right:.5rem;width:44px;height:44px;font-size:1.3rem}.slideshow-controls{bottom:1rem;left:50%;transform:translate(-50%);padding:.75rem 1.25rem;gap:.75rem}.control-btn{width:44px;height:44px;font-size:1.1rem}.slide-counter{font-size:.85rem;min-width:60px}.slideshow-hints{display:none}}.gallery-layout{min-height:100vh;background:var(--color-background)}.main-nav{background:var(--color-white);border-bottom:1px solid var(--color-border);position:sticky;top:0;z-index:var(--z-navigation)}.main-nav-content{max-width:1600px;margin:0 auto;padding:0 2rem;display:flex;align-items:center;justify-content:space-between;gap:2rem}.nav-left-section{display:flex;align-items:center;gap:2rem}.nav-tabs-group{display:flex;gap:0}.gallery-name{font-size:1.25rem;font-weight:400;color:var(--color-text);margin:0;letter-spacing:.02em}.nav-tab{background:transparent;border:none;border-bottom:3px solid transparent;color:var(--color-text-light);padding:1rem 2rem;cursor:pointer;font-size:1rem;font-weight:400;transition:all .2s;font-family:Sawarabi Mincho,serif}.nav-tab:hover:not(:disabled){color:var(--color-text);background:var(--color-background)}.nav-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary);font-weight:500;cursor:default}.nav-tab:disabled{cursor:default}.nav-actions{display:flex;align-items:center;gap:1rem;justify-content:flex-end}.nav-right-section{display:flex;align-items:center;gap:1rem}.slideshow-button-nav,.favorites-button-nav,.download-button-nav{background:transparent;border:1px solid var(--color-border);color:var(--color-text);padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-weight:400;transition:all .2s;font-family:Sawarabi Mincho,serif;font-size:.95rem;white-space:nowrap}.slideshow-button-nav:hover,.favorites-button-nav:hover,.download-button-nav:hover{background:var(--color-background);border-color:var(--color-text)}.download-button-nav{border-color:var(--color-primary);color:var(--color-primary)}.download-button-nav:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.download-menu-container{position:relative}.download-dropdown{position:absolute;top:calc(100% + .5rem);right:0;background:#fff;border:1px solid var(--color-border);border-radius:8px;box-shadow:0 4px 12px #0000001a;min-width:220px;z-index:1000;overflow:hidden}.download-dropdown-item{width:100%;padding:.875rem 1.25rem;background:#fff;border:none;text-align:left;cursor:pointer;font-family:Sawarabi Mincho,serif;font-size:.95rem;color:var(--color-text);transition:background .2s;display:flex;align-items:center;gap:.5rem}.download-dropdown-item:hover{background:var(--color-background)}.download-dropdown-item:not(:last-child){border-bottom:1px solid var(--color-border)}.gallery-layout-loading,.gallery-layout-error{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--color-background)}.loading,.error-message{text-align:center;padding:4rem 2rem;color:var(--color-text-light)}.error-message h2{font-size:1.75rem;color:var(--color-text);margin-bottom:1rem;font-weight:400}.back-button{background:var(--color-text);color:var(--color-white);border:none;padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;cursor:pointer;font-family:Sawarabi Mincho,serif;transition:all .2s}.back-button:hover{background:var(--color-primary);transform:translateY(-2px)}.burger-menu-button{display:none;flex-direction:column;justify-content:space-between;width:44px;height:36px;background:transparent;border:none;cursor:pointer;padding:.5rem;margin:-.5rem;margin-top:calc(-.5rem + 5px);z-index:1001}.burger-menu-button span{display:block;height:5px;width:100%;background:var(--color-text);border-radius:5px;transition:all .3s ease}.desktop-only{display:flex}.mobile-menu-actions{display:none}.cart-icon-wrapper{display:contents}.mobile-menu-overlay{display:none}@media(max-width:768px){.burger-menu-button{display:flex}.desktop-only{display:none!important}.main-nav-content{padding:0 1.5rem!important;gap:1rem}.nav-tabs-group{position:fixed;top:-100%;left:0;width:100%;max-height:100vh;background:var(--color-white);flex-direction:column;gap:0;z-index:var(--z-mobile-menu);transition:top .3s ease;padding:3rem 0 4rem;box-shadow:0 4px 10px #0000001a;overflow-y:auto}.nav-tabs-group.mobile-open{top:0}.mobile-menu-overlay{display:block;position:fixed;inset:0;background:transparent}.nav-tab{width:100%;padding:1.5rem 2rem!important;font-size:1.5rem!important;text-align:left;border-bottom:1px solid var(--color-border);border-left:3px solid transparent}.nav-tab.active{border-bottom-color:var(--color-border);border-left-color:var(--color-text);background:var(--color-background)}.nav-tab:hover:not(:disabled){background:var(--color-background)}.mobile-menu-actions{display:flex;flex-direction:column;gap:0;border-top:2px solid var(--color-border);margin-top:1rem}.mobile-menu-button{width:100%;padding:1.5rem 2rem!important;font-size:1.5rem!important;text-align:left;background:transparent;border:none;border-bottom:1px solid var(--color-border);color:var(--color-text);cursor:pointer;font-family:Sawarabi Mincho,serif}.mobile-menu-button:hover{background:var(--color-background)}.cart-icon-wrapper{display:block;margin-left:auto}}.admin-login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#ebe4db,#d4cdc4);padding:2rem}.login-card{background:#fff;border-radius:16px;padding:3rem;box-shadow:0 20px 60px #0000004d;max-width:450px;width:100%}.login-card h1{font-size:2rem;margin-bottom:.5rem;color:#2c3e50;text-align:center}.login-subtitle{text-align:center;color:#7f8c8d;margin-bottom:2rem}.login-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:600;color:#2c3e50;font-size:.95rem}.form-group input{padding:.875rem 1rem;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;transition:border-color .2s}.form-group input:focus{outline:none;border-color:#8b7d6b}.remember-me-group{margin:-.5rem 0}.remember-me-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.9rem;color:#64748b}.remember-me-label input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#8B7D6B}.remember-me-label span{-webkit-user-select:none;user-select:none}.error-message{background:#fee;color:#c33;padding:.875rem;border-radius:8px;text-align:center;font-size:.95rem}.login-button{background:#8b7d6b;color:#fff;border:none;padding:1rem;border-radius:8px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:background .2s;margin-top:.5rem}.login-button:hover:not(:disabled){background:#6d6254}.login-button:disabled{opacity:.6;cursor:not-allowed}.back-to-home{background:none;border:none;color:#7f8c8d;text-align:center;margin-top:1.5rem;cursor:pointer;font-size:.95rem;padding:.5rem;width:100%;transition:color .2s}.back-to-home:hover{color:#2c3e50}.gallery-admin-login-container{min-height:100vh;background:var(--color-background);display:flex;align-items:center;justify-content:center;padding:2rem}.gallery-admin-login-card{background:var(--color-white);border:1px solid var(--color-border);border-radius:12px;padding:3rem;max-width:400px;width:100%;text-align:center}.gallery-admin-login-card h1{font-size:2rem;font-weight:400;color:var(--color-text);margin:0 0 .5rem}.gallery-admin-subtitle{font-size:1rem;color:var(--color-text-light);margin:0 0 2rem}.gallery-admin-login-card form{text-align:left}.gallery-admin-login-card .form-group{margin-bottom:1.5rem}.gallery-admin-login-card label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--color-text)}.gallery-admin-login-card input{width:100%;padding:.75rem;border:1px solid var(--color-border);border-radius:6px;font-size:1rem;font-family:Sawarabi Mincho,serif}.gallery-admin-login-card input:focus{outline:none;border-color:var(--color-primary)}.gallery-admin-login-card .error-message{background:#fee;border:1px solid #fcc;color:#c33;padding:.75rem;border-radius:6px;margin-bottom:1rem;text-align:center}.login-button,.cancel-button{width:100%;padding:.875rem;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s;font-family:Sawarabi Mincho,serif}.login-button{background:var(--color-primary);color:var(--color-white);border:none;margin-bottom:.75rem}.login-button:hover{background:var(--color-primary-dark);transform:translateY(-1px)}.cancel-button{background:transparent;color:var(--color-text);border:1px solid var(--color-border)}.cancel-button:hover{background:var(--color-background)}.version-badge{position:fixed;top:1rem;right:1rem;z-index:9999;background:var(--color-white);border:1px solid var(--color-border);border-radius:4px;box-shadow:0 2px 12px var(--color-shadow);transition:all .2s ease}.version-badge.minimized{background:var(--color-primary);border-color:var(--color-primary)}.version-expand{background:transparent;border:none;color:var(--color-white);padding:.5rem .75rem;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .2s ease;font-family:Courier New,monospace}.version-expand:hover{opacity:.9}.version-content{padding:.75rem 1rem;min-width:140px}.version-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.25rem}.version-number{font-weight:600;color:var(--color-primary);font-size:.95rem;font-family:Courier New,monospace}.version-actions{display:flex;gap:.25rem}.version-minimize,.version-close{background:transparent;border:none;color:var(--color-text-light);width:20px;height:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.1rem;line-height:1;border-radius:2px;transition:all .2s ease}.version-minimize:hover,.version-close:hover{background:var(--color-background);color:var(--color-text)}.version-info{color:var(--color-text-lighter);font-size:.75rem;line-height:1.3}@media(max-width:768px){.version-badge{display:none}}#root{width:100%}
