:root{--accent: #174885;--text-accent: #1D5BA8;--surface-alt: #F4F8FF;--shadow-sm: 0 6px 16px rgba(23, 72, 133, .02);--shadow-md: 0 12px 30px rgba(23, 72, 133, .12);--shadow-lg: 0 20px 45px rgba(23, 72, 133, .16)}@font-face{font-family:"default";src:url(/fonts/segoeui.ttf);font-weight:400}@font-face{font-family:"default";src:url(/fonts/seguisb.ttf);font-weight:600}*{margin:0;padding:0;box-sizing:border-box;font-family:"default"}html{scroll-behavior:smooth;overflow-x:clip}body{background-color:var(--surface-alt);background-image:linear-gradient(to bottom right,#f4f8ff,#e9f2ff 55%,#dfe7f2);background-attachment:fixed;background-repeat:no-repeat;background-size:cover;color:#333;line-height:1.6;overflow-x:hidden}a:not(.default){position:relative;color:var(--text-accent);text-decoration:none}a:not(.default):before{content:"";position:absolute;width:100%;height:1px;bottom:0;left:0;background-color:#1f2b3a}a:not(.default):after{content:"";position:absolute;width:0;height:3px;bottom:-2px;opacity:80%;left:0;background-color:var(--text-accent);transition:width .6s ease;transform-origin:left;font-weight:800}a:not(.default):hover:after{width:100%}a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible{outline:3px solid rgba(29,91,168,.35);outline-offset:2px}.default{text-decoration:none}.top-bar{background-image:linear-gradient(140deg,#174885,#1d5ba8);padding:8px 20px 8px 0;display:flex;justify-content:flex-start;align-items:center;box-shadow:0 14px 28px #17488559;height:55%}.nav-container{display:flex;align-items:center;justify-content:space-between;width:100%}.nav-links{display:flex}.theme-controls{position:fixed;bottom:18px;right:16px;z-index:2001;display:inline-flex;align-items:center;gap:3px}.theme-toggle,.system-toggle{display:inline-flex;align-items:center;justify-content:center;position:relative;background:#fff3;border:1px solid rgba(0,0,0,.14);border-radius:999px;overflow:visible;width:42px;height:42px;padding:0;cursor:pointer;transition:background-color .3s ease,border-color .3s ease}.system-toggle{width:28px;height:28px;opacity:.78;position:relative}.system-toggle.active{opacity:1;background:#1d5ba829;border-color:#1d5ba8e6;box-shadow:0 0 0 2px #1d5ba833}.system-toggle.active:after{content:"";position:absolute;top:-3px;right:-3px;width:8px;height:8px;border-radius:50%;background:#1d5ba8;border:1px solid rgba(255,255,255,.95)}.theme-toggle-icon{width:24px;height:24px;display:block;filter:none}.system-toggle .theme-toggle-icon{width:14px;height:14px}.theme-toggle:hover,.system-toggle:hover{background:#ffffffe6}.theme-toggle:disabled{opacity:.45;cursor:not-allowed}.theme-toggle:after{content:"";position:absolute;top:-3px;right:-3px;width:9px;height:9px;border-radius:50%;border:1px solid rgba(255,255,255,.95)}.theme-toggle[data-theme-state=light]:after{background:#ffd54f}.theme-toggle[data-theme-state=dark]:after{background:#60a5fa}.nav-links a{margin-left:40px}.nav-item{color:#fff;text-decoration:none;transition:color .3s ease,text-shadow .3s ease,background-color .3s ease,transform .3s ease;font-size:20px;font-weight:600}.nav-item:hover{color:#60a5fa;text-shadow:0 4px 12px rgba(0,0,0,.35)}.nav-links .nav-item{margin-left:6px;padding:8px 16px;border-radius:999px}.nav-links .nav-item:hover{background:#ffffff1f;transform:translateY(-1px)}.top-bar>.nav-container>.nav-item{padding-left:20px}.banner-logo{display:inline;width:110%;text-align:left}.favicon-logo{height:40px;display:none}@media(max-width:400px){.banner-logo{width:90%}}@media(max-width:300px){.banner-logo{display:none}.favicon-logo{display:inline}}.hamburger{font-size:1.5rem;background:none;border:none;cursor:pointer;display:none;width:30px;height:22px;position:relative;z-index:1000}.hamburger span{display:block;height:4px;width:100%;background:#fff;margin:4px 0;border-radius:2px;transition:all .4s ease}.hamburger.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}.hamburger.active span:nth-child(2){opacity:0}.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}@media screen and (max-width:768px){.hamburger{display:block;z-index:1004}.theme-controls{bottom:10px;right:10px;gap:2px}.theme-toggle{width:38px;height:38px}.system-toggle{width:26px;height:26px}.nav-links{max-height:0;overflow:hidden;flex-direction:column;position:absolute;top:58px;left:0;width:calc(100% - 20px);margin:0 10px;background:linear-gradient(180deg,#fff,#f7f7f7);text-align:center;padding:0;align-items:center;border:1px solid #dedede;box-shadow:var(--shadow-md);border-radius:14px;opacity:0;z-index:1002;transition:max-height .5s ease,opacity .5s ease,padding .5s ease}.nav-links .nav-item{color:#000;text-decoration:none;width:calc(100% - 18px);margin:6px 0;padding:10px 14px;border-radius:12px}.nav-links.show{max-height:420px;opacity:1;padding:8px 0}}.fas{padding-right:16px}h1{font-weight:600}h2{font-size:17pt;font-weight:600;margin-bottom:10px}h3{font-size:15pt;font-weight:600;margin-bottom:10px}h4{font-size:13pt;margin-top:10px;margin-bottom:10px;font-weight:600}h4.cv{font-size:13pt;margin-top:0;margin-bottom:0}h5{font-size:13pt;margin-top:10px;margin-bottom:10px}hr{border:none;height:1px;background-color:#dedede;margin:20px 0;width:100%}.accordion{cursor:pointer;display:flex;align-items:center;padding:10px;background:linear-gradient(180deg,#fff,#f8f8f8);border-radius:12px;border:1px solid #ededed;box-shadow:var(--shadow-sm)}.arrow{transition:transform .3s ease;margin-right:10px}.arrow.open{transform:rotate(90deg)}.panel{max-height:0;overflow:hidden;transition:max-height 1s ease,padding 1s ease;border-bottom-left-radius:12px;border-bottom-right-radius:12px;background:linear-gradient(180deg,#fff,#fafafa);padding:0 10px}.panel.open{max-height:10000px;padding:10px}strong,b{font-weight:600}.score{float:right;padding-left:20px;font-family:Intel One Mono;font-size:36pt;position:relative;top:50%;transform:translateY(calc(-50% + 5px))}.mainframe{max-width:1000px;margin:40px auto;padding:0 20px}.contact-mainframe{max-width:800px;margin:40px auto;padding:0 20px}.introduction{text-align:center;margin-bottom:30px}.introduction h1{font-size:3rem;color:var(--accent);margin-bottom:10px;text-shadow:0 10px 30px rgba(10,61,98,.25)}.introduction p{font-size:15pt;font-weight:700;color:#555;display:flex;align-items:center;flex-direction:column;white-space:normal;overflow-wrap:break-word;padding:0 10px}p{white-space:pre-wrap;line-height:1.5}p:not(:last-child){margin-bottom:10px}.box{background:linear-gradient(135deg,#fff,#fdfdfe);padding:30px;margin-bottom:30px;border-radius:12px;border:1px solid #e7e7e7;box-shadow:var(--shadow-md)}.company-box{display:flex;align-items:flex-start;gap:16px}.contact{display:flex;align-items:center;justify-content:center;padding:20px 0;background-image:linear-gradient(140deg,#174885,#1d5ba8);border-radius:12px;gap:clamp(20px,2vw,65px);box-shadow:var(--shadow-md)}.profile-link{display:inline-flex;align-items:center;justify-content:center;color:#fff;font-size:2.5rem;text-decoration:none;cursor:pointer;transition:color .3s ease;position:relative;width:40px;height:40px}.social-icon-img{width:40px;height:40px;display:block;position:absolute;top:0;left:0;transition:opacity 1s ease}.social-icon-img--hover{opacity:0}.profile-link:hover .social-icon-img--hover{opacity:1}.profile-link:hover .social-icon-img--base{opacity:0}.cv-img{margin-top:8px;border-radius:4px}.btn{display:inline-flex;align-items:center;gap:10px;font-size:1rem;padding:10px 35px;border:1px solid #dedede;border-radius:12px;font-weight:600;cursor:pointer;transition:background-color .6s ease;background-color:var(--accent);color:#fff}.btn img{width:16px;height:16px;object-fit:contain}.btn:hover{background-color:#d8d8d8}.btn-inline{border-radius:32px;background-color:#fff;color:#000}.pagelink{display:flex;flex-direction:column;text-align:center;gap:20px}.btn-pagelink{text-align:center!important;border-radius:16px;background-color:#fff;color:#000;width:100%;height:65px;font-size:24px!important;padding:15px;box-shadow:0 2px 10px #00000012}.btn-pagelink:hover{background-color:#f0f4ff!important;box-shadow:0 4px 18px #17488524!important}.btn-pagelink img{width:24px;height:24px}@media(max-width:500px){.social-icons{width:38px;height:38px}.social-icon-img{width:34px;height:34px;top:50%;left:50%;transform:translate(-50%,-50%)}.btn{padding:8px 16px;font-size:.9rem}}.skills-container{padding:0;display:flex;flex-wrap:wrap;gap:20px;justify-content:center}.skill-card{width:160px;height:160px;perspective:1000px;cursor:pointer}.skill-card div{width:100%;height:100%;border-radius:10px;color:#000;display:flex;flex-direction:column;align-items:center;justify-content:center;transition:transform 1.5s,box-shadow .4s ease;backface-visibility:hidden;padding:15px;font-weight:600}.skill-front{background:#fff;border:1px solid #dedede;gap:10px;box-shadow:var(--shadow-sm)}.skill-card .skill-back{background:linear-gradient(135deg,#fff,#f3f5f8);transform:rotateY(180deg);text-align:center;font-size:13px;font-weight:400}.skill-card:hover .skill-front{transform:rotateY(180deg)}.skill-card:hover .skill-back{transform:rotateY(0)}.skill-card .skill-front,.skill-card .skill-back{position:absolute;border:1px solid #dedede}.skill-front p{margin-top:auto;margin-bottom:0}.inline-skill{color:#000;background-color:transparent;display:inline-block;border:1px solid #dedede;border-radius:6px;padding:2px 10px;margin-right:4px;height:30px;font-size:15px;cursor:pointer;transition:background-color .3s ease}.inline-skill:hover{background-color:#eee}.toc-panel{position:fixed;top:100px;right:0;width:200px;background:linear-gradient(180deg,#fff,#f5f5f5);border:1px solid #dedede;border-radius:12px;padding-bottom:20px;margin-right:20px;box-shadow:var(--shadow-sm);transition:transform .6s ease;z-index:1000}.toc-link{text-decoration:none;color:#000}.toc-link.active{color:var(--text-accent)}.toc-panel.hidden{transform:translate(2000px)}#toc-arrow{position:fixed;top:100px;right:0;width:30px;height:30px;background:linear-gradient(180deg,#fff,#f1f1f1);border:1px solid #dedede;border-radius:50%;padding:20px;display:flex;justify-content:center;align-items:center;cursor:pointer;z-index:1001;transition:transform .6s ease}#toc-arrow.rotated{transform:rotate(180deg)}#toc-list{margin:0;padding-left:20px}.project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px;margin-bottom:30px}.project-card{display:flex;flex-direction:column;background:linear-gradient(135deg,#fff,#fdfdfe);border:1px solid #e7e7e7;border-radius:12px;box-shadow:var(--shadow-md);overflow:hidden;transition:box-shadow .3s ease,transform .3s ease;cursor:pointer}.project-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px)}.project-card-img-wrap{width:100%;aspect-ratio:16 / 9;overflow:hidden;background:#e9eef5}.project-card-img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s ease}.project-card:hover .project-card-img{transform:scale(1.04)}.project-card-body{padding:20px;display:flex;flex-direction:column;gap:10px;flex:1}.project-card-title{margin-bottom:0;color:var(--accent)}.project-card-desc{font-size:14px;color:#555;line-height:1.55;margin-bottom:0}.project-card-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:auto;padding-top:6px}.project-tag{font-size:12px;font-weight:600;padding:3px 10px;border-radius:999px;background:var(--surface-alt);border:1px solid #d0daea;color:var(--text-accent)}[data-theme=dark] .project-card{background:linear-gradient(180deg,#223040,#1a2838);border-color:#2a3747}[data-theme=dark] .project-card-desc{color:#9fb3c8}[data-theme=dark] .project-tag{background:#1a2838;border-color:#2a3747;color:#60a5fa}[data-theme=dark] .project-card-img-wrap{background:#1a2838}.flex-container{display:flex;gap:20px;flex-wrap:wrap}.column{flex:1;min-width:200px;padding:20px;background:#fff;border-radius:12px;border:1px solid #e3e3e3;box-shadow:0 6px 16px #0a3d620f}.gallery{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:30px;justify-content:center}.gallery img{width:100%;height:auto;cursor:pointer;border-radius:8px;box-shadow:var(--shadow-sm);transition:box-shadow .4s ease,transform .3s ease}.gallery img:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.modal{display:flex;position:fixed;z-index:999;left:0;top:0;align-items:center;width:100%;height:100%;overflow:auto;background-color:#0000008c;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal-container{padding:0 20px 20px;margin-left:min(70%,calc(5% + 12vw));margin-right:min(70%,calc(5% + 12vw));margin-top:100px;background:linear-gradient(180deg,#fff,#f7f7f7);border:1px solid #dedede;border-radius:12px;box-shadow:var(--shadow-lg)}.modal-div{display:flex;align-items:top;justify-content:flex-start;gap:20px}.modal-img{width:100%;max-width:100%;height:auto;object-fit:contain}.modal-img-link{display:block;flex:0 0 45%;max-width:45%}#rightFrame{display:flex;flex-direction:column;justify-content:flex-start;flex:1;max-width:none;text-align:left}.inline-button{background-color:#fff;padding:0 10px;height:30px;border:0;font-size:12pt;border-radius:4px;transition:background-color .3s;cursor:pointer}.inline-button:hover{background-color:#f3f3f3}.inline-button:active{background-color:#e8e8e8}.close-button{color:#000;font-size:18px;font-weight:600;cursor:pointer;background:transparent;border:0;line-height:1}.active-image{box-shadow:0 0 15px 4px #87cefa;border-radius:4px;transition:box-shadow .5s ease,transform .3s ease;transform:scale(1.05)}@media(max-width:1000px){.modal-container{width:90%;margin:50px auto!important;padding:10px}.modal-div{flex-direction:column!important;align-items:center!important;gap:10px!important}.modal-img{max-width:100%!important;height:auto}.modal-img-link{max-width:100%!important;width:100%}#rightFrame{max-width:100%!important;text-align:left}.inline-button{width:45%;margin:0 2%}}ul,ol{margin-left:40px;margin-bottom:10px}.noindent{margin-left:0;margin-bottom:0}@media(min-width:761px){.school-indent{margin-left:40px}.school-box{padding-left:14px}}@media(max-width:760px){.school-box ul{margin-left:0}}code{font-family:Consolas;font-size:13px;border:1px solid #e1e1e1;padding:2px 4px;border-radius:4px;background:#fbfbfb}table{border-collapse:separate;border-spacing:0;width:100%;margin:20px 0}table tr th,table tr td{border-right:1px solid #dedede;border-bottom:1px solid #dedede;padding:10px}table tr th:first-child,table tr td:first-child{border-left:1px solid #dedede}table tr th{background:linear-gradient(180deg,#fff,#f5f5f5);border-top:1px solid #dedede}tr:nth-child(2n){background-color:#f6f8fa}table tr:first-child th:first-child{border-top-left-radius:12px}table tr:first-child th:last-child{border-top-right-radius:12px}table tr:last-child td:first-child{border-bottom-left-radius:12px}table tr:last-child td:last-child{border-bottom-right-radius:12px}@media(min-width:1750px){.modal-container{margin-left:25%;margin-right:25%}}.table-key{font-weight:600;color:var(--text-accent);border:none!important;display:flex;vertical-align:middle}.table-key i{color:var(--accent);font-size:24px}.table-value{border:none}.icon{width:24px;height:24px;margin-right:15px}input,textarea{flex:1;padding:20px;font-size:16px;border:1px solid #dedede;border-radius:20px;width:100%;height:45px;padding-left:15px!important;margin-bottom:10px;transition:box-shadow .5s ease,background-color .5s ease,border-color .4s ease}input:hover,textarea:hover{background-color:#f9f9f9}input:focus,textarea:focus{outline:none;box-shadow:0 0 0 3px #1d5ba826;border-color:#c7d7ec;background-color:#fff}textarea{padding-top:15px!important;height:100px;resize:none}input[id=email_]{position:absolute;left:-2000px}.btn.clicked{background-color:#910000;color:#fff;cursor:not-allowed;opacity:.8}.btn.clicked:hover{opacity:1}[data-theme=dark]{--accent: #60A5FA;--text-accent: #1D5BA8;--surface-alt: #0B1220;--shadow-sm: 0 6px 16px rgba(0, 0, 0, .35);--shadow-md: 0 12px 30px rgba(0, 0, 0, .5);--shadow-lg: 0 20px 45px rgba(0, 0, 0, .58)}[data-theme=dark] body{background-color:#0b1220;background-image:linear-gradient(to bottom right,#0b1220,#101826 55%,#16223a);color:#d8e2ee}[data-theme=dark] a:not(.default):before{background-color:#d8e2ee}[data-theme=dark] .top-bar{background-image:linear-gradient(140deg,#0c1f31,#143450);box-shadow:0 14px 28px #00000073}[data-theme=dark] .theme-toggle,[data-theme=dark] .system-toggle{background:#101822eb;border-color:#ffffff38}[data-theme=dark] .theme-toggle:hover,[data-theme=dark] .system-toggle:hover{background:#1c2632f5}[data-theme=dark] .theme-toggle-icon{filter:brightness(0) invert(1)}[data-theme=dark] .theme-toggle:after{border-color:#0c141ef2}[data-theme=dark] .theme-toggle[data-theme-state=light]:after{background:#ffe082}[data-theme=dark] .theme-toggle[data-theme-state=dark]:after{background:#8aa8c6}[data-theme=dark] .system-toggle.active{background:#5eb3ff33;border-color:#5eb3ffe6;box-shadow:0 0 0 2px #5eb3ff47}[data-theme=dark] .system-toggle.active:after{background:#5eb3ff;border-color:#0c141ef2}[data-theme=dark] .nav-item:hover{color:#8cc6ff;background:#ffffff14}@media screen and (max-width:768px){[data-theme=dark] .nav-links{background:linear-gradient(180deg,#1c2735,#131d29);border:1px solid #29384b}[data-theme=dark] .nav-links a{color:#d8e2ee}}[data-theme=dark] hr{background-color:#2f3d4c}[data-theme=dark] .introduction p{color:#b5c2cf}[data-theme=dark] .accordion,[data-theme=dark] .panel,[data-theme=dark] .box,[data-theme=dark] .skill-front,[data-theme=dark] .skill-card .skill-back,[data-theme=dark] .toc-panel,[data-theme=dark] #toc-arrow,[data-theme=dark] .column,[data-theme=dark] .modal-container,[data-theme=dark] table tr th{background:linear-gradient(180deg,#223040,#1a2838);border-color:#2a3747}[data-theme=dark] .skill-card div,[data-theme=dark] .inline-skill,[data-theme=dark] .inline-button,[data-theme=dark] .close-button,[data-theme=dark] .toc-link{color:#d8e2ee}[data-theme=dark] .inline-skill{border-color:#2a3747}[data-theme=dark] .inline-skill:hover{background-color:#ffffff14}[data-theme=dark] .btn-inline,[data-theme=dark] .btn-pagelink,[data-theme=dark] .inline-button{background-color:#1d2733;color:#d8e2ee;border-color:#2a3747}[data-theme=dark] .btn:hover,[data-theme=dark] .btn-inline:hover,[data-theme=dark] .inline-button:hover{background-color:#2a3747}[data-theme=dark] .btn-pagelink:hover{background-color:#253344!important;box-shadow:0 4px 18px #00000059!important}@media(max-width:760px){.box{padding:14px;margin-bottom:12px;border-radius:12px}.mainframe{margin:24px auto;max-width:100%;padding:0 12px 18px}.contact-mainframe{max-width:100%;padding:0 12px 18px;margin:24px auto}.company-box{gap:10px}.skills-container{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.skill-card{width:100%;height:clamp(130px,38vw,160px)}.skill-card div{padding:10px}.skill-card img{max-width:70%;height:auto}.introduction{margin-bottom:18px}.introduction h1{font-size:clamp(2rem,10vw,2.6rem);margin-bottom:8px}.introduction p{font-size:13.5pt;padding:0 4px}.contact{padding:14px 12px;gap:24px;flex-wrap:wrap}.profile-link,.social-icon-img{width:36px;height:36px}}.post-list{display:flex;flex-direction:column;gap:20px}.post-card{display:block;background:linear-gradient(135deg,#fff,#fdfdfe);border:1px solid #e7e7e7;border-radius:12px;box-shadow:var(--shadow-md);padding:24px 28px;text-decoration:none;color:inherit;transition:box-shadow .3s ease,transform .3s ease}.post-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px)}.post-card-date{font-size:13px;color:gray;font-weight:600;letter-spacing:.02em}.post-card-title{margin:6px 0 8px;color:var(--accent)}.post-card-excerpt{color:#555;margin-bottom:10px}.post-card-readmore{font-weight:600;color:var(--text-accent)}.post-body{overflow-wrap:break-word;word-break:break-word}.post-body h1,.post-body h2,.post-body h3{color:var(--accent);margin:24px 0 10px}.post-body h1:first-child,.post-body h2:first-child{margin-top:0}.post-body p{margin-bottom:14px}.post-body ul,.post-body ol{margin:0 0 14px 22px}.post-body li{margin-bottom:6px}.post-body code{background:var(--surface-alt);border:1px solid #e1e8f2;border-radius:5px;padding:1px 6px;font-family:monospace;font-size:.92em}.post-body pre{background:var(--surface-alt);border:1px solid #e1e8f2;border-radius:8px;padding:16px;overflow-x:auto;margin-bottom:14px}.post-body pre code{background:none;border:none;padding:0}.post-body blockquote{border-left:3px solid var(--accent);padding-left:16px;margin:0 0 14px;color:#555}[data-theme=dark] .post-card{background:linear-gradient(135deg,#16202e,#131c28);border-color:#2a3747}[data-theme=dark] .post-card-excerpt,[data-theme=dark] .post-body blockquote{color:#aab8c8}[data-theme=dark] .post-body code,[data-theme=dark] .post-body pre{background:#16202e;border-color:#2a3747}.field-error{display:block;margin-top:6px;color:#c0392b;font-size:13px}[data-theme=dark] .field-error{color:#ff8a80}.btn-loading{display:inline-flex;align-items:center;gap:8px}.spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spinner-rotate .7s linear infinite}@keyframes spinner-rotate{to{transform:rotate(360deg)}}.form-toast{margin:18px auto 0;max-width:420px;padding:12px 16px;border-radius:10px;text-align:center;font-weight:600;font-size:14px;animation:toast-in .3s ease both}.form-toast--success{background:#e6f7ed;color:#1c7a44;border:1px solid #b6e6c8}.form-toast--error{background:#fdecea;color:#b3261e;border:1px solid #f5c2bd}[data-theme=dark] .form-toast--success{background:#2ea05a26;color:#7ee0a3;border-color:#2ea05a66}[data-theme=dark] .form-toast--error{background:#e5393526;color:#ff9b94;border-color:#e5393566}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media(prefers-reduced-motion:reduce){.spinner{animation-duration:1.4s}.form-toast{animation:none}}@keyframes page-enter{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}.page-transition{animation:page-enter .45s cubic-bezier(.22,.61,.36,1) both}.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s cubic-bezier(.22,.61,.36,1),transform .6s cubic-bezier(.22,.61,.36,1);will-change:opacity,transform}.reveal.is-visible{opacity:1;transform:translateY(0)}.nav-links .nav-item.active{color:#60a5fa;background:#ffffff29}.top-bar>.nav-container>.nav-item.active{color:#60a5fa}.reading-progress{position:fixed;top:0;left:0;right:0;height:3px;z-index:1000;pointer-events:none;background:transparent}.reading-progress-bar{height:100%;width:100%;transform:scaleX(0);transform-origin:0 50%;background:linear-gradient(90deg,var(--accent),var(--text-accent));transition:transform .1s linear}.scroll-top{position:fixed;bottom:28px;right:28px;width:46px;height:46px;border:none;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:var(--shadow-md);opacity:0;visibility:hidden;transform:translateY(16px) scale(.9);transition:opacity .3s ease,transform .3s ease,visibility .3s ease,background-color .2s ease;z-index:1000}.scroll-top.show{opacity:1;visibility:visible;transform:translateY(0) scale(1)}.scroll-top:hover{background:var(--text-accent);transform:translateY(-2px) scale(1.05)}.scroll-top:focus-visible{outline:2px solid #fff;outline-offset:2px}[data-theme=dark] .scroll-top{color:#0b1220}@media(max-width:480px){.scroll-top{bottom:18px;right:18px;width:42px;height:42px}}@media(prefers-reduced-motion:reduce){.page-transition{animation:none}.reveal{opacity:1;transform:none;transition:none}.scroll-top{transition:opacity .2s ease,visibility .2s ease;transform:none}.scroll-top.show:hover{transform:none}}
