/*GLobal Variables*/
html,
body {
    height: 100%;
    margin: 0;
    font-size: 16px;
    font-family: IBM Plex;
    font-weight: 580;
    line-height: 1.8em;
}

/* =============================================
   Questrade Design System — Typography & Spacing
   ============================================= */
:root {
    --grid-columns: 1.5fr 250px 250px 250px 250px 1.5fr;
    --grid-gap: 0.7em;
    --content-col: 2 / 6;

    --section-y: 3.5rem;
    --feature-gap: 4rem;
    --block-gap: 2.5rem;
    --text-gap: 1.25rem;
    --media-gap: 2rem;
    --caption-gap: 0.75rem;

    --color-label: #999999;
    --color-title: #222222;
    --color-body: #222222;
    --color-caption: #000000;
    --color-meta: #c9c4c4;
}

/*Global Properties for all*/
.section-label {
    font-family: Karla;
    font-size: 20px;
    font-weight: 600;
    color: var(--color-label);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    line-height: 1.2;
    margin: 0 0 0.75rem;
}

.heading {
    font-family: Karla;
    font-size: 2rem;
    line-height: 1.25;
    font-weight: 400;
    color: var(--color-title);
    margin: 0 0 var(--text-gap);
    padding: 0;
}

.sub-heading {
    font-family: Karla;
    font-size: 1.5rem;
    line-height: 1.3;
    font-weight: 400;
    color: var(--color-title);
    margin: var(--block-gap) 0 var(--text-gap);
    padding: 0;
}

.sub-header {
    font-family: Karla;
    font-size: 1.25rem;
    line-height: 1.3;
    font-weight: 600;
    color: var(--color-title);
    margin: 0 0 0.75rem;
    padding: 0;
}

.heading + .sub-heading,
.section-label + .sub-heading {
    margin-top: var(--text-gap);
}

.paragraph {
    font-family: Karla;
    font-size: 22px;
    line-height: 34px;
    font-weight: 400;
    color: var(--color-body);
    margin: 0 0 var(--text-gap);
}

.paragraph:last-child {
    margin-bottom: 0;
}

.description {
    font-family: Karla;
    font-size: 18px;
    line-height: 1.5;
    font-weight: 400;
    text-align: center;
    color: var(--color-caption);
    margin: var(--caption-gap) 0 var(--media-gap);
    padding: 0;
}

/* Shared content column spacing */
.box0,
.box4,
.box6,
.box7,
.box9,
.box11,
.box12,
.box13,
.box160,
.box22,
.box25,
.box34 {
    grid-column: var(--content-col);
    padding-top: var(--section-y);
    padding-bottom: var(--section-y);
}

.box11,
.box12,
.box13 {
    padding-top: 0;
    padding-bottom: 0;
}

.box9 + .box11,
.box11 + .box12,
.box12 + .box13 {
    padding-top: var(--feature-gap);
}

.box13 {
    padding-bottom: var(--section-y);
}

.highlight-grid,
.bento-row,
.bento-grid,
.social-grid,
.youtube-embed {
    margin-top: var(--block-gap);
}

.highlight-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2rem;
}

.highlight-grid--2col {
    grid-template-columns: repeat(2, 1fr);
}

.highlight-item .sub-header {
    margin: 0 0 0.75rem;
}

.highlight-icon {
    display: flex;
    margin-bottom: 0.75rem;
    color: var(--color-title);
}

.highlight-icon svg {
    width: 32px;
    height: 32px;
}

.highlight-item .paragraph {
    font-size: 20px;
    line-height: 1.6;
    margin: 0;
}

.bento-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.5rem;
}

.bento-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
}

.bento-grid__wide {
    grid-column: span 2;
}

.social-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
}

.social-video {
    position: relative;
    aspect-ratio: 9 / 16;
    border-radius: 8px;
    overflow: hidden;
    background-color: #122035;
}

.social-video video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.social-video--empty {
    display: flex;
    align-items: center;
    justify-content: center;
    color: #8fa3b8;
    font-family: Karla;
    font-size: 0.875rem;
    text-align: center;
}

.social-video--empty span {
    padding: 1rem;
}

.feature-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 2rem;
    align-items: center;
}

.feature-row__media {
    margin-top: 0;
}

.feature-row__media video {
    width: 100%;
    height: auto;
    display: block;
    object-fit: cover;
    border-radius: 8px;
}

.feature-row__copy .sub-heading {
    margin-top: 0;
    margin-bottom: var(--text-gap);
}

.feature-row__copy .paragraph {
    margin-bottom: 0;
}

