:root{
  --bg:#050505; --panel:#111; --text:#fff; --muted:rgba(255,255,255,.68);
  --pink:#ff5bc8; --hot:#ff319a; --orange:#ff8a42; --yellow:#fff02f;
  --grad:linear-gradient(110deg,var(--pink),var(--orange),var(--yellow));
}
*{box-sizing:border-box} html{scroll-behavior:smooth} body{margin:0;background:var(--bg);color:var(--text);font-family:Inter,system-ui,sans-serif;overflow-x:hidden}
a{color:inherit;text-decoration:none}.noise{position:fixed;inset:0;pointer-events:none;opacity:.08;z-index:50;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}.speedlines{position:fixed;inset:-20%;z-index:-3;background:repeating-linear-gradient(105deg,transparent 0 38px,rgba(255,255,255,.035) 39px 41px);transform:skewY(-8deg);animation:lines 12s linear infinite}@keyframes lines{to{background-position:900px 0}}
.nav{position:fixed;top:18px;left:50%;transform:translateX(-50%);width:min(1180px,calc(100% - 28px));height:78px;z-index:40;display:flex;justify-content:space-between;align-items:center;padding:10px 14px 10px 20px;border:1px solid rgba(255,255,255,.12);border-radius:999px;background:rgba(6,6,6,.62);backdrop-filter:blur(18px);box-shadow:0 12px 40px rgba(0,0,0,.35)}.brand img{height:58px;width:auto;display:block}.nav nav{display:flex;gap:8px;align-items:center}.nav a:not(.brand){padding:13px 16px;border-radius:999px;font-weight:900;font-size:13px;text-transform:uppercase;letter-spacing:.06em;color:rgba(255,255,255,.78)}.nav a:hover,.nav-cta{background:rgba(255,255,255,.1);color:#fff!important}.nav-cta{background:var(--grad)!important;color:#050505!important}
.section{position:relative;width:min(1180px,calc(100% - 36px));margin:0 auto;padding:105px 0}.hero{min-height:100svh;display:grid;grid-template-columns:1.08fr .92fr;gap:48px;align-items:center;padding-top:150px}.hero-bg{position:absolute;inset:0;z-index:-2}.track{position:absolute;border:34px solid rgba(255,255,255,.09);border-radius:50%;transform:rotate(-16deg)}.track-a{width:850px;height:360px;right:-220px;top:140px}.track-b{width:640px;height:250px;left:-260px;bottom:80px;border-color:rgba(255,91,200,.12)}.glow{position:absolute;filter:blur(80px);opacity:.55}.glow-pink{width:360px;height:360px;background:var(--pink);left:-90px;top:210px}.glow-yellow{width:320px;height:320px;background:var(--yellow);right:20px;bottom:90px}.eyebrow{margin:0 0 18px;font-weight:1000;text-transform:uppercase;letter-spacing:.16em;font-size:13px;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}.hero h1,.section-head h2,.instagram h2,.contact h2{font-family:Anton,Impact,sans-serif;text-transform:uppercase;line-height:.9;letter-spacing:-.04em;margin:0}.hero h1{font-size:clamp(64px,11vw,156px);text-shadow:8px 8px 0 #000}.hero h1 span{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}.lead{font-size:clamp(18px,2vw,25px);max-width:710px;line-height:1.45;color:var(--muted);font-weight:700}.btn{display:inline-flex;align-items:center;justify-content:center;padding:17px 24px;border-radius:999px;font-weight:1000;text-transform:uppercase;letter-spacing:.06em;border:1px solid rgba(255,255,255,.16);transition:.2s}.btn:hover{transform:translateY(-3px) rotate(-1deg)}.primary{background:var(--grad);color:#050505;box-shadow:0 0 36px rgba(255,91,200,.35)}.ghost{background:rgba(255,255,255,.08);color:#fff}.hero-actions,.contact-actions{display:flex;gap:14px;flex-wrap:wrap}.hero-card{padding:34px;border-radius:42px;background:linear-gradient(180deg,rgba(255,255,255,.16),rgba(255,255,255,.05));border:1px solid rgba(255,255,255,.14);box-shadow:0 30px 90px rgba(0,0,0,.55);transform:rotate(2.5deg)}.hero-card img{width:100%;filter:drop-shadow(18px 18px 0 #000)}.hero-stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:24px}.hero-stat-grid span{background:#080808;border-radius:22px;padding:18px;font-size:13px;text-transform:uppercase;color:var(--muted);font-weight:800}.hero-stat-grid b{display:block;font-size:28px;color:#fff}
.marquee{overflow:hidden;border-block:1px solid rgba(255,255,255,.1);background:#0a0a0a}.marquee-inner{display:flex;width:max-content;gap:34px;padding:22px 0;animation:marq 22s linear infinite}.marquee span{font-family:Anton,sans-serif;text-transform:uppercase;font-size:40px;letter-spacing:-.03em}.marquee span:nth-child(3n){color:var(--pink)}.marquee span:nth-child(3n+1){color:var(--yellow)}@keyframes marq{to{transform:translateX(-50%)}}
.section-head{max-width:820px;margin-bottom:34px}.section-head h2,.instagram h2,.contact h2{font-size:clamp(46px,7vw,96px)}.muted{color:var(--muted);font-weight:650;line-height:1.6}.work-grid{display:grid;grid-template-columns:1.2fr .8fr .8fr;grid-auto-rows:280px;gap:18px}.tile{position:relative;overflow:hidden;border-radius:34px;padding:28px;background:radial-gradient(circle at 20% 10%,rgba(255,91,200,.7),transparent 35%),radial-gradient(circle at 90% 80%,rgba(255,240,47,.6),transparent 35%),#151515;border:1px solid rgba(255,255,255,.12);display:flex;flex-direction:column;justify-content:flex-end}.tile:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,transparent,rgba(0,0,0,.5)),repeating-linear-gradient(-18deg,transparent 0 22px,rgba(255,255,255,.08) 23px 24px)}.tile>*{position:relative}.tile-large{grid-row:span 2}.tile-wide{grid-column:span 2}.tile span{font-weight:1000;color:#000;background:#fff;border-radius:999px;padding:8px 12px;width:max-content}.tile h3{font-family:Anton,sans-serif;text-transform:uppercase;font-size:48px;margin:14px 0 6px;text-shadow:5px 5px 0 #000}.tile p{margin:0;color:rgba(255,255,255,.78);font-weight:800}.event-list{display:grid;gap:14px}.event{display:grid;grid-template-columns:100px 1fr auto;gap:22px;align-items:center;padding:18px;border-radius:28px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12)}.date{height:82px;border-radius:22px;background:var(--grad);color:#050505;display:grid;place-items:center;text-transform:uppercase;font-weight:1000}.date b{font-size:34px;line-height:.75}.date span{font-size:12px}.event h3{font-size:26px;margin:0 0 5px}.event p{margin:0;color:var(--muted);font-weight:650}.event a{font-weight:1000;color:var(--yellow)}.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.price-card{padding:30px;border-radius:34px;background:#101010;border:1px solid rgba(255,255,255,.12);box-shadow:0 20px 60px rgba(0,0,0,.28)}.price-card.featured{background:linear-gradient(135deg,rgba(255,91,200,.22),rgba(255,138,66,.18),rgba(255,240,47,.16));transform:translateY(-18px);border-color:rgba(255,91,200,.55)}.tag{font-weight:1000;color:var(--pink);text-transform:uppercase;letter-spacing:.13em}.price-card h3{font-family:Anton,sans-serif;text-transform:uppercase;font-size:44px;margin:0}.price{font-size:52px;font-weight:1000;margin:18px 0;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}.price-card ul{padding:0;margin:0;list-style:none;color:var(--muted);font-weight:750}.price-card li{padding:12px 0;border-top:1px solid rgba(255,255,255,.1)}.instagram{display:grid;grid-template-columns:1fr 360px;gap:60px;align-items:center}.phone{height:640px;border:12px solid #1b1b1b;border-radius:54px;padding:32px 18px 18px;background:#050505;box-shadow:0 30px 100px rgba(255,91,200,.18);position:relative}.phone-top{position:absolute;top:14px;left:50%;transform:translateX(-50%);width:110px;height:24px;border-radius:999px;background:#1b1b1b}.post{height:150px;border-radius:26px;margin:30px 0;background:var(--grad);position:relative;overflow:hidden}.post:after{content:"";position:absolute;inset:0;background:repeating-linear-gradient(110deg,transparent 0 20px,rgba(0,0,0,.18) 21px 23px)}.p2{background:linear-gradient(135deg,#222,var(--pink))}.p3{background:linear-gradient(135deg,var(--orange),#111)}.phone p{text-align:center;font-weight:1000}.contact{text-align:center;padding:80px 32px;margin-bottom:70px;border-radius:46px;background:radial-gradient(circle at 20% 0,rgba(255,91,200,.5),transparent 35%),radial-gradient(circle at 80% 100%,rgba(255,240,47,.38),transparent 35%),#101010;border:1px solid rgba(255,255,255,.14)}.contact p{max-width:720px;margin:20px auto;color:var(--muted);font-weight:750;font-size:18px}.contact-actions{justify-content:center}footer{padding:50px 18px 80px;text-align:center;color:var(--muted);font-weight:800}footer img{width:230px;max-width:60%;display:block;margin:0 auto 14px}.reveal{opacity:0;transform:translateY(28px);transition:opacity .75s ease,transform .75s ease}.reveal.visible{opacity:1;transform:none}.delay-1{transition-delay:.12s}.delay-2{transition-delay:.22s}.delay-3{transition-delay:.32s}
@media(max-width:900px){.nav{height:auto;border-radius:28px;align-items:flex-start}.brand img{height:48px}.nav nav{flex-wrap:wrap;justify-content:flex-end}.nav a:not(.brand){padding:9px 10px;font-size:11px}.hero,.instagram{grid-template-columns:1fr}.hero{padding-top:140px}.hero-card{transform:none}.work-grid,.cards{grid-template-columns:1fr}.tile-large,.tile-wide{grid-column:auto;grid-row:auto}.event{grid-template-columns:72px 1fr}.event a{grid-column:2}.date{height:72px}.phone{width:min(360px,100%);margin:auto}.section{padding:78px 0}.hero-stat-grid{grid-template-columns:1fr}.marquee span{font-size:30px}}


/* Media placeholders
   Korvaa tiedostot kansioissa:
   - photos/sample.jpg
   - videos/sample.mp4

   Pystyvideo:
   - videos/sample.mp4 voi olla 9:16 IG/Reels-video.
   - Hero-taustalla video on tarkoituksella blurrettu ja tumma, ettei pystyvideo näytä oudolta leveällä näytöllä.
   - Portfolio-videokorteissa pystyvideo näkyy keskellä reels-kehyksessä.

   Vaakavideo:
   - Jos vaihdat vaakavideoon, voit poistaa portrait-frame-divit index.html:stä ja jättää pelkän media-bg-videon.
*/
.hero-video{position:absolute;inset:-8%;width:116%;height:116%;object-fit:cover;object-position:center;opacity:.30;filter:blur(10px) saturate(1.35) contrast(1.15);z-index:-4;transform:scale(1.04)}
.hero-bg:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 20%,transparent,rgba(5,5,5,.72) 55%,#050505 100%),linear-gradient(90deg,rgba(5,5,5,.76),rgba(5,5,5,.34),rgba(5,5,5,.9));z-index:-3}

/* Portfolio: isot, lähes koko ruudun kokoiset media-kortit */
.work-grid{display:grid;grid-template-columns:1fr;grid-auto-rows:auto;gap:24px}.tile,.tile-large,.tile-wide{grid-column:auto;grid-row:auto;min-height:min(780px,78svh);padding:44px}.tile h3{font-size:clamp(54px,9vw,126px);line-height:.86;max-width:850px}.tile p{font-size:clamp(18px,2vw,28px);max-width:720px}.tile span{font-size:20px;padding:11px 16px}.media-tile>.media-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;opacity:.82;transform:scale(1.02);transition:transform .65s ease,opacity .45s ease,filter .45s ease}.media-tile:hover>.media-bg{transform:scale(1.08);opacity:.98}.media-tile:before{z-index:1;background:linear-gradient(180deg,rgba(0,0,0,.05),rgba(0,0,0,.18) 38%,rgba(0,0,0,.84)),repeating-linear-gradient(-18deg,transparent 0 22px,rgba(255,255,255,.06) 23px 24px)}.media-tile>*:not(.media-bg){z-index:2}

/* Kun lähdemateriaali on pystyvideo, ei venytetä sitä väkisin vaakaan. */
.portrait-media>.media-bg{filter:blur(18px) saturate(1.45) contrast(1.15);opacity:.55;transform:scale(1.16)}.portrait-media:hover>.media-bg{transform:scale(1.22);opacity:.68}.portrait-frame{position:absolute;right:clamp(28px,6vw,92px);top:50%;transform:translateY(-50%) rotate(2deg);height:min(620px,68svh);aspect-ratio:9/16;border-radius:38px;overflow:hidden;border:8px solid rgba(255,255,255,.92);box-shadow:0 30px 90px rgba(0,0,0,.7),0 0 60px rgba(255,91,200,.35);background:#000}.portrait-frame.small{height:min(520px,62svh)}.portrait-frame video{width:100%;height:100%;object-fit:cover;display:block}.portrait-media h3,.portrait-media p,.portrait-media span{max-width:55%}

.post img,.post video{width:100%;height:100%;object-fit:cover;display:block}.post:after{pointer-events:none}

@media(max-width:900px){.tile,.tile-large,.tile-wide{min-height:76svh;padding:26px}.portrait-frame{right:22px;top:34px;transform:none;height:48svh;opacity:.92}.portrait-media h3,.portrait-media p,.portrait-media span{max-width:100%}.portrait-media{justify-content:flex-end}.portrait-media:before{background:linear-gradient(180deg,rgba(0,0,0,.18),rgba(0,0,0,.14) 35%,rgba(0,0,0,.9)),repeating-linear-gradient(-18deg,transparent 0 22px,rgba(255,255,255,.06) 23px 24px)}}
