@import"https://fonts.googleapis.com/css2?family=Playfair+Display:wght@700&family=Shippori+Mincho:wght@400;600;700&family=DM+Sans:wght@300;400;500;600&display=swap";.navbar{position:sticky;top:0;z-index:100;background:#faf8f5eb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}.navbar-inner{display:flex;align-items:center;gap:1.5rem;height:64px}.navbar-logo{display:flex;align-items:center;gap:.7rem;flex-shrink:0}.logo-flower{flex-shrink:0}.logo-wordmark{display:flex;flex-direction:column;line-height:1}.logo-name{font-family:Playfair Display,Shippori Mincho,Georgia,serif;font-size:1.35rem;font-weight:700;color:var(--ink);letter-spacing:-.01em;line-height:1.1;border-bottom:1.5px dashed #d4698a;padding-bottom:.2rem}.logo-tagline{font-size:.54rem;color:#d4698a;letter-spacing:.17em;margin-top:.28rem;font-weight:400;white-space:nowrap}.navbar-links{display:flex;align-items:center;gap:.25rem;margin-left:auto}.navbar-links a{padding:.4rem .85rem;font-size:.88rem;color:var(--ink-soft);border-radius:var(--radius-sm);transition:var(--transition);font-weight:500}.navbar-links a:hover,.navbar-links a.active{color:var(--ink);background:var(--paper-2)}.navbar-links .admin-link{color:var(--vermillion);font-weight:600}.navbar-actions{display:flex;align-items:center;gap:.5rem;margin-left:1rem}.cart-btn{position:relative;display:flex;align-items:center;padding:.4rem;color:var(--ink-soft);border-radius:var(--radius-sm);transition:var(--transition)}.cart-btn:hover{color:var(--ink);background:var(--paper-2)}.cart-badge{position:absolute;top:-2px;right:-4px;background:var(--vermillion);color:#fff;font-size:.6rem;font-weight:700;min-width:17px;height:17px;border-radius:99px;display:flex;align-items:center;justify-content:center}.user-menu-wrap{position:relative}.user-btn{display:flex;align-items:center;gap:.5rem;padding:.3rem .7rem;background:var(--paper-2);border:1px solid var(--border);border-radius:99px;font-size:.85rem;color:var(--ink);transition:var(--transition)}.user-btn:hover{border-color:var(--ink-soft)}.user-avatar{width:26px;height:26px;border-radius:50%;background:var(--vermillion);color:#fff;font-size:.75rem;font-weight:700;display:flex;align-items:center;justify-content:center}.user-name{font-weight:500;max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-dropdown{position:absolute;right:0;top:calc(100% + 8px);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);min-width:180px;padding:.5rem;overflow:hidden;animation:dropIn .15s ease}@keyframes dropIn{0%{opacity:0;transform:translateY(-6px)}}.user-dropdown a,.user-dropdown button{display:block;width:100%;text-align:left;padding:.55rem .85rem;border-radius:var(--radius-sm);font-size:.87rem;color:var(--ink-soft);border:none;background:none;transition:var(--transition);cursor:pointer}.user-dropdown a:hover,.user-dropdown button:hover{background:var(--paper-2);color:var(--ink)}.user-dropdown .admin-item{color:var(--vermillion);font-weight:600}.user-dropdown .logout-item{color:var(--ink-faint);margin-top:.25rem;border-top:1px solid var(--border);border-radius:0}.user-dropdown .logout-item:hover{color:var(--vermillion);background:#fde8e6}.lang-switcher{display:flex;align-items:center;gap:.3rem;font-size:.75rem;font-weight:600}.lang-switcher span{color:var(--border)}.lang-switcher button{background:none;border:none;padding:.2rem .35rem;border-radius:var(--radius-sm);color:var(--ink-faint);cursor:pointer;transition:var(--transition);letter-spacing:.05em}.lang-switcher button:hover{color:var(--ink)}.lang-switcher button.active{color:var(--vermillion)}.mobile-lang{display:flex;align-items:center;gap:.5rem;padding:.7rem 0;font-size:.85rem;font-weight:600}.mobile-lang span{color:var(--border)}.mobile-lang button{background:none;border:none;color:var(--ink-faint);cursor:pointer;font-size:.85rem;font-weight:600}.mobile-lang button.active{color:var(--vermillion)}.auth-links{display:flex;align-items:center;gap:.5rem}.hamburger{display:none;flex-direction:column;gap:5px;padding:.4rem;background:none;border:none}.hamburger span{display:block;width:22px;height:2px;background:var(--ink);border-radius:2px;transition:var(--transition)}.mobile-menu{display:flex;flex-direction:column;padding:1rem 1.5rem 1.5rem;border-top:1px solid var(--border);background:var(--surface)}.mobile-menu a,.mobile-menu button{padding:.7rem 0;border-bottom:1px solid var(--paper-2);font-size:.95rem;color:var(--ink-soft);background:none;border-left:none;border-right:none;border-top:none;text-align:left;cursor:pointer}.mobile-menu a:last-child,.mobile-menu button:last-child{border-bottom:none}@media (max-width: 768px){.navbar-links,.user-name,.auth-links .btn-ghost{display:none}.hamburger{display:flex}}@media (min-width: 769px){.mobile-menu{display:none}}.hero{position:relative;overflow:hidden;min-height:560px;display:flex;align-items:center;background:linear-gradient(135deg,var(--paper) 0%,var(--paper-2) 60%,#f5e8e0 100%)}.hero-bg{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.hero-petals{position:absolute;top:0;right:0;bottom:0;left:0}.petal{position:absolute;font-size:1.4rem;opacity:.25;animation:fall 12s linear infinite;animation-delay:calc(var(--i) * 1.5s);left:calc(var(--i) * 12% + 5%);top:-2rem}@keyframes fall{to{transform:translateY(620px) rotate(360deg);opacity:0}}.hero-content{position:relative;z-index:1;padding-top:3rem;padding-bottom:3rem;max-width:640px}.hero-label{font-size:.75rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--vermillion);margin-bottom:1rem}.hero-title{font-size:clamp(2.4rem,6vw,4rem);line-height:1.1;margin-bottom:1rem;color:var(--ink)}.hero-title em{font-style:normal;color:var(--vermillion)}.hero-sub{font-size:1.05rem;color:var(--ink-soft);margin-bottom:2rem;max-width:480px;line-height:1.7}.hero-cta{display:flex;gap:1rem;flex-wrap:wrap}.hero-stamp{position:absolute;right:5%;top:50%;transform:translateY(-50%);width:120px;height:120px;border:3px solid var(--vermillion);border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;opacity:.15;font-family:var(--font-display);font-size:3rem;color:var(--vermillion);transform:translateY(-50%) rotate(-12deg)}.hero-stamp small{font-size:.55rem;letter-spacing:.12em;color:var(--vermillion)}.section{padding:5rem 0}.section-title{font-size:1.75rem;margin-bottom:2rem}.section-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:2rem}.see-all{font-size:.88rem;color:var(--vermillion);font-weight:500}.see-all:hover{text-decoration:underline}.categories-section{background:var(--surface)}.categories-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:1rem}.cat-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;padding:1.5rem .5rem;border-radius:var(--radius-md);background:var(--bg, var(--paper-2));border:1px solid var(--border);transition:var(--transition);text-decoration:none}.cat-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}.cat-kanji{font-family:var(--font-display);font-size:2rem;color:var(--ink)}.cat-label{font-size:.78rem;font-weight:600;letter-spacing:.04em;color:var(--ink-soft)}.featured-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem}.product-card{display:flex;flex-direction:column;overflow:hidden;transition:var(--transition)}.product-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.product-img{background:var(--paper-2);font-size:3.5rem;display:flex;align-items:center;justify-content:center;height:160px}.product-info{padding:1rem;display:flex;flex-direction:column;gap:.4rem;flex:1}.product-name{font-size:.92rem;font-weight:600;color:var(--ink);line-height:1.35;margin-top:.25rem}.product-cat{font-size:.75rem;color:var(--ink-faint)}.product-footer{display:flex;justify-content:space-between;align-items:center;margin-top:auto;padding-top:.75rem}.product-price{font-family:var(--font-display);font-size:1.1rem;font-weight:700;color:var(--ink)}.trust-bar{background:var(--ink);color:var(--paper);padding:2.5rem 0}.trust-inner{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}.trust-item{display:flex;gap:1rem;align-items:flex-start}.trust-icon{font-size:1.5rem;flex-shrink:0;margin-top:.1rem}.trust-item strong{display:block;font-size:.9rem;margin-bottom:.2rem;color:var(--paper)}.trust-item p{font-size:.78rem;color:var(--ink-faint);line-height:1.4}.banner-section{padding:4rem 0;background:var(--paper-2)}.banner{display:flex;align-items:center;justify-content:space-between;gap:2rem;padding:3rem;background:linear-gradient(135deg,var(--surface) 0%,#fff8f6 100%);border-left:4px solid var(--vermillion)}.banner-text{max-width:520px}.banner-kanji{font-family:var(--font-display);font-size:1rem;color:var(--vermillion);letter-spacing:.1em;margin-bottom:.5rem}.banner-text h2{margin-bottom:.75rem}.banner-text p{color:var(--ink-soft);margin-bottom:1.5rem;line-height:1.7}.banner-art{font-size:3.5rem;letter-spacing:.5rem;opacity:.5;flex-shrink:0}@media (max-width: 1024px){.categories-grid{grid-template-columns:repeat(3,1fr)}.featured-grid,.trust-inner{grid-template-columns:repeat(2,1fr)}.banner{padding:2rem}}@media (max-width: 768px){.hero{min-height:400px}.hero-c{padding:2.5rem 1.25rem}.hero-btns{flex-direction:column}.hero-btns .btn-lg{width:100%;justify-content:center}.categories-grid{grid-template-columns:repeat(3,1fr);gap:.6rem}.cat-card{padding:1rem .4rem}.cat-kanji{font-size:1.5rem}.featured-grid,.trust-inner{grid-template-columns:repeat(2,1fr)}.join{flex-direction:column;gap:1rem;padding:1.75rem}.join-art{display:none}}@media (max-width: 600px){.hero-stamp{display:none}.categories-grid{grid-template-columns:repeat(3,1fr)}.featured-grid{grid-template-columns:1fr 1fr}.prod-img{height:110px;font-size:2.5rem}.trust-inner{grid-template-columns:1fr 1fr}.banner{flex-direction:column;text-align:center;padding:1.5rem}.banner-art{display:none}.section{padding:2.5rem 0}.sec{padding:2rem 1rem}}@media (max-width: 400px){.categories-grid{grid-template-columns:repeat(2,1fr)}.featured-grid,.trust-inner{grid-template-columns:1fr}.hero-c{padding:2rem 1rem}}.auth-page{min-height:calc(100vh - 64px);display:flex;align-items:center;justify-content:center;padding:2rem 1rem;background:var(--paper);position:relative;overflow:hidden}.auth-page:before{content:"桜";font-family:var(--font-display);position:absolute;font-size:24rem;color:var(--paper-2);right:-4rem;bottom:-6rem;line-height:1;pointer-events:none;-webkit-user-select:none;user-select:none;z-index:0}.auth-card{width:min(420px,100%);padding:2.5rem 2rem;position:relative;z-index:1}.auth-header{text-align:center;margin-bottom:1.75rem}.auth-kanji{display:block;font-family:var(--font-display);font-size:2.5rem;color:var(--vermillion);line-height:1;margin-bottom:.5rem}.auth-header h1{font-size:1.6rem;margin-bottom:.25rem}.auth-header p{color:var(--ink-faint);font-size:.9rem}.auth-form{display:flex;flex-direction:column;gap:1.1rem}.auth-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.auth-submit{width:100%;margin-top:.5rem}.auth-error{background:#fde8e6;color:var(--vermillion);border:1px solid #f5c6c2;border-radius:var(--radius-sm);padding:.65rem 1rem;font-size:.85rem;margin-bottom:1rem}.auth-success{background:#e6f4ea;color:#2d6a4f;border:1px solid #b7dfc4;border-radius:var(--radius-sm);padding:.65rem 1rem;font-size:.85rem;margin-bottom:1rem}.auth-footer{text-align:center;font-size:.85rem;color:var(--ink-faint);margin-top:1.5rem}.auth-footer a{color:var(--vermillion);font-weight:500}.auth-footer a:hover{text-decoration:underline}.label-link{float:right;font-size:.78rem;color:var(--vermillion);font-weight:400}.label-link:hover{text-decoration:underline}.password-hints{display:flex;gap:.5rem;margin-top:.4rem}.hint{font-size:.72rem;color:var(--ink-faint);background:var(--paper-2);padding:2px 8px;border-radius:99px}.hint.ok{color:#2d6a4f;background:#e6f4ea}.code-input{text-align:center;font-size:1.4rem;letter-spacing:.4em;font-family:var(--font-display)}.link-btn{background:none;border:none;color:var(--vermillion);font-size:.85rem;font-weight:500;cursor:pointer;padding:0}.link-btn:hover{text-decoration:underline}@media (max-width: 480px){.auth-card{padding:2rem 1.25rem}.auth-row{grid-template-columns:1fr}}.page-container{max-width:1100px;margin:0 auto;padding:2rem 1.5rem}.page-title{font-family:var(--font-display);font-size:1.75rem;margin-bottom:.25rem}.page-subtitle{font-size:.85rem;color:var(--ink-faint);margin-bottom:1.5rem}.filter-chips{display:flex;gap:.4rem;flex-wrap:wrap}.filter-chip{padding:.35rem .85rem;border-radius:99px;font-size:.8rem;font-weight:500;border:1.5px solid var(--border);background:var(--surface);color:var(--ink-soft);transition:var(--transition);cursor:pointer}.filter-chip.active{background:var(--vermillion);border-color:var(--vermillion);color:#fff}.products-toolbar{display:flex;gap:.75rem;margin-bottom:1.5rem;align-items:center;flex-wrap:wrap}.products-search{padding:.5rem 1rem;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:.85rem;outline:none;font-family:inherit;background:var(--surface);color:var(--ink);width:220px}.products-search:focus{border-color:var(--vermillion)}.products-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem}.detail-layout{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;align-items:start}.breadcrumb{font-size:.78rem;color:var(--ink-faint);margin-bottom:1.5rem}.breadcrumb a{color:var(--ink-faint)}.breadcrumb a:hover{color:var(--vermillion);text-decoration:underline}.cart-layout{display:grid;grid-template-columns:1fr 340px;gap:1.5rem;align-items:start}.cart-summary-sticky{position:sticky;top:80px}.account-layout{display:grid;grid-template-columns:220px 1fr;gap:2rem;align-items:start}.account-nav{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:.75rem;position:sticky;top:80px}.account-nav-item{display:block;padding:.6rem .9rem;border-radius:var(--radius-sm);font-size:.87rem;color:var(--ink-soft);transition:var(--transition);font-weight:500}.account-nav-item:hover,.account-nav-item.active{background:var(--paper-2);color:var(--ink)}.account-nav-item.active{color:var(--vermillion);font-weight:600}@media (max-width: 1023px){.products-grid{grid-template-columns:repeat(3,1fr)}.detail-layout{gap:1.75rem}.cart-layout{grid-template-columns:1fr 300px;gap:1.25rem}.account-layout{grid-template-columns:180px 1fr;gap:1.25rem}}@media (max-width: 767px){.page-container{padding:1.25rem 1rem}.page-title{font-size:1.4rem}.products-grid{grid-template-columns:repeat(2,1fr);gap:.75rem}.products-toolbar{flex-direction:column;align-items:stretch}.products-search{width:100%}.detail-layout{grid-template-columns:1fr;gap:1.5rem}.cart-layout{grid-template-columns:1fr}.cart-summary-sticky{position:static}.account-layout{grid-template-columns:1fr}.account-nav{position:static;display:flex;flex-direction:row;overflow-x:auto;-webkit-overflow-scrolling:touch;gap:.25rem;padding:.5rem;border-radius:var(--radius-sm);margin-bottom:1rem}.account-nav-item{white-space:nowrap;flex-shrink:0}}@media (max-width: 479px){.products-grid{grid-template-columns:repeat(2,1fr);gap:.6rem}.detail-layout{gap:1.25rem}.breadcrumb{font-size:.72rem}}.admin-page{min-height:100vh;background:var(--paper)}.admin-header{background:var(--ink);color:var(--paper);padding:1.5rem 0 0}.admin-title-row{display:flex;justify-content:space-between;align-items:flex-start;gap:1.5rem;flex-wrap:wrap;margin-bottom:1.5rem}.admin-title-row h1{font-size:1.5rem;color:var(--paper);margin-bottom:.25rem}.admin-title-row p{font-size:.82rem;color:#888}.admin-stats{display:flex;gap:1rem}.stat-card{padding:1rem 1.25rem;text-align:center;min-width:100px;background:#ffffff0d;border-color:#ffffff1a}.stat-value{font-family:var(--font-display);font-size:1.75rem;font-weight:700;line-height:1}.stat-label{font-size:.7rem;color:#888;margin-top:.3rem;letter-spacing:.06em;text-transform:uppercase}.stat-sub{font-size:.72rem;color:#666;margin-top:.2rem}.admin-tabs{display:flex;gap:0;border-bottom:1px solid rgba(255,255,255,.1)}.admin-tab{padding:.75rem 1.5rem;background:none;border:none;color:#888;font-size:.88rem;cursor:pointer;font-family:inherit;font-weight:500;border-bottom:2px solid transparent;margin-bottom:-1px;transition:var(--transition)}.admin-tab:hover{color:var(--paper)}.admin-tab.active{color:var(--paper);border-bottom-color:var(--vermillion)}.admin-body{padding:2rem 1.5rem}.tab-toolbar{display:flex;gap:.75rem;margin-bottom:1.5rem;align-items:center;flex-wrap:wrap}.toolbar-search{max-width:300px;flex:1}.loading-row{display:flex;justify-content:center;padding:4rem}.empty-msg{text-align:center;padding:3rem;color:var(--ink-faint);font-size:.9rem}.muted{color:var(--ink-faint);font-size:.82rem}.admin-table{width:100%;border-collapse:collapse;font-size:.88rem}.admin-table th{text-align:left;padding:.65rem 1rem;border-bottom:2px solid var(--border);font-size:.72rem;color:var(--ink-faint);letter-spacing:.06em;text-transform:uppercase;white-space:nowrap}.admin-table td{padding:.85rem 1rem;border-bottom:1px solid var(--paper-2);vertical-align:middle}.admin-table tbody tr:hover{background:var(--paper)}.action-btns{display:flex;gap:.4rem}.btn-disable{background:#fde8e6;color:var(--vermillion);border:1px solid #f5c6c2}.btn-disable:hover{background:var(--vermillion);color:#fff}.order-id{font-size:.8rem;color:var(--ink-faint);background:var(--paper-2);padding:2px 6px;border-radius:4px}.status-select{width:auto;padding:.35rem .65rem;font-size:.82rem}.filter-tabs{display:flex;gap:.25rem;flex-wrap:wrap}.filter-btn{padding:.4rem .9rem;border-radius:99px;border:1px solid var(--border);background:none;font-size:.8rem;color:var(--ink-soft);cursor:pointer;font-family:inherit;text-transform:capitalize;transition:var(--transition)}.filter-btn:hover{border-color:var(--ink-soft);color:var(--ink)}.filter-btn.active{background:var(--ink);color:var(--paper);border-color:var(--ink)}.product-form{padding:1.5rem;margin-bottom:1.5rem}.product-form h3{margin-bottom:1rem;font-size:1rem}.form-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.85rem}.full-width{grid-column:1 / -1}.form-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.25rem}.bilingual-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:.5rem}.lang-col{display:flex;flex-direction:column;gap:.75rem}.lang-col-header{font-size:.72rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--ink-faint);padding-bottom:.5rem;border-bottom:2px solid var(--border);margin-bottom:.25rem}.lang-col:last-child .lang-col-header{color:#c05580;border-bottom-color:#f0c0d0}@media (max-width: 768px){.admin-stats{display:none}.form-grid,.bilingual-grid{grid-template-columns:1fr}.admin-body{padding:1rem}.admin-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch}.admin-tab{padding:.65rem 1rem;font-size:.82rem;white-space:nowrap}.tab-toolbar{flex-direction:column;align-items:stretch}.toolbar-search{max-width:100%}.filter-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap;padding-bottom:.25rem}.filter-btn{white-space:nowrap;flex-shrink:0}.admin-table{font-size:.78rem}.admin-table th,.admin-table td{padding:.6rem .65rem}.action-btns{flex-direction:column;gap:.3rem}.form-actions{flex-direction:column}.form-actions .btn{width:100%}}@media (max-width: 480px){.admin-title-row h1{font-size:1.2rem}.admin-table th:nth-child(5),.admin-table td:nth-child(5){display:none}.status-select{font-size:.75rem;padding:.25rem .4rem}}.stock-page{padding:2rem 1.5rem;max-width:1200px;margin:0 auto}.stock-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;flex-wrap:wrap;margin-bottom:1.5rem}.stock-header h1{font-family:var(--font-display);font-size:1.6rem;margin-bottom:.2rem}.stock-header p{font-size:.82rem;color:var(--ink-faint)}.stock-header-actions{display:flex;gap:.5rem}.stock-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;margin-bottom:1.5rem}.ss-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:.9rem 1rem;text-align:center}.ss-val{font-family:var(--font-display);font-size:1.75rem;font-weight:700;line-height:1}.ss-label{font-size:.65rem;color:var(--ink-faint);margin-top:.25rem;letter-spacing:.06em;text-transform:uppercase}.stock-toolbar{display:flex;gap:.75rem;margin-bottom:1.5rem;align-items:center;flex-wrap:wrap}.stock-search{padding:.45rem .9rem;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:.82rem;color:var(--ink);outline:none;font-family:inherit;width:240px;background:var(--surface)}.stock-search:focus{border-color:var(--vermillion)}.filter-chips{display:flex;gap:.35rem;flex-wrap:wrap}.filter-chip{padding:.3rem .75rem;border-radius:99px;border:1px solid var(--border);background:none;font-size:.75rem;color:var(--ink-soft);cursor:pointer;font-family:inherit;transition:var(--transition)}.filter-chip:hover{border-color:var(--ink-soft);color:var(--ink)}.filter-chip.active{background:var(--ink);color:var(--paper);border-color:var(--ink)}.view-toggle{display:flex;border:1.5px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;margin-left:auto}.vt-btn{padding:.35rem .7rem;background:none;border:none;font-size:.78rem;color:var(--ink-faint);cursor:pointer;font-family:inherit;transition:var(--transition)}.vt-btn.active{background:var(--ink);color:var(--paper)}.stock-content{display:flex;gap:1.5rem;align-items:flex-start}.stock-main{flex:1;min-width:0}.has-panel .stock-main{max-width:calc(100% - 320px)}.bin-section{margin-bottom:2rem}.bin-row-label{font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:.75rem;display:flex;align-items:center;gap:.5rem}.bin-row-label:after{content:"";flex:1;height:1px;background:var(--border)}.bin-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(155px,1fr));gap:.65rem}.bin-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-md);padding:.85rem;cursor:pointer;transition:var(--transition);position:relative;overflow:hidden}.bin-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.bin-card.bin-ok{border-color:#b7dfc4;background:#f8fdf9}.bin-card.bin-low{border-color:#f5a623;background:#fffdf4}.bin-card.bin-empty{border-color:var(--vermillion);background:#fff8f8}.bin-status-badge{position:absolute;top:.5rem;right:.5rem;font-size:.58rem;font-weight:700;letter-spacing:.05em;padding:2px 6px;border-radius:4px}.bin-ok .bin-status-badge{background:#e6f4ea;color:var(--green)}.bin-low .bin-status-badge{background:#fdf3d6;color:#7a5c00}.bin-empty .bin-status-badge{background:#fde8e6;color:var(--vermillion)}.bin-id-tag{display:inline-block;background:var(--ink);color:var(--paper);font-family:monospace;font-size:.68rem;font-weight:700;padding:2px 7px;border-radius:4px;letter-spacing:.06em;margin-bottom:.45rem}.bin-id-tag.bin-low{background:#e67e00}.bin-id-tag.bin-empty{background:var(--vermillion)}.bin-id-tag.sm{font-size:.72rem}.bin-id-tag.lg{font-size:.85rem;padding:3px 10px}.bin-name{font-size:.78rem;font-weight:600;line-height:1.3;margin-bottom:.25rem;color:var(--ink)}.bin-sku{font-size:.63rem;color:var(--ink-faint);font-family:monospace;margin-bottom:.5rem}.bin-qty{font-family:var(--font-display);font-size:1.5rem;font-weight:700;line-height:1}.bin-qty-label{font-size:.62rem;color:var(--ink-faint)}.bin-empty-slot{background:var(--paper-2);border:1.5px dashed var(--border);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--ink-faint);font-size:.75rem;cursor:pointer;transition:var(--transition);min-height:100px}.bin-empty-slot:hover{border-color:var(--ink-soft);color:var(--ink);background:var(--paper-3)}.table-wrap{overflow-x:auto}.stock-table{width:100%;border-collapse:collapse;font-size:.84rem}.stock-table th{text-align:left;padding:.55rem .85rem;border-bottom:2px solid var(--border);font-size:.65rem;color:var(--ink-faint);letter-spacing:.06em;text-transform:uppercase;white-space:nowrap}.stock-table td{padding:.8rem .85rem;border-bottom:1px solid var(--paper-2);vertical-align:middle}.stock-table code{font-size:.75rem;color:var(--ink-faint)}.clickable-row{cursor:pointer}.clickable-row:hover{background:var(--paper)}.bin-panel{width:300px;flex-shrink:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;position:sticky;top:80px}.panel-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.25rem;gap:.75rem}.panel-header h3{font-size:.95rem;margin:.35rem 0 .2rem;line-height:1.3}.panel-close{background:none;border:none;font-size:1.4rem;color:var(--ink-faint);cursor:pointer;line-height:1;padding:0 4px;flex-shrink:0}.panel-qty{text-align:center;padding:1.25rem 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin-bottom:1.25rem}.pq-val{font-family:var(--font-display);font-size:3rem;font-weight:800;line-height:1}.pq-label{font-size:.75rem;color:var(--ink-faint);margin-top:.25rem}.pq-min{font-size:.72rem;color:var(--ink-faint);margin-top:.35rem}.panel-adjust{margin-bottom:1.25rem}.panel-adjust .form-label{display:block;font-size:.72rem;font-weight:600;color:var(--ink-soft);letter-spacing:.04em;margin-bottom:.4rem;text-transform:uppercase}.adjust-btns{display:flex;gap:.5rem;margin-top:.75rem}.adjust-btns .btn{flex:1}.panel-meta{border-top:1px solid var(--border);padding-top:1rem}.meta-row{display:flex;justify-content:space-between;padding:.4rem 0;border-bottom:1px solid var(--paper-2);font-size:.8rem}.meta-row span{color:var(--ink-faint)}@media (max-width: 900px){.stock-summary{grid-template-columns:repeat(2,1fr)}.has-panel .stock-main{max-width:100%}.bin-panel{position:fixed;bottom:0;left:0;right:0;width:100%;border-radius:var(--radius-lg) var(--radius-lg) 0 0;z-index:50;max-height:60vh;overflow-y:auto}}@media (max-width: 600px){.stock-summary,.bin-grid{grid-template-columns:repeat(2,1fr)}}:root{--ink: #1a1410;--ink-soft: #4a3f38;--ink-faint: #9a8f88;--paper: #faf8f5;--paper-2: #f2ede6;--paper-3: #e8e0d5;--vermillion: #c0392b;--vermillion-light: #e74c3c;--gold: #c9a84c;--gold-light:#f0d080;--surface: #ffffff;--border: #ddd5c8;--font-display: "Shippori Mincho", "Georgia", serif;--font-body: "DM Sans", system-ui, sans-serif;--radius-sm: 6px;--radius-md: 12px;--radius-lg: 20px;--shadow-sm: 0 1px 3px rgba(26,20,16,.08);--shadow-md: 0 4px 16px rgba(26,20,16,.1);--shadow-lg: 0 16px 48px rgba(26,20,16,.14);--transition: .2s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{font-family:var(--font-body);background:var(--paper);color:var(--ink);line-height:1.6;-webkit-font-smoothing:antialiased}img{max-width:100%;display:block}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit}h1,h2,h3,h4{font-family:var(--font-display);font-weight:600;line-height:1.25}h1{font-size:clamp(2rem,5vw,3.5rem)}h2{font-size:clamp(1.5rem,3vw,2.25rem)}h3{font-size:1.25rem}h4{font-size:1rem}.container{max-width:1200px;margin:0 auto;padding:0 1.5rem}.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.7rem 1.5rem;border-radius:var(--radius-sm);font-size:.9rem;font-weight:500;border:none;transition:var(--transition);white-space:nowrap}.btn-primary{background:var(--vermillion);color:#fff}.btn-primary:hover{background:var(--vermillion-light);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-secondary{background:transparent;color:var(--ink);border:1.5px solid var(--border)}.btn-secondary:hover{border-color:var(--ink-soft);background:var(--paper-2)}.btn-ghost{background:none;border:none;color:var(--ink-soft);padding:.4rem .75rem}.btn-ghost:hover{color:var(--ink);background:var(--paper-2);border-radius:var(--radius-sm)}.btn-sm{padding:.45rem 1rem;font-size:.82rem}.btn-lg{padding:.9rem 2rem;font-size:1rem}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.input{width:100%;padding:.7rem 1rem;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--ink);font-size:.9rem;transition:border-color var(--transition),box-shadow var(--transition);outline:none}.input:focus{border-color:var(--vermillion);box-shadow:0 0 0 3px #c0392b1f}.input::placeholder{color:var(--ink-faint)}.input-error{border-color:var(--vermillion-light)}.form-group{display:flex;flex-direction:column;gap:.4rem}.form-label{font-size:.8rem;font-weight:500;color:var(--ink-soft);letter-spacing:.02em}.form-error{font-size:.78rem;color:var(--vermillion)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}.badge{display:inline-block;padding:2px 10px;border-radius:99px;font-size:.7rem;font-weight:600;letter-spacing:.04em}.badge-red{background:#fde8e6;color:var(--vermillion)}.badge-gold{background:#fdf3d6;color:#7a5c00}.badge-green{background:#e6f4ea;color:#2d6a4f}.badge-gray{background:var(--paper-3);color:var(--ink-soft)}.spinner{width:24px;height:24px;border:2.5px solid var(--border);border-top-color:var(--vermillion);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.toast{position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%);background:var(--ink);color:var(--paper);padding:.75rem 1.5rem;border-radius:var(--radius-md);font-size:.88rem;z-index:9999;box-shadow:var(--shadow-lg);animation:toastIn .25s ease}.toast-error{background:var(--vermillion)}.toast-success{background:#2d6a4f}@keyframes toastIn{0%{opacity:0;transform:translate(-50%) translateY(12px)}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--paper-2)}::-webkit-scrollbar-thumb{background:var(--paper-3);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:var(--ink-faint)}
