.header{background-color:var(--header-bg);border-bottom:1px solid var(--border-color);height:var(--header-height);left:0;position:fixed;right:0;top:0;transition:background-color var(--transition-normal),border-color var(--transition-normal);z-index:1000}.header-content{align-items:center;display:flex;height:100%;justify-content:space-between;margin:0 auto;max-width:1200px;padding:0 calc(min(var(--gutter-desktop), var(--gutter-max))/3)}.logo{color:var(--text-muted);font-size:1.25rem;font-weight:var(--font-weight-normal);text-decoration:none;transition:opacity var(--transition-fast)}.logo:hover{opacity:.7}.hamburger{background:#0000;border:none;cursor:pointer;display:flex;flex-direction:column;height:20px;justify-content:space-around;padding:0;width:24px;z-index:1001}.hamburger span{background-color:var(--text-primary);height:2px;transform-origin:center;transition:all var(--transition-fast);width:100%}.hamburger.open span:first-child{transform:rotate(45deg) translate(6px,6px)}.hamburger.open span:nth-child(2){opacity:0}.hamburger.open span:last-child{transform:rotate(-45deg) translate(6px,-6px)}.nav{background-color:var(--bg-primary);border-left:1px solid var(--border-color);display:flex;flex-direction:column;gap:1.5rem;height:calc(100vh - var(--header-height));padding:2rem var(--gutter-desktop);position:fixed;right:0;top:var(--header-height);transform:translateX(100%);transition:transform var(--transition-normal);width:300px}.nav-open{transform:translateX(0)}.nav a{border-bottom:1px solid #0000;color:var(--text-muted);font-size:1.1rem;font-weight:var(--font-weight-normal);padding:.75rem 0;text-decoration:none;transition:all var(--transition-fast)}.nav a:hover{border-bottom-color:var(--border-color)}@media (max-width:768px){.header-content{padding:0 var(--gutter-mobile)}.nav{padding:1.5rem var(--gutter-mobile);width:250px}}@media (min-width:1400px){.header-content{padding:0 calc(var(--gutter-max)/3)}}@media (min-width:1024px){.hamburger{display:none}.nav{align-items:center;background:#0000;flex-direction:row;gap:2rem;height:auto;position:static;transform:none;width:auto}.nav,.nav a{border:none;padding:0}.nav a{font-size:1rem}}.theme-toggle-floating{align-items:center;background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:50%;bottom:2rem;box-shadow:0 4px 12px var(--shadow);color:var(--text-muted);cursor:pointer;display:flex;height:50px;justify-content:center;position:fixed;right:2rem;transition:all var(--transition-fast);width:50px;z-index:1000}.theme-toggle-floating:hover{box-shadow:0 6px 16px var(--shadow);color:var(--text-primary);transform:translateY(-1px)}.theme-toggle-floating:active{transform:translateY(0)}.theme-toggle-floating svg{transition:transform var(--transition-fast)}.theme-toggle-floating:hover svg{transform:scale(1.1)}@media (max-width:768px){.theme-toggle-floating{bottom:1.5rem;height:44px;right:1.5rem;width:44px}.theme-toggle-floating svg{height:18px;width:18px}}.footer{background-color:var(--header-bg);border-top:1px solid var(--border-color);height:var(--header-height);transition:background-color var(--transition-normal),border-color var(--transition-normal)}.footer-content{align-items:center;display:flex;height:100%;justify-content:space-between;margin:0 auto;max-width:1200px;padding:0 calc(min(var(--gutter-desktop), var(--gutter-max))/3)}.footer-center,.footer-left,.footer-right{flex:1 1}.footer-center{display:flex;gap:2rem;justify-content:center}.copyright{font-size:.9rem}.copyright,.footer-link{color:var(--text-muted);font-weight:var(--font-weight-normal)}.footer-link{background:none;border:none;cursor:pointer;font-family:inherit;font-size:.95rem;text-decoration:underline;transition:opacity var(--transition-fast)}.footer-link:hover{opacity:.7}.email-link{position:relative}.email-link:hover:after{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:4px;bottom:100%;box-shadow:0 2px 8px var(--shadow);color:var(--text-primary);content:"aodhphelan@gmail.com";font-size:.85rem;left:50%;margin-bottom:.5rem;padding:.5rem 1rem;position:absolute;transform:translateX(-50%);white-space:nowrap;z-index:100}@media (max-width:768px){.footer-content{flex-direction:column;gap:1rem;padding:0 var(--gutter-mobile);text-align:center}.footer-center,.footer-left,.footer-right{flex:none}.footer-center{gap:1.5rem}}@media (min-width:1400px){.footer-content{padding:0 calc(var(--gutter-max)/3)}}@media (max-width:480px){.footer-center{flex-direction:column;gap:1rem}}.homepage{flex-direction:column;margin-top:var(--header-height);min-height:100vh}.homepage,.homepage-content{display:flex;position:relative}.homepage-content{align-items:center;flex:1 1;justify-content:center;padding:2rem 0;z-index:1}.skyline-container{bottom:var(--header-height);height:300px;left:0;margin:0;overflow:hidden;position:absolute;right:0;width:100%;z-index:0}.skyline-image{display:block;height:100%;-webkit-mask-image:linear-gradient(180deg,#0000 0,#000 50%,#000);mask-image:linear-gradient(180deg,#0000 0,#000 50%,#000);object-fit:cover;opacity:.25;width:100%}.welcome-section{margin:0 auto;max-width:800px;padding:0 calc(min(var(--gutter-desktop), var(--gutter-max))/3);text-align:center}.welcome-title{color:var(--text-primary);font-size:4rem;font-weight:var(--font-weight-normal);letter-spacing:-.02em;margin-bottom:2rem}.welcome-text{color:var(--text-secondary);font-size:1.5rem;line-height:1.4;margin-bottom:1.5rem}.fade-in-text{opacity:0;transform:translateY(6px);transition:opacity 1.2s ease-in-out,transform 1.2s ease-in-out}.fade-in-text.visible{opacity:1;transform:translateY(0)}.typewriter-text{color:var(--text-secondary);display:inline-block;font-weight:var(--font-weight-light)}.cursor{animation:blink 1s infinite;color:var(--text-primary)}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:0}}.explore-text{color:var(--text-muted);font-size:1.25rem;font-weight:var(--font-weight-light);margin-top:2rem;opacity:0;transition:opacity 1.2s ease-in-out}.explore-text.fade-in{opacity:1}@media (max-width:768px){.welcome-section{padding:0 var(--gutter-mobile)}.welcome-title{font-size:3rem}.welcome-text{font-size:1.25rem}.explore-text{font-size:1.1rem}}@media (min-width:1400px){.welcome-section{padding:0 var(--gutter-max)}}@media (max-width:480px){.welcome-title{font-size:2.5rem}.welcome-text{font-size:1.1rem}}.project-card{border-bottom:1px solid var(--border-color);color:inherit;display:block;text-decoration:none;transition:all var(--transition-normal);width:100%}.project-card:hover{background-color:var(--bg-secondary)}.project-card-inner{align-items:stretch;display:flex;min-height:400px;overflow:hidden}.project-info{display:flex;flex:1 1;flex-direction:column;justify-content:center;max-width:50%;padding:3rem}.project-header{margin-bottom:1.5rem}.project-title{color:var(--text-primary);font-size:2.5rem;font-weight:var(--font-weight-semibold);line-height:1.2;margin-bottom:.75rem}.project-date{color:var(--text-muted);font-size:.95rem;font-weight:var(--font-weight-normal);letter-spacing:.5px}.project-description{color:var(--text-secondary);font-size:1.25rem;line-height:1.5;margin:0}.project-visual{flex:1 1;min-height:400px;overflow:hidden;position:relative}.project-hero{background-position:50%;background-repeat:no-repeat;background-size:cover;height:100%;left:0;position:absolute;top:0;transition:transform var(--transition-slow);width:100%;z-index:1}.project-hero.shifted{transform:translateX(-85%)}.project-preview{align-items:center;background-color:var(--bg-primary);display:flex;height:100%;opacity:0;padding:3rem;position:absolute;right:0;top:0;transform:translateX(100%);transition:all var(--transition-slow);width:85%;z-index:2}.project-preview.visible{opacity:1;transform:translateX(0)}.project-first-paragraph{-webkit-box-orient:vertical;-webkit-line-clamp:8;color:var(--text-secondary);display:-webkit-box;font-size:1.1rem;line-height:1.6;margin:0;max-height:12.8rem;overflow:hidden}@media (max-width:1024px){.project-card-inner{flex-direction:column;min-height:auto}.project-info{max-width:100%;order:1;padding:2rem}.project-visual{min-height:300px;order:2;position:relative}.project-hero,.project-preview{position:relative;transform:none!important}.project-preview{border-left:none;border-top:1px solid var(--border-color);max-height:0;opacity:0;overflow:hidden;padding:0 2rem;transition:all var(--transition-normal);width:100%}.project-card:hover .project-preview{max-height:200px;opacity:1;padding:2rem}.project-title{font-size:2rem}.project-description{font-size:1.1rem}}@media (max-width:768px){.project-info{padding:1.5rem}.project-visual{min-height:250px}.project-title{font-size:1.75rem}.project-description{font-size:1rem}.project-card:hover .project-preview{padding:1.5rem}}.projects-page{margin-top:var(--header-height);min-height:calc(100vh - var(--header-height))}.projects-header{border-bottom:1px solid var(--border-color);padding:4rem 0 2rem}.projects-title{color:var(--text-primary);font-size:3rem;font-weight:var(--font-weight-semibold);margin-bottom:1rem;text-align:center}.projects-subtitle{color:var(--text-secondary);font-size:1.25rem;line-height:1.5;margin:0 auto;max-width:600px;text-align:center}@media (max-width:768px){.projects-header{padding:3rem 0 1.5rem}.projects-title{font-size:2.5rem}.projects-subtitle{font-size:1.1rem;padding:0 var(--gutter-mobile)}}.project-detail-page{margin-top:var(--header-height);min-height:calc(100vh - var(--header-height))}.project-hero-section{align-items:center;display:flex;height:100vh;justify-content:center;overflow:hidden;position:relative}.project-detail-title{color:#fff;font-size:4rem;font-weight:var(--font-weight-semibold);left:50%;max-width:90%;position:absolute;text-align:center;text-shadow:0 2px 8px #00000080;top:50%;transform:translate(-50%,-50%);z-index:2}.project-hero-image{background-position:50%;background-repeat:no-repeat;background-size:cover}.project-hero-image,.project-hero-image:after{height:100%;left:0;position:absolute;top:0;width:100%;z-index:1}.project-hero-image:after{background:#0000004d;content:""}.project-content{background-color:var(--bg-primary);padding:4rem 0}.content-section{margin-bottom:3rem}.content-paragraph{color:var(--text-secondary);font-size:1.25rem;line-height:1.7;margin-bottom:2rem;max-width:800px}.paragraph-with-inline-image{align-items:flex-start;display:flex;gap:3rem;margin-bottom:3rem}.paragraph-text{flex:2 1}.paragraph-text p{color:var(--text-secondary);font-size:1.25rem;line-height:1.7;margin:0}.inline-image{flex:1 1;min-width:300px}.inline-image img{border-radius:8px;box-shadow:0 4px 12px var(--shadow);height:auto;width:100%}.block-image{margin:2rem 0 3rem;text-align:center}.block-image img{border-radius:8px;box-shadow:0 4px 12px var(--shadow);height:auto;max-width:100%}.block-image-inline-right{clear:right;float:right;margin:0 0 1rem 1rem;max-width:300px;text-align:center}.block-image-inline-right img{border-radius:8px;box-shadow:0 4px 12px var(--shadow);height:auto;width:100%}.image-caption{color:var(--text-secondary);font-size:.9rem;font-style:italic;margin-top:1rem;text-align:center}.project-description .content-paragraph.lead{border-bottom:1px solid var(--border-color);color:var(--text-primary);font-size:1.5rem;font-weight:var(--font-weight-medium);line-height:1.6;margin-bottom:3rem;padding-bottom:2rem}.project-not-found{padding:4rem 0;text-align:center}.project-not-found h1{color:var(--text-primary);font-size:3rem;margin-bottom:1rem}.project-not-found p{color:var(--text-secondary);font-size:1.25rem}@media (max-width:1024px){.paragraph-with-inline-image{flex-direction:column;gap:2rem}.inline-image{min-width:auto}}@media (max-width:768px){.project-detail-title{font-size:2.5rem;padding:0 1rem}.project-content{padding:3rem 0}.content-paragraph,.paragraph-text p{font-size:1.1rem}.content-section{margin-bottom:2rem}.paragraph-with-inline-image{gap:1.5rem}}@media (max-width:480px){.project-detail-title{font-size:2rem}.content-paragraph,.paragraph-text p{font-size:1rem;line-height:1.6}}.blog-card{border-bottom:1px solid var(--border-color);color:inherit;display:block;text-decoration:none;transition:all var(--transition-normal);width:100%}.blog-card:hover{background-color:var(--bg-secondary)}.blog-card-inner{margin:0 auto;max-width:1200px;padding:3rem calc(min(var(--gutter-desktop), var(--gutter-max))/3)}.blog-header{margin-bottom:1.5rem}.blog-title{font-size:2.5rem;line-height:1.2;margin-bottom:.75rem}.blog-date{color:var(--text-muted);font-size:.95rem;font-weight:var(--font-weight-normal);letter-spacing:.5px}.blog-description{color:var(--text-secondary);font-size:1.25rem;line-height:1.5;margin:0;max-width:800px}@media (max-width:768px){.blog-card-inner{padding:2rem 1.5rem}.blog-title{font-size:2rem}.blog-description{font-size:1.1rem}}@media (max-width:480px){.blog-card-inner{padding:1.5rem 1rem}.blog-title{font-size:1.75rem}.blog-description{font-size:1rem}}.blog-page{margin-top:var(--header-height);min-height:calc(100vh - var(--header-height))}.blog-header{border-bottom:1px solid var(--border-color);padding:1.6rem 0 .8rem 20px}.blog-title{color:var(--text-primary);font-size:1.8rem;font-weight:var(--font-weight-semibold);margin-bottom:.4rem;text-align:left}.blog-subtitle{color:var(--text-secondary);font-size:1rem;line-height:1.4;margin:0 0 .6rem;max-width:800px;text-align:left}.blog-count{color:var(--text-muted);font-size:.95rem;font-weight:var(--font-weight-normal);letter-spacing:.5px;text-align:left}.blog-list{display:flex;flex-direction:column;gap:1rem}@media (max-width:768px){.blog-header{padding:1.2rem 0 .6rem}.blog-title{font-size:1.6rem}.blog-subtitle{font-size:.95rem;padding:0 var(--gutter-mobile)}}.blog-detail-page{margin-top:var(--header-height);min-height:calc(100vh - var(--header-height))}.blog-detail-header{border-bottom:1px solid var(--border-color);padding:4rem 0 3rem;text-align:center}.blog-detail-title{color:var(--text-primary);font-size:3.5rem;font-weight:var(--font-weight-semibold);line-height:1.1;margin-bottom:1.5rem;margin-left:auto;margin-right:auto;max-width:900px}.blog-detail-date{color:var(--text-muted);font-size:1rem;font-weight:var(--font-weight-normal);letter-spacing:.5px}.blog-detail-description{color:var(--text-secondary);font-size:1.25rem;line-height:1.6;margin-left:auto;margin-right:auto;margin-top:1.5rem;max-width:800px}.blog-image-section{margin:2rem 0;text-align:center}.blog-image{border-radius:8px;box-shadow:0 4px 12px var(--shadow);height:auto;max-width:100%}.blog-image-caption{color:var(--text-secondary);font-size:.9rem;font-style:italic;margin-top:1rem}.blog-image-section-inline-right{clear:right;float:right;margin:0 0 1rem 1rem;max-width:300px}.blog-image-section-inline-right .blog-image{height:auto;width:100%}.blog-detail-content{padding:4rem 0}.blog-article{margin:0 auto;max-width:700px}.blog-paragraph{color:var(--text-secondary);font-size:1.3rem;font-weight:var(--font-weight-normal);line-height:1.7;margin-bottom:2rem}.blog-paragraph:last-child{margin-bottom:0}.blog-not-found{padding:4rem 0;text-align:center}.blog-not-found h1{color:var(--text-primary);font-size:3rem;margin-bottom:1rem}.blog-not-found p{color:var(--text-secondary);font-size:1.25rem}@media (max-width:768px){.blog-detail-header{padding:3rem 0 2rem}.blog-detail-title{font-size:2.5rem}.blog-detail-content{padding:3rem 0}.blog-paragraph{font-size:1.15rem;line-height:1.6}}@media (max-width:480px){.blog-detail-title{font-size:2rem}.blog-paragraph{font-size:1.1rem}}.art-page{background-color:var(--bg-primary);color:var(--text-primary);margin-top:var(--header-height);min-height:calc(100vh - var(--header-height))}.art-carousel{display:flex;flex-direction:column;height:calc(100vh - var(--header-height));margin:0 auto;max-width:1400px;padding:2rem}.carousel-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:2rem}.art-title{color:var(--text-primary);font-size:2.5rem;font-weight:var(--font-weight-semibold);margin:0}.carousel-counter{color:var(--text-secondary);font-size:1.1rem;font-weight:var(--font-weight-medium)}.carousel-container{flex:1 1;gap:3rem;position:relative}.carousel-container,.carousel-nav{align-items:center;display:flex;justify-content:center}.carousel-nav{background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:50%;color:var(--text-primary);cursor:pointer;height:56px;transition:all .2s ease;width:56px;z-index:2}.carousel-nav:hover:not(:disabled){background:var(--accent-color);color:#fff;transform:scale(1.1)}.carousel-nav:disabled{cursor:not-allowed;opacity:.3}.carousel-main{align-items:center;display:flex;flex:1 1;flex-direction:column;gap:2rem;max-width:900px}.art-frame{background:linear-gradient(145deg,#8a8a8a,#6d6d6d);border-radius:4px;box-shadow:0 8px 32px #0000004d,inset 0 2px 4px #ffffff1a,inset 0 -2px 4px #0003;max-height:70vh;max-width:100%;padding:10px;position:relative}.art-frame:before{background:linear-gradient(145deg,#9a9a9a,#7a7a7a);border-radius:2px;bottom:2px;content:"";left:2px;position:absolute;right:2px;top:2px;z-index:1}.art-image{background:#fff;border-radius:2px;box-shadow:0 2px 8px #00000026;display:block;height:auto;max-height:60vh;max-width:100%;object-fit:contain;position:relative;width:auto;z-index:2}.art-details{max-width:600px;text-align:center}.art-piece-title{color:var(--text-primary);font-size:2rem;font-weight:var(--font-weight-semibold);margin:0 0 1rem}.art-description{color:var(--text-secondary);font-size:1.1rem;line-height:1.6;margin:0 0 1rem}.art-date{color:var(--text-muted);font-size:.95rem;font-style:italic}.carousel-dots{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center;margin-top:2rem}.carousel-dot{background:#0000;border:2px solid var(--border-color);border-radius:50%;cursor:pointer;height:12px;transition:all .2s ease;width:12px}.carousel-dot:hover{border-color:var(--accent-color);transform:scale(1.2)}.carousel-dot.active{background:var(--accent-color);border-color:var(--accent-color)}.art-empty,.art-error,.art-loading{align-items:center;display:flex;flex-direction:column;height:60vh;justify-content:center;padding:2rem;text-align:center}.art-empty h2,.art-error h2,.art-loading h2{color:var(--text-primary);font-size:2rem;margin-bottom:1rem}.art-empty p,.art-error p,.art-loading p{color:var(--text-secondary);font-size:1.1rem;max-width:500px}@media (max-width:1024px){.carousel-container{gap:2rem}.carousel-nav{height:48px;width:48px}.art-frame{max-height:60vh}.art-image{max-height:50vh}}@media (max-width:768px){.art-carousel{padding:1rem}.carousel-header{flex-direction:column;gap:1rem;text-align:center}.art-title{font-size:2rem}.carousel-container{flex-direction:column;gap:1.5rem}.carousel-nav{position:absolute;top:50%;transform:translateY(-50%)}.carousel-nav-prev{left:1rem}.carousel-nav-next{right:1rem}.art-frame{margin:0 3rem;max-height:50vh}.art-image{max-height:40vh}.art-piece-title{font-size:1.5rem}.art-description{font-size:1rem}}@media (max-width:480px){.art-carousel{padding:.5rem}.art-title{font-size:1.5rem}.carousel-nav{height:40px;width:40px}.art-frame{margin:0 2.5rem;max-height:45vh;padding:8px}.art-image{max-height:35vh}.art-piece-title{font-size:1.25rem}.carousel-dots{gap:.5rem}.carousel-dot{height:10px;width:10px}}.quotes-page{background-color:var(--bg-primary);color:var(--text-primary);margin-top:var(--header-height);min-height:calc(100vh - var(--header-height));padding:2rem 1rem}.quotes-container{margin:0 auto;max-width:900px}.quotes-title{color:var(--text-primary);font-size:3rem;font-weight:var(--font-weight-bold);margin-bottom:3rem;text-align:center}.error,.loading{color:var(--text-secondary);font-size:1.2rem;padding:3rem 2rem;text-align:center}.error{color:#dc2626}.empty-state{font-size:1.1rem;padding:4rem 2rem}.quotes-carousel{grid-gap:1rem;align-items:center;display:grid;gap:1rem;grid-template-columns:48px 1fr 48px}.quote-viewport{align-items:center;display:flex;justify-content:center;min-height:60vh;overflow:hidden;position:relative}.quote-slide{height:100%;width:100%}.quote-text{color:var(--text-muted);font-size:2.4rem;font-style:italic;font-weight:var(--font-weight-light);line-height:1.5;margin:0 0 .75rem;text-align:center}.quote-item:before{background:var(--accent-color);content:"";height:100%;left:0;position:absolute;top:0;transition:width .3s ease;width:4px}.quote-item:hover{border-color:var(--accent-color);box-shadow:0 8px 24px var(--shadow);transform:translateY(-2px)}.quote-item:hover:before{width:8px}.quote-attribution{color:var(--text-muted);font-size:1rem;font-weight:var(--font-weight-light);margin-top:.75rem;text-align:center}.quote-author{color:var(--text-primary);font-weight:var(--font-weight-semibold)}.quote-separator{color:var(--text-tertiary)}.quote-date{color:var(--text-secondary);font-style:normal}@media (max-width:768px){.quotes-page{padding:1.5rem .75rem}.quotes-title{font-size:2.5rem;margin-bottom:2rem}.quotes-list{gap:2rem}.quote-item{padding:2rem 1.5rem}.quote-text{font-size:1.2rem;line-height:1.6}.quote-text:before{font-size:1.5rem;left:-.3rem;top:-.1rem}.quote-text:after{font-size:1.5rem}}@media (max-width:480px){.quotes-title{font-size:2rem}.quote-item{padding:1.5rem 1rem}.quote-text{font-size:1.1rem;margin-bottom:1rem}.quote-attribution{font-size:.9rem}}@keyframes fadeInCenter{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.fade-in-attr,.fade-in-quote{animation:fadeInCenter 1.5s ease-in}.fade-in-attr{animation-delay:.2s}.carousel-arrow{align-items:center;background:#0000;border:1px solid var(--border-color);border-radius:50%;color:var(--text-secondary);cursor:pointer;display:flex;font-size:1.5rem;height:42px;justify-content:center;transition:all .2s ease;width:42px}.carousel-arrow:hover{border-color:var(--accent-color);box-shadow:0 4px 12px var(--shadow);color:var(--text-primary)}.science-page{background-color:var(--bg-primary);color:var(--text-primary);margin-top:var(--header-height);min-height:calc(100vh - var(--header-height))}.science-container{margin:0 auto;max-width:1200px;padding:3rem 2rem}.science-header{margin-bottom:4rem;text-align:center}.science-title{color:var(--text-primary);font-size:3rem;font-weight:var(--font-weight-semibold);margin:0 0 1rem}.science-subtitle{color:var(--text-secondary);font-size:1.25rem;margin:0 auto;max-width:600px}.discoveries-grid{grid-gap:2.5rem;align-items:start;display:grid;gap:2.5rem;grid-template-columns:repeat(auto-fit,minmax(350px,1fr))}.discovery-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius);box-shadow:0 4px 12px var(--shadow);overflow:hidden;transition:all .3s ease}.discovery-card:hover{border-color:var(--accent-color);box-shadow:0 8px 24px var(--shadow);transform:translateY(-4px)}.discovery-image{background:var(--bg-tertiary);height:200px;overflow:hidden;position:relative;width:100%}.discovery-image img{height:100%;object-fit:cover;transition:transform .3s ease;width:100%}.discovery-card:hover .discovery-image img{transform:scale(1.05)}.discovery-content{padding:1.5rem}.discovery-title{color:var(--text-primary);font-size:1.5rem;font-weight:var(--font-weight-semibold);line-height:1.3;margin:0 0 1rem}.discovery-creator{display:flex;flex-wrap:wrap;font-size:.95rem;gap:.5rem;margin-bottom:1rem}.creator-label{color:var(--text-secondary);font-weight:var(--font-weight-medium)}.creator-name{color:var(--accent-color);font-weight:var(--font-weight-semibold)}.discovery-description{color:var(--text-secondary);font-size:1rem;line-height:1.6;margin:0 0 1.5rem}.discovery-meta{border-top:1px solid var(--border-color);display:flex;flex-direction:column;gap:.75rem;padding-top:1rem}.discovery-date{color:var(--text-muted);font-size:.9rem;font-style:italic}.discovery-blog-link{align-items:center;color:var(--accent-color);display:inline-flex;font-size:.95rem;font-weight:var(--font-weight-medium);gap:.5rem;text-decoration:none;transition:all .2s ease}.discovery-blog-link:hover{color:var(--accent-hover);transform:translateX(2px)}.discovery-blog-link svg{transition:transform .2s ease}.discovery-blog-link:hover svg{transform:scale(1.1)}.science-empty,.science-error,.science-loading{align-items:center;display:flex;flex-direction:column;height:60vh;justify-content:center;padding:2rem;text-align:center}.science-empty h2,.science-error h2,.science-loading h2{color:var(--text-primary);font-size:2rem;margin-bottom:1rem}.science-empty p,.science-error p,.science-loading p{color:var(--text-secondary);font-size:1.1rem;max-width:500px}@media (max-width:768px){.science-container{padding:2rem 1rem}.science-header{margin-bottom:3rem}.science-title{font-size:2.5rem}.science-subtitle{font-size:1.1rem}.discoveries-grid{gap:2rem;grid-template-columns:1fr}.discovery-image{height:180px}.discovery-content{padding:1.25rem}.discovery-title{font-size:1.3rem}}@media (max-width:480px){.science-container{padding:1.5rem .75rem}.science-title{font-size:2rem}.science-subtitle{font-size:1rem}.discoveries-grid{gap:1.5rem}.discovery-image{height:160px}.discovery-content{padding:1rem}.discovery-title{font-size:1.2rem}.discovery-description{font-size:.95rem}.discovery-meta{gap:.5rem}}.books-page{padding:2rem 0}.books-title{margin-bottom:1rem}.shelves-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.shelf-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:1rem;position:relative}.shelf-header h2{margin:0 0 .75rem}.book-list{list-style:disc inside;margin:0;padding:0}.book-item{padding:.25rem 0;position:relative}.book-popover{border-radius:6px;box-shadow:0 6px 16px #0000004d;color:#fff;left:0;min-width:220px;padding:.75rem;position:absolute;top:100%;transform:translateY(4px);z-index:5}.popover-title{font-weight:600}.popover-author{margin-bottom:.5rem;opacity:.9}.popover-description{font-size:.9rem}.great-things-page{background-color:var(--bg-primary);color:var(--text-primary);margin-top:var(--header-height);min-height:calc(100vh - var(--header-height));padding:0}.gt-grid{grid-gap:0;display:grid;gap:0;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;height:100vh;max-height:100vh;overflow:hidden}.gt-section{border:1px solid var(--border-color);color:inherit;cursor:pointer;display:flex;flex-direction:column;overflow:hidden;position:relative;text-decoration:none;transition:all .3s ease}.gt-section:hover{border-color:var(--accent-color);box-shadow:0 8px 32px #0000004d;z-index:10}.gt-section-content{display:flex;flex:1 1;flex-direction:column;height:100%;padding:2rem;position:relative;width:100%}.gt-title{color:var(--text-primary);font-size:3rem;font-weight:var(--font-weight-bold);left:2rem;margin:0;position:absolute;text-decoration:none;top:2rem;transition:all .3s ease;z-index:2}.gt-section:hover .gt-title{color:var(--accent-color);transform:scale(1.1)}.gt-preview{align-items:center;display:flex;flex:1 1;justify-content:center;min-height:0;padding:5rem 2rem 2rem}.gt-mirror{background-color:var(--bg-primary);height:100%;overflow:auto;width:100%}.gt-mirror .books-page,.gt-mirror .science-page{height:100%;margin-top:0;min-height:auto;overflow:auto}.gt-mirror .books-page .container,.gt-mirror .science-container{max-width:100%;padding:1rem}.gt-mirror br{display:none}.gt-mirror>div{width:100%}.gt-empty,.gt-loading{color:var(--text-secondary);font-size:1.5rem;font-style:italic;text-align:center}.art-mini-carousel{align-items:center;display:flex;flex-wrap:wrap;gap:1.5rem;justify-content:center}.art-mini-frame{background:linear-gradient(145deg,#8a8a8a,#6d6d6d);border-radius:4px;box-shadow:0 4px 16px #0000004d;padding:6px;transition:transform .3s ease}.art-mini-frame:hover{transform:scale(1.05)}.art-mini-frame img{background:#fff;border-radius:2px;height:110px;object-fit:cover;width:150px}.quotes-mini-list{display:flex;flex-direction:column;gap:1.5rem;width:100%}.quote-mini{background:var(--bg-secondary);border-left:3px solid var(--accent-color);border-radius:var(--border-radius);margin:0;padding:1.5rem;text-align:center;transition:transform .3s ease}.quote-mini:hover{transform:translateX(8px)}.quote-mini p{color:var(--text-primary);font-size:1.2rem;font-style:italic;line-height:1.5;margin:0 0 .75rem}.quote-mini cite{color:var(--text-secondary);font-size:1rem;font-style:normal;font-weight:var(--font-weight-medium)}.science-mini-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));width:100%}.discovery-mini{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius);cursor:pointer;overflow:hidden;transition:all .3s ease}.discovery-mini:hover{border-color:var(--accent-color);box-shadow:0 6px 18px var(--shadow);transform:translateY(-2px)}.discovery-mini img{height:80px;object-fit:cover;width:100%}.discovery-mini-content{padding:.75rem}.discovery-mini-content h4{color:var(--text-primary);font-size:.95rem;font-weight:var(--font-weight-semibold);line-height:1.3;margin:0 0 .25rem}.discovery-mini-content span{color:var(--text-secondary);font-size:.8rem}.books-mini-shelf{align-items:flex-end;background:linear-gradient(145deg,#8b4513,#654321);border-radius:var(--border-radius);box-shadow:0 4px 16px #0000004d;flex-wrap:wrap;gap:1px;padding:1.5rem;width:100%}.book-mini-spine,.books-mini-shelf{display:flex;justify-content:center}.book-mini-spine{align-items:center;border:1px solid #0003;border-radius:2px;box-shadow:inset 0 1px 2px #fff3,0 1px 3px #0000004d;cursor:pointer;height:140px;min-width:22px;padding:6px 3px;text-orientation:mixed;transition:transform .2s ease;writing-mode:vertical-rl}.book-mini-spine:hover{transform:translateY(-3px)}.book-mini-title{color:#fff;font-size:.7rem;font-weight:var(--font-weight-semibold);line-height:1.1;text-align:center;text-shadow:0 1px 2px #000000b3;word-break:break-word}.gt-art{background:linear-gradient(135deg,var(--bg-primary) 0,var(--bg-secondary) 100%)}.gt-quotes{background:linear-gradient(135deg,var(--bg-secondary) 0,var(--bg-primary) 100%)}.gt-science{background:linear-gradient(135deg,var(--bg-primary) 0,var(--bg-tertiary) 100%)}.gt-books{background:linear-gradient(135deg,var(--bg-tertiary) 0,var(--bg-primary) 100%)}@media (max-width:900px){.gt-grid{grid-template-columns:1fr;grid-template-rows:repeat(4,1fr);height:250vh;max-height:250vh}.gt-section{min-height:auto}.gt-title{font-size:2.5rem}.gt-preview{padding:4rem 1.5rem 1.5rem}.art-mini-frame img{height:90px;width:120px}.science-mini-grid{gap:1rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.quotes-mini-list{gap:1rem}.quote-mini{padding:1rem}.quote-mini p{font-size:1.1rem}}@media (max-width:768px){.gt-grid{height:250vh;max-height:250vh}.gt-section-content{padding:1.5rem}.gt-title{font-size:2rem;left:1.5rem;top:1.5rem}.gt-preview{padding:3.5rem 1rem 1rem}.art-mini-carousel{flex-direction:column;gap:1rem}.art-mini-frame img{height:120px;width:160px}.science-mini-grid{gap:1rem;grid-template-columns:1fr}.books-mini-shelf{gap:1px;padding:1rem}.book-mini-spine{height:120px;min-width:20px}}@media (max-width:480px){.gt-section-content{padding:1rem}.gt-title{font-size:1.5rem;left:1rem;top:1rem}.gt-preview{padding:3rem .75rem .75rem}.art-mini-frame img{height:105px;width:140px}.quote-mini{padding:.75rem}.quote-mini p{font-size:1rem}.books-mini-shelf{padding:.75rem}.book-mini-spine{height:100px;min-width:18px}.book-mini-title{font-size:.65rem}}.admin-login-page{align-items:center;display:flex;margin-top:var(--header-height);min-height:calc(100vh - var(--header-height))}.admin-login-card{background-color:var(--bg-primary);border:1px solid var(--border-color);box-shadow:0 6px 16px var(--shadow);margin:0 auto;max-width:420px;padding:2rem;width:100%}.admin-login-title{font-size:2rem;margin-bottom:1.5rem;text-align:center}.admin-login-form{display:flex;flex-direction:column;gap:1rem}.admin-login-form label{color:var(--text-muted);display:flex;flex-direction:column;font-size:.95rem;gap:.5rem}.admin-login-form input{background:#0000;border:1px solid var(--border-color);color:var(--text-primary);outline:none;padding:.75rem .9rem}.admin-login-error{background:#c0392b14;border:1px solid #c0392b40;color:#c0392b;font-size:.9rem;padding:.75rem 1rem}.image-upload{margin-bottom:1rem}.upload-area{align-items:center;border:2px dashed var(--border-color);border-radius:var(--border-radius);cursor:pointer;display:flex;justify-content:center;min-height:120px;padding:2rem;position:relative;text-align:center;transition:all .2s ease}.upload-area.drag-over,.upload-area:hover{background:var(--bg-secondary);border-color:var(--text-primary)}.upload-area.drag-over{transform:scale(1.02)}.upload-area.uploading{cursor:not-allowed;opacity:.7}.upload-area.disabled{cursor:not-allowed;opacity:.5}.current-image{margin:0 auto;max-width:200px;position:relative;width:100%}.current-image img{border-radius:var(--border-radius);display:block;height:auto;width:100%}.upload-overlay{align-items:center;background:#000000b3;border-radius:var(--border-radius);bottom:0;display:flex;justify-content:center;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .2s ease}.current-image:hover .upload-overlay{opacity:1}.upload-prompt{color:#fff;font-size:.9rem;text-align:center}.upload-prompt span:first-child{display:block;font-size:1.5rem;margin-bottom:.5rem}.upload-placeholder{align-items:center;display:flex;flex-direction:column;gap:.5rem;justify-content:center;width:100%}.upload-icon{font-size:2rem;margin-bottom:.5rem;opacity:.6}.upload-text{font-size:.9rem}.upload-text,.upload-text strong{color:var(--text-primary)}.upload-hint{color:var(--text-secondary);font-size:.8rem}.upload-progress{align-items:center;color:var(--text-primary);display:flex;flex-direction:column;gap:.5rem}.spinner{animation:spin 1s linear infinite;border-top:2px solid var(--border-color);border:2px solid var(--border-color);border-radius:50%;border-top-color:var(--text-primary);height:20px;width:20px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.upload-error{background:#fee2e2;border:1px solid #fecaca;border-radius:var(--border-radius);color:#dc2626;font-size:.8rem;margin-top:.5rem;padding:.5rem}@media (prefers-color-scheme:dark){.upload-error{background:#dc26261a;border-color:#dc262633}}.content-editor-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;overflow-y:auto;padding:2rem;position:fixed;right:0;top:0;z-index:1000}.content-editor{background:var(--bg-primary);border-radius:var(--border-radius);box-shadow:0 20px 40px #0003;max-height:90vh;max-width:800px;overflow-y:auto;width:100%}.editor-header h2{font-size:1.5rem}.form-section{margin-bottom:2rem}.form-section h3{border-bottom:1px solid var(--border-color);color:var(--text-primary);font-size:1.2rem;margin:0 0 1.5rem;padding-bottom:.5rem}.form-group input,.form-group textarea{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--border-radius);color:var(--text-primary);font-size:.9rem;padding:.75rem;transition:border-color .2s ease;width:100%}.form-group input:focus,.form-group textarea:focus{border-color:var(--text-primary);outline:none}.checkbox-label{align-items:center;cursor:pointer;display:flex!important;gap:.5rem;margin-top:1.8rem}.checkbox-label input[type=checkbox]{margin:0;width:auto}.content-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.add-block-btn{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius);color:var(--text-primary);cursor:pointer;font-size:.8rem;padding:.5rem 1rem;transition:all .2s ease}.add-block-btn:hover{background:var(--bg-tertiary)}.content-blocks{display:flex;flex-direction:column;gap:1rem}.content-block{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:1rem}.block-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.block-type{color:var(--text-primary);font-size:.9rem;font-weight:var(--font-weight-medium)}.block-controls{display:flex;gap:.25rem}.move-btn,.remove-btn{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius);color:var(--text-primary);cursor:pointer;font-size:.8rem;padding:.25rem .5rem;transition:all .2s ease}.move-btn:hover{background:var(--bg-primary)}.remove-btn{background:#fee2e2;border-color:#fecaca;color:#dc2626}.remove-btn:hover{background:#fecaca}.move-btn:disabled{cursor:not-allowed;opacity:.5}.empty-content{background:var(--bg-secondary);border:1px dashed var(--border-color);border-radius:var(--border-radius);color:var(--text-secondary);padding:2rem;text-align:center}@media (max-width:768px){.content-editor-overlay{padding:1rem}.content-editor{max-height:95vh}.editor-header{padding:1rem}.editor-header h2{font-size:1.2rem}.editor-form{padding:1rem}.form-row{grid-template-columns:1fr}.content-header{align-items:stretch;flex-direction:column;gap:1rem}.content-actions{justify-content:center}.form-actions{flex-direction:column-reverse}.block-header{align-items:flex-start;flex-direction:column;gap:.5rem}.block-controls{align-self:flex-end}}@media (max-width:480px){.content-editor-overlay{padding:.5rem}.editor-form,.editor-header{padding:.75rem}.form-section h3{font-size:1rem}}.collection-editor-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;overflow-y:auto;padding:2rem;position:fixed;right:0;top:0;z-index:1000}.collection-editor{background:var(--bg-primary);border-radius:var(--border-radius);box-shadow:0 20px 40px #0003;max-height:90vh;max-width:600px;overflow-y:auto;width:100%}.editor-header{align-items:center;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);border-radius:var(--border-radius) var(--border-radius) 0 0;display:flex;justify-content:space-between;padding:1.5rem 2rem}.editor-header h2{color:var(--text-primary);font-size:1.3rem;margin:0}.close-btn{background:none;border:none;border-radius:var(--border-radius);color:var(--text-secondary);cursor:pointer;font-size:1.5rem;padding:.5rem;transition:all .2s ease}.close-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.editor-form{padding:2rem}.form-group{margin-bottom:1.5rem}.form-group label{color:var(--text-primary);display:block;font-size:.9rem;font-weight:var(--font-weight-medium);margin-bottom:.5rem}.form-group input,.form-group select,.form-group textarea{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--border-radius);color:var(--text-primary);font-size:.9rem;padding:.75rem;transition:border-color .2s ease;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--text-primary);outline:none}.form-group input.error,.form-group textarea.error{border-color:#dc2626}.form-group input[type=color]{cursor:pointer;height:40px;padding:.25rem}.form-group input[type=number]{max-width:120px}.form-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}.error-text{color:#dc2626;display:block;font-size:.8rem;margin-top:.25rem}.submit-error{background:#fee2e2;border:1px solid #fecaca;border-radius:var(--border-radius);color:#dc2626;margin-bottom:1rem;padding:1rem}.form-actions{border-top:1px solid var(--border-color);display:flex;gap:1rem;justify-content:flex-end;padding-top:1rem}.cancel-btn,.save-btn{border-radius:var(--border-radius);cursor:pointer;font-weight:var(--font-weight-medium);padding:.75rem 1.5rem;transition:all .2s ease}.cancel-btn{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-primary)}.cancel-btn:hover{background:var(--bg-tertiary)}.save-btn{background:var(--text-primary);border:none;color:var(--bg-primary)}.save-btn:hover{opacity:.8}.cancel-btn:disabled,.save-btn:disabled{cursor:not-allowed;opacity:.5}@media (max-width:768px){.collection-editor-overlay{padding:1rem}.collection-editor{max-height:95vh}.editor-header{padding:1rem}.editor-header h2{font-size:1.1rem}.editor-form{padding:1rem}.form-row{grid-template-columns:1fr}.form-actions{flex-direction:column-reverse}}@media (max-width:480px){.collection-editor-overlay{padding:.5rem}.editor-form,.editor-header{padding:.75rem}}.admin-dashboard-page{margin-top:var(--header-height);min-height:calc(100vh - var(--header-height))}.admin-header{background:var(--bg-primary);border-bottom:1px solid var(--border-color);padding:2rem 0}.admin-header-content{align-items:center;display:flex;justify-content:space-between}.admin-dashboard-title{color:var(--text-primary);font-size:2rem;margin:0}.logout-btn{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius);color:var(--text-primary);cursor:pointer;padding:.5rem 1rem;transition:all .2s ease}.logout-btn:hover{background:var(--bg-tertiary)}.admin-nav{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);padding:0}.admin-tabs{display:flex;gap:0;overflow-x:auto}.admin-tab{background:none;border:none;border-bottom:2px solid #0000;color:var(--text-secondary);cursor:pointer;font-size:.9rem;font-weight:var(--font-weight-medium);padding:1rem 1.5rem;transition:all .2s ease;white-space:nowrap}.admin-tab:hover{background:var(--bg-tertiary);color:var(--text-primary)}.admin-tab.active{background:var(--bg-primary);border-bottom-color:var(--text-primary);color:var(--text-primary)}.admin-content{padding:2rem 0}.loading{color:var(--text-secondary);padding:2rem;text-align:center}.overview-section{max-width:1200px}.stats-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:3rem}.stat-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:1.5rem;text-align:center;transition:transform .2s ease}.stat-card:hover{transform:translateY(-2px)}.stat-card h3{color:var(--text-secondary);font-size:.9rem;font-weight:var(--font-weight-medium);margin:0 0 .5rem}.stat-number{color:var(--text-primary);font-size:2.5rem;font-weight:var(--font-weight-bold);margin-bottom:.5rem}.stat-meta{color:var(--text-secondary);font-size:.8rem}.recent-activity h2{color:var(--text-primary);font-size:1.5rem;margin-bottom:1rem}.activity-list{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius);overflow:hidden}.activity-item{align-items:center;border-bottom:1px solid var(--border-color);display:flex;gap:1rem;padding:1rem}.activity-item:last-child{border-bottom:none}.activity-type{background:var(--bg-tertiary);border-radius:12px;font-size:.8rem;min-width:60px;padding:.25rem .75rem;text-align:center}.activity-title,.activity-type{color:var(--text-primary);font-weight:var(--font-weight-medium)}.activity-title{flex:1 1}.activity-status{color:var(--text-secondary);font-size:.8rem}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:2rem}.section-header h2{color:var(--text-primary);font-size:1.5rem;margin:0}.create-btn{background:var(--text-primary);border:none;border-radius:var(--border-radius);color:var(--bg-primary);cursor:pointer;font-weight:var(--font-weight-medium);padding:.75rem 1.5rem;transition:opacity .2s ease}.create-btn:hover{opacity:.8}.content-list{display:flex;flex-direction:column;gap:1rem}.content-item{align-items:flex-start;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius);display:flex;gap:2rem;justify-content:space-between;padding:1.5rem;transition:all .2s ease}.content-item:hover{border-color:var(--text-secondary)}.content-info{flex:1 1}.content-info h3{color:var(--text-primary);font-size:1.1rem;margin:0 0 .5rem}.content-info p{color:var(--text-secondary);line-height:1.5;margin:0 0 1rem}.content-meta{align-items:center;display:flex;gap:1rem}.status{border-radius:12px;font-size:.8rem;font-weight:var(--font-weight-medium);padding:.25rem .75rem}.status.published{background:#d1fae5;color:#047857}.status.draft{background:#fef3c7;color:#92400e}.order{color:var(--text-secondary);font-size:.8rem}.content-actions{display:flex;flex-shrink:0;gap:.5rem}.delete-btn,.edit-btn{border-radius:var(--border-radius);cursor:pointer;font-size:.8rem;font-weight:var(--font-weight-medium);padding:.5rem 1rem;transition:all .2s ease}.edit-btn{background:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-primary)}.edit-btn:hover{background:var(--bg-primary)}.delete-btn{background:#fee2e2;border:1px solid #fecaca;color:#dc2626}.delete-btn:hover{background:#fecaca}.empty-state{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius);color:var(--text-secondary);padding:3rem;text-align:center}@media (max-width:768px){.admin-header-content{flex-direction:column;gap:1rem;text-align:center}.admin-dashboard-title{font-size:1.5rem}.admin-tabs{justify-content:flex-start}.admin-tab{font-size:.8rem;padding:.75rem 1rem}.stats-grid{gap:1rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.stat-card{padding:1rem}.stat-number{font-size:2rem}.section-header{align-items:stretch}.content-item,.section-header{flex-direction:column;gap:1rem}.content-actions{justify-content:flex-end}.activity-item{align-items:flex-start;flex-direction:column;gap:.5rem}.activity-type{align-self:flex-start}}.delete-modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.delete-modal{background:var(--bg-primary);border-radius:var(--border-radius);box-shadow:0 20px 40px #0003;max-width:400px;padding:2rem;width:90%}.delete-modal h3{color:var(--text-primary);font-size:1.2rem;margin:0 0 1rem}.delete-modal p{color:var(--text-secondary);line-height:1.5;margin:0 0 2rem}.delete-modal-actions{display:flex;gap:1rem;justify-content:flex-end}.delete-confirm-btn{background:#dc2626;border:none;border-radius:var(--border-radius);color:#fff;cursor:pointer;font-weight:var(--font-weight-medium);padding:.75rem 1.5rem;transition:background-color .2s ease}.delete-confirm-btn:hover{background:#b91c1c}.blog-link,.scale{color:var(--text-secondary);font-size:.8rem}.blog-link{font-style:italic}.book-actions{display:flex;gap:.5rem}.create-btn.secondary{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-primary)}.create-btn.secondary:hover{background:var(--bg-tertiary)}.shelves-list{display:flex;flex-direction:column;gap:2rem}.shelf-item{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:1.5rem}.shelf-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;margin-bottom:1rem;padding-bottom:1rem}.shelf-header h3{color:var(--text-primary);font-size:1.2rem;margin:0}.shelf-actions{display:flex;gap:.5rem}.books-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.book-item{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:1rem;text-align:center}.book-spine{align-items:center;border-radius:2px;box-shadow:0 2px 4px #0000001a;display:flex;justify-content:center;margin:0 auto 1rem;min-height:40px;position:relative;width:40px}.book-title{color:#fff;font-size:.7rem;font-weight:var(--font-weight-medium);padding:.25rem;text-orientation:mixed;text-shadow:1px 1px 2px #00000080;writing-mode:vertical-rl}.book-info{align-items:center;display:flex;flex-direction:column;gap:.25rem}.book-info strong{color:var(--text-primary);font-size:.9rem;text-align:center}.book-info span{color:var(--text-secondary);font-size:.8rem}.book-actions{margin-top:.5rem}.delete-btn.small,.edit-btn.small{font-size:.7rem;padding:.25rem .5rem}.empty-shelf{color:var(--text-secondary);font-style:italic;padding:2rem;text-align:center}@media (max-width:768px){.shelf-header{align-items:stretch;flex-direction:column;gap:1rem}.shelf-actions{justify-content:center}.books-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.book-actions{flex-direction:column}}.App{display:flex;flex-direction:column;min-height:100vh}.main-content{display:flex;flex:1 1;flex-direction:column}:root{--bg-primary:#fefdfb;--bg-secondary:#fefdfb;--text-primary:#2c2c2c;--text-secondary:#6b6b6b;--text-muted:#999;--border-color:#e5e5e5;--accent-color:#333;--header-bg:#fefdfb;--shadow:#0000001a;--font-family:"Work Sans",-apple-system,BlinkMacSystemFont,"Segoe UI","Roboto",sans-serif;--font-weight-light:300;--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--gutter-desktop:50px;--gutter-mobile:20px;--gutter-max:60px;--header-height:80px;--transition-fast:0.15s ease;--transition-normal:0.3s ease;--transition-slow:0.5s ease}[data-theme=dark]{--bg-primary:#1a1a1a;--bg-secondary:#1a1a1a;--text-primary:#f0f0f0;--text-secondary:silver;--text-muted:grey;--border-color:#444;--accent-color:#fff;--header-bg:#1a1a1a;--shadow:#ffffff1a}*{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#fefdfb;background-color:var(--bg-primary);font-family:Work Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-family);font-weight:400;font-weight:var(--font-weight-normal);line-height:1.6;transition:color .3s ease,background-color .3s ease;transition:color var(--transition-normal),background-color var(--transition-normal)}body,h1,h2,h3,h4,h5,h6{color:#2c2c2c;color:var(--text-primary)}h1,h2,h3,h4,h5,h6{font-weight:600;font-weight:var(--font-weight-semibold);line-height:1.2}h1{font-size:3rem;font-weight:700;font-weight:var(--font-weight-bold)}h2{font-size:2.25rem}h3{font-size:1.75rem}p{color:#6b6b6b;color:var(--text-secondary);margin-bottom:1rem}a{color:#2c2c2c;color:var(--text-primary);text-decoration:none;transition:color .15s ease;transition:color var(--transition-fast)}a:hover{opacity:.7}.container{margin:0 auto;max-width:1200px;padding:0 calc(min(50px, 60px)/3);padding:0 calc(min(var(--gutter-desktop), var(--gutter-max))/3)}@media (max-width:768px){.container{padding:0 20px;padding:0 var(--gutter-mobile)}}@media (min-width:1400px){.container{padding:0 20px;padding:0 calc(var(--gutter-max)/3)}}.text-center{text-align:center}.visually-hidden{clip:rect(0,0,0,0);border:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}.btn{background:#0000;border:1px solid #e5e5e5;border:1px solid var(--border-color);color:#2c2c2c;color:var(--text-primary);cursor:pointer;display:inline-block;font-family:inherit;font-size:.95rem;font-weight:500;font-weight:var(--font-weight-medium);padding:12px 24px;text-decoration:none;transition:all .15s ease;transition:all var(--transition-fast)}.btn:hover{background-color:#2c2c2c;background-color:var(--text-primary);color:#fefdfb;color:var(--bg-primary)}@media (max-width:768px){html{font-size:14px}h1{font-size:2.5rem}h2{font-size:2rem}}
/*# sourceMappingURL=main.19b0757f.css.map*/