/* ================================================================= FEEDBACK STUDIOS — "Iridescent Apparatus" Art direction: rotund geometric capsules (the brand imagotype) living inside a generative iridescent atmosphere. Satoshi as the workhorse, Instrument Serif for editorial accent moments. ================================================================= */ /* ----------------------------------------------------------------- 1. DESIGN TOKENS (primitive → semantic → component) ----------------------------------------------------------------- */ :root { /* --- primitive palette (brand) --- */ --violet-500: #8b5cf6; --violet-400: #a78bfa; /* contrast-safe violet for small TEXT on light surfaces (>=4.5:1) */ --violet-text: #7340d6; --blue-500: #3b82f6; --blue-400: #60a5fa; --emerald-500: #10b981; --rose-400: #f472b6; --ink-900: #0a0a12; --ink-800: #111827; --ink-700: #1c2230; --haze-50: #f4f4fb; --haze-100: #ecebf6; --white: #ffffff; /* --- signature gradient --- */ --grad-brand: linear-gradient(100deg, var(--violet-500), var(--blue-500)); /* CTA fill: deeper start so white text stays >=4.5:1 across the gradient */ --grad-cta: linear-gradient(100deg, var(--violet-text), #2f6ee0); --grad-brand-soft: linear-gradient(100deg, var(--violet-400), var(--blue-400)); --grad-spectrum: linear-gradient( 100deg, var(--violet-500), var(--blue-500) 45%, var(--rose-400) 75%, var(--emerald-500) ); /* --- semantic (light / iridescent surface) --- */ --bg: var(--haze-50); --surface: rgba(255, 255, 255, 0.55); --surface-strong: rgba(255, 255, 255, 0.78); --on-bg: var(--ink-900); /* darkened so they clear 4.5:1 even over the busiest pastel backdrop region */ --on-bg-muted: #36364a; --on-bg-faint: #424256; --primary: var(--violet-500); --on-primary: var(--white); --border: rgba(17, 24, 39, 0.12); --border-strong: rgba(17, 24, 39, 0.22); --ring: var(--violet-500); /* --- ink chapter (dark sections) --- */ --ink-bg: var(--ink-900); --ink-surface: rgba(255, 255, 255, 0.05); --ink-surface-strong: rgba(255, 255, 255, 0.08); --on-ink: #f3f2fb; --on-ink-muted: #b3b3ca; --on-ink-faint: #8888a0; --ink-border: rgba(255, 255, 255, 0.14); /* --- typography --- */ --font-sans: "Satoshi", ui-sans-serif, system-ui, sans-serif; --font-serif: "Instrument Serif", Georgia, serif; /* fluid scale */ --step--1: clamp(0.83rem, 0.79rem + 0.18vw, 0.94rem); --step-0: clamp(1rem, 0.95rem + 0.25vw, 1.15rem); --step-1: clamp(1.2rem, 1.1rem + 0.5vw, 1.55rem); --step-2: clamp(1.6rem, 1.35rem + 1.2vw, 2.4rem); --step-3: clamp(2.1rem, 1.6rem + 2.5vw, 3.6rem); --step-4: clamp(2.8rem, 1.9rem + 4.5vw, 5.5rem); --step-5: clamp(3.4rem, 1.8rem + 8vw, 9rem); /* --- spacing / layout --- */ --wrap: 1280px; --gutter: clamp(1.25rem, 4vw, 4rem); --space-section: clamp(5rem, 10vw, 11rem); --radius: 18px; --radius-lg: 28px; --radius-pill: 999px; /* --- motion --- */ --ease-out: cubic-bezier(0.22, 1, 0.36, 1); --dur: 0.3s; /* --- shadow --- */ --shadow-soft: 0 24px 60px -28px rgba(76, 49, 140, 0.45); --shadow-card: 0 18px 50px -24px rgba(40, 30, 90, 0.35); } /* ----------------------------------------------------------------- 2. RESET / BASE ----------------------------------------------------------------- */ *, *::before, *::after { box-sizing: border-box; margin: 0; } html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; } body { font-family: var(--font-sans); font-size: var(--step-0); line-height: 1.6; color: var(--on-bg); background: var(--bg); -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; overflow-x: hidden; } /* hide native cursor only when our custom one is active (desktop) */ body.has-custom-cursor, body.has-custom-cursor a, body.has-custom-cursor button, body.has-custom-cursor .hoverable { cursor: none; } img, svg { display: block; max-width: 100%; } a { color: inherit; text-decoration: none; } h1, h2, h3 { line-height: 1.02; letter-spacing: -0.02em; font-weight: 900; text-wrap: balance; } p { text-wrap: pretty; } ::selection { background: var(--violet-500); color: var(--white); } /* visible, high-contrast focus for keyboard users */ :focus-visible { outline: 3px solid var(--violet-500); outline-offset: 3px; border-radius: 4px; } .wrap { width: min(100% - var(--gutter) * 2, var(--wrap)); margin-inline: auto; } .skip-link { position: fixed; top: 0.75rem; left: 0.75rem; z-index: 200; padding: 0.7rem 1.1rem; background: var(--ink-900); color: var(--white); border-radius: var(--radius-pill); font-weight: 700; transform: translateY(-160%); transition: transform 0.25s var(--ease-out); } .skip-link:focus { transform: translateY(0); } /* ----------------------------------------------------------------- 3. IRIDESCENT BACKDROP (WebGL canvas + CSS fallback) ----------------------------------------------------------------- */ .iridescence { position: fixed; inset: 0; z-index: -2; /* fallback shown if WebGL fails / canvas hidden */ background: radial-gradient(120% 90% at 70% 12%, #fdfbff 0%, transparent 55%), radial-gradient(90% 80% at 18% 80%, rgba(244, 114, 182, 0.35), transparent 60%), linear-gradient(160deg, #e7e3fb 0%, #d9e4fb 45%, #e9d9f5 100%); } .iridescence__canvas { width: 100%; height: 100%; } /* veil to keep text legible over the busy backdrop */ .iridescence::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(244, 244, 251, 0.35) 0%, rgba(244, 244, 251, 0.12) 30%, transparent 60%), radial-gradient(130% 100% at 50% 0%, transparent 38%, rgba(244, 244, 251, 0.5) 100%); pointer-events: none; } /* ----------------------------------------------------------------- 4. CUSTOM CURSOR ----------------------------------------------------------------- */ .cursor-dot, .cursor-ring { position: fixed; top: 0; left: 0; pointer-events: none; z-index: 300; will-change: transform; transform: translate(-50%, -50%); } .cursor-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--ink-900); mix-blend-mode: difference; } .cursor-ring { width: 38px; height: 38px; border-radius: 50%; border: 1.5px solid rgba(17, 24, 39, 0.55); display: grid; place-items: center; transition: width 0.3s var(--ease-out), height 0.3s var(--ease-out), background 0.3s var(--ease-out), border-color 0.3s var(--ease-out); margin: -19px 0 0 -19px; /* center via margin so transform stays pure translate */ } .cursor-ring--big { width: 72px; height: 72px; margin: -36px 0 0 -36px; background: rgba(139, 92, 246, 0.14); border-color: rgba(139, 92, 246, 0.6); } .cursor-ring__label { font-size: 11px; font-weight: 700; letter-spacing: 0.04em; color: var(--violet-500); opacity: 0; transform: scale(0.7); transition: opacity 0.2s, transform 0.2s var(--ease-out); text-transform: lowercase; white-space: nowrap; } .cursor-ring--label { width: 86px; height: 86px; margin: -43px 0 0 -43px; background: var(--violet-500); border-color: var(--violet-500); } .cursor-ring--label .cursor-ring__label { opacity: 1; transform: scale(1); color: var(--white); } /* ----------------------------------------------------------------- 5. HEADER / NAV ----------------------------------------------------------------- */ .site-header { position: fixed; inset: 0 0 auto 0; z-index: 100; transition: backdrop-filter 0.3s, background 0.3s; } .site-header.is-scrolled { background: rgba(244, 244, 251, 0.6); backdrop-filter: blur(14px) saturate(140%); -webkit-backdrop-filter: blur(14px) saturate(140%); border-bottom: 1px solid var(--border); } .site-header__inner { width: min(100% - var(--gutter) * 2, var(--wrap)); margin-inline: auto; display: flex; align-items: center; justify-content: space-between; padding-block: clamp(0.9rem, 2vw, 1.4rem); } .brand { display: inline-flex; align-items: center; gap: 0.6rem; font-weight: 900; letter-spacing: -0.03em; } .brand__mark { width: 22px; height: auto; } .brand__word { font-size: var(--step-0); } .brand__word-2 { color: var(--on-bg-muted); font-weight: 500; } .brand__word--lg { font-size: var(--step-2); } .site-nav { display: flex; align-items: center; gap: clamp(1rem, 3vw, 2.2rem); } .site-nav ul { display: flex; gap: clamp(1rem, 2.5vw, 2rem); list-style: none; } .site-nav a { font-weight: 500; font-size: var(--step--1); position: relative; padding-block: 0.3rem; } .site-nav ul a::after { content: ""; position: absolute; left: 0; bottom: 0; width: 100%; height: 2px; background: var(--grad-brand); transform: scaleX(0); transform-origin: left; transition: transform 0.35s var(--ease-out); } .site-nav ul a:hover::after, .site-nav ul a:focus-visible::after { transform: scaleX(1); } .site-header__toggle { display: none; flex-direction: column; gap: 5px; width: 44px; height: 44px; align-items: center; justify-content: center; background: none; border: 1px solid var(--border-strong); border-radius: var(--radius-pill); } .site-header__toggle span { display: block; width: 18px; height: 2px; background: var(--on-bg); transition: transform 0.3s var(--ease-out), opacity 0.3s; } .site-header.is-open .site-header__toggle span:first-child { transform: translateY(3.5px) rotate(45deg); } .site-header.is-open .site-header__toggle span:last-child { transform: translateY(-3.5px) rotate(-45deg); } /* ----------------------------------------------------------------- 6. BUTTONS / LINKS ----------------------------------------------------------------- */ .btn { --pad-y: 0.95rem; --pad-x: 1.7rem; display: inline-flex; align-items: center; justify-content: center; gap: 0.5rem; padding: var(--pad-y) var(--pad-x); border-radius: var(--radius-pill); font-weight: 700; font-size: var(--step-0); letter-spacing: -0.01em; border: 1px solid transparent; transition: transform 0.3s var(--ease-out), box-shadow 0.3s var(--ease-out), background 0.3s, color 0.3s; min-height: 48px; position: relative; overflow: hidden; } .btn span { position: relative; z-index: 1; } .btn--primary { background: var(--grad-cta); color: var(--on-primary); box-shadow: var(--shadow-soft); } .btn--primary::before { content: ""; position: absolute; inset: 0; background: var(--grad-spectrum); opacity: 0; transition: opacity 0.4s var(--ease-out); } .btn--primary:hover::before, .btn--primary:focus-visible::before { opacity: 1; } .btn--ghost { background: var(--surface); color: var(--on-bg); border-color: var(--border-strong); backdrop-filter: blur(8px); } .btn--ghost:hover, .btn--ghost:focus-visible { border-color: var(--violet-text); color: var(--violet-text); } .btn--sm { --pad-y: 0.6rem; --pad-x: 1.15rem; font-size: var(--step--1); min-height: 40px; } .btn--lg { --pad-y: 1.15rem; --pad-x: 2.4rem; font-size: var(--step-1); } .magnetic { display: inline-block; } .link-arrow { display: inline-flex; align-items: center; gap: 0.45rem; font-weight: 700; color: var(--violet-text); margin-top: 1.5rem; } .link-arrow span { transition: transform 0.3s var(--ease-out); } .link-arrow:hover span, .link-arrow:focus-visible span { transform: translateX(5px); } /* shared kicker */ .kicker { font-size: var(--step--1); font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase; color: var(--violet-text); margin-bottom: 1.2rem; } .kicker--light { color: var(--violet-400); } /* editorial serif accent */ .serif-em, .hero__serif { font-family: var(--font-serif); font-weight: 400; font-style: italic; letter-spacing: 0; background: var(--grad-brand); -webkit-background-clip: text; background-clip: text; color: transparent; } .grad, .band__title-grad, .cta__title-grad, .hero__line--grad { background: var(--grad-brand); -webkit-background-clip: text; background-clip: text; color: transparent; } /* ----------------------------------------------------------------- 7. KINETIC TEXT (masked word reveal) ----------------------------------------------------------------- */ .ktext { display: inline; } .ktext__word { display: inline-block; overflow: hidden; vertical-align: top; padding-block: 0.04em; /* room for descenders inside the mask */ } .ktext__in { display: inline-block; will-change: transform; } .ktext__word--grad .ktext__in { background: var(--grad-brand); -webkit-background-clip: text; background-clip: text; color: transparent; } /* ----------------------------------------------------------------- 8. HERO ----------------------------------------------------------------- */ .hero { position: relative; min-height: 100svh; display: flex; align-items: center; padding-top: clamp(6rem, 12vh, 9rem); padding-bottom: clamp(3rem, 8vh, 6rem); } .hero__inner { position: relative; z-index: 2; } .hero__eyebrow { display: inline-flex; align-items: center; gap: 0.6rem; font-weight: 600; font-size: var(--step--1); letter-spacing: 0.04em; color: var(--on-bg-muted); padding: 0.5rem 1rem 0.5rem 0.75rem; border: 1px solid var(--border-strong); border-radius: var(--radius-pill); background: var(--surface); backdrop-filter: blur(8px); margin-bottom: clamp(1.5rem, 4vw, 2.5rem); } .hero__eyebrow .dot { width: 9px; height: 9px; border-radius: 50%; background: var(--emerald-500); box-shadow: 0 0 0 0 rgba(16, 185, 129, 0.6); animation: pulse 2.4s var(--ease-out) infinite; } @keyframes pulse { 0% { box-shadow: 0 0 0 0 rgba(16, 185, 129, 0.5); } 70% { box-shadow: 0 0 0 9px rgba(16, 185, 129, 0); } 100% { box-shadow: 0 0 0 0 rgba(16, 185, 129, 0); } } .hero__display { font-size: var(--step-5); line-height: 0.92; letter-spacing: -0.04em; max-width: 16ch; will-change: transform; } .hero__line { display: block; } .hero__line--mixed { display: block; } .hero__mark { position: absolute; top: clamp(4rem, 10vw, 7rem); right: clamp(-1rem, 2vw, 3rem); width: clamp(120px, 16vw, 230px); z-index: -1; filter: drop-shadow(0 30px 60px rgba(76, 49, 140, 0.3)); will-change: transform; } .hero__mark .pillmark { width: 100%; height: auto; } .hero__sub { margin-top: clamp(1.5rem, 4vw, 2.5rem); max-width: 48ch; font-size: var(--step-1); color: var(--on-bg-muted); line-height: 1.5; } .hero__sub strong { color: var(--on-bg); font-weight: 700; } .hero__actions { display: flex; flex-wrap: wrap; gap: 1rem; margin-top: clamp(2rem, 4vw, 2.8rem); } .hero__meta { display: flex; flex-wrap: wrap; gap: clamp(1.5rem, 5vw, 4rem); margin-top: clamp(3rem, 7vw, 5rem); padding-top: 1.8rem; border-top: 1px solid var(--border); } .hero__meta dt { font-size: var(--step--1); text-transform: uppercase; letter-spacing: 0.12em; color: var(--on-bg-faint); margin-bottom: 0.3rem; } .hero__meta dd { font-weight: 700; font-size: var(--step-0); } .hero__scroll { position: absolute; bottom: clamp(1.5rem, 4vw, 2.5rem); left: 50%; transform: translateX(-50%); display: inline-flex; flex-direction: column; align-items: center; gap: 0.4rem; font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--on-bg-faint); z-index: 2; } .hero__scroll svg { animation: bob 2s var(--ease-out) infinite; } @keyframes bob { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(5px); } } /* ----------------------------------------------------------------- 9. MARQUEE ----------------------------------------------------------------- */ .marquee { position: relative; overflow: hidden; padding-block: clamp(1.4rem, 3vw, 2.2rem); border-block: 1px solid var(--border); background: var(--surface); backdrop-filter: blur(6px); } .marquee__track { display: flex; width: max-content; animation: marquee 32s linear infinite; } .marquee__row { display: flex; align-items: center; flex-shrink: 0; } .marquee__item { display: inline-flex; align-items: center; font-family: var(--font-serif); font-style: italic; font-size: clamp(1.4rem, 4vw, 2.6rem); color: var(--on-bg); padding-inline: clamp(1rem, 3vw, 2.5rem); white-space: nowrap; } .marquee__sep { display: inline-block; width: 14px; height: 14px; margin-left: clamp(1rem, 3vw, 2.5rem); border-radius: var(--radius-pill); background: var(--grad-brand); } @keyframes marquee { to { transform: translateX(-50%); } } /* ----------------------------------------------------------------- 10. BANDS / GENERIC SECTIONS ----------------------------------------------------------------- */ .band { position: relative; padding-block: var(--space-section); } .band--ink { background: var(--ink-bg); color: var(--on-ink); } .band--ink .kicker { color: var(--violet-400); } .band__title { font-size: var(--step-3); max-width: 20ch; margin-bottom: clamp(2.5rem, 6vw, 4.5rem); } /* --- VENTAJA INJUSTA --- */ .advantage__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1.5rem, 3vw, 2.5rem); } .advantage__item { position: relative; padding: clamp(1.6rem, 3vw, 2.4rem); border: 1px solid var(--ink-border); border-radius: var(--radius-lg); background: var(--ink-surface); overflow: hidden; transition: transform 0.4s var(--ease-out), background 0.4s; } .advantage__item::before { content: ""; position: absolute; inset: 0 0 auto 0; height: 3px; background: var(--grad-spectrum); transform: scaleX(0); transform-origin: left; transition: transform 0.5s var(--ease-out); } .advantage__item:hover { transform: translateY(-6px); background: var(--ink-surface-strong); } .advantage__item:hover::before { transform: scaleX(1); } .advantage__index { font-size: var(--step--1); color: var(--on-ink-faint); font-weight: 700; letter-spacing: 0.1em; } .advantage__metric { font-size: var(--step-4); font-weight: 900; line-height: 1; letter-spacing: -0.04em; margin-block: 0.8rem 0.2rem; background: var(--grad-brand-soft); -webkit-background-clip: text; background-clip: text; color: transparent; } .advantage__metric-sub { display: block; font-size: var(--step--1); font-weight: 500; letter-spacing: 0.04em; color: var(--on-ink-muted); -webkit-text-fill-color: var(--on-ink-muted); } .advantage__k { font-size: var(--step-1); margin-bottom: 0.6rem; } .advantage__d { color: var(--on-ink-muted); font-size: var(--step-0); line-height: 1.55; } /* ----------------------------------------------------------------- 11. SERVICES — HORIZONTAL JOURNEY ----------------------------------------------------------------- */ .sjourney { position: relative; background: var(--ink-bg); color: var(--on-ink); padding-top: var(--space-section); } .sjourney__head { position: relative; z-index: 2; } .sjourney .kicker { color: var(--violet-400); } .sjourney__title { font-size: var(--step-3); max-width: 22ch; } .sjourney__progress { margin-top: clamp(2rem, 5vw, 3rem); height: 3px; width: 100%; background: var(--ink-border); border-radius: var(--radius-pill); overflow: hidden; } .sjourney__progress-bar { display: block; height: 100%; width: 100%; background: var(--grad-spectrum); transform: scaleX(0); transform-origin: left; } .sjourney__viewport { margin-top: clamp(2.5rem, 6vw, 4rem); padding-bottom: var(--space-section); overflow: hidden; } .sjourney__track { display: flex; gap: clamp(1.2rem, 2.5vw, 2rem); padding-inline: var(--gutter); width: max-content; will-change: transform; } .sjourney__panel { position: relative; flex: 0 0 auto; width: min(78vw, 440px); min-height: 56vh; padding: clamp(1.8rem, 3vw, 2.8rem); border: 1px solid var(--ink-border); border-radius: var(--radius-lg); background: var(--ink-surface); display: flex; flex-direction: column; overflow: hidden; transition: background 0.4s, transform 0.4s var(--ease-out); } .sjourney__panel:hover { background: var(--ink-surface-strong); } .sjourney__n { font-family: var(--font-serif); font-style: italic; font-size: var(--step-4); line-height: 1; background: var(--grad-brand-soft); -webkit-background-clip: text; background-clip: text; color: transparent; } .sjourney__panel-title { font-size: var(--step-2); margin-block: 1.2rem 0.8rem; } .sjourney__panel-desc { color: var(--on-ink-muted); font-size: var(--step-0); line-height: 1.55; max-width: 36ch; } .sjourney__tags { display: flex; flex-wrap: wrap; gap: 0.5rem; list-style: none; margin-top: auto; padding-top: 1.8rem; } .sjourney__tags li { font-size: var(--step--1); font-weight: 600; padding: 0.4rem 0.9rem; border: 1px solid var(--ink-border); border-radius: var(--radius-pill); color: var(--on-ink-muted); } .sjourney__pill { position: absolute; right: -60px; bottom: -60px; width: 180px; height: 180px; border-radius: var(--radius-pill); background: var(--grad-brand); opacity: 0.16; filter: blur(8px); transition: opacity 0.4s, transform 0.5s var(--ease-out); } .sjourney__panel:hover .sjourney__pill { opacity: 0.3; transform: scale(1.1); } /* ----------------------------------------------------------------- 12. SECTORS ----------------------------------------------------------------- */ .sectors { background: var(--bg); } .sectors__wrap { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2.5rem, 6vw, 5rem); align-items: start; } .sectors__intro { position: sticky; top: clamp(6rem, 12vh, 8rem); } .sectors__title { font-size: var(--step-3); margin-bottom: 1.5rem; } .sectors__lead { color: var(--on-bg-muted); font-size: var(--step-1); max-width: 42ch; } .sectors__list { display: grid; gap: 1rem; } .sector { display: flex; align-items: center; gap: 1.4rem; padding: clamp(1.4rem, 3vw, 2rem); border: 1px solid var(--border); border-radius: var(--radius-lg); background: var(--surface-strong); backdrop-filter: blur(10px); box-shadow: var(--shadow-card); transition: transform 0.4s var(--ease-out), box-shadow 0.4s; } .sector:hover { transform: translateX(8px); box-shadow: var(--shadow-soft); } .sector__mark { width: 30px; flex-shrink: 0; } .sector__t { font-size: var(--step-1); margin-bottom: 0.25rem; } .sector__d { color: var(--on-bg-muted); font-size: var(--step-0); } /* ----------------------------------------------------------------- 13. PACKAGES ----------------------------------------------------------------- */ .packages { position: relative; background: var(--ink-bg); color: var(--on-ink); padding-block: var(--space-section); } .packages .kicker { color: var(--violet-400); } .packages__title { font-size: var(--step-3); max-width: 22ch; margin-bottom: clamp(2.5rem, 6vw, 4rem); } .packages__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(1rem, 2vw, 1.5rem); align-items: stretch; } .pkg { position: relative; display: flex; flex-direction: column; padding: clamp(1.6rem, 2.5vw, 2.2rem); border: 1px solid var(--ink-border); border-radius: var(--radius-lg); background: var(--ink-surface); transition: transform 0.4s var(--ease-out), background 0.4s; } .pkg:hover { transform: translateY(-8px); background: var(--ink-surface-strong); } .pkg--featured { background: linear-gradient(180deg, rgba(139, 92, 246, 0.18), rgba(59, 130, 246, 0.06)); border-color: transparent; } .pkg--featured::before { content: ""; position: absolute; inset: -1px; border-radius: var(--radius-lg); padding: 1px; background: var(--grad-spectrum); background-size: 200% 200%; -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0); -webkit-mask-composite: xor; mask-composite: exclude; animation: borderflow 6s linear infinite; pointer-events: none; } @keyframes borderflow { to { background-position: 200% 200%; } } .pkg__tag { position: absolute; top: -0.85rem; left: 50%; transform: translateX(-50%); font-size: 11px; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; padding: 0.4rem 0.9rem; border-radius: var(--radius-pill); background: var(--grad-cta); color: var(--white); white-space: nowrap; } .pkg__head { margin-bottom: 1.4rem; } .pkg__price { font-size: var(--step--1); font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--violet-400); } .pkg__name { font-size: var(--step-2); margin-block: 0.5rem 0.3rem; } .pkg__who { color: var(--on-ink-muted); font-size: var(--step--1); } .pkg__features { list-style: none; display: grid; gap: 0.8rem; margin-bottom: 1.8rem; flex: 1; } .pkg__features li { display: flex; align-items: flex-start; gap: 0.6rem; font-size: var(--step--1); color: var(--on-ink); line-height: 1.4; } .pkg__features svg { flex-shrink: 0; margin-top: 1px; color: var(--emerald-500); } .pkg__cta { display: inline-flex; align-items: center; justify-content: space-between; gap: 0.5rem; font-weight: 700; font-size: var(--step--1); padding: 0.85rem 1.2rem; border-radius: var(--radius-pill); border: 1px solid var(--ink-border); transition: background 0.3s, color 0.3s, border-color 0.3s; min-height: 44px; } .pkg__cta:hover, .pkg__cta:focus-visible { background: var(--white); color: var(--ink-900); border-color: var(--white); } .pkg--featured .pkg__cta { background: var(--grad-cta); color: var(--white); border-color: transparent; } .pkg--featured .pkg__cta:hover { filter: brightness(1.08); } /* ----------------------------------------------------------------- 14. CTA ----------------------------------------------------------------- */ .cta { position: relative; padding-block: clamp(6rem, 14vw, 12rem); text-align: center; } .cta__wrap { display: flex; flex-direction: column; align-items: center; } .cta__mark { width: clamp(70px, 10vw, 110px); margin-bottom: clamp(1.5rem, 4vw, 2.5rem); filter: drop-shadow(0 24px 50px rgba(76, 49, 140, 0.3)); } .cta__title { font-size: var(--step-4); max-width: 16ch; margin-bottom: 1.4rem; } .cta__lead { font-size: var(--step-1); color: var(--on-bg-muted); max-width: 44ch; margin-bottom: 2.5rem; } .cta__mail { margin-top: 1.5rem; color: var(--on-bg-faint); font-size: var(--step--1); } .cta__mail a { color: var(--violet-text); font-weight: 700; text-decoration: underline; text-underline-offset: 3px; } /* ----------------------------------------------------------------- 15. FOOTER ----------------------------------------------------------------- */ .site-footer { background: var(--ink-bg); color: var(--on-ink); padding-block: clamp(3rem, 7vw, 5rem); } .site-footer__inner { display: grid; grid-template-columns: 1.4fr 1fr; gap: 2.5rem 2rem; align-items: start; } .site-footer__brand .brand__word--lg { color: var(--on-ink); } .site-footer__brand .brand__word-2 { color: var(--on-ink-muted); } .site-footer__tag { margin-top: 1rem; color: var(--on-ink-muted); max-width: 38ch; } .site-footer__nav { display: flex; flex-direction: column; gap: 0.7rem; align-items: flex-end; } .site-footer__nav a { color: var(--on-ink-muted); font-weight: 500; transition: color 0.25s; } .site-footer__nav a:hover, .site-footer__nav a:focus-visible { color: var(--on-ink); } .site-footer__legal { grid-column: 1 / -1; margin-top: 1.5rem; padding-top: 1.5rem; border-top: 1px solid var(--ink-border); color: var(--on-ink-faint); font-size: var(--step--1); } /* ----------------------------------------------------------------- 16. RESPONSIVE ----------------------------------------------------------------- */ @media (max-width: 1024px) { .advantage__grid { grid-template-columns: 1fr; } .packages__grid { grid-template-columns: repeat(2, 1fr); } } @media (max-width: 899px) { .site-nav { position: fixed; inset: 0 0 0 auto; width: min(82vw, 360px); flex-direction: column; align-items: flex-start; justify-content: center; gap: 1.5rem; padding: 2rem var(--gutter); background: rgba(244, 244, 251, 0.92); backdrop-filter: blur(20px); border-left: 1px solid var(--border); transform: translateX(100%); transition: transform 0.4s var(--ease-out); z-index: 90; } .site-header.is-open .site-nav { transform: translateX(0); } .site-nav ul { flex-direction: column; gap: 1.2rem; } .site-nav a { font-size: var(--step-1); } .site-header__toggle { display: flex; z-index: 95; } /* services degrade to a normal stack */ .sjourney__viewport { overflow: visible; } .sjourney__track { flex-direction: column; width: 100%; transform: none !important; gap: 1rem; } .sjourney__panel { width: 100%; min-height: 0; } .sjourney__progress { display: none; } .sectors__wrap { grid-template-columns: 1fr; } .sectors__intro { position: static; } .hero__mark { position: static; width: clamp(90px, 22vw, 140px); margin-top: 2rem; filter: none; } } @media (max-width: 560px) { .packages__grid { grid-template-columns: 1fr; } .site-footer__inner { grid-template-columns: 1fr; } .site-footer__nav { align-items: flex-start; } .hero__meta { gap: 1.2rem 2rem; } } /* ----------------------------------------------------------------- 17. REDUCED MOTION ----------------------------------------------------------------- */ @media (prefers-reduced-motion: reduce) { *, *::before, *::after { animation-duration: 0.001ms !important; animation-iteration-count: 1 !important; transition-duration: 0.001ms !important; scroll-behavior: auto !important; } .marquee__track { animation: none; } .ktext__in { transform: none !important; } .hero__display, .hero__mark { transform: none !important; opacity: 1 !important; } }