:root{color:#222;background:#f3f2f1;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif}*{box-sizing:border-box}body{margin:0}#root{min-height:100vh}.layout{grid-template-rows:auto 1fr;grid-template-columns:1fr;gap:16px;padding:16px;display:grid}.app-shell{background:#f6f6f6;grid-template-columns:240px 1fr;min-height:100vh;display:grid}.side-menu{color:#f1f1f1;box-sizing:border-box;background:#0b0b0b;flex-direction:column;height:100vh;min-height:100vh;padding:16px 14px;display:flex;position:sticky;top:0}.side-brand{border-bottom:1px solid #ffffff14;margin:-2px -2px 14px;padding:10px 10px 18px}.side-title{letter-spacing:.08em;font-size:.95rem;font-weight:900}.side-logo{width:160px;height:auto;margin:0;display:block}.side-logo-wrap{background:#f1f1f1;border-radius:14px;justify-content:center;align-items:center;margin:0 0 6px;padding:6px 12px;display:flex}.side-subtitle{color:#ffffffb3;margin-top:8px;font-size:.78rem;font-weight:700}.side-nav{flex-direction:column;flex:1;min-height:0;padding:0 6px;display:flex}.side-nav-main{gap:10px;display:grid}.side-nav-item{appearance:none;color:#ffffffe6;cursor:pointer;text-align:left;background:#ffffff08;border:1px solid #ffffff6b;border-radius:10px;padding:10px 12px;font-weight:800}.side-nav-logout{color:#ffffffeb;text-align:center;border:1px solid #ffffff6b;justify-content:center;align-items:center;margin-top:auto;padding-top:16px;padding-bottom:12px;display:flex}.side-nav-logout-inner{flex-direction:column;justify-content:center;align-items:center;gap:8px;width:100%;display:flex}.side-nav-logout-icon{opacity:.95;flex-shrink:0;width:24px;height:24px}.side-nav-logout-label{font-size:.82rem;font-weight:800;line-height:1.2}.side-nav-logout:hover{background:#ffffff14;border-color:#ffffffc7}.side-nav-item:hover{background:#ffffff0f;border-color:#ffffffb8}.side-nav-item.active{background:#ffffff14;border-color:#fffffff2}.top-catalog{min-width:0}.content-grid{grid-template-columns:1fr 320px;gap:16px;min-width:0;display:grid}.column{flex-direction:column;gap:16px;display:flex}.column.main{min-width:0}.panel{background:#fff;border:1px solid #d9d9d9;border-radius:10px;padding:14px}.catalog-panel{padding:16px}.catalog-header{justify-content:space-between;align-items:center;gap:10px;margin-bottom:10px;display:flex}.catalog-header h2{margin-bottom:0}.catalog-hint{color:#666;text-align:right;flex-shrink:0;font-size:.9rem;font-weight:600}.catalog-grid-scroll{-webkit-overflow-scrolling:touch;max-height:min(45vh,720px);padding:2px 6px 8px 2px;overflow:hidden auto}.catalog-card-grid{grid-template-columns:repeat(auto-fill,minmax(176px,1fr));gap:12px;display:grid}.catalog-grid-card{justify-content:flex-start;min-height:168px}.catalog-grid-card .code-pill-icon{border-radius:12px;flex-shrink:0;width:142px;height:142px}.catalog-grid-card .code-pill-icon svg{width:56px;height:56px}.catalog-card-title{-webkit-line-clamp:2;line-clamp:2;color:#111;text-align:center;letter-spacing:.01em;-webkit-box-orient:vertical;max-width:100%;font-size:.84rem;font-weight:800;line-height:1.2;display:-webkit-box;overflow:hidden}.catalog-card-sub{-webkit-line-clamp:3;line-clamp:3;color:#7a8798;text-align:center;-webkit-hyphens:auto;hyphens:auto;word-break:break-word;-webkit-box-orient:vertical;max-width:100%;font-size:.72rem;font-weight:500;line-height:1.25;display:-webkit-box;overflow:hidden}.catalog-grid-card.active .catalog-card-title{color:#000}.catalog-load-sentinel{pointer-events:none;width:100%;height:4px}.catalog-load-more-hint{text-align:center;color:#888;margin:0;padding:10px 8px 4px;font-size:.78rem;font-weight:600}.catalog-load-end{color:#aaa}.catalog-series-grid{grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:12px;display:grid}.series-card{background:#fff;border:1px solid #ececec;border-radius:14px;padding:12px}.series-header{align-items:center;gap:12px;margin-bottom:10px;display:flex}.series-icon{background:#f8f2ea;border:1px solid #f0e6d6;border-radius:12px;place-items:center;width:46px;height:46px;display:grid}.series-meta{flex:1;min-width:0}.series-name{letter-spacing:.02em;color:#111;margin:0;font-size:.9rem}.series-sub{color:#777;margin-top:4px;font-size:.78rem;font-weight:700}.series-items{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:8px;display:grid}.code-pill{cursor:pointer;text-align:center;background:#fafafa;border:1px solid #d9d9d9;border-radius:12px;flex-direction:column;align-items:center;gap:8px;width:100%;padding:12px 10px;display:flex}.code-pill:disabled{cursor:not-allowed;opacity:.55}.code-pill.disabled-pill{opacity:.55}.code-pill.active{background:#f8f2ea;border-color:#8b7355}.code-pill-text{color:#111;white-space:nowrap;text-overflow:ellipsis;font-size:.86rem;font-weight:800;display:block;overflow:hidden}.code-pill-icon{background:#f8f2ea;border:1px solid #f0e6d6;border-radius:10px;place-items:center;width:44px;height:44px;display:grid;overflow:hidden}.catalog-thumb{object-fit:contain;background:#fff;width:100%;height:100%;display:block}h1,h2{margin:0 0 10px}h1{font-size:1.5rem}h2{font-size:1rem}.hint{color:#666;margin:0;font-size:.9rem}.catalog-figure-headline{flex-direction:column;gap:4px;margin:0;display:flex}.catalog-figure-headline-title{color:#111;letter-spacing:.01em;font-size:1.02rem;font-weight:800;line-height:1.25}.catalog-figure-headline-sub{color:#7a8798;font-size:.88rem;font-weight:500;line-height:1.3}.status{margin-top:10px;font-size:.9rem}.status.error{color:#b00020}.catalog-list{gap:14px;max-height:none;padding-right:4px;display:grid;overflow:visible}.top-catalog .catalog-list{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px}.top-catalog .catalog-group{background:#fff;border:1px solid #ececec;border-radius:12px;padding:12px}.top-catalog .code-grid{grid-template-columns:repeat(5,minmax(0,1fr))}.top-catalog .code-card{border-radius:12px;padding:10px 12px}.catalog-group h3{letter-spacing:.04em;color:#4f4f4f;margin:0 0 8px;font-size:.78rem}.code-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.code-card{text-align:left;color:#111;cursor:pointer;background:#fafafa;border:1px solid #cfcfcf;border-radius:8px;justify-content:space-between;align-items:center;gap:8px;width:100%;padding:9px 10px;display:flex}.code-card.active{background:#f8f2ea;border-color:#8b7355}.code-card:disabled{opacity:.7;cursor:not-allowed}.code-title{font-size:.86rem;font-weight:600}.code-status{font-size:.75rem;font-weight:700}.code-status.ok{color:#38a3a0}.code-status.off{color:#9a9a9a}.form-grid{gap:10px;display:grid}.form-grid label{color:#333;gap:6px;font-size:.85rem;display:grid}.form-grid input{border:1px solid #cfcfcf;border-radius:8px;padding:8px}.panel-breakdown{border-top:1px solid #ececec;margin-top:14px;padding-top:12px}.panel-breakdown h3{letter-spacing:.04em;color:#4f4f4f;margin:0 0 10px;font-size:.78rem}.quote-cta{margin-top:12px;display:flex}.dimension-form-quote-cta{border-top:1px solid #ececec;flex-direction:column;gap:10px;margin-top:16px;padding-top:14px;display:flex}.quote-generated-hint{color:#555;margin:0;font-size:12px;line-height:1.45}.primary-btn{color:#fff;cursor:pointer;background:#8b7355;border:1px solid #8b735599;border-radius:12px;width:100%;padding:10px 12px;font-weight:900}.primary-btn:disabled{opacity:.55;cursor:not-allowed}.primary-btn.primary-btn-quote-black{color:#fff;background:#0b0b0b;border-color:#1a1a1a}.primary-btn.primary-btn-quote-black:hover:not(:disabled){color:#fff;background:#1a1a1a;border-color:#333}.primary-btn.primary-btn-quote-black.is-generated{color:#fff;background:#0b0b0b;border-color:#1a1a1a}.secondary-btn{cursor:pointer;color:#111;background:#fafafa;border:1px solid #d9d9d9;border-radius:12px;padding:10px 12px;font-weight:800}.secondary-btn:disabled{opacity:.55;cursor:not-allowed}.history-list{gap:12px;display:grid}.quote-card{background:#fff;border:1px solid #ececec;border-radius:14px;gap:10px;padding:12px;display:grid}.quote-top{justify-content:space-between;align-items:flex-start;gap:10px;display:flex}.quote-commercial{letter-spacing:.02em;color:#111;margin-top:0;font-size:.88rem;font-weight:800;line-height:1.25}.quote-fefco-sub{color:#7a8798;letter-spacing:.03em;margin-top:4px;font-size:.78rem;font-weight:500;line-height:1.25}.quote-sub{color:#666;margin-top:4px;font-size:.85rem;font-weight:800}.quote-date{color:#777;margin-top:6px;font-size:.78rem;font-weight:700}.quote-actions{grid-template-columns:1fr 1fr;gap:10px;display:grid}.breakdown-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px 12px;display:grid}.breakdown-grid span{color:#666;margin-bottom:2px;font-size:.78rem;display:block}.breakdown-grid strong{color:#111;font-size:1.05rem}.viewer-header{justify-content:space-between;align-items:baseline;gap:8px;margin-bottom:8px;display:flex}.dieline-svg{background:#fff;border:1px solid #ececec;border-radius:8px;width:100%;height:420px}.canvas-host{background:#f0ede8;border:1px solid #ececec;border-radius:8px;width:100%;height:360px;overflow:hidden}.viewer3d-controls{align-items:center;gap:10px;margin-bottom:8px;display:flex}.viewer3d-label{color:#666;white-space:nowrap;font-size:12px}.viewer3d-slider{accent-color:#3b82f6;flex:1}.tabs-panel{padding:10px}.tabs{grid-template-columns:1fr 1fr;gap:8px;display:grid}.tab{color:#111;cursor:pointer;background:#fafafa;border:1px solid #cfcfcf;border-radius:10px;padding:10px 12px;font-weight:700}.tab.active{background:#f8f2ea;border-color:#8b7355}.tab:disabled{opacity:.6;cursor:not-allowed}.login-screen{background:linear-gradient(160deg,#1a1a1a 0%,#2d2520 45%,#1e1c1a 100%);place-items:center;min-height:100vh;padding:24px;display:grid}.login-card{background:#fafafa;border-radius:18px;width:min(420px,100%);padding:28px 26px 30px;box-shadow:0 24px 60px #00000059}.login-brand{text-align:center;margin-bottom:22px}.login-logo{width:180px;height:auto;margin-bottom:10px;display:inline-block}.login-sub{color:#555;margin:8px 0 0;font-size:.88rem;line-height:1.4}.login-form{gap:14px;display:grid}.login-label{color:#333;gap:6px;font-size:.82rem;font-weight:800;display:grid}.login-input{background:#fff;border:1px solid #ccc;border-radius:10px;padding:11px 12px;font-size:1rem}.login-input:focus{outline-offset:1px;border-color:#8b7355;outline:2px solid #8b7355}.login-checkbox-row{color:#333;cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:10px;font-size:.88rem;font-weight:700;display:flex}.login-checkbox{accent-color:#0b0b0b;cursor:pointer;width:1.05rem;height:1.05rem}.login-error{color:#b00020;margin:0;font-size:.85rem;font-weight:700}.login-submit{appearance:none;cursor:pointer;color:#fff;background:#0b0b0b;border:none;border-radius:12px;margin-top:4px;padding:12px 16px;font-size:.95rem;font-weight:900}.login-submit:hover:not(:disabled){background:#222}.login-submit:disabled{opacity:.65;cursor:not-allowed}@media (width<=1100px){.app-shell{grid-template-columns:1fr}.side-menu{display:none}.layout,.content-grid{grid-template-columns:1fr}.top-catalog .code-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.breakdown-grid{grid-template-columns:1fr}}