.media-placeholder,
.box4 .video,
.youtube-embed {
    margin-top: var(--media-gap);
}

.box4 .video:first-child,
.section-label:first-child + .heading + .paragraph + .media-placeholder,
.heading:first-child + .media-placeholder {
    margin-top: 0;
}

.youtube-embed {
    position: relative;
    width: 100%;
    padding-bottom: 56.25%;
    background-color: #0a1628;
    border-radius: 8px;
    overflow: hidden;
}

.youtube-embed iframe {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    border: 0;
    border-radius: 8px;
}

.picture{
    width: 100%;
    max-height: 100%;
    display: block;
    margin: 0 auto;
    padding-top: 5%;
}

.video video{
    object-fit: cover;
    width: 100%;
    max-height: 100%;
}


/* Cover Video Properties */
.cover{
    position: relative;
    min-height: 100vh;
    overflow: hidden;
    background-color: #070716;
}

.cover-video {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 100%;
    height: auto;
    max-height: 100%;
    transform: translate(-50%, -50%);
    object-fit: contain;
    z-index: 0;
}

.cover-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.55);
    z-index: 1;
    pointer-events: none;
}

.cover .navbar,
.cover .container {
    position: relative;
    z-index: 2;
}

/* Cover Image Title*/

.cover .text-box {
    width: 60%;
    height: 100%;
    position: absolute;
    top: 100px;
    left: 0px;
    z-index: 2;
    justify-content: flex-end;
    flex-direction: column;
    align-items: flex-start;
    display: flex;
    color: white;
}

.text-box h2 {
    font-family: Manrope;
    font-size: 35px;
    line-height: 27.8px;
    font-weight: 500;
    padding-left: 20%;
    padding-bottom: 5%;
    margin: 0;
}

.text-box h4 {
    font-family: Manrope;
    font-size: 86px;
    font-weight: 700;
    padding-left: 20%;
    padding-bottom: 250px;
    margin-top: 2%;
    margin-bottom: 2%;
    line-height: 100px;
}

/*Setting the story - Wrapper*/

.wrapper1 {
    display: grid;
    grid-template-columns: var(--grid-columns);
    grid-gap: var(--grid-gap);
    background-color: white;
}

/*Seeting the story*/
.box0 {
    grid-row: 1;
    padding-top: 1.5rem;
    padding-bottom: 1.5rem;
}

.disclaimer {
    font-family: Karla;
    font-size: 18px;
    padding: 0;
    margin: 0;
    padding-top: 1%;
    padding-bottom: 1.5rem;
    color: #3a3a3b;
}

/*My role intro content - Wrapper*/

.wrapper2 {
    display: grid;
    grid-template-columns: var(--grid-columns);
    grid-gap: var(--grid-gap);
    padding-top: var(--section-y);
    padding-bottom: 1.5rem;
    background-color: white;
}

.meta-col:nth-child(1) {
    grid-column: 2/3;
    grid-row: 1;
}

.meta-col:nth-child(2) {
    grid-column: 3/4;
    grid-row: 1;
}

.meta-col:nth-child(3) {
    grid-column: 4/5;
    grid-row: 1;
}

.meta-col:nth-child(4) {
    grid-column: 5/6;
    grid-row: 1;
}

.meta-col h4 {
    font-family: Karla;
    color: var(--color-meta);
    font-size: 1rem;
    margin: 0 0 0.5rem;
    padding: 0;
}

.meta-col h2 {
    color: #000000;
    font-size: 1.2rem;
    font-family: Karla;
    font-weight: 400;
    margin: 0;
    padding: 0 0 0.35rem;
}

.context{
    font-family: Karla;
    line-height: 28px;
    color: #222222;
    font-size: 22px;
    font-weight: 400;
    padding-top: 2%;
    padding-right: 7%;
}


/*Problem Definition - Wrapper*/

.wrapper3 {
    display: grid;
    grid-template-columns: var(--grid-columns);
    grid-gap: var(--grid-gap);
    background-color: white;
}

.box4 {
    grid-row: 1;
    padding-bottom: 5rem;
}

.box4 .video {
    width: 100%;
    padding: 0;
    margin: 0;
}

.box4 .video video {
    width: 100%;
    height: auto;
    display: block;
    object-fit: cover;
}

.box4 .description {
    width: 100%;
    padding-bottom: 1.5rem;
}

.box4 .highlight-grid {
    width: 100%;
}

.current img {
    width: 70%;
    max-height: 70%;
    display: block;
    margin: 0 auto;
    padding-top: 5%;
}

