:root{--ink:#16231f;--muted:#64716e;--line:#dfe7e2;--panel:#ffffff;--soft:#f4f7f5;--green:#1f7a68;--green-dark:#16312f;--amber:#cc8d20;--blue:#346fb5;--red:#bd4c3c;--shadow:0 18px 55px rgba(25,44,39,0.12)}*{box-sizing:border-box}html{min-width:320px;background:var(--soft)}body{margin:0;color:var(--ink);background:linear-gradient(180deg,rgba(47,143,131,.08),transparent 340px),var(--soft);font-family:Inter,Noto Sans TC,Microsoft JhengHei,PingFang TC,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}button,input,select{font:inherit}button{cursor:pointer}img{display:block;max-width:100%}.app-shell{width:min(1440px,100%);min-height:100svh;margin:0 auto;padding:22px}.book-meta,.brand,.eyebrow,.metric-row,.panel-heading,.posted-note,.profile-button,.publish-row,.seller-line,.top-actions,.topbar{display:flex;align-items:center}.topbar{justify-content:space-between;gap:16px;margin-bottom:18px}.brand{min-width:0;gap:12px;color:inherit;text-decoration:none}.brand-mark{display:grid;width:44px;height:44px;flex:0 0 auto;place-items:center;color:#ffffff;background:var(--green-dark);border:1px solid rgba(255,255,255,.2);border-radius:8px}.brand small,.brand strong{display:block}.brand strong{font-size:1.04rem}.brand small{color:var(--muted);font-size:.78rem}.top-actions{gap:10px}.icon-button,.primary-button,.profile-button,.secondary-button{border:0;transition:transform .16s ease,border-color .16s ease,background .16s ease}.icon-button{display:grid;width:42px;height:42px;place-items:center;color:var(--green-dark);background:#ffffff;border:1px solid var(--line);border-radius:8px}.icon-button.compact{width:34px;height:34px}.profile-button{gap:8px;min-height:42px;padding:0 12px;color:var(--green-dark);background:#ffffff;border:1px solid var(--line);border-radius:8px}.primary-button,.secondary-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:42px;padding:0 14px;border-radius:8px;white-space:nowrap}.primary-button{color:#ffffff;background:var(--green-dark)}.secondary-button{color:var(--green-dark);background:#eef5f2;border:1px solid #cfe0d9}.icon-button:hover,.primary-button:hover,.profile-button:hover,.secondary-button:hover{transform:translateY(-1px)}.campus-strip{display:grid;grid-template-columns:minmax(0,1fr) 340px;grid-gap:18px;gap:18px;margin-bottom:18px}.campus-panel{position:relative;min-height:258px;overflow:hidden;color:#ffffff;background:#102521;border-radius:8px;box-shadow:var(--shadow)}.campus-panel>img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}.campus-panel:after{position:absolute;inset:0;content:"";background:linear-gradient(90deg,rgba(10,28,24,.84),rgba(10,28,24,.52) 46%,rgba(10,28,24,.08))}.campus-copy{position:relative;z-index:1;width:min(620px,100%);padding:26px}.eyebrow{gap:6px;color:rgba(255,255,255,.82);font-size:.82rem;font-weight:700}.eyebrow.dark{color:var(--green)}h1,h2,h3,p{margin:0}h1{max-width:12em;margin-top:12px;font-size:clamp(2rem,5vw,4.2rem);line-height:.98}.campus-copy p{max-width:35rem;margin-top:14px;color:rgba(255,255,255,.84);line-height:1.7}.metric-row{flex-wrap:wrap;gap:10px;margin-top:22px}.metric{display:grid;grid-template-columns:22px auto;grid-gap:2px 7px;gap:2px 7px;min-width:118px;padding:10px;color:#ffffff;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);border-radius:8px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.metric svg{grid-row:span 2;margin-top:2px}.metric span{font-size:1.05rem;font-weight:800}.metric small{color:rgba(255,255,255,.72)}.metric-green svg{color:#83dbc5}.metric-amber svg{color:#f3c75f}.metric-blue svg{color:#91c6ff}.detail-panel,.handover-panel,.seller-panel{background:var(--panel);border:1px solid var(--line);border-radius:8px;box-shadow:0 10px 32px rgba(20,38,34,.08)}.handover-panel,.seller-panel{padding:16px}.panel-heading{justify-content:space-between;gap:12px;margin-bottom:14px}.panel-heading>span:first-child{display:inline-flex;align-items:center;gap:8px;font-weight:800}.p0-badge,.result-count{display:inline-flex;align-items:center;min-height:28px;padding:0 9px;color:var(--green-dark);background:#f4d06f;border-radius:8px;font-size:.78rem;font-weight:800}.handover-list{display:grid;grid-gap:9px;gap:9px}.handover-row{display:flex;align-items:center;justify-content:space-between;gap:10px;width:100%;min-height:62px;padding:10px;text-align:left;color:var(--ink);background:#ffffff;border:1px solid var(--line);border-left-width:5px;border-radius:8px}.handover-row small,.handover-row strong{display:block}.handover-row small{margin-top:3px;color:var(--muted)}.handover-row em{flex:0 0 auto;color:var(--muted);font-style:normal;font-size:.86rem}.handover-row.is-active{background:#f4fbf8;border-color:#9bcfc1}.tone-green{border-left-color:var(--green)}.tone-blue{border-left-color:var(--blue)}.tone-amber{border-left-color:var(--amber)}.tone-red{border-left-color:var(--red)}.workspace{display:grid;grid-template-columns:minmax(0,1fr) 370px;grid-gap:18px;gap:18px;align-items:start}.market-column{min-width:0}.filter-board{display:grid;grid-template-columns:minmax(240px,.62fr) minmax(0,1fr);grid-gap:14px;gap:14px;margin-bottom:18px}.search-box{display:flex;align-items:center;gap:9px;min-height:52px;padding:0 14px;color:var(--muted);background:#ffffff;border:1px solid var(--line);border-radius:8px}.search-box input{width:100%;min-width:0;color:var(--ink);background:transparent;border:0;outline:0}.filter-stack{display:grid;grid-gap:10px;gap:10px}.segmented{display:grid;grid-template-columns:88px minmax(0,1fr);align-items:center;grid-gap:10px;gap:10px}.segmented>span{display:inline-flex;align-items:center;gap:6px;color:var(--muted);font-size:.86rem;font-weight:800}.segmented>div{display:flex;min-width:0;overflow:hidden;background:#ffffff;border:1px solid var(--line);border-radius:8px}.segmented button{flex:1 1;min-width:0;min-height:38px;padding:0 10px;color:var(--muted);background:transparent;border:0;border-right:1px solid var(--line);font-size:.88rem}.segmented button:last-child{border-right:0}.segmented button.is-active{color:#ffffff;background:var(--green)}.section-title{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:12px}.section-title h2{margin-top:5px;font-size:1.35rem}.listing-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:12px;gap:12px}.empty-state{display:grid;min-height:164px;place-items:center;grid-gap:7px;gap:7px;margin-top:12px;padding:22px;color:var(--muted);text-align:center;background:#ffffff;border:1px dashed #cfd9d4;border-radius:8px}.empty-state svg{color:var(--green)}.empty-state strong{color:var(--green-dark)}.listing-card{display:grid;grid-template-columns:132px minmax(0,1fr);min-height:160px;overflow:hidden;color:var(--ink);text-align:left;background:#ffffff;border:1px solid var(--line);border-radius:8px}.listing-card.is-selected{border-color:var(--green);box-shadow:0 0 0 3px rgba(31,122,104,.14)}.book-photo{position:relative;min-height:160px;overflow:hidden;background:#d8e8e2}.book-photo img,.detail-cover img,.reservation-summary img{width:100%;height:100%;object-fit:cover}.book-photo em{position:absolute;left:8px;bottom:8px;padding:5px 7px;color:#ffffff;background:rgba(15,31,28,.78);border-radius:8px;font-size:.76rem;font-style:normal;font-weight:800}.book-body{display:flex;min-width:0;flex-direction:column;gap:8px;padding:14px}.book-body small,.book-body strong{overflow-wrap:anywhere}.book-body strong{font-size:1.05rem}.book-body small{color:var(--muted);line-height:1.5}.book-meta{flex-wrap:wrap;gap:8px;margin-top:auto}.book-meta span{display:inline-flex;align-items:center;min-height:28px;padding:0 8px;color:var(--green-dark);background:#eef5f2;border-radius:8px;font-size:.78rem;font-weight:800}.accent-teal .book-meta span:first-child,.accent-teal.detail-cover{background:#dcefe9}.accent-amber .book-meta span:first-child,.accent-amber.detail-cover{background:#f6e6bf}.accent-blue .book-meta span:first-child,.accent-blue.detail-cover{background:#deebf8}.accent-red .book-meta span:first-child,.accent-red.detail-cover{background:#f6dfda}.detail-panel{display:grid;grid-template-columns:minmax(0,1fr) 230px;grid-gap:18px;gap:18px;margin-top:14px;padding:16px}.detail-main{display:grid;grid-template-columns:188px minmax(0,1fr);grid-gap:16px;gap:16px;min-width:0}.detail-cover{min-height:190px;overflow:hidden;border-radius:8px}.detail-copy{min-width:0}.detail-copy h3{margin-top:7px;font-size:1.38rem;overflow-wrap:anywhere}.detail-copy p{margin-top:9px;color:var(--muted);line-height:1.7}.tag-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.tag-row button,.tag-row span{min-height:30px;padding:5px 9px;color:var(--green-dark);background:#f1f6f4;border:1px solid #dbe7e2;border-radius:8px;font-size:.82rem;font-weight:800}.tag-row button{color:var(--muted)}.buy-box{display:grid;grid-gap:12px;gap:12px;align-content:center;min-width:0}.price-line{padding-bottom:12px;border-bottom:1px solid var(--line)}.price-line small{display:block;color:var(--muted);font-size:.8rem}.price-line strong{display:block;margin-top:4px;color:var(--green-dark);font-size:1.25rem}.seller-line{gap:8px;color:var(--muted);font-size:.9rem}.seller-panel{position:-webkit-sticky;position:sticky;top:18px}.upload-zone{display:grid;min-height:138px;place-items:center;margin-bottom:12px;padding:18px;color:var(--green-dark);text-align:center;background:#f4fbf8;border:1px dashed #9bcfc1;border-radius:8px}.upload-zone input{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0)}.upload-zone small,.upload-zone strong{display:block}.upload-zone strong{margin-top:10px}.upload-zone small{margin-top:4px;color:var(--muted)}.seller-panel>.secondary-button{width:100%}.scan-status{position:relative;display:flex;align-items:center;justify-content:space-between;gap:12px;min-height:40px;margin:12px 0;padding:0 10px;overflow:hidden;color:var(--green-dark);background:#eef5f2;border-radius:8px}.scan-status span{position:absolute;inset:0 auto 0 0;width:92%;background:rgba(31,122,104,.16)}.scan-status strong{position:relative;z-index:1;font-size:.88rem}.scan-scanning span{width:52%;animation:scanPulse .9s ease-in-out infinite alternate}.scan-ready span{width:8%}@keyframes scanPulse{0%{width:28%}to{width:74%}}.course-bind,.field-list{display:grid;grid-gap:10px;gap:10px}.course-bind label,.field-list label{display:grid;grid-gap:6px;gap:6px}.choice-title,.course-bind span,.field-list span{color:var(--muted);font-size:.78rem;font-weight:800}.course-bind select,.field-list input{width:100%;min-height:40px;padding:0 10px;color:var(--ink);background:#ffffff;border:1px solid var(--line);border-radius:8px}.choice-group{margin:14px 0}.tag-row.selectable button{cursor:default}.course-bind{grid-template-columns:1fr 1fr}.handover-checks{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:8px;gap:8px;margin:14px 0}.handover-checks label{display:flex;align-items:center;justify-content:center;gap:6px;min-height:38px;padding:0 8px;text-align:center;background:#ffffff;border:1px solid var(--line);border-radius:8px;font-size:.82rem;font-weight:800}.publish-row{justify-content:space-between;gap:12px;padding-top:14px;border-top:1px solid var(--line)}.publish-row small,.publish-row strong{display:block}.publish-row small{color:var(--muted)}.publish-row strong{margin-top:3px}.posted-note{gap:8px;min-height:40px;margin-top:12px;padding:0 10px;color:var(--green-dark);background:#eaf7ef;border:1px solid #c7e6d2;border-radius:8px;font-weight:800}.modal-backdrop{position:fixed;z-index:20;inset:0;display:grid;place-items:center;padding:20px;background:rgba(8,20,17,.52)}.account-modal,.reservation-modal{width:min(760px,100%);max-height:min(90svh,760px);overflow:auto;padding:18px;background:#ffffff;border-radius:8px;box-shadow:0 30px 90px rgba(0,0,0,.28)}.modal-actions,.modal-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.modal-head h2{margin-top:5px}.reservation-layout{display:grid;grid-template-columns:230px minmax(0,1fr);grid-gap:16px;gap:16px;margin-top:16px}.reservation-summary{display:grid;align-content:start;grid-gap:9px;gap:9px}.reservation-summary img{height:174px;border-radius:8px}.reservation-summary span{color:var(--muted);line-height:1.5}.reservation-form{display:grid;grid-gap:14px;gap:14px}.option-block{display:grid;grid-gap:8px;gap:8px}.option-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:8px;gap:8px}.option-grid button,.quick-chat button{display:inline-flex;align-items:center;justify-content:center;gap:7px;min-height:40px;padding:0 10px;color:var(--green-dark);background:#ffffff;border:1px solid var(--line);border-radius:8px;font-weight:800}.option-grid button.is-active,.quick-chat button.is-active{color:#ffffff;background:var(--green);border-color:var(--green)}.quick-chat{display:flex;flex-wrap:wrap;gap:8px}.quick-chat .choice-title{flex:1 0 100%}.modal-actions{margin-top:18px;padding-top:14px;border-top:1px solid var(--line)}.account-modal{width:min(680px,100%)}.account-dashboard,.account-form{display:grid;grid-gap:14px;gap:14px;margin-top:16px}.account-card{grid-template-columns:52px minmax(0,1fr) auto;align-items:center;grid-gap:12px;gap:12px;padding:14px;background:#f4fbf8;border:1px solid #cfe5dd}.account-avatar,.account-card{display:grid;border-radius:8px}.account-avatar{width:52px;height:52px;place-items:center;color:#ffffff;background:var(--green-dark);font-size:1.25rem;font-weight:900}.account-card span,.account-card strong{display:block;overflow-wrap:anywhere}.account-card span{margin-top:3px;color:var(--muted)}.account-card em{display:inline-flex;align-items:center;justify-content:center;gap:6px;min-height:32px;padding:0 9px;color:var(--muted);background:#ffffff;border:1px solid var(--line);border-radius:8px;font-size:.8rem;font-style:normal;font-weight:800}.account-card em.verified{color:var(--green-dark);background:#e8f6f1;border-color:#c7e5da}.account-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:10px;gap:10px}.info-tile{display:grid;grid-template-columns:24px minmax(0,1fr);grid-gap:3px 8px;gap:3px 8px;padding:12px;background:#ffffff;border:1px solid var(--line);border-radius:8px}.info-tile svg{grid-row:span 2;color:var(--green)}.info-tile span{color:var(--muted);font-size:.78rem;font-weight:800}.info-tile strong{min-width:0;overflow-wrap:anywhere}.account-activity{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:10px;gap:10px}.account-activity div{display:grid;min-height:76px;place-items:center;padding:10px;text-align:center;background:#f7f9f8;border:1px solid var(--line);border-radius:8px}.account-activity strong{color:var(--green-dark);font-size:1.35rem}.account-activity span{color:var(--muted);font-size:.82rem;font-weight:800}.account-tabs{display:flex;overflow:hidden;border:1px solid var(--line);border-radius:8px}.account-tabs button{display:inline-flex;flex:1 1;align-items:center;justify-content:center;gap:7px;min-height:42px;color:var(--muted);background:#ffffff;border:0;border-right:1px solid var(--line);font-weight:800}.account-tabs button:last-child{border-right:0}.account-tabs button.is-active{color:#ffffff;background:var(--green)}.google-button{display:inline-flex;align-items:center;justify-content:center;gap:10px;min-height:44px;padding:0 14px;color:#1f2933;background:#ffffff;border:1px solid #d8e0dc;border-radius:8px;box-shadow:0 8px 22px rgba(25,44,39,.07);font-weight:850;transition:transform .16s ease,border-color .16s ease,box-shadow .16s ease}.google-button:hover{transform:translateY(-1px);border-color:#b9c8c2;box-shadow:0 12px 28px rgba(25,44,39,.1)}.google-mark{display:grid;width:24px;height:24px;place-items:center;color:#4285f4;background:linear-gradient(#ffffff,#ffffff) padding-box,conic-gradient(from -35deg,#4285f4,#34a853 30%,#fbbc05 58%,#ea4335 78%,#4285f4) border-box;border:2px solid transparent;border-radius:50%;font-size:.86rem;font-weight:950;line-height:1}.account-divider{display:flex;align-items:center;gap:10px;color:var(--muted);font-size:.78rem;font-weight:800}.account-divider:after,.account-divider:before{flex:1 1;height:1px;background:var(--line);content:""}.oauth-note{margin:0;padding:10px 12px;color:#6a4b0b;background:#fff8e8;border:1px solid #efd99d;border-radius:8px;font-size:.85rem;font-weight:750;line-height:1.5}.account-form label{display:grid;grid-gap:6px;gap:6px}.account-form label>span{color:var(--muted);font-size:.78rem;font-weight:800}.account-form input,.account-form select{width:100%;min-height:42px;padding:0 10px;color:var(--ink);background:#ffffff;border:1px solid var(--line);border-radius:8px;outline:0}.account-form input:focus,.account-form select:focus{border-color:var(--green);box-shadow:0 0 0 3px rgba(31,122,104,.12)}.input-with-icon{display:flex;align-items:center;gap:9px;min-height:42px;padding:0 10px;color:var(--muted);background:#ffffff;border:1px solid var(--line);border-radius:8px}.input-with-icon input{min-height:auto;padding:0;border:0}.input-with-icon:focus-within{border-color:var(--green);box-shadow:0 0 0 3px rgba(31,122,104,.12)}.account-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:10px;gap:10px}@media (max-width:1180px){.campus-strip,.workspace{grid-template-columns:1fr}.seller-panel{position:static}.filter-board{grid-template-columns:1fr}}@media (max-width:780px){.app-shell{padding:14px}.modal-actions,.modal-head,.section-title,.topbar{align-items:stretch;flex-direction:column}.buy-box .primary-button,.modal-actions,.modal-actions button,.profile-button,.top-actions{width:100%}.campus-copy{padding:20px}.campus-panel{min-height:420px}.campus-panel:after{background:linear-gradient(180deg,rgba(10,28,24,.84),rgba(10,28,24,.48))}h1{font-size:2.45rem}.segmented{grid-template-columns:1fr}.segmented>div{overflow-x:auto}.segmented button{flex-basis:112px}.account-card,.account-form-grid,.account-grid,.course-bind,.detail-main,.detail-panel,.handover-checks,.listing-grid,.reservation-layout{grid-template-columns:1fr}.listing-card{grid-template-columns:118px minmax(0,1fr)}.detail-panel{padding:14px}.detail-cover{min-height:220px}.reservation-summary img{height:210px}}@media (max-width:480px){.brand small,.profile-button span{display:none}.topbar{flex-direction:row;align-items:center}.top-actions{justify-content:flex-end;width:auto}.listing-card{grid-template-columns:1fr}.book-photo{min-height:188px}.option-grid{grid-template-columns:1fr}}