/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{@supports ((-webkit-hyphens:none) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-space-y-reverse:0;--tw-border-style:solid;--tw-gradient-position:initial;--tw-gradient-from:#0000;--tw-gradient-via:#0000;--tw-gradient-to:#0000;--tw-gradient-stops:initial;--tw-gradient-via-stops:initial;--tw-gradient-from-position:0%;--tw-gradient-via-position:50%;--tw-gradient-to-position:100%;--tw-font-weight:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid}}}@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;--color-red-100:oklch(93.6% .032 17.717);--color-red-600:oklch(57.7% .245 27.325);--color-red-700:oklch(50.5% .213 27.518);--color-green-100:oklch(96.2% .044 156.743);--color-green-500:oklch(72.3% .219 149.579);--color-green-700:oklch(52.7% .154 150.069);--color-blue-500:oklch(62.3% .214 259.815);--color-blue-600:oklch(54.6% .245 262.881);--color-indigo-100:oklch(93% .034 272.788);--color-indigo-300:oklch(78.5% .115 274.713);--color-indigo-500:oklch(58.5% .233 277.117);--color-indigo-600:oklch(51.1% .262 276.966);--color-indigo-700:oklch(45.7% .24 277.023);--color-gray-50:oklch(98.5% .002 247.839);--color-gray-100:oklch(96.7% .003 264.542);--color-gray-200:oklch(92.8% .006 264.531);--color-gray-400:oklch(70.7% .022 261.325);--color-gray-500:oklch(55.1% .027 264.364);--color-gray-600:oklch(44.6% .03 256.802);--color-gray-700:oklch(37.3% .034 259.733);--color-gray-800:oklch(27.8% .033 256.848);--color-gray-900:oklch(21% .034 264.665);--color-white:#fff;--spacing:.25rem;--container-6xl:72rem;--text-xs:.75rem;--text-xs--line-height:calc(1/.75);--text-sm:.875rem;--text-sm--line-height:calc(1.25/.875);--text-lg:1.125rem;--text-lg--line-height:calc(1.75/1.125);--text-xl:1.25rem;--text-xl--line-height:calc(1.75/1.25);--text-3xl:1.875rem;--text-3xl--line-height: 1.2 ;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--radius-sm:.25rem;--radius-md:.375rem;--radius-lg:.5rem;--animate-spin:spin 1s linear infinite;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4,0,.2,1);--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%;-moz-tab-size:4;-o-tab-size:4;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;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}::-moz-placeholder{opacity:1}::placeholder{opacity:1}@supports (not (-webkit-appearance:-apple-pay-button)) or (contain-intrinsic-size:1px){::-moz-placeholder{color:currentColor}::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::-moz-placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}::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]){-webkit-appearance:button;-moz-appearance:button;appearance:button}::file-selector-button{-webkit-appearance:button;-moz-appearance: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{.fixed{position:fixed}.col-span-4{grid-column:span 4/span 4}.col-span-8{grid-column:span 8/span 8}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.mx-auto{margin-inline:auto}.mt-1{margin-top:calc(var(--spacing)*1)}.mt-2{margin-top:calc(var(--spacing)*2)}.mt-3{margin-top:calc(var(--spacing)*3)}.mt-4{margin-top:calc(var(--spacing)*4)}.mt-6{margin-top:calc(var(--spacing)*6)}.mb-2{margin-bottom:calc(var(--spacing)*2)}.mb-3{margin-bottom:calc(var(--spacing)*3)}.mb-4{margin-bottom:calc(var(--spacing)*4)}.ml-2{margin-left:calc(var(--spacing)*2)}.block{display:block}.contents{display:contents}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-block{display:inline-block}.h-2{height:calc(var(--spacing)*2)}.h-5{height:calc(var(--spacing)*5)}.h-6{height:calc(var(--spacing)*6)}.h-9{height:calc(var(--spacing)*9)}.h-12{height:calc(var(--spacing)*12)}.h-14{height:calc(var(--spacing)*14)}.h-16{height:calc(var(--spacing)*16)}.h-32{height:calc(var(--spacing)*32)}.max-h-56{max-height:calc(var(--spacing)*56)}.max-h-72{max-height:calc(var(--spacing)*72)}.min-h-\[80px\]{min-height:80px}.min-h-screen{min-height:100vh}.w-5{width:calc(var(--spacing)*5)}.w-6{width:calc(var(--spacing)*6)}.w-9{width:calc(var(--spacing)*9)}.w-10{width:calc(var(--spacing)*10)}.w-12{width:calc(var(--spacing)*12)}.w-32{width:calc(var(--spacing)*32)}.w-80{width:calc(var(--spacing)*80)}.w-full{width:100%}.max-w-6xl{max-width:var(--container-6xl)}.flex-1{flex:1}.animate-spin{animation:var(--animate-spin)}.cursor-pointer{cursor:pointer}.resize-none{resize:none}.list-inside{list-style-position:inside}.list-decimal{list-style-type:decimal}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-12{grid-template-columns:repeat(12,minmax(0,1fr))}.items-center{align-items:center}.items-end{align-items:flex-end}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.gap-2{gap:calc(var(--spacing)*2)}.gap-3{gap:calc(var(--spacing)*3)}.gap-4{gap:calc(var(--spacing)*4)}.gap-6{gap:calc(var(--spacing)*6)}:where(.space-y-2>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*2)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*2)*calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-3>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*3)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*3)*calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-6>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*6)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*6)*calc(1 - var(--tw-space-y-reverse)))}.overflow-hidden{overflow:hidden}.rounded{border-radius:.25rem}.rounded-full{border-radius:3.40282e38px}.rounded-lg{border-radius:var(--radius-lg)}.rounded-md{border-radius:var(--radius-md)}.rounded-sm{border-radius:var(--radius-sm)}.rounded-t{border-top-left-radius:.25rem;border-top-right-radius:.25rem}.border{border-style:var(--tw-border-style);border-width:1px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-b-2{border-bottom-style:var(--tw-border-style);border-bottom-width:2px}.border-blue-500{border-color:var(--color-blue-500)}.bg-blue-500{background-color:var(--color-blue-500)}.bg-gray-50{background-color:var(--color-gray-50)}.bg-gray-100{background-color:var(--color-gray-100)}.bg-gray-200{background-color:var(--color-gray-200)}.bg-green-100{background-color:var(--color-green-100)}.bg-green-500{background-color:var(--color-green-500)}.bg-indigo-100{background-color:var(--color-indigo-100)}.bg-indigo-500{background-color:var(--color-indigo-500)}.bg-indigo-600{background-color:var(--color-indigo-600)}.bg-red-100{background-color:var(--color-red-100)}.bg-white{background-color:var(--color-white)}.bg-gradient-to-b{--tw-gradient-position:to bottom in oklab;background-image:linear-gradient(var(--tw-gradient-stops))}.from-indigo-300{--tw-gradient-from:var(--color-indigo-300);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position),var(--tw-gradient-from)var(--tw-gradient-from-position),var(--tw-gradient-to)var(--tw-gradient-to-position))}.to-indigo-500{--tw-gradient-to:var(--color-indigo-500);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position),var(--tw-gradient-from)var(--tw-gradient-from-position),var(--tw-gradient-to)var(--tw-gradient-to-position))}.object-cover{-o-object-fit:cover;object-fit:cover}.p-2{padding:calc(var(--spacing)*2)}.p-3{padding:calc(var(--spacing)*3)}.p-4{padding:calc(var(--spacing)*4)}.p-6{padding:calc(var(--spacing)*6)}.px-2{padding-inline:calc(var(--spacing)*2)}.px-3{padding-inline:calc(var(--spacing)*3)}.px-4{padding-inline:calc(var(--spacing)*4)}.px-6{padding-inline:calc(var(--spacing)*6)}.py-0\.5{padding-block:calc(var(--spacing)*.5)}.py-1{padding-block:calc(var(--spacing)*1)}.py-2{padding-block:calc(var(--spacing)*2)}.py-3{padding-block:calc(var(--spacing)*3)}.py-8{padding-block:calc(var(--spacing)*8)}.py-12{padding-block:calc(var(--spacing)*12)}.text-center{text-align:center}.text-3xl{font-size:var(--text-3xl);line-height:var(--tw-leading,var(--text-3xl--line-height))}.text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.text-gray-400{color:var(--color-gray-400)}.text-gray-500{color:var(--color-gray-500)}.text-gray-600{color:var(--color-gray-600)}.text-gray-700{color:var(--color-gray-700)}.text-gray-800{color:var(--color-gray-800)}.text-gray-900{color:var(--color-gray-900)}.text-green-700{color:var(--color-green-700)}.text-indigo-600{color:var(--color-indigo-600)}.text-indigo-700{color:var(--color-indigo-700)}.text-red-600{color:var(--color-red-600)}.text-red-700{color:var(--color-red-700)}.text-white{color:var(--color-white)}.shadow,.shadow-sm{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a),0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}@media (hover:hover){.hover\:bg-blue-600:hover{background-color:var(--color-blue-600)}.hover\:bg-gray-100:hover{background-color:var(--color-gray-100)}.hover\:text-gray-900:hover{color:var(--color-gray-900)}}@media (min-width:48rem){.md\:flex{display:flex}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:#2d3748;background-color:#f5f7fa;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.modern-header{z-index:1000;background:#fff;border-bottom:1px solid #e2e8f0;position:sticky;top:0;box-shadow:0 1px 3px #0000001a}.modern-header-container{justify-content:space-between;align-items:center;max-width:1280px;margin:0 auto;padding:1rem 1.5rem;display:flex}.header-logo{cursor:pointer;align-items:center;gap:.75rem;display:flex}.logo-icon{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:8px;justify-content:center;align-items:center;width:40px;height:40px;font-size:24px;display:flex}.logo-text{-webkit-text-fill-color:transparent;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-size:1.5rem;font-weight:700}.header-nav{align-items:center;gap:1.5rem;display:flex}.nav-button{cursor:pointer;color:#4a5568;background:0 0;border:none;border-radius:8px;align-items:center;gap:.5rem;padding:.625rem 1rem;font-weight:500;transition:all .2s;display:flex}.nav-button:hover{color:#2d3748;background:#f7fafc}.nav-button.active{color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 4px 6px #667eea4d}.user-avatar{color:#fff;cursor:pointer;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-weight:600;transition:transform .2s;display:flex}.user-avatar:hover{transform:scale(1.05);box-shadow:0 4px 12px #667eea66}.btn-primary{color:#fff;cursor:pointer;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;padding:.625rem 1.5rem;font-weight:500;transition:all .2s}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 12px #667eea66}.page-container{background:#f5f7fa;min-height:calc(100vh - 72px)}.content-wrapper{max-width:1280px;margin:0 auto;padding:2rem 1.5rem}.content-grid{grid-template-columns:1fr;gap:1.5rem;display:grid}@media (min-width:1024px){.content-grid{grid-template-columns:2fr 1fr}}.card{background:#fff;border-radius:12px;margin-bottom:1.5rem;padding:1.5rem;box-shadow:0 1px 3px #0000001a}.card:hover{transition:box-shadow .2s;box-shadow:0 4px 6px #0000001a}.card-header{color:#2d3748;margin-bottom:1rem;font-size:1.25rem;font-weight:600}.post-composer{gap:1rem;display:flex}.post-composer-textarea{resize:none;border:1px solid #e2e8f0;border-radius:8px;width:100%;margin-bottom:1rem;padding:.75rem;font-family:inherit;font-size:1rem}.post-composer-textarea:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a}.post-composer textarea{resize:none;border:1px solid #e2e8f0;border-radius:8px;flex:1;padding:.75rem;font-family:inherit;font-size:1rem}.post-composer textarea:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a}.emotion-selector{flex-wrap:wrap;gap:.5rem;margin-top:1rem;display:flex}.emotion-btn{cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:20px;padding:.5rem 1rem;font-size:.875rem;transition:all .2s}.emotion-btn:hover{background:#f7fafc}.emotion-btn.selected{color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);border-color:#0000;transform:scale(1.05)}.action-buttons{justify-content:space-between;align-items:center;margin-top:1rem;display:flex}.action-group{gap:.5rem;display:flex}.icon-btn{color:#718096;cursor:pointer;background:0 0;border:none;border-radius:6px;padding:.5rem 1rem;font-size:.875rem;transition:all .2s}.icon-btn:hover{color:#4a5568;background:#f7fafc}.icon-btn.active{color:#6366f1;background:#eef2ff}.feed-post{gap:.75rem;display:flex}.post-avatar{color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:.875rem;font-weight:600;display:flex}.post-content{flex:1}.post-header{align-items:center;gap:.5rem;margin-bottom:.5rem;display:flex}.post-username{color:#2d3748;font-weight:600}.post-emotion{color:#718096;font-size:.875rem}.post-book{color:#667eea;font-size:.875rem;font-weight:500}.post-timestamp{color:#a0aec0;font-size:.75rem}.tabs-container{background:#fff;border-radius:12px;margin-bottom:1.5rem;box-shadow:0 1px 3px #0000001a}.tabs-header{border-bottom:1px solid #e2e8f0;display:flex}.tab-button{color:#718096;cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;padding:1rem 1.5rem;font-weight:500;transition:all .2s}.tab-button:hover{color:#4a5568}.tab-button.active{color:#667eea;border-bottom-color:#667eea}.tab-count{background:#edf2f7;border-radius:12px;margin-left:.5rem;padding:.125rem .5rem;font-size:.75rem}.book-card{gap:1rem;display:flex}.book-cover-placeholder{color:#fff;text-align:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:96px;height:144px;padding:.5rem;font-size:.75rem;font-weight:600;display:flex}.book-details{flex:1;min-width:0}.book-title{color:#2d3748;margin-bottom:.25rem;font-size:1.125rem;font-weight:600}.book-author{color:#718096;font-size:.875rem}.status-badge{white-space:nowrap;border-radius:12px;padding:.25rem .75rem;font-size:.75rem;font-weight:600}.status-finished{color:#22543d;background:#c6f6d5}.status-reading{color:#2c5282;background:#bee3f8}.status-to-read{color:#4a5568;background:#e2e8f0}.progress-container{margin:.75rem 0}.progress-header{color:#718096;justify-content:space-between;margin-bottom:.25rem;font-size:.75rem;display:flex}.progress-bar{background:#e2e8f0;border-radius:4px;width:100%;height:8px;overflow:hidden}.progress-fill{background:linear-gradient(90deg,#667eea,#764ba2);height:100%;transition:width .3s}.page-counter{align-items:center;gap:.75rem;margin:.75rem 0;display:flex}.counter-btn{color:#4a5568;cursor:pointer;background:#edf2f7;border:none;border-radius:50%;width:32px;height:32px;font-weight:600;transition:all .2s}.counter-btn:hover:not(:disabled){background:#e2e8f0}.counter-btn:disabled{opacity:.3;cursor:not-allowed}.page-input{text-align:center;border:1px solid #e2e8f0;border-radius:6px;width:80px;padding:.375rem .5rem;font-size:.875rem}.page-input:focus{border-color:#667eea;outline:none}.page-label{color:#718096;font-size:.75rem}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:1rem;display:grid}.stat-card{text-align:center;background:linear-gradient(135deg,#f7fafc,#edf2f7);border-radius:8px;padding:1rem}.stat-icon{margin-bottom:.5rem;font-size:2rem}.stat-value{color:#2d3748;margin-bottom:.25rem;font-size:1.5rem;font-weight:700}.stat-label{color:#718096;text-transform:uppercase;letter-spacing:.05em;font-size:.75rem}.chart-container{justify-content:space-between;align-items:flex-end;gap:.5rem;height:192px;margin-bottom:1.5rem;display:flex}.chart-bar-wrapper{flex-direction:column;flex:1;align-items:center;gap:.5rem;display:flex}.chart-bar-container{flex-direction:column;justify-content:flex-end;width:100%;height:160px;display:flex}.chart-bar{background:linear-gradient(#667eea,#764ba2);border-radius:4px 4px 0 0;width:100%;min-height:8px;transition:all .3s}.chart-bar:hover{box-shadow:0 -4px 12px #667eea66}.chart-label{text-align:center}.chart-day{color:#718096;font-size:.75rem;font-weight:600}.chart-value{color:#a0aec0;font-size:.75rem}.sidebar-widget{background:#fff;border-radius:12px;margin-bottom:1.5rem;padding:1.5rem;box-shadow:0 1px 3px #0000001a}.widget-title{align-items:center;gap:.5rem;margin-bottom:1rem;font-size:1.125rem;font-weight:600;display:flex}.friend-item{border-left:4px solid #667eea;margin-bottom:1rem;padding-left:.75rem}.friend-item:last-child{margin-bottom:0}.friend-name{color:#2d3748;font-size:.875rem;font-weight:500}.friend-book{color:#667eea;margin-top:.125rem;font-size:.875rem;font-weight:600}.leaderboard-item{border-radius:6px;justify-content:space-between;align-items:center;margin-bottom:.5rem;padding:.5rem;transition:background .2s;display:flex}.leaderboard-item:hover{background:#f7fafc}.leaderboard-info{align-items:center;gap:.5rem;display:flex}.leaderboard-rank{color:#a0aec0;width:20px;font-size:.875rem;font-weight:700}.leaderboard-name{color:#4a5568;font-size:.875rem}.leaderboard-score{color:#667eea;font-size:.875rem;font-weight:600}.reader-tags{flex-wrap:wrap;gap:.5rem;display:flex}.reader-tag{color:#667eea;cursor:pointer;background:linear-gradient(135deg,#ebf4ff,#f3e8ff);border-radius:16px;padding:.375rem .75rem;font-size:.875rem;font-weight:500;transition:all .2s}.reader-tag:hover{transform:translateY(-1px);box-shadow:0 2px 4px #667eea33}.loading{text-align:center;padding:3rem}.spinner{border:4px solid #e2e8f0;border-top-color:#667eea;border-radius:50%;width:48px;height:48px;margin:0 auto 1rem;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{color:#718096}.empty-state{text-align:center;padding:3rem 1.5rem}.empty-icon{margin-bottom:1rem;font-size:4rem}.empty-title{color:#2d3748;margin-bottom:.5rem;font-size:1.25rem;font-weight:600}.empty-text{color:#718096}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background-color:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background-color:#fff;border-radius:12px;flex-direction:column;width:90%;max-width:600px;max-height:90vh;display:flex;overflow:hidden;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.modal-content.modal-lg{max-width:900px}.modal-content.modal-sm{max-width:500px}.modal-header{border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;padding:1.5rem;display:flex}.modal-title{color:#1f2937;margin:0;font-size:1.5rem;font-weight:700}.modal-close{cursor:pointer;color:#6b7280;background:0 0;border:none;padding:.25rem;font-size:1.5rem;transition:color .2s}.modal-close:hover{color:#1f2937}.modal-body{flex:1;padding:1.5rem;overflow-y:auto}.modal-footer{border-top:1px solid #e2e8f0;justify-content:flex-end;gap:.75rem;padding:1.5rem;display:flex}.form-group{margin-bottom:1rem}.form-label{color:#374151;margin-bottom:.5rem;font-size:.875rem;font-weight:500;display:block}.form-input,.form-textarea,.form-select{border:2px solid #e5e7eb;border-radius:8px;width:100%;padding:.75rem;font-family:inherit;font-size:.875rem;transition:border-color .2s}.form-input:focus,.form-textarea:focus,.form-select:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a}.form-textarea{resize:vertical;min-height:80px}.form-hint{color:#9ca3af;margin-top:.25rem;font-size:.75rem}.form-error{color:#ef4444;margin-top:.25rem;font-size:.75rem}.book-metadata-section{background-color:#f9fafb;border-radius:8px;margin-top:1rem;padding:1rem}.form-row{gap:1rem;margin-bottom:.75rem;display:flex}.form-row .form-group{flex:1}.btn{cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.875rem;font-weight:500;transition:all .2s;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{color:#374151;background:#f3f4f6}.btn-secondary:hover:not(:disabled){background:#e5e7eb}.btn-success{color:#fff;background:#10b981}.btn-success:hover:not(:disabled){background:#059669;box-shadow:0 4px 6px #10b9814d}.btn-danger{color:#fff;background:#ef4444}.btn-danger:hover:not(:disabled){background:#dc2626;box-shadow:0 4px 6px #ef44444d}.btn-sm{padding:.5rem 1rem;font-size:.75rem}.btn-lg{padding:1rem 2rem;font-size:1rem}.search-bar{gap:.75rem;margin-bottom:1rem;display:flex}.search-input{border:2px solid #e5e7eb;border-radius:8px;flex:1;padding:.75rem 1rem;font-size:1rem}.search-input:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a}.user-card{border:1px solid #e5e7eb;border-radius:8px;align-items:center;gap:1rem;padding:1rem;transition:all .2s;display:flex}.user-card:hover{border-color:#667eea;box-shadow:0 2px 4px #0000001a}.user-card-avatar{color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:1rem;font-weight:600;display:flex}.user-card-info{flex:1;min-width:0}.user-card-name{color:#1f2937;text-overflow:ellipsis;white-space:nowrap;font-size:.875rem;font-weight:600;overflow:hidden}.user-card-username{color:#6b7280;text-overflow:ellipsis;white-space:nowrap;font-size:.75rem;overflow:hidden}.user-card-actions{align-items:center;gap:.5rem;display:flex}.badge{white-space:nowrap;border-radius:12px;padding:.25rem .75rem;font-size:.75rem;font-weight:600}.badge-primary{color:#1e40af;background:#dbeafe}.badge-success{color:#065f46;background:#d1fae5}.badge-purple{color:#6b21a8;background:#ede9fe}.badge-gray{color:#4b5563;background:#f3f4f6}.alert{border-radius:8px;margin-bottom:1rem;padding:1rem;font-size:.875rem}.alert-error{color:#991b1b;background:#fee2e2;border:1px solid #fecaca}.alert-success{color:#065f46;background:#d1fae5;border:1px solid #a7f3d0}.alert-info{color:#1e40af;background:#dbeafe;border:1px solid #bfdbfe}.divider{background:#e5e7eb;height:1px;margin:1rem 0}.quote-box{background:#f9fafb;border:2px solid #e5e7eb;border-left:4px solid #6366f1;border-radius:8px;margin-bottom:1rem;padding:1rem;position:relative}.quote-box-header{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.quote-icon{font-size:1.5rem}.quote-close{cursor:pointer;color:#6b7280;background:0 0;border:none;padding:0;font-size:20px}.quote-textarea{resize:none;background:#fff;border:1px solid #d1d5db;border-radius:6px;width:100%;padding:.75rem;font-family:inherit;font-size:.95rem;font-style:italic}.image-preview{border:1px solid #e2e8f0;border-radius:8px;margin-bottom:1rem;position:relative;overflow:hidden}.image-preview img{-o-object-fit:cover;object-fit:cover;width:100%;max-height:300px}.image-preview-close{color:#fff;cursor:pointer;background:#0009;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:18px;display:flex;position:absolute;top:8px;right:8px}.post-meta{color:#9ca3af;font-size:.875rem}.post-book-info{color:#6b7280;margin-top:.25rem;font-size:.875rem;font-style:italic}.post-quote{background:linear-gradient(135deg,#f9fafb,#f3f4f6);border-left:4px solid #6366f1;border-radius:8px;margin-top:1rem;padding:1rem 1.25rem;position:relative}.post-quote-icon{color:#6366f1;font-size:2rem;line-height:1}.post-quote-text{color:#374151;margin:0;padding-top:.5rem;font-size:.95rem;font-style:italic;line-height:1.6}.post-quote-attribution{color:#6b7280;text-align:right;margin-top:.5rem;font-size:.875rem}.post-text{color:#4a5568;margin:1rem 0 .75rem;font-style:italic;line-height:1.6}.post-timestamp{color:#a0aec0;margin-top:.75rem;font-size:.75rem}.post-image{border-radius:8px;margin-top:1rem;overflow:hidden}.post-image img{-o-object-fit:cover;object-fit:cover;width:100%;max-height:384px}.post-actions{border-top:1px solid #f3f4f6;gap:1.5rem;margin-top:.75rem;padding-top:.75rem;display:flex}.post-action-button{cursor:pointer;color:#6b7280;background:0 0;border:none;align-items:center;gap:.5rem;padding:0;font-size:.875rem;transition:color .2s;display:flex}.post-action-button:hover{color:#374151}.post-action-icon{font-size:1.25rem}.section-title{color:#1f2937;margin-bottom:1.5rem;font-size:1.875rem;font-weight:700}.friend-activity-item{align-items:flex-start;gap:1rem;display:flex}.friend-activity-text{color:#4b5563;margin-bottom:.25rem;font-size:.875rem}.friend-activity-username{color:#1f2937;font-weight:600}.friend-activity-badge{color:#6b21a8;background:#ede9fe;border-radius:12px;margin-left:.5rem;padding:.125rem .5rem;font-size:.75rem;font-weight:600}.friend-activity-book{color:#1f2937;margin-bottom:.25rem;font-size:1rem;font-style:italic;font-weight:600}.friend-activity-author{color:#9ca3af;font-size:.875rem}.progress-circle{color:#1f2937;border:4px solid #e5e7eb;border-radius:50%;justify-content:center;align-items:center;width:60px;height:60px;font-size:.875rem;font-weight:700;display:flex}.progress-circle.progress-high{border-top-color:#10b981;border-right-color:#10b981}.progress-circle.progress-medium{border-top-color:#3b82f6;border-right-color:#3b82f6}.progress-circle.progress-low{border-top-color:#6b7280;border-right-color:#6b7280}.book-cover{-o-object-fit:cover;object-fit:cover;border-radius:6px;flex-shrink:0;width:100px;height:150px;box-shadow:0 2px 4px #0000001a}.book-cover-placeholder{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:100px;height:150px;padding:.5rem;display:flex;box-shadow:0 2px 4px #0000001a}.book-cover-icon{color:#fff;text-align:center;font-size:2rem}.emotion-badges{z-index:1;gap:.25rem;display:flex;position:absolute;top:.75rem;right:.75rem}.emotion-badge{border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:.875rem;display:flex;box-shadow:0 1px 2px #0000001a}.quick-action-btn{cursor:pointer;border:none;border-radius:6px;align-items:center;gap:.25rem;padding:.5rem .75rem;font-size:.75rem;font-weight:600;transition:background .2s;display:flex}.quick-action-btn.blue{color:#1e40af;background:#eff6ff}.quick-action-btn.blue:hover{background:#dbeafe}.quick-action-btn.purple{color:#6b21a8;background:#f3e8ff}.quick-action-btn.purple:hover{background:#e9d5ff}.quick-action-btn.red{color:#dc2626;background:#fee2e2}.quick-action-btn.red:hover{background:#fecaca}.note-badge{color:#9333ea;background:#fff;border-radius:9999px;margin-left:.25rem;padding:.125rem .375rem;font-size:.75rem;font-weight:600;line-height:1;display:inline-block}.flex{display:flex}.flex-1{flex:1}.gap-1{gap:1rem}.gap-half{gap:.5rem}.items-center{align-items:center}.justify-between{justify-content:space-between}.text-center{text-align:center}.hidden{display:none}.sidebar-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.sidebar-header .widget-title{margin:0}.empty-state{text-align:center;color:#6b7280;background-color:#f9fafb;border:1px dashed #e5e7eb;border-radius:8px;padding:2rem}.empty-state-title{margin-bottom:.5rem;font-size:1rem}.empty-state-subtitle{font-size:.875rem}.friend-list{flex-direction:column;gap:1.5rem;display:flex}.friend-item{align-items:flex-start;gap:1rem;display:flex}.friend-avatar{color:#4b5563;background-color:#e5e7eb;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.25rem;font-weight:600;display:flex}.friend-avatar.mutual{color:#7c3aed;background-color:#ddd6fe;border:2px solid #8b5cf6}.friend-content{flex:1}.friend-meta{color:#4b5563;margin-bottom:.25rem;font-size:.875rem}.friend-name{color:#1f2937;font-weight:600}.friend-book{color:#1f2937;margin-bottom:.25rem;font-size:1rem;font-style:italic;font-weight:600}.friend-author{color:#9ca3af;font-size:.875rem}.highlight-section{margin-top:1.5rem}.highlight-section:first-child{margin-top:0}.highlight-section.section-gap{margin-top:2rem}.highlight-header{color:#1f2937;align-items:center;gap:.5rem;margin-bottom:1rem;font-size:.875rem;font-weight:600;display:flex}.highlight-icon{font-size:1.25rem}.highlight-list{flex-direction:column;gap:.75rem;display:flex}.highlight-item{border-radius:6px;justify-content:space-between;align-items:center;padding:.5rem;transition:background .2s;display:flex}.highlight-item-content{flex:1;align-items:center;gap:.75rem;display:flex}.highlight-rank{color:#6b7280;min-width:24px;font-size:.875rem;font-weight:600}.highlight-title{color:#1f2937;font-size:.875rem;font-style:italic}.highlight-emoji{border-radius:16px;flex-shrink:0;margin-left:.5rem;padding:.375rem .75rem;font-size:1rem}.reader-item{border-radius:6px;align-items:center;gap:.75rem;padding:.5rem;transition:background .2s;display:flex}.reader-avatar{color:#4b5563;background-color:#e5e7eb;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:1rem;font-weight:600;display:flex}.reader-username{color:#1f2937;font-size:.875rem;font-weight:500}.book-card{cursor:pointer;background-color:#fff;border-radius:12px;flex-direction:column;gap:.75rem;padding:1rem;transition:all .2s;display:flex;position:relative;box-shadow:0 1px 3px #0000001a}.book-card:hover{transform:translateY(-2px);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.book-card-content{gap:1rem;display:flex}.book-cover-wrapper{flex-shrink:0}.book-cover-img{-o-object-fit:cover;object-fit:cover;border-radius:6px;width:100px;height:150px;box-shadow:0 2px 4px #0000001a}.book-cover-placeholder{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:6px;justify-content:center;align-items:center;width:100px;height:150px;padding:.5rem;display:flex;box-shadow:0 2px 4px #0000001a}.book-details{flex-direction:column;flex:1;min-width:0;display:flex}.book-header{width:100%;margin-bottom:.75rem;padding-right:.5rem}.book-author{color:#9ca3af;text-overflow:ellipsis;white-space:normal;margin-bottom:.25rem;font-size:.75rem;line-height:1.3;display:block;overflow:hidden}.book-title{color:#1f2937;text-overflow:ellipsis;-webkit-line-clamp:2;line-clamp:2;word-break:break-word;-webkit-box-orient:vertical;width:100%;margin-bottom:0;font-size:1rem;font-weight:600;display:-webkit-box;overflow:hidden}.progress-circle{color:#1f2937;border:4px solid #e5e7eb;border-radius:50%;justify-content:center;align-items:center;width:60px;height:60px;margin-bottom:.75rem;font-size:.875rem;font-weight:700;display:flex}.progress-circle.low{border-top-color:#6b7280;border-right-color:#6b7280}.progress-circle.medium{border-top-color:#3b82f6;border-right-color:#3b82f6}.progress-circle.high{border-top-color:#10b981;border-right-color:#10b981}.quick-actions{flex-direction:row;gap:.5rem;margin-top:0;display:flex}.book-footer{color:#9ca3af;border-top:1px solid #f3f4f6;justify-content:space-between;margin-top:.75rem;padding-top:.75rem;font-size:.75rem;display:flex}.search-results{flex:1;padding:1.5rem;overflow-y:auto}.search-empty{text-align:center;color:#9ca3af;padding:3rem 1rem}.search-empty-icon{margin-bottom:.5rem;font-size:1.125rem}.result-list{flex-direction:column;gap:1rem;display:flex}.result-item{cursor:pointer;border:1px solid #e5e7eb;border-radius:8px;gap:1rem;padding:1rem;transition:all .2s;display:flex}.result-item:hover{border-color:#3b82f6;box-shadow:0 4px 6px -1px #0000001a}.result-cover{flex-shrink:0}.result-cover-img{-o-object-fit:cover;object-fit:cover;border-radius:4px;width:80px;height:120px}.result-cover-placeholder{background-color:#e5e7eb;border-radius:4px;justify-content:center;align-items:center;width:80px;height:120px;font-size:2rem;display:flex}.result-details{flex:1;min-width:0}.result-title{color:#1f2937;text-overflow:ellipsis;white-space:nowrap;margin-bottom:.25rem;font-size:1rem;font-weight:600;overflow:hidden}.result-author{color:#6b7280;margin-bottom:.5rem;font-size:.875rem}.result-meta{color:#9ca3af;gap:1rem;margin-bottom:.5rem;font-size:.75rem;display:flex}.result-description{color:#6b7280;text-overflow:ellipsis;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;font-size:.75rem;line-height:1.4;display:-webkit-box;overflow:hidden}.result-action{flex-shrink:0;align-items:center;display:flex}.tab-selector{align-items:center;gap:.5rem;margin-top:1rem;display:flex}.tab-label{color:#6b7280;margin-right:.5rem;font-size:.875rem}.chart-container{align-items:flex-end;gap:1rem;height:200px;padding:1rem 0;display:flex}.chart-bar-wrapper{flex-direction:column;flex:1;align-items:center;display:flex}.chart-bar-container{flex:1;align-items:flex-end;width:100%;display:flex}.chart-bar{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:4px 4px 0 0;width:100%;transition:all .3s}.chart-bar:hover{opacity:.8}.chart-label{text-align:center;margin-top:.5rem}.chart-day{color:#6b7280;margin-bottom:.25rem;font-size:.75rem}.chart-value{color:#1f2937;font-size:.75rem;font-weight:600}.chart-summary{text-align:center;color:#4a5568;border-top:1px solid #e2e8f0;margin-top:1rem;padding-top:1rem;font-size:.875rem}.chart-summary-value{color:#667eea;font-weight:700}.stats-insight{border-top:1px solid #e2e8f0;margin-top:1.5rem;padding-top:1rem}.insight-grid{grid-template-columns:repeat(2,1fr);gap:.75rem;font-size:.875rem;display:grid}.insight-item{background:#f7fafc;border-radius:6px;justify-content:space-between;align-items:center;padding:.75rem;display:flex}.insight-label{color:#718096}.insight-value{color:#2d3748;font-weight:600}@media (max-width:768px){.page-container{max-width:100vw;overflow-x:hidden}.content-wrapper{max-width:100%;padding:1rem .5rem;overflow-x:hidden}.modern-header-container{padding:.75rem 1rem}.logo-text{font-size:1.25rem}.logo-icon{width:32px;height:32px;font-size:18px}.header-nav{gap:.5rem}.nav-button{padding:.5rem .75rem;font-size:.875rem}.nav-button .label{display:none}.nav-button .icon{font-size:1.25rem;display:block}.user-avatar{width:32px;height:32px;font-size:.875rem}.content-grid{box-sizing:border-box;grid-template-columns:1fr;gap:1rem;max-width:100%;padding:.5rem}.main-content{box-sizing:border-box;max-width:100%;padding:0}.sidebar{display:none}.card{margin-bottom:.75rem;padding:1rem}.post-composer{padding:1rem}.composer-input{font-size:.9375rem}.composer-actions{flex-wrap:wrap;gap:.5rem}.composer-btn{padding:.5rem .75rem;font-size:.875rem}.feed-post{padding:1rem}.post-header{flex-wrap:wrap}.post-username,.post-text{font-size:.9375rem}.post-quote{margin:.75rem 0;padding:.75rem}.stats-grid{grid-template-columns:repeat(2,1fr);gap:.75rem}.stat-card{padding:.75rem}.library-header{padding:1rem}.library-title{font-size:1.5rem}.library-actions{flex-direction:column;gap:.5rem;width:100%}.library-actions button{width:100%}.library-tabs{-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:0 1rem;overflow-x:auto}.library-tabs::-webkit-scrollbar{display:none}.tabs-container{border-radius:8px;max-width:100%;margin-left:0;margin-right:0;overflow:hidden}.tabs-header{-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-wrap:wrap;overflow:visible}.tabs-header::-webkit-scrollbar{display:none}.tab-button{white-space:normal;text-align:center;flex:1 1 0;min-width:0;padding:.5rem .75rem;font-size:.8125rem;line-height:1.3}.library-filters-container{gap:.5rem!important;padding:.75rem!important}.filter-dropdown-wrapper{flex:1;max-width:calc(50% - .25rem);min-width:0!important}.filter-dropdown-wrapper select{padding:.5rem!important;font-size:.8125rem!important}.books-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem;padding:1rem}.book-card{width:100%}.book-cover{height:200px}.book-title{font-size:.9375rem}.book-author{font-size:.8125rem}.book-actions{flex-direction:column;gap:.5rem}.book-actions button{width:100%;padding:.5rem;font-size:.8125rem}.modal-content{border-radius:12px;width:95%;max-width:95vw;max-height:90vh;margin:0}.modal-header{padding:1rem}.modal-title{font-size:1.25rem}.modal-body{max-height:calc(90vh - 120px);padding:1rem}.modal-footer{flex-direction:column;gap:.5rem;padding:1rem}.modal-footer button{width:100%}.book-detail-header{flex-direction:row;gap:1rem;padding:1rem}.book-info-title{font-size:1.25rem}.book-meta{flex-direction:column;gap:.5rem}.tabs-nav{-webkit-overflow-scrolling:touch;padding:0 1rem;overflow-x:auto}.tab-nav-button{white-space:nowrap;padding:.75rem 1rem;font-size:.8125rem}.tab-content{padding:1rem}.form-grid{grid-template-columns:1fr}.form-group label{font-size:.875rem}.form-control{font-size:.9375rem}.search-results{max-height:400px}.book-result{flex-direction:column;align-items:flex-start}.book-result-cover{width:100%;max-width:120px;height:auto}.emotion-selector{gap:.375rem}.emotion-btn{padding:.375rem .625rem;font-size:.6875rem}.library-filters{flex-direction:column;gap:.5rem;padding:0 1rem 1rem}.library-filters select{width:100%}.progress-buttons{flex-direction:column}.progress-buttons button{width:100%}.note-card{padding:.75rem}.note-card-header{flex-direction:column;gap:.5rem}.following-tabs{-webkit-overflow-scrolling:touch;overflow-x:auto}.user-card{padding:1rem}.user-card-content{text-align:center;flex-direction:column}.user-card-actions{justify-content:center;width:100%}button,.btn{min-width:44px;min-height:44px}input,textarea,select{font-size:16px!important}.chart-container{max-width:100%;padding:.75rem;overflow-x:hidden}.chart-bar-wrapper{flex:none;min-width:40px}.chart-bar-container{height:120px}.chart-day,.chart-value{font-size:.75rem}.chart-summary{padding:.75rem;font-size:.875rem}.library-page{padding-bottom:1rem}.library-section{margin-bottom:1rem}.weekly-pulse-section{padding:1rem}.weekly-pulse-title{margin-bottom:1rem;font-size:1.25rem}.book-detail-content{max-height:calc(90vh - 60px);overflow-y:auto}.book-cover-large{max-width:100%;height:auto}.stats-container{padding:.75rem}.stat-value{font-size:1.5rem}.stat-label{font-size:.75rem}}@media (max-width:480px){.logo-text{display:none}.books-grid{grid-template-columns:repeat(2,1fr);gap:.75rem;padding:.75rem}.book-cover{height:180px}.stats-grid{grid-template-columns:1fr}.composer-actions{flex-direction:column}.composer-btn{width:100%}}.book-detail-header{border-bottom:1px solid #e5e7eb;gap:1rem;padding:1.5rem;display:flex}.book-info{flex:1}.book-info-title{color:#1f2937;margin-bottom:.5rem;font-size:1.5rem;font-weight:700}.book-info-author{color:#6b7280;margin-bottom:.75rem;font-size:1rem}.book-meta{color:#9ca3af;gap:1rem;font-size:.875rem;display:flex}.progress-circle-large{color:#1f2937;border:6px solid #3b82f6;border-color:#3b82f6 #3b82f6 #e5e7eb #e5e7eb;border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;margin-top:1rem;font-size:1.25rem;font-weight:700;display:flex}.modal-close-btn{cursor:pointer;color:#6b7280;z-index:10;background:#fff;border:1px solid #e5e7eb;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;padding:0;font-size:1.5rem;line-height:1;transition:all .2s;display:flex;position:absolute;top:1rem;right:1rem}.modal-close-btn:hover{color:#374151;background:#f3f4f6;transform:scale(1.1)}.close-btn{cursor:pointer;color:#6b7280;background:0 0;border:none;align-self:flex-start;padding:.25rem;font-size:1.5rem}.close-btn:hover{color:#374151}.tabs-nav{border-bottom:1px solid #e5e7eb;padding:0 1.5rem;display:flex}.tab-nav-button{cursor:pointer;color:#6b7280;background:0 0;border-top:none;border-bottom:2px solid #0000;border-left:none;border-right:1px solid #e5e7eb;padding:1rem 1.5rem;font-size:.875rem;font-weight:600}.tab-nav-button:last-child{border-right:none}.tab-nav-button:hover{color:#3b82f6}.tab-nav-button.active{color:#3b82f6;border-bottom-color:#3b82f6}.tab-content{flex:1;padding:1.5rem;overflow-y:auto}.progress-section h3,.notes-section h3{color:#1f2937;margin-bottom:1rem;font-size:1.125rem;font-weight:600}.progress-input-group{margin-bottom:1.5rem}.progress-buttons{gap:.75rem;display:flex}.btn.btn-success{background-color:#10b981}.btn.btn-success:hover{background-color:#059669}.add-note-form{background-color:#f9fafb;border-radius:8px;margin-bottom:1.5rem;padding:1.5rem}.form-grid{grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem;display:grid}.emotion-selector{flex-wrap:wrap;gap:.5rem;display:flex}.emotion-btn{cursor:pointer;border:2px solid #0000;border-radius:20px;align-items:center;gap:.25rem;padding:.5rem .75rem;font-size:.75rem;font-weight:600;display:flex}.emotion-btn.selected{border-color:#3b82f6}.notes-list{flex-direction:column;gap:1rem;display:flex}.note-card{background-color:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:1rem}.note-card-header{justify-content:space-between;align-items:start;margin-bottom:.5rem;display:flex}.note-card-meta{align-items:center;gap:.5rem;display:flex}.note-card-emotion{border-radius:12px;padding:.25rem .5rem;font-size:.75rem;font-weight:600}.note-card-location,.note-card-date{color:#9ca3af;font-size:.75rem}.note-card-text{color:#1f2937;font-size:.875rem;line-height:1.5}@media (max-width:768px){button,.nav-button,.tab-button,.tab-nav-button{-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}html{scroll-behavior:smooth;-webkit-overflow-scrolling:touch}.library-tabs::-webkit-scrollbar{display:none}.tabs-nav::-webkit-scrollbar{display:none}.following-tabs::-webkit-scrollbar{display:none}.book-card:active,.user-card:active,.note-card:active{transition:transform .1s;transform:scale(.98)}input[type=text],input[type=email],input[type=password],input[type=number],textarea,select{font-size:16px!important}.modern-header-container{padding-top:max(.75rem,env(safe-area-inset-top));padding-left:max(1rem,env(safe-area-inset-left));padding-right:max(1rem,env(safe-area-inset-right))}.content-grid{padding-bottom:max(.75rem,env(safe-area-inset-bottom))}.modal-overlay{-webkit-overflow-scrolling:touch;padding:0 .75rem}.modal-content{margin:1rem 0;animation:.3s ease-out slideUp}@keyframes slideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.modern-header-container{z-index:100;position:sticky;top:0}p,.post-text,.note-card-text{line-height:1.6}.card{box-shadow:0 1px 3px #0000001a}a:active,button:active,.btn:active{opacity:.7}}*{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f9fafb;margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}#root{min-height:100vh}@property --tw-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-gradient-position{syntax:"*";inherits:false}@property --tw-gradient-from{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-via{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-to{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-stops{syntax:"*";inherits:false}@property --tw-gradient-via-stops{syntax:"*";inherits:false}@property --tw-gradient-from-position{syntax:"<length-percentage>";inherits:false;initial-value:0%}@property --tw-gradient-via-position{syntax:"<length-percentage>";inherits:false;initial-value:50%}@property --tw-gradient-to-position{syntax:"<length-percentage>";inherits:false;initial-value:100%}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}
