/* ShipViaUS — reset, global layout, typography, grain, utilities */

*,
*::before,
*::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html {
    scroll-behavior: smooth;
    overflow-x: hidden;
    max-width: 100%;
    overscroll-behavior-x: none;
}

body, h1, h2, h3, h4, h5, h6, p, ul, ol, figure {
    margin: 0;
}

ul, ol {
    list-style: none;
}

img {
    max-width: 100%;
    height: auto;
    display: block;
}

a {
    color: inherit;
    text-decoration: none;
}

button, input, select, textarea {
    font: inherit;
    color: inherit;
}

table {
    border-collapse: collapse;
    width: 100%;
}

body {
    position: relative;
    min-height: 100vh;
    max-width: 100%;
    overscroll-behavior-x: none;
    background: var(--c-bg);
    color: var(--c-text);
    font-family: var(--f-body);
    font-size: clamp(0.94rem, 0.2vw + 0.9rem, 1.05rem);
    line-height: 1.7;
    -webkit-font-smoothing: antialiased;
}

body::before {
    content: "";
    position: fixed;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    opacity: 0.035;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.55'/%3E%3C/svg%3E");
    background-size: 180px 180px;
    mix-blend-mode: overlay;
}

body > * {
    position: relative;
    z-index: 1;
}

::selection {
    background: var(--c-accent2);
    color: #fff;
}

* {
    scrollbar-width: thin;
    scrollbar-color: var(--c-accent1) var(--c-surface);
}
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: var(--c-surface); }
::-webkit-scrollbar-thumb { background: var(--c-accent1); border-radius: 3px; }

.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.skip-link {
    position: absolute;
    left: -10000px;
    top: 0.5rem;
    z-index: 10000;
    padding: 0.5rem 1rem;
    background: var(--c-accent1);
    color: var(--c-bg);
    font-weight: 600;
    border-radius: 4px;
}
.skip-link:focus {
    left: 0.5rem;
    outline: 2px solid var(--c-accent2);
    outline-offset: 2px;
}

.container {
    max-width: 1280px;
    margin-inline: auto;
    padding: 0 clamp(1.5rem, 5vw, 4rem);
}

.section {
    padding: clamp(80px, 12vw, 160px) 0;
}

.eyebrow {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    font-family: var(--f-body);
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.3em;
    text-transform: uppercase;
    color: var(--c-accent1);
    margin-bottom: 1.25rem;
}
.eyebrow::before,
.eyebrow::after {
    content: "";
    width: 32px;
    height: 1px;
    background: var(--c-accent1);
    opacity: 0.8;
}

.display {
    font-family: var(--f-display);
    font-size: clamp(4rem, 10vw, 8.75rem);
    letter-spacing: 0.02em;
    line-height: 0.95;
    text-transform: uppercase;
}

