/* gamelicensor.com - Memphis + Coastal Licensing Bureau */

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

:root{
    --harbor:#1B3A4B;
    --adriatic:#3D7A8A;
    --seaglass:#A8D5D0;
    --coral:#E07A5F;
    --sand:#E8C547;
    --foam:#F4F1EB;
    --drift:#B8AFA3;
    --kelp:#2C2C2E;
}

body{
    background:var(--foam);
    color:var(--kelp);
    font-family:'Lato',sans-serif;
    font-weight:400;
    font-size:clamp(1rem,1.8vw,1.15rem);
    line-height:1.65;
    overflow-x:hidden;
    scroll-behavior:smooth;
}

/* Hero Cluster */
.hero-cluster{
    min-height:100svh;
    display:grid;
    grid-template-rows:1fr auto;
    grid-template-columns:1fr auto;
    padding:clamp(2rem,4vw,4rem);
    background:linear-gradient(135deg,var(--harbor) 0%,var(--adriatic) 100%);
    position:relative;
    overflow:hidden;
}

.hero-main{
    grid-column:1/-1;
    align-self:center;
    z-index:2;
}

.hero-domain{
    font-family:'Playfair Display',serif;
    font-weight:700;
    font-size:clamp(3.5rem,10vw,8rem);
    color:var(--foam);
    letter-spacing:-0.02em;
    line-height:1.05;
}

.hero-dot{color:var(--coral)}

.hero-tagline{
    font-family:'Lato',sans-serif;
    font-size:clamp(1rem,2vw,1.3rem);
    color:var(--seaglass);
    margin-top:1rem;
    letter-spacing:0.005em;
}

.hero-seal-block{
    position:absolute;
    bottom:12vh;right:6vw;
    width:clamp(120px,20vw,200px);
    z-index:2;
    opacity:0;
    transform:scale(0.9);
    transition:opacity 0.8s ease,transform 0.8s ease;
}

.hero-seal-block.shown{
    opacity:1;transform:scale(1);
}

.seal-mini{width:100%;height:auto}

.seal-ring-outer{
    stroke-dasharray:600;
    stroke-dashoffset:600;
    transition:stroke-dashoffset 1.5s ease;
}

.hero-seal-block.shown .seal-ring-outer{
    stroke-dashoffset:0;
}

.hero-ticker{
    grid-column:1/-1;
    overflow:hidden;
    background:rgba(0,0,0,0.2);
    padding:0.75rem 0;
    z-index:2;
}

.ticker-track{
    display:flex;
    gap:3rem;
    white-space:nowrap;
    animation:ticker 30s linear infinite;
    font-family:'IBM Plex Mono',monospace;
    font-weight:500;
    font-size:clamp(0.75rem,1.2vw,0.9rem);
    color:var(--sand);
    letter-spacing:0.05em;
}

@keyframes ticker{
    from{transform:translateX(0)}
    to{transform:translateX(-50%)}
}

.tri-cluster{
    position:absolute;
    display:flex;gap:8px;
    z-index:1;
}

.tri-1{top:15%;left:70%}
.tri-cluster svg{width:40px;height:auto}

/* Mission Band */
.mission-band{
    position:relative;
    padding:clamp(3rem,6vw,6rem) clamp(2rem,4vw,4rem);
    overflow:hidden;
}

.terrazzo-bg{
    position:absolute;inset:0;
    background:
        radial-gradient(circle 3px at 10% 20%,var(--coral) 100%,transparent 100%),
        radial-gradient(circle 2px at 30% 60%,var(--sand) 100%,transparent 100%),
        radial-gradient(circle 4px at 55% 15%,var(--seaglass) 100%,transparent 100%),
        radial-gradient(circle 2px at 70% 75%,var(--coral) 100%,transparent 100%),
        radial-gradient(circle 3px at 85% 35%,var(--adriatic) 100%,transparent 100%),
        radial-gradient(circle 2px at 15% 80%,var(--sand) 100%,transparent 100%),
        radial-gradient(circle 3px at 45% 45%,var(--seaglass) 100%,transparent 100%),
        radial-gradient(circle 2px at 90% 90%,var(--coral) 100%,transparent 100%),
        radial-gradient(circle 4px at 25% 30%,var(--adriatic) 100%,transparent 100%),
        radial-gradient(circle 2px at 60% 85%,var(--sand) 100%,transparent 100%),
        radial-gradient(circle 3px at 80% 10%,var(--seaglass) 100%,transparent 100%),
        radial-gradient(circle 2px at 40% 95%,var(--coral) 100%,transparent 100%);
    opacity:0.25;
    pointer-events:none;
}

