/* ============================================================
   It's Ben a Minute — Coming Soon
   Aesthetic: dark broadcast timekeeper
   Palette pulled from the logo: deep navy, teal/cyan, coral hand
   ============================================================ */

:root {
    --navy-900: #04141d;
    --navy-850: #061b27;
    --navy-800: #0a2433;
    --navy-700: #0f3147;
    --navy-line: #14384c;

    --teal:     #11b5b0;
    --teal-br:  #2fe3dc;
    --cyan:     #3fd0e6;
    --blue:     #1f7fb8;
    --logo-navy:#004878;

    --coral:    #ff6b3d;
    --coral-br: #ff8a5c;

    --ink:      #eaf6f8;
    --ink-soft: #a7c4cd;
    --ink-mute: #5f7e8a;

    --font-disp: 'Syne', sans-serif;
    --font-body: 'Schibsted Grotesk', sans-serif;
    --font-mono: 'JetBrains Mono', monospace;

    --maxw: 1180px;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }

body {
    font-family: var(--font-body);
    background: var(--navy-900);
    color: var(--ink);
    line-height: 1.6;
    overflow-x: hidden;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}

img { max-width: 100%; display: block; }

::selection { background: var(--coral); color: #fff; }

/* ---------- Grain overlay ---------- */
.grain {
    position: fixed;
    inset: 0;
    pointer-events: none;
    z-index: 200;
    opacity: .045;
    mix-blend-mode: overlay;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---------- Scroll progress dial (fixed) ---------- */
.scroll-dial {
    position: fixed;
    bottom: 26px;
    right: 26px;
    width: 56px;
    height: 56px;
    z-index: 150;
    display: grid;
    place-items: center;
    opacity: 0;
    transform: scale(.7);
    transition: opacity .4s ease, transform .4s ease;
}
.scroll-dial.show { opacity: 1; transform: scale(1); }
.scroll-dial svg { position: absolute; inset: 0; width: 100%; height: 100%; transform: rotate(-90deg); }
.scroll-dial .dial-track { fill: rgba(6,27,39,.85); stroke: var(--navy-line); stroke-width: 3; }
.scroll-dial .dial-fill {
    fill: none;
    stroke: var(--coral);
    stroke-width: 3;
    stroke-linecap: round;
    stroke-dasharray: 119.4;
    stroke-dashoffset: 119.4;
    filter: drop-shadow(0 0 5px rgba(255,107,61,.6));
    transition: stroke-dashoffset .1s linear;
}
.scroll-dial .dial-num {
    font-family: var(--font-mono);
    font-size: .72rem;
    font-weight: 700;
    color: var(--coral-br);
}

/* ---------- Top nav ---------- */
.site-nav {
    position: fixed;
    top: 0; left: 0; right: 0;
    z-index: 120;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1rem clamp(1.1rem, 4vw, 3rem);
    background: linear-gradient(to bottom, rgba(4,20,29,.85), rgba(4,20,29,0));
    backdrop-filter: blur(2px);
}
.nav-brand {
    display: flex;
    align-items: center;
    gap: .65rem;
    text-decoration: none;
    color: var(--ink);
}
.nav-brand img {
    height: 42px;
    width: 42px;
    object-fit: contain;
    display: block;
    flex-shrink: 0;
    filter: drop-shadow(0 2px 8px rgba(0,0,0,.35));
}
.nav-brand .brand-text { display: flex; flex-direction: column; line-height: 1.05; }
.nav-brand .brand-text strong {
    font-family: var(--font-disp);
    font-weight: 800;
    font-size: 1.02rem;
    letter-spacing: -.01em;
    color: var(--ink);
}
.nav-brand .brand-text em {
    font-family: var(--font-mono);
    font-style: normal;
    font-size: .58rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .22em;
    color: var(--teal-br);
    margin-top: .15rem;
}
.nav-badge {
    display: inline-flex;
    align-items: center;
    gap: .45rem;
    font-family: var(--font-mono);
    font-size: .68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .14em;
    color: var(--teal-br);
    border: 1px solid var(--navy-line);
    background: rgba(10,36,51,.6);
    padding: .35rem .7rem;
    border-radius: 100px;
}
.nav-badge .dot {
    width: 7px; height: 7px; border-radius: 50%;
    background: var(--coral);
    box-shadow: 0 0 8px var(--coral);
    animation: blink 1.6s ease-in-out infinite;
}
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:.25} }

