:root{font-family:var(--font-primary, "Helvetica Neue", Helvetica, Arial, sans-serif);line-height:1.6;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh;font-family:var(--font-primary, "Helvetica Neue", Helvetica, Arial, sans-serif)}html{scroll-behavior:smooth}.header{width:100%;background-color:#282c34;padding:.25rem 0;display:flex;justify-content:center;box-shadow:0 2px 4px #0000001a}.header-inner-container{display:flex;justify-content:space-between;align-items:center;width:100%;max-width:1100px;padding:0 1rem}.logo-container{display:flex;align-items:center}.logo{height:30px;margin-right:.5rem}.title{color:#fff;font-size:1.3rem;margin:0}.header-nav{margin-left:auto}.header-nav-list{display:flex;list-style:none;gap:1.5rem;margin:0;padding:0}.nav-link{color:#fff;text-decoration:none;font-weight:700;padding:.4rem .8rem;font-size:.9rem;border-radius:4px;transition:all .3s ease;position:relative;cursor:pointer}.nav-link:hover{background-color:#ffffff1a;transform:translateY(-2px)}.nav-link:active{transform:translateY(0)}.nav-link:after{content:"";position:absolute;bottom:0;left:50%;width:0;height:2px;background-color:#61dafb;transition:all .3s ease;transform:translate(-50%)}.nav-link:hover:after{width:90%}@media (max-width: 500px){.header-inner-container{flex-direction:column;align-items:flex-start}.header-nav{margin-left:0;margin-top:1rem;width:100%}.header-nav-list{flex-direction:column;gap:.5rem;align-items:flex-start;width:100%}.nav-link{padding:.5rem 0;display:block;width:100%;text-align:left}.nav-link:hover:after{width:100%}}.footer{background-color:var(--secondary-color);color:var(--text-color-primary);padding:50px 20px 20px;font-size:.95rem}.footer-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:30px;max-width:1200px;margin:0 auto 40px;text-align:left}.footer-section h3{font-size:1.5rem;color:var(--primary-color);margin-bottom:20px;font-weight:600}.footer-section p,.footer-section ul,.footer-section li{margin-bottom:10px;line-height:1.7}.footer-section ul{list-style:none;padding:0}.footer-section ul li a{color:var(--text-color-primary);text-decoration:none;transition:color .3s ease,padding-left .3s ease;display:inline-block}.footer-section ul li a:hover{color:var(--primary-color);padding-left:5px}.footer-bottom{text-align:center;padding-top:20px;border-top:1px solid var(--border-color);font-size:.9rem;color:var(--text-color-light)}.footer-contact-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:1.1rem}.footer-contact-list li{display:flex;align-items:center;gap:.7rem;font-size:1.05rem}.footer-contact-list i{color:var(--accent-color-1);font-size:1.3rem;min-width:22px;text-align:center}.footer-contact-list a{color:var(--primary-color);text-decoration:none;transition:color .2s;font-weight:500}.footer-contact-list a:hover{color:var(--accent-color-2);text-decoration:underline}@media (max-width: 768px){.footer-content{grid-template-columns:1fr;text-align:center}.footer-section h3{margin-top:20px}.footer-section:first-child h3{margin-top:0}.footer-section ul{display:inline-block;text-align:left}}:root{--primary-color: #3B5984;--primary-color-dark: #2E4769;--primary-color-light: #5F7A9D;--secondary-color: #ECEFF1;--accent-color-1: #A1887F;--accent-color-2: #81C784;--text-color-primary: #37474F;--text-color-secondary: #FFFFFF;--background-light: #FFFFFF;--background-dark: #455A64;--border-color: #CFD8DC;--shadow-color: rgba(0, 0, 0, .06);--font-primary: "Source Sans 3", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, sans-serif;--font-secondary: "Noto Serif JP", Georgia, serif;--heading-font: "Lato", sans-serif;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-xxl: 3rem;--border-radius-sm: 4px;--border-radius-md: 8px;--border-radius-lg: 16px;--transition-speed: .3s;--secondary-bg-color: #F0F4F8;--card-bg-color: #FFFFFF;--card-border-color: #E0E0E0;--text-color: #333333;--text-color-light: #666666;--button-text-color: #FFFFFF;--light-gray: #E9ECEF;--medium-gray: #CED4DA;--success-color: #28A745;--error-color: #DC3545;--warning-color: #FFC107;--shadow-light: 0 2px 4px rgba(0,0,0,.05);--shadow-medium: 0 4px 8px rgba(0,0,0,.1);--shadow-large: 0 8px 16px rgba(0, 0, 0, .1);--border-radius-small: 4px;--border-radius-medium: 8px;--border-radius-large: 12px}body{line-height:1.6;color:var(--text-color-primary);background-color:var(--background-light);margin:0;padding:0}.App{min-height:100vh;display:flex;flex-direction:column;background-color:var(--background-light)}main{flex:1;padding:0}section{max-width:1200px;margin:0 auto;padding:6rem 2rem;position:relative}section h2{color:var(--primary-color);font-size:2.5rem;margin-bottom:3rem;text-align:center;font-weight:600;letter-spacing:.02em;position:relative;font-family:var(--heading-font);transition:all .3s ease}section h2:hover{transform:translateY(-2px);color:var(--primary-color-dark);letter-spacing:.04em}section h2:after{content:"";position:absolute;bottom:-10px;left:50%;transform:translate(-50%);width:60px;height:4px;background:var(--accent-color-1);border-radius:2px}section p{color:var(--text-color-primary);line-height:1.6;font-size:1.1rem}.hero-section{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:calc(100vh - 60px);background:linear-gradient(135deg,var(--primary-color),var(--background-dark));padding-top:4rem;padding-bottom:4rem;padding-left:0;padding-right:0;text-align:center;color:var(--text-color-secondary);position:relative;width:100%;max-width:none;box-sizing:border-box}.hero-content{max-width:800px;padding:0 2rem;position:relative;z-index:1}.hero-roman{font-size:1.3rem;color:var(--secondary-color);margin-bottom:.5rem;font-family:var(--heading-font);letter-spacing:.08em;font-weight:400}.hero-catch{font-size:1.25rem;color:var(--accent-color-2);margin-bottom:2.5rem;font-weight:600;letter-spacing:.05em}.social-label{margin-top:1.2rem;color:var(--secondary-color);font-size:1rem;letter-spacing:.04em;font-weight:500;text-align:center}.hero-content h1{font-size:3.5rem;margin-bottom:.7rem;font-weight:800;letter-spacing:.04em;color:var(--secondary-color);font-family:var(--heading-font);text-shadow:2px 2px 8px rgba(0,0,0,.08);animation:fadeInUp 1s cubic-bezier(.23,1,.32,1) .1s both}.hero-roman{animation:fadeInUp 1s cubic-bezier(.23,1,.32,1) .4s both}.hero-subtitle{animation:fadeInUp 1s cubic-bezier(.23,1,.32,1) .7s both}.hero-catch{animation:fadeInUpColor 1.2s cubic-bezier(.23,1,.32,1) 1.1s both}@keyframes fadeInUp{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUpColor{0%{opacity:0;transform:translateY(40px);color:var(--secondary-color)}80%{color:var(--secondary-color)}to{opacity:1;transform:translateY(0);color:var(--accent-color-2)}}.hero-subtitle{font-size:1.2rem;margin-bottom:.7rem;color:var(--secondary-color);font-weight:500;letter-spacing:.04em}.hero-buttons{display:flex;gap:1.5rem;justify-content:center;margin-bottom:3rem;animation:fadeInUp 1s ease .4s;animation-fill-mode:both}.primary-btn,.secondary-btn{padding:1.2rem 2.5rem;border-radius:50px;text-decoration:none;font-weight:600;font-size:1.1rem;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.primary-btn{background-color:var(--accent-color-1);color:var(--text-color-secondary);box-shadow:0 4px 15px #0000001a}.secondary-btn{border:2px solid var(--secondary-color);color:var(--primary-color-dark);background-color:var(--secondary-color);font-weight:700}.primary-btn:hover,.secondary-btn:hover{transform:translateY(-3px);box-shadow:0 6px 20px #00000026}.secondary-btn:hover{background-color:#fff;border-color:#fff;color:var(--primary-color)}.social-links{display:flex;gap:3rem;justify-content:center;animation:fadeInUp 1s ease .6s;animation-fill-mode:both;margin-bottom:4rem}.social-links a{color:var(--secondary-color);font-size:2.2rem;transition:all .3s ease;position:relative}.social-links a:hover{color:var(--accent-color-1);transform:translateY(-3px)}.scroll-indicator{position:absolute;bottom:3rem;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:.8rem;animation:bounce 2s infinite}.scroll-indicator span{font-size:1rem;color:var(--secondary-color);font-weight:500;text-shadow:0 1px 2px rgba(0,0,0,.2)}.about-section{background:linear-gradient(135deg,var(--background-light) 0%,var(--secondary-bg-color) 100%);padding-top:6rem;padding-bottom:6rem;position:relative;width:100%;max-width:none;box-sizing:border-box;margin:0}.about-content{max-width:1000px;margin:0 auto;padding:0 2rem}.about-card{background:var(--background-light);border-radius:20px;box-shadow:0 20px 40px #0000001a;overflow:hidden;position:relative;transition:all .3s ease}.about-card:hover{transform:translateY(-5px);box-shadow:0 30px 60px #00000026}.about-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--primary-color),var(--accent-color-2),var(--accent-color-1))}.about-header{display:flex;align-items:center;padding:3rem;background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-color-dark) 100%);color:var(--text-color-secondary);position:relative}.about-header:after{content:"";position:absolute;bottom:-20px;left:50%;transform:translate(-50%);width:0;height:0;border-left:20px solid transparent;border-right:20px solid transparent;border-top:20px solid var(--primary-color-dark)}.profile-image-container{position:relative;margin-right:2rem;display:flex;align-items:center;justify-content:center}.profile-image{width:120px;height:120px;border-radius:50%;object-fit:cover;border:4px solid var(--text-color-secondary);box-shadow:0 10px 20px #0003;transition:all .3s ease}.profile-image:hover{transform:scale(1.05);box-shadow:0 15px 30px #0000004d}.profile-status{position:absolute;bottom:-18px;right:-18px;background:var(--accent-color-2);color:var(--text-color-secondary);padding:.2rem 1rem;border-radius:20px;font-size:.85rem;font-weight:500;display:flex;align-items:center;gap:.5rem;box-shadow:0 2px 8px #0000002e;z-index:2;min-width:120px;justify-content:center;white-space:nowrap}@media (max-width: 600px){.profile-status{bottom:-12px;right:50%;left:50%;transform:translate(50%);min-width:90px;font-size:.75rem;padding:.15rem .7rem}}.status-dot{width:8px;height:8px;background:#4caf50;border-radius:50%;animation:pulse 2s infinite}@keyframes pulse{0%{opacity:1}50%{opacity:.5}to{opacity:1}}.profile-info{flex:1}.profile-name{font-size:2.2rem;font-weight:700;margin:0 0 .5rem;color:var(--text-color-secondary);font-family:var(--heading-font)}.profile-title{font-size:1.2rem;margin:0 0 1.5rem;color:var(--secondary-color);font-weight:400}.profile-details{display:flex;flex-direction:column;gap:.8rem}.detail-item{display:flex;align-items:center;gap:.8rem;font-size:1rem}.detail-item i{width:20px;color:var(--accent-color-2);font-size:1.1rem}.about-body{padding:3rem}.about-section-item{margin-bottom:2.5rem}.about-section-item:last-child{margin-bottom:0}.section-title{display:flex;align-items:center;gap:.8rem;font-size:1.4rem;color:var(--primary-color);margin:0 0 1.5rem;font-weight:600;position:relative;padding-bottom:.5rem}.section-title:after{content:"";position:absolute;bottom:0;left:0;width:40px;height:3px;background:var(--accent-color-1);border-radius:2px}.section-title i{color:var(--accent-color-1);font-size:1.2rem}.tech-stack{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.tech-category{background:var(--secondary-bg-color);padding:1.5rem;border-radius:12px;border:1px solid var(--border-color);transition:all .3s ease}.tech-category:hover{transform:translateY(-2px);box-shadow:0 8px 16px #0000001a;border-color:var(--accent-color-2)}.category-label{display:block;font-weight:600;color:var(--primary-color);margin-bottom:1rem;font-size:1rem;text-transform:uppercase;letter-spacing:.5px}.tech-tags{display:flex;flex-wrap:wrap;gap:.5rem}.tech-tag{background:var(--primary-color);color:var(--text-color-secondary);padding:.5rem 1rem;border-radius:20px;font-size:.85rem;font-weight:500;transition:all .3s ease;cursor:pointer}.tech-tag:hover{background:var(--accent-color-1);transform:translateY(-1px);box-shadow:0 4px 8px #00000026}.hobbies-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:1rem}.hobby-item{display:flex;flex-direction:column;align-items:center;text-align:center;padding:1.5rem 1rem;background:var(--secondary-bg-color);border-radius:12px;border:1px solid var(--border-color);transition:all .3s ease;cursor:pointer}.hobby-item:hover{transform:translateY(-3px);box-shadow:0 8px 16px #0000001a;border-color:var(--accent-color-2);background:var(--background-light)}.hobby-icon{width:50px;height:50px;background:linear-gradient(135deg,var(--primary-color),var(--accent-color-1));border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:1rem;color:var(--text-color-secondary);font-size:1.2rem;transition:all .3s ease}.hobby-item:hover .hobby-icon{transform:scale(1.1);box-shadow:0 4px 12px #0003}.hobby-item span{font-weight:500;color:var(--text-color-primary);font-size:.9rem}.about-description{font-size:1.1rem;line-height:1.8;color:var(--text-color-primary);background:var(--secondary-bg-color);padding:2rem;border-radius:12px;border-left:4px solid var(--accent-color-2);position:relative}.about-description:before{content:'"';position:absolute;top:-10px;left:20px;font-size:3rem;color:var(--accent-color-1);font-family:serif;line-height:1}@media (max-width: 768px){.about-header{flex-direction:column;text-align:center;padding:2rem}.profile-image-container{margin-right:0;margin-bottom:1.5rem}.profile-details{align-items:center}.tech-stack{grid-template-columns:1fr}.hobbies-grid{grid-template-columns:repeat(auto-fit,minmax(100px,1fr))}.about-body{padding:2rem}}@media (max-width: 480px){.about-card{margin:0 1rem}.profile-name{font-size:1.8rem}.profile-title{font-size:1rem}.section-title{font-size:1.2rem}.hobbies-grid{grid-template-columns:repeat(2,1fr)}}.experience-section{background-color:var(--secondary-bg-color);padding:6rem 2rem;width:100%;max-width:none;position:relative;box-sizing:border-box}.experience-section .timeline{max-width:1200px;margin:0 auto;padding:2rem}.timeline{position:relative;max-width:900px;margin:0 auto;padding:2rem 0;box-sizing:border-box}.timeline:before{content:"";position:absolute;left:50%;transform:translate(-50%);width:4px;height:100%;background:linear-gradient(to bottom,var(--primary-color) 0%,var(--accent-color-2) 70%,transparent 100%);z-index:1}.timeline-item{position:relative;width:100%;margin-bottom:2.5rem;display:flex;align-items:flex-start}.timeline-item:last-child{margin-bottom:0}.timeline-dot{position:absolute;left:50%;transform:translate(-50%);width:10px;height:10px;background-color:var(--primary-color);border-radius:50%;z-index:3;top:25px;border:2px solid var(--secondary-bg-color);box-sizing:content-box}.timeline-content{background:var(--background-light);border-radius:var(--border-radius-medium);box-shadow:var(--shadow-medium);transition:transform .3s ease,box-shadow .3s ease;position:relative;border:1px solid var(--card-border-color);padding:20px;width:calc(50% - 15px);box-sizing:border-box}.timeline-content .timeline-item{position:relative;width:100%;margin-bottom:2.5rem;display:flex;align-items:flex-start}.timeline-content .timeline-item .timeline-content{width:calc(50% - 30px);background:var(--card-bg-color);border-radius:var(--border-radius-md);padding:1.5rem;box-shadow:0 2px 4px var(--shadow-color);position:relative}.timeline-content .timeline-item:nth-child(2n){justify-content:flex-end}.timeline-content .timeline-item:nth-child(odd) .timeline-content{margin-left:30px}.timeline-content .timeline-item:nth-child(2n) .timeline-content{margin-right:30px}.timeline-content .timeline-item:nth-child(odd) .timeline-content:before{left:-8px;border-width:8px 8px 8px 0;border-color:transparent var(--card-bg-color) transparent transparent}.timeline-content .timeline-item:nth-child(2n) .timeline-content:before{right:-8px;border-width:8px 0 8px 8px;border-color:transparent transparent transparent var(--card-bg-color)}.timeline-content h3{color:var(--primary-color);margin-bottom:.5rem}.timeline-content p{color:var(--text-color-primary);margin-bottom:.5rem}.timeline-content ul{color:var(--text-color-primary);padding-left:1.5rem;margin-top:.5rem}.timeline-content ul li{margin-bottom:.25rem}.timeline-content:hover{transform:translateY(-5px);box-shadow:0 12px 30px #0000001f}.timeline-item:nth-child(odd) .timeline-content{margin-left:calc(50% + 10px);text-align:left}.timeline-item:nth-child(2n) .timeline-content{margin-left:5px;text-align:left}.timeline-content:before{content:"";position:absolute;top:25px;width:0;height:0;border-style:solid;z-index:1}.timeline-item:nth-child(odd) .timeline-content:before{left:-10px;border-width:10px 10px 10px 0;border-color:transparent var(--card-bg-color) transparent transparent}.timeline-item:nth-child(2n) .timeline-content:before{right:-10px;border-width:10px 0 10px 10px;border-color:transparent transparent transparent var(--card-bg-color)}.projects-section{background-color:var(--background-dark);padding:6rem 2rem;width:100%;max-width:none;box-sizing:border-box;overflow:hidden}.projects-section h2{color:var(--secondary-color)}.projects-section h2:after{background:var(--accent-color-1)}.projects-carousel{display:flex;align-items:center;position:relative;width:90%;max-width:1200px;margin:20px auto;box-sizing:border-box}.project-viewport{flex-grow:1;overflow:hidden;box-sizing:border-box}.projects-container{display:flex;transition:transform .5s ease-in-out;box-sizing:border-box;height:100%}.project-card{box-sizing:border-box;padding:25px;display:flex;flex-direction:column;align-items:center;text-align:center;justify-content:space-between;background-color:var(--card-bg-color);color:var(--text-color);border-radius:var(--border-radius-large);box-shadow:var(--shadow-medium);margin:0;min-height:500px;border:1px solid var(--card-border-color)}.project-card .project-image{width:100%;height:350px;object-fit:contain;border-radius:16px;margin-bottom:1.5rem}.project-card .project-title{font-size:1.5rem;font-weight:600;margin-bottom:15px;color:var(--primary-color);font-family:var(--heading-font);transition:all .3s ease}.project-card:hover .project-title{color:var(--primary-color-dark)}.project-card .project-description{font-size:1rem;line-height:1.6;margin-bottom:15px;flex-grow:1;max-width:90%;color:var(--text-color)}.project-card .project-tech{width:100%;margin-bottom:20px}.project-card .project-tech h4{font-size:1rem;margin:0 0 8px;color:var(--primary-color);font-weight:600}.project-card .tech-tags{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.project-card .tech-tag{background-color:var(--primary-color-light);color:#fff;padding:4px 10px;border-radius:15px;font-size:.75rem;font-weight:500;display:inline-block;transition:all .2s ease}.project-card .tech-tag:hover{transform:translateY(-2px);background-color:var(--primary-color);box-shadow:0 2px 4px #0000001a}.project-card .project-buttons{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}.project-card .project-link{padding:10px 15px;background-color:var(--primary-color);color:var(--button-text-color, white);text-decoration:none;border-radius:var(--border-radius-small);transition:background-color .3s ease,transform .2s ease;font-weight:500;display:inline-block;font-size:.9rem}.project-card .project-link.demo-link{background-color:var(--accent-color-1)}.project-card .project-link.github-link{background-color:var(--accent-color-2)}.project-card .project-link:hover{background-color:var(--primary-color-dark);transform:translateY(-2px)}.project-card .project-link.demo-link:hover{background-color:#8a7369}.project-card .project-link.github-link:hover{background-color:#6aad6d}.contact-section{background-color:var(--background-dark);padding-top:6rem;padding-bottom:6rem;padding-left:0;padding-right:0;width:100%;max-width:none;box-sizing:border-box;color:var(--text-color-secondary)}.contact-section h2{color:var(--secondary-color)}.contact-content{display:grid;grid-template-columns:1fr 1.5fr;gap:4rem;max-width:1100px;margin:0 auto;align-items:flex-start;padding:0 2rem}.contact-info h3{font-size:2rem;color:var(--accent-color-1);margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid var(--accent-color-1-rgb-transparent, rgba(161, 136, 127, .5));display:inline-block}.contact-info p{font-size:1.1rem;line-height:1.7;margin-bottom:2rem;color:var(--secondary-color)}.contact-details{display:flex;flex-direction:column;gap:1.5rem}.contact-item{display:flex;align-items:center;gap:1.2rem}.contact-item i{font-size:1.8rem;color:var(--accent-color-1);width:35px;text-align:center}.contact-item p{margin:0;font-size:1rem;color:var(--secondary-color)}.form-group{margin-bottom:1.8rem}.form-group label{display:block;margin-bottom:.6rem;font-weight:600;font-size:1.05rem;color:var(--secondary-color)}.form-group input,.form-group textarea{width:100%;padding:1.2rem;border-radius:var(--border-radius-medium);border:1px solid rgba(var(--accent-color-2-rgb, 0, 123, 255),.5);background-color:var(--primary-color-dark);color:var(--text-color-secondary);font-size:1rem;transition:border-color .3s ease,box-shadow .3s ease;box-sizing:border-box}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--accent-color-1);box-shadow:0 0 0 4px rgba(var(--accent-color-1-rgb, 161, 136, 127),.35)}.form-group textarea{min-height:160px;resize:vertical}.submit-btn{background-color:var(--accent-color-1);color:var(--text-color-secondary);padding:1.2rem 3rem;border:none;border-radius:var(--border-radius-medium);font-size:1.15rem;font-weight:600;cursor:pointer;transition:background-color .3s ease,transform .2s ease,box-shadow .3s ease;box-shadow:var(--shadow-light)}.submit-btn:hover{background-color:var(--accent-color-1-dark, #8A7367);transform:translateY(-3px);box-shadow:var(--shadow-medium)}@media (max-width: 992px){.about-content{grid-template-columns:1fr;gap:3rem}.about-text{order:1}.about-image{order:2;margin-top:2rem}.about-image img{width:300px}.contact-content{grid-template-columns:1fr;gap:3rem}}@media (max-width: 768px){section{padding:4rem 1rem;max-width:100%;box-sizing:border-box}section h2{font-size:2rem}.hero-section{max-width:100%;box-sizing:border-box;padding-left:1rem;padding-right:1rem}.hero-content{padding:0 1rem}.hero-content h1{font-size:2.2rem}.hero-roman,.hero-catch{font-size:1.05rem}.hero-buttons{flex-direction:column;gap:.7rem}.primary-btn,.secondary-btn{width:auto;min-width:0;text-align:center;padding-left:1.5rem;padding-right:1.5rem;font-size:1rem}.projects-carousel{width:100%;padding:0 1rem;box-sizing:border-box}.project-card{margin:0;padding:2rem}.carousel-button{width:50px;height:50px;font-size:1.8rem}.carousel-indicators{bottom:-30px}}@media (max-width: 576px){.hero-content h1{font-size:2.5rem}.hero-subtitle{font-size:1.3rem}.about-image img{width:100%;max-width:250px}}.news-section{padding:60px 20px;background-color:var(--secondary-bg-color);text-align:center}.news-section h2{font-size:2.5rem;color:var(--primary-color);margin-bottom:40px}.news-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:30px;max-width:1200px;margin:0 auto;text-align:left}.news-section{background-color:var(--secondary-bg-color);padding-top:6rem;padding-bottom:6rem;padding-left:0;padding-right:0;width:100%;max-width:none;box-sizing:border-box}.news-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2.5rem;max-width:1200px;margin:0 auto;padding:0 2rem}.news-item{background-color:var(--card-bg-color);padding:25px;border-radius:var(--border-radius-medium);box-shadow:var(--shadow-medium);border:1px solid var(--card-border-color);transition:transform .3s ease-in-out,box-shadow .3s ease-in-out}.news-date{font-size:.9rem;color:var(--text-color-light);margin-bottom:8px}.news-title{font-size:1.5rem;color:var(--primary-color-dark);margin-bottom:12px;font-family:var(--heading-font);transition:all .3s ease;position:relative;padding-bottom:5px;display:inline-block}.news-title:after{content:"";position:absolute;bottom:0;left:0;width:0;height:2px;background-color:var(--accent-color-1);transition:width .3s ease}.news-item:hover .news-title{color:var(--primary-color)}.news-item:hover .news-title:after{width:100%}.news-content{font-size:1rem;line-height:1.6;color:var(--text-color);margin-bottom:15px}.news-link{display:inline-block;font-weight:500;color:var(--primary-color);text-decoration:none;transition:color .3s ease}.news-link:hover{color:var(--primary-color-dark);text-decoration:underline}.news-link i{margin-left:5px;transition:transform .3s ease}.news-link:hover i{transform:translate(3px)}@media (max-width: 768px){.news-section h2{font-size:2rem}.news-title{font-size:1.3rem}}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0) translate(-50%)}40%{transform:translateY(-15px) translate(-50%)}60%{transform:translateY(-10px) translate(-50%)}}.projects-carousel .carousel-button{background-color:#fff;color:var(--primary-color);border:none;padding:0;border-radius:50%;cursor:pointer;position:absolute;top:50%;transform:translateY(-50%);z-index:10;width:50px;height:50px;display:flex;align-items:center;justify-content:center;transition:all .3s ease;box-shadow:0 4px 12px #0003}.projects-carousel .carousel-button i{font-size:2.2rem;color:var(--primary-color);transition:transform .3s ease}.projects-carousel .carousel-button.prev{left:-25px}.projects-carousel .carousel-button.next{right:-25px}.projects-carousel .carousel-button:hover{background-color:var(--primary-color)}.projects-carousel .carousel-button:hover i{color:#fff}.projects-carousel .carousel-button.prev:hover i{transform:translate(-4px)}.projects-carousel .carousel-button.next:hover i{transform:translate(4px)}.projects-carousel .carousel-button:active{background-color:var(--primary-color-dark);transform:translateY(-50%) scale(.95);box-shadow:0 2px 8px #0003}.projects-carousel .carousel-button:active i{color:#fff}html,body{overflow-x:hidden}body{position:relative}@media (max-width: 992px){.timeline{padding-left:0}.timeline:before{left:10px;transform:none;width:5px}.timeline-dot{left:-28px;transform:none;margin-top:0;top:25px;width:15px;height:15px;border:1px solid var(--secondary-bg-color)}.timeline-item:nth-child(odd) .timeline-content,.timeline-item:nth-child(2n) .timeline-content{margin-left:0;width:calc(100% - 20px);text-align:left}.timeline-item:nth-child(odd) .timeline-content:before,.timeline-item:nth-child(2n) .timeline-content:before{left:-8px;border-width:8px 8px 8px 0;border-color:transparent var(--card-bg-color) transparent transparent;right:auto}.timeline-item{align-items:flex-start;padding-left:0}}.profile-roman{font-size:1rem;color:var(--secondary-color);margin:0 0 .5rem;font-family:var(--heading-font);letter-spacing:.05em}.project-images{display:flex;flex-direction:row;gap:1.5rem;margin-bottom:2rem}.project-title-image,.project-content-image{width:50%;height:320px;object-fit:contain;border-radius:16px;background-color:transparent;border:none}@media (max-width: 768px){.project-card .project-image{height:250px}}.news-show-more{text-align:center;margin-top:40px;padding:20px 0}.show-more-btn{background:linear-gradient(135deg,var(--primary-color) 0%,var(--accent-color-1) 100%);color:#fff;border:none;padding:15px 30px;border-radius:50px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 15px #0003;position:relative;overflow:hidden;min-width:140px}.show-more-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.show-more-btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px #0000004d;background:linear-gradient(135deg,var(--primary-color-dark) 0%,var(--accent-color-2) 100%)}.show-more-btn:hover:before{left:100%}.show-more-btn:active{transform:translateY(0);box-shadow:0 4px 15px #0003}.news-item{animation:fadeInUp .6s ease-out;animation-fill-mode:both}.news-item:nth-child(1){animation-delay:.1s}.news-item:nth-child(2){animation-delay:.2s}.news-item:nth-child(3){animation-delay:.3s}.news-item:nth-child(4){animation-delay:.4s}.news-item:nth-child(5){animation-delay:.5s}.news-item:nth-child(6){animation-delay:.6s}.news-item:nth-child(7){animation-delay:.7s}.news-item:nth-child(8){animation-delay:.8s}.show-more-btn.loading{pointer-events:none;opacity:.7}.show-more-btn.loading:after{content:"";position:absolute;top:50%;left:50%;width:20px;height:20px;margin:-10px 0 0 -10px;border:2px solid transparent;border-top:2px solid white;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 768px){.show-more-btn{padding:12px 24px;font-size:.9rem;min-width:120px}.news-show-more{margin-top:30px;padding:15px 0}}.news-section{transition:all .3s ease;overflow:hidden}.news-container{transition:all .3s ease;display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2.5rem;max-width:1200px;margin:0 auto;padding:0 2rem}.news-item{background-color:var(--card-bg-color);padding:25px;border-radius:var(--border-radius-medium);box-shadow:var(--shadow-medium);border:1px solid var(--card-border-color);transition:all .3s ease;animation:fadeInUp .6s ease-out;animation-fill-mode:both}.news-item:hover{transform:translateY(-5px);box-shadow:var(--shadow-large)}.news-container{transition:max-height .3s ease,opacity .3s ease}.news-item.expanding,.news-item.collapsing,.news-container.expanding,.news-container.collapsing{animation:none}.news-section{background-color:var(--secondary-bg-color);padding-top:6rem;padding-bottom:6rem;padding-left:0;padding-right:0;width:100%;max-width:none;box-sizing:border-box;transition:all .5s cubic-bezier(.4,0,.2,1);overflow:hidden}.news-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2.5rem;max-width:1200px;margin:0 auto;padding:0 2rem;transition:all .5s cubic-bezier(.4,0,.2,1);opacity:1;transform:scale(1)}.news-item{background-color:var(--card-bg-color);padding:25px;border-radius:var(--border-radius-medium);box-shadow:var(--shadow-medium);border:1px solid var(--card-border-color);transition:all .4s cubic-bezier(.4,0,.2,1);animation:fadeInUp .6s ease-out;animation-fill-mode:both;opacity:1;transform:translateY(0) scale(1)}.news-item.new-item{animation:fadeInScale .6s cubic-bezier(.4,0,.2,1) forwards}@keyframes fadeInScale{0%{opacity:0;transform:translateY(20px) scale(.95)}50%{opacity:.7;transform:translateY(10px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.news-container.expanding{animation:containerExpand .5s cubic-bezier(.4,0,.2,1) forwards}@keyframes containerExpand{0%{opacity:.8;transform:scale(.98)}to{opacity:1;transform:scale(1)}}.news-container{transition:all .5s cubic-bezier(.4,0,.2,1)}.news-item:hover{transform:translateY(-5px) scale(1.02);box-shadow:var(--shadow-large)}