.mission-cols{
    display:flex;
    gap:2rem;
    align-items:stretch;
    position:relative;
    max-width:1100px;
    margin:0 auto;
}

.mission-col{
    flex:1;
    opacity:0;
    transform:translateY(20px);
    transition:opacity 0.6s ease,transform 0.6s ease;
}

.mission-col.shown{
    opacity:1;transform:translateY(0);
}

.mission-heading{
    font-family:'Playfair Display',serif;
    font-weight:600;
    font-size:clamp(1.8rem,4vw,3.2rem);
    color:var(--harbor);
    letter-spacing:0.01em;
    margin-bottom:1rem;
}

.zigzag-divider{
    width:20px;
    flex-shrink:0;
    align-self:stretch;
}

.zigzag-path{
    stroke-dasharray:600;
    stroke-dashoffset:600;
    transition:stroke-dashoffset 1.2s ease;
}

.mission-band.shown .zigzag-path{
    stroke-dashoffset:0;
}

/* Process Blocks */
.process-section{
    padding:clamp(3rem,6vw,6rem) clamp(2rem,4vw,4rem);
}

.process-grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:clamp(2rem,4vw,4rem);
    max-width:1000px;
    margin:0 auto;
}

.process-grid>:nth-child(3),
.process-grid>:nth-child(4){
    margin-left:15%;
}

.process-block{
    position:relative;
    background:var(--bg);
    color:var(--fg);
    padding:clamp(1.5rem,3vw,2.5rem);
    overflow:hidden;
    opacity:0;
    transform:translateY(16px);
    transition:opacity 0.6s ease,transform 0.6s ease;
}

.process-block.shown{
    opacity:1;transform:translateY(0);
}

.block-numeral{
    position:absolute;
    top:-10%;right:-5%;
    font-family:'Playfair Display',serif;
    font-weight:700;
    font-size:15vw;
    color:rgba(255,255,255,0.06);
    line-height:1;
    pointer-events:none;
}

.block-title{
    font-family:'Playfair Display',serif;
    font-weight:600;
    font-size:clamp(1.4rem,3vw,2rem);
    margin-bottom:0.75rem;
    position:relative;
}

.block-text{
    position:relative;
    line-height:1.7;
}

.block-border{
    position:absolute;inset:0;
    width:100%;height:100%;
    pointer-events:none;
}

.border-path{
    stroke-dasharray:1600;
    stroke-dashoffset:1600;
    transition:stroke-dashoffset 1.5s ease;
}

.process-block.shown .border-path{
    stroke-dashoffset:0;
}

/* Knowledge Stack */
.knowledge-section{
    padding:clamp(3rem,6vw,6rem) clamp(2rem,4vw,4rem);
    display:flex;
    flex-direction:column;
    gap:clamp(1.5rem,3vw,2rem);
    align-items:center;
}

.slab{
    display:flex;
    align-items:center;
    gap:1.5rem;
    background:var(--foam);
    border-left:4px solid var(--adriatic);
    padding:clamp(1.5rem,2.5vw,2rem);
    opacity:0;
    transition:opacity 0.6s ease,transform 0.6s ease;
}

.slab[data-dir="left"]{transform:translateX(-60px)}
.slab[data-dir="right"]{transform:translateX(60px)}
.slab.shown{opacity:1;transform:translateX(0)}

.slab-full{width:100%;max-width:900px}
.slab-narrow{width:85%;max-width:760px}

.slab-icon{
    width:60px;height:50px;
    flex-shrink:0;
}

.icon-path{
    stroke-dasharray:300;
    stroke-dashoffset:300;
    transition:stroke-dashoffset 1.2s ease;
}

.slab.shown .icon-path{
    stroke-dashoffset:0;
}

.slab-title{
    font-family:'Playfair Display',serif;
    font-weight:600;
    font-size:clamp(1.2rem,2.5vw,1.6rem);
    color:var(--harbor);
    margin-bottom:0.5rem;
}

