*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;background:#050505;color:#fff;font-family:Inter,Arial,sans-serif;overflow-x:hidden}button,a{font:inherit}.bg{position:fixed;top:0;right:0;bottom:0;left:0;z-index:-2;background:radial-gradient(circle at 50% 0%,#1a1a1a,#050505 55%);overflow:hidden}.dots{position:absolute;top:-100px;right:-100px;bottom:-100px;left:-100px;background-image:radial-gradient(rgba(255,255,255,.22) 1px,transparent 1px);background-size:32px 32px;animation:dots 18s linear infinite}.glow{position:absolute;width:420px;height:420px;border-radius:50%;filter:blur(30px);opacity:.22;animation:float 9s ease-in-out infinite}.g1{background:#6c7cff;left:-120px;top:140px}.g2{background:#fff;right:-160px;bottom:100px;animation-delay:-3s}@keyframes dots{to{transform:translate3d(-64px,-64px,0)}}@keyframes float{50%{transform:translate(90px,55px)}}.splash{height:100vh;min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:22px;background:#000;text-align:center}.splash-logo{font-size:76px;font-weight:900;letter-spacing:-6px;animation:pulse 1.8s ease-in-out infinite}.splash p{margin:0;color:#fff;font-size:20px}.loader{display:flex;gap:9px;position:static;margin-top:10px}.loader span{width:9px;height:9px;border-radius:50%;background:#fff;animation:bounce 1s infinite}.loader span:nth-child(2){animation-delay:.16s}.loader span:nth-child(3){animation-delay:.32s}@keyframes pulse{50%{transform:scale(1.08);opacity:.72}}@keyframes bounce{50%{transform:translateY(-12px);opacity:.45}}.modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:20;background:#000000b8;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);display:grid;place-items:center;padding:20px}.modal-card{max-width:460px;background:#ffffff14;border:1px solid rgba(255,255,255,.16);border-radius:28px;padding:34px;text-align:center;box-shadow:0 30px 80px #00000080}.modal h2{font-size:42px;margin:0 0 10px}.modal p{color:#cfcfcf;line-height:1.6}.modal button,.hero-actions button,.chat form button{border:0;border-radius:999px;background:#fff;color:#050505;padding:14px 24px;font-weight:800;cursor:pointer}.nav{position:sticky;top:18px;z-index:10;max-width:1180px;margin:18px auto 0;padding:14px 18px;border:1px solid rgba(255,255,255,.12);background:#0a0a0aa8;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);border-radius:999px;display:flex;justify-content:space-between;align-items:center}.brand{font-weight:900;letter-spacing:-.5px}.nav nav{display:flex;gap:20px}.nav button{background:transparent;border:0;color:#ffffff9e;cursor:pointer;font-weight:700;transition:.25s}.nav button:hover{color:#fff}main{max-width:1180px;margin:auto;padding:0 24px}.hero{min-height:760px;display:grid;grid-template-columns:1.25fr .75fr;align-items:center;gap:42px}.eyebrow{color:#ffffff8c;letter-spacing:2px;text-transform:uppercase;font-size:13px;font-weight:800}.hero h1,.section h2,.contact h2{font-size:clamp(44px,7vw,86px);line-height:.98;margin:12px 0;font-weight:950;letter-spacing:-4px}.hero p:not(.eyebrow),.about p{font-size:18px;color:#ffffffb3;line-height:1.65;max-width:650px}.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:30px}.hero-actions .ghost{background:#ffffff14;color:#fff;border:1px solid rgba(255,255,255,.14)}.hero-img{border:1px solid rgba(255,255,255,.12);border-radius:42px;overflow:hidden;background:#ffffff0d;height:560px}.hero-img img,.project img,.gallery img{width:100%;height:100%;object-fit:cover;display:block}.section{padding-top:110px;scroll-margin-top:110px}.section h2,.contact h2{font-size:clamp(34px,5vw,58px);max-width:780px;letter-spacing:-2px}.cards,.service-grid,.about-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}.project,.service-grid article,.contact,.about-grid>div{border:1px solid rgba(255,255,255,.1);background:#ffffff0e;border-radius:34px;overflow:hidden}.project img{height:380px}.project div,.service-grid article,.about-grid>div{padding:26px}.project h3,.service-grid h3,.about h3{font-size:24px;margin:0 0 10px}.project p,.service-grid p,li{color:#ffffffad;line-height:1.6}.project a{color:#fff;font-weight:900;text-decoration:none}.service-grid small{color:#ffffff73;font-weight:900}.skills{display:flex;flex-wrap:wrap;gap:10px;align-content:flex-start}.skills span{border:1px solid rgba(255,255,255,.12);background:#ffffff12;padding:10px 14px;border-radius:999px;color:#eee;font-weight:700}.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;padding-top:100px}.gallery img{height:390px;border-radius:32px}.contact{margin-top:110px;padding:54px}.icons{display:flex;gap:14px;margin-top:26px;flex-wrap:wrap}.icons a{width:56px;height:56px;border-radius:50%;display:grid;place-items:center;color:#fff;text-decoration:none;border:1px solid rgba(255,255,255,.15);background:#ffffff14;font-size:24px;font-weight:900;transition:.25s}.icons a:hover{background:#fff;color:#050505;transform:translateY(-3px)}.chat-float{position:fixed;right:24px;bottom:24px;z-index:15;width:64px;height:64px;border-radius:50%;border:0;background:#fff;color:#050505;font-weight:950;box-shadow:0 20px 60px #00000080;cursor:pointer}.chat{position:fixed;right:24px;bottom:100px;z-index:16;width:min(380px,calc(100vw - 32px));height:520px;background:#101010;border:1px solid rgba(255,255,255,.14);border-radius:28px;overflow:hidden;box-shadow:0 30px 90px #000000a6;display:flex;flex-direction:column}.chat-head{display:flex;justify-content:space-between;align-items:center;padding:16px 18px;border-bottom:1px solid rgba(255,255,255,.1)}.chat-head button{background:transparent;color:#fff;border:0;font-size:28px;cursor:pointer}.chat-body{flex:1;overflow:auto;padding:16px;display:flex;flex-direction:column;gap:10px}.msg{padding:12px 14px;border-radius:18px;line-height:1.45;color:#e8e8e8}.msg.bot{background:#ffffff14;align-self:flex-start}.msg.user{background:#fff;color:#050505;align-self:flex-end}.chat form{display:flex;gap:8px;padding:12px;border-top:1px solid rgba(255,255,255,.1)}.chat input{flex:1;background:#ffffff14;border:1px solid rgba(255,255,255,.12);border-radius:999px;color:#fff;padding:12px 14px;outline:none}footer{max-width:1180px;margin:40px auto;padding:0 24px 40px;color:#ffffff73}@media (max-width:760px){.nav{border-radius:26px;align-items:flex-start;gap:12px;flex-direction:column}.nav nav{gap:13px;flex-wrap:wrap}.hero{grid-template-columns:1fr;min-height:auto;padding-top:70px}.hero-img{height:430px}.cards,.service-grid,.about-grid,.gallery{grid-template-columns:1fr}.project img,.gallery img{height:320px}.contact{padding:30px}.hero h1{letter-spacing:-2px}.splash{gap:18px}.splash-logo{font-size:72px}.splash p{font-size:18px}.loader{margin-top:2px}.chat{left:12px;right:12px;bottom:82px;width:auto;height:min(640px,calc(100dvh - 105px));border-radius:24px}.chat-head{padding:14px 16px}.chat-body{padding:12px;gap:10px}.clock{font-size:12px;padding:9px 14px}.meeting-form{width:100%;gap:12px}.meeting-form input,.meeting-form textarea{font-size:16px;min-height:52px;border-radius:16px}.meeting-form input[type=date],.meeting-form input[type=time]{height:54px;line-height:54px;text-align:left;-webkit-appearance:none;-moz-appearance:none;appearance:none}.meeting-form label{font-size:14px;margin-top:2px}.chat form.chat-form{padding:10px}.chat-form input{min-width:0}.chat-float{right:16px;bottom:16px}}.clock{padding:10px 16px;color:#ffffff9e;font-size:13px;border-bottom:1px solid rgba(255,255,255,.08)}.meeting-form{display:flex!important;flex-direction:column!important;border:1px solid rgba(255,255,255,.1)!important;border-radius:18px!important;padding:12px!important;background:#ffffff0a!important;margin-top:4px!important}.meeting-form input,.meeting-form textarea{width:100%;background:#ffffff14;border:1px solid rgba(255,255,255,.12);border-radius:14px;color:#fff;padding:12px 14px;outline:none;font:inherit}.meeting-form textarea{min-height:78px;resize:vertical}.meeting-form button{border-radius:14px!important}.chat-form{flex-shrink:0}.tutoring{margin-top:100px;border:1px solid rgba(255,255,255,.1);background:#ffffff0f;border-radius:34px;padding:42px}.tutoring h2{font-size:clamp(32px,5vw,56px);line-height:1;margin:10px 0;letter-spacing:-2px}.tutoring p:not(.eyebrow){color:#ffffffad;line-height:1.6;font-size:17px;max-width:760px}.chat,.chat *{box-sizing:border-box;min-width:0}.meeting-form{max-width:100%;overflow:hidden;gap:10px}.meeting-form label{color:#fff;font-weight:800}.meeting-form input,.meeting-form textarea{max-width:100%}.form-error{margin:-4px 0 2px;color:#ff9b9b;font-size:13px;line-height:1.35;font-weight:700}@media (max-width:760px){.chat{height:calc(100dvh - 96px);max-height:720px;bottom:76px;display:flex;flex-direction:column;overflow:hidden}.chat-body{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding-bottom:22px;max-height:none}.meeting-form{margin-bottom:18px!important;padding-bottom:16px!important}.meeting-form button{min-height:54px;width:100%;font-size:16px;margin-top:4px}.chat-form{position:sticky;bottom:0;background:#101010;z-index:2}}.meeting-form{scroll-margin-bottom:120px}.meeting-form input:invalid{box-shadow:none}.meeting-form input[type=email]:focus{border-color:#ffffff59}@media (max-width:760px){.chat{max-height:calc(100dvh - 94px)!important}.chat-body{overscroll-behavior:contain;padding-bottom:34px!important}.meeting-form{margin-bottom:34px!important}.chat form.chat-form{flex-shrink:0}.project h3{font-size:22px}}.chat-body{min-height:0}.meeting-form{flex-shrink:0}@media (max-width:760px){.chat{position:fixed!important;top:0!important;right:0!important;bottom:0!important;left:0!important;width:100vw!important;height:100dvh!important;max-height:none!important;border-radius:0!important;display:flex!important;flex-direction:column!important;overflow:hidden!important}.chat-head,.clock{flex-shrink:0!important}.chat-body{flex:1 1 auto!important;min-height:0!important;overflow-y:auto!important;-webkit-overflow-scrolling:touch!important;padding:14px 14px 26px!important}.chat.calendar-open .chat-form{display:none!important}.meeting-form{width:100%!important;max-width:100%!important;gap:14px!important;padding:14px!important;margin:8px 0 28px!important;overflow:visible!important}.meeting-form input,.meeting-form textarea{width:100%!important;min-height:54px!important;font-size:16px!important;border-radius:18px!important}.meeting-form input[type=date],.meeting-form input[type=time]{display:block!important;height:58px!important;line-height:normal!important;text-align:left!important;padding:12px 14px!important}.meeting-form textarea{min-height:110px!important}.meeting-form button{width:100%!important;min-height:58px!important;margin-bottom:22px!important}}
