*{box-sizing:border-box}body{margin:0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:#eafbf0;color:#1f2937;-webkit-font-smoothing:antialiased;line-height:1.5}#root{min-height:100vh}html{width:100%;height:100%}:root{--primary: #46aa8f;--primary-hover: #0a594e;--primary-light: #e3f6ee;--bg-color: #eafbf0;--card-bg: #ffffff;--text-main: #1f2937;--text-secondary: #6b7280;--border-color: #ddefe5;--price-color: #AE322A;--success-bg: #FFF7B3;--success-text: #0a594e;--shadow-sm: 0 1px 3px rgba(10, 89, 78, .12);--shadow: 0 12px 22px -16px rgba(10, 89, 78, .35);--shadow-lg: 0 24px 40px -28px rgba(10, 89, 78, .45);--radius: 18px}body{margin:0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:var(--bg-color);color:var(--text-main);-webkit-font-smoothing:antialiased;-webkit-text-size-adjust:100%;line-height:1.5;width:100%;min-height:100%;overflow-x:hidden;touch-action:manipulation}.container{max-width:100%;margin:0;padding:0;overflow-x:hidden}.loading-mask{position:sticky;top:0;z-index:5;display:flex;justify-content:center;padding:12px 16px}.loading-card{background:#fff;border-radius:999px;border:1px solid var(--border-color);box-shadow:var(--shadow-sm);padding:8px 14px;display:inline-flex;align-items:center;gap:8px;font-size:.85rem;color:var(--text-secondary)}.loading-spinner{width:14px;height:14px;border-radius:50%;border:2px solid #d7f0e4;border-top-color:var(--primary);animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.app-header{background:transparent;padding:40px 24px 48px;display:flex;justify-content:space-between;align-items:center;margin-bottom:0;position:relative;color:var(--text-main)}.header-content{max-width:1200px;margin:0 auto;width:100%;display:flex;justify-content:space-between;align-items:center;padding:0 24px;gap:24px}.header-content.header-home{display:flex;justify-content:center}.header-actions-left{justify-content:flex-start;justify-self:start}.header-actions-right{justify-content:flex-end;justify-self:end}.title-group{display:flex;flex-direction:column;gap:6px;z-index:1}.title-group.home-title{align-items:center;text-align:center}.app-logo{width:84px;height:84px;object-fit:contain}.app-title{font-size:1.8rem;font-weight:800;color:var(--text-main);letter-spacing:-.5px}.app-title-svg{display:inline-flex;align-items:center;gap:6px}.app-title-svg img{height:42px;width:auto;display:block}.app-subtitle{font-size:.95rem;color:var(--text-secondary)}.btn-primary{background-color:var(--primary);color:#fff;padding:10px 20px;border-radius:999px;border:none;font-weight:700;cursor:pointer;transition:all .2s ease;box-shadow:var(--shadow);display:flex;align-items:center;gap:8px;height:40px;z-index:1}.btn-primary:hover{background-color:var(--primary-hover);transform:translateY(-1px)}.btn-secondary{background-color:#fff;color:var(--text-main);padding:10px 20px;border-radius:999px;border:1px solid var(--border-color);font-weight:600;cursor:pointer;transition:all .2s ease;height:40px;z-index:1}.header-login-button{background:#fadd2e;border-color:#fadd2e;color:#1f2937}.header-login-button:hover{border-color:#f1cd00;color:#1f2937}.otp-button{padding:0 14px;min-width:96px;white-space:nowrap;font-size:.85rem}.btn-secondary:hover{border-color:var(--primary);color:var(--primary)}.search-container{max-width:1200px;margin:-6px auto 24px;padding:0 24px 16px;display:flex;flex-direction:column;align-items:center}.college-filter{display:flex;flex-wrap:wrap;gap:10px;margin-top:14px;justify-content:center}.college-chip{border:1px solid var(--border-color);background:#fff;color:var(--text-secondary);padding:6px 12px;border-radius:999px;font-size:.85rem;cursor:pointer;transition:all .2s ease}.college-chip.active{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:0 6px 12px -8px #0a594e59}.search-bar{display:flex;gap:12px;max-width:600px;width:100%;background:#fff;align-items:center;padding:6px;border-radius:999px;border:1px solid var(--border-color);box-shadow:var(--shadow-sm)}.search-input{flex:1;padding:12px 20px;border:none;border-radius:999px;font-size:.95rem;outline:none;background:transparent}.search-input:focus{box-shadow:none}.campus-select{padding:10px 16px;border:none;border-left:1px solid var(--border-color);border-radius:0;background:transparent;min-width:110px;font-size:.9rem;cursor:pointer;outline:none;color:var(--text-secondary);margin-right:6px}.book-list-container{max-width:1200px;margin:0 auto;padding:10px 24px 40px;position:relative;z-index:1}.book-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}.book-card{background:var(--card-bg);padding:14px;border-radius:var(--radius);box-shadow:var(--shadow-sm);border:1px solid var(--border-color);display:flex;flex-direction:column;gap:10px;transition:transform .2s,box-shadow .2s;width:220px;flex-shrink:0;box-sizing:border-box}.book-card.sold{opacity:.6}.book-card.pending{opacity:.8}.book-card-clickable{cursor:pointer}.book-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}.book-cover{width:100%;height:180px;background-color:#f3fbf7;border-radius:18px;overflow:hidden;display:flex;align-items:center;justify-content:center;margin-bottom:2px;position:relative}.book-cover-track{display:flex;width:100%;height:100%;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;scrollbar-width:none}.book-cover-track::-webkit-scrollbar{display:none}.book-cover-slide{min-width:100%;height:100%;scroll-snap-align:start;display:flex;align-items:center;justify-content:center}.book-cover-slide img{width:100%;height:100%;object-fit:cover}.book-card.sold .book-cover-slide img{filter:grayscale(1)}.book-status{position:absolute;top:8px;left:8px;background:#0a594ec7;color:#fff;font-size:.7rem;padding:4px 8px;border-radius:999px;font-weight:600}.book-status.pending{background:#f59e0be6}.book-cover-placeholder{color:#94a3b8;font-size:.8rem;font-weight:500}.book-cover-dots{position:absolute;bottom:8px;left:50%;transform:translate(-50%);display:flex;gap:4px;padding:2px 6px;border-radius:999px;background:#0a594e1f;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.book-cover-dot{width:5px;height:5px;border-radius:999px;background:#fff9}.book-cover-dot.active{background:var(--primary)}.book-header{display:flex;justify-content:space-between;align-items:center;gap:8px}.book-title{font-size:1rem;font-weight:700;margin:0;line-height:1.2;color:var(--text-main);display:-webkit-box;line-clamp:1;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden;height:1.2em}.book-price{font-size:.8rem;font-weight:600;color:var(--price-color);background:var(--success-bg);padding:3px 8px;border-radius:999px;white-space:nowrap}.book-author{font-size:.78rem;color:var(--text-secondary);margin-top:-4px}.book-meta{display:flex;flex-wrap:wrap;gap:4px}.meta-tag{background:#f4fbf7;padding:2px 8px;border-radius:4px;font-size:.7rem;color:var(--text-secondary);font-weight:500;border:1px solid var(--border-color);white-space:nowrap}.meta-tag.condition{background:var(--primary-light);color:var(--primary);border-color:transparent}.meta-tag.major{background:#f1f7f5;color:#2f6b5e;border-color:#e3efea}.meta-tag.status.pending{background:#fff7ed;color:#b45309;border-color:#fed7aa}.meta-tag.status.sold{background:#fee2e2;color:#b91c1c;border-color:#fecaca}.book-desc{display:none}.book-footer{margin-top:auto;padding-top:8px;border-top:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center;gap:8px}.contact-info{font-weight:600;color:var(--success-text);font-size:.75rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:120px}.contact-info.copyable,.detail-contact.copyable{cursor:pointer}.contact-info.copyable:hover,.detail-contact.copyable:hover{text-decoration:underline}.timestamp{color:#9ca3af;font-size:.65rem}.empty-state{margin:0 24px 24px;background:#fff;padding:32px;border-radius:12px;border:1px dashed var(--border-color);color:var(--text-secondary);text-align:center}.post-form-container{background:#fff;padding:32px;border-radius:var(--radius);box-shadow:var(--shadow);max-width:600px;margin:20px auto;border:1px solid var(--border-color)}.form-group{margin-bottom:16px}.form-label{display:block;margin-bottom:6px;font-weight:600;font-size:.9rem}.required-star{color:#ef4444;font-weight:700}.form-input,.form-textarea,.form-select{width:100%;padding:10px 14px;border:1px solid var(--border-color);border-radius:8px;font-size:.95rem;box-sizing:border-box}.form-textarea{min-height:110px;resize:none}.contact-row{display:flex;gap:10px;align-items:center;flex-wrap:nowrap;width:100%}.contact-select{width:92px;flex:0 0 92px;max-width:92px}.contact-row .form-input{min-width:0;flex:1 1 0;width:auto}.prefill-card{border:1px solid var(--border-color);border-radius:12px;padding:14px 16px;background:#fff;display:grid;gap:10px}.prefill-label-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px;flex-wrap:wrap}.prefill-summary{font-size:.88rem;color:var(--text-main);text-align:center;line-height:1.5;word-break:break-all;padding:0 6px}.prefill-hint{font-size:.75rem;color:var(--text-secondary)}.prefill-toggle{border:1px solid var(--primary);background:var(--primary-light);color:var(--primary);border-radius:999px;padding:6px 14px;font-size:.8rem;cursor:pointer;white-space:nowrap}.prefill-toggle:hover{background:#dff5ea;color:#1f7b59}.prefill-fields{display:grid;gap:12px}.prefill-summary-two{display:grid;gap:4px}@media(max-width:420px){.contact-row{gap:8px;flex-wrap:wrap;align-items:stretch;display:grid}.contact-select{width:100%;flex-basis:100%;max-width:100%}.contact-row .form-input{width:100%;flex:1 1 100%}}.phrase-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.phrase-chip{border:1px solid var(--border-color);background:#f4fbf7;color:var(--text-secondary);padding:6px 10px;border-radius:999px;font-size:.8rem;cursor:pointer}.phrase-chip:hover{background:var(--primary-light);color:var(--primary);border-color:#cfece0}.form-actions{display:flex;justify-content:center;gap:12px;margin-top:24px;padding-top:20px;border-top:1px solid var(--border-color)}.upload-area{display:block;border:1px dashed #cfece0;border-radius:16px;padding:16px;background:#f4fbf7;text-align:center;cursor:pointer}.upload-input{display:none}.upload-content{display:flex;flex-direction:column;align-items:center;gap:6px;color:var(--text-secondary)}.upload-icon{width:56px;height:56px;border-radius:999px;background:#fff;border:1px solid #cfece0;color:var(--primary);display:flex;align-items:center;justify-content:center;font-size:1.4rem;box-shadow:var(--shadow-sm)}.upload-title{font-weight:600;color:var(--text-main)}.upload-subtitle{font-size:.8rem;color:var(--text-secondary)}.upload-preview-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px}.upload-preview-item{display:flex;flex-direction:column;gap:8px}.upload-preview-item img{width:100%;height:120px;object-fit:cover;border-radius:12px}.upload-actions{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:12px}.upload-action{border:1px solid var(--border-color);border-radius:999px;height:40px;font-weight:600;cursor:pointer;background:#fff;color:var(--text-main)}.upload-action.primary{background:var(--primary);color:#fff;border-color:transparent}.upload-action.danger{background:#fef2f2;color:#ef4444;border-color:transparent}.detail-page{max-width:720px;margin:0 auto;padding:12px 16px 120px}.detail-topbar{display:flex;align-items:center;justify-content:space-between;padding:4px 0 12px}.detail-topbar-title{font-weight:700;font-size:1rem}.icon-button{width:36px;height:36px;border-radius:999px;border:1px solid var(--border-color);background:#fff;color:var(--text-main);font-size:1rem;display:flex;align-items:center;justify-content:center;cursor:pointer}.icon-button img{width:20px;height:20px}.icon-button.ghost{border:none;background:#ffffffe6;box-shadow:var(--shadow-sm)}.detail-hero{background:#fff;border-radius:24px;overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:10px}.detail-hero-track{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;scrollbar-width:none}.detail-hero-track::-webkit-scrollbar{display:none}.detail-hero-slide{min-width:100%;scroll-snap-align:start}.detail-hero-slide img{width:100%;height:260px;object-fit:cover;display:block}.detail-hero-placeholder{height:260px;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);background:#f1f7f5}.detail-dots{display:flex;justify-content:center;gap:6px;padding-bottom:12px}.dot{width:6px;height:6px;border-radius:999px;background:#d1d5db}.dot.active{background:var(--primary)}.detail-card{background:#fff;margin-top:16px;padding:18px;border-radius:24px;box-shadow:var(--shadow)}.detail-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.detail-name{font-size:1.2rem;font-weight:700;line-height:1.4}.detail-author{font-size:.9rem;color:var(--text-secondary);margin-top:4px}.detail-price{font-size:1.2rem;font-weight:800;color:var(--price-color);white-space:nowrap}.detail-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}.detail-section{margin-top:16px;padding-top:12px;border-top:1px solid var(--border-color)}.detail-section-title{font-weight:700;font-size:.95rem;margin-bottom:8px}.detail-section-body{color:var(--text-secondary);font-size:.9rem;line-height:1.6}.detail-info-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.detail-info-item{background:#f4fbf7;border-radius:12px;padding:10px 12px}.detail-info-label{font-size:.75rem;color:var(--text-secondary);margin-bottom:4px}.detail-info-value{font-weight:600;font-size:.9rem;color:var(--text-main)}.detail-seller{background:#f4fbf7;border-radius:12px;padding:10px 12px;display:flex;flex-direction:column;gap:4px}.detail-seller-name{font-weight:700;font-size:.95rem;color:var(--text-main)}.detail-seller-meta{font-size:.78rem;color:var(--text-secondary)}.detail-contact{font-weight:700;color:var(--success-text);background:var(--success-bg);padding:10px 12px;border-radius:12px;display:inline-flex}.copy-toast{position:fixed;left:50%;bottom:80px;transform:translate(-50%);background:#111827eb;color:#f9fafb;padding:10px 16px;border-radius:999px;font-weight:600;font-size:.85rem;box-shadow:var(--shadow);z-index:999}.detail-actions{position:sticky;bottom:16px;margin-top:16px;display:grid;gap:12px}.detail-tabbar{position:fixed;left:0;right:0;bottom:0;padding:16px 26px 20px;background:#ffffffeb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-top:1px solid var(--border-color);z-index:20;display:flex;justify-content:center}.detail-tabbar-row{width:min(720px,100%);display:flex;gap:10px;align-items:center}.detail-tabbar-icon{width:72px;height:48px;border-radius:999px;border:1px solid var(--border-color);background:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;font-size:.72rem;font-weight:600;color:var(--text-main);cursor:pointer}.detail-tabbar-icon img{width:20px;height:20px}.detail-tabbar-button{flex:1;height:48px;border-radius:999px;border:1px solid rgba(15,110,98,.7);background:#fff;color:var(--primary);font-size:.95rem;font-weight:700;cursor:pointer}.detail-tabbar-button.primary{background:var(--primary);color:#fff;border-color:transparent}.detail-tabbar-button.ghost{background:#fff7ed;color:#b45309;border-color:transparent}.detail-tabbar-battery{flex:1;display:flex;align-items:stretch;height:48px;border-radius:999px;overflow:hidden;border:1.55px solid rgba(15,110,98,.7);background:#fff}.detail-tabbar-battery-left{flex:0 0 100%;border:none;border-radius:0;transition:flex-basis .3s ease}.detail-tabbar-battery-right{flex:0 0 0%;border:none;border-radius:0;background:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;font-size:.66rem;font-weight:600;color:var(--text-secondary);cursor:pointer;opacity:0;pointer-events:none;transition:flex-basis .3s ease,opacity .2s ease}.detail-tabbar-battery-right img{width:18px;height:18px}.detail-tabbar-battery.expanded .detail-tabbar-battery-left{flex-basis:40%}.detail-tabbar-battery.expanded .detail-tabbar-battery-right{flex-basis:60%;opacity:1;pointer-events:auto}.detail-primary{width:100%;height:48px;border:none;border-radius:999px;background:var(--primary);color:#fff;font-size:1rem;font-weight:700;box-shadow:var(--shadow);cursor:pointer}.detail-secondary{width:100%;height:48px;border-radius:999px;border:1px solid var(--primary);background:#fff;color:var(--primary);font-size:1rem;font-weight:700;cursor:pointer}.detail-empty{background:#fff;border-radius:20px;padding:32px;box-shadow:var(--shadow);text-align:center;margin-top:24px}.detail-empty-title{font-weight:700;margin-bottom:16px}.header-actions{display:flex;gap:12px;align-items:center}.admin-page{max-width:1200px;margin:0 auto;padding:24px}.admin-toolbar{display:flex;flex-direction:column;align-items:stretch;gap:16px;margin-bottom:16px}.admin-toolbar-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.admin-title{font-size:1.4rem;font-weight:800}.admin-subtitle{font-size:.8rem;color:var(--text-secondary);margin-top:4px}.admin-toolbar-actions{display:flex;flex-wrap:wrap;gap:12px;align-items:center;justify-content:flex-end}.admin-filters{display:flex;flex-wrap:wrap;gap:10px;align-items:center}.admin-input,.admin-select{height:38px;border-radius:10px;border:1px solid var(--border-color);padding:0 12px;font-size:.9rem;background:#fff;color:var(--text-main)}.admin-input{min-width:220px}.admin-content{display:grid;grid-template-columns:minmax(0,2.1fr) minmax(0,1fr);gap:16px}.admin-table-card,.admin-detail-card{background:#fff;border-radius:16px;box-shadow:var(--shadow);border:1px solid var(--border-color)}.admin-table-card{padding:12px}.admin-table-header{display:flex;justify-content:space-between;align-items:center;font-weight:600;color:var(--text-secondary);padding:4px 6px 10px}.admin-table-wrap{overflow-x:auto}.admin-table-desktop{display:block}.admin-mobile-list{display:none}.admin-table{width:100%;border-collapse:collapse;min-width:860px}.admin-table th,.admin-table td{text-align:left;padding:10px 8px;border-bottom:1px solid var(--border-color);font-size:.85rem;color:var(--text-main);vertical-align:middle}.admin-table th{font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;color:var(--text-secondary);background:#f4fbf7;position:sticky;top:0}.admin-table tr{cursor:pointer;transition:background .2s ease}.admin-table tr:hover{background:#f1f7f5}.admin-table tr.active{background:#e3f6ee}.admin-cover{width:48px;height:48px;border-radius:10px;overflow:hidden;background:#f3fbf7;display:flex;align-items:center;justify-content:center}.admin-cover img{width:100%;height:100%;object-fit:cover}.admin-cover-placeholder{font-size:.7rem;color:var(--text-secondary)}.admin-title-cell{font-weight:700}.admin-status{display:inline-flex;align-items:center;padding:2px 8px;border-radius:999px;font-size:.7rem;font-weight:600;background:var(--primary-light);color:var(--primary)}.admin-status-trigger{border:none;cursor:pointer}.admin-status-trigger:focus-visible{outline:2px solid #9bd6c6;outline-offset:2px}.admin-status.hidden{background:#fee2e2;color:#dc2626}.admin-status.sold{background:#e5e7eb;color:#6b7280}.admin-status-cell{position:relative;display:inline-flex;align-items:center}.admin-status-menu{position:absolute;top:calc(100% + 6px);left:0;background:#fff;border:1px solid var(--border-color);border-radius:12px;box-shadow:var(--shadow);padding:8px;display:grid;gap:6px;min-width:88px;z-index:30}.admin-status-option{border:none;background:#f4fbf7;border-radius:8px;padding:6px 10px;font-size:.8rem;cursor:pointer;text-align:left;color:var(--text-main)}.admin-status-option:hover{background:#e7f4ee}.admin-status-option.danger{background:#fef2f2;color:#dc2626}.admin-status-option.danger:hover{background:#fee2e2}.admin-detail-card{padding:16px;display:flex;flex-direction:column;gap:12px;min-height:320px}.admin-detail-desktop{display:block}.admin-detail-sheet{display:none}.admin-empty{color:var(--text-secondary);text-align:center;padding:40px 0}.admin-detail-title{font-size:1.1rem;font-weight:800}.admin-sheet-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.admin-sheet-close{width:32px;height:32px;border-radius:50%;border:1px solid #ddefe5;background:#f4fbf7;color:#3f4b47;font-size:1.1rem;font-weight:700;cursor:pointer}.admin-sheet-close:hover{background:#e7f4ee}.admin-detail-meta{display:flex;flex-wrap:wrap;gap:8px;color:var(--text-secondary);font-size:.85rem}.admin-detail-image{width:100%;height:180px;border-radius:14px;overflow:hidden;background:#f3fbf7;display:flex;align-items:center;justify-content:center}.admin-detail-image img{width:100%;height:100%;object-fit:cover}.admin-detail-placeholder{color:var(--text-secondary);font-size:.85rem}.admin-detail-section{display:grid;gap:4px}.admin-detail-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em}.admin-auth-card{max-width:420px;margin:40px auto 0;padding:24px;border-radius:16px;background:#fff;box-shadow:var(--shadow);border:1px solid var(--border-color);display:flex;flex-direction:column;gap:12px}.admin-auth-title{font-size:1.1rem;font-weight:800}.admin-auth-desc{color:var(--text-secondary);font-size:.9rem}.admin-auth-input{height:40px;border-radius:10px;border:1px solid var(--border-color);padding:0 12px;font-size:.9rem}.admin-auth-error{color:#dc2626;font-size:.85rem}.admin-auth-btn{height:40px;border-radius:10px;border:none;background:var(--primary);color:#fff;font-weight:700;cursor:pointer}.admin-auth-btn:disabled{opacity:.7;cursor:default}.admin-logout{height:38px;border-radius:10px;border:1px solid #cfece0;background:#f0fbf6;color:#0a594e;font-weight:700;cursor:pointer;padding:0 14px}.admin-logout:hover{background:#e3f6ee}.admin-actions{display:flex;gap:10px;margin-top:8px}.admin-mobile-card{width:100%;border:1px solid var(--border-color);background:#fff;border-radius:14px;padding:12px;display:grid;grid-template-columns:64px 1fr auto;gap:12px;align-items:center;text-align:left;cursor:pointer}.admin-mobile-card+.admin-mobile-card{margin-top:12px}.admin-mobile-card.active{border-color:#cfece0;background:#e3f6ee}.admin-mobile-cover{width:64px;height:64px;border-radius:12px;overflow:hidden;background:#f3fbf7;display:flex;align-items:center;justify-content:center}.admin-mobile-cover img{width:100%;height:100%;object-fit:cover}.admin-mobile-body{display:grid;gap:6px}.admin-mobile-title{font-weight:700;font-size:.95rem}.admin-mobile-meta{display:flex;flex-wrap:wrap;gap:8px;color:var(--text-secondary);font-size:.78rem}.admin-mobile-status{display:flex;align-items:center}.admin-mobile-status .admin-status-menu{left:auto;right:0}.admin-btn{flex:1;height:40px;border-radius:10px;border:1px solid #cfece0;background:#e6faf1;color:#0a594e;font-weight:700;cursor:pointer}.admin-btn:hover{background:#d8f3e8}.admin-btn.danger{border-color:#fecaca;background:#fef2f2;color:#dc2626}.admin-btn.danger:hover{background:#fee2e2}@media(max-width:640px){.home-hero-bg{position:relative;overflow:hidden}.home-hero-bg:before{content:"";position:absolute;left:-10%;right:-10%;top:-30px;height:200px;background-image:url(/home-hero.png);background-size:130%;background-position:right top;opacity:.9;z-index:0;transform:rotate(10deg) scale(.9);transform-origin:center;mask-image:linear-gradient(to bottom,transparent 0%,black 18%,black 82%,transparent 100%);-webkit-mask-image:linear-gradient(to bottom,transparent 0%,black 18%,black 82%,transparent 100%)}.app-header,.search-container{position:relative;z-index:1}body{background-color:#fff}.app-header{padding:50px 16px 10px}.header-content{flex-direction:column;gap:12px;align-items:center;padding:0}.header-content.header-home{justify-content:center;gap:8px}.title-group.home-title{margin-top:0}.app-logo,.app-subtitle{display:none}.app-title-svg img{height:34px}.search-container{margin:4px auto 8px;max-width:100%;width:100%;padding:0 16px 8px}.search-bar{max-width:100%;width:100%;padding:4px;gap:6px}.search-input{padding:8px 12px;font-size:.85rem;min-width:0}.search-input::placeholder{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.campus-select{min-width:72px;padding:8px;font-size:.8rem}.college-filter{flex-wrap:nowrap;overflow:hidden;width:100%;justify-content:center;margin-top:8px;padding:0 8px;gap:8px;box-sizing:border-box}.college-chip{flex:0 0 auto;padding:6px 10px;font-size:.8rem;white-space:nowrap}.user-hero{padding:50px 22px 24px;flex-direction:column;align-items:center;text-align:center}.user-hero-content{align-items:center;width:100%}.user-hero-subtitle{text-align:center}.user-admin-button{align-self:center;margin-top:12px}.admin-page{padding:16px}.admin-content{grid-template-columns:1fr}.admin-detail-desktop{display:none}.admin-detail-sheet{display:flex;position:fixed;left:50%;bottom:50%;transform:translate(-50%,50%);width:min(92vw,360px);z-index:20;max-height:65vh;overflow:auto;box-shadow:var(--shadow-lg);border-radius:18px}.admin-table-desktop{display:none}.admin-mobile-list{display:block}.admin-toolbar-actions{width:100%;justify-content:flex-start}.search-bar{max-width:100%}.admin-table{min-width:520px}.admin-table th,.admin-table td{padding:8px 6px}.admin-table th:nth-child(3),.admin-table td:nth-child(3),.admin-table th:nth-child(5),.admin-table td:nth-child(5),.admin-table th:nth-child(6),.admin-table td:nth-child(6),.admin-table th:nth-child(7),.admin-table td:nth-child(7),.admin-table th:nth-child(9),.admin-table td:nth-child(9),.admin-table th:nth-child(10),.admin-table td:nth-child(10){display:none}.book-list-container{margin:0;padding:0 16px 32px;overflow-x:visible}.book-list{display:grid;width:100%;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.book-list.book-list-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));column-count:initial;column-gap:0;gap:12px}.book-list.book-list-grid .book-card{margin:0;display:flex}.book-card{width:100%;break-inside:avoid;display:inline-flex;margin:0;transform:none}.book-card:hover{transform:none;box-shadow:var(--shadow-sm)}.book-cover{height:120px}.book-card:nth-child(3n) .book-cover{height:150px}.book-card:nth-child(3n+1) .book-cover{height:100px}.detail-page{padding:8px 12px 112px}.detail-hero-slide img,.detail-hero-placeholder{height:220px}.detail-info-grid{grid-template-columns:1fr}}@media(min-width:641px){.home-hero-bg{position:relative;overflow:hidden}.home-hero-bg:before{content:"";position:absolute;left:-8%;right:-8%;top:-90px;height:460px;background-image:url(/web-hero.png);background-size:130%;background-position:center top;opacity:.95;z-index:0;transform:rotate(10deg);transform-origin:center;mask-image:linear-gradient(to bottom,transparent 0%,black 12%,black 78%,transparent 100%);-webkit-mask-image:linear-gradient(to bottom,transparent 0%,black 12%,black 78%,transparent 100%)}.home-hero-bg>*{position:relative;z-index:1}}@media(min-width:641px)and (max-width:1024px){.book-list-container{padding:10px 20px 40px}.book-list{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}}.user-page{max-width:760px;margin:0 auto;padding:0 20px 56px;display:grid;gap:20px}.user-hero{padding:40px 22px 28px;border-radius:0 0 24px 24px;display:flex;align-items:flex-end;justify-content:center;gap:16px;margin:0 -20px;position:relative}.user-hero-content{display:flex;flex-direction:column;align-items:center}.user-hero-title{display:inline-flex;align-items:center;gap:6px;justify-content:center}.user-hero-subtitle{font-size:.9rem;color:var(--text-secondary);margin-top:16px}.user-hero-actions{display:flex;align-items:center}.user-admin-button{align-self:flex-end}.user-hero-btn{border:1px solid var(--border-color);background:#fff;color:var(--text-main);padding:8px 16px;border-radius:999px;font-weight:600;cursor:pointer;box-shadow:var(--shadow-sm)}@media(min-width:641px){.user-admin-button{position:absolute;right:22px;top:50%;transform:translateY(-50%)}}@media(max-width:640px){.user-page{padding:0 14px 72px;gap:14px}.user-hero{padding:28px 16px 18px;flex-direction:column;align-items:center;margin:0 -14px}.user-hero-content{align-items:center}.user-hero-title{justify-content:center}.user-admin-button{align-self:center}.user-card,.login-card{padding:16px}.user-card-header{flex-direction:column;align-items:center}.user-profile-header{align-items:center}.user-profile-actions{width:100%;justify-content:center}.user-stats{gap:16px}.user-tabs{gap:0}.user-tab{padding:6px 8px;font-size:.85rem}.user-empty-logo{width:80px;height:80px}}.user-card,.login-card{background:#fff;border-radius:22px;border:1px solid var(--border-color);box-shadow:var(--shadow-lg);padding:22px;display:grid;gap:16px}.user-card-header{display:flex;justify-content:space-between;align-items:center;gap:12px}.user-card-title,.login-title{font-size:1rem;font-weight:700;color:var(--text-main)}.user-card-desc{color:var(--text-secondary);font-size:.9rem}.user-profile-header{align-items:center;justify-content:center}.user-profile-main{display:flex;flex-direction:column;align-items:center;gap:8px;width:100%}.user-avatar{width:52px;height:52px;border-radius:50%;background:#e5f4ee;display:inline-flex;align-items:center;justify-content:center;color:var(--primary);font-weight:700;font-size:1.2rem}.user-profile-text{display:flex;flex-direction:column;gap:4px;align-items:center;width:100%}.user-profile-name{font-size:1.05rem;font-weight:700;color:var(--text-main);text-align:center;word-break:break-word;white-space:normal;width:100%}.user-profile-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}.user-profile-actions-center{justify-content:center;width:100%}.trade-list{display:grid;gap:16px}.trade-subtabs{display:flex;gap:10px;padding:4px 6px;border-radius:999px;background:#f4fbf7;border:1px solid var(--border-color);justify-content:space-between;align-items:center}.trade-subtab{border:none;background:transparent;color:var(--text-secondary);font-size:.85rem;font-weight:600;padding:6px 12px;border-radius:999px;cursor:pointer;flex:1}.trade-subtab.active{background:#fff;color:var(--primary);box-shadow:var(--shadow-sm)}.trade-empty-state{border:1px solid var(--border-color);border-radius:18px;padding:20px 16px;display:grid;gap:8px;align-items:center;justify-items:center;text-align:center;background:#f8fffb}.trade-empty-logo{width:60px;height:60px;opacity:.9}.trade-empty-title{font-size:.95rem;font-weight:700;color:var(--text-main)}.trade-empty-desc{font-size:.8rem;color:var(--text-secondary)}.trade-section{display:grid;gap:12px}.trade-section-title{font-weight:700;color:var(--text-main)}.trade-item{border:1px solid var(--border-color);border-radius:16px;padding:12px;display:grid;gap:10px;background:#f8fffb}.trade-item.role-buyer{border-color:#0a594e4d;background:#e5f4eeb3}.trade-item.role-seller{border-color:#ef444459;background:#fef2f2}.trade-item-compact{grid-template-columns:1fr auto;align-items:center;padding:10px 12px}.trade-item-compact .trade-item-actions{flex-wrap:nowrap}.trade-item-compact .trade-button{padding:6px 10px;font-size:.78rem}.trade-item-compact .trade-item-title{font-size:.95rem;margin-bottom:2px}.trade-item-compact .trade-item-meta{font-size:.78rem}.trade-item-title{font-weight:600;color:var(--text-main)}.trade-item-meta{font-size:.85rem;color:var(--text-secondary);display:flex;gap:6px;align-items:center}.trade-sep{opacity:.5}.trade-item-actions{display:flex;flex-wrap:wrap;gap:8px}.favorite-list{display:grid;gap:10px}.favorite-row{display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%;padding:10px 12px;border:1px solid var(--border-color);border-radius:14px;background:#f8fffb;text-align:left;cursor:pointer}.favorite-row-main{display:flex;flex-direction:column;gap:2px;min-width:0}.favorite-row-title{font-weight:600;color:var(--text-main);font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.favorite-row-meta{font-size:.78rem;color:var(--text-secondary);display:flex;gap:6px;align-items:center;flex-wrap:wrap}.favorite-row-price{font-weight:700;color:var(--primary);font-size:.9rem;flex-shrink:0}.trade-button{padding:6px 12px;border-radius:999px;border:1px solid var(--border-color);background:#fff;color:var(--text-main);font-size:.8rem;font-weight:600;cursor:pointer}.trade-button.primary{background:var(--primary);color:#fff;border-color:transparent}.trade-button.ghost{background:#f4fbf7;color:var(--primary);border-color:transparent}.user-stats{display:flex;align-items:center;justify-content:center;gap:24px;padding-top:8px}.user-stat-item{text-align:center}.user-stat-value{font-size:1.1rem;font-weight:700;color:var(--text-main)}.user-stat-label{font-size:.85rem;color:var(--text-secondary);margin-top:2px}.user-stat-divider{width:1px;height:28px;background:var(--border-color)}.user-tabs{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:0}.user-tab{border:none;background:transparent;color:var(--text-secondary);padding:10px 8px;border-radius:0;font-weight:600;cursor:pointer;text-align:center}.user-tab.active{color:var(--primary)}.user-empty-state{display:flex;flex-direction:column;align-items:center;gap:10px;padding:12px 0 4px}.user-empty-logo{width:96px;height:96px;object-fit:contain}.user-empty-title{font-weight:600;color:var(--text-main)}.user-empty-desc{font-size:.85rem;color:var(--text-secondary)}.user-logout-card{box-shadow:none;border:none;background:transparent;padding:0}.user-logout-button{width:100%;justify-content:center;height:44px}.login-field{display:flex;gap:12px;align-items:center}.login-input,.user-input,.user-select{width:100%;height:40px;border-radius:12px;border:1px solid var(--border-color);padding:0 12px;font-size:.9rem;background:#f9fafb;color:var(--text-main)}.login-error{color:#dc2626;font-size:.85rem}.login-card .btn-primary{justify-content:center}.login-agreement{text-align:center;font-size:.75rem;color:var(--text-secondary);display:flex;justify-content:center;gap:4px;flex-wrap:wrap}.agreement-link{color:var(--text-secondary);text-decoration:underline;background:transparent;border:none;padding:0;cursor:pointer;font-size:.75rem}.agreement-modal{position:fixed;inset:0;background:#0f172a73;display:flex;align-items:center;justify-content:center;z-index:20;padding:16px}.agreement-card{width:min(720px,100%);max-height:86vh;background:#fff;border-radius:18px;box-shadow:var(--shadow-lg);border:1px solid var(--border-color);display:flex;flex-direction:column;overflow:hidden}.agreement-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px 12px;border-bottom:1px solid var(--border-color)}.agreement-title{font-size:1rem;font-weight:700;color:var(--text-main)}.agreement-close{background:#f3f4f6;border:none;border-radius:999px;padding:6px 12px;font-size:.8rem;cursor:pointer;color:var(--text-secondary)}.agreement-body{padding:16px 20px 96px;overflow-y:auto;display:grid;gap:14px;font-size:.9rem;color:var(--text-main)}.agreement-meta{display:grid;gap:4px;font-size:.8rem;color:var(--text-secondary);justify-self:end;text-align:right}.agreement-sections{display:grid;gap:12px}.agreement-section{display:grid;gap:6px}.agreement-section-title{font-weight:600;color:var(--text-main)}.agreement-section-text{color:var(--text-secondary);line-height:1.6}.confirm-modal{position:fixed;inset:0;background:#0f172a73;display:flex;align-items:center;justify-content:center;z-index:20;padding:16px}.confirm-card{width:min(360px,92vw);background:#fff;border-radius:18px;box-shadow:var(--shadow-lg);border:1px solid var(--border-color);display:flex;flex-direction:column;overflow:hidden}.confirm-header{padding:16px 18px 10px;border-bottom:1px solid var(--border-color);display:flex;justify-content:center}.confirm-title{font-size:1rem;font-weight:700;color:var(--text-main);text-align:center}.confirm-body{padding:14px 18px 16px;display:grid;gap:16px;font-size:.9rem;color:var(--text-main)}.confirm-messages{display:grid;gap:8px}.confirm-message{color:var(--text-secondary);line-height:1.5}.confirm-actions{display:grid;grid-template-columns:1fr 1fr;gap:12px}.confirm-actions .btn-secondary,.confirm-actions .btn-primary{width:100%;min-height:44px;font-size:.95rem;padding:0 12px;display:flex;align-items:center;justify-content:center;text-align:center}.site-footer{display:flex;justify-content:center;padding:18px 16px 24px;color:var(--text-secondary);font-size:.75rem}.icp-link{color:var(--text-secondary);text-decoration:none}.icp-link:hover{text-decoration:underline}.register-success-text{font-size:.95rem;color:var(--text-main);text-align:center}.register-success-actions{display:flex;gap:12px;justify-content:center}.user-field{display:grid;gap:8px}.user-contact-row{display:grid;grid-template-columns:120px minmax(0,1fr);gap:12px}.user-label{font-size:.85rem;color:var(--text-secondary)}.user-value{font-weight:600;color:var(--text-main)}.user-books{display:grid;gap:12px}.user-book-row{display:flex;justify-content:space-between;gap:12px;padding:10px 12px;border-radius:12px;background:#f4fbf7;border:1px solid #e3efea}.user-book-title{font-weight:700}.user-book-sub{font-size:.85rem;color:var(--text-secondary);margin-top:2px}.user-book-price{font-weight:700;color:var(--price-color);background:var(--success-bg);border-radius:999px;padding:4px 10px;height:fit-content}.user-empty{color:var(--text-secondary);font-size:.9rem;text-align:center;padding:12px 0}.has-tabbar{padding-bottom:calc(130px + env(safe-area-inset-bottom))}.app-tabbar{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:12px;background:#ffffffdb;border-top:1px solid rgba(221,239,229,.9);padding:12px 26px 14px;margin:12px auto 18px;max-width:760px;position:relative;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-shadow:0 -10px 30px #0a594e14}.tabbar-item{border:none;background:transparent;color:#5f6f6a;font-weight:600;padding:4px 10px;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px}.tabbar-icon{transition:transform .2s ease}.tabbar-icon path{transition:fill .2s ease}.tabbar-item.active .tabbar-icon{transform:translateY(-2px) scale(1.05)}.tabbar-text{font-size:.75rem;line-height:1.2}.tabbar-item.active{color:#fadf2e}.tabbar-center{display:flex;flex-direction:column;align-items:center;gap:4px;margin-top:-22px;position:relative;z-index:2}.tabbar-center-label{font-size:.75rem;color:#fadf2e;font-weight:600}.tabbar-plus{width:58px;height:58px;border-radius:50%;border:none;background:#fadf2e;color:#0a594e;font-size:1.6rem;font-weight:700;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 18px 26px -14px #0a594e40,0 4px 12px #0a594e26}.tabbar-plus svg{display:block}@media(max-width:768px){.app-tabbar{position:fixed;left:0;right:0;bottom:0;margin:0;max-width:none;z-index:40;border-top:1px solid #ddefe5;padding:12px 28px calc(16px + env(safe-area-inset-bottom));background:#fffffff2}.app-tabbar:after{content:"";position:absolute;left:0;right:0;bottom:calc(-1*(env(safe-area-inset-bottom) + 20px));height:calc(40px + env(safe-area-inset-bottom));background:#fffffff2;pointer-events:none}}@media(min-width:769px){.app-tabbar{position:fixed;left:50%;transform:translate(-50%);bottom:0;margin:0;max-width:760px;width:calc(100% - 48px);z-index:40;border:1px solid #e3efea;border-radius:16px 16px 0 0;box-shadow:0 -12px 30px -24px #0a594e59}}.post-form-page{padding:0 0 100px}.post-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;position:sticky;top:0;background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:50;border-bottom:1px solid var(--border-color)}.post-title{font-size:1.1rem;font-weight:700;color:var(--text-primary)}.post-form{padding:20px}.image-upload-area{min-height:120px;background:#f9fafb;border:2px dashed #e5e7eb;border-radius:16px;display:flex;align-items:center;justify-content:center;cursor:pointer;overflow:hidden;margin-bottom:24px}.image-preview-list{display:flex;gap:12px;padding:12px;overflow-x:auto;width:100%}.image-preview-item{flex-shrink:0;width:100px;height:100px;border-radius:12px;overflow:hidden;position:relative}.image-preview{width:100%;height:100%;object-fit:cover}.add-image-btn{flex-shrink:0;width:100px;height:100px;border-radius:12px;background:#fff;border:2px dashed #e5e7eb;display:flex;align-items:center;justify-content:center;font-size:2rem;color:#9ca3af}.upload-placeholder{color:#6b7280;font-size:.9rem}.form-group{margin-bottom:20px}.form-label{display:block;font-size:.9rem;font-weight:600;margin-bottom:8px;color:var(--text-primary)}.form-input,.form-select,.form-textarea{width:100%;padding:12px 16px;border:1px solid var(--border-color);border-radius:12px;font-size:1rem;background:#fff;transition:all .2s}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #10b9811a}.form-row{display:flex;gap:12px;margin-bottom:20px}.form-group.half{flex:1;margin-bottom:0}.tags-select{display:flex;flex-wrap:wrap;gap:8px}.tag-option{padding:6px 14px;background:#f3f4f6;border-radius:999px;font-size:.85rem;color:#4b5563;cursor:pointer;transition:all .2s}.tag-option.active{background:var(--primary);color:#fff;font-weight:600}.form-section-title{font-size:1rem;font-weight:700;margin:32px 0 16px;color:var(--text-primary)}.contact-method{width:100px!important;flex-shrink:0}.contact-value{flex:1}.btn-primary-small{background:#fadf2e;color:#333;font-weight:600;border:none;padding:8px 16px;border-radius:999px;font-size:.9rem;cursor:pointer}.btn-text{background:none;border:none;color:var(--text-secondary);font-size:.9rem;cursor:pointer;padding:8px}
