.books-page{padding:30px;color:var(--color-text)}.books-page .header{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:24px}.books-page h1{font-size:2rem;font-weight:600;color:var(--color-purple);font-family:Coolvetica}.books-page .controls{display:flex;justify-content:center;gap:12px;margin-bottom:24px}.books-page button{padding:8px 16px;border:1px solid var(--color-accent-border);border-radius:6px;font-family:inherit;font-size:.875rem;font-weight:500;cursor:pointer;color:var(--color-text);background:var(--color-surface-hover)}.books-page button:hover{background:var(--color-accent-hover);color:var(--color-accent)}.books-page .controls button:last-child{background:var(--color-surface-accent);border-color:var(--color-accent-border-strong);color:var(--color-accent)}.books-page .controls button:last-child:hover{background:var(--color-surface-accent-hover)}.books-page .books{display:flex;flex-direction:column;gap:1px;max-width:900px;margin:0 auto;border:1px solid var(--color-border);border-radius:6px;overflow:hidden}.books-page .book{background:var(--color-surface);padding:16px;border-bottom:1px solid var(--color-border-subtle)}.books-page .book:last-child{border-bottom:none}.books-page .book-row{display:flex;align-items:center;gap:16px}.books-page .book .rating{font-size:2rem;font-weight:600;min-width:70px;text-align:center}.books-page .book .cover{width:90px;height:130px;border-radius:6px;border:1px solid var(--color-purple-muted);overflow:hidden;flex-shrink:0}.books-page .book .cover .spine{width:100%;height:100%;background:var(--spine-color);display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:600;color:var(--color-text-bright)}.books-page .book .info{flex:1}.books-page .book h3{color:var(--color-text-bright);font-weight:600}.books-page .book p{font-size:.875rem}.books-page .actions{display:flex;gap:8px}.books-page .actions .comment-btn{display:flex;align-items:center;gap:4px}.books-page .actions .comment-btn span{font-size:.75rem}.books-page .actions button:last-child{color:var(--color-red);border-color:var(--color-red-border)}.books-page .actions button:last-child:hover{background:var(--color-red-hover)}.books-page .timeline{margin-top:12px;padding-top:12px;border-top:1px solid var(--color-border-subtle);position:relative}.books-page .timeline:before{content:"";position:absolute;left:7px;top:12px;bottom:0;width:2px;background:var(--color-line);border-radius:1px}.books-page .timeline-item{position:relative;padding-left:28px;margin-bottom:20px}.books-page .timeline-item:last-child{margin-bottom:0}.books-page .timeline-badge{position:absolute;left:2px;top:12px;width:12px;height:12px;border-radius:50%;background:var(--color-accent-badge);border:2px solid var(--color-bg);z-index:1}.books-page .timeline-body{border:1px solid var(--color-border);border-radius:6px;overflow:hidden}.books-page .timeline-header{display:flex;align-items:center;gap:6px;padding:8px 12px;background:var(--color-surface);border-bottom:1px solid var(--color-border-faint);font-size:.8rem}.books-page .timeline-header strong{color:var(--color-accent)}.books-page .timeline-header time{color:var(--color-text-faint);font-size:.75rem}.books-page .timeline-header button{margin-left:auto;padding:2px 6px;font-size:.7rem;background:transparent;border:none;color:var(--color-text-faint)}.books-page .timeline-header button:hover{color:var(--color-red);background:transparent}.books-page .timeline-content{padding:10px 12px;font-size:.85rem;background:var(--color-surface-inset)}.books-page .comment-form{display:flex;flex-direction:column;gap:6px;padding:10px 12px;background:var(--color-surface-inset)}.books-page .comment-form input,.books-page .comment-form textarea{padding:6px 10px;border:1px solid var(--color-line);border-radius:6px;font-family:inherit;font-size:.8rem;background:var(--color-surface-input);color:var(--color-text);resize:vertical}.books-page .comment-form input:focus,.books-page .comment-form textarea:focus{outline:none;border-color:var(--color-accent)}.books-page .comment-form button{align-self:flex-end;background:var(--color-surface-accent);border-color:var(--color-accent-border-strong);color:var(--color-accent);font-size:.8rem;padding:6px 12px}.books-page .comment-form button:hover{background:var(--color-surface-accent-hover)}.books-page .comment-form .error{color:var(--color-red);font-size:.75rem}.books-page .form{background:var(--color-surface);padding:20px;border-radius:6px;margin:0 auto 24px;max-width:400px;border:1px solid var(--color-border)}.books-page .form input{width:100%;padding:8px 12px;margin-bottom:10px;border:1px solid var(--color-line);border-radius:6px;font-family:inherit;font-size:.875rem;background:var(--color-surface-inset);color:var(--color-text)}.books-page .form input::placeholder{color:var(--color-text-placeholder)}.books-page .form input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-focus-ring)}.books-page .form .error{display:block;color:var(--color-red);font-size:.75rem;margin:-6px 0 8px}.books-page .form .buttons{display:flex;gap:10px}.books-page .form .buttons button:first-child{background:var(--color-surface-accent);border-color:var(--color-accent-border-strong);color:var(--color-accent)}.books-page .form .buttons button:first-child:hover{background:var(--color-surface-accent-hover)}@keyframes fade-up{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}.section-hero{padding:6em 0 5em;display:flex;flex-direction:column;gap:.25em}.hero-line{margin-left:4em;margin-right:4em;max-width:780px;line-height:1.25;opacity:0;animation:fade-up .8s ease forwards}.hero-line:nth-child(1){animation-delay:.05s}.hero-line:nth-child(2){animation-delay:.15s}.hero-line:nth-child(3){animation-delay:.25s}.hero-line:nth-child(4){animation-delay:.35s}.hero-line p{margin:0;font-size:clamp(1rem,1.5vw,1.15rem);line-height:1.6}.hero-line:nth-child(1) p{color:var(--color-accent);font-size:.95rem;letter-spacing:.08em;text-transform:uppercase}.hero-line:nth-child(2) p{font-size:clamp(2.8rem,6vw,4.6rem);letter-spacing:.025em;color:var(--color-purple);font-family:Coolvetica}.hero-line:nth-child(3) p{font-size:clamp(2.4rem,5.5vw,4.2rem);letter-spacing:.025em;color:var(--color-heading);font-family:Coolvetica}.hero-line:nth-child(4) span{font-size:clamp(1rem,1.4vw,1.1rem);line-height:1.7;color:var(--color-text);text-align:justify;display:block}.hero-socials{display:flex;flex-wrap:wrap;column-gap:1em;row-gap:.75em;margin-left:4em;margin-right:4em;margin-top:1.25em}.hero-social-icon{width:1.5em;height:1.5em;transition:transform .2s ease,filter .2s ease}.is-active{filter:invert(.45) sepia(3) saturate(5) hue-rotate(220deg)}.hero-social-icon:hover{filter:invert(.45) sepia(3) saturate(5) hue-rotate(220deg);transform:translateY(-2px) scale(1.08)}.hero-social:hover{cursor:pointer}@media screen and (max-width:720px){.hero-line{text-align:center;margin-left:2em;margin-right:2em}.hero-socials{justify-content:center;margin-left:2em;margin-right:2em}}.interest-bar{display:flex;align-items:center;gap:1em;width:100%}.interest-label{font-size:.95rem;color:var(--color-text);min-width:150px}.interest-track{display:flex;gap:4px;flex:1}.interest-segment{height:20px;flex:1;border-radius:3px;background:var(--color-purple-muted);transition:background .3s ease}.interest-segment.filled{background:var(--color-purple)}.section-resume{padding:6em 4em 5em;max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:2em}.resume-title{font-family:Coolvetica;font-size:clamp(2.4rem,5vw,3.8rem);color:var(--color-purple);margin:0}.resume-section h2{color:var(--color-accent);font-size:clamp(1.6rem,3vw,2.2rem);font-family:Coolvetica;letter-spacing:.04em;margin:0 0 1em;display:flex;align-items:center;gap:.4em}.resume-item{margin-bottom:1.5em}.resume-item-header{display:flex;justify-content:space-between;align-items:baseline;flex-wrap:wrap;gap:.5em}.resume-item h3{margin:0;font-size:1.1rem;font-weight:700;color:var(--color-purple)}.resume-date{font-size:.85rem;color:var(--color-text-muted)}.resume-item p{margin:.25em 0 0;color:var(--color-text);line-height:1.6}.resume-interests{display:flex;flex-direction:column;gap:.75em}@media screen and (max-width:720px){.section-resume{padding:4.5em 2em 5em}}.strava-page h2{color:var(--color-accent);font-family:Coolvetica;font-size:1.4rem;margin:1.5em 0 .5em}.strava-page ol,.strava-page ul{padding-left:1.5em;margin-bottom:1em}.strava-page li{margin-bottom:.3em}.strava-page a{color:var(--color-accent);text-decoration:none;font-weight:600}.strava-page a:hover{text-decoration:underline}.strava-tree{background:var(--color-surface-hover);border:1px solid var(--color-border);border-radius:8px;padding:1.25em 1.5em;font-size:.85rem;line-height:1.6;overflow-x:auto;color:var(--color-accent)}.section-work{padding:5.5em 4em 6.5em;display:flex;flex-direction:column;gap:2.5em}.work-title{font-family:Coolvetica;font-size:clamp(2.4rem,5vw,3.8rem);margin:0;color:var(--color-purple)}.work-timeline{display:flex;flex-direction:column;gap:2em}.work-timeline-group{display:flex;align-items:flex-start;gap:1.5em}.work-timeline-projects{display:flex;flex-direction:column;gap:2em;flex:1}.work-year{font-size:.85rem;font-weight:600;color:var(--color-accent);letter-spacing:.06em;min-width:3.5em;padding-top:.15em}.work-timeline-line{width:2px;align-self:stretch;background:var(--color-line);border-radius:1px;flex-shrink:0}.work-item{text-decoration:none;display:block}.work-item h3{margin:0;font-size:1.35rem;font-weight:600;color:var(--color-text-bright);transition:color .2s ease}.work-item p{margin:0 0 .5em;color:var(--color-text);line-height:1.55}.work-item span{color:var(--color-accent-muted);font-size:.85rem;letter-spacing:.08em;text-transform:uppercase}.work-item-header{display:flex;align-items:center;gap:.5em}.work-item:hover h3{color:var(--color-accent)}.work-arrow{font-size:1.5rem;line-height:1;color:var(--color-text-bright);transition:transform .2s ease}.work-item:hover .work-arrow{transform:translate(4px)}.work-item .work-wip{font-size:.7rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--color-text-bright);background:var(--color-red);padding:.15em .6em;border-radius:999px}@media screen and (max-width:720px){.section-work{padding:4.5em 2em 5.5em}}.home-assistant-frame{width:100%;height:calc(100vh - 60px);border:none}.site-nav{position:fixed;top:0;right:0;display:flex;gap:1.5em;padding:1.25em 2em;z-index:10}.site-nav a{color:var(--color-text);text-decoration:none;font-size:.85rem;letter-spacing:.08em;text-transform:uppercase;transition:color .2s ease}.site-nav a:hover{color:var(--color-accent)}.content-page{max-width:680px;margin:0 auto;padding:6em 2em 4em;color:var(--color-text);line-height:1.7}.content-page h1{font-family:Coolvetica;font-size:clamp(2rem,4vw,3rem);color:var(--color-purple);margin-bottom:.5em}:root{--color-bg: #585858;--color-text: #cdd6e8;--color-text-bright: #ffffff;--color-text-muted: #a8b2d1;--color-text-faint: rgba(205, 214, 232, .4);--color-text-placeholder: rgba(205, 214, 232, .35);--color-heading: #d8d2e6;--color-accent: #64ffda;--color-accent-muted: rgba(100, 255, 218, .85);--color-accent-border: rgba(100, 255, 218, .25);--color-accent-border-strong: rgba(100, 255, 218, .4);--color-accent-hover: rgba(100, 255, 218, .08);--color-accent-badge: rgba(100, 255, 218, .3);--color-purple: #d1a2f9;--color-purple-muted: rgba(209, 162, 249, .15);--color-red: #da3633;--color-red-border: rgba(218, 54, 51, .5);--color-red-hover: rgba(218, 54, 51, .1);--color-border: rgba(100, 255, 218, .15);--color-border-subtle: rgba(100, 255, 218, .08);--color-border-faint: rgba(100, 255, 218, .1);--color-surface: rgba(255, 255, 255, .03);--color-surface-input: rgba(255, 255, 255, .04);--color-surface-hover: rgba(255, 255, 255, .05);--color-surface-inset: rgba(15, 31, 61, .6);--color-surface-accent: rgba(100, 255, 218, .12);--color-surface-accent-hover: rgba(100, 255, 218, .2);--color-line: rgba(100, 255, 218, .2);--color-focus-ring: rgba(100, 255, 218, .15)}@font-face{font-family:Consonlas;src:url(/fonts/CONSOLAB.ttf) format("truetype");font-weight:400;font-style:normal}@font-face{font-family:Coolvetica;src:url(/fonts/Coolvetica.ttf) format("truetype");font-weight:400;font-style:normal}body{font-family:Consonlas,Courier New,monospace;background-color:var(--color-bg);color:var(--color-text-bright);min-height:100vh;-webkit-user-select:none;user-select:none}a{color:inherit}
