:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--bg:#f7f2ea;--wall:#fbf7f0;--ink:#312519;--muted:#796c5f;--line:#513c262e;--panel:#fffbf4e6;--panel-solid:#fffaf2;--teal:#004f45;--teal-2:#0a6a5c;--lemon:#f4d84f;--lemon-deep:#d8a82d;--leaf:#537d35;--brass:#c8953e;--danger:#94443e;--shadow:0 24px 80px #31251929;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Microsoft YaHei,Hiragino Sans GB,Arial,sans-serif}*{box-sizing:border-box}body{min-width:320px;min-height:100vh;color:var(--ink);background:radial-gradient(circle at 92% 11%, #f4d84f42, transparent 13rem), radial-gradient(circle at 6% 85%, #376b3a2e, transparent 18rem), radial-gradient(circle at 83% 34%, #c8953e24, transparent 20rem), linear-gradient(180deg, var(--wall), var(--bg));margin:0}button,input,select,textarea{font:inherit}button{cursor:pointer}.app-shell{min-height:100vh}.topbar{z-index:20;border-bottom:1px solid var(--line);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#fbf7f0d6;grid-template-columns:auto minmax(220px,330px) minmax(280px,1fr) auto;align-items:center;gap:22px;min-height:78px;padding:12px 30px;display:grid;position:sticky;top:0}.menu-button{border-right:1px solid var(--line);border-radius:0;padding-right:25px}.brand-lockup{align-items:center;gap:0;min-width:0;display:flex}.brand-lockup h1{letter-spacing:0;margin:0;font-family:"Bodoni 72",Didot,Georgia,Songti SC,serif;font-size:36px;font-weight:700;line-height:.95}.search-box{border:1px solid var(--line);background:#fffdf8d1;border-radius:8px;justify-self:center;align-items:center;gap:12px;width:min(100%,560px);min-height:45px;padding:0 14px;display:flex;box-shadow:0 10px 28px #4b37220f}.search-box input{min-width:0;color:var(--ink);background:0 0;border:0;outline:0;flex:1;font-size:14px}.search-box kbd{border:1px solid var(--line);min-width:38px;color:var(--muted);text-align:center;background:#eee6db;border-radius:6px;padding:4px 8px;font-size:12px}.topbar-actions{justify-content:flex-end;align-items:center;gap:12px;display:flex}.icon-button,.soft-button,.primary-button{border:1px solid var(--line);color:var(--ink);background:#fffcf7db;border-radius:8px;justify-content:center;align-items:center;transition:transform .16s,border-color .16s,background .16s,box-shadow .16s;display:inline-flex}.icon-button{color:#674621;width:42px;height:42px;padding:0}.soft-button,.primary-button{gap:9px;min-height:45px;padding:0 17px;font-size:14px;font-weight:650}.primary-button{background:var(--teal);color:#fffdf7;border-color:#004f4547;box-shadow:0 14px 30px #004f4533}.icon-button:hover,.soft-button:hover,.primary-button:hover{border-color:#67462159;transform:translateY(-1px);box-shadow:0 12px 28px #4b37221a}.danger{color:var(--danger)}.workspace{grid-template-columns:minmax(0,1fr) minmax(330px,390px);gap:clamp(24px,3vw,42px);width:min(1500px,100% - 48px);margin:0 auto;padding:24px 0 34px;display:grid}.cabinet-zone{min-width:0;padding-bottom:18px;position:relative}.cabinet-zone:before{content:"";z-index:0;opacity:.82;background:linear-gradient(140deg,#f4d84fe6,#fbf6dab3),linear-gradient(#fffaf0,#ead9bd);border:8px solid #b78043;border-radius:4px;width:92px;height:118px;position:absolute;top:125px;left:-18px;box-shadow:0 18px 38px #37221121}.cabinet-zone:after{content:"";z-index:0;background:radial-gradient(at 50% 10%,#ffffffb8,#0000 1.5rem),#e9dfca;border-radius:48px 48px 12px 12px;width:96px;height:110px;position:absolute;bottom:24px;left:-28px;box-shadow:inset 0 -20px #87693829,0 18px 38px #37221129}.cabinet{z-index:1;min-height:calc(100vh - 130px);box-shadow:inset 0 0 0 5px #6c3d18bd, inset 0 0 0 12px #c57d3957, var(--shadow);background:linear-gradient(90deg,#5a30129e,#0000 3.4% 96.4%,#43220ca8),repeating-linear-gradient(88deg,#7d491e21 0 2px,#d38a4114 2px 8px),linear-gradient(110deg,#8d521f,#b97534 22%,#7b4219 62%,#aa672b);border-radius:8px;padding:25px 44px 88px;position:relative;overflow:hidden}.cabinet:after{content:"";z-index:3;filter:blur(5px);background:#1b0d0538;border-radius:999px;width:94px;height:15px;position:absolute;bottom:112px;left:52px}.cabinet:before{content:"";background:radial-gradient(circle at 40% 12%,#ffdf9b47,#0000 7rem),radial-gradient(circle at 77% 10%,#ffdf9b2e,#0000 9rem),repeating-linear-gradient(93deg,#ffd59114 0 1px,#0000 1px 9px),linear-gradient(#40200ce0,#5c3013ed);border:1px solid #2a170b6b;border-radius:6px;position:absolute;inset:22px 32px 74px;box-shadow:inset 0 22px 55px #140a0375}.cabinet-crown{background:repeating-linear-gradient(96deg,#4e291040 0 2px,#0000 2px 8px),linear-gradient(#d08a44,#8a4c1e);border-radius:5px;height:17px;position:absolute;top:9px;left:32px;right:32px;box-shadow:0 4px 7px #190a005c,inset 0 2px 2px #ffe8ab66}.cabinet-inner{z-index:2;grid-template-rows:repeat(4,minmax(143px,1fr));gap:20px;min-height:calc(100vh - 245px);display:grid;position:relative}.shelf-block{min-height:143px;position:relative}.shelf-label{z-index:8;background:color-mix(in srgb, var(--shelf-accent), #8b5a28 34%);color:#fff7e8;border:1px solid #f9e2ab42;border-radius:7px;align-items:center;gap:8px;min-height:36px;padding:0 12px;font-size:14px;font-weight:650;display:inline-flex;position:absolute;top:4px;left:50%;transform:translate(-50%);box-shadow:0 8px 20px #1f0e0440}.shelf-label strong{background:#fff0cc33;border-radius:999px;justify-content:center;align-items:center;min-width:24px;height:24px;font-size:12px;display:inline-flex}.shelf-stage{border-inline:1px solid #2b15081f;position:absolute;inset:0 0 18px}.wood-shelf-front{z-index:7;background:repeating-linear-gradient(96deg,#4b240c38 0 1px,#0000 1px 10px),linear-gradient(#ce843f,#7f431a);border-radius:4px;height:25px;position:absolute;bottom:0;left:-7px;right:-7px;box-shadow:0 8px 18px #11080370,inset 0 2px 2px #ffe39d42,inset 0 -3px 5px #2c120552}.book-tile{z-index:5;width:clamp(66px,7.2vw,86px);height:clamp(105px,11.4vw,132px);transform:translateX(-50%) rotate(var(--book-tilt));touch-action:none;background:0 0;border:0;border-radius:2px 5px 5px 2px;padding:0;transition:transform .16s,filter .16s,opacity .16s;position:absolute;bottom:20px;box-shadow:12px 12px 18px #150b0552}.book-tile img{object-fit:cover;pointer-events:none;background:#e8d3ad;border-radius:2px 5px 5px 2px;width:100%;height:100%;display:block;box-shadow:inset 7px 0 #ffffff2e,0 0 0 1px #1d0e064d}.book-tile:after{content:"";pointer-events:none;background:linear-gradient(90deg,#10060252,#ffffff14);border-radius:2px 0 0 2px;width:12px;position:absolute;inset:0 auto 0 0}.book-tile.selected{filter:drop-shadow(0 0 .55rem #fae9b18c)}.book-tile.dragging{z-index:18;filter:drop-shadow(0 18px 20px #00000052);transform:translate(-50%)translateY(-12px)scale(1.03)rotate(0)}.book-tile.dimmed{opacity:.24;filter:grayscale(.35)}.book-status{z-index:2;background:var(--status-color);border:2px solid #fff7e8;border-radius:50%;width:14px;height:14px;position:absolute;top:-8px;right:-7px;box-shadow:0 3px 9px #00000047}.book-spine{color:#fff7e8;text-align:left;background:#231409c2;border-radius:6px;width:105px;padding:6px 7px;font-size:11px;line-height:1.25;display:none;position:absolute;bottom:5px;right:calc(100% + 8px)}.book-tile:hover .book-spine{display:block}.add-book-slot{z-index:4;color:#fff2cc;background:#4b2a1147;border:1px dashed #fff2ce80;border-radius:7px;flex-direction:column;justify-content:center;align-items:center;gap:9px;width:clamp(64px,7vw,84px);height:clamp(105px,11.4vw,132px);font-size:12px;font-weight:650;display:inline-flex;position:absolute;bottom:20px;right:8%}.add-book-slot:hover{background:#6a401861}.hanging-plant{z-index:5;pointer-events:none;width:60px;height:160px;position:absolute;top:21px;left:46px}.hanging-plant:before{content:"";background:linear-gradient(#446b35,#0000);width:2px;height:152px;position:absolute;top:0;left:29px}.hanging-plant span{top:var(--leaf-top);left:var(--leaf-left);width:22px;height:13px;transform:rotate(var(--leaf-rotate));background:linear-gradient(135deg,#6ea14d,#2f642f);border-radius:100% 0;position:absolute;box-shadow:0 3px 6px #00000038}.lemon-vine{z-index:3;pointer-events:none;width:142px;height:78px;position:absolute;top:35px;right:64px}.lemon-vine:before{content:"";border-top:3px solid #4c7032d1;border-radius:50%;height:42px;position:absolute;inset:8px 2px auto;transform:rotate(-8deg)}.lemon-vine span{background:radial-gradient(circle at 33% 31%,#ffffffad,#0000 .32rem),linear-gradient(135deg,#f8e36d,#d4a521);border:2px solid #5f64238c;border-radius:55% 45%;width:24px;height:18px;position:absolute;transform:rotate(-17deg);box-shadow:0 6px 10px #210f0438}.lemon-vine span:first-child{top:5px;left:4px}.lemon-vine span:nth-child(2){top:28px;left:31px}.lemon-vine span:nth-child(3){top:3px;left:62px}.lemon-vine span:nth-child(4){top:31px;left:91px}.lemon-vine span:nth-child(5){top:8px;left:116px}.wall-frame{z-index:4;pointer-events:none;position:absolute}.lemon-study{background:radial-gradient(circle at 32% 35%,#f4d84fe0 0 14px,#0000 15px),radial-gradient(circle at 58% 44%,#f4d84fb8 0 13px,#0000 14px),repeating-linear-gradient(90deg,#007bb861 0 6px,#0000 6px 16px),linear-gradient(#fffdefeb,#ecd6aad6);border:7px solid #975b25eb;border-radius:4px;width:96px;height:118px;top:158px;right:31px;box-shadow:0 18px 24px #180b0447,inset 0 0 0 1px #fff5d29e}.lemon-study span{background:var(--lemon);border:2px solid #777138;border-radius:56% 44%;width:42px;height:30px;position:absolute;top:38px;left:26px;transform:rotate(-13deg)}.lemon-study strong{background:var(--leaf);border-radius:100% 0;width:28px;height:15px;position:absolute;top:24px;right:24px;transform:rotate(-20deg)}.lemon-bowl{z-index:5;pointer-events:none;background:linear-gradient(#0000 0 29%,#fffae3f0 30%),linear-gradient(135deg,#b57b3b,#f3d49b);border-radius:0 0 46px 46px;width:92px;height:58px;position:absolute;bottom:92px;left:54px;box-shadow:inset 0 -10px 12px #764a1f38,0 13px 22px #140a0457}.lemon-bowl i{background:radial-gradient(circle at 32% 29%,#ffffff9e,#0000 .35rem),linear-gradient(135deg,#f9e66e,#d2a421);border:2px solid #6a69268f;border-radius:55% 45%;width:30px;height:22px;position:absolute;top:3px}.lemon-bowl i:first-child{left:12px;transform:rotate(14deg)}.lemon-bowl i:nth-child(2){top:-3px;left:31px;transform:rotate(-12deg)}.lemon-bowl i:nth-child(3){right:12px;transform:rotate(9deg)}.cabinet-base{z-index:10;color:#fff3d6;grid-template-columns:auto 1fr auto;align-items:center;gap:18px;font-size:13px;display:grid;position:absolute;bottom:17px;left:20px;right:20px}.cabinet-base p{text-align:center;text-shadow:0 1px 2px #00000080;justify-content:center;align-items:center;gap:8px;margin:0;display:inline-flex}.cabinet-base span{color:#ffe5b0;justify-self:end}.view-switcher{min-height:44px;color:var(--ink);background:#fffcf6db;border:1px solid #ffeec780;border-radius:999px;align-items:center;padding:4px;display:inline-flex;box-shadow:0 12px 24px #15090238}.view-switcher button{color:#6b4a25;background:0 0;border:0;border-radius:999px;align-items:center;gap:8px;min-height:34px;padding:0 13px;font-size:13px;font-weight:700;display:inline-flex}.view-switcher .active{background:var(--teal);color:#fffdf7}.details-panel{border:1px solid var(--line);background:var(--panel);min-height:560px;max-height:calc(100vh - 122px);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-radius:8px;align-self:start;padding:28px 24px 22px;position:sticky;top:102px;overflow:auto}.panel-toolbar{justify-content:flex-end;gap:9px;margin-bottom:11px;display:flex}.book-summary{grid-template-columns:106px 1fr;align-items:start;gap:22px;margin-bottom:24px;display:grid}.book-summary img{aspect-ratio:.68;object-fit:cover;border-radius:5px;width:106px;box-shadow:0 16px 32px #36251538}.book-summary h2{letter-spacing:0;margin:14px 0 7px;font-family:"Bodoni 72",Didot,Georgia,Songti SC,serif;font-size:28px;line-height:1}.book-summary p{color:#5d5148;margin:0 0 15px;font-size:15px;line-height:1.42}.source-note{color:#816039;background:#c6974521;border-radius:999px;max-width:100%;padding:5px 9px;font-size:11px;line-height:1.25;display:inline-flex}.field{gap:8px;margin-bottom:17px;display:grid}.field>span,.book-form label>span,.shelf-form label>span{color:#77675a;font-size:12px;font-weight:700}.field select,.field input,.field textarea,.book-form input,.book-form select,.book-form textarea,.shelf-form input{border:1px solid var(--line);width:100%;color:var(--ink);background:#fffdf8c7;border-radius:8px;outline:0}.field select,.field input,.book-form input,.book-form select,.shelf-form input{min-height:43px;padding:0 12px}.field textarea,.book-form textarea{resize:vertical;min-height:116px;padding:12px;line-height:1.45}.field em{color:var(--muted);justify-self:end;margin-top:-4px;font-size:11px;font-style:normal}.date-input{border:1px solid var(--line);background:#fffdf8c7;border-radius:8px;align-items:center;gap:9px;padding:0 12px;display:flex}.date-input input{background:0 0;border:0;padding:0}.rating-row{border:1px solid var(--line);background:#fffdf8c7;border-radius:8px;align-items:center;gap:6px;min-height:58px;padding:0 12px;display:flex}.rating-row button{color:#b8ab9b;background:0 0;border:0;width:34px;height:34px;padding:0}.rating-row .filled{color:var(--brass)}.empty-panel{text-align:center;align-content:center;place-items:center;gap:12px;display:grid}.empty-panel h2{margin:0;font-family:"Bodoni 72",Didot,Georgia,Songti SC,serif;font-size:30px}.empty-panel p{max-width:270px;color:var(--muted);margin:0;line-height:1.5}.modal-backdrop{z-index:80;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#2c20155c;place-items:center;padding:24px;display:grid;position:fixed;inset:0}.modal-card{background:var(--panel-solid);border:1px solid #4b341f33;border-radius:8px;width:min(760px,100%);max-height:min(850px,100vh - 48px);padding:24px;overflow:auto;box-shadow:0 32px 90px #22140a47}.modal-head{justify-content:space-between;align-items:center;gap:18px;margin-bottom:20px;display:flex}.modal-head h2{margin:0;font-family:"Bodoni 72",Didot,Georgia,Songti SC,serif;font-size:34px;line-height:1}.book-form,.shelf-form{gap:17px;display:grid}.lookup-row{grid-template-columns:minmax(0,1fr) auto;align-items:end;gap:12px;display:grid}.book-form label,.shelf-form label{gap:8px;display:grid}.form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;display:grid}.cover-results{grid-auto-columns:112px;grid-auto-flow:column;gap:12px;padding:4px 2px 10px;display:grid;overflow-x:auto}.cover-results button{color:var(--ink);text-align:left;background:#f0e5d58a;border:1px solid #0000;border-radius:8px;gap:8px;padding:8px;display:grid}.cover-results button.selected{background:#004f451a;border-color:#004f457a}.cover-results img{aspect-ratio:.68;object-fit:cover;border-radius:4px;width:100%}.cover-results span,.cover-results small{-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.cover-results span{-webkit-line-clamp:2;min-height:32px;font-size:12px;font-weight:750;line-height:1.25}.cover-results small{-webkit-line-clamp:1;color:var(--muted);font-size:11px}.dialog-actions{justify-content:flex-end;gap:12px;margin-top:3px;display:flex}.form-error{color:var(--danger);margin:-5px 0 0;font-size:13px}.topbar{background:#fffbf4e6;min-height:72px;box-shadow:0 8px 24px #4f341d14}.brand-lockup h1{color:#6b4928;font-size:40px}.workspace{grid-template-columns:minmax(740px,1fr) minmax(310px,370px);gap:24px;width:min(1520px,100% - 42px);padding-top:10px}.cabinet-zone{padding:12px 76px 22px 96px;overflow:visible}.cabinet-zone:before,.cabinet-zone:after{display:none}.room-art{z-index:0;background:linear-gradient(#fff9ebe6,#e7d3b4d1),linear-gradient(135deg,#0000 48%,#63533d38 49% 53%,#0000 54%);border:9px solid #b2783d;width:88px;height:170px;position:absolute;box-shadow:0 18px 36px #4327122e}.left-art{top:160px;left:10px}.side-plant{z-index:3;pointer-events:none;background:radial-gradient(at 50% 100%,#eee1cc 0 28%,#0000 30%),linear-gradient(#0000 0 57%,#a87443 58% 100%);border-radius:58px 58px 16px 16px;width:118px;height:184px;position:absolute;bottom:68px;left:7px}.side-plant:before{content:"";background:#54723c;width:2px;height:112px;position:absolute;bottom:42px;left:48px;box-shadow:-24px 20px #54723c,22px 15px #54723c}.side-plant span{background:linear-gradient(135deg,#6a8f48,#254f2e);border-radius:80% 0;width:39px;height:20px;position:absolute;box-shadow:0 6px 13px #22160c33}.side-plant span:first-child{top:22px;left:15px;transform:rotate(-34deg)}.side-plant span:nth-child(2){top:24px;left:55px;transform:rotate(28deg)}.side-plant span:nth-child(3){top:48px;left:28px;transform:rotate(-18deg)}.side-plant span:nth-child(4){top:54px;left:67px;transform:rotate(36deg)}.side-plant span:nth-child(5){top:78px;left:8px;transform:rotate(-42deg)}.side-plant span:nth-child(6){top:84px;left:60px;transform:rotate(18deg)}.side-plant span:nth-child(7){top:104px;left:30px;transform:rotate(-12deg)}.side-plant span:nth-child(8){top:112px;left:74px;transform:rotate(35deg)}.side-plant span:nth-child(9){top:128px;left:14px;transform:rotate(-30deg)}.side-plant span:nth-child(10){top:139px;left:53px;transform:rotate(20deg)}.side-plant span:nth-child(11){top:70px;left:38px;transform:rotate(12deg)}.side-plant span:nth-child(12){top:110px;left:2px;transform:rotate(-8deg)}.floor-lamp{z-index:3;pointer-events:none;width:112px;height:270px;position:absolute;bottom:36px;right:5px}.floor-lamp:before{content:"";background:linear-gradient(90deg,#83552e,#d7a564,#6b421f);border-radius:999px;width:5px;height:164px;position:absolute;bottom:0;right:49px}.floor-lamp span{background:radial-gradient(circle at 50% 62%,#ffecb2d1,#0000 3.6rem),linear-gradient(#fff1d2,#d8b482);border-radius:50% 50% 28px 28px;width:96px;height:92px;position:absolute;top:0;right:8px;box-shadow:0 22px 55px #ffd17f75}.floor-lamp strong{background:#6d4526;border-radius:999px;width:52px;height:12px;position:absolute;bottom:0;right:28px}.cabinet{background:linear-gradient(90deg,#3a1e0ce0,#0000 4.4% 95.6%,#3b1e0be0),repeating-linear-gradient(90deg,#43220d57 0 2px,#0000 2px 13px),linear-gradient(112deg,#8d5426,#c07a37 18%,#8b4d21 55%,#b57132);border-radius:4px;min-height:calc(100vh - 96px);padding:54px 74px 118px;box-shadow:inset 0 0 0 7px #592f13e0,inset 0 0 0 18px #b96f307a,0 30px 80px #462a1652}.cabinet:before{background:radial-gradient(at 28% 2%,#ffdb8b3d,#0000 9rem),radial-gradient(at 73% 2%,#ffdb8b3d,#0000 9rem),repeating-linear-gradient(93deg,#ffe8b60e 0 1px,#0000 1px 11px),repeating-linear-gradient(0deg,#2f17080f 0 2px,#0000 2px 9px),linear-gradient(#4a260e 0%,#6f3a18 48%,#5a2d11 100%);border-radius:3px;inset:42px 58px 112px;box-shadow:inset 0 20px 48px #0e0702b3,inset 0 -10px 24px #ffca7e0f}.cabinet:after{display:none}.cabinet-crown{background:repeating-linear-gradient(94deg,#34180852 0 2px,#0000 2px 12px),linear-gradient(#d59655,#8c4b1f 76%,#5b2b0e);border-radius:3px 3px 7px 7px;height:27px;top:13px;left:42px;right:42px}.cabinet-lights{z-index:4;pointer-events:none;justify-content:space-around;display:flex;position:absolute;top:47px;left:58px;right:58px}.cabinet-lights span{filter:drop-shadow(0 12px 30px #ffc559bf);background:radial-gradient(#fff8d4 0 36%,#e1a94b 55%,#0000 70%);border-radius:50%;width:40px;height:13px}.shelf-stage{border-inline:0;inset:0 0 18px}.shelf-label{background:linear-gradient(180deg, color-mix(in srgb, var(--shelf-accent), #bd8a43 42%), #8a551f);border-radius:6px;min-height:34px;top:0;box-shadow:0 7px 18px #150a0347}.book-tile:hover,.book-tile.selected{transform:translate(-50%)translateY(-5px)rotate(0)}.add-book-slot{background:#40200c38;border:1px dashed #ffebbe6b;width:clamp(64px,6.8vw,82px);height:clamp(98px,10.4vw,128px);bottom:18px;right:15%}.hanging-plant{height:234px;top:27px;left:62px}.hanging-plant:before{background:linear-gradient(#334c24,#334c241a);height:224px;left:30px}.hanging-plant span{background:linear-gradient(135deg,#7b9c58,#315b2e);width:29px;height:16px}.lemon-garland{z-index:5;pointer-events:none;border-top:2px solid #506d2dd1;align-items:center;gap:14px;padding-top:7px;display:flex;position:absolute;top:76px;right:82px}.lemon-garland img{object-fit:contain;filter:drop-shadow(0 5px 5px #170b0347);width:24px;height:24px;transform:rotate(var(--lemon-rotate))}.wall-frame{z-index:6}.lemon-study{background:repeating-linear-gradient(90deg,#3e96ae61 0 7px,#fff6 7px 16px),linear-gradient(#fff8e8,#e2c79a);border:7px solid #9a5b26f5;width:88px;height:108px;top:170px;right:45px}.lemon-study img{filter:drop-shadow(0 5px 5px #49280d38);width:40px;height:40px;position:absolute;top:26px;left:21px}.lemon-bowl{z-index:8;background:linear-gradient(#0000 0 34%,#fff7e1f5 35%),linear-gradient(135deg,#a46531,#e5c187);bottom:94px;left:58px}.lemon-bowl img{object-fit:contain;filter:drop-shadow(0 5px 4px #482c1040);width:28px;height:28px;position:absolute;top:-1px}.lemon-bowl img:first-child{left:12px;transform:rotate(14deg)}.lemon-bowl img:nth-child(2){top:-6px;left:31px;transform:rotate(-10deg)}.lemon-bowl img:nth-child(3){right:13px;transform:rotate(9deg)}.cabinet-drawers{z-index:4;background:repeating-linear-gradient(90deg,#3b1c0a33 0 2px,#0000 2px 10px),linear-gradient(#a9652c,#7e431a);border-top:3px solid #48220cb8;grid-template-columns:repeat(4,1fr);height:58px;display:grid;position:absolute;bottom:58px;left:58px;right:58px;box-shadow:inset 0 5px 11px #ffd4922e}.cabinet-drawers span{border-left:2px solid #3e1c0985;border-right:1px solid #e09e5447;position:relative}.cabinet-drawers span:after{content:"";background:radial-gradient(circle at 35% 35%,#201209,#050302);border-radius:50%;width:10px;height:10px;position:absolute;bottom:15px;left:50%;transform:translate(-50%)}.details-panel{background:#fffbf4d1}body{background:linear-gradient(90deg,#dfcbb0db 0 9%,#0000 18% 82%,#e1cdb0c7 91%),radial-gradient(at 50% 0,#fff7e5f2,#f5e7d2db 54%,#e9d5ba 100%)}.topbar{background:#fffcf6f0;border-bottom-color:#6143262e;min-height:68px;box-shadow:0 10px 24px #4a301b14}.workspace{gap:18px;width:min(1480px,100% - 22px);padding-top:8px}.cabinet-zone{padding:38px 84px 28px 128px}.room-art{background:linear-gradient(145deg,#fffcf2db,#decbaebd),radial-gradient(at 44% 44%,#5647342e,#0000 42%);border:10px solid #b07a42;box-shadow:0 20px 42px #462c172e}.left-art{width:86px;height:156px;top:210px;left:22px}.right-art{width:72px;height:118px;top:190px;right:14px}.wall-art-layer{z-index:0;pointer-events:none;position:absolute;inset:0}.wall-art-piece{z-index:0;width:96px;height:128px;transform:translate(-50%, -50%) rotate(var(--art-tilt,0deg));pointer-events:auto;touch-action:none;cursor:grab;background:linear-gradient(145deg,#ffdc9738,#3a190642),url(/textures/ref-oak-frame.png) 0 0/240px 320px;border:0;border-radius:2px;padding:8px;transition:box-shadow .16s,transform .16s,filter .16s;position:absolute;box-shadow:0 20px 38px #462c1733,inset 0 0 0 1px #4e240c6b,inset 0 0 0 5px #b8743770}.wall-art-piece:hover,.wall-art-piece.dragging{filter:saturate(1.04);box-shadow:0 28px 48px #462c1745,inset 0 0 0 1px #4e240c6b,inset 0 0 0 5px #b8743780}.wall-art-piece.dragging{z-index:18;cursor:grabbing;transform:translate(-50%,-50%)rotate(0)scale(1.035)}.art-small{--art-tilt:1.5deg;width:76px;height:98px}.art-medium{--art-tilt:-1deg;width:92px;height:118px}.art-tall{--art-tilt:.8deg;width:94px;height:156px}.art-wide{--art-tilt:-.6deg;width:118px;height:110px}.art-canvas{background:#efe0c5;border:1px solid #5c3d212e;width:100%;height:100%;display:block;position:relative;overflow:hidden;box-shadow:inset 0 0 0 5px #fff8e7b8,inset 0 0 26px #54351b1f}.art-canvas:after{content:"";pointer-events:none;background:linear-gradient(135deg,#ffffff6b,#0000 38%,#5332191a);position:absolute;inset:0}.wall-art-piece i,.wall-art-piece b{display:block;position:absolute}.art-mountain .art-canvas{background:linear-gradient(#ebe0ccf0,#c6b598e6),linear-gradient(145deg,#0000 45%,#5848376b 46% 62%,#0000 63%)}.art-mountain i{clip-path:polygon(0 100%,28% 42%,43% 70%,62% 25%,100% 100%);background:linear-gradient(#9e927c,#6d604d);height:42px;bottom:24px;left:8px;right:8px}.art-mountain b{background:linear-gradient(90deg,#50463838,#84735647);height:18px;bottom:10px;left:10px;right:10px}.art-botanical .art-canvas{background:radial-gradient(at 50% 92%,#72774629,#0000 42%),linear-gradient(#fff8e8,#ead9bc)}.art-botanical i{background:#425e2c9e;width:2px;height:66px;top:20px;left:42%;transform:rotate(-8deg)}.art-botanical b{background:#5f803e9e;border-radius:90% 0;width:30px;height:18px;top:29px;left:33px;transform:rotate(-28deg);box-shadow:-16px 19px #5377398c,13px 31px #728f4b80}.art-lemon .art-canvas{background:repeating-linear-gradient(90deg,#2d7d924d 0 7px,#ffffffc2 7px 16px),linear-gradient(#fff9e8,#e5cf9e)}.art-lemon img{z-index:2;filter:drop-shadow(0 5px 6px #4a2b0c38);pointer-events:none;width:43px;height:43px;position:absolute;top:35%;left:48%;transform:translate(-50%,-50%)rotate(-12deg)}.art-lemon i{background:#497d37b8;border-radius:100% 0;width:24px;height:13px;top:26px;right:22px;transform:rotate(-24deg)}.art-lemonTree{padding:9px}.art-lemonTree .art-canvas{background:#e7d4aa;box-shadow:inset 0 0 0 4px #fff9e7b8,inset 0 0 16px #391f0c24}.art-lemonTree .art-image{object-fit:cover;object-position:center;pointer-events:none;filter:saturate(1.03)contrast(1.02);width:calc(100% - 10px);height:calc(100% - 10px);position:absolute;inset:5px}.art-lemonTree i,.art-lemonTree b{display:none}.art-coast .art-canvas{background:radial-gradient(at 78% 28%,#ffe789a3,#0000 14%),linear-gradient(#7ec5cf 0 43%,#2f8da1 44% 62%,#efe2bf 63% 100%)}.art-coast i{background:linear-gradient(135deg,#ffffff9e,#fff0 66%);height:24px;bottom:28px;left:0;right:0}.art-coast b{clip-path:polygon(0 100%,50% 20%,100% 100%);background:#e3884ecc;width:43px;height:21px;bottom:13px;left:11px}.side-plant{filter:drop-shadow(0 18px 22px #3a24142e);background:radial-gradient(at 50% 90%,#f1eadb 0 27%,#c7ad85 28% 37%,#0000 38%),linear-gradient(#0000 0 62%,#80532e 63% 100%);width:128px;height:226px;bottom:78px;left:28px}.side-plant span{background:radial-gradient(at 32% 34%,#ffffff38,#0000 34%),linear-gradient(135deg,#7ea157,#244d2c 72%);border-radius:80% 10%;width:45px;height:24px}.floor-lamp{filter:drop-shadow(-14px 18px 20px #4a2f1829);height:292px;bottom:48px;right:18px}.floor-lamp span{background:radial-gradient(circle at 50% 68%,#fff1c6e6,#0000 4.2rem),linear-gradient(#fff5dc,#d4ad77);width:106px;height:103px;box-shadow:0 22px 58px #ffd2817a}.cabinet{background:linear-gradient(90deg,#301607b3,#0000 9% 91%,#2d1407b8),linear-gradient(#ffd9911f,#2d150724),url(/textures/ref-oak-frame.png) 0 0/380px 720px;border-radius:2px;min-height:calc(100vh - 74px);padding:72px 86px 132px;overflow:visible;box-shadow:inset 0 0 0 7px #4e240ceb,inset 0 0 0 25px #b0672a9e,inset 0 0 0 44px #4c220b94,0 26px 72px #39221259}.cabinet:before{background:radial-gradient(at 30% 6%,#ffcd742e,#0000 10rem),radial-gradient(at 73% 4%,#ffcd7429,#0000 10rem),linear-gradient(90deg,#1006026b,#0000 18% 82%,#10060261),linear-gradient(#0a040147,#0000 16% 84%,#0a040152),url(/textures/ref-walnut-back.png) 0 0/680px 520px;border:1px solid #160903b8;border-radius:1px;inset:48px 64px 126px;box-shadow:inset 0 34px 60px #0a0401b8,inset 0 -18px 34px #0000006b,inset 22px 0 36px #00000047,inset -22px 0 36px #00000047}.cabinet-crown{background:linear-gradient(#ffd98e47,#3616052e),url(/textures/ref-oak-shelf-front.png) 0 0/620px 100%;border-radius:5px 5px 2px 2px;height:46px;top:-24px;left:-18px;right:-18px;box-shadow:0 9px 14px #14080275,inset 0 3px 2px #ffe0a480,inset 0 -9px 12px #36160580}.cabinet-crown:after{content:"";background:linear-gradient(#7a3912,#3b1604);border-radius:0 0 4px 4px;height:14px;position:absolute;bottom:-12px;left:16px;right:16px;box-shadow:0 8px 15px #10050161}.cabinet-lights{z-index:9;top:42px;left:76px;right:76px}.cabinet-lights span{filter:drop-shadow(0 18px 30px #ffc255b8);background:radial-gradient(#fff7d4 0 29%,#e7b35e 52%,#e3a64800 73%);width:46px;height:15px}.cabinet-inner{grid-template-rows:repeat(5,minmax(128px,1fr));gap:0;min-height:calc(100vh - 254px)}.shelf-block{min-height:128px}.shelf-stage{inset:0 4px 30px}.shelf-label{background:linear-gradient(#bc7d37e6,#754519f0),url(/textures/ref-oak-shelf-front.png) 0 0/260px 60px;border:1px solid #ffd99747;border-radius:7px;min-height:36px;top:-5px;box-shadow:0 9px 16px #10060161,inset 0 1px #ffe7ae47}.wood-shelf-front{background:linear-gradient(#ffdb962e,#250e033d),url(/textures/ref-oak-shelf-front.png) 0 0/760px 100%;border-radius:1px;height:33px;left:-38px;right:-38px;box-shadow:0 14px 23px #0a04019e,inset 0 3px 2px #ffe19d70,inset 0 -8px 12px #2b100485}.wood-shelf-front:before{content:"";filter:blur(1px);background:#ffcb7e3d;height:7px;position:absolute;top:-7px;left:4px;right:4px}.book-tile{width:clamp(70px,7.1vw,94px);height:clamp(112px,11.3vw,146px);bottom:30px;box-shadow:20px 16px 24px #0803017a,-3px 0 #fff4dc1a}.book-tile img{border-radius:2px 5px 5px 2px;box-shadow:inset 10px 0 11px #ffffff24,inset -6px 0 10px #0003,0 0 0 1px #0f06028c}.book-tile:before{content:"";transform-origin:0 100%;background:linear-gradient(90deg,#1c0c0385,#fff6de2e);border-radius:0 3px 3px 0;width:7px;height:calc(100% - 5px);position:absolute;bottom:1px;right:-6px;transform:skewY(-7deg)}.add-book-slot{background:#27110638;border:1px dashed #eecfa480;width:clamp(70px,7.1vw,94px);height:clamp(112px,11.3vw,146px);bottom:30px;right:17%;box-shadow:inset 0 0 0 1px #ffedca0d}.hanging-plant{z-index:12;height:256px;top:-18px;left:33px}.hanging-plant:before{background:linear-gradient(#28431f,#28431f14);height:255px}.hanging-plant span{background:radial-gradient(at 35% 28%,#ffffff3d,#0000 38%),linear-gradient(135deg,#88a75a,#2e552d 72%);border-radius:90% 10%;width:31px;height:17px}.lemon-garland{display:none}.lemon-study{background:linear-gradient(#fffaece0,#e0ccacc2),repeating-linear-gradient(90deg,#36819559 0 6px,#0000 6px 15px);border-width:8px;width:74px;height:104px;top:214px;right:-58px;box-shadow:0 18px 32px #321d0e3d}.lemon-study img{opacity:.92;width:35px;height:35px;top:27px;left:15px}.lemon-bowl{z-index:14;filter:drop-shadow(0 13px 15px #0f06025c);width:86px;height:54px;bottom:112px;left:42px}.cabinet-drawers{background:linear-gradient(#ffd68b29,#2c11042e),url(/textures/ref-oak-drawers.png) 0 0/720px 100%;border-top:4px solid #361706bd;height:70px;bottom:50px;left:64px;right:64px;box-shadow:inset 0 7px 10px #ffd68b21,inset 0 -12px 18px #290f036b}.cabinet-drawers span{border-left:2px solid #2f120494;border-right:1px solid #eba75638;box-shadow:inset 0 0 0 5px #4a1e0742}.cabinet-base{bottom:8px}.side-plant{z-index:4;filter:drop-shadow(0 18px 20px #2c1a0d2e);background:0 0;border-radius:0;width:168px;height:auto;bottom:54px;left:0}.side-plant:before{display:none}.side-plant img{-webkit-user-select:none;user-select:none;pointer-events:none;width:100%;height:auto;display:block}.floor-lamp{z-index:4;filter:drop-shadow(-12px 18px 18px #482c1629);width:118px;height:auto;bottom:36px;right:-2px}.floor-lamp:before,.floor-lamp span,.floor-lamp strong{display:none}.floor-lamp img{-webkit-user-select:none;user-select:none;pointer-events:none;width:100%;height:auto;display:block}.hanging-plant{z-index:13;filter:drop-shadow(9px 13px 12px #0b050138);width:92px;height:auto;top:-38px;left:26px}.hanging-plant:before,.hanging-plant span{display:none}.hanging-plant img{-webkit-user-select:none;user-select:none;pointer-events:none;width:100%;height:auto;display:block}@media (width<=1180px){.topbar{grid-template-columns:auto 1fr auto}.search-box{grid-area:2/1/auto/-1;justify-self:stretch;width:100%}.workspace{grid-template-columns:1fr}.details-panel{max-height:none;position:static}}@media (width<=760px){.topbar{grid-template-columns:1fr;gap:13px;padding:14px 16px}.menu-button{display:none}.brand-lockup h1{font-size:30px}.topbar-actions{justify-content:stretch}.topbar-actions button{flex:1}.workspace{width:min(100% - 24px,620px);padding-top:15px}.cabinet{min-height:670px;padding:22px 20px 83px}.cabinet:before{inset:20px 16px 76px}.cabinet-inner{grid-template-rows:repeat(5,minmax(104px,1fr));gap:14px;min-height:545px}.shelf-block{min-height:104px}.book-tile,.add-book-slot{width:50px;height:80px}.shelf-label{min-height:30px;font-size:12px;top:0}.hanging-plant,.lemon-garland,.lemon-study,.lemon-bowl,.cabinet-lights,.cabinet-drawers,.room-art,.wall-art-layer,.side-plant,.floor-lamp,.cabinet-zone:before,.cabinet-zone:after{display:none}.cabinet-base{text-align:center;grid-template-columns:1fr;gap:8px}.cabinet-base span,.view-switcher{justify-self:center}.details-panel{padding:21px 16px}.book-summary{grid-template-columns:82px 1fr;gap:15px}.book-summary img{width:82px}.book-summary h2{font-size:24px}.lookup-row,.form-grid{grid-template-columns:1fr}.dialog-actions{flex-direction:column-reverse}.dialog-actions button{width:100%}}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}