.display__line {
    display: block;
    color: var(--c-text);
}
.display__gradient {
    display: block;
    /* Deep charcoal → navy → cyan: reads on bright hero photography */
    background: linear-gradient(
        118deg,
        #050608 0%,
        #0a1018 14%,
        #0f1a24 28%,
        #123544 48%,
        #0088a8 68%,
        #00c4e8 82%,
        #00D4FF 92%,
        #9aefff 100%
    );
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
    filter: drop-shadow(0 2px 24px color-mix(in srgb, #000 55%, transparent))
        drop-shadow(0 0 28px color-mix(in srgb, var(--c-accent1) 35%, transparent));
}

h1 {
    font-family: var(--f-heading);
    font-weight: 700;
    font-size: clamp(2.5rem, 6vw, 4.5rem);
    line-height: 1.1;
    letter-spacing: -0.02em;
    color: var(--c-text);
}
h2 {
    font-family: var(--f-heading);
    font-weight: 800;
    font-size: clamp(2rem, 4vw, 3.25rem);
    line-height: 1.1;
    letter-spacing: -0.02em;
    color: var(--c-text);
    text-transform: uppercase;
}
h3 {
    font-family: var(--f-heading);
    font-weight: 600;
    font-size: clamp(1.15rem, 2.2vw, 1.6rem);
    line-height: 1.2;
    color: var(--c-text);
}

p {
    font-family: var(--f-body);
    font-size: clamp(0.9rem, 1.1vw, 1.05rem);
    color: var(--c-muted);
}

.page-hero {
    position: relative;
    padding: clamp(3.5rem, 8vw, 5.5rem) 0;
    overflow: hidden;
}
.page-hero--mesh {
    background:
        radial-gradient(ellipse 80% 50% at 20% 30%, color-mix(in srgb, var(--c-accent1) 18%, transparent) 0%, transparent 50%),
        radial-gradient(ellipse 60% 40% at 80% 70%, color-mix(in srgb, var(--c-accent2) 12%, transparent) 0%, transparent 50%),
        conic-gradient(from 120deg at 50% 50%, #0B0C10 0deg, #121620 90deg, #0B0C10 180deg, #161A23 270deg, #0B0C10 360deg);
}
.page-hero--img {
    background: var(--c-bg);
}
.page-hero--img::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 0;
    background-image: linear-gradient(
            135deg,
            rgba(11, 12, 16, 0.88) 0%,
            rgba(11, 12, 16, 0.55) 100%
        ),
        var(--page-hero-img, none);
    background-size: cover, cover;
    background-position: center, center 40%;
}
.page-hero--img .page-hero__title,
.page-hero--img .page-hero__lede {
    position: relative;
    z-index: 1;
    text-shadow: 0 2px 24px color-mix(in srgb, var(--c-bg) 80%, #000);
}
.page-hero--clip .container {
    position: relative;
    z-index: 1;
}
.page-hero__title {
    font-family: var(--f-display);
    font-size: clamp(2.35rem, 8vw, 5.5rem);
    line-height: 0.95;
    margin-bottom: 0.5rem;
}
.page-hero__lede {
    max-width: 50ch;
    font-size: 1.05rem;
}

/* Photo backgrounds — dark overlay for text contrast (brand #0B0C10 ≈ rgb 11,12,16)) */
.photo-bg {
    position: relative;
    background-color: var(--c-bg);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    overflow: hidden;
}
.photo-bg::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(
        135deg,
        rgba(11, 12, 16, 0.88) 0%,
        rgba(11, 12, 16, 0.65) 100%
    );
    z-index: 1;
    pointer-events: none;
}
.photo-bg > * {
    position: relative;
    z-index: 2;
}

.photo-bg--blur {
    background-image: none !important;
}
.photo-bg--blur::after {
    content: "";
    position: absolute;
    inset: -36px;
    z-index: 0;
    background-image: var(--photo-bg-url, none);
    background-size: cover;
    background-position: center;
    filter: blur(20px);
    transform: scale(1.06);
    pointer-events: none;
}
.photo-bg--blur::before {
    z-index: 1;
}

.section-lede { color: var(--c-muted); }
.text-center { text-align: center; }

/* Clip path utilities */
.clip-down { clip-path: polygon(0 0, 100% 0, 100% 88%, 0 100%); }
.clip-up { clip-path: polygon(0 6%, 100% 0, 100% 100%, 0 100%); }
.clip-both { clip-path: polygon(0 4%, 100% 0, 100% 96%, 0 100%); }

/* Reveal (JS) */
.reveal {
    opacity: 0;
    transform: translateY(40px);
    transition: opacity 0.7s cubic-bezier(0.22, 1, 0.36, 1), transform 0.7s cubic-bezier(0.22, 1, 0.36, 1);
}
.reveal.is-in {
    opacity: 1;
    transform: translateY(0);
}

/* Top bar + ticker */
.topbar {
    height: 40px;
    background: var(--c-surface);
    border-bottom: 1px solid var(--border);
    display: flex;
    align-items: center;
    z-index: 1001;
    position: relative;
}
.topbar__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    height: 100%;
    max-width: 100%;
    padding: 0 clamp(1.5rem, 5vw, 4rem);
    gap: 1rem;
}
.ticker {
    flex: 1;
    min-width: 0;
    overflow: hidden;
    height: 100%;
    display: flex;
    align-items: center;
    mask-image: linear-gradient(90deg, transparent, black 6%, black 94%, transparent);
}
.ticker__track {
    display: flex;
    width: max-content;
    animation: tickerScroll 32s linear infinite;
    will-change: transform;
}
.ticker__text {
    font-family: var(--f-body);
    font-weight: 500;
    font-size: 12px;
    color: var(--c-accent1);
    white-space: nowrap;
    padding-right: 0;
}
@media (max-width: 420px) {
    .ticker__text { font-size: 10px; letter-spacing: 0.02em; }
    .topbar__inner { padding-inline: clamp(0.75rem, 3vw, 1rem); gap: 0.5rem; }
    .topbar__phone { font-size: 10px; }
    .topbar__phone span { max-width: 7.5rem; overflow: hidden; text-overflow: ellipsis; }
}
.topbar__phone {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    font-family: var(--f-body);
    font-size: 12px;
    font-weight: 500;
    color: var(--c-muted);
    white-space: nowrap;
    flex-shrink: 0;
    transition: color 0.2s;
}
.topbar__phone:hover, .topbar__phone:focus-visible { color: var(--c-accent1); outline: none; }
.topbar__phone-icon { color: var(--c-accent1); }

/* Sticky site header (rest in components if needed)
   Blur lives on ::before so the principal box does not use backdrop-filter —
   otherwise fixed .nav is positioned against the header and horizontal panning
   reveals the off-canvas menu. */
.site-header {
    position: sticky;
    top: 0;
    z-index: 1000;
    background: transparent;
    border-bottom: 1px solid rgba(0, 212, 255, 0.1);
    transition: box-shadow 0.25s ease, padding 0.25s ease;
}
.site-header::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    background: color-mix(in srgb, var(--c-bg) 85%, transparent);
    -webkit-backdrop-filter: blur(20px) saturate(180%);
    backdrop-filter: blur(20px) saturate(180%);
}
@media (max-width: 767px) {
    .site-header::before {
        -webkit-backdrop-filter: none;
        backdrop-filter: none;
        background: color-mix(in srgb, var(--c-bg) 92%, transparent);
    }
}
.site-header.is-compact { box-shadow: 0 8px 32px rgba(0,0,0,0.4); }
.site-header__row {
    position: relative;
    z-index: 1;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    padding: 0.9rem 0;
    min-height: 64px;
    transition: padding 0.25s ease, min-height 0.25s ease;
}
.site-header.is-compact .site-header__row { padding: 0.45rem 0; min-height: 52px; }
.brand {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    z-index: 2;
    text-decoration: none;
    transition: opacity 0.2s ease;
}
.brand:hover { opacity: 0.94; }
.brand:focus-visible {
    outline: 2px solid var(--c-accent1);
    outline-offset: 4px;
    border-radius: 4px;
}
.brand__mark {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    filter: drop-shadow(0 2px 14px color-mix(in srgb, var(--c-accent1) 22%, transparent));
    transition: transform 0.35s cubic-bezier(0.22, 1, 0.36, 1), filter 0.25s ease;
}
.brand:hover .brand__mark,
.brand:focus-visible .brand__mark {
    transform: translateY(-1px) scale(1.03);
    filter: drop-shadow(0 4px 20px color-mix(in srgb, var(--c-accent1) 32%, transparent));
}
.brand__text {
    font-family: var(--f-display);
    font-size: 36px;
    line-height: 0.92;
    letter-spacing: 0.04em;
    transition: font-size 0.25s ease, transform 0.25s ease;
    display: flex;
    align-items: baseline;
    gap: 0;
}
.site-header.is-compact .brand__text { font-size: 28px; }
.brand__ship {
    color: var(--c-text);
    letter-spacing: 0.06em;
}
.brand__via {
    background: linear-gradient(118deg, #00e5ff 0%, #00a8cc 45%, #00D4FF 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
    letter-spacing: 0.08em;
}
.brand__us {
    color: var(--c-accent2);
    letter-spacing: 0.05em;
    text-shadow: 0 0 28px color-mix(in srgb, var(--c-accent2) 25%, transparent);
}
.brand__icon { flex-shrink: 0; display: block; }
.nav { display: flex; align-items: center; gap: 1.5rem; }
.nav__list {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem 1.75rem;
}
.nav__link {
    font-family: var(--f-body);
    font-weight: 500;
    font-size: 14px;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--c-muted);
    position: relative;
    padding: 0.25rem 0;
    transition: color 0.2s;
}
.nav__link:hover, .nav__link:focus-visible { color: var(--c-accent1); outline: none; }
.nav__link.is-active { color: var(--c-text); }
.nav__link.is-active::after {
    content: "";
    position: absolute;
    left: 0; bottom: 0; width: 100%; height: 2px;
    background: var(--c-accent2);
}