/* ---------- Reveal animation ---------- */
[data-reveal] {
    opacity: 0;
    transform: translateY(26px);
    filter: blur(6px);
    transition: opacity .8s cubic-bezier(.2,.7,.2,1),
                transform .8s cubic-bezier(.2,.7,.2,1),
                filter .8s ease;
}
[data-reveal].in { opacity: 1; transform: none; filter: blur(0); }
[data-delay="1"]{ transition-delay:.08s } [data-delay="2"]{ transition-delay:.16s }
[data-delay="3"]{ transition-delay:.24s } [data-delay="4"]{ transition-delay:.32s }
[data-delay="5"]{ transition-delay:.40s }

/* ============================================================
   HERO
   ============================================================ */
.hero {
    position: relative;
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 7rem 1.25rem 4rem;
    overflow: hidden;
}
.hero-bg { position: absolute; inset: 0; z-index: 0; }
.glow {
    position: absolute;
    border-radius: 50%;
    filter: blur(90px);
    opacity: .5;
}
.glow-teal  { width: 46vw; height: 46vw; background: var(--teal);     top: -8%; left: -6%;  animation: float1 16s ease-in-out infinite; }
.glow-coral { width: 34vw; height: 34vw; background: var(--coral);    bottom: -10%; right: 4%; opacity: .38; animation: float2 19s ease-in-out infinite; }
.glow-blue  { width: 40vw; height: 40vw; background: var(--logo-navy); top: 30%; right: -12%; opacity: .55; animation: float1 22s ease-in-out infinite reverse; }
@keyframes float1 { 0%,100%{ transform: translate(0,0) } 50%{ transform: translate(4%, 6%) } }
@keyframes float2 { 0%,100%{ transform: translate(0,0) } 50%{ transform: translate(-5%, -4%) } }

