/*! tailwindcss v4.3.0 | MIT License | https://tailwindcss.com */
@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-outline-style:solid}}}.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.border{border-style:var(--tw-border-style);border-width:1px}.uppercase{text-transform:uppercase}.italic{font-style:italic}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,ease);transition-duration:var(--tw-duration,0s)}*,:before,:after{box-sizing:border-box}html{scroll-behavior:smooth}body{color:#1a2456;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#fff;font-family:Noto Sans JP,sans-serif}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:#f7f8fa}::-webkit-scrollbar-thumb{background:#bcccdc;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#829ab1}.fade-in-up{opacity:0;transition:opacity .6s ease-out,transform .6s ease-out;transform:translateY(24px)}.fade-in-up.visible{opacity:1;transform:translateY(0)}.card-hover{transition:transform .3s,box-shadow .3s,border-color .3s}.card-hover:hover{transform:translateY(-4px);box-shadow:0 4px 12px #1a24561a,0 8px 24px #1a24560f}.border-reveal{position:relative;overflow:hidden}.border-reveal:after{content:"";transform-origin:0;background:linear-gradient(90deg,#1a2456,#e8a0b0,#00b4d8);height:2px;transition:transform .4s;position:absolute;bottom:0;left:0;right:0;transform:scaleX(0)}.border-reveal:hover:after{transform:scaleX(1)}.section-fade{opacity:0;transition:opacity .8s ease-out,transform .8s ease-out;transform:translateY(20px)}.section-fade.visible{opacity:1;transform:translateY(0)}.skill-tag{transition:background-color .2s,color .2s,transform .2s}.skill-tag:hover{color:#fff;background-color:#1a2456;transform:translateY(-1px)}.nav-link{text-decoration:none;position:relative}.nav-link:after{content:"";background:#1a2456;width:0;height:1px;transition:width .3s;position:absolute;bottom:-2px;left:0}.nav-link:hover:after{width:100%}.btn-primary{color:#fff;background-color:#1a2456;border-radius:6px;align-items:center;gap:8px;padding:10px 24px;font-size:14px;font-weight:500;text-decoration:none;transition:background-color .2s,transform .2s,box-shadow .2s;display:inline-flex}.btn-primary:hover{background-color:#0f1a3d;transform:translateY(-1px);box-shadow:0 4px 12px #1a245633}.btn-secondary{color:#1a2456;background-color:#0000;border:1px solid #1a2456;border-radius:6px;align-items:center;gap:8px;padding:10px 24px;font-size:14px;font-weight:500;text-decoration:none;transition:background-color .2s,color .2s,transform .2s;display:inline-flex}.btn-secondary:hover{color:#fff;background-color:#1a2456;transform:translateY(-1px)}.dot-pattern{background-image:radial-gradient(circle,#d9e2ec 1px,#0000 1px);background-size:24px 24px}.container-custom{max-width:1120px;margin:0 auto;padding:0 24px}.section-padding{padding:80px 0}@media (width<=768px){.desktop-nav{display:none!important}.hamburger-btn{display:flex!important}.mobile-menu{background-color:#fff;border-top:1px solid #eef0f5;flex-direction:column;display:none!important}.mobile-menu-open{display:flex!important}.language-switcher{gap:8px!important}}@media (width>=769px){.mobile-menu{display:none!important}}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}
