*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--black: #0a0a0a;--white: #fafaf8;--gray: #6b6b6b;--light: #efefec;--accent: #1a1a1a;--pnum: #cfcfcf;--line: rgba(0,0,0,.1)}html{scroll-behavior:smooth}body{font-family:DM Sans,sans-serif;background:var(--white);color:var(--black);font-size:16px;line-height:1.6;overflow-x:hidden}nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;justify-content:space-between;align-items:center;padding:1.4rem 5vw;background:#fafaf8d9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);animation:fadeDown .8s ease both}.logo{font-family:"DM Serif Display",serif;font-size:1.5rem;letter-spacing:-.02em;color:var(--black);text-decoration:none}.nav-links{display:flex;gap:2.5rem;list-style:none}.nav-links a{font-size:.875rem;font-weight:400;color:var(--gray);text-decoration:none;letter-spacing:.02em;transition:color .2s}.nav-links a:hover{color:var(--black)}.nav-cta{font-size:.875rem;font-weight:500;background:var(--black);color:var(--white);padding:.55rem 1.4rem;border-radius:100px;text-decoration:none;transition:background .2s,transform .15s}.nav-cta:hover{background:#333;transform:translateY(-1px)}#hero{min-height:100vh;display:grid;grid-template-columns:1fr 1fr;align-items:center;padding:8rem 5vw 5rem;gap:4rem;position:relative;overflow:hidden}.hero-bg{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 60% 50% at 80% 40%,rgba(0,0,0,.04) 0%,transparent 70%),radial-gradient(ellipse 40% 40% at 20% 70%,rgba(0,0,0,.03) 0%,transparent 70%);pointer-events:none}.hero-grid-lines{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:80px 80px;-webkit-mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black 30%,transparent 100%);mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black 30%,transparent 100%);opacity:.5;pointer-events:none}.hero-left{position:relative;z-index:1}.hero-tag{display:inline-block;font-size:.75rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--gray);border:1px solid var(--line);padding:.4rem 1rem;border-radius:100px;margin-bottom:2rem;animation:fadeUp .9s .2s ease both}h1{font-family:"DM Serif Display",serif;font-size:clamp(3rem,5.5vw,5.5rem);line-height:1.05;letter-spacing:-.03em;margin-bottom:1.5rem;animation:fadeUp .9s .35s ease both}h1 em{font-style:italic;color:var(--gray)}.hero-sub{font-size:1.05rem;font-weight:300;color:var(--gray);max-width:40ch;margin-bottom:2.5rem;animation:fadeUp .9s .5s ease both}.hero-actions{display:flex;gap:1rem;align-items:center;animation:fadeUp .9s .65s ease both}.btn-primary{display:inline-flex;align-items:center;gap:.5rem;background:var(--black);color:var(--white);font-size:.9rem;font-weight:500;padding:.85rem 1.8rem;border-radius:100px;text-decoration:none;transition:background .2s,transform .15s}.btn-primary:hover{background:#333;transform:translateY(-2px)}.btn-ghost{display:inline-flex;align-items:center;gap:.4rem;font-size:.9rem;font-weight:400;color:var(--gray);text-decoration:none;transition:color .2s}.btn-ghost:hover{color:var(--black)}.btn-ghost svg{transition:transform .2s}.btn-ghost:hover svg{transform:translate(3px)}.hero-right{position:relative;z-index:1;animation:fadeUp .9s .5s ease both}.stat-card{background:var(--white);border:1px solid var(--line);border-radius:20px;padding:2.5rem;box-shadow:0 4px 40px #0000000f}.stat-card-label{font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gray);margin-bottom:2rem}.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-bottom:2rem}.stat-item .num{font-family:"DM Serif Display",serif;font-size:2.8rem;line-height:1;letter-spacing:-.03em}.stat-item .desc{font-size:.82rem;color:var(--gray);margin-top:.3rem}.stat-divider{height:1px;background:var(--line);margin:1.5rem 0}.stack-pills{display:flex;flex-wrap:wrap;gap:.5rem}.pill{font-size:.78rem;font-weight:400;background:var(--light);color:var(--accent);padding:.35rem .85rem;border-radius:100px}section{padding:7rem 5vw}.section-label{font-size:.75rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gray);margin-bottom:1rem}.section-title{font-family:"DM Serif Display",serif;font-size:clamp(2rem,3.5vw,3.2rem);line-height:1.1;letter-spacing:-.025em;max-width:18ch;margin-bottom:1rem}.section-sub{font-size:1rem;font-weight:300;color:var(--gray);max-width:50ch;margin-bottom:4rem}.marquee-section{position:relative;padding:2.5rem 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden;transition:border-color .4s ease}.marquee-section--active{border-color:transparent}.marquee-bg-fill{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--black);clip-path:circle(0% at 50% 50%);transition:clip-path .55s cubic-bezier(.4,0,.2,1);pointer-events:none;z-index:0}.marquee-header{position:relative;z-index:1;display:flex;align-items:center;justify-content:center;gap:2rem;margin-bottom:1.5rem;min-height:1.5rem}.marquee-label{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gray);opacity:.6;transition:color .4s ease,opacity .4s ease;white-space:nowrap}.marquee-section--active .marquee-label{color:#fff6;opacity:1}.marquee-meta{display:flex;align-items:center;gap:.75rem;opacity:0;transform:translateY(6px);transition:opacity .3s ease .05s,transform .3s ease .05s;pointer-events:none}.marquee-meta--visible{opacity:1;transform:translateY(0);pointer-events:auto}.marquee-meta-category{font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:#ffffff8c}.marquee-meta-dot{width:3px;height:3px;border-radius:50%;background:#ffffff40;flex-shrink:0}.marquee-meta-year{font-size:.72rem;letter-spacing:.08em;color:#ffffff59}.marquee-meta-link{font-size:.72rem;letter-spacing:.08em;color:var(--white);text-decoration:none;border-bottom:1px solid rgba(255,255,255,.3);padding-bottom:1px;transition:border-color .2s}.marquee-meta-link:hover{border-color:var(--white)}.marquee-outer{position:relative;z-index:1;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,black 10%,black 90%,transparent);mask-image:linear-gradient(90deg,transparent,black 10%,black 90%,transparent)}.marquee-track{display:flex;width:max-content;animation:marquee 28s linear infinite}.marquee-track--paused{animation-play-state:paused}.marquee-logo{font-family:"DM Serif Display",serif;font-size:1.1rem;letter-spacing:-.01em;color:var(--gray);text-decoration:none;opacity:.5;padding:0 3rem;white-space:nowrap;transition:opacity .25s ease,color .25s ease}.marquee-logo--active{color:var(--white);opacity:1}.marquee-logo--dim{opacity:.18;color:var(--gray)}@keyframes marquee{0%{transform:translate(0)}to{transform:translate(-50%)}}#work{padding:7rem 5vw}.work-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}.work-card{border:1px solid var(--line);border-radius:16px;padding:2rem;display:flex;flex-direction:column;gap:.9rem;transition:box-shadow .25s,transform .25s}.work-card:hover{box-shadow:0 8px 40px #00000012;transform:translateY(-3px)}.work-tag{font-size:.72rem;font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:var(--gray)}.work-title{font-family:"DM Serif Display",serif;font-size:1.25rem;letter-spacing:-.02em;line-height:1.2;color:var(--black)}.work-desc{font-size:.875rem;font-weight:300;color:var(--gray);line-height:1.65;flex:1}.work-metric{display:flex;align-items:baseline;gap:.5rem;padding-top:.8rem;border-top:1px solid var(--line);margin-top:auto}.work-metric-num{font-family:"DM Serif Display",serif;font-size:2rem;letter-spacing:-.03em;line-height:1;color:var(--black)}.work-metric-label{font-size:.8rem;color:var(--gray)}#services{background:var(--black);color:var(--white)}#services .section-label{color:#fff6}#services .section-title{color:var(--white)}#services .section-sub{color:#ffffff80}.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:#ffffff14;border:1px solid rgba(255,255,255,.08);border-radius:20px;overflow:hidden}.service-card{background:var(--black);padding:2.5rem;transition:background .25s;position:relative;overflow:hidden}.service-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,rgba(255,255,255,.03) 0%,transparent 60%);opacity:0;transition:opacity .3s}.service-card:hover{background:#111}.service-card:hover:before{opacity:1}.service-icon{width:44px;height:44px;border-radius:12px;border:1px solid rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center;margin-bottom:1.8rem;font-size:1.2rem}.service-card h3{font-family:"DM Serif Display",serif;font-size:1.3rem;letter-spacing:-.02em;margin-bottom:.8rem;color:var(--white)}.service-card p{font-size:.875rem;font-weight:300;color:#ffffff80;line-height:1.65}.service-card .service-link{display:inline-flex;align-items:center;gap:.4rem;margin-top:1.5rem;font-size:.82rem;font-weight:500;color:#fff6;text-decoration:none;transition:color .2s}.service-card:hover .service-link{color:#ffffffe6}#process{border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:3.5rem 5vw;display:flex;align-items:center;gap:1.5rem;overflow-x:auto}.process-step{display:flex;align-items:center;gap:1rem;flex-shrink:0}.process-num{font-family:"DM Serif Display",serif;font-size:1.8rem;color:var(--pnum);line-height:1;min-width:2rem}.process-info strong{display:block;font-size:.9rem;font-weight:500;margin-bottom:.2rem}.process-info span{font-size:.8rem;color:var(--gray)}.process-arrow{color:var(--line);font-size:1.5rem;flex-shrink:0}#contact{display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:start}.contact-form{display:flex;flex-direction:column;gap:1.2rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.45rem}.form-group label{font-size:.78rem;letter-spacing:.04em;color:var(--gray);font-weight:500;text-transform:uppercase}.form-group input,.form-group textarea,.form-group select{font-family:DM Sans,sans-serif;font-size:.9rem;background:var(--light);border:1px solid transparent;border-radius:10px;padding:.8rem 1rem;color:var(--black);outline:none;transition:border-color .2s,background .2s;resize:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--black);background:var(--white)}.form-group textarea{min-height:120px}.form-submit{font-family:DM Sans,sans-serif;font-size:.95rem;font-weight:500;background:var(--black);color:var(--white);border:none;padding:.9rem 2rem;border-radius:100px;cursor:pointer;align-self:flex-start;transition:background .2s,transform .15s}.form-submit:hover:not(:disabled){background:#333;transform:translateY(-2px)}.form-submit:disabled{cursor:default}.contact-info .section-title{margin-bottom:.8rem}.contact-details{display:flex;flex-direction:column;gap:1.5rem;margin-top:3rem}.contact-detail{display:flex;align-items:flex-start;gap:1rem}.contact-detail-icon{width:40px;height:40px;background:var(--light);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}.contact-detail strong{display:block;font-size:.85rem;font-weight:500;margin-bottom:.15rem}.contact-detail span{font-size:.85rem;color:var(--gray)}.wizard-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a0a0a8c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;display:flex;align-items:center;justify-content:center;padding:1.5rem;animation:fadeIn .2s ease both}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.wizard-panel{background:var(--white);border-radius:20px;padding:2.5rem;width:100%;max-width:520px;position:relative;animation:slideUp .25s ease both}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.wizard-close{position:absolute;top:1.2rem;right:1.2rem;background:var(--light);border:none;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:.75rem;cursor:pointer;color:var(--gray);transition:background .15s,color .15s}.wizard-close:hover{background:var(--black);color:var(--white)}.wizard-progress{display:flex;gap:.4rem;margin-bottom:1.8rem}.wizard-dot{height:4px;flex:1;border-radius:2px;background:var(--light);transition:background .2s}.wizard-dot.active{background:var(--black)}.wizard-dot.done{background:#888}.wizard-heading{font-family:"DM Serif Display",serif;font-size:1.4rem;letter-spacing:-.02em;margin-top:.3rem;margin-bottom:1.4rem;line-height:1.25}.wizard-options{display:flex;flex-direction:column;gap:.55rem}.wizard-option{display:flex;align-items:center;justify-content:space-between;text-align:left;font-family:DM Sans,sans-serif;font-size:.9rem;background:var(--light);border:1.5px solid transparent;border-radius:10px;padding:.75rem 1rem;cursor:pointer;color:var(--black);transition:border-color .15s,background .15s}.wizard-option:hover{border-color:#bbb}.wizard-option.selected{border-color:var(--black);background:var(--white)}.wizard-option-sub{font-size:.78rem;color:var(--gray);margin-left:1rem;white-space:nowrap}.wizard-contact-fields{display:flex;flex-direction:column;gap:1rem}.wizard-footer{display:flex;align-items:center;justify-content:flex-end;gap:1rem;margin-top:1.8rem}.wizard-back{font-family:DM Sans,sans-serif;font-size:.9rem;background:none;border:none;cursor:pointer;color:var(--gray);padding:.5rem 0;transition:color .15s}.wizard-back:hover{color:var(--black)}.wizard-success{display:flex;flex-direction:column;align-items:center;text-align:center;gap:.8rem;padding:1rem 0 .5rem}.wizard-success-icon{width:52px;height:52px;background:#e8f5ee;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.4rem;color:#2d7a4f;margin-bottom:.4rem}.wizard-success h3{font-family:"DM Serif Display",serif;font-size:1.5rem;letter-spacing:-.02em}.wizard-success p{color:var(--gray);font-size:.9rem;margin-bottom:.8rem}.wizard-trigger-row{grid-column:1 / -1;display:flex;justify-content:center;padding-top:.5rem}.wizard-trigger{display:inline-flex;align-items:center;gap:.4rem;font-family:DM Sans,sans-serif;font-size:.88rem;color:var(--gray);background:none;border:none;cursor:pointer;padding:0;margin-top:.6rem;text-decoration:underline;text-underline-offset:3px;transition:color .15s}.wizard-trigger:hover{color:var(--black)}footer{border-top:1px solid var(--line);padding:2rem 5vw;display:flex;justify-content:space-between;align-items:center}footer .logo{font-size:1.1rem}.footer-copy{font-size:.8rem;color:var(--gray)}.footer-links{display:flex;gap:1.5rem}.footer-links a{font-size:.8rem;color:var(--gray);text-decoration:none;transition:color .2s}.footer-links a:hover{color:var(--black)}.footer-link-btn{font-family:DM Sans,sans-serif;font-size:.8rem;color:var(--gray);background:none;border:none;padding:0;cursor:pointer;transition:color .2s}.footer-link-btn:hover{color:var(--black)}.privacy-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a0a0a8c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;display:flex;align-items:center;justify-content:center;padding:1.5rem;animation:fadeIn .2s ease both}.privacy-panel{background:var(--white);border-radius:20px;padding:2.5rem;width:100%;max-width:600px;max-height:85vh;overflow-y:auto;position:relative;animation:slideUp .25s ease both}.privacy-close{position:absolute;top:1.2rem;right:1.2rem;background:var(--light);border:none;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:.75rem;cursor:pointer;color:var(--gray);transition:background .15s,color .15s}.privacy-close:hover{background:var(--black);color:var(--white)}.privacy-heading{font-family:"DM Serif Display",serif;font-size:1.6rem;letter-spacing:-.02em;margin-bottom:.3rem;line-height:1.2}.privacy-updated{font-size:.8rem;color:var(--gray);margin-bottom:1.8rem}.privacy-body h3{font-family:DM Sans,sans-serif;font-size:.85rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--gray);margin-top:1.5rem;margin-bottom:.5rem}.privacy-body p{font-size:.9rem;line-height:1.7;color:var(--black)}@keyframes fadeDown{0%{opacity:0;transform:translateY(-16px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease}.reveal.visible{opacity:1;transform:translateY(0)}@media (max-width: 900px){section{padding:5rem 5vw}#hero{grid-template-columns:1fr;padding-top:7rem;min-height:auto;padding-bottom:4rem}.hero-right,.nav-links{display:none}.services-grid{grid-template-columns:repeat(2,1fr)}.work-grid{grid-template-columns:1fr}#contact{grid-template-columns:1fr;gap:3rem}.form-row{grid-template-columns:1fr}footer{flex-direction:column;align-items:flex-start;gap:1.2rem}}@media (max-width: 640px){section{padding:4rem 5vw}#hero{padding-top:5.5rem}.hero-actions{flex-wrap:wrap}.nav-cta{font-size:.8rem;padding:.45rem 1rem}.services-grid{grid-template-columns:1fr}#process{flex-direction:column;align-items:flex-start;overflow-x:unset;gap:1.2rem}.process-arrow{display:none}.cookie-banner{left:1rem;right:1rem;bottom:1rem;max-width:none}.marquee-header{flex-direction:column;gap:.5rem}.marquee-meta{display:none}}.cookie-banner{position:fixed;bottom:1.5rem;left:1.5rem;z-index:200;background:var(--white);border:1px solid var(--line);border-radius:16px;padding:1.5rem;max-width:320px;box-shadow:0 8px 40px #0000001a;animation:fadeUp .4s ease both}.cookie-title{font-family:"DM Serif Display",serif;font-size:1rem;letter-spacing:-.01em;margin-bottom:.5rem;color:var(--black)}.cookie-body{font-size:.8rem;font-weight:300;color:var(--gray);line-height:1.6;margin-bottom:1.2rem}.cookie-actions{display:flex;gap:.6rem}.cookie-btn-primary{font-family:DM Sans,sans-serif;font-size:.82rem;font-weight:500;background:var(--black);color:var(--white);border:none;padding:.55rem 1.1rem;border-radius:100px;cursor:pointer;transition:background .2s,transform .15s}.cookie-btn-primary:hover{background:#333;transform:translateY(-1px)}.cookie-btn-ghost{font-family:DM Sans,sans-serif;font-size:.82rem;font-weight:400;background:var(--light);color:var(--gray);border:none;padding:.55rem 1.1rem;border-radius:100px;cursor:pointer;transition:background .2s,color .2s}.cookie-btn-ghost:hover{background:#e2e2de;color:var(--black)}[data-theme=kawaii] .cookie-btn-primary{background:linear-gradient(135deg,#ff6eb4,#bf3ff0)}[data-theme=kawaii] .cookie-btn-primary:hover{background:linear-gradient(135deg,#ff90c6,#cf60f5)}.kawaii-toggle{display:none;position:fixed;bottom:24px;right:1.5rem;width:44px;height:44px;border-radius:50%;border:none;font-size:1.25rem;line-height:1;cursor:pointer;z-index:200;transition:transform .25s ease,box-shadow .25s ease}[data-theme=kawaii]{--black: #2b1640;--white: #fff4fb;--gray: #aa7fc4;--light: #f7d6f0;--accent: #c040a8;--pnum: #e4b8e8;--line: rgba(180, 100, 160, .18)}[data-theme=kawaii] nav{background:#ffeefae0}[data-theme=kawaii] #services,[data-theme=kawaii] .service-card{background:#1c0930}[data-theme=kawaii] .service-card:hover{background:#2a1045}[data-theme=kawaii] .work-card:hover{box-shadow:0 8px 40px #c850b41a}[data-theme=kawaii] .nav-cta,[data-theme=kawaii] .btn-primary,[data-theme=kawaii] .form-submit:not(:disabled){background:linear-gradient(135deg,#ff6eb4,#bf3ff0)}[data-theme=kawaii] .nav-cta:hover,[data-theme=kawaii] .btn-primary:hover,[data-theme=kawaii] .form-submit:hover:not(:disabled){background:linear-gradient(135deg,#ff90c6,#cf60f5);transform:translateY(-2px)}[data-theme=kawaii] .kawaii-toggle{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#ffb3de,#d4a0f7);box-shadow:0 2px 16px #c850b459}[data-theme=kawaii] .kawaii-toggle:hover{transform:scale(1.2) rotate(20deg);box-shadow:0 4px 24px #c850b480}