.grid-lines {
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(var(--navy-line) 1px, transparent 1px),
        linear-gradient(90deg, var(--navy-line) 1px, transparent 1px);
    background-size: 64px 64px;
    opacity: .25;
    mask-image: radial-gradient(ellipse 75% 65% at 50% 45%, #000 30%, transparent 75%);
    -webkit-mask-image: radial-gradient(ellipse 75% 65% at 50% 45%, #000 30%, transparent 75%);
}

.hero-inner { position: relative; z-index: 1; max-width: 760px; }

.hero-logo {
    position: relative;
    width: clamp(190px, 30vw, 280px);
    margin: 0 auto 2rem;
    aspect-ratio: 1;
    display: grid;
    place-items: center;
}
.hero-logo img {
    width: 78%;
    filter: drop-shadow(0 14px 40px rgba(0,0,0,.5));
    animation: bob 6s ease-in-out infinite;
}
@keyframes bob { 0%,100%{ transform: translateY(0) } 50%{ transform: translateY(-9px) } }

.logo-ring { position: absolute; inset: 0; width: 100%; height: 100%; }
.logo-ring .ring-track {
    fill: none; stroke: var(--navy-line); stroke-width: 2;
}
.logo-ring .ring-sweep {
    fill: none;
    stroke: var(--coral);
    stroke-width: 3;
    stroke-linecap: round;
    stroke-dasharray: 703.7;
    stroke-dashoffset: 703.7;
    transform: rotate(-90deg);
    transform-origin: center;
    filter: drop-shadow(0 0 6px rgba(255,107,61,.7));
    animation: sweep 6s linear infinite;
}
@keyframes sweep {
    0%   { stroke-dashoffset: 703.7; }
    92%  { stroke-dashoffset: 0; }
    100% { stroke-dashoffset: 0; }
}
.logo-ring .tick { stroke: var(--ink-mute); stroke-width: 1.5; }
.logo-ring .tick-big { stroke: var(--teal-br); stroke-width: 2; }

.hero-eyebrow {
    font-family: var(--font-mono);
    font-size: .8rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .28em;
    color: var(--teal-br);
    margin-bottom: 1.1rem;
}

.hero-title {
    font-family: var(--font-disp);
    font-weight: 800;
    font-size: clamp(2.6rem, 8vw, 5.4rem);
    line-height: .98;
    letter-spacing: -.03em;
}
.hero-title .line { display: block; }
.hero-title .accent { color: var(--ink); }
.hero-title .word-flip {
    position: relative;
    display: inline-grid;
    color: var(--coral-br);
    text-shadow: 0 0 30px rgba(255,107,61,.45);
}
.hero-title .word-flip span {
    grid-area: 1/1;
    animation: flip 5s ease-in-out infinite;
}
.hero-title .word-flip span:nth-child(2) { animation-delay: 2.5s; opacity: 0; font-family: var(--font-mono); }
@keyframes flip {
    0%, 8%   { opacity: 0; transform: translateY(14px) rotateX(-40deg); }
    14%, 42% { opacity: 1; transform: none; }
    50%,100% { opacity: 0; transform: translateY(-14px) rotateX(40deg); }
}

.hero-sub {
    max-width: 540px;
    margin: 1.5rem auto 0;
    color: var(--ink-soft);
    font-size: clamp(1rem, 1.6vw, 1.15rem);
}
.hero-sub strong { color: var(--ink); }

.hero-counter {
    display: inline-flex;
    align-items: center;
    gap: 1rem;
    margin-top: 2.2rem;
    padding: .7rem .7rem .7rem 1.2rem;
    border: 1px solid var(--navy-line);
    border-radius: 100px;
    background: rgba(6,27,39,.6);
    backdrop-filter: blur(6px);
}
.counter-face { display: flex; flex-direction: column; align-items: flex-start; line-height: 1; }
.counter-label {
    font-family: var(--font-mono);
    font-size: .58rem;
    text-transform: uppercase;
    letter-spacing: .2em;
    color: var(--ink-mute);
    margin-bottom: .25rem;
}
.counter-time {
    font-family: var(--font-mono);
    font-weight: 700;
    font-size: 1.5rem;
    color: var(--teal-br);
    font-variant-numeric: tabular-nums;
}
.coming-pill {
    display: inline-flex;
    align-items: center;
    gap: .45rem;
    background: var(--coral);
    color: #fff;
    font-weight: 700;
    font-size: .82rem;
    text-transform: uppercase;
    letter-spacing: .08em;
    padding: .55rem 1rem;
    border-radius: 100px;
    box-shadow: 0 8px 24px rgba(255,107,61,.35);
}
.coming-pill .pulse {
    width: 8px; height: 8px; border-radius: 50%;
    background: #fff;
    animation: pulse 1.4s ease-out infinite;
}
@keyframes pulse {
    0% { box-shadow: 0 0 0 0 rgba(255,255,255,.7); }
    100% { box-shadow: 0 0 0 9px rgba(255,255,255,0); }
}

.scroll-cue {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    gap: .5rem;
    margin-top: 3rem;
    text-decoration: none;
    color: var(--ink-mute);
    font-family: var(--font-mono);
    font-size: .66rem;
    text-transform: uppercase;
    letter-spacing: .22em;
    transition: color .3s;
}
.scroll-cue:hover { color: var(--teal-br); }
.scroll-cue svg {
    width: 22px; height: 22px;
    fill: none; stroke: currentColor; stroke-width: 2;
    stroke-linecap: round; stroke-linejoin: round;
    animation: nudge 1.8s ease-in-out infinite;
}
@keyframes nudge { 0%,100%{ transform: translateY(0) } 50%{ transform: translateY(6px) } }

/* ============================================================
   MARQUEE
   ============================================================ */
.marquee {
    border-top: 1px solid var(--navy-line);
    border-bottom: 1px solid var(--navy-line);
    background: var(--navy-850);
    overflow: hidden;
    padding: 1.1rem 0;
}
.marquee-track {
    display: flex;
    align-items: center;
    gap: 1.6rem;
    width: max-content;
    animation: scroll-x 26s linear infinite;
}
.marquee-track span {
    font-family: var(--font-disp);
    font-weight: 700;
    font-size: clamp(1.1rem, 2.4vw, 1.7rem);
    text-transform: uppercase;
    letter-spacing: .02em;
    color: var(--ink);
    white-space: nowrap;
}
.marquee-track .sep { color: var(--coral); font-size: 1.1rem; }
@keyframes scroll-x { to { transform: translateX(-50%); } }

/* ============================================================
   CONCEPT
   ============================================================ */
.concept {
    max-width: var(--maxw);
    margin: 0 auto;
    padding: clamp(5rem, 12vw, 9rem) clamp(1.1rem, 4vw, 2rem);
}
.concept-grid {
    display: grid;
    grid-template-columns: 1.25fr .9fr;
    gap: clamp(2rem, 6vw, 5rem);
    align-items: center;
}
.kicker {
    font-family: var(--font-mono);
    font-size: .72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .26em;
    color: var(--coral-br);
    margin-bottom: 1rem;
}
.kicker.center { text-align: center; }
.concept h2, .platforms h2, .notify h2 {
    font-family: var(--font-disp);
    font-weight: 800;
    font-size: clamp(1.8rem, 4.2vw, 3rem);
    line-height: 1.05;
    letter-spacing: -.02em;
}
.center { text-align: center; }
.lead {
    margin-top: 1.4rem;
    color: var(--ink-soft);
    font-size: 1.06rem;
    max-width: 46ch;
}
.lead strong { color: var(--ink); }

.concept-points { list-style: none; margin-top: 2.2rem; display: grid; gap: 1rem; }
.concept-points li {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1rem 1.2rem;
    border: 1px solid var(--navy-line);
    border-radius: 14px;
    background: linear-gradient(180deg, rgba(10,36,51,.5), rgba(6,27,39,.3));
    transition: border-color .3s, transform .3s;
}
.concept-points li:hover { border-color: var(--teal); transform: translateX(5px); }
.pt-num {
    font-family: var(--font-mono);
    font-weight: 700;
    font-size: 1.1rem;
    color: var(--teal-br);
    flex-shrink: 0;
}
.concept-points strong { color: var(--ink); }
.concept-points span:last-child { color: var(--ink-soft); }

.concept-dial { position: relative; aspect-ratio: 1; display: grid; place-items: center; }
.big-dial { width: 100%; height: 100%; transform: rotate(-90deg); }
.big-dial .bd-track { fill: none; stroke: var(--navy-line); stroke-width: 6; }
.big-dial .bd-fill {
    fill: none;
    stroke: url(#dialGrad);
    stroke: var(--coral);
    stroke-width: 6;
    stroke-linecap: round;
    stroke-dasharray: 565.5;
    stroke-dashoffset: 565.5;
    filter: drop-shadow(0 0 10px rgba(255,107,61,.5));
    transition: stroke-dashoffset 1.6s cubic-bezier(.2,.7,.2,1);
}
.big-dial .bd-fill.go { stroke-dashoffset: 0; }
.big-dial-center {
    position: absolute;
    display: flex;
    flex-direction: column;
    align-items: center;
    line-height: 1;
}
.bd-num {
    font-family: var(--font-disp);
    font-weight: 800;
    font-size: clamp(3.4rem, 9vw, 5.5rem);
    color: var(--ink);
    font-variant-numeric: tabular-nums;
}
.bd-unit {
    font-family: var(--font-mono);
    font-size: .8rem;
    text-transform: uppercase;
    letter-spacing: .24em;
    color: var(--teal-br);
    margin-top: .4rem;
}

/* ============================================================
   PLATFORMS
   ============================================================ */
.platforms {
    max-width: var(--maxw);
    margin: 0 auto;
    padding: clamp(4rem, 9vw, 7rem) clamp(1.1rem, 4vw, 2rem);
}
.platform-cards {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.4rem;
    margin-top: 3rem;
}
.pcard {
    position: relative;
    padding: 2.2rem 1.8rem;
    border: 1px solid var(--navy-line);
    border-radius: 20px;
    background: linear-gradient(180deg, rgba(10,36,51,.55), rgba(6,27,39,.35));
    overflow: hidden;
    transition: transform .4s cubic-bezier(.2,.7,.2,1), border-color .4s;
}
.pcard::before {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(120% 80% at 50% 0%, color-mix(in srgb, var(--pc) 26%, transparent), transparent 60%);
    opacity: 0;
    transition: opacity .4s;
}
.pcard:hover { transform: translateY(-8px); border-color: var(--pc); }
.pcard:hover::before { opacity: 1; }
.pc-ico {
    width: 56px; height: 56px;
    display: grid; place-items: center;
    border-radius: 14px;
    background: color-mix(in srgb, var(--pc) 16%, transparent);
    border: 1px solid color-mix(in srgb, var(--pc) 45%, transparent);
    margin-bottom: 1.3rem;
}
.pc-ico svg {
    width: 28px; height: 28px;
    fill: none; stroke: var(--pc); stroke-width: 1.8;
    stroke-linecap: round; stroke-linejoin: round;
}
.pcard h3 {
    font-family: var(--font-disp);
    font-weight: 700;
    font-size: 1.35rem;
    margin-bottom: .5rem;
}
.pcard p { color: var(--ink-soft); font-size: .96rem; margin-bottom: 1.4rem; }
.pc-status {
    display: inline-flex;
    align-items: center;
    font-family: var(--font-mono);
    font-size: .68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .14em;
    color: var(--ink-mute);
    border: 1px dashed var(--navy-line);
    padding: .35rem .8rem;
    border-radius: 100px;
}

/* ============================================================
   NOTIFY
   ============================================================ */
.notify {
    position: relative;
    margin: 0 auto;
    padding: clamp(5rem, 12vw, 8rem) clamp(1.1rem, 4vw, 2rem);
    overflow: hidden;
}
.notify-bg { position: absolute; inset: 0; z-index: 0; opacity: .6; }
.notify-bg .glow-teal  { width: 38vw; height: 38vw; left: 8%; bottom: -10%; }
.notify-bg .glow-coral { width: 30vw; height: 30vw; right: 6%; top: -8%; opacity: .3; }
.notify-inner { position: relative; z-index: 1; max-width: 620px; margin: 0 auto; }
.notify-sub {
    text-align: center;
    color: var(--ink-soft);
    margin: 1.2rem auto 0;
    max-width: 46ch;
}
.notify-form {
    display: flex;
    gap: .6rem;
    margin-top: 2rem;
    padding: .5rem;
    border: 1px solid var(--navy-line);
    border-radius: 100px;
    background: rgba(6,27,39,.7);
    backdrop-filter: blur(6px);
    transition: border-color .3s, box-shadow .3s;
}
.notify-form:focus-within {
    border-color: var(--teal);
    box-shadow: 0 0 0 4px rgba(17,181,176,.15);
}
.notify-form input {
    flex: 1;
    border: 0;
    background: transparent;
    color: var(--ink);
    font-family: var(--font-body);
    font-size: 1rem;
    padding: .7rem 1.1rem;
    outline: none;
}
.notify-form input::placeholder { color: var(--ink-mute); }
.notify-form button {
    flex-shrink: 0;
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .5rem;
    border: 0;
    cursor: pointer;
    font-family: var(--font-disp);
    font-weight: 700;
    font-size: .95rem;
    color: #fff;
    padding: .75rem 1.6rem;
    border-radius: 100px;
    background: linear-gradient(135deg, var(--coral), var(--coral-br));
    box-shadow: 0 8px 22px rgba(255,107,61,.35);
    transition: transform .2s, box-shadow .3s, filter .3s;
}
.notify-form button:hover { transform: translateY(-2px); box-shadow: 0 12px 28px rgba(255,107,61,.45); }
.notify-form button:disabled { filter: saturate(.5) brightness(.85); cursor: default; transform: none; }
.btn-spin {
    display: none;
    width: 15px; height: 15px;
    border: 2px solid rgba(255,255,255,.4);
    border-top-color: #fff;
    border-radius: 50%;
    animation: spin .7s linear infinite;
}
button.loading .btn-text { opacity: .55; }
button.loading .btn-spin { display: inline-block; }
@keyframes spin { to { transform: rotate(360deg); } }

.notify-msg {
    text-align: center;
    margin-top: 1.1rem;
    min-height: 1.4rem;
    font-size: .94rem;
    font-weight: 500;
}
.notify-msg.ok  { color: var(--teal-br); }
.notify-msg.err { color: var(--coral-br); }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer {
    border-top: 1px solid var(--navy-line);
    background: var(--navy-850);
    text-align: center;
    padding: 3rem 1.25rem;
}
.foot-mark img { width: 64px; margin: 0 auto 1rem; opacity: .9; }
.foot-tag {
    font-family: var(--font-disp);
    font-weight: 700;
    font-size: 1.1rem;
    color: var(--ink);
}
.foot-copy {
    font-family: var(--font-mono);
    font-size: .74rem;
    color: var(--ink-mute);
    margin-top: .6rem;
    letter-spacing: .04em;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 860px) {
    .concept-grid { grid-template-columns: 1fr; }
    .concept-dial { max-width: 280px; margin: 1rem auto 0; order: -1; }
    .lead { max-width: none; }
    .platform-cards { grid-template-columns: 1fr; gap: 1rem; }
    .nav-brand img { height: 36px; width: 36px; }
    .nav-brand .brand-text em { display: none; }
}
@media (max-width: 560px) {
    .hero-counter { flex-direction: column; gap: .8rem; padding: 1rem; }
    .notify-form { flex-direction: column; border-radius: 22px; }
    .notify-form button { justify-content: center; }
    .scroll-dial { bottom: 16px; right: 16px; }
}

/* Respect reduced-motion */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: .001ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: .001ms !important;
        scroll-behavior: auto !important;
    }
    [data-reveal] { opacity: 1; transform: none; filter: none; }
}