.nav-toggle { display: none; }

@media (max-width: 767px) {
    .nav-toggle {
        display: flex;
        flex-direction: column;
        justify-content: center;
        gap: 5px;
        width: 44px;
        height: 44px;
        background: var(--c-surface);
        border: 1px solid var(--border);
        border-radius: 4px;
        cursor: pointer;
        z-index: 2;
    }
    .nav-toggle__bar { width: 20px; height: 2px; background: var(--c-text); transition: 0.25s; }
    body.nav-open .nav-toggle__bar:nth-child(1) { transform: translateY(7px) rotate(45deg); }
    body.nav-open .nav-toggle__bar:nth-child(2) { opacity: 0; }
    body.nav-open .nav-toggle__bar:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

    /* Full-viewport overlay above topbar (1001); hamburger stays tappable on top */
    body.nav-open .site-header {
        z-index: 1200;
    }
    body.nav-open .nav-toggle {
        position: relative;
        z-index: 10;
    }

    .nav {
        position: fixed;
        left: 0;
        right: 0;
        top: 0;
        bottom: 0;
        width: 100%;
        max-width: 100%;
        min-height: 100vh;
        min-height: 100dvh;
        background: #0B0C10;
        flex-direction: column;
        padding: 5.5rem 1.5rem max(2rem, env(safe-area-inset-bottom, 0px));
        transform: translate3d(100%, 0, 0);
        transition: transform 0.3s ease;
        justify-content: flex-start;
        overflow-y: auto;
        overflow-x: hidden;
        -webkit-overflow-scrolling: touch;
        overscroll-behavior: contain;
        z-index: 2;
        will-change: transform;
    }
    body.nav-open .nav { transform: translate3d(0, 0, 0); }
    .nav__list { flex-direction: column; width: 100%; gap: 0; }
    .nav__link { display: block; width: 100%; padding: 1rem 0; border-bottom: 1px solid var(--border); font-size: 1rem; }
    .nav .btn--nav { margin-top: 1rem; width: 100%; text-align: center; justify-content: center; }
}

@media (min-width: 768px) {
    .nav .btn--nav { margin-left: 0.5rem; }
}

html.nav-open,
body.nav-open {
    overflow: hidden;
    overflow-x: hidden;
    touch-action: pan-y;
}

@media (max-width: 480px) {
    .container {
        padding-inline: clamp(1rem, 4vw, 1.35rem);
    }
    .section {
        padding: clamp(48px, 10vw, 88px) 0;
    }
    .eyebrow::before,
    .eyebrow::after {
        display: none;
    }
    .display {
        font-size: clamp(2.65rem, 11vw, 5.25rem);
        letter-spacing: 0.01em;
    }
    .brand__text { font-size: clamp(1.65rem, 9vw, 2rem); letter-spacing: 0.02em; }
    .brand__mark .brand__icon { width: 38px; height: 38px; }
    .site-header__row { min-height: 56px; padding-block: 0.65rem; }
    .hero__actions .btn { flex: 1 1 auto; min-width: min(100%, 12rem); justify-content: center; }
    .hero__sub { font-size: 16px; margin: 1.25rem 0 1.5rem; }
}
