﻿/*
Theme Name: Intermedia
Theme URI: https://intermedia-werbeagentur.de/
Author: Intermedia Peters GmbH
Description: Custom WordPress theme for Intermedia Peters GmbH.
Version: 1.0.0
Text Domain: intermedia
*/

/* Allgemein */
:root{--bg:#0b1020;--bg-soft:#11182c;--surface:#151f36;--surface-soft:#1d2944;--ink:#f8fafc;--muted:#94a3b8;--line:#94a3b838;--primary:#e2001a;--primary-strong:#b80015;--secondary:#f26b7a;--accent:#ffb000;--footer-hover:#7dd3fc;--warning:#f59e0b;--white:#fff;--black:#020617;--radius-sm:.75rem;--radius-md:1.25rem;--radius-lg:2rem;--shadow-soft:0 24px 80px #00000047;--shadow-glow:0 0 80px #e2001a2e}

*,::before,::after{box-sizing:border-box}
html{min-height:100%;scroll-behavior:smooth}
body{min-height:100vh;margin:0;padding-top:88px;display:flex;flex-direction:column;font-family:"Nunito Sans",Arial,sans-serif;background:var(--bg);color:var(--ink)}
a{color:inherit;text-decoration:none}
a:focus-visible,
button:focus-visible{outline:2px solid var(--footer-hover);outline-offset:4px;border-radius:6px}
img{display:block;max-width:100%;height:auto}
main:focus{outline:none}
.skip-link{position:fixed;top:12px;left:12px;z-index:2000;padding:10px 14px;border-radius:8px;background:var(--white);color:var(--black);font-weight:800;line-height:1;box-shadow:0 14px 40px rgba(2,6,23,.28);transform:translateY(-160%);transition:transform .2s ease}
.skip-link:focus{transform:translateY(0)}
.container{box-sizing:border-box;width:100%;max-width:1320px;margin-inline:auto;padding-inline:15px}

/* Header */
.site-header{position:fixed;top:0;left:0;z-index:1000;width:100%;border-bottom:1px solid rgba(148,163,184,.16);background:transparent;box-shadow:0 16px 50px rgba(2,6,23,.18);color:var(--ink)}
.admin-bar .site-header{top:32px}
.site-header::before{content:"";position:absolute;inset:0;z-index:0;background:rgba(11,16,32,.76);backdrop-filter:blur(18px) saturate(140%);-webkit-backdrop-filter:blur(18px) saturate(140%);pointer-events:none}
.header-inner{position:relative;z-index:1;display:flex;align-items:center;gap:24px;min-height:88px}
.header-logo{display:inline-block;flex:0 0 auto;width:170px}
.header-toggle,
.header-overlay{display:none}
.header-nav{display:flex;justify-content:flex-end;min-width:0;flex:1}
.header-menu{display:flex;align-items:center;justify-content:flex-end;gap:4px;margin:0;padding:0;list-style:none}
.header-menu > li{position:relative}
.has-dropdown::before{content:"";position:absolute;right:0;bottom:-14px;left:0;display:none;height:14px}
.has-dropdown:hover::before,
.has-dropdown:focus-within::before,
.has-dropdown.is-open::before{display:block}
.header-menu a{display:flex;align-items:center;min-height:44px;padding:0 9px;border-radius:8px;color:var(--muted);font-size:14px;font-weight:700;line-height:1;white-space:nowrap;transition:background-color .2s ease,color .2s ease}
.header-menu > li > a{padding-inline:14px}
.header-menu a:hover,
.header-menu a[aria-current="page"],
.header-menu .current-menu-item > a,
.header-menu .current-menu-ancestor > a,
.header-menu .current-menu-parent > a,
.header-menu .current_page_item > a,
.header-menu .current_page_parent > a,
.has-dropdown:hover > .has-submenu,
.has-dropdown:focus-within > .has-submenu,
.has-dropdown.is-open > .has-submenu{background:var(--surface);color:var(--white)}
.header-menu a.has-submenu::after{content:"";width:6px;height:6px;margin-left:8px;border-right:1px solid currentColor;border-bottom:1px solid currentColor;transform:rotate(45deg) translateY(-2px);opacity:.75;transition:transform .2s ease,opacity .2s ease}
.has-dropdown:hover > .has-submenu::after,
.has-dropdown:focus-within > .has-submenu::after,
.has-dropdown.is-open > .has-submenu::after{transform:rotate(225deg) translate(-2px,-2px);opacity:1}
.header-submenu{position:absolute;top:calc(100% + 14px);left:0;z-index:20;display:grid;gap:4px;min-width:300px;margin:0;padding:12px 10px 10px;border:1px solid rgba(148,163,184,.24);border-radius:12px;background:rgba(8,13,28,.46);backdrop-filter:blur(34px) saturate(180%) brightness(.82);-webkit-backdrop-filter:blur(34px) saturate(180%) brightness(.82);box-shadow:0 22px 70px rgba(2,6,23,.38),inset 0 1px 0 rgba(255,255,255,.08);isolation:isolate;overflow:hidden;list-style:none;opacity:0;visibility:hidden;transform:translateY(8px);transition:opacity .18s ease,visibility .18s ease,transform .18s ease}
.header-submenu::before{content:"";position:absolute;inset:0;z-index:0;border-radius:inherit;background:linear-gradient(135deg,rgba(255,255,255,.08),rgba(255,255,255,.02) 42%,rgba(8,13,28,.12));pointer-events:none}
.header-submenu::after{content:"";position:absolute;inset:0 0 auto;z-index:2;height:2px;background:linear-gradient(90deg,transparent,var(--primary),#7dd3fc,transparent);border-radius:12px 12px 0 0;opacity:.72;pointer-events:none}
.header-submenu-right{right:0;left:auto}
.header-menu > li:last-child > .header-submenu{right:0;left:auto}
.has-dropdown:hover > .header-submenu,
.has-dropdown:focus-within > .header-submenu,
.has-dropdown.is-open > .header-submenu{opacity:1;visibility:visible;transform:translateY(0)}
.header-submenu a{position:relative;z-index:1;display:grid;grid-template-columns:16px 1fr;align-items:center;justify-content:flex-start;gap:8px;min-height:38px;padding:4px 12px;border-radius:7px;font-size:14px;font-weight:600;line-height:1.25;white-space:normal}
.header-submenu a i,
.header-submenu a svg,
.header-submenu-icon{width:16px;height:16px;color:var(--muted);font-size:10px;transition:color .2s ease}
.header-submenu-icon{display:grid;place-items:center}
.header-submenu-icon::before{content:"";width:6px;height:6px;border-radius:999px;background:currentColor;opacity:.55}
.header-submenu a span{min-width:0}
.header-submenu a:hover i,
.header-submenu a:hover svg,
.header-submenu a:hover .header-submenu-icon,
.header-submenu a:focus-visible i,
.header-submenu a:focus-visible svg,
.header-submenu a:focus-visible .header-submenu-icon{color:var(--white)}

/* Main Inhalt*/
main{flex:1}
.section{position:relative;width:100%;padding-block:110px;scroll-margin-top:88px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;min-height:50px;padding:0 24px;border-radius:8px;font-size:16px;font-weight:800;line-height:1;transition:background-color .2s ease,color .2s ease,box-shadow .2s ease,transform .2s ease}
.btn i,
.btn svg{font-size:14px}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:var(--primary);color:var(--white);box-shadow:0 16px 40px rgba(226,0,26,.26)}
.btn-primary:hover{background:var(--primary-strong);color:var(--white)}
.hero-section{display:flex;align-items:center;min-height:760px;margin-top:-88px;padding:calc(88px + 110px) 0 84px;overflow:hidden;isolation:isolate;background:var(--black);color:var(--white)}
.hero-bg{position:absolute;inset:-28%;z-index:0;background:url("img/sternenhimmel.jpg") center/cover no-repeat;opacity:.95;filter:brightness(1.08) contrast(1.08);transform-origin:center;animation:heroStars 14s ease-in-out infinite alternate;will-change:transform}
.hero-section::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(90deg,rgba(2,6,23,.78),rgba(2,6,23,.5) 46%,rgba(2,6,23,.16)),linear-gradient(0deg,rgba(2,6,23,.55),rgba(2,6,23,.08) 42%,rgba(2,6,23,.48));pointer-events:none}
.hero-container{position:relative;z-index:2;display:grid;gap:72px}
.hero-intro{display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,.72fr);align-items:center;gap:72px}
.hero-content{max-width:790px}
.hero-visual{position:relative;display:grid;place-items:center;min-height:480px;pointer-events:none}
.hero-earth{width:min(520px,100%);filter:drop-shadow(0 32px 80px rgba(2,6,23,.48));animation:heroFloat 7s ease-in-out infinite alternate}
.hero-astronaut{position:absolute;top:6%;right:4%;width:min(150px,30%);filter:drop-shadow(0 22px 48px rgba(2,6,23,.46));transform:rotate(10deg);animation:heroAstronaut 5.5s ease-in-out infinite alternate}
.hero-kicker{margin:24px 0 0;color:var(--white);font-size:24px;font-weight:700;line-height:1.35}
.hero-content h1{max-width:900px;margin:0;font-family:"Bebas Neue","Nunito Sans",Arial,sans-serif;font-size:clamp(64px,8rem,142px);font-weight:400;line-height:.9;letter-spacing:0;color:var(--white)}
.hero-text{max-width:720px;margin:18px 0 34px;color:#dbe4f0;font-size:22px;line-height:1.55}
.hero-services{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:0}
.hero-service{position:relative;display:grid;grid-template-rows:auto 1fr auto;gap:14px;min-height:240px;padding:32px 24px 22px;border:1px solid rgba(148,163,184,.22);border-radius:8px;background:rgba(11,16,32,.52);backdrop-filter:blur(14px) saturate(130%);-webkit-backdrop-filter:blur(14px) saturate(130%);color:var(--white);box-shadow:0 18px 60px rgba(2,6,23,.22);isolation:isolate;overflow:hidden;transition:background-color .2s ease,border-color .2s ease,transform .2s ease}
.hero-service::before{content:"";position:absolute;inset:0 0 auto;z-index:2;height:2px;background:linear-gradient(90deg,transparent,var(--primary),#7dd3fc,transparent);border-radius:8px 8px 0 0;opacity:.72}
.hero-service::after{content:"";position:absolute;top:10px;left:50%;z-index:0;width:76%;height:150px;background:radial-gradient(circle,rgba(125,211,252,.22),rgba(226,0,26,.12) 42%,transparent 72%);filter:blur(18px);transform:translateX(-50%);pointer-events:none}
.hero-service img{position:relative;z-index:4;top:-104px;width:min(112%,360px);aspect-ratio:16 / 9;margin-bottom:-112px;justify-self:center;object-fit:contain;object-position:center;border-radius:6px;filter:drop-shadow(0 20px 24px rgba(2,6,23,.34));transition:filter .25s ease}
.hero-service-title{position:relative;z-index:2;padding:0;font-size:20px;font-weight:800;line-height:1.2}
.hero-service-text{position:relative;z-index:2;padding:0;color:#dbe4f0;font-size:15px;line-height:1.5}
.hero-service-cta{position:relative;z-index:2;display:inline-flex;align-items:center;gap:8px;align-self:end;padding:0;color:var(--white);font-size:14px;font-weight:800;line-height:1.2}
.hero-service-cta i,
.hero-service-cta svg{width:12px;height:12px;font-size:12px;transition:transform .2s ease}
.hero-service:hover{border-color:rgba(226,0,26,.58);background:rgba(226,0,26,.16);transform:translateY(-3px)}
.hero-service:hover img{filter:brightness(1.08) drop-shadow(0 22px 30px rgba(125,211,252,.22))}
.hero-service:hover .hero-service-cta i,
.hero-service:hover .hero-service-cta svg{transform:translateX(3px)}
.section:not(.hero-section):not(.webdesign-hero-section){background:var(--bg);color:var(--ink)}
.section:not(.hero-section) h2{margin:0;font-family:"Bebas Neue","Nunito Sans",Arial,sans-serif;font-size:54px;font-weight:400;line-height:1;letter-spacing:0;color:var(--white)}
.parallax-section{--parallax-bg-y:0px;--parallax-bg-inset:180px;--parallax-bg-scale:1.04;--parallax-bg-opacity:.9;overflow:hidden;isolation:isolate;background:var(--bg)}
.parallax-section::before{content:"";position:absolute;inset:calc(var(--parallax-bg-inset) * -1) 0;z-index:-2;background-image:var(--parallax-bg-image,none);background-size:cover;background-repeat:no-repeat;background-position:center calc(50% + var(--parallax-bg-y));opacity:var(--parallax-bg-opacity);transform:scale(var(--parallax-bg-scale));will-change:background-position}
.about-section,
.print-section{--parallax-bg-image:url("img/abstract-background-blue-red.jpg");--parallax-bg-inset:230px;--parallax-bg-scale:1.06;--parallax-bg-opacity:.9;background:var(--bg)}
.about-section::after,
.print-section::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(90deg,rgba(2,6,23,.58),rgba(2,6,23,.42) 48%,rgba(2,6,23,.28)),linear-gradient(0deg,rgba(2,6,23,.44),rgba(2,6,23,.08) 48%,rgba(2,6,23,.48))}
.about-grid{position:relative;display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,.82fr);align-items:center;gap:72px}
.about-content{max-width:760px}
.section .section-copy > h1,
.section .section-copy > h2{position:relative;display:grid;gap:4px;max-width:720px;padding-bottom:24px;font-family:"Bebas Neue","Nunito Sans",Arial,sans-serif;font-size:74px;font-weight:400;line-height:.94;letter-spacing:0;text-wrap:balance;color:var(--white)}
.section .section-copy > h1 span,
.section .section-copy > h2 span{display:block}
.section .section-copy > h1::after,
.section .section-copy > h2::after{content:"";position:absolute;left:0;bottom:0;width:116px;height:3px;border-radius:999px;background:linear-gradient(90deg,var(--primary),#7dd3fc,transparent)}
.section .section-copy > p{max-width:720px;margin:22px 0 0;color:#dbe4f0;font-size:20px;line-height:1.68}
.section .section-copy > .section-lead{max-width:670px;margin-top:24px;color:var(--white);font-size:24px;font-weight:700;line-height:1.42}
.section .section-copy > .btn{margin-top:34px}
.about-content > [data-reveal]:nth-child(2){--reveal-delay:90ms}
.about-content > [data-reveal]:nth-child(3){--reveal-delay:170ms}
.about-content > [data-reveal]:nth-child(4){--reveal-delay:250ms}
.about-content > [data-reveal]:nth-child(5){--reveal-delay:330ms}
.about-visual[data-reveal]{--reveal-delay:220ms}
.reveal-ready [data-reveal]{opacity:0;transform:translate3d(0,28px,0);transition:opacity .72s ease,transform .72s cubic-bezier(.2,.8,.2,1);transition-delay:var(--reveal-delay,0ms);will-change:opacity,transform}
.reveal-ready [data-reveal="up"]{transform:translate3d(0,28px,0)}
.reveal-ready [data-reveal="left"]{transform:translate3d(-30px,0,0)}
.reveal-ready [data-reveal="right"]{transform:translate3d(30px,0,0)}
.reveal-ready [data-reveal="down"]{transform:translate3d(0,-28px,0)}
.reveal-ready [data-reveal].is-visible{opacity:1;transform:none}
.about-visual{position:relative;display:grid;place-items:center;min-height:520px}
.about-visual::before{content:"";position:absolute;width:min(560px,92%);aspect-ratio:1;border-radius:50%;background:radial-gradient(circle,rgba(255,176,0,.34),rgba(226,0,26,.16) 40%,rgba(125,211,252,.1) 64%,transparent 78%);filter:blur(18px);opacity:.95}
.about-visual::after{content:"";position:absolute;left:51%;top:48%;z-index:2;width:min(136px,27%);aspect-ratio:1;border-radius:48% 52% 46% 54%;background:radial-gradient(ellipse at 50% 42%,rgba(255,252,226,.98) 0 9%,rgba(255,225,128,.64) 29%,rgba(255,176,0,.26) 55%,transparent 74%);box-shadow:0 0 34px rgba(255,204,84,.32),0 0 68px rgba(255,176,0,.22);transform:translate(calc(-50% - 20px),calc(-124% + 20px)) rotate(-7deg) scale(.96);filter:blur(7px) brightness(1.12);opacity:.76;mix-blend-mode:screen;animation:aboutBulbFlicker 2.8s ease-in-out infinite}
.about-visual img{position:relative;z-index:1;width:min(340px,78%);transform:rotate(-7deg);filter:drop-shadow(0 0 24px rgba(255,176,0,.34)) drop-shadow(0 34px 80px rgba(2,6,23,.46))}
.webdesign-section{overflow:hidden;background:linear-gradient(180deg,#0b1020 0%,#111827 54%,#0b1020 100%)}
.webdesign-section::before{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(90deg,rgba(226,0,26,.12),transparent 32%,rgba(125,211,252,.1) 100%),linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);background-size:auto,64px 64px,64px 64px;mask-image:linear-gradient(180deg,transparent,black 16%,black 84%,transparent);opacity:.55}
.webdesign-grid{position:relative;display:grid;grid-template-columns:minmax(360px,.9fr) minmax(0,1fr);align-items:center;gap:76px}
.webdesign-content{justify-self:end;max-width:720px}
.webdesign-points{order:-1}
.webdesign-hero-section{isolation:isolate;min-height:760px;background:#050914 url("img/webdesign-background.jpg") center/cover no-repeat;animation:webdesignHeroDrift 18s ease-in-out infinite alternate}
.webdesign-hero-section::before{z-index:0;background:linear-gradient(90deg,rgba(2,6,23,.95) 0%,rgba(2,6,23,.88) 32%,rgba(2,6,23,.62) 66%,rgba(2,6,23,.5) 100%),linear-gradient(180deg,rgba(2,6,23,.78),rgba(2,6,23,.16) 42%,rgba(2,6,23,.86)),radial-gradient(circle at 76% 34%,rgba(226,0,26,.18),transparent 28%),radial-gradient(circle at 88% 72%,rgba(125,211,252,.1),transparent 26%);mask-image:none;opacity:1;animation:webdesignOverlayPulse 10s ease-in-out infinite alternate}
.webdesign-hero-section::after{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;background:linear-gradient(115deg,transparent 0 43%,rgba(125,211,252,.09) 49%,rgba(226,0,26,.14) 51%,transparent 59% 100%),repeating-linear-gradient(180deg,transparent 0 22px,rgba(125,211,252,.035) 23px,transparent 24px),linear-gradient(90deg,transparent 0 58%,rgba(226,0,26,.08) 64%,transparent 72%);background-size:220% 100%,100% 160px,180% 100%;background-position:-90% 0,0 0,-60% 0;mix-blend-mode:screen;opacity:.5;animation:webdesignSignalSweep 9s ease-in-out infinite}
.webdesign-hero-section .webdesign-grid{z-index:1}
.webdesign-hero-section .webdesign-content{order:-1;justify-self:start}
.webdesign-hero-section .webdesign-points{order:0}
.section-points{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;margin:0;padding:0;list-style:none}
.section-points li{position:relative;min-height:178px;padding:22px;border:1px solid rgba(148,163,184,.18);border-radius:8px;background:rgba(15,23,42,.56);backdrop-filter:blur(16px) saturate(130%);-webkit-backdrop-filter:blur(16px) saturate(130%);box-shadow:0 18px 54px rgba(2,6,23,.2);overflow:hidden}
.section-points li::before{content:"";position:absolute;inset:0 0 auto;height:2px;background:linear-gradient(90deg,transparent,var(--primary),#7dd3fc,transparent);opacity:.72}
.section-points i,
.section-points svg{width:24px;height:24px;color:#7dd3fc;font-size:22px}
.section-points h3{margin:18px 0 0;color:var(--white);font-size:20px;line-height:1.2}
.section-points p{margin:10px 0 0;color:var(--muted);font-size:15px;line-height:1.5}
.section-points--list{grid-template-columns:1fr;gap:14px}
.section-points--list li{display:grid;grid-template-columns:34px 1fr;column-gap:16px;align-items:start;min-height:auto;padding:20px 22px}
.section-points--list i,
.section-points--list svg{grid-row:1 / span 2;margin-top:2px}
.section-points--list h3{margin:0}
.section-points--list p{grid-column:2;margin-top:8px}
.section-tags{display:grid;gap:12px;margin:0;padding:0;list-style:none}
.section-tags li{display:flex;align-items:center;gap:12px;min-height:78px;padding:18px 18px;border:1px solid rgba(148,163,184,.18);border-radius:8px;background:rgba(15,23,42,.54);backdrop-filter:blur(14px) saturate(130%);-webkit-backdrop-filter:blur(14px) saturate(130%);color:var(--white);font-size:15px;font-weight:800;line-height:1.2;box-shadow:0 14px 42px rgba(2,6,23,.16)}
.section-tags i,
.section-tags svg{width:18px;height:18px;color:#7dd3fc;font-size:16px;flex:0 0 auto}
.print-grid{position:relative;display:grid;grid-template-columns:minmax(0,1fr) minmax(390px,.88fr);align-items:center;gap:76px}
.print-content{max-width:720px}
.print-showcase{position:relative;display:grid;place-items:center;min-height:600px}
.print-showcase::before{content:"";position:absolute;width:min(600px,94%);aspect-ratio:1;border-radius:50%;background:radial-gradient(circle,rgba(125,211,252,.18),rgba(226,0,26,.11) 46%,transparent 72%);filter:blur(20px);opacity:.9;animation:printGlow 5.8s ease-in-out infinite alternate}
.print-image{position:relative;display:grid;place-items:center}
.print-image img{position:relative;z-index:1;width:min(640px,108%);filter:drop-shadow(0 34px 72px rgba(2,6,23,.42));transform-origin:center;animation:printFloat 6.5s ease-in-out infinite alternate}
.print-points{margin-top:28px;gap:14px}
.print-points li{min-height:178px}
.it-section{--parallax-bg-image:url("img/dark-abstract-background.jpg");--parallax-bg-inset:210px;--parallax-bg-scale:1.05;--parallax-bg-opacity:.95;background:var(--bg)}
.it-section::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(90deg,rgba(2,6,23,.62),rgba(2,6,23,.46) 48%,rgba(2,6,23,.3)),linear-gradient(0deg,rgba(2,6,23,.5),rgba(2,6,23,.08) 50%,rgba(2,6,23,.5))}
.it-grid{position:relative;display:grid;grid-template-columns:minmax(0,1fr) minmax(380px,.86fr);align-items:center;gap:76px}
.it-content{justify-self:end;max-width:720px}
.it-support{position:relative}
.it-support{order:-1}
.it-grid--content-first .it-content{justify-self:start;order:0}
.it-grid--content-first .it-support{order:0}
.it-support::before{content:"";position:absolute;top:24px;bottom:24px;left:38px;width:2px;background:linear-gradient(180deg,transparent,var(--primary),#7dd3fc,transparent);opacity:.42}
.it-points{position:relative}
.it-points li{background:rgba(11,16,32,.58)}
.marketing-section{overflow:hidden;background:linear-gradient(180deg,#0b1020 0%,#12192b 48%,#0b1020 100%)}
.marketing-section::before{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(120deg,rgba(226,0,26,.12),transparent 30%,rgba(125,211,252,.12)),radial-gradient(circle at 82% 18%,rgba(125,211,252,.14),transparent 30%),linear-gradient(rgba(255,255,255,.032) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.032) 1px,transparent 1px);background-size:auto,auto,68px 68px,68px 68px;mask-image:linear-gradient(180deg,transparent,black 14%,black 86%,transparent);opacity:.62}
.marketing-wrap{position:relative;display:grid;gap:54px}
.marketing-hero{display:grid;grid-template-columns:minmax(0,1fr) minmax(360px,.72fr);align-items:center;gap:76px}
.marketing-intro{max-width:880px}
.marketing-visual{position:relative;display:grid;place-items:center;min-height:430px}
.marketing-visual::before{content:"";position:absolute;width:min(560px,92%);aspect-ratio:1;border-radius:50%;background:radial-gradient(circle,rgba(125,211,252,.2),rgba(226,0,26,.11) 46%,transparent 72%);filter:blur(22px);opacity:.86;animation:printGlow 6.2s ease-in-out infinite alternate}
.marketing-visual img{position:relative;z-index:1;width:min(600px,116%);filter:contrast(.88) saturate(.96) drop-shadow(0 34px 72px rgba(2,6,23,.42));animation:mediaFloat 7s ease-in-out infinite alternate;transform-origin:center}
.marketing-board{display:grid;grid-template-columns:minmax(0,1fr) minmax(260px,.34fr);align-items:stretch;gap:18px}
.marketing-main{grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}
.marketing-main li{min-height:202px}
.marketing-tags{align-content:start}
.about-history-layout{position:relative;display:grid;grid-template-columns:minmax(0,1fr) minmax(340px,.62fr);align-items:start;gap:76px}
.about-page-photo{position:relative;display:grid;place-items:center;min-height:520px}
.about-page-photo::before{content:"";position:absolute;width:min(560px,92%);aspect-ratio:1;border-radius:50%;background:radial-gradient(circle,rgba(125,211,252,.2),rgba(226,0,26,.12) 46%,transparent 72%);filter:blur(22px);opacity:.88;animation:printGlow 6s ease-in-out infinite alternate}
.about-page-photo img{position:relative;z-index:1;width:min(520px,100%);border:1px solid rgba(148,163,184,.24);border-radius:8px;box-shadow:0 34px 72px rgba(2,6,23,.42);transform:rotate(1.2deg)}
.about-history-grid{display:flex;flex-wrap:wrap;align-items:center;align-content:flex-start;gap:16px;margin:0;padding:0;list-style:none}
.about-history-grid li{display:flex;min-width:0}
.about-history-grid a{position:relative;display:block;border-radius:8px;outline-offset:5px;transition:transform .2s ease,filter .2s ease}
.about-history-grid a::after{content:"";position:absolute;inset:0;border:1px solid rgba(148,163,184,.18);border-radius:inherit;pointer-events:none}
.about-history-grid a:hover{filter:brightness(1.08);transform:translateY(-2px)}
.about-history-grid img{width:auto;max-width:100%;height:118px;border-radius:8px;box-shadow:0 18px 54px rgba(2,6,23,.2)}

/* Philosophy page */
.philosophy-page{--parallax-bg-image:url("img/abstract-background-blue-red.jpg");--parallax-bg-inset:220px;--parallax-bg-scale:1.05;--parallax-bg-opacity:.86;overflow:hidden;isolation:isolate;background:var(--bg)}
.philosophy-page::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(90deg,rgba(2,6,23,.66),rgba(2,6,23,.46) 48%,rgba(2,6,23,.24)),linear-gradient(0deg,rgba(2,6,23,.46),rgba(2,6,23,.08) 48%,rgba(2,6,23,.52))}
.philosophy-grid{position:relative;display:grid;grid-template-columns:minmax(0,1fr) minmax(300px,.62fr);align-items:center;gap:76px}
.philosophy-copy{max-width:none}
.section .philosophy-copy > h1,
.section .philosophy-copy > p,
.section .philosophy-copy > .section-lead{max-width:none}
.philosophy-visual{min-height:500px}
.philosophy-visual img{width:min(310px,74%)}
.philosophy-plain{overflow:hidden;background:linear-gradient(180deg,#0b1020 0%,#111827 56%,#0b1020 100%)}
.philosophy-plain::before{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(120deg,rgba(226,0,26,.1),transparent 32%,rgba(125,211,252,.1)),linear-gradient(rgba(255,255,255,.032) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.032) 1px,transparent 1px);background-size:auto,64px 64px,64px 64px;mask-image:linear-gradient(180deg,transparent,black 14%,black 86%,transparent);opacity:.58}
.philosophy-plain-wrap{position:relative;display:grid;grid-template-columns:minmax(280px,.46fr) minmax(0,1fr);align-items:start;gap:76px}
.section.philosophy-plain h2{position:relative;margin:0;padding-bottom:22px;font-family:"Bebas Neue","Nunito Sans",Arial,sans-serif;font-size:62px;font-weight:400;line-height:.98;letter-spacing:0;color:var(--white)}
.section.philosophy-plain h2::after{content:"";position:absolute;left:0;bottom:0;width:116px;height:3px;border-radius:999px;background:linear-gradient(90deg,var(--primary),#7dd3fc,transparent)}
.philosophy-claim{margin:26px 0 0;color:var(--white);font-size:24px;font-weight:800;line-height:1.42}
.philosophy-textflow{display:grid}
.philosophy-textflow p{margin:0;padding:24px 0;border-top:1px solid rgba(148,163,184,.18);color:#dbe4f0;font-size:19px;line-height:1.7}
.philosophy-textflow p:last-of-type{border-bottom:1px solid rgba(148,163,184,.18)}
.philosophy-textflow .btn{justify-self:start;margin-top:34px}

/* B2B agency page */
.b2b-page{overflow:hidden;background:linear-gradient(180deg,#0b1020 0%,#10192d 52%,#0b1020 100%)}
.b2b-page::before{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(90deg,rgba(226,0,26,.13),transparent 36%,rgba(125,211,252,.1)),linear-gradient(rgba(255,255,255,.032) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.032) 1px,transparent 1px);background-size:auto,72px 72px,72px 72px;mask-image:linear-gradient(180deg,transparent,black 13%,black 88%,transparent);opacity:.58}
.b2b-hero{position:relative;display:block}
.section .b2b-copy > h1,
.section .b2b-copy > p,
.section .b2b-copy > .section-lead{max-width:none}
.b2b-text-columns{column-count:2;column-gap:64px;margin-top:24px}
.b2b-text-columns p{break-inside:avoid;margin:0;color:#dbe4f0;font-size:19px;line-height:1.68}
.b2b-text-columns p + p{margin-top:20px}
.founder-page::before{background:linear-gradient(90deg,rgba(226,0,26,.12),transparent 34%,rgba(255,176,0,.08),rgba(125,211,252,.08)),linear-gradient(rgba(255,255,255,.032) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.032) 1px,transparent 1px);background-size:auto,72px 72px,72px 72px}
.founder-cta::before{background:radial-gradient(circle at 88% 34%,rgba(255,176,0,.13),transparent 28%),linear-gradient(90deg,rgba(226,0,26,.12),transparent 38%,rgba(125,211,252,.08));opacity:.84}
.b2b-visual{position:relative;display:grid;place-items:center;min-height:470px;isolation:isolate}
.b2b-visual::before{content:"";position:absolute;width:min(460px,86%);aspect-ratio:1;border-radius:50%;background:radial-gradient(circle,rgba(125,211,252,.2),rgba(226,0,26,.12) 46%,transparent 72%);filter:blur(22px);opacity:.88;animation:printGlow 6s ease-in-out infinite alternate}
.b2b-mark{position:relative;z-index:1;font-family:"Bebas Neue","Nunito Sans",Arial,sans-serif;font-size:clamp(132px,18vw,260px);font-weight:400;line-height:.8;letter-spacing:0;color:transparent;-webkit-text-stroke:1px rgba(255,255,255,.56);text-shadow:0 0 46px rgba(125,211,252,.16)}
.b2b-mark::after{content:"";position:absolute;right:6%;bottom:-18px;left:6%;height:3px;border-radius:999px;background:linear-gradient(90deg,transparent,var(--primary),#7dd3fc,transparent);box-shadow:0 0 30px rgba(125,211,252,.34)}
.b2b-smallprint{position:absolute;right:0;bottom:58px;z-index:2;max-width:230px;margin:0;padding-top:18px;border-top:1px solid rgba(148,163,184,.26);color:#dbe4f0;font-size:15px;font-weight:800;line-height:1.35}
.b2b-text-section{overflow:hidden;background:linear-gradient(180deg,#0b1020 0%,#111827 56%,#0b1020 100%)}
.b2b-text-section::before{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(circle at 88% 16%,rgba(125,211,252,.12),transparent 30%),linear-gradient(120deg,rgba(226,0,26,.1),transparent 34%,rgba(125,211,252,.08));opacity:.72}
.b2b-text-wrap{position:relative;display:grid;grid-template-columns:minmax(280px,.46fr) minmax(0,1fr);align-items:start;gap:76px}
.section.b2b-text-section h2{position:relative;margin:0;padding-bottom:22px;font-family:"Bebas Neue","Nunito Sans",Arial,sans-serif;font-size:62px;font-weight:400;line-height:.98;letter-spacing:0;color:var(--white)}
.section.b2b-text-section h2::after{content:"";position:absolute;left:0;bottom:0;width:116px;height:3px;border-radius:999px;background:linear-gradient(90deg,var(--primary),#7dd3fc,transparent)}
.b2b-headline p{margin:26px 0 0;color:var(--white);font-size:23px;font-weight:800;line-height:1.45}
.webdesign-content-image{position:relative;margin:34px 0 0;overflow:hidden;border:1px solid rgba(148,163,184,.24);border-radius:8px;background:rgba(15,23,42,.54);box-shadow:0 22px 62px rgba(2,6,23,.28)}
.webdesign-content-image::before{content:"";position:absolute;inset:0 0 auto;height:2px;background:linear-gradient(90deg,transparent,var(--primary),#7dd3fc,transparent);opacity:.78;pointer-events:none}
.webdesign-content-image a,
.webdesign-abstract-visual a,
.webdesign-team-cutout a{display:block;cursor:zoom-in}
.webdesign-content-image a:hover img,
.webdesign-content-image a:focus-visible img,
.webdesign-abstract-visual a:hover img,
.webdesign-abstract-visual a:focus-visible img{filter:brightness(1.08) saturate(1.04)}
.webdesign-team-cutout a:hover img,
.webdesign-team-cutout a:focus-visible img{filter:drop-shadow(0 30px 52px rgba(125,211,252,.24)) drop-shadow(0 26px 46px rgba(2,6,23,.36))}
.webdesign-content-image img{display:block;width:100%;height:auto;aspect-ratio:4 / 3;object-fit:cover}
.webdesign-content-image figcaption{margin:0;padding:14px 16px;color:#cbd5e1;font-size:14px;font-weight:800;line-height:1.35}
.webdesign-strategy-section .b2b-text-wrap{grid-template-columns:minmax(0,.92fr) minmax(360px,.78fr);align-items:center;gap:70px}
.webdesign-strategy-section{--parallax-bg-image:url("img/abstract-background-blue-red.jpg");--parallax-bg-inset:230px;--parallax-bg-scale:1.06;--parallax-bg-opacity:.92;background:var(--bg)}
.webdesign-strategy-section::before{background-image:var(--parallax-bg-image);background-size:cover;background-repeat:no-repeat;background-position:center calc(50% + var(--parallax-bg-y));opacity:var(--parallax-bg-opacity);transform:scale(var(--parallax-bg-scale));will-change:background-position}
.webdesign-strategy-section::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(90deg,rgba(2,6,23,.7),rgba(2,6,23,.48) 46%,rgba(2,6,23,.32)),linear-gradient(0deg,rgba(2,6,23,.5),rgba(2,6,23,.12) 48%,rgba(2,6,23,.58));pointer-events:none}
.webdesign-strategy-copy{max-width:790px}
.webdesign-strategy-flow{margin-top:30px}
.webdesign-strategy-section .webdesign-content-image{margin:0;align-self:center}
.webdesign-abstract-visual{position:relative;width:min(980px,100%);margin:8px auto 0;overflow:hidden;border:1px solid rgba(148,163,184,.24);border-radius:8px;background:rgba(15,23,42,.5);box-shadow:0 24px 70px rgba(2,6,23,.3)}
.webdesign-abstract-visual::before{content:"";position:absolute;inset:0 0 auto;height:2px;background:linear-gradient(90deg,transparent,var(--primary),#7dd3fc,transparent);opacity:.78;pointer-events:none}
.webdesign-abstract-visual img{display:block;width:100%;height:auto;aspect-ratio:16 / 9;object-fit:cover}
.webdesign-team-cutout{position:relative;display:grid;justify-items:center;margin:34px 0 0;min-height:220px;overflow:visible}
.webdesign-team-cutout::before{content:"";position:absolute;right:8%;bottom:10px;left:8%;height:48%;border-radius:50%;background:radial-gradient(circle,rgba(125,211,252,.2),rgba(226,0,26,.14) 46%,transparent 72%);filter:blur(18px);opacity:.9}
.webdesign-team-cutout img{position:relative;z-index:1;width:min(520px,100%);height:auto;align-self:end;filter:drop-shadow(0 26px 46px rgba(2,6,23,.36))}
.b2b-flow{display:grid}
.b2b-flow p{margin:0;padding:24px 0;border-top:1px solid rgba(148,163,184,.18);color:#dbe4f0;font-size:18px;line-height:1.7}
.b2b-flow p:last-of-type{border-bottom:1px solid rgba(148,163,184,.18)}
.b2b-lines{overflow:hidden;background:var(--bg)}
.b2b-lines-wrap{position:relative;display:grid;gap:34px}
.section.b2b-lines h2{position:relative;margin:0;padding-bottom:22px;font-family:"Bebas Neue","Nunito Sans",Arial,sans-serif;font-size:58px;font-weight:400;line-height:.98;letter-spacing:0;color:var(--white)}
.section.b2b-lines h2::after{content:"";position:absolute;left:0;bottom:0;width:116px;height:3px;border-radius:999px;background:linear-gradient(90deg,var(--primary),#7dd3fc,transparent)}
.b2b-service-lines{display:grid;margin:0;padding:0;border-top:1px solid rgba(148,163,184,.22);list-style:none}
.b2b-service-lines li{display:grid;grid-template-columns:minmax(210px,.34fr) minmax(0,1fr);gap:38px;padding:24px 0;border-bottom:1px solid rgba(148,163,184,.18)}
.b2b-service-lines strong{color:var(--white);font-size:20px;line-height:1.25}
.b2b-service-lines span{color:#dbe4f0;font-size:17px;line-height:1.62}
.b2b-service-lines i,
.b2b-service-lines svg{width:18px;margin-right:10px;color:#7dd3fc;font-size:16px}
.webdesign-services-section{overflow:hidden;background:linear-gradient(180deg,#0b1020 0%,#101827 50%,#0b1020 100%);isolation:isolate}
.webdesign-services-section::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;background:radial-gradient(circle at 14% 22%,rgba(226,0,26,.18),transparent 31%),radial-gradient(circle at 86% 68%,rgba(125,211,252,.14),transparent 35%),linear-gradient(120deg,rgba(255,255,255,.04),transparent 31%,rgba(125,211,252,.05));opacity:.86}
.webdesign-services-section::after{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;background:linear-gradient(90deg,transparent,rgba(255,255,255,.055),transparent);opacity:.18;transform:translateX(-48%) skewX(-14deg);animation:webdesignServicesSweep 18s ease-in-out infinite alternate}
.webdesign-services-wrap{position:relative;z-index:1;display:grid;grid-template-columns:minmax(280px,.42fr) minmax(0,1fr);align-items:start;gap:72px}
.webdesign-services-head{position:sticky;top:120px;display:grid;gap:24px}
.section.webdesign-services-section h2{position:relative;margin:0;padding-bottom:22px;font-family:"Bebas Neue","Nunito Sans",Arial,sans-serif;font-size:64px;font-weight:400;line-height:.98;letter-spacing:0;color:var(--white)}
.section.webdesign-services-section h2::after{content:"";position:absolute;left:0;bottom:0;width:116px;height:3px;border-radius:999px;background:linear-gradient(90deg,var(--primary),#7dd3fc,transparent)}
.webdesign-services-head p{margin:0;color:#dbe4f0;font-size:20px;font-weight:800;line-height:1.55}
.webdesign-services-note{position:relative;display:grid;gap:10px;margin-top:2px;padding:20px 22px 22px;border:1px solid rgba(148,163,184,.18);border-radius:8px;background:rgba(15,23,42,.48);color:var(--muted);font-size:16px;line-height:1.6;box-shadow:0 18px 56px rgba(2,6,23,.22)}
.webdesign-services-note::before{content:"";position:absolute;inset:0 0 auto;height:2px;border-radius:8px 8px 0 0;background:linear-gradient(90deg,var(--primary),#7dd3fc,transparent);opacity:.9}
.webdesign-services-note strong{color:var(--white);font-size:15px;font-weight:900;letter-spacing:.08em;text-transform:uppercase}
.webdesign-service-list{position:relative;display:grid;margin:0;padding:10px;border:1px solid rgba(148,163,184,.18);border-radius:8px;background:linear-gradient(135deg,rgba(15,23,42,.72),rgba(11,16,32,.5));box-shadow:0 26px 80px rgba(2,6,23,.32),inset 0 1px 0 rgba(255,255,255,.04);list-style:none;overflow:hidden}
.webdesign-service-list::before{content:"";position:absolute;inset:0 0 auto;height:1px;background:linear-gradient(90deg,transparent,rgba(125,211,252,.58),rgba(226,0,26,.52),transparent);opacity:.86}
.webdesign-service-item{position:relative;display:grid;grid-template-columns:74px minmax(190px,.34fr) minmax(0,1fr);align-items:start;gap:26px;padding:26px 24px;border-bottom:1px solid rgba(148,163,184,.15);border-radius:6px;transition:background-color .2s ease,border-color .2s ease,box-shadow .2s ease,transform .2s ease}
.webdesign-service-item:last-child{border-bottom:0}
.webdesign-service-item::before{content:"";position:absolute;top:14px;bottom:14px;left:0;width:3px;border-radius:999px;background:linear-gradient(180deg,var(--primary),#7dd3fc);opacity:0;transition:opacity .2s ease}
.webdesign-service-item::after{content:"";position:absolute;inset:0;border-radius:6px;background:linear-gradient(90deg,rgba(226,0,26,.12),rgba(125,211,252,.08),transparent 62%);opacity:0;pointer-events:none;transition:opacity .2s ease}
.webdesign-service-item:hover{border-color:rgba(125,211,252,.22);background:rgba(15,23,42,.76);box-shadow:0 16px 42px rgba(2,6,23,.24);transform:translateX(4px)}
.webdesign-service-item:hover::before,.webdesign-service-item:hover::after{opacity:1}
.webdesign-service-index{position:relative;z-index:1;display:grid;place-items:center;width:54px;height:54px;border:1px solid rgba(125,211,252,.3);border-radius:8px;background:rgba(125,211,252,.1);color:#e0f2fe;font-family:"Bebas Neue","Nunito Sans",Arial,sans-serif;font-size:34px;font-weight:400;line-height:1;box-shadow:inset 0 1px 0 rgba(255,255,255,.06)}
.webdesign-service-item h3{position:relative;z-index:1;display:flex;align-items:flex-start;gap:10px;margin:0;color:var(--white);font-size:22px;font-weight:900;line-height:1.2}
.webdesign-service-item p{position:relative;z-index:1;margin:0;color:#dbe4f0;font-size:17px;line-height:1.68}
.webdesign-service-item i{flex:0 0 30px;display:grid;place-items:center;width:30px;height:30px;margin:0;border:1px solid rgba(125,211,252,.28);border-radius:8px;background:rgba(125,211,252,.1);color:#7dd3fc;font-size:13px;line-height:1}
.webdesign-service-item svg.svg-inline--fa{flex:0 0 30px;box-sizing:border-box;width:30px;height:30px;margin:0;padding:7px;border:1px solid rgba(125,211,252,.28);border-radius:8px;background:rgba(125,211,252,.1);color:#7dd3fc}
.b2b-cta{overflow:hidden;background:linear-gradient(135deg,#111827 0%,#0b1020 52%,#131b2f 100%)}
.b2b-cta::before{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(circle at 88% 34%,rgba(125,211,252,.14),transparent 28%),linear-gradient(90deg,rgba(226,0,26,.12),transparent 38%,rgba(125,211,252,.08));opacity:.84}
.b2b-cta-wrap{position:relative;display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:48px;padding:42px 0;border-top:1px solid rgba(148,163,184,.22);border-bottom:1px solid rgba(148,163,184,.18)}
.b2b-cta-wrap::before{content:"";position:absolute;top:-1px;left:0;width:min(220px,38%);height:3px;border-radius:999px;background:linear-gradient(90deg,var(--primary),#7dd3fc,transparent)}
.b2b-cta h2{margin:0;color:var(--white);font-size:34px;line-height:1.12}
.section.b2b-cta h2{font-family:"Nunito Sans",Arial,sans-serif;font-size:34px;font-weight:900;letter-spacing:0}
.b2b-cta p{max-width:760px;margin:16px 0 0;color:#dbe4f0;font-size:18px;line-height:1.65}
.b2b-cta .btn{box-shadow:0 18px 46px rgba(226,0,26,.32),0 16px 54px rgba(2,6,23,.22)}

/* Workflow page */
.workflow-page{overflow:hidden;background:linear-gradient(180deg,#0b1020 0%,#10192d 52%,#0b1020 100%)}
.workflow-page::before{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(90deg,rgba(226,0,26,.12),transparent 36%,rgba(125,211,252,.1)),linear-gradient(rgba(255,255,255,.032) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.032) 1px,transparent 1px);background-size:auto,58px 58px,58px 58px;mask-image:linear-gradient(180deg,transparent,black 12%,black 88%,transparent);opacity:.58}
.workflow-wrap{position:relative;display:grid;gap:46px}
.workflow-hero{display:block}
.workflow-intro{max-width:none}
.workflow-intro h1{position:relative;margin:0;padding-bottom:24px;font-family:"Bebas Neue","Nunito Sans",Arial,sans-serif;font-size:74px;font-weight:400;line-height:.95;letter-spacing:0;color:var(--white)}
.workflow-intro h1::after{content:"";position:absolute;left:0;bottom:0;width:116px;height:3px;border-radius:999px;background:linear-gradient(90deg,var(--primary),#7dd3fc,transparent)}
.workflow-lead{max-width:none;margin:24px 0 0;color:var(--white);font-size:23px;font-weight:800;line-height:1.42}
.workflow-intro p:not(.workflow-lead){max-width:none;margin:20px 0 0;color:#dbe4f0;font-size:18px;line-height:1.65}
.workflow-steps{position:relative;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin:0;padding:0;list-style:none}
.workflow-steps::before{content:"";position:absolute;top:36px;right:10%;left:10%;height:2px;background:linear-gradient(90deg,var(--primary),#7dd3fc);opacity:.34}
.workflow-step{position:relative;display:grid;grid-template-rows:auto auto 1fr;gap:12px;min-height:230px;padding:22px;border:1px solid rgba(148,163,184,.18);border-radius:8px;background:rgba(11,16,32,.62);box-shadow:0 18px 54px rgba(2,6,23,.2);overflow:hidden}
.workflow-step::before{content:"";position:absolute;inset:0 0 auto;height:2px;background:linear-gradient(90deg,transparent,var(--primary),#7dd3fc,transparent);opacity:.72}
.workflow-step-number{position:relative;z-index:1;display:grid;place-items:center;width:42px;height:42px;border:1px solid rgba(125,211,252,.38);border-radius:8px;background:rgba(125,211,252,.12);color:var(--white);font-size:15px;font-weight:900;line-height:1}
.workflow-step h2{position:relative;z-index:1;margin:0;color:var(--white);font-family:"Nunito Sans",Arial,sans-serif;font-size:20px;font-weight:900;line-height:1.2;letter-spacing:0}
.workflow-step p{position:relative;z-index:1;margin:0;color:#cbd5e1;font-size:15px;line-height:1.55}
.workflow-principles{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin:0;padding:0;list-style:none}
.workflow-principles li{display:flex;align-items:center;gap:12px;min-height:74px;padding:16px 18px;border:1px solid rgba(148,163,184,.16);border-radius:8px;background:rgba(15,23,42,.5);color:var(--white);font-size:15px;font-weight:800;line-height:1.25}
.workflow-principles i{color:#7dd3fc;font-size:16px}
.workflow-industries{overflow:hidden;background:linear-gradient(180deg,#0b1020 0%,#111827 58%,#0b1020 100%)}
.workflow-industries::before{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(circle at 84% 18%,rgba(125,211,252,.13),transparent 30%),linear-gradient(120deg,rgba(226,0,26,.1),transparent 34%,rgba(125,211,252,.08));opacity:.72}
.workflow-industries-wrap{position:relative;display:grid;justify-items:center;gap:28px;text-align:center}
.workflow-industries-intro{max-width:860px;margin-inline:auto}
.workflow-industries h2{position:relative;display:inline-block;margin:0;padding-bottom:18px;font-family:"Bebas Neue","Nunito Sans",Arial,sans-serif;font-size:54px;font-weight:400;line-height:1;letter-spacing:0;color:var(--white)}
.workflow-industries h2::after{content:"";position:absolute;left:50%;bottom:0;width:116px;height:3px;border-radius:999px;background:linear-gradient(90deg,var(--primary),#7dd3fc,transparent);transform:translateX(-50%)}
.workflow-industries p{max-width:760px;margin:18px auto 0;color:#dbe4f0;font-size:18px;line-height:1.6}
.industry-tags{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin:0;padding:0;list-style:none}
.industry-tag{display:inline-flex;align-items:center;min-height:42px;padding:10px 14px;border:1px solid rgba(148,163,184,.18);border-radius:8px;background:rgba(15,23,42,.56);color:#dbe4f0;font-size:15px;font-weight:800;line-height:1.2;box-shadow:0 12px 34px rgba(2,6,23,.16)}
.industry-tag:is(a){transition:background-color .2s ease,border-color .2s ease,color .2s ease,transform .2s ease}
.industry-tag:is(a):hover{border-color:var(--footer-hover);background:rgba(125,211,252,.14);color:var(--white);transform:translateY(-1px)}
.webdesign-technology-section::before{background:radial-gradient(circle at 84% 16%,rgba(125,211,252,.16),transparent 30%),radial-gradient(circle at 12% 74%,rgba(226,0,26,.14),transparent 32%),linear-gradient(120deg,rgba(226,0,26,.1),transparent 34%,rgba(125,211,252,.08));opacity:.82}
.webdesign-technology-wrap{display:grid;grid-template-columns:minmax(0,.8fr) minmax(360px,.62fr);grid-template-areas:"intro visual";align-items:center;justify-items:stretch;gap:50px 70px;text-align:left}
.webdesign-technology-intro{grid-area:intro;max-width:720px;margin:0}
.webdesign-technology-section h2{display:block}
.webdesign-technology-section h2::after{left:0;transform:none}
.webdesign-technology-section p{max-width:680px;margin:22px 0 0}
.webdesign-tech-proof{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:30px}
.webdesign-tech-proof span{position:relative;display:grid;gap:4px;min-height:72px;padding:16px 16px 14px;border:1px solid rgba(148,163,184,.18);border-radius:8px;background:rgba(15,23,42,.5);color:#dbe4f0;font-size:14px;font-weight:700;line-height:1.32;overflow:hidden}
.webdesign-tech-proof span::before{content:"";position:absolute;inset:0 0 auto;height:2px;background:linear-gradient(90deg,var(--primary),#7dd3fc,transparent);opacity:.78}
.webdesign-tech-proof strong{display:block;color:var(--white);font-size:16px;font-weight:900;line-height:1.1}
.webdesign-technology-visual{grid-area:visual;width:100%;margin:0;box-shadow:0 28px 84px rgba(2,6,23,.36)}
.webdesign-technology-visual img{height:clamp(320px,32vw,430px);aspect-ratio:auto;object-fit:cover}

/* Reusable image lightbox */
.lightbox-open{overflow:hidden}
.site-lightbox{position:fixed;inset:0;z-index:3000;display:grid;place-items:center;padding:48px;background:rgba(2,6,23,.88);backdrop-filter:blur(18px) saturate(135%);-webkit-backdrop-filter:blur(18px) saturate(135%);opacity:0;visibility:hidden;pointer-events:none;transition:opacity .22s ease,visibility .22s ease}
.site-lightbox::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 24% 18%,rgba(226,0,26,.22),transparent 32%),radial-gradient(circle at 78% 74%,rgba(125,211,252,.18),transparent 34%);pointer-events:none}
.site-lightbox.is-active{opacity:1;visibility:visible;pointer-events:auto}
.site-lightbox-figure{position:relative;z-index:1;display:grid;gap:14px;max-width:min(1180px,calc(100vw - 168px));max-height:calc(100vh - 96px);margin:0;justify-items:center}
.site-lightbox-image{display:block;width:auto;max-width:100%;height:auto;max-height:calc(100vh - 152px);border:1px solid rgba(148,163,184,.26);border-radius:8px;background:rgba(11,16,32,.7);box-shadow:0 34px 90px rgba(0,0,0,.54)}
.site-lightbox-caption{max-width:min(760px,100%);color:#dbe4f0;font-size:15px;line-height:1.45;text-align:center}
.site-lightbox-caption:empty{display:none}
.site-lightbox button{position:relative;z-index:2;display:grid;place-items:center;width:48px;height:48px;border:1px solid rgba(148,163,184,.28);border-radius:8px;background:rgba(11,16,32,.62);color:var(--white);font:inherit;cursor:pointer;backdrop-filter:blur(14px) saturate(130%);-webkit-backdrop-filter:blur(14px) saturate(130%);transition:background-color .2s ease,border-color .2s ease,color .2s ease,transform .2s ease}
.site-lightbox button:hover{border-color:var(--footer-hover);background:var(--footer-hover);color:var(--black);transform:translateY(-1px)}
.site-lightbox button[hidden]{display:none}
.site-lightbox button i,
.site-lightbox button svg{font-size:18px}
.site-lightbox-close{position:absolute!important;top:22px;right:22px}
.site-lightbox-nav{position:absolute!important;top:50%;transform:translateY(-50%)}
.site-lightbox-nav:hover{transform:translateY(calc(-50% - 1px))!important}
.site-lightbox-prev{left:22px}
.site-lightbox-next{right:22px}

/* Support modal */
body.support-open{overflow:hidden}
.support-float{position:fixed;right:22px;bottom:22px;z-index:980;display:inline-flex;align-items:center;justify-content:center;gap:10px;min-height:54px;padding:0 20px;border:1px solid rgba(255,255,255,.16);border-radius:8px;background:var(--primary);color:var(--white);font:inherit;font-size:15px;font-weight:900;line-height:1;box-shadow:0 18px 46px rgba(226,0,26,.34),0 18px 54px rgba(2,6,23,.28);cursor:pointer;transition:background-color .2s ease,border-color .2s ease,box-shadow .2s ease,transform .2s ease}
.support-float i,
.support-float svg{font-size:18px}
.support-float:hover{border-color:rgba(255,255,255,.24);background:var(--primary-strong);transform:translateY(-2px)}
.support-modal{position:fixed;inset:0;z-index:3100;display:grid;place-items:center;padding:42px;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .22s ease,visibility .22s ease}
.support-modal.is-active{opacity:1;visibility:visible;pointer-events:auto}
.support-modal-backdrop{position:absolute;inset:0;background:rgba(2,6,23,.86);backdrop-filter:blur(18px) saturate(135%);-webkit-backdrop-filter:blur(18px) saturate(135%)}
.support-modal-backdrop::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 22% 18%,rgba(226,0,26,.24),transparent 32%),radial-gradient(circle at 82% 72%,rgba(125,211,252,.18),transparent 34%);pointer-events:none}
.support-modal-panel{position:relative;z-index:1;width:min(1080px,calc(100vw - 84px));max-height:calc(100vh - 84px);padding:58px;border:1px solid rgba(148,163,184,.26);border-radius:8px;background:linear-gradient(135deg,rgba(11,16,32,.98),rgba(17,24,39,.96) 58%,rgba(11,16,32,.98));box-shadow:0 34px 110px rgba(0,0,0,.56);overflow:auto;outline:none}
.support-modal-panel::before{content:"";position:absolute;inset:0 0 auto;height:3px;background:linear-gradient(90deg,transparent,var(--primary),#7dd3fc,transparent);opacity:.84}
.support-modal-close{position:absolute;top:18px;right:18px;z-index:2;display:grid;place-items:center;width:46px;height:46px;border:1px solid rgba(148,163,184,.28);border-radius:8px;background:rgba(15,23,42,.64);color:var(--white);font:inherit;cursor:pointer;transition:background-color .2s ease,border-color .2s ease,color .2s ease,transform .2s ease}
.support-modal-close:hover{border-color:var(--footer-hover);background:var(--footer-hover);color:var(--black);transform:translateY(-1px)}
.support-modal-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,.72fr);align-items:start;gap:64px}
.support-modal-main h2{position:relative;margin:0;padding-bottom:22px;font-family:"Bebas Neue","Nunito Sans",Arial,sans-serif;font-size:68px;font-weight:400;line-height:.96;letter-spacing:0;color:var(--white)}
.support-modal-main h2::after{content:"";position:absolute;left:0;bottom:0;width:116px;height:3px;border-radius:999px;background:linear-gradient(90deg,var(--primary),#7dd3fc,transparent)}
.support-modal-main p{max-width:660px;margin:20px 0 0;color:#dbe4f0;font-size:19px;line-height:1.65}
.support-modal-main .support-modal-lead{margin-top:26px;color:var(--white);font-size:23px;font-weight:800;line-height:1.42}
.support-download{margin-top:34px}
.support-modal-steps{padding-left:34px;border-left:1px solid rgba(148,163,184,.22)}
.support-modal-steps h3{margin:0;color:var(--white);font-size:28px;line-height:1.15}
.support-modal-steps ol{display:grid;gap:22px;margin:28px 0 0;padding:0;list-style:none;counter-reset:support-step}
.support-modal-steps li{position:relative;min-height:42px;padding-left:58px;color:#dbe4f0;font-size:17px;line-height:1.55;counter-increment:support-step}
.support-modal-steps li::before{content:counter(support-step);position:absolute;top:0;left:0;display:grid;place-items:center;width:40px;height:40px;border:1px solid rgba(125,211,252,.38);border-radius:8px;background:rgba(125,211,252,.12);color:var(--white);font-size:15px;font-weight:900;line-height:1}
.support-modal-steps a{color:var(--footer-hover);font-weight:900}
.support-modal-steps a:hover{text-decoration:underline;text-underline-offset:4px}

/* Legal pages */
.legal-page{overflow:hidden;background:linear-gradient(180deg,#0b1020 0%,#111827 48%,#0b1020 100%)}
.legal-page > .container{position:relative}
.legal-content{color:#dbe4f0;font-size:17px;line-height:1.7}
.legal-content h1{margin:0;font-family:"Bebas Neue","Nunito Sans",Arial,sans-serif;font-size:68px;font-weight:400;line-height:.96;letter-spacing:0;color:var(--white)}
.legal-content h2{margin:0 0 10px;color:var(--white);font-size:18px;line-height:1.3}
.legal-content > h2{margin-top:18px;font-size:20px}
.section.legal-page .legal-content h2{margin:0 0 10px;font-family:"Nunito Sans",Arial,sans-serif;font-size:18px;font-weight:800;line-height:1.3;letter-spacing:0;color:var(--white)}
.section.legal-page .legal-content > h2{margin-top:18px;font-size:20px}
.legal-content p,
.legal-content address{margin:0;color:#dbe4f0;font-style:normal}
.legal-content > p{margin-top:14px}
.legal-content > h2 + p{margin-top:22px}
.legal-content a{color:var(--footer-hover);text-decoration:none;text-underline-offset:4px}
.legal-content a:hover{text-decoration:underline}
.legal-details{display:grid;margin:30px 0 0;border-top:1px solid rgba(148,163,184,.22)}
.legal-detail-row{display:grid;grid-template-columns:minmax(130px,.18fr) minmax(0,1fr);gap:24px;padding:18px 0;border-top:1px solid rgba(148,163,184,.16)}
.legal-detail-row:first-child{border-top:0}
.legal-detail-label{color:var(--white);font-size:15px;font-weight:800;line-height:1.35}
.legal-detail-value{min-width:0;color:#dbe4f0}
.legal-contact-list{display:grid;gap:8px}
.legal-contact-item{display:grid;grid-template-columns:18px minmax(0,1fr);align-items:center;gap:10px;color:#dbe4f0}
.legal-contact-item i,
.legal-contact-item svg{width:18px;color:var(--white);font-size:14px;line-height:1}
.legal-contact-item span{min-width:0}
.legal-section{padding-top:28px;margin-top:28px;border-top:1px solid rgba(148,163,184,.18)}
.legal-section p + p{margin-top:14px}
.legal-note{margin-top:34px!important;color:var(--muted)!important;font-size:14px;line-height:1.6}
.custom-sitemap{display:grid;gap:34px;margin-top:34px}
.custom-sitemap-section{padding-top:28px;border-top:1px solid rgba(148,163,184,.18)}
.custom-sitemap-section:first-child{padding-top:0;border-top:0}
.custom-sitemap-list,
.custom-sitemap-children{margin:0;padding:0;list-style:none}
.custom-sitemap-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,280px),1fr));column-gap:36px}
.custom-sitemap-item{min-width:0;border-bottom:1px solid rgba(148,163,184,.16)}
.custom-sitemap-link{display:grid;grid-template-columns:18px minmax(0,1fr);align-items:center;gap:10px;padding:13px 0;color:#dbe4f0;text-decoration:none}
.custom-sitemap-link i{width:18px;color:var(--white);font-size:12px;line-height:1;transition:transform .2s ease}
.custom-sitemap-link span{min-width:0;overflow-wrap:anywhere}
.custom-sitemap-link:hover{color:var(--footer-hover);text-decoration:none}
.custom-sitemap-link:hover i{transform:translateX(3px)}
.custom-sitemap-children{margin:0 0 10px 28px;border-top:1px solid rgba(148,163,184,.12)}
.custom-sitemap-children .custom-sitemap-item{border-bottom:0}
.custom-sitemap-children .custom-sitemap-link{padding:9px 0;font-size:15px}

@keyframes aboutBulbFlicker{
    0%,100%{opacity:.58;transform:translate(calc(-50% - 20px),calc(-124% + 20px)) rotate(-7deg) scale(.92);filter:blur(8px) brightness(.96)}
    8%{opacity:.98;transform:translate(calc(-50% - 20px),calc(-124% + 20px)) rotate(-7deg) scale(1.08);filter:blur(6px) brightness(1.48)}
    13%{opacity:.42;transform:translate(calc(-50% - 20px),calc(-124% + 20px)) rotate(-7deg) scale(.86);filter:blur(10px) brightness(.88)}
    20%{opacity:1;transform:translate(calc(-50% - 20px),calc(-124% + 20px)) rotate(-7deg) scale(1.12);filter:blur(5px) brightness(1.62)}
    32%{opacity:.62;transform:translate(calc(-50% - 20px),calc(-124% + 20px)) rotate(-7deg) scale(.96);filter:blur(9px) brightness(1)}
    45%{opacity:.9;transform:translate(calc(-50% - 20px),calc(-124% + 20px)) rotate(-7deg) scale(1.04);filter:blur(7px) brightness(1.32)}
    59%{opacity:.5;transform:translate(calc(-50% - 20px),calc(-124% + 20px)) rotate(-7deg) scale(.9);filter:blur(10px) brightness(.9)}
    68%{opacity:1;transform:translate(calc(-50% - 20px),calc(-124% + 20px)) rotate(-7deg) scale(1.14);filter:blur(5px) brightness(1.68)}
    76%{opacity:.46;transform:translate(calc(-50% - 20px),calc(-124% + 20px)) rotate(-7deg) scale(.88);filter:blur(10px) brightness(.86)}
    88%{opacity:.82;transform:translate(calc(-50% - 20px),calc(-124% + 20px)) rotate(-7deg) scale(1.02);filter:blur(7px) brightness(1.22)}
}

@keyframes printFloat{
    from{transform:translate3d(0,-10px,0) rotate(-1.4deg)}
    to{transform:translate3d(0,10px,0) rotate(1.2deg)}
}

@keyframes printGlow{
    from{opacity:.68;transform:scale(.96)}
    to{opacity:.95;transform:scale(1.04)}
}

@keyframes mediaFloat{
    from{transform:translate3d(0,9px,0) rotate(1.2deg)}
    to{transform:translate3d(0,-9px,0) rotate(-1deg)}
}

@keyframes heroStars{
    from{transform:scale(1.18) translate3d(-3%,-2%,0) rotate(-12deg)}
    to{transform:scale(1.18) translate3d(3%,2%,0) rotate(12deg)}
}

@keyframes heroFloat{
    from{transform:translate3d(0,-8px,0) rotate(-1deg)}
    to{transform:translate3d(0,8px,0) rotate(1deg)}
}

@keyframes heroAstronaut{
    from{transform:translate3d(-8px,4px,0) rotate(6deg)}
    to{transform:translate3d(8px,-8px,0) rotate(14deg)}
}

@keyframes webdesignHeroDrift{
    from{background-position:50% 50%}
    to{background-position:56% 50%}
}

@keyframes webdesignOverlayPulse{
    from{filter:saturate(1) brightness(1)}
    to{filter:saturate(1.08) brightness(1.05)}
}

@keyframes webdesignSignalSweep{
    0%,18%{background-position:-120% 0,0 0,-80% 0;opacity:.32}
    48%{opacity:.56}
    72%,100%{background-position:160% 0,0 160px,120% 0;opacity:.36}
}

@keyframes webdesignServicesSweep{
    from{transform:translateX(-52%) skewX(-14deg)}
    to{transform:translateX(52%) skewX(-14deg)}
}

@media (prefers-reduced-motion: reduce) {
    .webdesign-hero-section,
    .webdesign-hero-section::before,
    .webdesign-hero-section::after,
    .webdesign-services-section::after{animation:none}
}

/* Footer */
.site-footer{margin-top:auto;padding:80px 0 28px;border-top:1px solid var(--line);background:var(--bg-soft);color:var(--ink)}
.footer-main{display:grid;grid-template-columns:1.35fr .75fr .75fr 1.35fr;gap:48px;padding-bottom:56px;border-bottom:1px solid var(--line)}
.footer-logo{display:inline-block;width:220px;max-width:100%}
.footer-brand-text{max-width:390px;margin:26px 0 0;color:var(--muted);font-size:16px;line-height:1.6}
.footer-socials{display:flex;gap:12px;margin-top:28px}
.footer-socials a{display:grid;place-items:center;width:48px;height:48px;border:1px solid var(--line);border-radius:8px;color:var(--muted);font-size:18px;transition:background-color .2s ease,border-color .2s ease,color .2s ease}
.footer-socials a:hover{border-color:var(--footer-hover);background:var(--footer-hover);color:var(--black)}
.footer-column{display:flex;flex-direction:column;gap:12px;font-style:normal}
.footer-column h2{margin:0 0 8px;font-family:"Bebas Neue","Nunito Sans",Arial,sans-serif;font-size:26px;font-weight:400;line-height:1;letter-spacing:0;color:var(--white)}
.footer-link-list,.footer-legal-list{margin:0;padding:0;list-style:none}
.footer-link-list{display:grid;gap:12px}
.footer-column a,.footer-column span,.footer-contact-name{color:var(--muted);font-size:16px;line-height:1.5}
.footer-column a:hover{color:var(--footer-hover)}
.footer-contact-item{display:grid;grid-template-columns:18px 1fr;align-items:center;gap:10px}
.footer-contact-item i,.footer-contact-item svg{color:var(--muted);font-size:14px;line-height:1;transition:color .2s ease}
.footer-contact-item span{min-width:0}
.footer-contact-item:hover i,.footer-contact-item:hover svg,.footer-contact-item:hover span{color:var(--footer-hover)}
.footer-hours{display:grid;gap:4px;margin-top:4px;color:var(--muted);font-size:16px;line-height:1.5}
.footer-hours strong{color:var(--white);font-size:15px;font-weight:700}
.footer-bottom{display:grid;grid-template-columns:1fr auto;align-items:center;gap:24px;padding-top:24px;color:var(--muted);font-size:15px}
.footer-bottom p{margin:0}
.footer-bottom p a:hover{color:var(--footer-hover)}
.footer-legal-list{display:flex;gap:24px;justify-content:flex-end;flex-wrap:wrap}
.footer-legal a:hover{color:var(--footer-hover)}

@media screen and (min-width: 1921px) {
    .container{max-width:1600px}
    .header-inner{gap:42px}
    .header-menu{gap:8px}
    .header-menu > li > a{padding-inline:18px}
    .hero-section{min-height:860px}
    .hero-content h1{font-size:142px}
    .hero-container{gap:90px}
    .hero-visual{min-height:560px}
    .hero-earth{width:min(600px,100%)}
    .hero-astronaut{width:min(180px,30%)}
}

@media screen and (max-width: 1399px) {
    .container{max-width:1140px}
    .header-inner{gap:22px}
    .header-logo{width:168px}
    .header-menu a{padding-inline:8px;font-size:13px}
    .header-menu > li > a{padding-inline:11px}
    .header-menu a.has-submenu::after{margin-left:6px}
    .hero-content h1{font-size:116px}
    .hero-text{font-size:20px}
    .hero-intro{gap:48px}
}

@media screen and (max-width: 1199px) {
    .container{max-width:960px}
    body.nav-open{overflow:hidden}
    .header-inner{justify-content:space-between}
    .header-logo{width:170px}
    .header-toggle{position:relative;z-index:1003;display:grid;place-items:center;width:46px;height:46px;padding:0;border:1px solid rgba(148,163,184,.22);border-radius:8px;background:rgba(255,255,255,.04);color:var(--ink);font-size:20px;cursor:pointer;transition:background-color .2s ease,border-color .2s ease,color .2s ease}
    .header-toggle:hover,
    .header-toggle:focus-visible{border-color:rgba(226,0,26,.45);background:rgba(226,0,26,.12)}
    .header-toggle i,
    .header-toggle svg{grid-area:1 / 1;transition:opacity .18s ease,transform .18s ease}
    .header-toggle-close{opacity:0;transform:scale(.82) rotate(-45deg)}
    body.nav-open .header-toggle-open{opacity:0;transform:scale(.82) rotate(45deg)}
    body.nav-open .header-toggle-close{opacity:1;transform:scale(1) rotate(0)}
    .header-overlay{position:fixed;inset:0;z-index:1001;display:block;border:0;background:rgba(2,6,23,.58);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);opacity:0;visibility:hidden;cursor:pointer;transition:opacity .22s ease,visibility .22s ease}
    body.nav-open .header-overlay{opacity:1;visibility:visible}
    .header-nav{position:fixed;top:0;right:0;z-index:1002;display:block;width:min(420px,calc(100vw - 28px));height:100vh;padding:104px 20px 28px;border-left:1px solid rgba(148,163,184,.22);background:rgba(8,13,28,.97);backdrop-filter:blur(28px) saturate(150%);-webkit-backdrop-filter:blur(28px) saturate(150%);box-shadow:-24px 0 80px rgba(2,6,23,.5);overflow-y:auto;opacity:0;visibility:hidden;transform:translateX(100%);transition:opacity .24s ease,visibility .24s ease,transform .24s ease}
    .admin-bar .header-nav{top:32px;height:calc(100vh - 32px)}
    body.nav-open .header-nav{opacity:1;visibility:visible;transform:translateX(0)}
    .header-menu{display:grid;align-items:stretch;justify-content:stretch;gap:6px}
    .header-menu > li{width:100%}
    .has-dropdown::before{display:none}
    .header-menu > li > a{justify-content:space-between;width:100%;min-height:48px;padding-inline:14px;font-size:15px}
    .header-menu a:hover,
    .header-menu a[aria-current="page"],
    .has-dropdown:hover > .has-submenu,
    .has-dropdown:focus-within > .has-submenu,
    .has-dropdown.is-open > .has-submenu{background:rgba(255,255,255,.055);color:var(--white)}
    .header-submenu{position:static;display:grid;gap:2px;min-width:0;max-height:0;margin:0;padding:0 0 0 14px;border:0;border-radius:0;background:transparent;box-shadow:none;backdrop-filter:none;-webkit-backdrop-filter:none;opacity:1;visibility:visible;overflow:hidden;transform:none;transition:max-height .25s ease,padding .25s ease}
    .header-submenu::before,
    .header-submenu::after{display:none}
    .header-submenu-right{right:auto}
    .has-dropdown:hover > .header-submenu,
    .has-dropdown:focus-within > .header-submenu,
    .has-dropdown.is-open > .header-submenu{opacity:1;visibility:visible;transform:none}
    .has-dropdown.is-open > .header-submenu{max-height:620px;margin-top:4px;padding:8px 8px 10px;border:1px solid rgba(148,163,184,.16);border-radius:8px;background:rgba(17,24,44,.5);backdrop-filter:blur(16px) saturate(135%);-webkit-backdrop-filter:blur(16px) saturate(135%)}
    .header-submenu a{min-height:36px;padding:4px 10px;font-size:14px}
    .hero-section{min-height:720px}
    .hero-intro{grid-template-columns:1fr}
    .hero-visual{min-height:360px;max-width:520px;justify-self:center;width:100%}
    .hero-earth{width:min(420px,78vw)}
    .hero-astronaut{right:12%;width:min(120px,24%)}
    .hero-services{grid-template-columns:repeat(2,1fr)}
    .about-grid{grid-template-columns:1fr;gap:48px}
    .about-content{max-width:none}
    .about-visual{min-height:420px}
    .about-visual img{width:min(320px,72vw)}
    .webdesign-grid{grid-template-columns:1fr;gap:48px}
    .webdesign-content{order:-1;justify-self:start;max-width:none}
    .webdesign-points{order:0}
    .webdesign-hero-section{min-height:auto;background-position:58% center}
    .print-grid{grid-template-columns:1fr;gap:48px}
    .print-showcase{max-width:760px}
    .it-grid{grid-template-columns:1fr;gap:48px}
    .it-content{order:-1;justify-self:start;max-width:none}
    .it-support{order:0;max-width:760px}
    .marketing-hero{grid-template-columns:1fr;gap:42px}
    .marketing-visual{max-width:640px;min-height:360px}
    .marketing-board{grid-template-columns:1fr;gap:18px}
    .marketing-tags{grid-template-columns:repeat(2,minmax(0,1fr))}
    .about-history-layout{grid-template-columns:1fr;gap:42px}
    .philosophy-grid{grid-template-columns:1fr;gap:44px}
    .philosophy-visual{max-width:540px;min-height:380px;justify-self:center;width:100%}
    .philosophy-plain-wrap{grid-template-columns:1fr;gap:38px}
    .b2b-hero{grid-template-columns:1fr;gap:44px}
    .b2b-visual{max-width:560px;min-height:340px;justify-self:center;width:100%}
    .b2b-smallprint{right:30px;bottom:36px}
    .b2b-text-wrap{grid-template-columns:1fr;gap:38px}
    .webdesign-strategy-section .b2b-text-wrap{grid-template-columns:1fr;gap:38px}
    .webdesign-services-wrap{grid-template-columns:1fr;gap:36px}
    .webdesign-services-head{position:relative;top:auto}
    .b2b-cta-wrap{grid-template-columns:1fr;align-items:start}
    .workflow-steps{grid-template-columns:repeat(2,minmax(0,1fr))}
    .workflow-steps::before{display:none}
    .workflow-principles{grid-template-columns:repeat(2,minmax(0,1fr))}
    .footer-bottom{grid-template-columns:1fr;text-align:center}
    .footer-legal-list{justify-content:center}
}

@media screen and (max-width: 991px) {
    .container{max-width:720px}
    body{padding-top:78px}
    .header-inner{min-height:78px;gap:20px}
    .header-logo{width:155px}
    .section{padding-block:84px;scroll-margin-top:78px}
    .hero-section{min-height:auto;margin-top:-78px;padding:calc(78px + 82px) 0 70px}
    .hero-container{gap:52px}
    .hero-content h1{font-size:92px}
    .hero-text{font-size:19px}
    .hero-visual{min-height:320px}
    .hero-earth{width:min(360px,76vw)}
    .hero-astronaut{width:min(96px,24%)}
    .section:not(.hero-section) h2{font-size:46px}
    .section .section-copy > h1{font-size:54px}
    .section .section-copy > h2{font-size:54px}
    .section .section-copy > p{font-size:18px}
    .section .section-copy > .section-lead{font-size:21px}
    .section.philosophy-plain h2{font-size:50px}
    .philosophy-claim{font-size:21px}
    .philosophy-textflow p{font-size:17px}
    .section.b2b-text-section h2,
    .section.b2b-lines h2,
    .section.webdesign-services-section h2{font-size:50px}
    .b2b-headline p{font-size:21px}
    .b2b-flow p,
    .b2b-service-lines span{font-size:17px}
    .webdesign-service-item{grid-template-columns:64px minmax(160px,.34fr) minmax(0,1fr);gap:22px;padding:24px 20px}
    .webdesign-services-head p{font-size:18px}
    .section.b2b-cta h2{font-size:30px}
    .workflow-intro h1{font-size:54px}
    .workflow-lead{font-size:21px}
    .workflow-intro p:not(.workflow-lead){font-size:17px}
    .workflow-industries h2{font-size:46px}
    .webdesign-technology-wrap{grid-template-columns:1fr;grid-template-areas:"intro" "visual";gap:34px;text-align:left}
    .webdesign-technology-visual{max-width:820px}
    .section-points li{min-height:166px;padding:20px}
    .print-showcase{min-height:380px}
    .site-footer{padding-top:64px}
    .footer-main{grid-template-columns:1fr;gap:40px;text-align:center}
    .footer-brand{display:grid;justify-items:center}
    .footer-brand-text{margin-inline:auto}
    .footer-socials{justify-content:center}
    .footer-column{align-items:center}
    .footer-link-list{justify-items:center}
    .footer-contact-item{grid-template-columns:auto auto;justify-content:center}
    .footer-hours{justify-items:center}
}

@media screen and (max-width: 767px) {
    .container{max-width:540px}
    body{padding-top:78px}
    .header-inner{min-height:78px}
    .header-menu a{min-height:36px;padding-inline:10px;font-size:14px}
    .header-menu > li > a{padding-inline:12px}
    .hero-section{padding:calc(78px + 64px) 0 56px}
    .hero-content h1{font-size:76px}
    .hero-kicker{font-size:21px}
    .hero-text{font-size:18px}
    .hero-service{min-height:220px}
    .about-grid{gap:36px}
    .about-visual{min-height:340px}
    .webdesign-grid{gap:36px}
    .webdesign-hero-section{background-position:62% center}
    .section-points{grid-template-columns:1fr}
    .section-points li{min-height:auto}
    .section-points--list li{grid-template-columns:32px 1fr}
    .print-grid{gap:36px}
    .it-grid{gap:36px}
    .marketing-wrap{gap:36px}
    .marketing-hero{gap:32px}
    .marketing-visual{min-height:300px}
    .marketing-main{grid-template-columns:1fr}
    .about-page-photo{min-height:360px}
    .philosophy-visual{min-height:320px}
    .b2b-visual{min-height:280px}
    .b2b-service-lines li{grid-template-columns:1fr;gap:12px;padding:22px 0}
    .about-history-grid img{height:96px}
    .site-lightbox{padding:72px 20px 28px}
    .site-lightbox-figure{max-width:100%;max-height:calc(100vh - 112px)}
    .site-lightbox-image{max-height:calc(100vh - 170px)}
    .site-lightbox-close{top:16px;right:16px}
    .site-lightbox-prev{left:16px}
    .site-lightbox-next{right:16px}
    .support-modal{padding:24px}
    .support-modal-panel{width:100%;max-height:calc(100vh - 48px);padding:46px 30px 34px}
    .support-modal-grid{grid-template-columns:1fr;gap:34px}
    .support-modal-main h2{font-size:54px}
    .support-modal-main .support-modal-lead{font-size:20px}
    .support-modal-main p{font-size:17px}
    .support-modal-steps{padding-top:30px;padding-left:0;border-top:1px solid rgba(148,163,184,.22);border-left:0}
    .legal-content h1{font-size:54px}
    .footer-main{grid-template-columns:1fr;gap:36px}
    .footer-bottom{grid-template-columns:1fr;gap:16px}
    .footer-legal-list{display:grid;gap:10px;justify-items:center;margin-top:8px}
}

@media screen and (max-width: 575px) {
    .container{max-width:100%;padding-inline:20px}
    .section{padding-block:68px}
    .hero-section{padding-top:calc(78px + 66px)}
    .hero-content h1{font-size:64px}
    .hero-visual{display:none}
    .hero-services{grid-template-columns:1fr;gap:18px}
    .hero-service{min-height:auto;gap:14px}
    .section:not(.hero-section) h2{font-size:40px}
    .section .section-copy > h1{font-size:42px}
    .section .section-copy > h2{font-size:42px}
    .section .section-copy > p{font-size:17px}
    .section .section-copy > .section-lead{font-size:19px;line-height:1.45}
    .section.philosophy-plain h2{font-size:42px}
    .philosophy-textflow p{padding:20px 0}
    .philosophy-textflow .btn{width:100%;margin-top:28px}
    .b2b-mark{font-size:clamp(112px,42vw,180px)}
    .b2b-smallprint{position:relative;right:auto;bottom:auto;justify-self:center;max-width:260px;margin-top:-28px;text-align:center}
    .b2b-text-columns{column-count:1;column-gap:0}
    .b2b-text-columns p{font-size:17px}
    .section.b2b-text-section h2,
    .section.b2b-lines h2,
    .section.webdesign-services-section h2{font-size:42px}
    .b2b-flow p{padding:20px 0}
    .b2b-service-lines strong{font-size:19px}
    .b2b-service-lines span{font-size:16px}
    .webdesign-services-wrap{gap:30px}
    .webdesign-services-note{padding:18px 18px 20px;font-size:15px}
    .webdesign-service-list{padding:8px}
    .webdesign-service-item{grid-template-columns:1fr;gap:12px;padding:22px 14px}
    .webdesign-service-item:hover{background:transparent;box-shadow:none;transform:none}
    .webdesign-service-item:hover::before,.webdesign-service-item:hover::after{opacity:0}
    .webdesign-service-index{width:48px;height:48px;font-size:32px}
    .webdesign-service-item h3{font-size:20px}
    .webdesign-service-item i{flex-basis:28px;width:28px;height:28px;font-size:12px}
    .webdesign-service-item svg.svg-inline--fa{flex-basis:28px;width:28px;height:28px;padding:7px}
    .webdesign-service-item p{font-size:16px}
    .b2b-cta-wrap{gap:28px}
    .section.b2b-cta h2{font-size:26px}
    .b2b-cta .btn{width:100%}
    .workflow-intro h1{font-size:42px}
    .workflow-steps,
    .workflow-principles{grid-template-columns:1fr}
    .workflow-step{min-height:auto}
    .workflow-industries h2{font-size:40px}
    .workflow-industries p{font-size:17px}
    .webdesign-tech-proof{grid-template-columns:1fr;gap:8px;margin-top:24px}
    .webdesign-technology-visual img{height:auto;aspect-ratio:4 / 3}
    .industry-tag{min-height:38px;padding:9px 12px;font-size:14px}
    .section-points h3{font-size:19px}
    .section-points p{font-size:15px}
    .section-points--list li{padding:18px}
    .marketing-tags{grid-template-columns:1fr}
    .marketing-visual{min-height:240px}
    .marketing-visual img{width:min(360px,94vw)}
    .about-page-photo{min-height:280px}
    .about-page-photo img{width:min(360px,94vw)}
    .about-history-grid{gap:12px}
    .about-history-grid img{height:76px}
    .site-lightbox{padding:72px 16px 24px}
    .site-lightbox button{width:44px;height:44px}
    .site-lightbox-nav{top:auto;bottom:16px;transform:none}
    .site-lightbox-nav:hover{transform:translateY(-1px)!important}
    .site-lightbox-prev{right:70px;left:auto}
    .site-lightbox-next{right:16px}
    .site-lightbox-image{max-height:calc(100vh - 190px)}
    .support-float{right:16px;bottom:16px;min-height:50px;padding:0 15px;font-size:14px}
    .support-modal{padding:16px}
    .support-modal-panel{max-height:calc(100vh - 32px);padding:42px 20px 26px}
    .support-modal-close{top:12px;right:12px;width:42px;height:42px}
    .support-modal-main h2{font-size:46px}
    .support-download{width:100%;margin-top:28px}
    .support-modal-steps h3{font-size:24px}
    .support-modal-steps li{padding-left:50px;font-size:16px}
    .section-tags li{min-height:56px;padding:14px 16px}
    .it-support::before{left:34px}
    .print-showcase{min-height:280px}
    .about-visual{min-height:280px}
    .about-visual img{width:min(250px,76vw)}
    .legal-content{font-size:16px}
    .legal-content h1{font-size:46px}
    .legal-detail-row{grid-template-columns:1fr;gap:8px;padding:16px 0}
    .site-footer{padding:56px 0 24px}
    .footer-main{padding-bottom:40px}
    .footer-logo{width:190px}
    .footer-socials a{width:44px;height:44px}
}

@media screen and (max-width: 400px) {
    .container{padding-inline:15px}
    .header-logo{width:145px}
}

@media screen and (max-width: 782px) {
    .admin-bar .site-header{top:46px}
    .admin-bar .header-nav{top:46px;height:calc(100vh - 46px)}
}