/* Seal Chamber */
.seal-chamber{
    min-height:100svh;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    background:linear-gradient(160deg,var(--harbor) 0%,#0f2a38 100%);
    position:relative;
    overflow:hidden;
    padding:2rem;
}

.bubble{
    position:absolute;
    width:var(--size);height:var(--size);
    left:var(--x);
    bottom:-120px;
    border-radius:50%;
    background:radial-gradient(circle at 30% 30%,rgba(168,213,208,0.3),rgba(168,213,208,0.05));
    border:1px solid rgba(255,255,255,0.2);
    backdrop-filter:blur(2px);
    animation:bubbleRise var(--dur) ease-in-out var(--delay) infinite;
    pointer-events:none;
}

@keyframes bubbleRise{
    0%{transform:translateY(0) translateX(0);opacity:0}
    10%{opacity:0.6}
    90%{opacity:0.6}
    100%{transform:translateY(-120vh) translateX(20px);opacity:0}
}

.seal-large{
    width:clamp(200px,40vmin,300px);
    margin-bottom:2rem;
    opacity:0;
    transform:scale(0.9);
    transition:opacity 1s ease,transform 1s ease;
}

.seal-large.shown{
    opacity:1;transform:scale(1);
}

.seal-svg{width:100%;height:auto}

.seal-outer{
    stroke-dasharray:900;
    stroke-dashoffset:900;
    transition:stroke-dashoffset 2s ease;
    transform-origin:center;
}

.seal-large.shown .seal-outer{
    stroke-dashoffset:0;
    animation:sealSpin 60s linear infinite;
}

@keyframes sealSpin{
    from{transform:rotate(0deg)}
    to{transform:rotate(360deg)}
}

.seal-dots{
    animation:dotPulse 3s ease-in-out infinite;
}

@keyframes dotPulse{
    0%,100%{transform:scale(1);transform-origin:center}
    50%{transform:scale(1.03);transform-origin:center}
}

.seal-initials{
    transition:opacity 1.5s ease 0.8s;
}

.seal-large.shown .seal-initials{
    opacity:1 !important;
}

.seal-domain{
    font-family:'Playfair Display',serif;
    font-weight:700;
    font-size:clamp(1.5rem,4vw,3rem);
    color:var(--foam);
    letter-spacing:0.02em;
    opacity:0;
    transition:opacity 0.8s ease 1.5s;
}

.seal-large.shown ~ .seal-domain{
    opacity:1;
}

.seal-date{
    font-family:'IBM Plex Mono',monospace;
    font-weight:500;
    font-size:clamp(0.75rem,1vw,0.9rem);
    color:var(--drift);
    margin-top:0.5rem;
    opacity:0;
    transition:opacity 0.8s ease 2s;
}

.seal-large.shown ~ .seal-date{
    opacity:1;
}

/* Radial Nav */
.nav-btn{
    position:fixed;
    bottom:1.5rem;right:1.5rem;
    width:48px;height:48px;
    border-radius:50%;
    background:var(--harbor);
    border:2px solid var(--coral);
    cursor:pointer;
    z-index:200;
    display:flex;align-items:center;justify-content:center;
    transition:transform 0.3s;
}

.nav-btn:hover{transform:scale(1.15)}

.nav-overlay{
    position:fixed;inset:0;
    background:rgba(27,58,75,0.85);
    z-index:190;
    display:flex;align-items:center;justify-content:center;
    opacity:0;pointer-events:none;
    transition:opacity 0.4s ease;
}

.nav-overlay.open{
    opacity:1;pointer-events:auto;
}

.nav-links{
    display:flex;
    flex-direction:column;
    gap:1.5rem;
    text-align:center;
}

.nav-link{
    font-family:'Lato',sans-serif;
    font-weight:700;
    font-size:clamp(1.2rem,3vw,2rem);
    color:var(--foam);
    text-decoration:none;
    transition:color 0.3s;
}

.nav-link:hover{color:var(--coral)}

/* Dotted grid on light sections */
.knowledge-section::before{
    content:'';
    position:absolute;inset:0;
    background:radial-gradient(circle 1.5px,var(--drift) 100%,transparent 100%);
    background-size:16px 16px;
    opacity:0.15;
    pointer-events:none;
}

.knowledge-section{position:relative}

/* Responsive */
@media(max-width:768px){
    .mission-cols{flex-direction:column}
    .zigzag-divider{display:none}
    .process-grid{grid-template-columns:1fr}
    .process-grid>:nth-child(3),
    .process-grid>:nth-child(4){margin-left:0}
    .slab-narrow{width:100%}
    .hero-seal-block{display:none}
    .tri-cluster{display:none}
}

@media(prefers-reduced-motion:reduce){
    .ticker-track{animation:none}
    .mission-col,.process-block,.slab,.seal-large,.hero-seal-block{opacity:1;transform:none;transition:none}
    .seal-ring-outer,.zigzag-path,.border-path,.icon-path,.seal-outer{stroke-dashoffset:0;transition:none}
    .seal-initials{opacity:1 !important;transition:none}
    .seal-domain,.seal-date{opacity:1;transition:none}
    .bubble{animation:none}
    .seal-outer{animation:none}
}
