.app-portal{--app-bg: hsl(45, 96%, 95%);--app-fg: hsl(25, 15%, 15%);--app-card: hsl(0, 0%, 100%);--app-card-fg: hsl(25, 15%, 15%);--app-primary: hsl(45, 96%, 55%);--app-primary-fg: hsl(0, 0%, 0%);--app-secondary: hsl(45, 85%, 85%);--app-secondary-fg: hsl(25, 15%, 15%);--app-accent: hsl(40, 100%, 65%);--app-accent-fg: hsl(0, 0%, 0%);--app-muted: hsl(45, 50%, 90%);--app-muted-fg: hsl(25, 8%, 45%);--app-destructive: hsl(0, 84.2%, 60.2%);--app-destructive-fg: hsl(0, 0%, 98%);--app-border: hsl(45, 30%, 85%);--app-input: hsl(45, 30%, 90%);--app-ring: hsl(45, 96%, 55%);--app-price: hsl(39, 100%, 56%);--app-background: var(--app-bg);--app-foreground: var(--app-fg);--app-bg-rgb: 251, 243, 219;--app-fg-rgb: 46, 40, 35;--app-card-rgb: 255, 255, 255;--app-primary-rgb: 217, 174, 17;--app-primary-fg-rgb: 0, 0, 0;--app-secondary-rgb: 240, 222, 176;--app-secondary-fg-rgb: 46, 40, 35;--app-accent-rgb: 255, 191, 77;--app-accent-fg-rgb: 0, 0, 0;--app-muted-rgb: 237, 230, 214;--app-muted-fg-rgb: 116, 108, 96;--app-border-rgb: 222, 210, 183;--app-price-rgb: 255, 163, 31;--app-destructive-rgb: 239, 68, 68;--app-warm-gradient: linear-gradient(135deg, hsl(45 95% 88%) 0%, hsl(35 85% 85%) 100%);--app-hero-gradient: linear-gradient(135deg, hsl(52 95% 88%) 0%, hsl(48 90% 82%) 50%, hsl(50 95% 85%) 100%);--app-card-shadow: 0 4px 20px -2px hsl(45 96% 55% / .15);--app-card-hover-shadow: 0 8px 30px -2px hsl(45 96% 55% / .25);--app-transition-smooth: all .3s cubic-bezier(.4, 0, .2, 1);--app-safe-area-top: var(--safe-area-inset-top, env(safe-area-inset-top, 0px));--app-safe-area-bottom: var(--safe-area-inset-bottom, env(safe-area-inset-bottom, 0px));--app-safe-area-left: var(--safe-area-inset-left, env(safe-area-inset-left, 0px));--app-safe-area-right: var(--safe-area-inset-right, env(safe-area-inset-right, 0px));--app-radius: 1rem;--bs-body-bg: var(--app-bg);--bs-body-color: var(--app-fg);--bs-primary: var(--app-primary);--bs-primary-rgb: var(--app-primary-rgb);--bs-border-color: var(--app-border);--bs-border-radius: var(--app-radius);--bs-card-bg: var(--app-card);--bs-card-border-color: var(--app-border);--bs-link-color: var(--app-primary);--bs-secondary-rgb: var(--app-secondary-rgb);background-color:var(--app-bg);color:var(--app-fg)}.app-portal *,.app-portal *:before,.app-portal *:after{border-color:var(--app-border)}.app-portal h1,.app-portal h2,.app-portal h3,.app-portal h4,.app-portal h5,.app-portal h6,.app-portal p{margin-top:0;margin-bottom:0}.app-portal :where(h1,h2,h3,h4,h5,h6){font-size:inherit;font-weight:inherit;line-height:inherit}.app-portal .bg-app-bg{background-color:var(--app-bg)}.app-portal .bg-app-card{background-color:var(--app-card)}.app-portal .bg-app-accent{background-color:var(--app-accent)}.app-portal .bg-app-primary{background-color:var(--app-primary)}.app-portal .bg-app-secondary{background-color:var(--app-secondary)}.app-portal .bg-app-muted{background-color:var(--app-muted)}.app-portal .text-app-fg{color:var(--app-fg)}.app-portal .text-app-muted-fg{color:var(--app-muted-fg)}.app-portal .text-app-accent{color:var(--app-accent)}.app-portal .text-app-accent-fg{color:var(--app-accent-fg)}.app-portal .text-app-primary-fg{color:var(--app-primary-fg)}.app-portal .text-app-secondary-fg{color:var(--app-secondary-fg)}.app-portal .text-app-price{color:var(--app-price)}.app-portal .text-app-destructive{color:var(--app-destructive)!important}.app-portal .border-app-border{border-color:var(--app-border)}.app-portal .border-app-primary{border-color:var(--app-primary)}.app-portal .bg-card-90{background:rgba(var(--app-card-rgb),.9)}.app-portal .bg-card-80{background:rgba(var(--app-card-rgb),.8)}.app-portal .bg-accent-10{background:rgba(var(--app-accent-rgb),.1)}.app-portal .bg-accent-15{background:rgba(var(--app-accent-rgb),.15)}.app-portal .bg-accent-20{background:rgba(var(--app-accent-rgb),.2)}.app-portal .bg-primary-10{background:rgba(var(--app-primary-rgb),.1)}.app-portal .bg-primary-15{background:rgba(var(--app-primary-rgb),.15)}.app-portal .bg-primary-20{background:rgba(var(--app-primary-rgb),.2)}.app-portal .bg-secondary-50{background:rgba(var(--app-secondary-rgb),.5)}.app-portal .hover-bg-accent-10:hover{background:rgba(var(--app-accent-rgb),.1)}.app-portal .hover-bg-accent-30:hover{background:rgba(var(--app-accent-rgb),.3)}.app-portal .hover-bg-accent-90:hover{background:rgba(var(--app-accent-rgb),.9)}.app-portal .hover-opacity-80:hover{opacity:.8}.app-portal .backdrop-blur-md{backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.app-portal .backdrop-blur-lg{backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}.app-portal .shadow-sm{box-shadow:0 1px 2px #0000000d}.app-portal .shadow-md{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a}.app-portal .shadow-lg{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a}.app-portal .shadow-card{box-shadow:var(--app-card-shadow)}.app-portal .shadow-card-hover,.app-portal .hover-shadow-card-hover:hover{box-shadow:var(--app-card-hover-shadow)}.app-portal .bg-gradient-join-cta{background:linear-gradient(135deg,rgba(var(--app-accent-rgb),.2) 0%,rgba(var(--app-primary-rgb),.1) 50%,var(--app-secondary) 100%)}.app-portal .bg-accent-10-blur{background:rgba(var(--app-accent-rgb),.1);filter:blur(48px)}.app-portal .bg-accent-20-blur{background:rgba(var(--app-accent-rgb),.2);filter:blur(24px)}.app-portal .bg-primary-10-blur{background:rgba(var(--app-primary-rgb),.1);filter:blur(48px)}.app-portal .bg-primary-20-blur{background:rgba(var(--app-primary-rgb),.2);filter:blur(24px)}.app-portal .bg-gradient-to-t-card-fade{background:linear-gradient(to top,var(--app-card),rgba(var(--app-card-rgb),.3),transparent)}.app-portal .text-2xs{font-size:.625rem;line-height:1rem}.app-portal .text-xs{font-size:.75rem;line-height:1rem}.app-portal .text-sm{font-size:.875rem;line-height:1.25rem}.app-portal .text-base{font-size:1rem;line-height:1.5rem}.app-portal .text-lg{font-size:1.125rem;line-height:1.75rem}.app-portal .text-xl{font-size:1.25rem;line-height:1.75rem}.app-portal .text-2xl{font-size:1.5rem;line-height:2rem}.app-portal .text-3xl{font-size:1.875rem;line-height:2.25rem}.app-portal .text-5xl{font-size:3rem;line-height:1}.app-portal .font-semibold{font-weight:600}.app-portal .font-bold{font-weight:700}.app-portal .font-extrabold{font-weight:800}.app-portal .leading-tight{line-height:1.25}.app-portal .leading-relaxed{line-height:1.625}.app-portal .whitespace-nowrap,.app-portal .text-nowrap{white-space:nowrap}.app-portal .break-words{overflow-wrap:break-word;word-break:break-word}.app-portal .line-clamp-1{display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.app-portal .line-clamp-3{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.app-portal .w-4{width:1rem}.app-portal .w-5{width:1.25rem}.app-portal .w-6{width:1.5rem}.app-portal .w-8{width:2rem}.app-portal .w-10{width:2.5rem}.app-portal .w-12{width:3rem}.app-portal .w-16{width:4rem}.app-portal .w-28{width:7rem}.app-portal .w-40{width:10rem}.app-portal .w-56{width:14rem}.app-portal .w-72{width:18rem}.app-portal .h-4{height:1rem}.app-portal .h-5{height:1.25rem}.app-portal .h-6{height:1.5rem}.app-portal .h-8{height:2rem}.app-portal .h-10{height:2.5rem}.app-portal .h-12{height:3rem}.app-portal .h-16{height:4rem}.app-portal .h-24{height:6rem}.app-portal .h-36{height:9rem}.app-portal .h-40{height:10rem}.app-portal .h-72{height:18rem}.app-portal .h-full{height:100%}.app-portal .w-100{width:100%}.app-portal .h-100{height:100%}.app-portal .max-w-xs{max-width:20rem}.app-portal .max-w-lg{max-width:32rem}.app-portal .max-w-2xl{max-width:42rem}.app-portal .max-w-3xl{max-width:48rem}.app-portal .max-w-4xl{max-width:56rem}.app-portal .max-w-5xl{max-width:64rem}.app-portal .max-w-6xl{max-width:72rem}.app-portal .max-w-7xl{max-width:80rem}.app-portal .app-container{width:100%;margin-left:auto;margin-right:auto}@media(min-width:1536px){.app-portal .app-container{max-width:1600px}}.app-portal .py-8{padding-top:2rem;padding-bottom:2rem}.app-portal .py-20{padding-top:5rem;padding-bottom:5rem}.app-portal .py-24{padding-top:6rem;padding-bottom:6rem}.app-portal .py-28{padding-top:7rem;padding-bottom:7rem}.app-portal .pt-24{padding-top:6rem}.app-portal .pb-12{padding-bottom:3rem}.app-portal .px-4{padding-left:1rem;padding-right:1rem}.app-portal .p-5{padding:1.25rem}.app-portal .p-6{padding:1.5rem}.app-portal .p-8{padding:2rem}.app-portal .px-2-5{padding-left:.625rem;padding-right:.625rem}.app-portal .py-1-5{padding-top:.375rem;padding-bottom:.375rem}.app-portal .mt-1{margin-top:.25rem}.app-portal .mt-2{margin-top:.5rem}.app-portal .mt-4{margin-top:1rem}.app-portal .mt-6{margin-top:1.5rem}.app-portal .mt-8{margin-top:2rem}.app-portal .mt-10{margin-top:2.5rem}.app-portal .mt-16{margin-top:4rem}.app-portal .mb-3{margin-bottom:.75rem}.app-portal .mb-4{margin-bottom:1rem}.app-portal .mb-10{margin-bottom:2.5rem}.app-portal .mb-12{margin-bottom:3rem}.app-portal .pt-8{padding-top:2rem}.app-portal .mb-6{margin-bottom:1.5rem}.app-portal .my-6{margin-top:1.5rem;margin-bottom:1.5rem}.app-portal .gap-1-5{gap:.375rem}.app-portal .gap-3{gap:.75rem}.app-portal .gap-8{gap:2rem}.app-portal .space-y-2>*+*{margin-top:.5rem}.app-portal .space-y-3>*+*{margin-top:.75rem}.app-portal .space-y-4>*+*{margin-top:1rem}.app-portal .space-y-8>*+*{margin-top:2rem}.app-portal .mb-2{margin-bottom:.5rem}.app-portal .mb-8{margin-bottom:2rem}.app-portal .mt-12{margin-top:3rem}.app-portal .pl-6{padding-left:1.5rem}.app-portal .ps-10{padding-left:2.5rem!important}.app-portal .list-disc{list-style-type:disc}.app-portal .w-1-of-3{width:33.3333%}.app-portal .fixed{position:fixed}.app-portal .sticky{position:sticky}.app-portal .relative{position:relative}.app-portal .absolute{position:absolute}.app-portal .inset-0{inset:0}.app-portal .inset-x-0{left:0;right:0}.app-portal .top-0{top:0}.app-portal .bottom-3{bottom:.75rem}.app-portal .left-3{left:.75rem}.app-portal .z-10{z-index:10}.app-portal .z-50{z-index:50}.app-portal .-top-10{top:-2.5rem}.app-portal .-top-20{top:-5rem}.app-portal .-bottom-10{bottom:-2.5rem}.app-portal .-bottom-20{bottom:-5rem}.app-portal .-left-10{left:-2.5rem}.app-portal .-left-20{left:-5rem}.app-portal .-right-10{right:-2.5rem}.app-portal .-right-20{right:-5rem}.app-portal .pt-safe{padding-top:var(--app-safe-area-top)!important}.app-portal .pb-safe{padding-bottom:var(--app-safe-area-bottom)!important}.app-portal .pl-safe{padding-left:var(--app-safe-area-left)!important}.app-portal .pr-safe{padding-right:var(--app-safe-area-right)!important}.app-portal .px-safe{padding-left:var(--app-safe-area-left)!important;padding-right:var(--app-safe-area-right)!important}.app-portal .py-safe{padding-top:var(--app-safe-area-top)!important;padding-bottom:var(--app-safe-area-bottom)!important}.app-portal .mt-safe{margin-top:var(--app-safe-area-top)!important}.app-portal .mb-safe{margin-bottom:var(--app-safe-area-bottom)!important}.app-portal .pt-12-safe{padding-top:calc(3rem + var(--app-content-safe-area-top, 0px))!important}.app-portal .pt-24-safe{padding-top:calc(6rem + var(--app-content-safe-area-top, 0px))!important}.app-portal .scroll-mt-24-safe{scroll-margin-top:calc(6rem + var(--app-content-safe-area-top, 0px))!important}.app-portal .d-grid{display:grid}.app-portal .grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.app-portal .grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.app-portal .flex-shrink-0,.app-portal .shrink-0{flex-shrink:0}.app-portal .flex-1{flex:1 1 0%}.app-portal .cursor-pointer{cursor:pointer}.app-portal .overflow-hidden{overflow:hidden}.app-portal .overflow-x-auto{overflow-x:auto}.app-portal .object-contain{object-fit:contain}.app-portal .object-cover{object-fit:cover}.app-portal .object-top{object-position:top}.app-portal .rounded{border-radius:.25rem!important}.app-portal .rounded-lg{border-radius:.5rem}.app-portal .rounded-xl{border-radius:.75rem}.app-portal .rounded-2xl{border-radius:1rem}.app-portal .rounded-3xl{border-radius:1.5rem}.app-portal .rounded-full{border-radius:9999px}.app-portal .border-0{border:0}.app-portal .border-2{border-width:2px}.app-portal .border-transparent{border-color:transparent}.app-portal .hover-border-accent-30:hover{border-color:rgba(var(--app-accent-rgb),.3)}.app-portal .transition-all{transition:all .15s cubic-bezier(.4,0,.2,1)}.app-portal .transition-colors{transition:color .15s cubic-bezier(.4,0,.2,1),background-color .15s cubic-bezier(.4,0,.2,1),border-color .15s cubic-bezier(.4,0,.2,1)}.app-portal .transition-opacity{transition:opacity .15s cubic-bezier(.4,0,.2,1)}.app-portal .transition-shadow{transition:box-shadow .15s cubic-bezier(.4,0,.2,1)}.app-portal .transition-transform{transition:transform .15s cubic-bezier(.4,0,.2,1)}.app-portal .duration-300{transition-duration:.3s}.app-portal .duration-500{transition-duration:.5s}.app-portal .hover-text-app-price:hover{color:var(--app-price)}.app-portal .hover-scale-101:hover{transform:scale(1.01)}.app-portal .group:hover .group-hover-scale-105{transform:scale(1.05)}.app-portal .hover-shadow-card-hover:hover{box-shadow:var(--app-card-hover-shadow)}.app-portal .bg-transparent{background-color:transparent}.app-portal .min-h-screen{min-height:100vh}@media(min-width:576px){.app-portal .sm-text-3xl{font-size:1.875rem;line-height:2.25rem}.app-portal .sm-text-4xl{font-size:2.25rem;line-height:2.5rem}.app-portal .sm-text-5xl{font-size:3rem;line-height:1}.app-portal .sm-text-6xl{font-size:3.75rem;line-height:1}.app-portal .sm-text-lg{font-size:1.125rem;line-height:1.75rem}.app-portal .sm-text-2xl{font-size:1.5rem;line-height:2rem}.app-portal .sm-px-6{padding-left:1.5rem;padding-right:1.5rem}.app-portal .sm-py-16{padding-top:4rem;padding-bottom:4rem}.app-portal .sm-py-24{padding-top:6rem;padding-bottom:6rem}.app-portal .sm-py-28{padding-top:7rem;padding-bottom:7rem}.app-portal .sm-pt-24{padding-top:6rem}.app-portal .sm-pt-32{padding-top:8rem}.app-portal .sm-pt-24-safe{padding-top:calc(6rem + var(--app-content-safe-area-top, 0px))!important}.app-portal .sm-pt-32-safe{padding-top:calc(8rem + var(--app-content-safe-area-top, 0px))!important}.app-portal .sm-pb-16{padding-bottom:4rem}.app-portal .sm-p-6{padding:1.5rem}.app-portal .sm-p-8{padding:2rem}.app-portal .sm-p-14{padding:3.5rem}.app-portal .sm-mb-4{margin-bottom:1rem}.app-portal .sm-mb-3{margin-bottom:.75rem}.app-portal .sm-p-3{padding:.75rem}.app-portal .sm-mb-6{margin-bottom:1.5rem}.app-portal .sm-mb-8{margin-bottom:2rem}.app-portal .sm-mb-14{margin-bottom:3.5rem}.app-portal .sm-gap-6{gap:1.5rem}.app-portal .sm-gap-8{gap:2rem}.app-portal .sm-w-36{width:9rem}.app-portal .sm-w-44{width:11rem}.app-portal .sm-h-44{height:11rem}.app-portal .sm-h-52{height:13rem}.app-portal .sm-grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.app-portal .sm-grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.app-portal .sm-grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.app-portal .sm-block{display:block!important}.app-portal .sm-inline-flex{display:inline-flex!important}.app-portal .sm-flex{display:flex!important}.app-portal .sm-space-y-4>*+*{margin-top:1rem}.app-portal .sm-space-y-6>*+*{margin-top:1.5rem}}@media(min-width:768px){.app-portal .md-text-6xl{font-size:3.75rem;line-height:1}.app-portal .md-grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.app-portal .md-grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.app-portal .md-grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.app-portal .w-md-auto{width:auto!important}.app-portal .px-md-4{padding-left:1rem!important;padding-right:1rem!important}}@media(min-width:992px){.app-portal .lg-block{display:block!important}.app-portal .lg-flex{display:flex!important}.app-portal .lg-inline-flex{display:inline-flex!important}.app-portal .lg-hidden{display:none!important}.app-portal .lg-pointer-events-none{pointer-events:none}.app-portal .lg-grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.app-portal .lg-grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.app-portal .lg-grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}.app-portal .lg-px-4{padding-left:1rem!important;padding-right:1rem!important}.app-portal .lg-text-sm{font-size:.875rem;line-height:1.25rem}}@media(min-width:1200px){.app-portal .xl-grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}}.app-portal .w-full{width:100%}.app-portal .w-3{width:.75rem}.app-portal .h-3{height:.75rem}.app-portal .gap-1{gap:.25rem}.app-portal .gap-2{gap:.5rem}.app-portal .space-y-6>*+*{margin-top:1.5rem}.app-portal .hover-underline:hover{text-decoration:underline}.app-portal .hover-text-app-fg:hover{color:var(--app-fg)}.app-portal .hover-bg-accent:hover{background-color:var(--app-accent)!important}.app-portal .text-app-primary{color:var(--app-primary)}.app-portal .text-green-600{color:#16a34a}.app-portal .table-fixed{table-layout:fixed}.app-portal .bg-app-muted-half{background-color:rgba(var(--app-muted-rgb),.5)}.app-portal .hover-bg-muted-half:hover{background-color:rgba(var(--app-muted-rgb),.3)}.app-portal .aspect-book-cover{aspect-ratio:1 / 1.38}.app-portal .scrollbar-hide{scrollbar-width:none;-ms-overflow-style:none}.app-portal .scrollbar-hide::-webkit-scrollbar{display:none}.app-portal .min-h-400{min-height:400px}.app-portal .mt-half{margin-top:.125rem}.app-portal .flip-card{perspective:1000px}.app-portal .flip-card-inner{position:relative;width:100%;height:100%;transform-style:preserve-3d;transition:transform .7s}.app-portal .flip-card-inner.rotate-y-180{transform:rotateY(180deg)}@media(min-width:1024px){.app-portal .flip-card:hover .flip-card-inner{transform:rotateY(180deg)}}.app-portal .transform-style-3d{transform-style:preserve-3d}.app-portal .backface-hidden{-webkit-backface-visibility:hidden;backface-visibility:hidden}.app-portal .rotate-y-180{transform:rotateY(180deg)}.app-portal .transition-transform{transition-property:transform}.app-portal .duration-700{transition-duration:.7s}.app-portal .border-accent-30{border-color:rgba(var(--app-accent-rgb),.3)}.app-portal .bg-accent-5{background:rgba(var(--app-accent-rgb),.05)}.app-portal .h-52{height:13rem}.app-portal .bg-gradient-to-t-black{background:linear-gradient(to top,rgba(0,0,0,.7) 0%,transparent 100%)}.app-portal .w-11{width:2.75rem}.app-portal .h-11{height:2.75rem}.app-portal .w-14{width:3.5rem}.app-portal .h-14{height:3.5rem}.app-portal .h-80{height:20rem}.app-portal .whitespace-pre-wrap{white-space:pre-wrap}@media(min-width:576px){.app-portal .sm-h-72{height:18rem}.app-portal .sm-flex-column{flex-direction:column!important}.app-portal .sm-align-items-center{align-items:center!important}.app-portal .sm-text-center{text-align:center!important}}@media(min-width:992px){.app-portal .lg-grid-cols-3{grid-template-columns:repeat(3,1fr)}}.app-portal .w-max{width:max-content!important}.app-portal .hover-text-app-primary:hover{color:var(--app-primary)!important}.app-portal .pt-6{padding-top:1.5rem}.app-portal .pt-12{padding-top:3rem}@media(min-width:576px){.app-portal .sm-text-base{font-size:1rem;line-height:1.5rem}.app-portal .sm-w-10{width:2.5rem}.app-portal .sm-h-10{height:2.5rem}.app-portal .sm-w-6{width:1.5rem}.app-portal .sm-h-6{height:1.5rem}}.app-portal .btn-link-unstyled{background:none;border:none;padding:0;cursor:pointer;font-size:inherit;line-height:inherit}.app-portal .empty-state-icon-circle{width:5rem;height:5rem;border-radius:9999px;background-color:var(--app-muted, hsl(210 40% 96.1%));display:flex;align-items:center;justify-content:center}.app-portal .ring-2-primary-40{box-shadow:0 0 0 2px rgba(var(--app-primary-rgb, 147, 62, 0),.4)}.app-portal .w-24{width:6rem}.app-portal .h-32{height:8rem}.app-portal .w-7{width:1.75rem}.app-portal .h-7{height:1.75rem}.app-portal .w-3-5{width:.875rem}.app-portal .h-3-5{height:.875rem}.app-portal .opacity-60{opacity:.6}.app-portal .gap-4{gap:1rem}.app-portal .gap-x-4{column-gap:1rem}.app-portal .gap-y-1{row-gap:.25rem}.app-portal .mb-1{margin-bottom:.25rem}.app-portal .py-0-5{padding-top:.125rem;padding-bottom:.125rem}.app-portal .py-5{padding-top:1.25rem;padding-bottom:1.25rem}.app-portal .gap-6{gap:1.5rem}.app-portal .py-16{padding-top:4rem;padding-bottom:4rem}.app-portal .py-10{padding-top:2.5rem;padding-bottom:2.5rem}.app-portal .py-12{padding-top:3rem;padding-bottom:3rem}@media(min-width:576px){.app-portal .sm-w-20{width:5rem}.app-portal .sm-h-28{height:7rem}.app-portal .sm-text-left{text-align:left!important}.app-portal .sm-mx-0{margin-left:0!important;margin-right:0!important}.app-portal .sm-truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.app-portal .sm-flex-row{flex-direction:row!important}.app-portal .sm-items-center{align-items:center!important}.app-portal .sm-p-4{padding:1rem!important}.app-portal .sm-space-y-3>*+*{margin-top:.75rem}.app-portal .sm-hidden,.app-portal .d-sm-none{display:none!important}}@media(min-width:992px){.app-portal .lg-justify-end{justify-content:flex-end!important}}.app-portal .bg-pink-500{background-color:#ec4899}.app-portal .bg-red-100-90{background:#fee2e2e6}.app-portal .text-red-600{color:#dc2626}.app-portal .bg-gradient-red-pink{background:linear-gradient(to right,#ef4444,#ec4899)}.app-portal .bg-emerald-500{background-color:#10b981}.app-portal .bg-purple-500{background-color:#8b5cf6}.app-portal .bg-blue-50{background-color:#eff6ff}.app-portal .text-blue-800{color:#1e40af}.app-portal .border-blue-200{border-color:#bfdbfe}.app-portal .text-yellow-400{color:#facc15}.app-portal .text-amber-600{color:#d97706}.app-portal .text-gray-200{color:#e5e7eb}.app-portal .bg-orange-100{background-color:#ffedd5}.app-portal .btn{height:2.5rem;padding:.5rem 1rem;border-radius:calc(var(--app-radius) - 2px);font-size:.875rem;font-weight:600;transition:var(--app-transition-smooth)}.app-portal .btn-primary{--bs-btn-bg: var(--app-primary);--bs-btn-border-color: var(--app-primary);--bs-btn-color: var(--app-primary-fg);--bs-btn-hover-bg: rgba(var(--app-primary-rgb), .9);--bs-btn-hover-border-color: rgba(var(--app-primary-rgb), .9);--bs-btn-hover-color: var(--app-primary-fg);--bs-btn-active-bg: rgba(var(--app-primary-rgb), .85);--bs-btn-active-border-color: rgba(var(--app-primary-rgb), .85);--bs-btn-active-color: var(--app-primary-fg)}.app-portal .btn-sm{height:2.25rem;padding:0 .75rem;font-size:.875rem}.app-portal .btn-lg{padding:.625rem 1.5rem;font-size:1.125rem}.app-portal .btn-accent{background-color:var(--app-accent);color:var(--app-accent-fg);border:none;box-shadow:var(--app-card-shadow)}.app-portal .btn-accent:hover{background:rgba(var(--app-accent-rgb),.9)}.app-portal .btn-accent-outline{background-color:var(--app-card, #ffffff);color:var(--app-fg);border:1px solid var(--app-border)}.app-portal .btn-accent-outline:hover{background-color:var(--app-accent);color:var(--app-accent-fg)}.app-portal .btn-primary-nav{background-color:var(--app-primary);color:var(--app-primary-fg);border:none}.app-portal .btn-primary-nav:hover{background:rgba(var(--app-primary-rgb),.9);color:var(--app-primary-fg)}.app-portal .btn-ghost{background:transparent;border:none;color:var(--app-fg)}.app-portal .btn-ghost:hover{background:rgba(var(--app-accent-rgb),.1);color:var(--app-accent-fg)}.app-portal .btn-outline-secondary{--bs-btn-color: var(--app-fg);--bs-btn-border-color: var(--app-border);--bs-btn-bg: var(--app-bg);--bs-btn-hover-bg: var(--app-accent);--bs-btn-hover-color: var(--app-accent-fg);--bs-btn-hover-border-color: var(--app-accent);--bs-btn-active-bg: var(--app-accent);--bs-btn-active-color: var(--app-accent-fg);--bs-btn-active-border-color: var(--app-accent)}.app-portal .btn-link-reset{background:none;border:none;padding:0;border-radius:0;box-shadow:none;font-weight:inherit}.app-portal .card{background-color:var(--app-card);border:1px solid var(--app-border);border-radius:var(--app-radius);box-shadow:var(--app-card-shadow);transition:transform .2s cubic-bezier(.4,0,.2,1),box-shadow .2s cubic-bezier(.4,0,.2,1)}.app-portal .card.persona-card{border-color:transparent}.app-portal .card-title{font-size:1.125rem;font-weight:600}.app-portal .card:hover{transform:translateY(-4px);box-shadow:var(--app-card-hover-shadow)}.app-portal .dropdown-menu{background-color:var(--app-card);border:1px solid var(--app-border);border-radius:.75rem;box-shadow:var(--app-card-shadow)}.app-portal .error-text{color:var(--app-destructive);font-size:.75rem;display:block;margin-top:.25rem}.app-portal .field-error{border-color:var(--app-destructive)!important}.app-portal .field-error:focus{border-color:var(--app-destructive)!important;box-shadow:0 0 0 .2rem rgba(var(--app-price-rgb),.25)}.app-portal .profile-avatar-placeholder{width:6rem;height:6rem;background:rgba(var(--app-primary-rgb),.1);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.app-portal .profile-avatar-icon{width:3rem;height:3rem}.app-portal .profile-avatar-edit-btn{position:absolute;bottom:-.25rem;right:-.25rem;padding:.375rem;background-color:#ca8a04;color:#fff;border-radius:50%;border:none;box-shadow:0 4px 6px -1px #0000001a;cursor:pointer;transition:background-color .2s;display:flex;align-items:center;justify-content:center}.app-portal .profile-avatar-edit-btn:hover{background-color:#a16207}.app-portal .profile-card>.card-header{background:var(--app-card, #ffffff);border-bottom:none}.app-portal .profile-card:hover{transform:none;box-shadow:var(--app-card-shadow)}.app-portal .profile-settings-btn{background-color:var(--app-bg);color:var(--app-fg);border:1px solid var(--app-input);text-align:start;width:100%}.app-portal .profile-settings-btn:hover{background-color:var(--app-accent);color:var(--app-accent-fg);border-color:var(--app-accent)}.app-portal .profile-delete-link{display:inline-flex;align-items:center;gap:.375rem;font-size:.875rem;color:var(--app-destructive);background:none;border:none;padding:0;cursor:pointer;text-decoration-offset:2px;transition:color .2s}.app-portal .profile-delete-link:hover{color:#ef4444cc;text-decoration:underline}.app-portal .profile-avatar-img{width:100%;height:100%;object-fit:cover;border-radius:50%}.app-portal .profile-image-option-btn{width:56px;height:56px;padding:0;border:2px solid var(--app-border);border-radius:50%;overflow:hidden;cursor:pointer;background:transparent;transition:border-color .2s}.app-portal .profile-image-option-btn:hover{border-color:var(--app-primary)}.app-portal .profile-image-option-btn.selected{border-color:var(--app-accent);box-shadow:0 0 0 2px var(--app-accent)}.app-portal .profile-image-option-thumb{width:100%;height:100%;object-fit:cover;border-radius:50%}.app-portal .profile-field-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);width:.875rem;height:.875rem;pointer-events:none}.app-portal .app-form-select{position:relative}.app-portal .app-form-select__trigger{display:flex;height:2.5rem;width:100%;align-items:center;justify-content:space-between;border-radius:.375rem;border:1px solid var(--app-input);background-color:var(--app-bg);padding:.5rem .75rem;font-size:.875rem;color:var(--app-fg);outline:none;cursor:pointer;transition:border-color .15s,box-shadow .15s}.app-portal .app-form-select__trigger:focus{border-color:var(--app-ring);box-shadow:0 0 0 2px var(--app-ring),0 0 0 4px var(--app-bg)}.app-portal .app-form-select__trigger:disabled{cursor:not-allowed;opacity:.5}.app-portal .app-form-select__trigger.field-error{border-color:var(--app-destructive)}.app-portal .app-form-select__value{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.app-portal .app-form-select__placeholder{color:var(--app-muted-fg)}.app-portal .app-form-select__icon{font-size:.75rem;opacity:.5;flex-shrink:0;margin-left:.5rem}.app-portal .app-form-select__content{border-radius:.375rem;border:1px solid var(--app-border);background-color:var(--app-card);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;animation:appSelectFadeIn .15s ease-out}.app-portal .app-form-select__viewport{padding:.25rem;max-height:24rem;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--app-border) transparent}.app-portal .app-form-select__viewport::-webkit-scrollbar{width:6px}.app-portal .app-form-select__viewport::-webkit-scrollbar-track{background:transparent}.app-portal .app-form-select__viewport::-webkit-scrollbar-thumb{background-color:var(--app-border);border-radius:3px}.app-portal .app-form-select__viewport::-webkit-scrollbar-thumb:hover{background-color:var(--app-muted-fg)}.app-portal .app-form-select__content--dob .app-form-select__viewport{max-height:15rem}.app-portal .app-form-select__item{position:relative;display:flex;width:100%;cursor:default;user-select:none;align-items:center;border-radius:.125rem;padding:.375rem .5rem .375rem 2rem;font-size:.875rem;outline:none;color:var(--app-fg)}.app-portal .app-form-select__item--focused,.app-portal .app-form-select__item:hover{background-color:var(--app-accent);color:var(--app-accent-fg)}.app-portal .app-form-select__item-indicator{position:absolute;left:.5rem;display:flex;width:.875rem;height:.875rem;align-items:center;justify-content:center;font-size:.75rem}@keyframes appSelectFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.app-portal .app-toast-viewport{position:fixed;bottom:0;right:0;z-index:1100;display:flex;flex-direction:column;gap:.5rem;max-width:420px;width:100%;padding:1rem;padding-bottom:calc(1rem + var(--app-safe-area-bottom, 0px));padding-right:calc(1rem + var(--app-safe-area-right, 0px));pointer-events:none}@media(max-width:575.98px){.app-portal .app-toast-viewport{inset:0 0 auto;max-width:100%;padding-top:calc(1rem + var(--app-safe-area-top, 0px));padding-bottom:1rem;padding-right:1rem}}.app-portal .app-toast{position:relative;display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem;padding:1rem 1.25rem;border-radius:var(--app-radius, .75rem);border:1px solid var(--app-border);box-shadow:var(--app-card-shadow);pointer-events:auto;overflow:hidden}.app-portal .app-toast--default{background-color:var(--app-card, #ffffff);color:var(--app-fg);border-color:var(--app-border)}.app-portal .app-toast--destructive{background-color:var(--app-destructive, #ef4444);color:#fff;border-color:var(--app-destructive, #ef4444)}.app-portal .app-toast--success{background-color:var(--app-card, #ffffff);color:var(--app-fg);border-color:var(--app-border)}.app-portal .app-toast-content{flex:1;min-width:0}.app-portal .app-toast-title{font-size:.875rem;font-weight:600;line-height:1.25}.app-portal .app-toast-description{font-size:.875rem;line-height:1.4;opacity:.9;margin-top:.125rem}.app-portal .app-toast-close{position:absolute;top:.5rem;right:.5rem;display:flex;align-items:center;justify-content:center;width:1.25rem;height:1.25rem;border:none;border-radius:50%;background:transparent;cursor:pointer;opacity:0;transition:opacity .2s ease;color:inherit;font-size:.75rem;padding:0}.app-portal .app-toast:hover .app-toast-close{opacity:1}.app-portal .app-toast--destructive .app-toast-close{color:#fff}.app-portal .app-toast--has-icon{padding-left:3.5rem}.app-portal .app-toast-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);width:1.75rem;height:1.75rem;display:flex;align-items:center;justify-content:center}.app-portal .kid-qr-trigger-btn{background:#fff;border:1px solid var(--app-border);border-radius:.375rem;padding:.5rem;cursor:pointer;transition:transform .15s;line-height:1}.app-portal .kid-qr-trigger-btn:hover{transform:scale(1.05)}.app-portal #kidSignInModal .modal-content{background-color:#fff}.app-portal .kid-scan-spinner{width:3rem;height:3rem;border:4px solid var(--app-accent);border-top-color:transparent;border-radius:50%;animation:spin .8s linear infinite}.app-portal .kid-select-btn{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem;border-radius:.5rem;border:1px solid var(--app-border);background:transparent;text-align:left;transition:background .15s,border-color .15s}.app-portal .kid-select-btn:hover{background:rgba(var(--app-accent-rgb),.08);border-color:var(--app-accent)}.app-portal .kid-select-btn--dashed{border-style:dashed}.app-portal .kid-avatar-circle{width:3rem;height:3rem;border-radius:50%;background:#fff;border:2px solid #fde68a;display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0;box-shadow:0 2px 6px #0000001a}.app-portal .kid-done-icon{width:4rem;height:4rem;border-radius:50%;background:#dcfce7;display:flex;align-items:center;justify-content:center}.app-portal .library-sample-banner{border-color:rgba(var(--app-primary-rgb),.2);background:rgba(var(--app-primary-rgb),.05)}.app-portal .library-book-cover-wrap{aspect-ratio:1 / 1.38}.app-portal .library-book-badge{position:absolute;top:.5rem;left:.5rem;background-color:var(--app-primary)!important;color:var(--app-primary-fg);font-size:.75rem;font-weight:600;padding:.25rem .5rem;border-radius:.5rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a}.app-portal .library-series-badge{font-size:.75rem;font-weight:500;color:#2463eb;background:#f0f7ff;border:1px solid hsl(213 94% 87%);padding:.125rem .625rem;border-radius:9999px}.app-portal .library-series-card{background:#eff6ff4d;border:1px solid hsl(213,94%,87%);border-radius:.5rem;box-shadow:0 1px 2px #0000000d}.app-portal .library-series-order-bubble{background:#dbebff;color:#2463eb}.app-portal .library-series-badge-count{background:#dbebff;color:#2463eb;border:1px solid hsl(213 94% 87%)}.app-portal .library-series-read-btn{border:1px solid hsl(213,94%,87%);color:#2463eb;background:transparent;border-radius:.375rem;padding:.25rem .75rem}.app-portal .library-series-read-btn:hover{background:#f0f7ff}.app-portal .ca-book-header{display:flex;align-items:center;gap:.75rem;padding:.75rem}.app-portal .ca-book-thumb{width:3rem;height:4rem;border-radius:.25rem;overflow:hidden;flex-shrink:0}.app-portal .ca-book-info{min-width:0;flex:1}.app-portal .ca-expiry-warning{display:inline-flex;align-items:center;gap:.25rem;padding:0 .375rem;border-radius:.25rem;font-size:.75rem;font-weight:500;background-color:#f9deb8;color:#663919}.app-portal .ca-badge{font-size:.75rem;padding:.125rem .5rem;border-radius:9999px;border:1px solid;font-weight:500}.app-portal .ca-badge--available{color:#16a34a;border-color:#86efac}.app-portal .ca-badge--full{color:var(--app-muted-fg);border-color:var(--app-border);background:var(--app-muted)}.app-portal .ca-batch-tabs{display:flex;gap:.5rem;overflow-x:auto;padding-bottom:.25rem;scrollbar-width:thin}.app-portal .ca-batch-tab{display:flex;flex-direction:column;align-items:flex-start;gap:.125rem;min-width:8rem;flex-shrink:0;padding:.5rem .75rem;border-radius:.5rem;border:1px solid var(--app-border);background:var(--app-bg);cursor:pointer;transition:border-color .15s,background-color .15s}.app-portal .ca-batch-tab:hover{border-color:var(--app-primary)}.app-portal .ca-batch-tab--active{border-color:var(--app-primary);background:var(--app-primary-muted, rgba(var(--app-primary-rgb, 59, 130, 246), .08))}.app-portal .ca-batch-content{display:flex;flex-direction:column;gap:.75rem}.app-portal .ca-member-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem}@media(min-width:576px){.app-portal .ca-member-grid{grid-template-columns:repeat(3,1fr)}}.app-portal .ca-member-btn{display:flex;align-items:center;gap:.5rem;width:100%;border-radius:.5rem;padding:.5rem .625rem;font-size:.875rem;transition:all .15s;border:1px solid var(--app-border);background:var(--app-bg);color:var(--app-fg);cursor:pointer}.app-portal .ca-member-btn:hover:not(:disabled){border-color:rgba(var(--app-primary-rgb),.4)}.app-portal .ca-member-btn--assigned{background:rgba(var(--app-primary-rgb),.1);border-color:rgba(var(--app-primary-rgb),.3)}.app-portal .ca-member-btn--disabled{opacity:.5;cursor:not-allowed}.app-portal .ca-member-avatar{width:2rem;height:2rem;border-radius:9999px;overflow:hidden;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:rgba(var(--app-primary-rgb),.15);color:var(--app-price)}.app-portal .ca-member-name{flex:1;text-align:left;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.app-portal .ca-member-check{width:1.25rem;height:1.25rem;border-radius:9999px;background:var(--app-primary);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--app-primary-fg)}.app-portal .ca-assign-btn{background-color:var(--app-accent);color:var(--app-accent-fg);border:none;font-weight:600}.app-portal .ca-assign-btn:hover{background-color:var(--app-accent-hover, hsl(45, 80%, 48%))}.app-portal .ca-read-prompt-footer{display:flex;flex-direction:row;justify-content:center;gap:.5rem}.app-portal .library-pin-btn-filled{background-color:var(--app-primary);color:var(--app-primary-fg)}.app-portal .library-pin-btn-outline{background-color:var(--app-card);color:var(--app-muted-fg)}.app-portal .library-pin-btn-outline:hover{background-color:var(--app-muted)}.app-portal .library-pin-btn-filled,.app-portal .library-pin-btn-outline{border-radius:9999px;padding:.375rem;line-height:1;border:none}.app-portal .library-series-icon{color:#e1aa05}.app-portal .library-series-card-icon{color:#2463eb}.app-portal .library-series-row{display:grid;grid-template-columns:2.5rem 1fr auto;gap:.75rem;align-items:center;min-height:3.5rem;padding:.5rem;border-radius:.5rem;background:rgba(var(--app-card-rgb),.8)}.app-portal .library-series-thumb{width:2.5rem;height:3.5rem}.app-portal .library-no-cover{background:linear-gradient(to bottom right,var(--app-muted),hsl(210,40%,96%),var(--app-muted));color:var(--app-muted-fg)}.app-portal .library-book-card:hover .group-hover-scale-105{transform:scale(1.05)}.app-portal .continue-reading-container{display:flex;gap:1.5rem;overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:none;-ms-overflow-style:none}.app-portal .continue-reading-container::-webkit-scrollbar{display:none}.app-portal .continue-reading-card{flex-shrink:0;width:16rem;padding:.75rem;scroll-snap-align:start;border-radius:var(--app-radius);border:1px solid var(--app-border);background:var(--app-card);cursor:pointer;transition:all .2s}.app-portal .continue-reading-cover{width:6rem;aspect-ratio:1 / 1.38;flex-shrink:0}.app-portal .continue-reading-read-btn{height:1.75rem;padding-left:1.25rem;padding-right:1.25rem;font-size:.75rem;border-radius:.375rem}.app-portal .library-filter-tabs{display:flex;width:100%;align-items:center;border-radius:9999px;border:1px solid var(--app-border);background:var(--app-card);padding:.125rem;font-size:.75rem;font-weight:500;overflow-x:auto}@media(min-width:576px){.app-portal .library-filter-tabs{width:auto}}.app-portal .library-filter-tab{display:flex;flex:1;align-items:center;justify-content:center;gap:.375rem;padding:.375rem .625rem;border-radius:9999px;white-space:nowrap;transition:background-color .15s,color .15s;font-size:.875rem;color:var(--app-fg);background:transparent;border:none;cursor:pointer}@media(min-width:576px){.app-portal .library-filter-tab{flex:none;padding:.375rem .75rem}}.app-portal .library-filter-tab:hover{color:var(--app-fg)}.app-portal .library-filter-tab--active{background:var(--app-primary);color:var(--app-primary-fg)}.app-portal .library-filter-dot{width:.375rem;height:.375rem;border-radius:9999px;flex-shrink:0}.app-portal .library-filter-dot--green{background-color:#22c55e}.app-portal .library-filter-dot--grey{background-color:var(--app-muted-fg)}.app-portal .library-copy-status-badge{bottom:.5rem;right:.5rem;display:flex;align-items:center;gap:.25rem;padding:.125rem .375rem;border-radius:9999px;font-weight:700;font-size:.75rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a}.app-portal .library-copy-status-badge--available{background-color:#22c55e;color:#fff}.app-portal .library-copy-status-badge--full{background-color:var(--app-muted);color:var(--app-muted-fg)}.app-portal .library-copy-status-dot{width:.375rem;height:.375rem;border-radius:9999px}.app-portal .library-assign-btn{height:1.75rem;gap:.375rem}.app-portal .rental-subtitle{font-size:.875rem;color:var(--app-fg);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%;margin-top:.25rem}.app-portal .rental-token-row{display:flex;align-items:center;justify-content:space-between;padding:.75rem;border-radius:.5rem;border:1px solid var(--app-border);background-color:#f2ecd966}.app-portal .rental-option-row{display:flex;align-items:center;justify-content:space-between;padding:.75rem;border-radius:.5rem;border:1px solid var(--app-border)}.app-portal .rental-qty-btn{display:inline-flex;align-items:center;justify-content:center;width:1.75rem;height:1.75rem;border-radius:50%;border:1px solid var(--app-border);background:var(--app-bg);cursor:pointer;font-size:.75rem;transition:background .15s}.app-portal .rental-qty-btn:hover{background:var(--app-muted)}.app-portal .rental-qty-btn:disabled{opacity:.4;cursor:not-allowed}.app-portal .rental-auto-renewal-toggle:checked{background-color:var(--app-accent);border-color:transparent}.app-portal .rental-insufficient-warning{display:flex;align-items:flex-start;gap:.5rem;padding:.75rem;border-radius:.5rem;border:1px solid #fde047;background-color:#fefce8}.app-portal .rental-insufficient-warning .warning-icon{color:#ca8a04;flex-shrink:0;margin-top:.125rem}.app-portal .rental-insufficient-warning .warning-title{font-weight:600;font-size:.875rem;color:#854d0e}.app-portal .rental-insufficient-warning .warning-detail{font-size:.75rem;margin-top:.25rem;color:#92400e}.app-portal .not-enough-icon-circle{width:3.5rem;height:3.5rem;border-radius:9999px;background-color:#facc15;display:flex;align-items:center;justify-content:center;margin:0 auto .5rem}.app-portal .rental-action-btn{width:100%}@media(min-width:576px){.app-portal .rental-action-btn{width:auto}}.app-portal .rental-info-box{border-radius:.5rem;border:1px solid var(--app-border);background-color:#f2ecd966;padding:.75rem}.app-portal .rental-info-row{display:flex;align-items:center;justify-content:space-between}.app-portal .rental-info-row+.rental-info-row{margin-top:.5rem}.app-portal .rental-token-amount{display:inline-flex;align-items:center;gap:.25rem;font-size:1.125rem;font-weight:700}.app-portal .rental-token-amount.text-red{color:#dc2626}.app-portal .rental-legal-text{font-size:.75rem;line-height:1.625;color:var(--app-muted-fg);white-space:pre-line}.app-portal .rental-legal-text a{color:var(--app-fg);font-weight:500;text-decoration:underline}.app-portal .rental-legal-text a:hover{text-decoration:none}.app-portal .rental-confirm-token-icon{color:#933e00}.app-portal .app-toast-icon .token-coin-toast{color:#ffc34c}.app-portal .app-toast-icon .token-coin-toast text{fill:#933e00}.app-portal .rental-auto-renewal-toggle{width:2.75rem;height:1.5rem;border:2px solid transparent;background-color:#e2e0dc;border-radius:9999px;cursor:pointer}.app-portal .rental-auto-renewal-toggle:focus{outline:none;box-shadow:none;border-color:transparent}.app-portal .markdown-content h1{font-size:1.875rem;font-weight:700;margin-bottom:.5rem}.app-portal .markdown-content h2{font-size:1.25rem;font-weight:600;margin-top:2rem;margin-bottom:.75rem}.app-portal .markdown-content p{color:var(--app-muted-fg);line-height:1.625;margin-bottom:1rem}.app-portal .markdown-content ul{list-style-type:disc;padding-left:1.5rem;color:var(--app-muted-fg)}.app-portal .markdown-content ul li{margin-bottom:.5rem}.app-portal .markdown-content strong{font-weight:700;color:var(--app-fg)}.app-portal .markdown-content h1+p{font-size:.875rem;color:var(--app-muted-fg);margin-bottom:2rem}.app-portal .library-book-card--highlighted{animation:rental-highlight-pulse 1.5s ease-in-out 2;border-radius:.5rem;box-shadow:0 0 0 2px var(--app-accent)}@keyframes rental-highlight-pulse{0%,to{box-shadow:0 0 0 2px var(--app-accent)}50%{box-shadow:0 0 0 4px rgba(var(--app-accent-rgb, 99,102,241),.3)}}.app-portal .tab-pill-container{display:flex;gap:.25rem;padding:.375rem;border-radius:1rem;background-color:var(--app-muted)}.app-portal .tab-pill-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1rem;border-radius:.75rem;font-size:.875rem;font-weight:600;border:none;background:transparent;color:var(--app-muted-fg);cursor:pointer;transition:all .2s;white-space:nowrap}.app-portal .tab-pill-btn:hover{color:var(--app-fg);background:#fff6}.app-portal .tab-pill-btn.active{background-color:var(--app-primary);color:var(--app-primary-fg);box-shadow:0 4px 6px -1px #0000001a}.app-portal .app-dialog-overlay{position:fixed;inset:0;z-index:50;background-color:#000c;animation:fadeIn .15s ease-out}.app-portal .app-dialog-content{position:fixed;left:50%;top:50%;z-index:51;transform:translate(-50%,-50%);width:calc(100% - 2rem);max-width:28rem;border-radius:.5rem;border:1px solid var(--app-border);background-color:var(--app-bg);padding:1.5rem;display:grid;gap:1rem;box-shadow:0 20px 25px -5px #0000001a;animation:zoomIn .15s ease-out;max-height:calc(100vh - 2rem);overflow-y:auto}.app-portal .app-dialog-content.sm-max-w-md{max-width:28rem}.app-portal .app-dialog-content.sm-max-w-lg{max-width:32rem}.app-portal .app-dialog-content.app-dialog-bg-white{background-color:#fff}.app-portal .app-dialog-close{position:absolute;right:1rem;top:1rem;width:1.5rem;height:1.5rem;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--app-muted-fg);opacity:.7;cursor:pointer;border-radius:.25rem;transition:opacity .2s}.app-portal .app-dialog-close:hover{opacity:1;color:var(--app-fg)}.app-portal .app-dialog-header{display:flex;flex-direction:column;gap:.375rem;text-align:center}@media(min-width:640px){.app-portal .app-dialog-header{text-align:left}}.app-portal .member-card{padding:1.25rem;border:1px solid var(--app-border);border-radius:1.5rem;background-color:var(--app-card);box-shadow:0 1px 2px #0000000d;transition:box-shadow .2s}.app-portal .member-card:hover{box-shadow:0 4px 6px -1px #0000001a}@media(min-width:768px){.app-portal .member-card{padding:1.5rem}}.app-portal .member-avatar{position:relative;width:3.5rem;height:3.5rem;flex-shrink:0;border-radius:50%;overflow:visible;background-color:var(--app-muted);display:flex;align-items:center;justify-content:center}.app-portal .member-avatar img{border-radius:50%}.app-portal .member-avatar-edit{position:absolute;bottom:-.25rem;right:-.25rem;padding:.375rem;background-color:#ca8a04;color:#fff;border-radius:50%;border:none;box-shadow:0 4px 6px -1px #0000001a;cursor:pointer;transition:background-color .2s;display:flex;align-items:center;justify-content:center}.app-portal .member-avatar-edit:hover{background-color:#a16207}.app-portal .member-field-icon-box{padding:.5rem;background-color:var(--app-muted);border-radius:.5rem;flex-shrink:0;display:flex;align-items:center;justify-content:center}.app-portal .member-field-label{font-size:.625rem;text-transform:uppercase;letter-spacing:.1em;font-weight:700;color:var(--app-muted-fg);opacity:.7;line-height:1;margin-bottom:.25rem}.app-portal .member-field-value{font-size:.875rem;font-weight:600;color:var(--app-fg)}.app-portal .member-change-pw-link{font-size:.75rem;font-weight:700;color:#ca8a04;text-decoration:none;background:none;border:none;padding:0;cursor:pointer}.app-portal .member-change-pw-link:hover{text-decoration:underline}.app-portal .member-remove-btn{display:flex;align-items:center;gap:.375rem;font-size:.875rem;font-weight:700;color:var(--app-destructive);background:transparent;border:none;padding:.5rem .75rem;border-radius:.75rem;cursor:pointer;transition:background-color .2s}.app-portal .member-remove-btn:hover{background-color:#ef44441a}.app-portal .app-switch{position:relative;width:2.75rem;height:1.5rem;border-radius:9999px;border:none;background-color:var(--app-input);cursor:pointer;transition:background-color .2s}.app-portal .app-switch[aria-checked=true]{background-color:var(--app-primary)}.app-portal .app-switch-thumb{position:absolute;top:.125rem;left:.125rem;width:1.25rem;height:1.25rem;border-radius:50%;background-color:#fff;transition:transform .2s}.app-portal .app-switch[aria-checked=true] .app-switch-thumb{transform:translate(1.25rem)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes zoomIn{0%{opacity:0;transform:translate(-50%,-50%) scale(.95)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.app-portal .exchange-unpublished-card{border-color:rgba(var(--app-destructive-rgb, 239, 68, 68),.3);background-color:rgba(var(--app-destructive-rgb, 239, 68, 68),.05)}.app-portal .exchange-heading{font-family:Nunito,sans-serif;font-size:1.1rem;font-weight:600;color:var(--app-fg)}@media(min-width:576px){.app-portal .exchange-heading{font-size:1.25rem}}.app-portal .exchange-action-btn{display:inline-flex;align-items:center;justify-content:center;background-color:var(--app-primary);color:var(--app-primary-fg, #000);font-weight:700;padding:1.25rem 1.5rem;font-size:1rem;border-radius:9999px;border:none;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;cursor:pointer;transition:var(--app-transition-smooth)}.app-portal .exchange-action-btn:hover{background-color:rgba(var(--app-primary-rgb),.9)}.app-portal .exchange-action-btn:disabled{opacity:.5;cursor:not-allowed}.app-portal .exchange-book-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}@media(min-width:576px){.app-portal .exchange-book-grid{grid-template-columns:repeat(3,1fr)}}@media(min-width:768px){.app-portal .exchange-book-grid{grid-template-columns:repeat(4,1fr)}}@media(min-width:992px){.app-portal .exchange-book-grid{grid-template-columns:repeat(5,1fr)}}.app-portal .exchange-book-btn{text-align:left;border-radius:.5rem;border:1px solid var(--app-border);background:var(--app-card);overflow:hidden;display:flex;flex-direction:column;height:100%;transition:all .3s;cursor:pointer;padding:0}.app-portal .exchange-book-btn:hover{box-shadow:var(--app-card-hover-shadow)}.app-portal .exchange-book-btn--selected{outline:2px solid var(--app-primary);border-color:var(--app-primary)}.app-portal .exchange-check-indicator{position:absolute;top:.5rem;left:.5rem;width:1.75rem;height:1.75rem;border-radius:50%;background:var(--app-primary);color:var(--app-primary-fg, #000);display:flex;align-items:center;justify-content:center;box-shadow:0 1px 3px #0003}.app-portal .exchange-category-badge{position:absolute;top:.5rem;right:.5rem;background:rgba(var(--app-secondary-rgb, 240, 222, 176),.9);backdrop-filter:blur(4px);color:var(--app-secondary-fg);font-size:.75rem;padding:.25rem .5rem;border-radius:9999px;font-weight:500;max-width:calc(100% - 1rem);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.app-portal .group:hover .group-hover-text-primary{color:var(--app-primary)}.app-portal .idle-timeout-clock-circle{display:flex;align-items:center;justify-content:center;width:3rem;height:3rem;border-radius:9999px;background-color:rgba(var(--app-primary-rgb, 234, 179, 8),.1)}@keyframes fade-in-up{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}@keyframes fade-in-up-sm{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes marquee-left{0%{transform:translate(0)}to{transform:translate(-50%)}}@keyframes marquee-right{0%{transform:translate(-50%)}to{transform:translate(0)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.app-portal .animate-fade-in-up{animation:fade-in-up .6s cubic-bezier(.4,0,.2,1) both}.app-portal .animate-fade-in-up-sm{animation:fade-in-up-sm .5s cubic-bezier(.4,0,.2,1) both}.app-portal .animate-fade-in{animation:fade-in .3s ease-out both}.app-portal .animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.app-portal .animate-marquee-left{animation:marquee-left var(--marquee-duration, 35s) linear infinite}.app-portal .animate-marquee-right{animation:marquee-right var(--marquee-duration, 40s) linear infinite}@keyframes app-toast-slide-in-right{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes app-toast-slide-out-right{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(100%)}}@keyframes app-toast-slide-in-top{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}@keyframes app-toast-slide-out-top{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-100%)}}.app-toast-slide-enter-active{animation:app-toast-slide-in-right .3s cubic-bezier(.4,0,.2,1) both}.app-toast-slide-leave-active{animation:app-toast-slide-out-right .3s cubic-bezier(.4,0,.2,1) both}@media(max-width:575.98px){.app-toast-slide-enter-active{animation:app-toast-slide-in-top .3s cubic-bezier(.4,0,.2,1) both}.app-toast-slide-leave-active{animation:app-toast-slide-out-top .3s cubic-bezier(.4,0,.2,1) both}}.app-portal .app-toast--closed{animation:app-toast-slide-out-right .3s cubic-bezier(.4,0,.2,1) both}@media(max-width:575.98px){.app-portal .app-toast--closed{animation:app-toast-slide-out-top .3s cubic-bezier(.4,0,.2,1) both}}.app-portal .hero-badge-icon{width:10px;height:10px;vertical-align:middle;display:inline-block}@media(min-width:576px){.app-portal .hero-badge-icon{width:16px;height:16px}}.app-portal .hero-banner{position:relative;overflow:hidden;height:336px}@media(min-width:576px){.app-portal .hero-banner{height:360px;border-radius:1rem}}@media(min-width:768px){.app-portal .hero-banner{height:420px}}.app-portal .hero-slide-enter-active,.app-portal .hero-slide-leave-active{transition:opacity .4s ease-in-out,transform .4s ease-in-out}.app-portal .hero-slide-enter-from{opacity:0;transform:translate(300px)}.app-portal .hero-slide-leave-to,.app-portal .hero-slide-reverse-enter-from{opacity:0;transform:translate(-300px)}.app-portal .hero-slide-reverse-leave-to{opacity:0;transform:translate(300px)}.app-portal .hero-gradient-mobile{position:absolute;inset:auto 0 0;height:45%;background:linear-gradient(to top,rgba(var(--app-bg-rgb),.9),rgba(var(--app-bg-rgb),.6),transparent)}.app-portal .hero-gradient-desktop{position:absolute;inset:0;background:linear-gradient(to right,rgba(var(--app-bg-rgb),.4),rgba(var(--app-bg-rgb),.2),transparent)}.app-portal .hero-dot{width:.625rem;height:.625rem;border-radius:9999px;border:none;padding:0;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);background:rgba(var(--app-fg-rgb),.3)}.app-portal .hero-dot.active{width:1.5rem;background:var(--app-accent-fg)}.app-portal .hero-nav-btn{position:absolute;top:50%;transform:translateY(-50%);z-index:20;width:2.25rem;height:2.25rem;border-radius:9999px;background:rgba(var(--app-card-rgb),.7);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);border:none;color:var(--app-fg);display:none;align-items:center;justify-content:center;box-shadow:0 4px 6px -1px #0000001a;cursor:pointer;transition:background .2s}.app-portal .hero-nav-btn:hover{background:rgba(var(--app-card-rgb),.9)}@media(min-width:992px){.app-portal .hero-nav-btn{display:flex}}.app-portal .hero-nav-btn.prev{left:.75rem}.app-portal .hero-nav-btn.next{right:.75rem}.app-portal .book-carousel-container{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none}.app-portal .book-carousel-container::-webkit-scrollbar{display:none}.app-portal .series-pill{font-size:.875rem;padding:.25rem .75rem;border-radius:9999px;font-weight:500;border:none;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1)}.app-portal .series-pill.active{background:var(--app-accent);color:var(--app-accent-fg)}.app-portal .series-pill:not(.active){background:var(--app-secondary);color:var(--app-secondary-fg)}.app-portal .series-pill:not(.active):hover{background:rgba(var(--app-secondary-rgb),.8)}.app-portal .holiday-banner{position:relative;overflow:hidden;border-radius:1rem;height:170px}@media(min-width:576px){.app-portal .holiday-banner{height:150px}}@media(min-width:992px){.app-portal .holiday-banner{height:100px}}.app-portal .holiday-banner-overlay{position:absolute;inset:0;background:linear-gradient(to right,#000000b3,#0000004d,#0009)}.app-portal .promo-code-btn{padding:.25rem;border:none;background:transparent;color:#fff;border-radius:.25rem;cursor:pointer;transition:background .2s}.app-portal .promo-code-btn:hover{background:#fff3}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.app-portal .animate-shimmer{animation:shimmer 2s infinite}.app-portal .carousel-card-item{flex:0 0 269px;min-width:0}@media(min-width:576px){.app-portal .carousel-card-item{flex:0 0 336px}}.app-portal .scroll-mt-24{scroll-margin-top:6rem}.app-portal .space-y-1>*+*{margin-top:.25rem}.app-portal .space-y-1-5>*+*{margin-top:.375rem}.app-portal .space-y-5>*+*{margin-top:1.25rem}.app-portal .space-y-12>*+*{margin-top:3rem}.app-portal .-mx-4{margin-left:-1rem;margin-right:-1rem}.app-portal .leading-snug{line-height:1.375}.app-portal .tracking-wide{letter-spacing:.025em}.app-portal .font-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace}.app-portal .font-medium{font-weight:500}.app-portal .w-fit{width:fit-content}.app-portal .line-clamp-2{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.app-portal .text-decoration-none{text-decoration:none}.app-portal .list-unstyled{list-style:none;padding-left:0;margin-bottom:0}.app-portal .border-top{border-top:1px solid var(--app-border)}.app-portal .w-9{width:2.25rem}.app-portal .h-9{height:2.25rem}.app-portal .w-48{width:12rem}.app-portal .h-48{height:12rem}.app-portal .h-64{height:16rem}.app-portal .max-w-md{max-width:28rem}.app-portal .max-w-xl{max-width:36rem}.app-portal .text-4xl{font-size:2.25rem;line-height:2.5rem}@media(min-width:576px){.app-portal .sm-mx-0{margin-left:0;margin-right:0}.app-portal .sm-rounded-2xl{border-radius:1rem}.app-portal .sm-pt-24{padding-top:6rem}.app-portal .sm-block{display:block!important}.app-portal .sm-hidden{display:none!important}.app-portal .sm-text-base{font-size:1rem;line-height:1.5rem}.app-portal .sm-text-2xl{font-size:1.5rem;line-height:2rem}.app-portal .sm-space-y-5>*+*{margin-top:1.25rem}.app-portal .sm-p-6{padding:1.5rem}.app-portal .sm-text-sm{font-size:.875rem;line-height:1.25rem}.app-portal .sm-px-4{padding-left:1rem;padding-right:1rem}.app-portal .sm-py-2{padding-top:.5rem;padding-bottom:.5rem}.app-portal .sm-w-4{width:1rem}.app-portal .sm-h-4{height:1rem}.app-portal .sm-h-64{height:16rem}.app-portal .sm-px-8{padding-left:2rem;padding-right:2rem}.app-portal .sm-text-xl{font-size:1.25rem;line-height:1.75rem}.app-portal .sm-flex{display:flex!important}}@media(min-width:768px){.app-portal .md-p-12{padding:3rem}.app-portal .md-text-4xl{font-size:2.25rem;line-height:2.5rem}.app-portal .md-text-lg{font-size:1.125rem;line-height:1.75rem}}@media(min-width:992px){.app-portal .lg-flex{display:flex!important}.app-portal .lg-hidden{display:none!important}.app-portal .lg-inline-flex{display:inline-flex!important}.app-portal .lg-grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}}.app-portal .promotion-card{height:120px;border-radius:1rem;display:flex;flex-direction:column}.app-portal .promotion-card-overlay{position:absolute;inset:0;background:linear-gradient(to right,rgba(0,0,0,.6),transparent,rgba(0,0,0,.5));pointer-events:none}.app-portal .promotion-tag{background:#fff3;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);color:#fff;font-size:11.5px;font-weight:500;padding:3px .75rem;border-radius:9999px}.app-portal .promotion-discount-badge{font-size:1.5rem;font-weight:800;text-shadow:0 2px 4px rgba(0,0,0,.2);white-space:nowrap}.app-portal .promotion-code-text{max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media(min-width:576px){.app-portal .promotion-card{height:100px}.app-portal .promotion-tag{font-size:.75rem;padding:.25rem .75rem}}.app-portal .app-footer-grid{display:grid;grid-template-columns:1fr;gap:2rem}@media(min-width:768px){.app-portal .app-footer-grid{grid-template-columns:1.5fr 1fr 1.5fr}}.app-portal .app-footer-grid-4col{display:grid;grid-template-columns:1fr;gap:2rem}@media(min-width:768px){.app-portal .app-footer-grid-4col{grid-template-columns:1.5fr 1fr 1fr 1.5fr}}.app-portal .series-pill-count{display:inline-flex;align-items:center;justify-content:center;min-width:1.25rem;height:1.25rem;padding:0 .375rem;border-radius:9999px;font-size:.6875rem;font-weight:700;background:var(--app-bg);color:var(--app-fg);margin-left:.25rem}.app-portal .series-pill-count.active{background:#0003;color:var(--app-accent-fg)}.app-portal .series-tabs-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;margin-left:-1rem;margin-right:-1rem;padding-left:1rem;padding-right:1rem}.app-portal .series-tabs-scroll::-webkit-scrollbar{display:none}.app-portal .series-tabs-inner{display:flex;align-items:center;gap:.5rem;width:max-content;flex-wrap:nowrap}@media(min-width:992px){.app-portal .series-tabs-scroll{overflow:visible;margin-left:0;margin-right:0;padding-left:0;padding-right:0}.app-portal .series-tabs-inner{width:auto;flex-wrap:wrap}}.app-portal .carousel-card-item-flex{flex:0 0 calc(48% - .6rem);min-width:0;display:flex;flex-direction:column}.app-portal .carousel-card-item-flex>*{flex:1;display:flex;flex-direction:column}.app-portal .carousel-card-item-flex>*>*{flex:1;display:flex;flex-direction:column}.app-portal .carousel-card-item-flex>*>*>.preview-book-card-enhanced{flex:1}@media(min-width:576px){.app-portal .carousel-card-item-flex{flex:0 0 calc(28.571% - .714rem)}}@media(min-width:992px){.app-portal .carousel-card-item-flex{flex:0 0 calc(20% - .8rem)}}.app-portal .tag-tabs-dropdown{position:absolute;top:calc(100% + .5rem);left:0;z-index:50;width:16rem;background-color:var(--app-card);border:1px solid var(--app-border);border-radius:.75rem;box-shadow:var(--app-card-shadow);overflow:hidden}.app-portal .tag-tabs-command-input{width:100%;padding:.5rem .75rem .5rem 2rem;border:none;border-bottom:1px solid var(--app-border);background:transparent;font-size:.875rem;color:var(--app-fg);outline:none}.app-portal .tag-tabs-command-input::placeholder{color:var(--app-muted-fg)}.app-portal .tag-tabs-search-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);font-size:.75rem;color:var(--app-muted-fg);pointer-events:none}.app-portal .tag-tabs-command-list{max-height:18rem;overflow-y:auto;padding:.25rem}.app-portal .tag-tabs-command-item{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.5rem .75rem;background:transparent;border:none;border-radius:.375rem;font-size:.875rem;color:var(--app-fg);cursor:pointer;text-align:left}.app-portal .tag-tabs-command-item:hover{background-color:rgba(var(--app-accent-rgb),.08)}.app-portal .tag-tabs-empty{padding:.75rem;font-size:.875rem;color:var(--app-muted-fg);text-align:center}.app-portal .px-1-5{padding-left:.375rem;padding-right:.375rem}.app-portal .child-selector-scroll{display:flex;gap:.75rem;overflow-x:auto;padding-bottom:.5rem;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none}.app-portal .child-selector-scroll::-webkit-scrollbar{display:none}@media(min-width:992px){.app-portal .child-selector-scroll{flex-wrap:wrap;overflow-x:visible;scroll-snap-type:none;padding-bottom:0}}.app-portal .child-selector-btn{display:flex;align-items:center;gap:.75rem;padding:.625rem 1rem;border-radius:.5rem;border:1px solid var(--app-border);background:var(--app-bg);cursor:pointer;white-space:nowrap;flex-shrink:0;scroll-snap-align:start;transition:var(--app-transition-smooth);font-size:.875rem}.app-portal .child-selector-btn:hover{background:rgba(var(--app-primary-rgb),.15);border-color:rgba(var(--app-primary-rgb),.5)}.app-portal .child-selector-btn.active{background:var(--app-primary);border-color:var(--app-primary);color:var(--app-primary-fg)}.app-portal .child-avatar{width:2.5rem;height:2.5rem;border-radius:50%;overflow:hidden;background:#f3f4f6;flex-shrink:0}.app-portal .child-avatar img{width:100%;height:100%;object-fit:cover}.app-portal .reading-history-scroll{display:flex;gap:1.5rem;overflow-x:auto;padding-bottom:.75rem;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none}.app-portal .reading-history-scroll::-webkit-scrollbar{display:none}.app-portal .reading-history-card{flex:0 0 16rem;min-width:0;scroll-snap-align:start;border-radius:.75rem;border:1px solid var(--app-border);background:rgba(var(--app-card-rgb, 255, 255, 255),.8);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);padding:.75rem;display:flex;gap:.75rem;transition:box-shadow .2s,transform .2s}.app-portal .reading-history-card:hover{box-shadow:var(--app-card-hover-shadow, 0 4px 12px rgba(0,0,0,.1));transform:translateY(-2px)}.app-portal .reading-history-cover{width:4rem;flex-shrink:0;border-radius:.5rem;overflow:hidden;aspect-ratio:1 / 1.38}.app-portal .reading-history-cover img{width:100%;height:100%;object-fit:cover}.app-portal .reading-history-info{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:center;gap:.125rem}.app-portal .reading-history-title{font-size:.875rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.app-portal .reading-history-author{font-size:.75rem;color:var(--app-muted-fg)}.app-portal .reading-history-genre{display:inline-block;font-size:10px;background:rgba(var(--app-primary-rgb),.1);color:var(--app-primary);padding:.125rem .5rem;border-radius:9999px;align-self:flex-start}.app-portal .reading-history-last-read{font-size:10px;color:var(--app-muted-fg)}.app-portal .reading-history-nav{display:none;position:absolute;top:50%;transform:translateY(-50%);width:2rem;height:2rem;border-radius:50%;border:1px solid var(--app-border);background:var(--app-card);box-shadow:0 4px 6px -1px #0000001a;align-items:center;justify-content:center;cursor:pointer;z-index:2;color:var(--app-fg);font-size:.75rem}@media(min-width:992px){.app-portal .reading-history-nav{display:flex}}.app-portal .reading-history-nav--prev{left:-.75rem}.app-portal .reading-history-nav--next{right:-.75rem}.app-portal .reading-history-nav:hover{background:rgba(var(--app-primary-rgb),.1)}.app-portal .parents-section-heading{font-size:1.125rem;font-weight:700;display:flex;align-items:center;gap:.5rem}@media(min-width:576px){.app-portal .parents-section-heading{font-size:1.25rem}}.app-portal .ebook-mgmt-row{display:flex;flex-direction:column;gap:.75rem;padding:1rem;border-radius:.5rem;background:var(--app-muted)}.app-portal .ebook-mgmt-cover{width:3rem;height:4rem;border-radius:.25rem;overflow:hidden;flex-shrink:0}.app-portal .ebook-mgmt-cover img{width:100%;height:100%;object-fit:cover}.app-portal .ebook-assign-count{font-size:.75rem;font-weight:500;background:var(--app-secondary);color:var(--app-secondary-fg);padding:.25rem .625rem;border-radius:9999px;white-space:nowrap}.app-portal .ebook-available-count{font-size:.75rem;font-weight:500;color:#16a34a;border:1px solid #86efac;padding:.25rem .625rem;border-radius:9999px;white-space:nowrap}.app-portal .ebook-assign-pill{display:inline-flex;align-items:center;gap:.5rem;padding:.375rem .75rem;border-radius:9999px;font-size:.875rem;font-weight:500;border:1px solid var(--app-border);background:var(--app-bg);color:var(--app-fg);cursor:pointer;transition:all .2s}.app-portal .ebook-assign-pill:hover:not(:disabled){border-color:rgba(var(--app-primary-rgb),.5)}.app-portal .ebook-assign-pill.active{background:var(--app-primary);border-color:var(--app-primary);color:var(--app-primary-fg);box-shadow:0 1px 2px #0000000d}.app-portal .ebook-assign-pill.disabled,.app-portal .ebook-assign-pill:disabled{opacity:.5;cursor:not-allowed}.app-portal .qr-scanner-placeholder{width:12rem;height:12rem;border:2px dashed rgba(var(--app-primary-rgb),.3);border-radius:1rem;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;color:var(--app-muted-fg);margin:0 auto}.app-portal .qr-scanner-placeholder .fa-qrcode{font-size:3rem;color:rgba(var(--app-primary-rgb),.4)}.app-portal #kidQuickLoginModal .modal-body{overflow-y:auto;max-height:70vh}.app-portal .parents-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:3rem 1rem;color:var(--app-muted-fg)}.app-portal .parents-empty-state svg{margin-bottom:.5rem;opacity:.5}.app-portal .bd-top-grid{display:grid;grid-template-columns:auto 1fr;gap:.5rem}@media(min-width:768px){.app-portal .bd-top-grid{grid-template-columns:auto auto 1fr;gap:1rem}}@media(min-width:992px){.app-portal .bd-top-grid{gap:2rem}}.app-portal .bd-back-btn{align-self:start;width:2.25rem;height:2.25rem;padding:0;border:none;background:transparent;border-radius:9999px;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;transition:background-color .15s,color .15s;color:var(--app-fg);cursor:pointer}.app-portal .bd-back-btn:hover{background-color:#ffc61a}@media(min-width:576px){.app-portal .bd-back-btn{width:2.5rem;height:2.5rem}}.app-portal .bd-cover-col{justify-self:start;width:100%;max-width:234px}@media(min-width:576px){.app-portal .bd-cover-col{max-width:20rem}}@media(min-width:768px){.app-portal .bd-cover-col{max-width:280px}}@media(min-width:992px){.app-portal .bd-cover-col{max-width:19.6rem}}.app-portal .bd-cover-card{overflow:hidden;border-radius:var(--app-radius);border:1px solid var(--app-border);box-shadow:0 1px 2px #0000000d;color:var(--app-fg);background-color:var(--app-card);position:relative}.app-portal .bd-wished-banner{position:absolute;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;padding:.35rem .75rem;background:#4e5fe2e6;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);color:#fff;font-weight:700;font-size:.75rem;box-shadow:0 -2px 6px #0000001f}.app-portal .bd-info-col{grid-column:span 2}@media(min-width:768px){.app-portal .bd-info-col{grid-column:span 1}}.app-portal .bd-below-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}@media(min-width:992px){.app-portal .bd-below-grid{grid-template-columns:1fr 1fr;gap:2rem}}.app-portal .bd-title{font-size:1.25rem;line-height:1.3}@media(min-width:576px){.app-portal .bd-title{font-size:1.125rem}}@media(min-width:768px){.app-portal .bd-title{font-size:1.125rem}}@media(min-width:992px){.app-portal .bd-title{font-size:1.25rem}}@media(min-width:1200px){.app-portal .bd-title{font-size:1.5rem}}.app-portal .bd-section-title{font-size:1.125rem;font-weight:600;color:var(--app-fg);margin-top:0;line-height:1.4}@media(min-width:576px){.app-portal .bd-section-title{font-size:1.25rem}}.app-portal .bd-description{line-height:1.625}.app-portal .bd-meta-badge{display:inline-flex;align-items:center;border-radius:9999px;border:1px solid transparent;font-weight:600;transition:background-color .15s,color .15s;font-size:.875rem;padding:.25rem .75rem;background-color:var(--app-secondary);color:var(--app-secondary-fg)}.app-portal .bd-meta-badge:hover{background-color:rgba(var(--app-secondary-rgb),.8)}.app-portal .bd-meta-icon{width:.75rem;height:.75rem}.app-portal .bd-award-badge{display:inline-flex;align-items:center;gap:.5rem;background:linear-gradient(to right,#ef4444,#db2777);color:#fff;padding:.5rem 1rem;border-radius:9999px;font-weight:700;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;border:2px solid white}.app-portal .bd-features-grid{display:grid;grid-template-columns:1fr;gap:.5rem}@media(min-width:576px){.app-portal .bd-features-grid{grid-template-columns:1fr 1fr}}.app-portal .bd-feature-icon{width:1rem;height:1rem;flex-shrink:0}.app-portal .bd-price-card{background:rgba(var(--app-accent-rgb),.05);border:1px solid var(--app-border);border-radius:var(--app-radius);color:var(--app-fg);box-shadow:0 1px 2px #0000000d;padding:1rem}@media(min-width:576px){.app-portal .bd-price-card{padding:1.5rem}}.app-portal .bd-price{font-size:1.5rem;font-weight:700;color:var(--app-price);line-height:1.25}.app-portal .bd-original-price{font-size:1.25rem;text-decoration:line-through;color:var(--app-muted-fg)}.app-portal .bd-fav-btn{padding:.5rem;border-radius:50%}.app-portal .bd-fav-active{background-color:#fef2f2;color:#dc2626}.app-portal .bd-fav-active:hover{background-color:#fee2e2}.app-portal .bd-rent-btn{font-size:1rem;height:2.75rem;padding-top:1.5rem;padding-bottom:1.5rem;background-color:var(--app-accent);color:var(--app-accent-fg, #000);border:none;margin-left:auto;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;border-radius:var(--app-radius, .5rem);cursor:pointer}.app-portal .bd-rent-btn:hover{background-color:rgba(var(--app-accent-rgb),.9)}@media(max-width:575.98px){.app-portal .bd-rent-btn{width:100%;margin-left:0}}.app-portal .bd-wish-btn{font-size:1rem;height:2.75rem;padding-top:1.5rem;padding-bottom:1.5rem;background-color:var(--app-accent);color:var(--app-accent-fg, #000);border:none;margin-left:auto;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;border-radius:var(--app-radius, .5rem);cursor:pointer}.app-portal .bd-wish-btn:hover{background-color:rgba(var(--app-accent-rgb),.9)}@media(max-width:575.98px){.app-portal .bd-wish-btn{width:100%;margin-left:0}}.app-portal .bd-remove-wish-btn{width:100%;font-size:1rem;height:2.75rem;padding:0 1rem;background:#fff;color:#4e5fe2;border:1px solid #a0abf2;margin-left:0;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;border-radius:9999px;cursor:pointer}.app-portal .bd-remove-wish-btn:hover{background:#e8ebfd;color:#4e5fe2}@media(max-width:575.98px){.app-portal .bd-remove-wish-btn{width:100%;margin-left:0}}.app-portal .bd-manage-btn{width:100%;height:2.25rem;background:var(--app-accent);color:var(--app-accent-fg);font-size:.75rem;padding:.5rem 1rem;border:none;border-radius:.375rem;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;font-weight:500;transition:background .2s}.app-portal .bd-manage-btn:hover{background:rgba(var(--app-accent-rgb),.9)}.app-portal .bd-price-inner{display:flex;align-items:center;justify-content:space-between;gap:.75rem;flex-wrap:wrap}.app-portal .bd-price-inner-mobile{display:flex;flex-direction:column;gap:.75rem;flex-wrap:wrap}@media(min-width:576px){.app-portal .bd-price-inner-mobile{flex-direction:row;align-items:center;justify-content:space-between}}.app-portal .bd-author-dl{margin:0}.app-portal .bd-author-dt{font-weight:600;color:var(--app-fg);min-width:6.5rem;margin:0}.app-portal .bd-author-dd{margin:0}.app-portal .bd-fav-outline-btn{height:3rem;width:3.5rem;border:2px solid var(--app-border);flex-shrink:0;transition:background-color .15s,color .15s,border-color .15s;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--app-radius, .5rem);background:transparent;color:var(--app-muted-fg);cursor:pointer;padding:0}.app-portal .bd-fav-outline-btn:hover{color:#ef4444;background-color:var(--app-muted)}.app-portal .bd-fav-outline-btn.bd-fav-active{background-color:#fef2f2;border-color:#fecaca;color:#dc2626}.app-portal .bd-fav-outline-btn.bd-fav-active:hover{background-color:#fee2e2}.app-portal .bd-sample-btn{flex:1;height:3rem;font-size:1rem;border:2px solid var(--app-accent);color:var(--app-accent-fg, #000);background:transparent;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;border-radius:var(--app-radius, .5rem);transition:background-color .15s;cursor:pointer;padding:0 1rem}.app-portal .bd-sample-btn:hover{background-color:rgba(var(--app-accent-rgb),.1)}.app-portal .bd-series-tabs{display:flex;flex-wrap:wrap;gap:.25rem;padding:.25rem;background:var(--app-muted);border-radius:.5rem}.app-portal .bd-series-tab-btn{font-size:.75rem;padding:.375rem .75rem;border-radius:.375rem;border:none;background:transparent;color:var(--app-muted-fg);cursor:pointer;transition:var(--app-transition-smooth)}@media(min-width:576px){.app-portal .bd-series-tab-btn{font-size:.875rem}}.app-portal .bd-series-tab-btn.active{background:var(--app-card);color:var(--app-fg);box-shadow:0 1px 3px #0000001a}.app-portal .bd-series-content{padding:1.25rem;background:#f4f7fa;border:1px solid hsl(210,30%,90%);border-radius:.75rem}.app-portal .bd-series-title{font-size:.875rem;font-weight:600;color:var(--app-fg);margin-bottom:.75rem}.app-portal .bd-series-item{display:flex;align-items:center;gap:.5rem;font-size:.875rem;padding:.5rem 1rem;border-radius:.5rem;border:1px solid var(--app-border);text-decoration:none;color:var(--app-fg);transition:var(--app-transition-smooth)}.app-portal .bd-series-item.active{background:#ddecfd;color:#084691;border-color:#6eacf7}.app-portal .bd-series-item:hover:not(.active){border-color:#6eacf7;box-shadow:0 1px 2px #0000000d}.app-portal .bd-series-order{width:1.25rem;height:1.25rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;flex-shrink:0;background:#ddecfd;color:#0b5dc1}.app-portal .bd-series-item.active .bd-series-order{background:#2682f2;color:#fff}.app-portal .bd-series-thumb{width:2rem;height:2.5rem;border-radius:.25rem;object-fit:cover;box-shadow:0 1px 2px #0000000d;flex-shrink:0}@media(min-width:576px){.app-portal .bd-series-thumb{width:2.5rem;height:3rem}}.app-portal .bd-series-book-title{font-size:1rem;line-height:1.25;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}@media(min-width:576px){.app-portal .bd-series-book-title{display:block;white-space:nowrap;text-overflow:ellipsis;overflow:hidden}}.app-portal .bd-discount-badge{background-color:#dcfce7;color:#166534;border:1px solid #bbf7d0;font-size:.75rem;font-weight:700}.app-portal .bd-buy-series-btn{background-color:#3b82f6;color:#fff;border-color:#3b82f6;border-radius:.375rem}.app-portal .bd-buy-series-btn:hover{background-color:#2563eb;border-color:#2563eb;color:#fff}.app-portal .bd-package-item{padding:.75rem 1rem;border:1px solid var(--app-border);border-radius:.5rem}.app-portal .preview-book-card-link{display:block;text-decoration:none;color:inherit}.app-portal .preview-book-card-link:hover{text-decoration:none}.app-portal .auth-legal-footer{padding-top:1rem}.app-portal .auth-legal-footer a{font-size:.75rem;text-underline-offset:2px}.modal-backdrop{z-index:1040;opacity:.8!important}.app-portal .modal{z-index:9999}.app-portal .modal-content{background-color:#fff}.app-portal .modal-title{font-size:1rem}@media(min-width:576px){.app-portal .modal-title{font-size:1.125rem}}.app-portal .modal-body .btn-link-reset{text-decoration:none!important}.app-portal .modal-body .btn-link-reset:hover{text-decoration:underline!important}.app-portal .two-fa-countdown--urgent{color:var(--app-destructive)}.app-portal .otp-group{display:flex;align-items:center}.app-portal .otp-slot{position:relative;display:flex;align-items:center;justify-content:center;width:2.25rem;height:2.5rem;text-align:center;font-size:1rem;font-weight:600;border-top:1px solid var(--app-input, hsl(45, 30%, 90%));border-bottom:1px solid var(--app-input, hsl(45, 30%, 90%));border-right:1px solid var(--app-input, hsl(45, 30%, 90%));border-left:none;border-radius:0;outline:none;transition:all .15s ease;background:transparent;color:var(--app-fg, hsl(25, 15%, 15%))}.app-portal .otp-slot:first-child{border-left:1px solid var(--app-input, hsl(45, 30%, 90%));border-top-left-radius:.375rem;border-bottom-left-radius:.375rem}.app-portal .otp-slot:last-child{border-top-right-radius:.375rem;border-bottom-right-radius:.375rem}.app-portal .otp-slot:focus{z-index:10;box-shadow:0 0 0 2px var(--app-ring, hsl(45, 96%, 55%));border-color:var(--app-ring, hsl(45, 96%, 55%))}@media(min-width:576px){.app-portal .otp-slot{width:2.5rem;height:3rem;font-size:1.125rem}}.app-portal.kid-signin-webview{min-height:100vh;background-color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1.5rem 1rem;padding-top:calc(1.5rem + var(--app-safe-area-top, env(safe-area-inset-top, 0px)));padding-bottom:calc(1.5rem + var(--app-safe-area-bottom, env(safe-area-inset-bottom, 0px)))}.app-portal .kid-signin-qr-content{display:flex;flex-direction:column;align-items:center;gap:1rem;width:100%;max-width:20rem;text-align:center}.app-portal .token-balance-card{background:linear-gradient(135deg,rgba(var(--app-primary-rgb),.1),rgba(var(--app-accent-rgb),.1));border:1px solid rgba(var(--app-primary-rgb),.3);border-radius:var(--app-radius);padding:1.5rem;box-shadow:0 1px 2px #0000000d}.app-portal .token-usage-card{background-color:var(--app-card);border:1px solid var(--app-border);border-radius:var(--app-radius);padding:1.5rem;box-shadow:0 1px 2px #0000000d}.app-portal .token-packs-grid-hk{display:none}@media(min-width:992px){.app-portal .token-packs-grid-hk{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}}.app-portal .token-pack-card{background-color:var(--app-card);border:1px solid var(--app-border);border-radius:var(--app-radius);box-shadow:0 1px 2px #0000000d;transition:all .3s cubic-bezier(.4,0,.2,1)}.app-portal .token-pack-card:hover{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a}.app-portal .token-pack-card--popular{box-shadow:0 0 0 2px var(--app-primary),0 1px 2px #0000000d}.app-portal .token-pack-card--popular:hover{box-shadow:0 0 0 2px var(--app-primary),0 10px 15px -3px #0000001a}.app-portal .token-pack-card--bestvalue{box-shadow:0 0 0 2px var(--app-accent),0 1px 2px #0000000d}.app-portal .token-pack-card--bestvalue:hover{box-shadow:0 0 0 2px var(--app-accent),0 10px 15px -3px #0000001a}.app-portal .token-pack-icon-wrap{width:3rem;height:3rem;background:rgba(var(--app-primary-rgb),.1);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto .5rem}.app-portal .token-legal-bar{background:#fff9e0;border-radius:.5rem;padding:.75rem 1rem;font-size:.875rem;line-height:1.6}.app-portal .token-warning-icon-wrap{width:3rem;height:3rem;background:#fff5cc;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto .5rem;color:#c90}.app-portal .token-smartphone-icon-wrap{width:3.5rem;height:3.5rem;background:rgba(var(--app-primary-rgb),.1);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto .5rem}.app-portal .token-checkout-container{border-radius:var(--app-radius);overflow:hidden}
