@layer base, publisher;@layer base{@import url("https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap");:root{--sf-brand:#147A6E;--sf-brand-light:#147A6E20;--sf-brand-dark:#0f5c53;--sf-bg:#fafafa;--sf-surface:#ffffff;--sf-border:#e8eaed;--sf-border-hover:#c4c8cc;--sf-text-primary:#1a1a2e;--sf-text-secondary:#5f6368;--sf-text-tertiary:#9aa0a6;--sf-text-on-brand:#ffffff;--sf-radius-sm:10px;--sf-radius-md:14px;--sf-radius-lg:20px;--sf-radius-pill:100px;--sf-shadow-sm:0 1px 3px rgba(0,0,0,0.04),0 1px 2px rgba(0,0,0,0.06);--sf-shadow-md:0 4px 16px rgba(0,0,0,0.06),0 1px 3px rgba(0,0,0,0.04);--sf-shadow-lg:0 10px 32px rgba(0,0,0,0.08),0 2px 8px rgba(0,0,0,0.04);--sf-shadow-xl:0 16px 48px rgba(0,0,0,0.1),0 4px 12px rgba(0,0,0,0.04);--sf-font:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;--sf-ct-magazine:#6366f1;--sf-ct-book:#0891b2;--sf-ct-report:#059669;--sf-ct-catalog:#d97706;--sf-ct-brochure:#dc2626;--sf-ct-other:#6b7280}.portal-storefront-root{position:fixed;inset:0;overflow-y:auto;overflow-x:hidden;z-index:10;background:var(--sf-bg);font-family:var(--sf-font);color:var(--sf-text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@keyframes sf-fade-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes sf-hero-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.sf-animate-in{animation:sf-fade-up .45s cubic-bezier(.22,1,.36,1) both}.portal-reader-nav{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.95);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-bottom:1px solid rgba(0,0,0,.06)}.portal-reader-nav-inner{max-width:1280px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:10px 32px;min-height:48px}.portal-reader-nav-left{display:flex;align-items:center;gap:12px}.portal-nav-brand{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--sf-text-primary);font-weight:700;font-size:15px;letter-spacing:-.01em}.portal-nav-brand-logo{height:28px;width:auto;object-fit:contain}.portal-nav-brand-letter{width:28px;height:28px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;color:#fff;font-size:13px;font-weight:700}.portal-reader-nav-back{display:flex;align-items:center;gap:5px;font-size:13px;color:var(--sf-text-secondary);background:none;border:none;cursor:pointer;font-family:inherit;padding:6px 10px;border-radius:8px;transition:all .15s;font-weight:500}.portal-reader-nav-back:hover{background:rgba(0,0,0,.04);color:var(--sf-text-primary)}.portal-reader-nav-right{display:flex;align-items:center;gap:10px}.portal-reader-nav-btn{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:500;color:var(--sf-text-secondary);background:none;border:1px solid var(--sf-border);cursor:pointer;font-family:inherit;padding:7px 14px;border-radius:8px;transition:all .15s}.portal-reader-nav-btn:hover{background:rgba(0,0,0,.03);color:var(--sf-text-primary)}.portal-reader-nav-btn.active{background:rgba(0,0,0,.05);color:var(--sf-text-primary);border-color:var(--sf-border-hover)}.portal-reader-badge{font-size:10px;font-weight:700;background:var(--sf-brand);color:white;border-radius:10px;padding:0 6px;line-height:18px;min-width:18px;text-align:center}.portal-reader-account{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--sf-text-primary);padding:5px 12px;border-radius:8px;background:rgba(0,0,0,.03);font-weight:500}.portal-reader-name{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.portal-reader-logout{display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:var(--sf-text-tertiary);padding:3px;border-radius:4px;transition:all .15s}.portal-reader-logout:hover{color:#dc2626;background:rgba(220,38,38,.08)}.portal-reader-signin{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:600;background:white;border:1.5px solid var(--sf-border);cursor:pointer;font-family:inherit;padding:7px 16px;border-radius:8px;transition:all .2s;color:var(--sf-text-primary);white-space:nowrap}.portal-reader-signin:hover{border-color:var(--sf-border-hover);box-shadow:var(--sf-shadow-sm)}.portal-nav-search{position:relative;flex:0 1 420px;margin:0 16px}.portal-nav-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--sf-text-tertiary);pointer-events:none}.portal-nav-search-input{width:100%;padding:8px 36px;border-radius:10px;border:1.5px solid var(--sf-border);background:#f5f6f8;font-size:13px;font-family:var(--sf-font);font-weight:400;color:var(--sf-text-primary);outline:none;transition:all .2s}.portal-nav-search-input::placeholder{color:var(--sf-text-tertiary)}.portal-nav-search-input:focus{background:#fff;border-color:var(--sf-brand);box-shadow:0 0 0 3px var(--sf-brand-light)}.portal-nav-search-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--sf-text-tertiary);cursor:pointer;padding:2px;border-radius:4px;display:flex;align-items:center;transition:color .15s}.portal-nav-search-clear:hover{color:var(--sf-text-primary)}.portal-carousel,.portal-carousel-slide{position:relative;overflow:hidden}.portal-carousel-slide{padding:72px 32px 80px;min-height:320px;display:flex;align-items:center;justify-content:center;animation:sf-carousel-fade-in .5s ease-out}@keyframes sf-carousel-fade-in{0%{opacity:.6}to{opacity:1}}.portal-carousel-texture{background:url("data:image/svg+xml,%3Csvg viewBox='0 0 400 400' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23g)' opacity='.03'/%3E%3C/svg%3E")}.portal-carousel-shapes,.portal-carousel-texture{position:absolute;inset:0;pointer-events:none;z-index:1}.portal-carousel-circle{position:absolute;border-radius:50%;border:2px solid}.portal-carousel-circle-1{width:400px;height:400px;top:-100px;right:-80px}.portal-carousel-circle-2{width:280px;height:280px;bottom:-60px;left:-40px}.portal-carousel-glow{position:absolute;width:500px;height:500px;border-radius:50%;top:50%;left:50%;transform:translate(-50%,-50%);filter:blur(80px)}.portal-carousel-content{position:relative;z-index:2;text-align:center;max-width:680px;margin:0 auto;animation:sf-fade-up .6s cubic-bezier(.22,1,.36,1) both}.portal-carousel-icon{margin-bottom:24px;opacity:.9}.portal-carousel-headline{font-size:40px;font-weight:800;color:#fff;letter-spacing:-.035em;line-height:1.1;margin-bottom:16px}.portal-carousel-subheadline{font-size:17px;color:rgba(255,255,255,.75);line-height:1.65;max-width:540px;margin:0 auto;font-weight:400}.portal-carousel-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:5;width:44px;height:44px;border-radius:50%;border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.08);backdrop-filter:blur(8px);color:rgba(255,255,255,.8);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.portal-carousel-arrow:hover{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.35);color:#fff}.portal-carousel-arrow-prev{left:24px}.portal-carousel-arrow-next{right:24px}.portal-carousel-dots{position:absolute;bottom:56px;left:50%;transform:translateX(-50%);z-index:5;display:flex;gap:8px}.portal-carousel-dot{width:8px;height:8px;border-radius:50%;border:none;background:rgba(255,255,255,.3);cursor:pointer;padding:0;transition:all .25s}.portal-carousel-dot.active{background:#fff;width:24px;border-radius:4px}.portal-carousel-dot:hover:not(.active){background:rgba(255,255,255,.5)}.portal-hero{position:relative;padding:80px 32px 72px;text-align:center;overflow:hidden}.portal-hero:not(.has-bg){background:radial-gradient(ellipse 80% 60% at 10% 90%,rgba(255,255,255,.12) 0,transparent 60%),radial-gradient(ellipse 60% 50% at 80% 20%,rgba(255,255,255,.08) 0,transparent 50%),linear-gradient(155deg,var(--sf-brand) 0,var(--sf-brand-dark) 55%,color-mix(in srgb,var(--sf-brand-dark) 80%,#1a1a2e) 100%)}.portal-hero:not(.has-bg):before{content:"";position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg viewBox='0 0 400 400' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23g)' opacity='.04'/%3E%3C/svg%3E");pointer-events:none;z-index:1}.portal-hero-bg{position:absolute;inset:0;background-size:cover;background-position:50%;filter:brightness(.25) saturate(1.2);z-index:0}.portal-hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.3),rgba(0,0,0,.55));z-index:1}.portal-hero-content{position:relative;z-index:2;max-width:680px;margin:0 auto}.portal-hero-logo{height:80px;width:auto;max-width:280px;object-fit:contain;margin-bottom:28px;filter:drop-shadow(0 4px 12px rgba(0,0,0,.2))}.portal-hero-letter{width:72px;height:72px;border-radius:18px;display:inline-flex;align-items:center;justify-content:center;color:#fff;font-size:30px;font-weight:800;margin-bottom:28px;background:rgba(255,255,255,.12);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.2);box-shadow:0 8px 24px rgba(0,0,0,.15)}.portal-hero-title{font-size:42px;font-weight:800;margin-bottom:12px;letter-spacing:-.035em;line-height:1.1;color:#fff}.portal-hero-subtitle{font-size:18px;margin-bottom:36px;line-height:1.6;color:rgba(255,255,255,.8);max-width:520px;margin-left:auto;margin-right:auto;font-weight:400}.portal-hero-count{display:none}.portal-hero-wave{position:absolute;bottom:-1px;left:0;right:0;z-index:3;line-height:0}.portal-hero-wave svg{display:block;width:100%;height:48px}.portal-search-wrapper{position:relative;max-width:520px;margin:0 auto}.portal-search-icon{position:absolute;left:18px;top:50%;transform:translateY(-50%);color:rgba(255,255,255,.45);pointer-events:none;z-index:1}.portal-search{width:100%;padding:15px 44px 15px 48px;border-radius:14px;border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.1);backdrop-filter:blur(16px);font-size:15px;font-family:var(--sf-font);font-weight:400;color:#fff;outline:none;transition:all .3s cubic-bezier(.22,1,.36,1);box-shadow:0 4px 24px rgba(0,0,0,.08)}.portal-search::placeholder{color:rgba(255,255,255,.5);font-weight:400}.portal-search:focus{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.35);box-shadow:0 4px 32px rgba(0,0,0,.12),0 0 0 3px rgba(255,255,255,.08)}.portal-search-clear{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.12);border:none;color:rgba(255,255,255,.7);font-size:18px;cursor:pointer;padding:5px 7px;border-radius:8px;transition:all .15s;z-index:1}.portal-search-clear:hover{color:#fff;background:rgba(255,255,255,.22)}.portal-adv-toggle{display:inline-flex;align-items:center;gap:6px;margin-top:14px;background:none;border:none;color:rgba(255,255,255,.55);font-size:13px;font-weight:500;cursor:pointer;padding:5px 12px;border-radius:8px;transition:all .15s;font-family:var(--sf-font)}.portal-adv-toggle:hover{color:rgba(255,255,255,.8);background:rgba(255,255,255,.08)}.portal-adv-toggle .adv-chevron{transition:transform .2s}.portal-adv-toggle.open .adv-chevron{transform:rotate(180deg)}.portal-adv-panel{max-width:520px;margin:12px auto 0;padding:10px 16px;background:rgba(255,255,255,.1);backdrop-filter:blur(12px);border-radius:12px;border:1px solid rgba(255,255,255,.12);display:flex;align-items:center;gap:8px}.portal-adv-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:rgba(255,255,255,.5);flex-shrink:0}.portal-adv-btn{padding:5px 14px;border-radius:var(--sf-radius-pill);border:1px solid rgba(255,255,255,.15);background:transparent;color:rgba(255,255,255,.65);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s;font-family:var(--sf-font);white-space:nowrap}.portal-adv-btn:hover{border-color:rgba(255,255,255,.3);color:#fff}.portal-adv-btn.active{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.35);color:#fff;font-weight:600}.portal-filter-bar{position:sticky;top:48px;z-index:50;background:rgba(250,250,250,.88);backdrop-filter:blur(16px) saturate(180%);-webkit-backdrop-filter:blur(16px) saturate(180%);border-bottom:1px solid transparent;transition:all .25s}.portal-filter-bar.scrolled{border-bottom-color:var(--sf-border);box-shadow:0 1px 8px rgba(0,0,0,.04)}.portal-filter-bar-inner{max-width:1280px;margin:0 auto;padding:14px 32px}.portal-filter-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.portal-filter-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--sf-text-tertiary);margin-right:4px;flex-shrink:0}.portal-filter-divider{width:1px;height:24px;background:var(--sf-border);margin:0 10px;flex-shrink:0}.portal-chip{padding:6px 14px;border-radius:8px;border:none;background:transparent;color:var(--sf-text-secondary);font-size:13px;font-weight:500;cursor:pointer;transition:all .2s cubic-bezier(.22,1,.36,1);white-space:nowrap;flex-shrink:0;font-family:var(--sf-font);position:relative}.portal-chip:hover{color:var(--sf-text-primary);background:rgba(0,0,0,.04)}.portal-chip.active{color:#ffffff;background:var(--sf-brand);box-shadow:0 2px 8px rgba(0,0,0,.1)}.portal-chip:focus-visible{outline:2px solid var(--sf-brand);outline-offset:2px}.portal-chip-dot{display:none}.portal-topics-dropdown{position:relative;flex-shrink:0}.portal-topics-trigger{display:inline-flex;align-items:center;gap:6px;padding:6px 12px 6px 14px;border-radius:8px;border:1.5px solid var(--sf-border);background:var(--sf-surface);color:var(--sf-text-secondary);font-size:13px;font-weight:500;cursor:pointer;font-family:var(--sf-font);transition:all .2s;white-space:nowrap}.portal-topics-trigger:hover{border-color:var(--sf-border-hover);color:var(--sf-text-primary)}.portal-topics-trigger.has-selection{font-weight:600;background:var(--sf-brand-light)}.portal-topics-chevron{transition:transform .2s}.portal-topics-chevron.open{transform:rotate(180deg)}.portal-topics-popover{position:absolute;top:calc(100% + 6px);left:0;min-width:220px;max-height:320px;overflow-y:auto;background:var(--sf-surface);border:1px solid var(--sf-border);border-radius:12px;box-shadow:var(--sf-shadow-lg);z-index:60;padding:4px;animation:sf-popover-in .15s ease-out}@keyframes sf-popover-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.portal-topics-option{display:flex;align-items:center;justify-content:space-between;width:100%;padding:9px 12px;border:none;background:none;color:var(--sf-text-secondary);font-size:13px;font-weight:500;font-family:var(--sf-font);cursor:pointer;border-radius:8px;transition:all .12s;text-align:left}.portal-topics-option:hover{background:#f3f4f6;color:var(--sf-text-primary)}.portal-topics-option.active{color:var(--sf-text-primary);font-weight:600;background:var(--sf-brand-light)}.portal-topics-search-wrap{position:relative;padding:4px 4px 0;margin-bottom:4px}.portal-topics-search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--sf-text-tertiary);pointer-events:none;margin-top:2px}.portal-topics-search{width:100%;padding:8px 12px 8px 32px;border:1.5px solid var(--sf-border);border-radius:8px;font-size:13px;font-family:var(--sf-font);color:var(--sf-text-primary);background:#f9fafb;outline:none;transition:border-color .15s;box-sizing:border-box}.portal-topics-search:focus{border-color:var(--sf-brand);background:#fff}.portal-topics-search::placeholder{color:var(--sf-text-tertiary)}.portal-topics-list{max-height:260px;overflow-y:auto}.portal-topics-empty{padding:16px 12px;text-align:center;font-size:13px;color:var(--sf-text-tertiary)}.portal-sort-select{padding:7px 32px 7px 12px;border-radius:10px;border:1.5px solid var(--sf-border);background:var(--sf-surface);color:var(--sf-text-secondary);font-size:13px;font-weight:500;font-family:var(--sf-font);cursor:pointer;outline:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%239ca3af' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;transition:border-color .15s}.portal-sort-select:hover{border-color:var(--sf-border-hover)}.portal-sort-select:focus-visible{outline:2px solid var(--sf-brand);outline-offset:2px}.portal-view-toggle{display:flex;border-radius:10px;border:1.5px solid var(--sf-border);overflow:hidden}.portal-view-btn{padding:6px 10px;background:var(--sf-surface);border:none;cursor:pointer;color:var(--sf-text-tertiary);display:flex;align-items:center;justify-content:center;transition:all .15s}.portal-view-btn.active{background:#f0f1f3;color:var(--sf-text-primary)}.portal-view-btn:focus-visible{outline:2px solid var(--sf-brand);outline-offset:-2px}.portal-featured{max-width:1280px;margin:0 auto 40px;padding:28px 32px 32px;background:var(--sf-surface);border-radius:24px;border:1px solid var(--sf-border);box-shadow:var(--sf-shadow-sm)}.portal-section-kicker{display:none}.portal-section-title{font-size:22px;font-weight:700;color:var(--sf-text-primary);margin-bottom:20px;display:flex;align-items:center;gap:10px;letter-spacing:-.02em;line-height:1.2}.portal-section-title-sub{display:block;font-size:13px;font-weight:500;color:var(--sf-text-tertiary);margin-top:4px;letter-spacing:0}.portal-library-heading{max-width:1280px;margin:0 auto 20px;padding:0 32px}.portal-library-heading .portal-section-title{font-size:20px;padding-bottom:14px;border-bottom:2px solid var(--sf-border);margin-bottom:0}.portal-featured-scroll{display:flex;gap:20px;overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:8px;scrollbar-width:thin;-webkit-overflow-scrolling:touch;padding-right:60px;margin-right:-24px}.portal-featured-scroll::-webkit-scrollbar{height:3px}.portal-featured-scroll::-webkit-scrollbar-track{background:transparent}.portal-featured-scroll::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:2px}.portal-featured-card{flex:0 0 280px;scroll-snap-align:start;text-decoration:none;display:flex;flex-direction:column;border-radius:16px;border:1px solid var(--sf-border);overflow:hidden;background:var(--sf-surface);transition:all .3s cubic-bezier(.22,1,.36,1);position:relative;cursor:pointer;font-family:var(--sf-font);box-shadow:var(--sf-shadow-sm)}.portal-featured-card:before{display:none}.portal-featured-card:hover{box-shadow:var(--sf-shadow-lg);transform:translateY(-4px);border-color:var(--sf-border-hover)}.portal-featured-card:focus-visible{outline:2px solid var(--sf-brand);outline-offset:2px}.portal-featured-badge{display:none}.portal-featured-thumb{aspect-ratio:3/4;background:linear-gradient(145deg,#f5f6f8,#eceef1);position:relative;overflow:hidden}.portal-featured-thumb img{width:100%;height:100%;object-fit:contain;transition:transform .4s cubic-bezier(.22,1,.36,1)}.portal-featured-card:hover .portal-featured-thumb img{transform:scale(1.03)}.portal-featured-thumb:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 65%,rgba(0,0,0,.04));opacity:0;transition:opacity .3s}.portal-featured-card:hover .portal-featured-thumb:after{opacity:1}.portal-featured-body{padding:16px 18px 18px;flex:1;display:flex;flex-direction:column}.portal-featured-category{display:inline-block;align-self:flex-start;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:3px 8px;border-radius:4px;margin-bottom:8px;max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;background:#f0f1f3;color:var(--sf-text-secondary)}.portal-featured-title{font-size:16px;font-weight:600;color:var(--sf-text-primary);line-height:1.35;letter-spacing:-.01em;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.portal-featured-meta{font-size:13px;color:var(--sf-text-tertiary);margin-top:auto;padding-top:10px;font-weight:400}.portal-category-section{max-width:1280px;margin:0 auto 40px;padding:0 32px}.portal-category-header{display:flex;align-items:center;gap:12px;margin-bottom:20px;padding-bottom:14px;border-bottom:2px solid var(--sf-border)}.portal-category-name{font-size:20px;font-weight:700;color:var(--sf-text-primary);letter-spacing:-.01em}.portal-category-count{justify-content:center;min-width:28px;height:24px;padding:0 8px;border-radius:var(--sf-radius-pill);background:var(--sf-brand-light);font-size:12px;font-weight:700}.portal-category-count,.portal-category-viewall{display:inline-flex;align-items:center;color:var(--sf-brand)}.portal-category-viewall{gap:4px;margin-top:20px;font-size:14px;font-weight:600;background:none;border:none;cursor:pointer;padding:8px 16px;border-radius:var(--sf-radius-sm);transition:all .15s;font-family:var(--sf-font)}.portal-category-viewall:hover{background:var(--sf-brand-light)}.portal-category-viewall:focus-visible{outline:2px solid var(--sf-brand);outline-offset:2px}.portal-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:24px}.portal-list{gap:8px}.portal-card,.portal-list{display:flex;flex-direction:column}.portal-card{border-radius:16px;border:1px solid var(--sf-border);overflow:hidden;background:var(--sf-surface);text-decoration:none;transition:all .3s cubic-bezier(.22,1,.36,1);cursor:pointer;font-family:var(--sf-font)}.portal-card:hover{box-shadow:var(--sf-shadow-lg);border-color:var(--sf-border-hover);transform:translateY(-4px) scale(1.01)}.portal-card:active{transform:translateY(-1px);box-shadow:var(--sf-shadow-md)}.portal-card:focus-visible{outline:2px solid var(--sf-brand);outline-offset:2px}.portal-card-thumb{aspect-ratio:3/4;background:linear-gradient(145deg,#f5f6f8,#eceef1);position:relative;overflow:hidden}.portal-card-thumb img{width:100%;height:100%;object-fit:contain;transition:transform .4s cubic-bezier(.22,1,.36,1)}.portal-card:hover .portal-card-thumb img{transform:scale(1.04)}.portal-card-thumb:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(0,0,0,.06));opacity:0;transition:opacity .3s;pointer-events:none}.portal-card:hover .portal-card-thumb:after{opacity:1}.portal-card-thumb-fallback{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px}.portal-card-content-badge{position:absolute;top:10px;right:10px;color:#fff;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;padding:4px 10px;border-radius:6px;box-shadow:0 2px 8px rgba(0,0,0,.12);z-index:1}.portal-card-body{padding:16px 18px;flex:1;display:flex;flex-direction:column}.portal-card-category{display:inline-block;align-self:flex-start;font-size:10px;font-weight:700;color:var(--sf-text-secondary);background:#f0f1f3;text-transform:uppercase;letter-spacing:.06em;padding:3px 8px;border-radius:4px;border-left:3px solid var(--sf-brand);margin-bottom:10px;max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.portal-card-tags{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:8px}.portal-card-tag{font-size:10px;font-weight:500;padding:2px 8px;border-radius:var(--sf-radius-pill);background:#f0f1f3;color:var(--sf-text-secondary);border:1px solid var(--sf-border)}.portal-card-title{font-size:15px;font-weight:600;color:var(--sf-text-primary);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:4px;letter-spacing:-.01em}.portal-card-author{font-size:13px;color:var(--sf-text-tertiary);font-style:normal;font-weight:400;margin-bottom:6px}.portal-card-desc{font-size:13px;color:var(--sf-text-secondary);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;flex:1}.portal-card-meta{display:flex;align-items:center;justify-content:space-between;margin-top:12px;padding-top:10px;border-top:1px solid #f3f4f6;font-size:12px;color:var(--sf-text-tertiary)}.portal-card-meta-info{display:flex;align-items:center;gap:6px}.portal-card-pages-icon{display:inline-flex;align-items:center;gap:3px}.portal-card-arrow{opacity:0;transition:opacity .2s,transform .2s;color:var(--sf-brand)}.portal-card:hover .portal-card-arrow{opacity:1;transform:translateX(3px)}.portal-list-card{display:flex;align-items:center;gap:16px;padding:14px 18px;border-radius:var(--sf-radius-md);border:1px solid var(--sf-border);background:var(--sf-surface);text-decoration:none;transition:all .2s;cursor:pointer;font-family:var(--sf-font)}.portal-list-card:hover{box-shadow:var(--sf-shadow-md);border-color:var(--sf-border-hover);transform:translateX(2px)}.portal-list-card:focus-visible{outline:2px solid var(--sf-brand);outline-offset:2px}.portal-list-thumb{width:56px;height:72px;border-radius:8px;overflow:hidden;background:#f0f1f3;flex-shrink:0;position:relative}.portal-list-thumb img{width:100%;height:100%;object-fit:cover}.portal-list-info{flex:1;min-width:0}.portal-list-title{font-size:14px;font-weight:600;color:var(--sf-text-primary)}.portal-list-desc,.portal-list-title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.portal-list-desc{font-size:13px;color:var(--sf-text-tertiary);margin-top:2px}.portal-list-meta{display:flex;gap:12px;font-size:12px;color:var(--sf-text-tertiary);margin-top:4px}.portal-card-price-badge{font-size:11px;color:#92400e;background:linear-gradient(135deg,#fef3c7,#fde68a);padding:4px 12px;box-shadow:0 2px 8px rgba(0,0,0,.1);letter-spacing:.02em}.portal-card-free-badge,.portal-card-price-badge{position:absolute;top:10px;right:10px;font-weight:700;border-radius:8px;z-index:2}.portal-card-free-badge{font-size:10px;color:#065f46;background:linear-gradient(135deg,#d1fae5,#a7f3d0);padding:3px 10px;box-shadow:0 2px 8px rgba(0,0,0,.06);text-transform:uppercase;letter-spacing:.04em}.portal-detail{max-width:1100px;margin:0 auto;padding:0 32px 80px}.portal-detail-hero{position:relative;margin:0 -32px 36px;padding:40px 32px;overflow:hidden;background:linear-gradient(145deg,var(--sf-brand),var(--sf-brand-dark));min-height:80px}.portal-detail-hero-blur{position:absolute;inset:-20px;background-size:cover;background-position:50%;filter:blur(30px) brightness(.35) saturate(1.3);z-index:0}.portal-detail-hero-overlay{position:absolute;inset:0;background:rgba(0,0,0,.25);z-index:1}.portal-detail-hero-inner{position:relative;z-index:2;max-width:1100px;margin:0 auto;display:flex;align-items:center;justify-content:space-between}.portal-detail-back{display:inline-flex;align-items:center;gap:6px;font-size:14px;font-weight:500;color:rgba(255,255,255,.8);text-decoration:none;padding:8px 14px;border-radius:var(--sf-radius-sm);transition:all .15s;background:none;border:none;cursor:pointer;font-family:var(--sf-font)}.portal-detail-back:hover{color:#fff;background:rgba(255,255,255,.1)}.portal-detail-back:focus-visible{outline:2px solid #fff;outline-offset:2px}.portal-detail-layout{display:grid;grid-template-columns:340px 1fr;gap:48px;align-items:start}.portal-detail-sidebar{position:sticky;top:80px}.portal-detail-cover{border-radius:16px;overflow:hidden;border:1px solid var(--sf-border);background:linear-gradient(145deg,#f5f6f8,#eceef1);aspect-ratio:3/4;box-shadow:var(--sf-shadow-md)}.portal-detail-cover img{width:100%;height:100%;object-fit:contain;display:block}.portal-detail-cover-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:56px}.portal-detail-badges{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}.portal-detail-badge{font-size:11px;font-weight:600;padding:4px 12px;border-radius:6px;letter-spacing:.04em;text-transform:uppercase}.portal-detail-title{font-size:32px;font-weight:800;color:var(--sf-text-primary);line-height:1.2;margin-bottom:12px;letter-spacing:-.025em}.portal-detail-meta{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:20px;color:var(--sf-text-tertiary);font-size:14px}.portal-detail-author{font-style:normal;font-weight:500;color:var(--sf-text-secondary)}.portal-detail-cta{display:flex;gap:12px;margin-bottom:36px}.portal-detail-read-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:14px 36px;color:#fff;font-size:15px;font-weight:600;border-radius:12px;text-decoration:none;transition:all .25s cubic-bezier(.22,1,.36,1);border:none;cursor:pointer;font-family:var(--sf-font);box-shadow:0 4px 16px rgba(0,0,0,.12)}.portal-detail-read-btn:hover{filter:brightness(.93);box-shadow:0 6px 20px rgba(0,0,0,.18);transform:translateY(-2px)}.portal-detail-read-btn:focus-visible{outline:2px solid var(--sf-brand);outline-offset:3px}.portal-detail-share-btn{padding:14px 24px;background:transparent;color:var(--sf-text-secondary);font-size:14px;font-weight:500;border:1.5px solid var(--sf-border);border-radius:12px;cursor:pointer;transition:all .2s;font-family:var(--sf-font);display:inline-flex;align-items:center;gap:6px}.portal-detail-share-btn:hover{border-color:var(--sf-border-hover);color:var(--sf-text-primary);background:#f9fafb;box-shadow:var(--sf-shadow-sm)}.portal-detail-share-btn:focus-visible{outline:2px solid var(--sf-brand);outline-offset:2px}.portal-detail-section{margin-bottom:32px}.portal-detail-section-label{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--sf-text-tertiary);margin-bottom:12px}.portal-detail-description{color:#374151;font-size:15px;line-height:1.75}.portal-detail-tags{display:flex;gap:6px;flex-wrap:wrap}.portal-detail-tag-pill{display:inline-flex;align-items:center;gap:4px;padding:5px 14px;border-radius:var(--sf-radius-pill);font-size:12px;font-weight:500;border:1px solid var(--sf-border);background:var(--sf-surface);color:var(--sf-text-secondary);transition:all .15s}.portal-detail-tag-pill:hover{border-color:var(--sf-border-hover);background:#f3f4f6}.portal-detail-takeaways{list-style:none;padding:0;margin:0}.portal-detail-takeaways li{color:#374151;font-size:14px;line-height:1.65;padding:6px 0 6px 22px;position:relative}.portal-detail-takeaways li:before{content:"";position:absolute;left:0;top:13px;width:6px;height:6px;border-radius:50%;background:var(--sf-brand)}.portal-detail-toc{list-style:none;padding:0;margin:0;border:1px solid var(--sf-border);border-radius:12px;overflow:hidden}.portal-detail-toc-item{display:flex;justify-content:space-between;align-items:baseline;padding:12px 18px;border-bottom:1px solid #f3f4f6;transition:background .15s}.portal-detail-toc-item:last-child{border-bottom:none}.portal-detail-toc-item:hover{background:#f9fafb}.portal-detail-toc-title{color:#374151;font-size:14px}.portal-detail-toc-page{color:var(--sf-text-tertiary);font-size:12px;font-variant-numeric:tabular-nums;flex-shrink:0;margin-left:12px}.portal-detail-toc-link{text-decoration:none;color:inherit;display:flex;justify-content:space-between;align-items:baseline;width:100%}.portal-detail-toc-link:hover .portal-detail-toc-title{color:var(--sf-brand)}.portal-detail-previews{margin-top:20px}.portal-detail-preview-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.portal-detail-preview-thumb{width:100%;aspect-ratio:3/4;object-fit:contain;border-radius:8px;border:1px solid var(--sf-border);background:#f5f6f8;transition:border-color .15s}.portal-detail-preview-thumb:hover{border-color:var(--sf-brand)}.portal-detail-price{display:flex;align-items:baseline;gap:10px;margin-bottom:16px}.portal-detail-price-value{font-size:28px;font-weight:800;color:var(--sf-text-primary);letter-spacing:-.02em}.portal-detail-price-preview{font-size:12px;color:var(--sf-text-secondary);background:#f3f4f6;padding:3px 10px;border-radius:6px}.portal-detail-purchase-btn{display:inline-flex!important;align-items:center;gap:6px}.portal-chat-fab{position:fixed;bottom:24px;right:24px;width:56px;height:56px;border-radius:50%;border:none;color:#fff;cursor:pointer;box-shadow:0 4px 24px rgba(0,0,0,.18),0 0 0 3px rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center;transition:all .25s cubic-bezier(.22,1,.36,1);z-index:1000;font-family:var(--sf-font)}.portal-chat-fab:hover{transform:scale(1.08);box-shadow:0 6px 32px rgba(0,0,0,.25),0 0 0 3px rgba(255,255,255,.15)}.portal-chat-fab:focus-visible{outline:3px solid var(--sf-brand);outline-offset:3px}.portal-chat-panel{position:fixed;bottom:96px;right:24px;width:400px;max-height:560px;border-radius:20px;border:1px solid var(--sf-border);background:var(--sf-surface);box-shadow:var(--sf-shadow-xl);display:flex;flex-direction:column;z-index:1001;overflow:hidden;animation:sf-chat-in .25s ease-out}@keyframes sf-chat-in{0%{opacity:0;transform:translateY(12px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.portal-chat-header{padding:16px 20px;border-bottom:1px solid #f3f4f6;display:flex;align-items:center;justify-content:space-between}.portal-chat-header-title{font-size:15px;font-weight:600;color:var(--sf-text-primary);display:flex;align-items:center}.portal-chat-close{background:none;border:none;color:var(--sf-text-tertiary);cursor:pointer;padding:6px;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:all .15s}.portal-chat-close:hover{color:var(--sf-text-secondary);background:#f3f4f6}.portal-chat-close:focus-visible{outline:2px solid var(--sf-brand);outline-offset:2px}.portal-chat-messages{flex:1;overflow-y:auto;padding:16px 20px;gap:12px}.portal-chat-messages,.portal-chat-msg-wrapper{display:flex;flex-direction:column}.portal-chat-msg{max-width:85%;padding:10px 14px;border-radius:14px;font-size:14px;line-height:1.5;word-break:break-word}.portal-chat-msg.user{align-self:flex-end;color:#fff;border-bottom-right-radius:4px}.portal-chat-msg.assistant{align-self:flex-start;background:#f3f4f6;color:#374151;border-bottom-left-radius:4px}.portal-chat-msg-time{font-size:10px;color:var(--sf-text-tertiary);margin-top:4px;padding:0 4px}.portal-chat-msg-time.user{align-self:flex-end;text-align:right}.portal-chat-msg-time.assistant{align-self:flex-start}.portal-chat-citations{margin-top:8px;padding-top:8px;border-top:1px solid var(--sf-border);align-self:flex-start}.portal-chat-citations-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--sf-text-secondary);margin-bottom:6px}.portal-chat-citation{display:inline-flex;align-items:center;gap:5px;font-size:11px;color:var(--sf-text-secondary);padding:4px 10px;border-radius:8px;background:#f9fafb;border:1px solid var(--sf-border);text-decoration:none;margin-right:4px;margin-bottom:4px;transition:all .15s}.portal-chat-citation:hover{border-color:var(--sf-border-hover);color:var(--sf-text-primary);background:#f3f4f6}.portal-chat-citation-icon{flex-shrink:0}.portal-chat-input-area{padding:12px 16px;border-top:1px solid #f3f4f6;display:flex;gap:8px;background:var(--sf-surface)}.portal-chat-input{flex:1;padding:10px 14px;border-radius:12px;border:1px solid var(--sf-border);font-size:14px;font-family:var(--sf-font);color:var(--sf-text-primary);outline:none;resize:none;min-height:40px;max-height:80px;transition:border-color .15s}.portal-chat-input:focus{border-color:var(--sf-brand);box-shadow:0 0 0 2px var(--sf-brand-light)}.portal-chat-send{width:40px;height:40px;border-radius:12px;border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}.portal-chat-send:disabled{opacity:.5;cursor:not-allowed}.portal-chat-send:hover:not(:disabled){filter:brightness(.9);transform:scale(1.05)}.portal-chat-send:focus-visible{outline:2px solid var(--sf-brand);outline-offset:2px}.portal-chat-typing{display:flex;gap:4px;padding:10px 14px;align-self:flex-start;background:#f3f4f6;border-radius:14px;border-bottom-left-radius:4px}.portal-chat-typing span{width:6px;height:6px;border-radius:50%;background:#d1d5db;animation:portal-dot-pulse 1.4s ease-in-out infinite}.portal-chat-typing span:nth-child(2){animation-delay:.2s}.portal-chat-typing span:nth-child(3){animation-delay:.4s}@keyframes portal-dot-pulse{0%,80%,to{opacity:.4;transform:scale(.8)}40%{opacity:1;transform:scale(1)}}.portal-empty{text-align:center;padding:80px 24px}.portal-empty-icon{width:72px;height:72px;border-radius:20px;background:#f3f4f6;display:flex;align-items:center;justify-content:center;margin:0 auto 20px;color:#d1d5db}.portal-empty-title{font-size:20px;font-weight:600;color:var(--sf-text-primary);margin-bottom:8px}.portal-empty-text{font-size:14px;color:var(--sf-text-tertiary);max-width:360px;margin:0 auto;line-height:1.6}.portal-footer{padding:40px 32px;text-align:center;border-top:1px solid var(--sf-border);background:var(--sf-surface);margin-top:auto}.portal-footer-inner{max-width:1280px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:12px}.portal-footer-brand{font-size:14px;font-weight:600;color:var(--sf-text-primary);letter-spacing:-.01em}.portal-footer-divider{width:32px;height:1px;background:var(--sf-border)}.portal-footer a{font-size:12px;color:var(--sf-text-tertiary);text-decoration:none;transition:color .15s;font-weight:500}.portal-footer a:hover{color:var(--sf-brand)}.portal-bookshelf{max-width:1280px;margin:0 auto;padding:32px 32px 48px;min-height:60vh}.portal-bookshelf-header{display:flex;align-items:center;gap:12px;margin-bottom:28px;padding-bottom:16px;border-bottom:1px solid var(--sf-border)}.portal-bookshelf-title{font-size:24px;font-weight:700;color:var(--sf-text-primary);margin:0;letter-spacing:-.02em}.portal-bookshelf-count{font-size:13px;color:var(--sf-text-secondary);background:#f3f4f6;padding:4px 12px;border-radius:20px;font-weight:500}.portal-bookshelf-empty{text-align:center;padding:80px 20px}.portal-bookshelf-empty h3{font-size:18px;font-weight:600;color:var(--sf-text-primary);margin:16px 0 8px}.portal-bookshelf-empty p{font-size:14px;color:var(--sf-text-secondary);margin:0 0 24px}.portal-bookshelf-browse{display:inline-flex;align-items:center;gap:6px;padding:10px 24px;color:white;font-size:14px;font-weight:600;border:none;border-radius:10px;cursor:pointer;font-family:inherit;transition:all .2s}.portal-bookshelf-browse:hover{opacity:.9;transform:translateY(-1px)}.portal-bookshelf-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.portal-bookshelf-card{display:flex;gap:16px;background:var(--sf-surface);border:1px solid var(--sf-border);border-radius:14px;padding:16px;transition:all .2s}.portal-bookshelf-card:hover{border-color:var(--sf-border-hover);box-shadow:var(--sf-shadow-md)}.portal-bookshelf-card-thumb{position:relative;width:80px;height:110px;flex-shrink:0;border-radius:8px;overflow:hidden;background:#f5f6f8}.portal-bookshelf-card-fallback{display:flex;align-items:center;justify-content:center;height:100%}.portal-bookshelf-owned-badge{position:absolute;bottom:4px;left:4px;right:4px;display:flex;align-items:center;justify-content:center;gap:3px;font-size:9px;font-weight:700;color:white;background:rgba(5,150,105,.85);backdrop-filter:blur(4px);padding:3px 0;border-radius:4px;text-transform:uppercase;letter-spacing:.04em}.portal-bookshelf-card-info{flex:1;min-width:0;display:flex;flex-direction:column}.portal-bookshelf-card-title{font-size:15px;font-weight:600;color:var(--sf-text-primary);margin:0 0 4px;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.portal-bookshelf-card-author{font-size:12px;color:var(--sf-text-secondary);margin:0 0 8px}.portal-bookshelf-card-meta{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--sf-text-tertiary);margin-bottom:auto}.portal-bookshelf-card-type{text-transform:uppercase;font-weight:600;font-size:10px;background:#f3f4f6;padding:1px 6px;border-radius:4px}.portal-bookshelf-read-btn{display:inline-flex;align-items:center;justify-content:center;margin-top:10px;padding:7px 16px;color:white;font-size:12px;font-weight:600;text-decoration:none;border-radius:8px;transition:all .2s;width:fit-content}.portal-bookshelf-read-btn:hover{opacity:.9;transform:translateY(-1px)}.portal-modal-overlay{position:fixed;inset:0;z-index:10000;display:flex;align-items:center;justify-content:center;background:rgba(15,15,35,.5);backdrop-filter:blur(8px);padding:20px}.portal-modal{position:relative;background:white;border-radius:20px;padding:36px;width:100%;max-width:420px;box-shadow:var(--sf-shadow-xl);text-align:center;max-height:90vh;overflow-y:auto}.portal-modal-close{position:absolute;top:14px;right:14px;background:none;border:none;cursor:pointer;color:var(--sf-text-tertiary);padding:4px;border-radius:6px;transition:all .15s}.portal-modal-close:hover{background:#f3f4f6;color:var(--sf-text-primary)}.portal-modal-icon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}.portal-modal-title{font-size:20px;font-weight:700;color:var(--sf-text-primary);margin:0 0 6px}.portal-modal-subtitle{font-size:13px;color:var(--sf-text-secondary);margin:0 0 24px}.portal-auth-tabs{display:flex;gap:4px;background:#f3f4f6;border-radius:10px;padding:3px;margin-bottom:20px}.portal-auth-tab{flex:1;padding:8px;font-size:13px;font-weight:600;color:var(--sf-text-secondary);background:transparent;border:none;border-radius:8px;cursor:pointer;font-family:inherit;transition:all .15s}.portal-auth-tab.active{background:white;color:var(--sf-text-primary);box-shadow:var(--sf-shadow-sm)}.portal-auth-form{text-align:left}.portal-auth-field{margin-bottom:14px}.portal-auth-field label{display:block;font-size:12px;font-weight:600;color:#374151;margin-bottom:5px}.portal-auth-field input{width:100%;padding:10px 14px;border:1.5px solid var(--sf-border);border-radius:10px;font-size:14px;font-family:inherit;background:#fafafa;transition:all .15s;box-sizing:border-box}.portal-auth-field input:focus{outline:none;border-color:var(--sf-brand);box-shadow:0 0 0 3px var(--sf-brand-light)}.portal-auth-error{font-size:13px;color:#dc2626;margin:0 0 12px;text-align:center}.portal-auth-submit{width:100%;padding:12px;color:white;font-size:14px;font-weight:600;border:none;border-radius:10px;cursor:pointer;font-family:inherit;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .15s;margin-top:4px}.portal-auth-submit:hover{opacity:.9}.portal-auth-submit:disabled{opacity:.5;cursor:not-allowed}.portal-purchase-card{display:flex;align-items:center;gap:12px;background:#f9fafb;border:1px solid var(--sf-border);border-radius:12px;padding:14px;margin-bottom:16px;text-align:left}.portal-purchase-info{flex:1;min-width:0}.portal-purchase-title{font-size:14px;font-weight:600;color:var(--sf-text-primary);margin:0 0 2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.portal-purchase-org{font-size:12px;color:var(--sf-text-secondary);margin:0}.portal-purchase-price{font-size:22px;font-weight:800;color:var(--sf-text-primary);flex-shrink:0}.portal-purchase-btn{width:100%;padding:12px;color:white;font-size:15px;font-weight:700;border:none;border-radius:10px;cursor:pointer;font-family:inherit;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s}.portal-purchase-btn:hover{opacity:.9;transform:translateY(-1px)}.portal-purchase-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.portal-purchase-note{font-size:11px;color:var(--sf-text-tertiary);margin:12px 0 0}@media (max-width:1199px){.portal-detail-layout{grid-template-columns:280px 1fr;gap:32px}.portal-featured-card{flex:0 0 250px}.portal-reader-nav-inner{padding:10px 24px}.portal-filter-bar-inner{padding:12px 24px}}@media (max-width:768px){.portal-hero{padding:56px 20px 60px}.portal-hero-title{font-size:28px}.portal-hero-subtitle{font-size:15px}.portal-hero-logo{height:60px}.portal-hero-wave svg{height:32px}.portal-carousel-slide{padding:48px 20px 64px;min-height:240px}.portal-carousel-headline{font-size:26px}.portal-carousel-subheadline{font-size:14px}.portal-carousel-arrow{display:none}.portal-carousel-dots{bottom:44px}.portal-carousel-circle-1{width:250px;height:250px}.portal-carousel-circle-2{width:180px;height:180px}.portal-reader-nav-inner{padding:8px 16px;flex-wrap:wrap;gap:8px}.portal-nav-brand span,.portal-reader-name{display:none}.portal-nav-search{flex:1 1 100%;order:10;margin:0}.portal-nav-search-input{font-size:13px;padding:9px 36px}.portal-reader-nav-btn{padding:6px 10px;font-size:12px}.portal-nav-btn-text{display:none}.portal-reader-signin{padding:6px 12px;font-size:12px}.portal-filter-bar-inner{padding:10px 16px}.portal-filter-bar{position:relative;top:auto}.portal-filter-row{flex-wrap:wrap;gap:8px}.portal-filter-divider{display:none}.portal-topics-dropdown{width:100%}.portal-topics-trigger{width:100%;justify-content:space-between}.portal-topics-popover{left:0;right:0;min-width:unset;width:100%}.portal-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}.portal-featured-card{flex:0 0 220px}.portal-featured-scroll{padding-right:40px}.portal-featured{padding:20px 16px 24px;margin:0 16px 32px;border-radius:16px}.portal-detail-hero{margin:0 -16px 24px;padding:24px 16px}.portal-detail{padding:0 16px 60px}.portal-detail-layout{grid-template-columns:1fr;gap:24px}.portal-detail-sidebar{position:static}.portal-detail-cover{max-width:260px;margin:0 auto}.portal-detail-title{font-size:24px}.portal-detail-cta{flex-direction:column}.portal-chat-panel{right:8px;left:8px;width:auto;bottom:80px;max-height:70vh}.portal-category-section,.portal-library-heading{padding:0 16px}.portal-adv-panel{flex-wrap:wrap}.portal-bookshelf{padding:20px 16px 40px}.portal-bookshelf-grid{grid-template-columns:1fr}.portal-bookshelf-card{gap:12px;padding:12px}.portal-modal{padding:24px;margin:10px}.portal-footer{padding:28px 16px}.portal-filter-row>div[style*=marginLeft]{margin-left:0!important;width:100%;justify-content:space-between}}@media (max-width:480px){.portal-filter-row{flex-wrap:wrap;gap:6px}.portal-filter-row>div[role=group]{display:flex;overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch;gap:4px;padding-bottom:2px;width:100%}.portal-chip{padding:5px 10px;font-size:12px}.portal-filter-label{font-size:10px}.portal-grid{grid-template-columns:1fr}.portal-hero-title{font-size:24px}.portal-detail-preview-grid{grid-template-columns:repeat(3,1fr)}.portal-carousel-headline{font-size:22px}.portal-carousel-subheadline{font-size:13px;max-width:280px}.portal-carousel-icon svg{width:36px;height:36px}.portal-featured-card{flex:0 0 180px}}}