:root{--p:#7B4F9E;--pm:#5B6BAD;--t:#2D7B8A;--grad:linear-gradient(120deg,#7B4F9E 0%,#5B6BAD 45%,#2D7B8A 100%);--gs:linear-gradient(120deg,rgba(123,79,158,.08),rgba(45,123,138,.08));--black:#0d0d0d;--border:rgba(0,0,0,.07);--gray:#666}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;background:#fff;color:var(--black);overflow-x:hidden;cursor:none}
#cursor{position:fixed;width:12px;height:12px;background:var(--p);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:width .2s,height .2s,background .2s}
#cursor-ring{position:fixed;width:36px;height:36px;border:1.5px solid var(--p);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:width .35s cubic-bezier(.23,1,.32,1),height .35s cubic-bezier(.23,1,.32,1);opacity:.5}
body.ch #cursor{width:20px;height:20px;background:var(--t)}
body.ch #cursor-ring{width:52px;height:52px;border-color:var(--t)}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:1.1rem 2.5rem;background:rgba(255,255,255,.92);backdrop-filter:blur(20px);border-bottom:.5px solid var(--border);transition:box-shadow .3s}
.nav-logo{font-size:17px;font-weight:800;letter-spacing:-.5px;text-decoration:none;color:var(--black);cursor:none}
.nav-logo span{background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.nav-links{display:flex;gap:1.75rem;list-style:none;align-items:center}
.nav-links a{font-size:13px;color:#555;text-decoration:none;position:relative;transition:color .2s;cursor:none}
.nav-links a::after{content:'';position:absolute;bottom:-3px;left:0;width:0;height:1.5px;background:var(--grad);transition:width .3s cubic-bezier(.23,1,.32,1)}
.nav-links a:hover,.nav-links a.active{color:var(--p)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-dd{position:relative}
.nav-dd::after{content:'';position:absolute;top:100%;left:-20px;right:-20px;height:16px}
.nav-dd-menu{position:absolute;top:calc(100% + 14px);left:50%;transform:translateX(-50%) translateY(-4px);background:#fff;border:.5px solid var(--border);border-radius:14px;padding:.5rem;min-width:220px;box-shadow:0 12px 40px rgba(0,0,0,.1);opacity:0;pointer-events:none;transition:opacity .25s,transform .25s;z-index:200}
.nav-dd:hover .nav-dd-menu{opacity:1;pointer-events:all;transform:translateX(-50%) translateY(0)}
.nav-dd-menu a{display:block;padding:.65rem .9rem;font-size:13px;color:#444;text-decoration:none;border-radius:8px;transition:background .15s;cursor:none;white-space:nowrap}
.nav-dd-menu a:hover{background:var(--gs);color:var(--p)}
.nav-dd-menu a::after{display:none}
.nav-cta{font-size:13px;font-weight:600;padding:8px 20px;background:var(--grad);color:#fff;border:none;border-radius:100px;cursor:none;transition:opacity .2s,transform .15s,box-shadow .2s;text-decoration:none;display:inline-block}
.nav-cta:hover{opacity:.88;transform:scale(1.04);box-shadow:0 6px 24px rgba(91,107,173,.4)}
.nav-hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:none;padding:4px}
.nav-hamburger span{display:block;width:22px;height:2px;background:var(--black);border-radius:2px;transition:all .3s}
.nav-hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-hamburger.open span:nth-child(2){opacity:0}
.nav-hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.nav-mobile-menu{display:none;position:fixed;top:60px;left:0;right:0;bottom:0;background:rgba(255,255,255,.97);backdrop-filter:blur(20px);z-index:99;flex-direction:column;align-items:center;justify-content:center;gap:1.75rem}
.nav-mobile-menu.open{display:flex;animation:menuIn .3s ease}
@keyframes menuIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
.nav-mobile-menu a{font-size:22px;font-weight:700;color:var(--black);text-decoration:none;cursor:none;transition:color .2s}
.nav-mobile-menu a:hover{color:var(--p)}
.mob-sub{font-size:14px!important;font-weight:500!important;color:#999!important}
.mob-cta{background:var(--grad);color:#fff!important;padding:13px 32px;border-radius:100px;font-size:16px!important}

/* PAGE WRAPPER */
.page-wrap{padding-top:72px}

/* HERO */
.hero{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:5rem 2rem 7rem;text-align:center;position:relative;overflow:hidden;background:linear-gradient(120deg,#7B4F9E 0%,#5B6BAD 40%,#2D7B8A 100%)}
.hero-bg{position:absolute;inset:0;z-index:0;overflow:hidden}
.hero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:60px 60px;z-index:0;pointer-events:none;animation:gridShift 20s linear infinite}
@keyframes gridShift{0%{background-position:0 0}100%{background-position:60px 60px}}
.blob{position:absolute;border-radius:50%;filter:blur(90px);pointer-events:none}
.b1{width:500px;height:500px;background:rgba(180,100,210,.35);top:-120px;right:-80px;animation:bf 8s ease-in-out infinite}
.b2{width:400px;height:400px;background:rgba(30,100,140,.3);bottom:-100px;left:-80px;animation:bf2 10s ease-in-out infinite}
.b3{width:350px;height:350px;background:rgba(100,80,180,.2);top:50%;left:50%;margin:-175px 0 0 -175px;animation:bf 9s ease-in-out infinite 1.5s}
@keyframes bf{0%,100%{transform:translateY(0) scale(1)}50%{transform:translateY(-30px) scale(1.05)}}
@keyframes bf2{0%,100%{transform:translateY(0)}50%{transform:translateY(25px)}}
.hero-content{position:relative;z-index:1;max-width:820px}
.badge{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:600;letter-spacing:.5px;color:rgba(255,255,255,.9);background:rgba(255,255,255,.15);padding:5px 14px;border-radius:100px;margin-bottom:1.75rem;border:.5px solid rgba(255,255,255,.3);backdrop-filter:blur(8px);animation:fu .7s ease both}
.pulse-dot{width:7px;height:7px;background:#7fff6a;border-radius:50%;position:relative;flex-shrink:0}
.pulse-dot::after{content:'';position:absolute;inset:-3px;background:rgba(127,255,106,.4);border-radius:50%;animation:pr 1.5s ease-out infinite}
@keyframes pr{0%{transform:scale(1);opacity:1}100%{transform:scale(2.5);opacity:0}}
.hero h1{font-size:clamp(44px,7vw,80px);font-weight:800;line-height:1.04;letter-spacing:-2.5px;color:#fff;margin-bottom:1.25rem}
.h1-line{display:inline-block;animation:heroSlide .7s cubic-bezier(.23,1,.32,1) both}
.h1-line:nth-child(1){animation-delay:.1s}
.h1-line:nth-child(3){animation-delay:.25s}
@keyframes heroSlide{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}
.hero-sub{font-size:17px;color:rgba(255,255,255,.75);line-height:1.7;max-width:520px;margin:0 auto 2.5rem;animation:fu .7s .35s ease both}
.hero-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;animation:fu .7s .45s ease both}
.scroll-ind{position:absolute;bottom:1.75rem;left:0;right:0;display:flex;flex-direction:column;align-items:center;gap:8px;color:rgba(255,255,255,.45);font-size:10px;letter-spacing:1.5px;text-transform:uppercase;animation:fu 1s .8s ease both;z-index:2;pointer-events:none}
.scroll-line{width:1px;height:40px;background:rgba(255,255,255,.3);overflow:hidden;position:relative}
.scroll-line::after{content:'';position:absolute;top:-100%;left:0;width:100%;height:100%;background:rgba(255,255,255,.8);animation:sd 1.5s ease-in-out infinite}
@keyframes sd{0%{top:-100%}100%{top:100%}}

/* BUTTONS */
.btn{padding:13px 26px;border:none;border-radius:100px;font-size:14px;font-weight:700;cursor:none;transition:all .25s;text-decoration:none;display:inline-flex;align-items:center;gap:6px;position:relative;overflow:hidden}
.btn-white{background:rgba(255,255,255,.95);color:var(--p)}
.btn-white:hover{background:#fff;transform:translateY(-3px);box-shadow:0 12px 36px rgba(0,0,0,.2)}
.btn-outline{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.4)}
.btn-outline:hover{border-color:rgba(255,255,255,.85);background:rgba(255,255,255,.1);transform:translateY(-2px)}
.btn-grad{background:var(--grad);color:#fff}
.btn-grad:hover{opacity:.9;transform:translateY(-2px);box-shadow:0 8px 28px rgba(91,107,173,.4)}
.shine::after{content:'';position:absolute;top:0;left:-100%;width:60%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.5),transparent);transform:skewX(-20deg);transition:left .5s}
.shine:hover::after{left:150%}

/* TICKER */
.ticker-wrap{background:var(--grad);padding:13px 0;overflow:hidden;width:100%}
.ticker-inner{display:flex;width:max-content;animation:tk 40s linear infinite;will-change:transform}
.ti{font-size:12px;font-weight:700;letter-spacing:2px;text-transform:uppercase;padding:0 2rem;color:rgba(255,255,255,.85);white-space:nowrap;flex-shrink:0}
@keyframes tk{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* COUNTER */
.cnt-strip{padding:4rem 2rem;background:#fafafa;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.cnt-inner{max-width:900px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;text-align:center}
.cnt-num{font-size:42px;font-weight:800;letter-spacing:-2px;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;line-height:1}
.cnt-label{font-size:13px;color:#888;margin-top:6px}

/* LOGO STRIP */
.logo-wrap{overflow:hidden;width:100%;padding:2.5rem 0;background:#fff;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.logo-track{display:flex;width:max-content;animation:tk 35s linear infinite;will-change:transform}
.logo-item{padding:0 3rem;opacity:.28;font-size:13px;font-weight:700;white-space:nowrap;letter-spacing:.5px;flex-shrink:0;transition:opacity .3s}
.logo-item:hover{opacity:.7}

/* SECTIONS */
.section{padding:6rem 2rem}
.si{max-width:1100px;margin:0 auto}
.si-sm{max-width:780px;margin:0 auto}
.ey{font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;display:inline-block;margin-bottom:.75rem}
.h2{font-size:clamp(28px,4vw,44px);font-weight:800;letter-spacing:-1px;line-height:1.15;margin-bottom:.75rem}
.h2s{font-size:clamp(22px,3vw,32px);font-weight:800;letter-spacing:-1px;line-height:1.2;margin-bottom:.75rem}
.lead{font-size:15px;color:var(--gray);line-height:1.7;max-width:560px;margin-bottom:2.5rem}

/* SERVICES */
.srv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:2rem}
.srv{background:#fff;border:1.5px solid var(--border);border-radius:24px;padding:2.5rem;transition:all .4s cubic-bezier(.23,1,.32,1);cursor:none;position:relative;overflow:hidden}
.srv-glow{position:absolute;width:200px;height:200px;border-radius:50%;filter:blur(60px);opacity:0;transition:opacity .4s;pointer-events:none;background:radial-gradient(circle,rgba(123,79,158,.2),transparent)}
.srv:hover .srv-glow{opacity:1}
.srv:hover{transform:translateY(-8px);border-color:rgba(123,79,158,.2);box-shadow:0 24px 64px rgba(123,79,158,.1)}
.srv-num{font-size:11px;font-weight:700;letter-spacing:1px;margin-bottom:1.25rem;opacity:.4;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.srv-icon{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;margin-bottom:1.25rem;position:relative;z-index:1;transition:transform .4s cubic-bezier(.23,1,.32,1);background:linear-gradient(135deg,rgba(123,79,158,.1),rgba(45,123,138,.1));border:1px solid rgba(123,79,158,.15)}
.srv:hover .srv-icon{transform:scale(1.15) rotate(-6deg)}
.srv-icon svg{width:22px;height:22px;stroke:var(--pm);fill:none;stroke-width:1.8}
.srv h3{font-size:18px;font-weight:700;margin-bottom:.6rem;position:relative;z-index:1}
.srv p{font-size:13px;color:var(--gray);line-height:1.65;position:relative;z-index:1}
.srv-list{list-style:none;margin-top:1rem;position:relative;z-index:1}
.srv-list li{font-size:12px;color:#555;padding:5px 0 5px 18px;position:relative;border-bottom:.5px solid rgba(0,0,0,.04)}
.srv-list li:last-child{border:none}
.srv-list li::before{content:'→';position:absolute;left:0;font-size:11px;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;transition:transform .2s}
.srv:hover .srv-list li::before{transform:translateX(3px)}
.srv-link{display:inline-flex;align-items:center;gap:4px;margin-top:1.5rem;font-size:12px;font-weight:700;text-decoration:none;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;position:relative;z-index:1;transition:gap .2s;cursor:none}
.srv-link:hover{gap:10px}

/* ABOUT */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.float-wrap{position:relative;height:400px}
.fc{position:absolute;border-radius:20px;box-shadow:0 12px 48px rgba(123,79,158,.15)}
.fc-main{background:var(--grad);color:#fff;width:250px;padding:2rem;top:20px;left:20px;animation:flt 6s ease-in-out infinite}
.fc-1{background:#fff;width:165px;padding:1.25rem;bottom:60px;left:0;animation:flt 7s ease-in-out infinite 1s}
.fc-2{background:#fff;width:175px;padding:1.25rem;top:80px;right:10px;animation:flt 5s ease-in-out infinite 2s}
@keyframes flt{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
.fc-num{font-size:52px;font-weight:800;color:rgba(255,255,255,.9);line-height:1}
.fc-lbl{font-size:13px;color:rgba(255,255,255,.6);margin-top:6px}
.fc-ns{font-size:28px;font-weight:800;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;line-height:1}
.fc-ls{font-size:11px;color:#999;margin-top:4px}
.check-item{display:flex;align-items:flex-start;gap:12px;margin-bottom:1rem;padding:.75rem;border-radius:12px;transition:background .25s,transform .25s;cursor:none}
.check-item:hover{background:rgba(123,79,158,.05);transform:translateX(4px)}
.check-dot{width:22px;height:22px;min-width:22px;background:var(--grad);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;color:#fff;font-weight:700;margin-top:2px}
.check-item p{font-size:14px;color:#444;line-height:1.6}
.testi{background:#fff;border-radius:16px;padding:1.5rem;border:1px solid var(--border);box-shadow:0 4px 20px rgba(123,79,158,.08);transition:all .3s;cursor:none}
.testi:hover{transform:translateY(-3px);box-shadow:0 12px 40px rgba(123,79,158,.15)}
.t-stars{font-size:14px;margin-bottom:.75rem;letter-spacing:2px;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.t-text{font-size:14px;color:#333;line-height:1.65;font-style:italic;margin-bottom:1rem}
.t-author{display:flex;align-items:center;gap:10px}
.t-av{width:36px;height:36px;background:var(--grad);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;flex-shrink:0}
.t-name{font-size:13px;font-weight:600}
.t-role{font-size:11px;color:#999}

/* DARK BAND */
.dark-band{background:var(--black);color:#fff}
.pf-widget{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:24px;padding:2.5rem;backdrop-filter:blur(10px)}
.sliders{display:flex;flex-direction:column;gap:1.25rem;margin-bottom:1.75rem}
.sl-label{display:flex;justify-content:space-between;font-size:12px;font-weight:600;color:rgba(255,255,255,.65);margin-bottom:8px}
.sl-val{font-size:13px;color:#fff}
input[type=range]{width:100%;height:4px;appearance:none;border-radius:100px;outline:none;cursor:pointer;background:rgba(255,255,255,.15)}
input[type=range]::-webkit-slider-thumb{appearance:none;width:20px;height:20px;background:#fff;border-radius:50%;cursor:pointer;box-shadow:0 2px 8px rgba(0,0,0,.3);transition:transform .2s}
input[type=range]:active::-webkit-slider-thumb{transform:scale(1.3)}
.dist-bar{display:flex;height:12px;border-radius:100px;overflow:hidden;gap:2px;margin-bottom:1rem}
.ds{height:100%;transition:width .4s cubic-bezier(.4,0,.2,1);border-radius:100px}
.ds-s{background:#7B4F9E}.ds-p{background:#5B6BAD}.ds-w{background:#2D7B8A}
.dist-leg{display:flex;gap:1.25rem;margin-bottom:2rem;flex-wrap:wrap}
.dist-leg span{font-size:11px;color:rgba(255,255,255,.4);display:flex;align-items:center;gap:5px}
.dist-leg span::before{content:'';width:8px;height:8px;border-radius:50%;display:inline-block}
.dl-s::before{background:#7B4F9E}.dl-p::before{background:#5B6BAD}.dl-w::before{background:#2D7B8A}

/* PRICING */
.p-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:2.5rem}
.p-card{border:1.5px solid var(--border);border-radius:24px;padding:2rem;background:#fff;transition:all .4s cubic-bezier(.23,1,.32,1);position:relative;overflow:hidden;cursor:none}
.p-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--grad);transform:scaleX(0);transform-origin:left;transition:transform .4s cubic-bezier(.23,1,.32,1)}
.p-card:hover{transform:translateY(-8px);box-shadow:0 24px 64px rgba(123,79,158,.12);border-color:rgba(123,79,158,.2)}
.p-card:hover::before{transform:scaleX(1)}
.p-card.feat{background:var(--grad);border-color:transparent;color:#fff}
.p-card.feat::before{transform:scaleX(1);background:rgba(255,255,255,.25)}
.p-card.feat:hover{box-shadow:0 24px 64px rgba(123,79,158,.35)}
.p-tag{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.5px;padding:4px 10px;border-radius:100px;margin-bottom:1.25rem}
.p-card:not(.feat) .p-tag{background:var(--gs);color:var(--pm);border:1px solid rgba(123,79,158,.15)}
.p-card.feat .p-tag{background:rgba(255,255,255,.2);color:#fff}
.p-name{font-size:12px;font-weight:600;opacity:.55;margin-bottom:.25rem;text-transform:uppercase;letter-spacing:1px}
.p-hours{font-size:13px;font-weight:600;margin-bottom:1rem}
.p-card:not(.feat) .p-hours{color:var(--pm)}
.p-card.feat .p-hours{color:rgba(255,255,255,.8)}
.p-price{font-size:40px;font-weight:800;letter-spacing:-1.5px;line-height:1}
.p-period{font-size:13px;color:#999;margin-bottom:1.5rem}
.p-card.feat .p-period,.p-card.feat .p-desc{color:rgba(255,255,255,.65)}
.p-desc{font-size:13px;color:var(--gray);line-height:1.6;margin-bottom:1.5rem}
.p-btn{width:100%;padding:11px;border-radius:100px;font-size:13px;font-weight:600;cursor:none;transition:all .3s;text-decoration:none;display:block;text-align:center}
.p-card:not(.feat) .p-btn{border:1.5px solid rgba(0,0,0,.1);background:transparent;color:var(--black)}
.p-card:not(.feat) .p-btn:hover{background:var(--grad);color:#fff;border-color:transparent}
.p-card.feat .p-btn{background:rgba(255,255,255,.2);color:#fff;border:1.5px solid rgba(255,255,255,.3)}
.p-card.feat .p-btn:hover{background:rgba(255,255,255,.35)}

/* FAQ */
.faq-item{border-bottom:1px solid rgba(0,0,0,.07)}
.faq-q{width:100%;text-align:left;background:none;border:none;padding:1.25rem 0;font-size:15px;font-weight:600;color:var(--black);cursor:none;display:flex;justify-content:space-between;align-items:center;gap:1rem;transition:color .2s}
.faq-q:hover{color:var(--p)}
.faq-icon{width:28px;height:28px;border-radius:50%;background:var(--gs);border:1px solid rgba(123,79,158,.15);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform .4s cubic-bezier(.23,1,.32,1),background .3s}
.faq-icon span{background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;font-size:18px;font-weight:300;line-height:1}
.faq-q.open .faq-icon{transform:rotate(45deg);background:var(--grad)}
.faq-q.open .faq-icon span{-webkit-text-fill-color:#fff}
.faq-a{font-size:14px;color:#555;line-height:1.7;max-height:0;overflow:hidden;transition:max-height .5s cubic-bezier(.23,1,.32,1),padding .3s}
.faq-a.show{max-height:300px;padding-bottom:1.25rem}

/* CTA */
.cta-sect{padding:7rem 2rem;text-align:center;background:var(--grad);position:relative;overflow:hidden}
.cta-sect::before{content:'';position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.06) 1px,transparent 1px);background-size:30px 30px;pointer-events:none}
.cta-sect h2{font-size:clamp(36px,6vw,64px);font-weight:800;letter-spacing:-2px;color:#fff;margin-bottom:1rem;position:relative;z-index:1}
.cta-sect p{font-size:16px;color:rgba(255,255,255,.7);margin-bottom:2.5rem;position:relative;z-index:1}
.cta-sect .btn{position:relative;z-index:1}

/* LEISTUNGEN HERO */
.leist-hero{background:var(--grad);padding:7rem 2rem 5rem;text-align:center;position:relative;overflow:hidden}
.leist-hero h1{font-size:clamp(34px,6vw,60px);font-weight:800;letter-spacing:-2px;color:#fff;margin-bottom:1rem;position:relative;z-index:1}
.leist-hero p{font-size:16px;color:rgba(255,255,255,.75);max-width:560px;margin:0 auto;line-height:1.7;position:relative;z-index:1}

/* HOW */
.leist-how{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:2rem}
.how-item{display:flex;gap:1rem;align-items:flex-start;padding:1.5rem;border-radius:16px;border:1px solid var(--border);transition:all .3s;cursor:none}
.how-item:hover{box-shadow:0 8px 32px rgba(123,79,158,.1);border-color:rgba(123,79,158,.2);transform:translateY(-3px)}
.how-num{width:36px;height:36px;min-width:36px;background:var(--grad);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#fff;flex-shrink:0}
.how-text h4{font-size:15px;font-weight:700;margin-bottom:.4rem}
.how-text p{font-size:13px;color:var(--gray);line-height:1.6}

/* ADV */
.adv-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:2rem}
.adv-item{padding:1.25rem 1.5rem;background:#fafafa;border-radius:14px;border:1px solid var(--border);display:flex;align-items:flex-start;gap:10px;transition:all .3s;cursor:none}
.adv-item:hover{background:var(--gs);border-color:rgba(123,79,158,.2);transform:translateX(4px)}
.adv-dot{width:8px;height:8px;min-width:8px;border-radius:50%;background:var(--grad);margin-top:4px;flex-shrink:0}
.adv-item p{font-size:13px;font-weight:500;line-height:1.5}

/* DETAIL BLOCKS */
.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:2.5rem}
.db{background:#fafafa;border-radius:20px;padding:2rem;border:1px solid var(--border);transition:all .3s;cursor:none}
.db:hover{border-color:rgba(123,79,158,.2);box-shadow:0 8px 32px rgba(123,79,158,.08);transform:translateY(-4px)}
.db-head{display:flex;align-items:center;gap:10px;margin-bottom:.75rem}
.db-icon{width:32px;height:32px;min-width:32px;background:var(--grad);border-radius:8px;display:flex;align-items:center;justify-content:center}
.db-icon svg{width:16px;height:16px;stroke:#fff;fill:none;stroke-width:2}
.db h3{font-size:16px;font-weight:700}
.db p{font-size:13px;color:var(--gray);line-height:1.7}
.db ul{list-style:none;margin-top:1rem}
.db ul li{font-size:13px;color:#555;padding:4px 0 4px 18px;position:relative;border-bottom:.5px solid rgba(0,0,0,.04)}
.db ul li:last-child{border:none}
.db ul li::before{content:'✓';position:absolute;left:0;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;font-weight:700;font-size:12px}

/* STAT ROW */
.stat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:2.5rem 0}
.stat-box{text-align:center;padding:2rem;background:#fafafa;border-radius:20px;border:1px solid var(--border);transition:all .3s;cursor:none}
.stat-box:hover{border-color:rgba(123,79,158,.2);transform:translateY(-3px)}
.stat-box .sn{font-size:34px;font-weight:800;letter-spacing:-1px;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.stat-box .sl{font-size:13px;color:var(--gray);margin-top:4px;line-height:1.5}

/* CONTACT */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start}
.contact-form{background:#fafafa;border-radius:24px;padding:2.5rem;border:1px solid var(--border)}
.form-group{margin-bottom:1.25rem}
.form-group label{display:block;font-size:12px;font-weight:600;color:#444;margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}
.form-group input,.form-group textarea{width:100%;padding:12px 16px;border:1.5px solid var(--border);border-radius:12px;font-size:14px;font-family:inherit;background:#fff;transition:border-color .2s,box-shadow .2s;outline:none}
.form-group input:focus,.form-group textarea:focus{border-color:var(--pm);box-shadow:0 0 0 3px rgba(91,107,173,.12)}
.form-group textarea{resize:vertical;min-height:120px}
.cb-group{display:flex;flex-direction:column;gap:.75rem}
.cb-item{display:flex;align-items:center;gap:10px;cursor:none;padding:.5rem;border-radius:10px;transition:background .2s}
.cb-item:hover{background:var(--gs)}
.cb-item input[type=checkbox]{width:16px;height:16px;accent-color:var(--pm)}
.cb-item label{font-size:14px;color:#444;cursor:none}
.form-consent{font-size:12px;color:#888;line-height:1.6;margin:.5rem 0 1.5rem}
.form-consent a{color:var(--pm);text-decoration:none;cursor:none}
.submit-btn{width:100%;padding:14px;background:var(--grad);color:#fff;border:none;border-radius:100px;font-size:15px;font-weight:700;cursor:none;transition:all .25s}
.submit-btn:hover{opacity:.9;transform:scale(1.02);box-shadow:0 8px 28px rgba(91,107,173,.4)}
.success-msg{display:none;text-align:center;padding:2rem;background:var(--gs);border-radius:16px;border:1px solid rgba(123,79,158,.2)}
.success-msg h3{font-size:20px;font-weight:700;margin-bottom:.5rem;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.c-detail{display:flex;align-items:center;gap:12px;margin-bottom:1rem;font-size:14px}
.c-detail svg{width:18px;height:18px;stroke:var(--pm);fill:none;stroke-width:1.8;flex-shrink:0}
.srv-tag{display:inline-block;padding:5px 12px;border-radius:100px;font-size:12px;font-weight:600;background:var(--gs);border:1px solid rgba(123,79,158,.15);color:var(--pm);cursor:none;transition:all .2s;margin:.25rem}
.srv-tag:hover,.srv-tag.active{background:var(--grad);color:#fff;border-color:transparent}

/* PORTFOLIO */
.ptag{font-size:11px;font-weight:600;padding:3px 10px;border-radius:100px;background:var(--gs);color:var(--pm);border:1px solid rgba(123,79,158,.15);display:inline-block}
.ptag-lg{font-size:12px;padding:5px 12px}
.pf-case{display:grid;grid-template-columns:1.3fr 1fr;gap:5rem;align-items:start;padding:4rem 0 6rem}
.pf-case .pf-info{order:2;padding-top:1rem}
.pf-case .pf-devices{order:1}
.pf-case-rev .pf-info{order:1;padding-top:1rem}
.pf-case-rev .pf-devices{order:2}
.pf-divider{height:1px;background:var(--border);margin:1rem 0}
.pf-logo-wrap{display:flex;align-items:center;gap:12px;margin-bottom:1.25rem}
.pf-logo-letter{width:44px;height:44px;min-width:44px;background:var(--grad);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:800;color:#fff}
.pf-ll-sm{width:36px;height:36px;min-width:36px;border-radius:10px;font-size:15px}
.pf-client{font-size:20px;font-weight:800;letter-spacing:-.5px}
.pf-category{font-size:12px;color:var(--gray);margin-top:2px}
.pf-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:1.25rem}
.pf-desc{font-size:14px;color:var(--gray);line-height:1.7;margin-bottom:1.5rem}
.pf-results{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:1.5rem}
.pf-result{background:#fafafa;border-radius:12px;padding:.875rem;text-align:center;border:1px solid var(--border);transition:all .3s;cursor:none}
.pf-result:hover{border-color:rgba(123,79,158,.2);transform:translateY(-2px)}
.pf-r-num{font-size:16px;font-weight:800;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.pf-r-lbl{font-size:11px;color:var(--gray);margin-top:3px;line-height:1.4}
.pf-list{list-style:none}
.pf-list li{font-size:13px;color:#555;padding:5px 0 5px 18px;position:relative;border-bottom:.5px solid rgba(0,0,0,.04)}
.pf-list li:last-child{border:none}
.pf-list li::before{content:'✓';position:absolute;left:0;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;font-weight:700}

/* DEVICE MOCKUPS */
.pf-devices{position:relative;width:100%;margin-bottom:2rem}
.device-wrap{position:relative;width:100%;display:flex;align-items:flex-end;justify-content:flex-start}
.macbook{position:relative;width:80%;flex-shrink:0;filter:drop-shadow(0 32px 64px rgba(0,0,0,.35))}
.macbook-svg{width:100%;display:block}
.iphone{position:absolute;right:-3%;bottom:-2%;width:21%;z-index:10;filter:drop-shadow(0 24px 48px rgba(0,0,0,.45))}
.iphone-svg{width:100%;display:block}

/* MINI GRID */
.pf-mini-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.pf-mini{background:#fafafa;border-radius:20px;padding:2rem;border:1px solid var(--border);transition:all .3s;cursor:none}
.pf-mini:hover{border-color:rgba(123,79,158,.2);box-shadow:0 8px 32px rgba(123,79,158,.08);transform:translateY(-4px)}
.pf-mini-head{display:flex;align-items:center;gap:10px}
.pf-mini-name{font-size:16px;font-weight:700}
.pf-mini-cat{font-size:11px;color:var(--gray);margin-top:2px}
.pf-mini-list{list-style:none;margin-top:.75rem}
.pf-mini-list li{font-size:12px;color:#555;padding:3px 0 3px 16px;position:relative}
.pf-mini-list li::before{content:'→';position:absolute;left:0;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;font-size:11px}

/* FOOTER */
footer{background:#0a0a0a;color:rgba(255,255,255,.35);padding:2.5rem;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:2rem}
.foot-logo{font-size:15px;font-weight:800;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;cursor:none;text-decoration:none}
.foot-links{display:flex;gap:1.5rem;justify-content:center;flex-wrap:wrap}
footer a{color:rgba(255,255,255,.35);text-decoration:none;font-size:12px;transition:color .2s;cursor:none}
footer a:hover{color:rgba(255,255,255,.8)}
.foot-right{text-align:right;font-size:12px}

/* ANIMATIONS */
@keyframes fu{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
.rv{opacity:0;transform:translateY(32px);transition:opacity .75s cubic-bezier(.23,1,.32,1),transform .75s cubic-bezier(.23,1,.32,1)}
.rv.vi{opacity:1;transform:translateY(0)}
.rv-d1{transition-delay:.1s}.rv-d2{transition-delay:.2s}.rv-d3{transition-delay:.3s}

/* RESPONSIVE */
@media(max-width:900px){
  .srv-grid,.p-grid,.about-grid,.leist-how,.contact-grid,.adv-grid,.detail-grid,.stat-row,.pf-mini-grid{grid-template-columns:1fr}
  .float-wrap{display:none}
  nav{padding:1rem 1.25rem}
  .nav-links,.nav-cta{display:none}
  .nav-hamburger{display:flex}
  #cursor,#cursor-ring{display:none}
  body{cursor:auto}
  .cnt-inner{grid-template-columns:repeat(2,1fr)}
  footer{grid-template-columns:1fr;text-align:center}
  .foot-right{text-align:center}
  .pf-case{grid-template-columns:1fr;padding-bottom:4rem}
  .pf-case .pf-info,.pf-case-rev .pf-info{order:1;padding-top:0}
  .pf-case .pf-devices,.pf-case-rev .pf-devices{order:2}
}