/*Design Challenge - Wrapper*/

.wrapper4 {
    display: grid;
    grid-template-columns: var(--grid-columns);
    grid-gap: var(--grid-gap);
    background-color: #e3e7f8;
}

.box6 {
    grid-row: 1;
    padding-bottom: 1.5rem;
}


/*Product Goals - Wrapper*/

.wrapper5 {
    display: grid;
    grid-template-columns: var(--grid-columns);
    grid-gap: var(--grid-gap);
    background-color: #e3e7f8;
}


.box7 {
    grid-row: 1;
}


/*From a user's perspective - Wrapper*/

.wrapper6 {
    display: grid;
    grid-template-columns: var(--grid-columns);
    grid-gap: var(--grid-gap);
    background-color: white;
}

.box9 {
    grid-row: 1;
    padding-bottom: 0;
}

.box11 {
    grid-row: 2;
}

.box12 {
    grid-row: 3;
}

.box13 {
    grid-row: 4;
    padding-bottom: var(--section-y);
}

.testing img {
    width: 100%;
    max-height: 100%;
    display: block;
    margin: 0 auto;
}

.persona img{
    padding-top: 0;
}

.servicedesign img {
    object-fit: cover;
    width: 100%;
    max-height: 100%;
}

/*Proposed user flow*/
.box14 {
    grid-column: 2/6;
    grid-row: 13/15;
}

/*Identifying user flow failures*/
.box15 {
    grid-column: 2/6;
    grid-row: 15/17;
    padding-bottom: 8%;
}

.sketching img {
    width: 100%;
    max-height: 100%;
    display: block;
    margin: 0 auto;
}

/*Design Adjustments - Wrapper*/

.wrapper7 {
    display: grid;
    grid-template-columns: var(--grid-columns);
    grid-gap: var(--grid-gap);
    background-color: #F2F4FB;
}

.box160 {
    grid-row: 1;
}

/*A Frustrating Onboarding*/
.box16 {
    grid-column: 2/6;
    grid-row: 18/19;
}

.box17 {
    grid-column: 2/6;
    grid-row: 19/21;
    padding-bottom: 8%;
}

/*Removing Unnecessary Questions*/
.box18 {
    grid-column: 2/6;
    grid-row: 21/23;
}

.box19 {
    grid-column: 2/6;
    grid-row: 23/25;
    padding-bottom: 8%;
}

/*A Familiar but Unfamiliar homepage*/
.box20 {
    grid-column: 2/6;
    grid-row: 25/27;
}

.box21 {
    grid-column: 2/6;
    grid-row: 27/29;
    padding-bottom: 8%;
}

/*Brand - Wrapper*/

.wrapper8 {
    display: grid;
    grid-template-columns: var(--grid-columns);
    grid-gap: var(--grid-gap);
    background-color: white;
}

.box22 {
    grid-row: 1;
    padding-bottom: 1.5rem;
}

/*Color and Typography*/
.box23 {
    grid-column: 2/6;
    grid-row: 31/33;
    padding-bottom: 8%;
}

/*Feather Icons*/
.box24 {
    grid-column: 2/6;
    grid-row: 33/35;
    padding-bottom: 8%;
}

/*Solutions - Wrapper*/

.wrapper9 {
    display: grid;
    grid-template-columns: var(--grid-columns);
    grid-gap: var(--grid-gap);
    background-color: white;
}

.box25 {
    grid-row: 1;
}


/*Feature Highlight*/
.box26 {
    grid-column: 2/4;
    grid-row: 37/39;
}

.box27 {
    padding-top: 80%;
    padding-left: 10%;
    grid-column: 4/6;
    grid-row: 37/39;
}

/*Lightning Fast Recommendations*/
.box28 {
    grid-column: 4/6;
    grid-row: 43/45;
}

.box29 {
    padding-top: 80%;
    grid-column: 2/4;
    grid-row: 43/45;
}

/*A Dynamic Experience*/
.box30 {
    grid-column: 2/4;
    grid-row: 45/47;
    padding-bottom: 10%;
}

.box31 {
    padding-top: 80%;
    padding-left: 10%;
    grid-column: 4/6;
    grid-row: 45/47;
}

/*The Big Picture*/
.box32 {
    grid-column: 2/6;
    grid-row: 49/51;
}

.box33 {
    grid-column: 2/6;
    grid-row: 51/53;
    padding-bottom: 10%;
}

/*Results - Wrapper*/

.wrapper10 {
    display: grid;
    grid-template-columns: var(--grid-columns);
    grid-gap: var(--grid-gap);
    background-color: white;
}

