@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/2c55a0e60120577a-s.2a48534a.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/9c72aa0f40e4eef8-s.18a48cbc.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/ad66f9afd8947f86-s.7a40eb73.woff2)format("woff2");unicode-range:U+1F??}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/5476f68d60460930-s.c995e352.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/2bbe8d2671613f1f-s.76dcb0b2.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/1bffadaabf893a1e-s.7cd81963.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/83afe278b6a6bb3c-s.p.3a6ba036.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter Fallback;src:local(Arial);ascent-override:90.44%;descent-override:22.52%;line-gap-override:0.0%;size-adjust:107.12%}.inter_5901b7c6-module__ec5Qua__className{font-family:Inter,Inter Fallback;font-style:normal}.inter_5901b7c6-module__ec5Qua__variable{--font-inter:"Inter","Inter Fallback"}
@font-face{font-family:Playfair Display;font-style:italic;font-weight:400 900;font-display:swap;src:url(../media/35161b7740c25d33-s.c0314740.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Playfair Display;font-style:italic;font-weight:400 900;font-display:swap;src:url(../media/391e53907fa6d8ec-s.1942ea8f.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Playfair Display;font-style:italic;font-weight:400 900;font-display:swap;src:url(../media/ae8872c8a32e309c-s.bd3beac6.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Playfair Display;font-style:italic;font-weight:400 900;font-display:swap;src:url(../media/70e3db2de7f94926-s.p.347f98aa.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Playfair Display;font-style:normal;font-weight:400 900;font-display:swap;src:url(../media/65c558afe41e89d6-s.e2c8389a.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Playfair Display;font-style:normal;font-weight:400 900;font-display:swap;src:url(../media/14e23f9b59180572-s.9c448f3c.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Playfair Display;font-style:normal;font-weight:400 900;font-display:swap;src:url(../media/b49b0d9b851e4899-s.4f3fa681.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Playfair Display;font-style:normal;font-weight:400 900;font-display:swap;src:url(../media/2a65768255d6b625-s.p.d19752fb.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Playfair Display Fallback;src:local(Times New Roman);ascent-override:97.25%;descent-override:22.56%;line-gap-override:0.0%;size-adjust:111.26%}.playfair_display_4d205e00-module__6l-nFW__className{font-family:Playfair Display,Playfair Display Fallback}.playfair_display_4d205e00-module__6l-nFW__variable{--font-playfair:"Playfair Display","Playfair Display Fallback"}
@font-face{font-family:Crimson Pro;font-style:italic;font-weight:200 900;font-display:swap;src:url(../media/d4cfff78d70c32f1-s.f5b8b66b.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Crimson Pro;font-style:italic;font-weight:200 900;font-display:swap;src:url(../media/edd49e6a728081e1-s.7e5a275e.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Crimson Pro;font-style:italic;font-weight:200 900;font-display:swap;src:url(../media/a41eab1df8ed80c4-s.p.c12a81de.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Crimson Pro;font-style:normal;font-weight:200 900;font-display:swap;src:url(../media/bbe2082c2ebf69de-s.dd28a007.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Crimson Pro;font-style:normal;font-weight:200 900;font-display:swap;src:url(../media/9ae69ccf0a67f3e4-s.e0d1d72d.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Crimson Pro;font-style:normal;font-weight:200 900;font-display:swap;src:url(../media/115e7a2565b70400-s.p.e440a306.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Crimson Pro Fallback;src:local(Times New Roman);ascent-override:90.96%;descent-override:21.8%;line-gap-override:0.0%;size-adjust:98.56%}.crimson_pro_6b50e16c-module__XO2Q-G__className{font-family:Crimson Pro,Crimson Pro Fallback}.crimson_pro_6b50e16c-module__XO2Q-G__variable{--font-crimson:"Crimson Pro","Crimson Pro Fallback"}
@font-face{font-family:DM Sans;font-style:normal;font-weight:300;font-display:swap;src:url(../media/c3cb240f9c892514-s.d8e4bce2.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:DM Sans;font-style:normal;font-weight:300;font-display:swap;src:url(../media/5c285b27cdda1fe8-s.p.a62025f2.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:DM Sans;font-style:normal;font-weight:400;font-display:swap;src:url(../media/c3cb240f9c892514-s.d8e4bce2.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:DM Sans;font-style:normal;font-weight:400;font-display:swap;src:url(../media/5c285b27cdda1fe8-s.p.a62025f2.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:DM Sans;font-style:normal;font-weight:500;font-display:swap;src:url(../media/c3cb240f9c892514-s.d8e4bce2.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:DM Sans;font-style:normal;font-weight:500;font-display:swap;src:url(../media/5c285b27cdda1fe8-s.p.a62025f2.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:DM Sans Fallback;src:local(Arial);ascent-override:94.9%;descent-override:29.66%;line-gap-override:0.0%;size-adjust:104.53%}.dm_sans_c3b86bd5-module__TLKi-q__className{font-family:DM Sans,DM Sans Fallback;font-style:normal}.dm_sans_c3b86bd5-module__TLKi-q__variable{--font-dm-sans:"DM Sans","DM Sans Fallback"}
@layer theme{:root,:host{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--spacing:.25rem;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.visible{visibility:visible}.absolute{position:absolute}.start{inset-inline-start:var(--spacing)}.block{display:block}.flex{display:flex}.hidden{display:none}.min-h-screen{min-height:100vh}.items-center{align-items:center}.justify-center{justify-content:center}.bg-\[\#FAF7F2\]{background-color:#faf7f2}.font-sans{font-family:var(--font-sans)}.italic{font-style:italic}}:root{--ink:#2c1810;--ink-soft:#6b4c3b;--parchment:#faf5ee;--cream:#f5edd8;--gold:#c9973a;--gold-lt:#e8c97a;--rose:#c4736a;--sage:#7a9e7e;--line:#2c18101f}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{background:var(--parchment);color:var(--ink);font-family:var(--font-crimson),Georgia,serif;min-height:100vh;overflow-x:hidden}body:before{content:"";pointer-events:none;z-index:1000;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E");position:fixed;inset:0}#connect-screen{background:var(--parchment);z-index:100;text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:28px;padding:40px;display:flex;position:fixed;inset:0}.connect-ornament{font-size:3rem;animation:3s ease-in-out infinite float}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.connect-title{font-family:var(--font-playfair),serif;color:var(--ink);font-size:2.5rem;font-weight:400}.connect-sub{color:var(--ink-soft);max-width:420px;font-size:1.05rem;font-style:italic;line-height:1.7}.connect-fields{flex-direction:column;gap:12px;width:100%;max-width:340px;display:flex}.connect-fields input{border:1px solid var(--line);width:100%;font-family:var(--font-crimson),serif;color:var(--ink);background:#fff;border-radius:2px;outline:none;padding:14px 18px;font-size:1rem;transition:border-color .2s}.connect-fields input:focus{border-color:var(--gold)}.connect-fields input::placeholder{color:var(--ink-soft);opacity:.4}#start-btn{background:var(--ink);color:var(--parchment);font-family:var(--font-playfair),serif;cursor:pointer;letter-spacing:.04em;border:none;border-radius:2px;padding:16px 48px;font-size:1.05rem;transition:all .2s}#start-btn:hover{background:var(--ink-soft);transform:translateY(-1px)}.connect-note{color:var(--ink-soft);opacity:.4;font-size:.75rem}#app{grid-template-rows:auto 1fr;grid-template-columns:340px 1fr;min-height:100vh;display:none}#dashboard-screen{background:var(--parchment);flex-direction:column;grid-area:1/1/-1/-1;justify-content:flex-start;align-items:center;width:100%;min-height:100vh;padding:80px 40px;display:flex;position:relative;overflow-y:auto}#dashboard-screen:before{content:"";pointer-events:none;z-index:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E");position:absolute;inset:0}.dashboard-header{z-index:10;border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;width:100%;max-width:1000px;margin-bottom:60px;padding-bottom:24px;display:flex;position:relative}.dashboard-header h1{font-family:var(--font-playfair),serif;color:var(--ink);letter-spacing:-.02em;font-size:3rem;font-weight:500}.btn-signout{color:var(--ink-soft);border:1px solid var(--line);font-family:var(--font-inter),sans-serif;cursor:pointer;white-space:nowrap;background:0 0;border-radius:100px;padding:10px 24px;font-size:.95rem;transition:all .3s;display:inline-block}.btn-signout:hover{color:var(--ink);background:#2c18100d;border-color:#2c181033}.btn-books{color:var(--ink-soft);border:1px solid var(--line);font-family:var(--font-inter),sans-serif;cursor:pointer;white-space:nowrap;background:0 0;border-radius:100px;align-items:center;gap:8px;padding:8px 18px;font-size:.9rem;transition:all .3s;display:inline-flex}.btn-books:hover{color:var(--ink);background:#2c18100d;border-color:#2c181033}.books-grid{z-index:10;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:32px;width:100%;max-width:1000px;display:grid;position:relative}.book-card{-webkit-backdrop-filter:blur(10px);cursor:pointer;background:#fff9;border:1px solid #fff6;border-radius:16px;flex-direction:column;justify-content:space-between;min-height:220px;padding:32px 28px;transition:all .4s cubic-bezier(.16,1,.3,1);display:flex;position:relative;overflow:hidden;box-shadow:0 4px 20px #2c181008,inset 0 0 0 1px #fff9}.book-card:before{content:"";opacity:0;background:linear-gradient(135deg,#c9973a00 0%,#c9973a0d 100%);transition:opacity .4s;position:absolute;inset:0}.book-card:hover{border-color:#c9973a4d;transform:translateY(-4px);box-shadow:0 12px 32px #2c181014,0 4px 12px #c9973a0d,inset 0 0 0 1px #fffc}.book-card:hover:before{opacity:1}.book-card-title{font-family:var(--font-playfair),serif;color:var(--ink);z-index:2;margin-bottom:6px;font-size:1.5rem;font-weight:600;position:relative}.book-card-date{color:var(--ink-soft);font-size:.85rem;font-family:var(--font-inter),sans-serif;opacity:.7;z-index:2;text-transform:uppercase;letter-spacing:.05em;margin-bottom:20px;position:relative}.book-card-summary{color:var(--ink);opacity:.8;-webkit-line-clamp:3;line-clamp:3;font-size:.95rem;font-style:italic;font-family:var(--font-crimson),serif;z-index:2;-webkit-box-orient:vertical;line-height:1.6;display:-webkit-box;position:relative;overflow:hidden}.book-card-action{color:var(--gold);font-size:.9rem;font-weight:500;font-family:var(--font-inter),sans-serif;z-index:2;align-items:center;gap:6px;margin-top:24px;transition:gap .3s;display:flex;position:relative}.book-card:hover .book-card-action{gap:12px}.new-book-card{text-align:center;color:var(--ink-soft);box-shadow:none;background:0 0;border:2px dashed #2c181026;justify-content:center;align-items:center}.new-book-card:hover{color:var(--gold);background:#c9973a08;border-style:solid;border-color:#c9973a66;transform:translateY(-4px);box-shadow:0 12px 32px #2c18100d}.new-book-card .plus-icon{margin-bottom:16px;font-size:2.5rem;font-weight:300;line-height:1;transition:transform .4s cubic-bezier(.34,1.56,.64,1)}.new-book-card:hover .plus-icon{transform:scale(1.2)rotate(90deg)}.new-book-card h3{font-family:var(--font-inter),sans-serif;letter-spacing:.02em;font-size:1.1rem;font-weight:500}.modal-overlay{-webkit-backdrop-filter:blur(8px);z-index:2000;opacity:0;pointer-events:none;background:#2c181066;justify-content:center;align-items:center;transition:opacity .4s;display:flex;position:fixed;inset:0}.modal-overlay.active{opacity:1;pointer-events:all}.modal-box{-webkit-backdrop-filter:blur(20px);text-align:center;background:#ffffffe6;border-radius:24px;width:90%;max-width:440px;padding:48px;transition:all .4s cubic-bezier(.16,1,.3,1);transform:translateY(20px)scale(.95);box-shadow:0 24px 80px #2c18101f,inset 0 0 0 1px #fffc}.modal-overlay.active .modal-box{transform:translateY(0)scale(1)}.modal-box h2{font-family:var(--font-playfair),serif;color:var(--ink);margin-bottom:12px;font-size:2rem}.modal-box p{color:var(--ink-soft);font-style:italic;font-family:var(--font-crimson),serif;margin-bottom:32px;font-size:1.1rem}.modal-input{border:1px solid var(--line);text-align:center;width:100%;font-size:1.05rem;font-family:var(--font-inter),sans-serif;color:var(--ink);background:#fff;border-radius:12px;outline:none;margin-bottom:32px;padding:16px 20px;transition:all .3s}.modal-input:focus{border-color:var(--gold);box-shadow:0 0 0 4px #c9973a1a}.modal-actions{gap:16px;display:flex}.btn-cancel{color:var(--ink-soft);font-family:var(--font-inter),sans-serif;cursor:pointer;background:0 0;border:1px solid #2c181026;border-radius:100px;flex:1;padding:14px;font-weight:500;transition:all .3s}.btn-cancel:hover{color:var(--ink);background:#2c18100d}.btn-primary{background:var(--ink);color:var(--parchment);font-family:var(--font-inter),sans-serif;cursor:pointer;border:none;border-radius:100px;flex:1.5;padding:14px;font-weight:500;transition:all .3s;box-shadow:0 4px 12px #2c181026}.btn-primary:hover{background:var(--ink-soft);transform:translateY(-2px);box-shadow:0 8px 16px #2c181033}header{border-bottom:1px solid var(--line);background:var(--cream);grid-column:1/-1;justify-content:space-between;align-items:center;padding:18px 40px;display:flex}.logo-title{font-family:var(--font-playfair),serif;letter-spacing:.02em;font-size:1.75rem;font-weight:400}.logo-sub{font-family:var(--font-crimson),serif;color:var(--ink-soft);margin-left:10px;font-size:.95rem;font-style:italic}.header-status{color:var(--ink-soft);align-items:center;gap:8px;font-size:.85rem;display:flex}.status-dot{background:#ccc;border-radius:50%;width:8px;height:8px;transition:background .4s}.status-dot.connected{background:var(--sage);box-shadow:0 0 6px var(--sage);animation:2s infinite pdot}.status-dot.listening{background:var(--rose);box-shadow:0 0 8px var(--rose);animation:1s infinite pdot}@keyframes pdot{0%,to{opacity:1}50%{opacity:.4}}#sidebar{background:var(--cream);border-right:1px solid var(--line);flex-direction:column;grid-row:2;gap:20px;height:calc(100vh - 65px);padding:28px 22px;display:flex;position:sticky;top:0;overflow-y:auto}.mode-toggle{border:1px solid var(--line);border-radius:2px;gap:0;display:flex;overflow:hidden}.mode-btn{cursor:pointer;font-family:var(--font-crimson),serif;color:var(--ink-soft);letter-spacing:.05em;text-transform:uppercase;background:0 0;border:none;flex:1;padding:8px;font-size:.8rem;transition:all .2s}.mode-btn.active{background:var(--ink);color:var(--parchment)}#voice-panel{flex-direction:column;align-items:center;gap:16px;display:flex}.mic-ring{width:110px;height:110px;position:relative}.mic-ring-outer{border:2px solid var(--line);border-radius:50%;transition:all .3s;position:absolute;inset:0}.mic-ring-outer.active{border-color:var(--rose);animation:1.5s ease-in-out infinite ring-pulse}@keyframes ring-pulse{0%,to{box-shadow:0 0 0 4px #c4736a1f,0 0 0 12px #c4736a0d}50%{box-shadow:0 0 0 12px #c4736a14,0 0 0 24px #c4736a08}}#mic-btn{background:var(--parchment);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;transition:all .25s;display:flex;position:absolute;inset:8px;box-shadow:0 2px 12px #2c18101f}#mic-btn:hover{transform:scale(1.04)}#mic-btn.recording{background:var(--rose)}#mic-btn.recording svg{color:#fff}.mic-label{color:var(--ink-soft);text-align:center;letter-spacing:.05em;text-transform:uppercase;font-size:.78rem}#visualizer{justify-content:center;align-items:center;gap:4px;width:100%;height:100px;display:flex}.viz-bar{background:var(--gold);border-radius:4px;width:4px;height:4px;transition:height 50ms ease-out}#text-panel{flex-direction:column;gap:12px;display:none}#text-input{background:var(--parchment);border:1px solid var(--line);width:100%;font-family:var(--font-crimson),serif;color:var(--ink);resize:none;border-radius:2px;outline:none;height:200px;padding:12px 14px;font-size:.95rem;line-height:1.6;overflow-y:auto}#text-input:focus{border-color:var(--gold)}#send-btn{background:var(--ink);color:var(--parchment);font-family:var(--font-playfair),serif;cursor:pointer;letter-spacing:.03em;border:none;border-radius:2px;padding:10px;font-size:.9rem;transition:all .2s}#send-btn:hover{background:var(--ink-soft)}#send-btn:disabled{opacity:.4;cursor:not-allowed}#generating-banner{color:var(--gold);background:#c9973a14;border:1px solid #c9973a33;border-radius:4px;align-items:center;gap:10px;padding:12px 14px;font-size:.8rem;display:none}#generating-banner.visible{display:flex}.gen-spinner{border:2px solid #c9973a33;border-top-color:var(--gold);border-radius:50%;width:14px;height:14px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.transcript-label{text-transform:uppercase;letter-spacing:.1em;color:var(--ink-soft);opacity:.6;font-size:.7rem}#transcript-box{background:var(--parchment);border:1px solid var(--line);color:var(--ink-soft);border-radius:4px;flex:1;min-height:120px;max-height:220px;padding:14px;font-size:.88rem;font-style:italic;line-height:1.7;overflow-y:auto}#transcript-box::-webkit-scrollbar{width:4px}#transcript-box::-webkit-scrollbar-thumb{background:var(--line);border-radius:2px}.transcript-agent{color:var(--ink);font-style:normal}.transcript-agent:before{content:"✦ ";color:var(--gold);font-size:.7em}.transcript-user{color:var(--ink-soft);font-style:italic}.transcript-user:before{content:"you — ";opacity:.5;font-size:.8em}.session-info{border:1px solid var(--line);color:var(--ink-soft);background:#2c181008;border-radius:4px;padding:14px;font-size:.82rem;line-height:1.6}.session-info strong{color:var(--ink);font-weight:500}#book-area{grid-row:2;padding:40px;overflow-y:auto}#book-area::-webkit-scrollbar{width:6px}#book-area::-webkit-scrollbar-thumb{background:var(--line);border-radius:3px}#welcome-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:18px;min-height:60vh;padding:60px 40px;display:flex}.welcome-ornament{color:var(--gold);opacity:.6;font-size:2rem}.welcome-title{font-family:var(--font-playfair),serif;font-size:1.9rem;font-weight:400;line-height:1.3}.welcome-sub{color:var(--ink-soft);max-width:360px;font-size:1.05rem;font-style:italic;line-height:1.7}.welcome-hint{color:var(--ink-soft);opacity:.4;letter-spacing:.05em;text-transform:uppercase;margin-top:6px;font-size:.78rem}#book-content{display:block}.book-header{border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;margin-bottom:36px;padding-bottom:18px;display:flex}.book-title-text{font-family:var(--font-playfair),serif;font-size:1.4rem;font-weight:400}.book-page-count{color:var(--ink-soft);opacity:.5;letter-spacing:.05em;font-size:.8rem}#pages-container{flex-direction:column;gap:56px;display:flex}.book-page{opacity:0;background:#fff;border-radius:2px;grid-template-columns:1fr 1fr;animation:.8s forwards page-appear;display:grid;overflow:hidden;transform:translateY(24px);box-shadow:0 4px 40px #2c18101a,0 1px 8px #2c18100f}@keyframes page-appear{to{opacity:1;transform:translateY(0)}}.page-illustration{background:var(--cream);aspect-ratio:4/3;position:relative;overflow:hidden}.page-illustration img{object-fit:cover;opacity:0;width:100%;height:100%;transition:opacity .8s;display:block}.page-illustration img.loaded{opacity:1}.img-loading{flex-direction:column;justify-content:center;align-items:center;gap:12px;display:flex;position:absolute;inset:0}.watercolor-spin{filter:blur(2px);background:conic-gradient(#c9973a4d 0deg,#c4736a4d 120deg,#7a9e7e4d 240deg,#c9973a4d 360deg);border-radius:50%;width:56px;height:56px;animation:3s linear infinite wcspin}@keyframes wcspin{to{transform:rotate(360deg)}}.img-loading-text{color:var(--ink-soft);opacity:.5;font-size:.75rem;font-style:italic}.page-content{flex-direction:column;justify-content:center;gap:18px;padding:44px 38px;display:flex;position:relative}.page-content:before{content:"";background:linear-gradient(to bottom,transparent,var(--line),transparent);width:1px;position:absolute;top:40px;bottom:40px;left:0}.page-number{text-transform:uppercase;letter-spacing:.12em;color:var(--gold);opacity:.7;font-size:.7rem}.page-chapter-tag{text-transform:uppercase;letter-spacing:.1em;color:var(--ink-soft);opacity:.5;border:1px solid var(--line);border-radius:20px;align-self:flex-start;padding:3px 10px;font-size:.7rem;display:inline-block}.page-narration{font-family:var(--font-playfair),serif;color:var(--ink);font-size:1.08rem;font-style:italic;line-height:1.85}.page-era{color:var(--ink-soft);opacity:.45;letter-spacing:.05em;font-size:.78rem}.page-divider{background:var(--gold);opacity:.4;width:36px;height:1px}.page-people{flex-wrap:wrap;gap:6px;display:flex}.person-tag{color:var(--gold);letter-spacing:.04em;background:#c9973a14;border:1px solid #c9973a33;border-radius:20px;padding:2px 8px;font-size:.7rem}@media (max-width:768px){#app{grid-template-rows:auto auto 1fr;grid-template-columns:1fr}#sidebar{border-right:none;border-bottom:1px solid var(--line);grid-row:2;height:auto;max-height:50vh;padding:20px;position:relative}#book-area{grid-row:3;padding:20px}.book-page{grid-template-columns:1fr}.page-illustration{aspect-ratio:16/9}.page-content{padding:24px}.page-content:before{display:none}header{padding:12px 20px}.logo-title{font-size:1.4rem}.logo-sub{display:none}.connect-title{font-size:2rem}.welcome-title{font-size:1.5rem}}.app-container{grid-template-rows:72px 1fr;grid-template-columns:320px 1fr;height:100vh;display:grid}.auth-wrapper{background:var(--cream);z-index:1000;grid-area:1/1/-1/-1;justify-content:center;align-items:center;display:flex;position:fixed;inset:0;overflow:hidden}.ambient-orb{filter:blur(80px);opacity:.4;pointer-events:none;border-radius:50%;animation:20s ease-in-out infinite alternate float-orb;position:absolute}.orb-1{background:radial-gradient(circle,#c9973a33 0%,#c9973a00 70%);width:50vw;height:50vw;animation-delay:-5s;top:-10%;left:-10%}.orb-2{background:radial-gradient(circle,#c4736a26 0%,#c4736a00 70%);width:40vw;height:40vw;animation-duration:25s;bottom:-5%;right:-5%}@keyframes float-orb{0%{transform:translate(0)scale(1)}50%{transform:translate(5%,10%)scale(1.05)}to{transform:translate(-5%,-5%)scale(.95)}}.auth-glass-panel{z-index:10;-webkit-backdrop-filter:blur(20px);text-align:center;opacity:0;background:#ffffffb3;border:1px solid #ffffff80;border-radius:24px;width:90%;max-width:440px;padding:60px 50px;animation:1s cubic-bezier(.16,1,.3,1) forwards auth-appear;position:relative;transform:translateY(20px);box-shadow:0 24px 80px #2c181014,inset 0 0 0 1px #fffc}@keyframes auth-appear{to{opacity:1;transform:translateY(0)}}.auth-logo-icon{background:linear-gradient(135deg,var(--gold),var(--rose));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:12px;font-size:3rem;animation:3s linear infinite shine;display:inline-block}@keyframes shine{0%{filter:brightness()drop-shadow(0 0 2px #c9973a00)}50%{filter:brightness(1.2)drop-shadow(0 0 8px #c9973a66)}to{filter:brightness()drop-shadow(0 0 2px #c9973a00)}}.auth-brand-title{font-family:var(--font-playfair),serif;color:var(--ink);letter-spacing:-.02em;margin-bottom:8px;font-size:2.75rem;font-weight:700}.auth-brand-subtitle{color:var(--ink-soft);font-size:1rem;font-style:italic;font-family:var(--font-playfair),serif;opacity:.8;margin-bottom:32px}.auth-divider{justify-content:center;align-items:center;gap:16px;margin-bottom:32px;display:flex}.auth-divider-line{background:linear-gradient(90deg,transparent,var(--line),transparent);flex:1;height:1px}.auth-divider-icon{color:var(--gold);opacity:.6;font-size:.8rem}.auth-instruction{color:var(--ink-soft);margin-bottom:24px;font-size:.95rem}.auth-error-pill{color:var(--error);background:#e539351a;border:1px solid #e5393533;border-radius:12px;margin-bottom:24px;padding:10px 16px;font-size:.85rem}.btn-google-premium{width:100%;color:var(--ink);font-family:var(--font-inter),sans-serif;cursor:pointer;background:#fff;border:1px solid #2c18101a;border-radius:100px;justify-content:center;align-items:center;gap:14px;padding:16px 24px;font-size:1.05rem;font-weight:500;transition:all .4s cubic-bezier(.16,1,.3,1);display:flex;position:relative;overflow:hidden;box-shadow:0 4px 14px #0000000a}.google-icon-wrapper{background:#f8f9fa;border-radius:50%;justify-content:center;align-items:center;padding:6px;transition:transform .4s;display:flex}.google-btn-text{z-index:1;transition:transform .4s;position:relative}.google-btn-glow{opacity:0;z-index:0;background:linear-gradient(90deg,#c9973a00 0%,#c9973a1a 50%,#c9973a00 100%);transition:opacity .4s;position:absolute;inset:0}.btn-google-premium:hover{border-color:#c9973a4d;transform:translateY(-2px);box-shadow:0 12px 24px #2c181014,0 4px 8px #c9973a1a}.btn-google-premium:hover .google-icon-wrapper{background:#fff;transform:scale(1.1);box-shadow:0 2px 8px #0000000d}.btn-google-premium:hover .google-btn-glow{opacity:1;animation:2s linear infinite shimmer}.btn-google-premium:active{transform:translateY(0);box-shadow:0 4px 12px #2c18100d}.btn-google-premium.loading{opacity:.8;pointer-events:none;cursor:wait}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.auth-footnote{color:var(--ink-soft);opacity:.6;letter-spacing:.02em;margin-top:32px;font-size:.75rem}@media (max-width:768px){.app-container{grid-template-rows:auto auto 1fr;grid-template-columns:1fr;height:auto;min-height:100vh}}