.box34 {
    grid-row: 1;
}

/*Lesson 1*/
.box35 {
    grid-column: 2/6;
    grid-row: 55/57;
    padding-bottom: 4%;
}

/*Lesson 2*/
.box36 {
    grid-column: 2/6;
    grid-row: 57/59;
    padding-bottom: 4%;
}

/*Lesson 3*/
.box37 {
    grid-column: 2/6;
    grid-row: 59/61;
    padding-bottom: 4%;
}

/*That's a Wrap*/
.box38 {
    grid-column: 2/6;
    grid-row: 61/63;
}

/*Footer*/
.wrapper11 {
    display: grid;
    grid-template-columns: var(--grid-columns);
    grid-gap: var(--grid-gap);
    background-color: white;
    padding-top: 0%;
    padding-bottom: 0%;
}

/*Footer Line*/
.line{
    grid-column: 1/7;
    grid-row: 1/2;
    padding-top: 3%;
}
hr {
    display: block;
    height: 1px;
    border: 0;
    border-top: 1px solid #ccc;
    margin: 1em 0;
    padding: 0;
}

/*Footer*/
.foot1{
    grid-column: 1/4;
    grid-row: 2/4;
    padding-top: 10%;
    padding-left: 25%;
    padding-bottom: 5%;
}

.tag2{
    font-family: Manrope;
    line-height: 1.5em;
    color: #1B1A38;
    font-size: 3em;
    font-weight: 500;
    padding-top: 12px;
    padding-bottom: 32px;
    margin: 0;
}

.foot2{
    grid-column: 4/7;
    grid-row: 2/4;
    padding-top: 10%;
    padding-left: 20%;
}

.links a{
    font-family: Manrope;
    text-decoration: none;
    line-height: 1.3em;
    color: #1B1A38;
    font-size: 2em;
    font-weight: 500;
    padding-right: 10%;
    margin: 0;
}

.links a:hover{
    color: #A2BBA5;
    transition: 0.5s ease;
    transition-delay: .5s;
    transition: 0.5s ease-out;
}

.foot3{
    grid-column: 4/7;
    grid-row: 3/5;
    padding-left: 20%;
    padding-bottom: 5%;
    padding-top: 5%;
}

.tag3{
    font-family: Manrope;
    line-height: 0.8em;
    color: #acacac; 
    font-size: 1em;
    font-weight: 300;
    letter-spacing: 2px;
    padding-top: 56px;
}

.foot4{
    grid-column: 1/4;
    grid-row: 4/6;
    padding-top: 5%;
    padding-left: 25%;
    padding-bottom: 15%;
}


/*Intro Motion*/
#motion1{
    -webkit-animation: 1.2s ease 0s normal forwards 1 fadein1;
    animation: 1.2s ease 0s normal forwards 1 fadein1;
    opacity: 0;
}

@keyframes fadein1{
    0% { opacity:0;}
    66% { opacity:0}
    100% { opacity:1;}
}

@-webkit-keyframes fadein1{
    0% { opacity:0;}
    66% {  opacity:0}
    100% { opacity:1;}
}

#motion2{
    -webkit-animation: 1.8s ease 0.6s normal forwards 1 fadein2;
    animation: 1.8s ease 0.6s normal forwards 1 fadein2;
    opacity: 0;
}

@keyframes fadein2{
    0% { opacity:0;}
    33% { opacity:0; transform: translatey(50px);}
    100% { opacity:1;}
}

@-webkit-keyframes fadein2{
    0% { opacity:0;}
    33% {  opacity:0; transform: translatey(50px);}
    100% { opacity:1;}
}

.media-placeholder {
    width: 100%;
    min-height: 320px;
    background-color: #0D1B2A;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #8fa3b8;
    font-family: Karla;
    font-size: 1rem;
    text-align: center;
    padding: 2rem;
    margin: 0 auto;
}

.media-placeholder--alt {
    background-color: #1a1a2e;
}

.media-placeholder--video {
    min-height: 240px;
    background-color: #122035;
}

@media (max-width: 768px) {
    .highlight-grid,
    .highlight-grid--2col,
    .bento-row,
    .bento-grid {
        grid-template-columns: 1fr;
    }

    .feature-row {
        grid-template-columns: 1fr;
    }

    .social-grid {
        grid-template-columns: repeat(2, 1fr);
        grid-template-rows: auto;
    }

    .bento-grid__wide {
        grid-column: span 1;
    }
}

@media (max-width: 480px) {
    .social-grid {
        grid-template-columns: 1fr;
    }
}

