/* ============================================
   Studio Norm — Creative Agency Template
   © KodTree
   ============================================ */
:root{
    --sn-bg:#f8f5f2;
    --sn-text:#1a1a1a;
    --sn-text-soft:#525252;
    --sn-border:#1a1a1a;
    --sn-accent:#e0fe10;
    --sn-dark:#0a0a0a;
    --sn-radius:0;
    --bs-body-font-family:'Inter','Pretendard',-apple-system,sans-serif;
    --sn-display:'Playfair Display',Georgia,serif;
}
*{-webkit-font-smoothing:antialiased;}
body{font-family:var(--bs-body-font-family);color:var(--sn-text);background:var(--sn-bg);line-height:1.55;}
.serif{font-family:var(--sn-display);font-weight:500;letter-spacing:-0.01em;}

/* ── Navbar ───────────────────────────── */
.navbar{background:transparent;padding:1rem 0;transition:all .25s ease;border-bottom:1px solid transparent;}
.navbar.scrolled{background:var(--sn-bg);border-bottom-color:var(--sn-border);}
.navbar-brand{font-family:var(--sn-display);font-size:1.5rem;font-weight:600;color:var(--sn-text)!important;letter-spacing:-0.01em;}
.nav-link{font-weight:500;color:var(--sn-text)!important;font-size:.9375rem;}
.nav-link:hover,.nav-link.active{color:var(--sn-text)!important;text-decoration:underline;text-underline-offset:6px;}

/* ── Buttons ──────────────────────────── */
.btn{font-weight:600;padding:.75rem 1.5rem;border-radius:0;transition:all .2s ease;font-size:.9375rem;border:1.5px solid transparent;}
.btn-dark{background:var(--sn-text);color:var(--sn-bg);border-color:var(--sn-text);}
.btn-dark:hover{background:transparent;color:var(--sn-text);}
.btn-outline-dark{border-color:var(--sn-text);color:var(--sn-text);background:transparent;}
.btn-outline-dark:hover{background:var(--sn-text);color:var(--sn-bg);}
.btn-accent{background:var(--sn-accent);color:var(--sn-text);border-color:var(--sn-text);}
.btn-accent:hover{background:var(--sn-text);color:var(--sn-accent);}
.btn-lg{padding:1rem 1.75rem;font-size:1rem;}

/* ── Hero ─────────────────────────────── */
.hero{padding:10rem 0 5rem;position:relative;overflow:hidden;}
.hero__eyebrow{display:inline-block;font-size:.8125rem;font-weight:600;letter-spacing:.15em;text-transform:uppercase;margin-bottom:1.5rem;color:var(--sn-text-soft);}
.hero__eyebrow::before{content:"●";color:var(--sn-accent);margin-right:.625rem;text-shadow:0 0 8px rgba(224,254,16,.5);}
.hero__title{font-family:var(--sn-display);font-size:clamp(2.75rem,7vw,5.5rem);font-weight:500;line-height:1;letter-spacing:-0.03em;margin-bottom:2rem;}
.hero__title em{font-style:italic;color:var(--sn-text);position:relative;display:inline-block;}
.hero__title em::after{content:"";position:absolute;left:-.25rem;right:-.25rem;bottom:.1em;height:.4em;background:var(--sn-accent);z-index:-1;}
.hero__subtitle{font-size:1.125rem;color:var(--sn-text-soft);max-width:580px;margin-bottom:2.5rem;}
.hero__cta{display:flex;gap:.75rem;flex-wrap:wrap;}
.hero__marquee{margin-top:6rem;border-top:1px solid var(--sn-border);border-bottom:1px solid var(--sn-border);padding:1rem 0;overflow:hidden;white-space:nowrap;}
.hero__marquee-track{display:inline-block;animation:marquee 30s linear infinite;}
.hero__marquee-track span{font-family:var(--sn-display);font-size:1.5rem;margin:0 2rem;color:var(--sn-text-soft);}
.hero__marquee-track span::after{content:"✦";margin-left:2rem;color:var(--sn-text);}
@keyframes marquee{0%{transform:translateX(0);}100%{transform:translateX(-50%);}}

/* ── Sections ─────────────────────────── */
section{padding:6rem 0;}
.section-eyebrow{display:inline-block;font-size:.8125rem;font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:var(--sn-text-soft);margin-bottom:1rem;}
.section-eyebrow::before{content:"●";color:var(--sn-accent);margin-right:.5rem;}
.section-title{font-family:var(--sn-display);font-size:clamp(2rem,4.5vw,3.5rem);font-weight:500;line-height:1.05;letter-spacing:-0.02em;margin-bottom:1rem;}
.section-lead{font-size:1.0625rem;color:var(--sn-text-soft);max-width:640px;}

/* ── Services ─────────────────────────── */
.service-row{display:grid;grid-template-columns:60px 1fr auto;gap:2rem;align-items:center;padding:2rem 0;border-top:1px solid var(--sn-border);transition:all .3s ease;}
.service-row:last-child{border-bottom:1px solid var(--sn-border);}
.service-row:hover{padding-left:1rem;}
.service-row__num{font-family:var(--sn-display);font-style:italic;color:var(--sn-text-soft);}
.service-row__title{font-family:var(--sn-display);font-size:clamp(1.5rem,3vw,2.25rem);font-weight:500;letter-spacing:-0.01em;margin:0;}
.service-row__title em{color:var(--sn-text);position:relative;font-style:italic;display:inline-block;}
.service-row__title em::after{content:"";position:absolute;left:-.15rem;right:-.15rem;bottom:.05em;height:.35em;background:var(--sn-accent);z-index:-1;}
.service-row__arrow{font-size:1.5rem;color:var(--sn-text);transition:transform .25s ease;}
.service-row:hover .service-row__arrow{transform:translateX(8px);}

/* ── Portfolio Grid ───────────────────── */
.portfolio-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:1.5rem;}
.portfolio-item{position:relative;overflow:hidden;background:#1a1a1a;aspect-ratio:4/3;display:flex;flex-direction:column;justify-content:space-between;padding:1.5rem;color:#fff;transition:transform .3s ease;cursor:pointer;}
.portfolio-item:hover{transform:translateY(-4px);}
.portfolio-item--lg{grid-column:span 7;}
.portfolio-item--md{grid-column:span 5;}
.portfolio-item--full{grid-column:span 12;aspect-ratio:21/9;}
.portfolio-item--half{grid-column:span 6;}
.portfolio-item__cat{font-size:.75rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;opacity:.7;}
.portfolio-item__title{font-family:var(--sn-display);font-size:clamp(1.25rem,2.5vw,2rem);font-weight:500;line-height:1.05;margin:0;}
.portfolio-item__year{font-family:var(--sn-display);font-style:italic;font-size:.875rem;opacity:.7;}
.portfolio-item--bright{background:var(--sn-accent);color:var(--sn-text);}
.portfolio-item--cream{background:#e8e3dd;color:var(--sn-text);}
.portfolio-item--gradient{background:linear-gradient(135deg,#ff5f1f,#e0fe10);color:var(--sn-text);}
@media(max-width:767.98px){.portfolio-item,.portfolio-item--lg,.portfolio-item--md,.portfolio-item--half{grid-column:span 12;}}

/* ── Process steps ────────────────────── */
.process-step{padding:2.5rem;border:1px solid var(--sn-border);height:100%;background:transparent;transition:all .25s ease;}
.process-step:hover{background:var(--sn-text);color:var(--sn-bg);}
.process-step:hover .process-step__title em::after{background:var(--sn-accent);}
.process-step__num{font-family:var(--sn-display);font-style:italic;font-size:1rem;color:var(--sn-text-soft);margin-bottom:1.5rem;}
.process-step:hover .process-step__num{color:var(--sn-accent);}
.process-step__title{font-family:var(--sn-display);font-size:1.75rem;font-weight:500;margin-bottom:1rem;letter-spacing:-0.01em;}
.process-step__text{font-size:.9375rem;color:inherit;opacity:.85;margin:0;}

/* ── Team Card ────────────────────────── */
.team-card{position:relative;overflow:hidden;aspect-ratio:3/4;background:#e8e3dd;display:flex;align-items:flex-end;padding:1.5rem;transition:transform .3s ease;}
.team-card:hover{transform:translateY(-4px);}
.team-card__avatar{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--sn-display);font-size:6rem;font-weight:500;color:rgba(26,26,26,.15);font-style:italic;}
.team-card__info{position:relative;z-index:1;background:var(--sn-bg);padding:.875rem 1rem;width:100%;border:1px solid var(--sn-border);}
.team-card__name{font-family:var(--sn-display);font-size:1.25rem;font-weight:500;margin:0;}
.team-card__role{font-size:.8125rem;color:var(--sn-text-soft);margin:0;}

/* ── Stats ────────────────────────────── */
.stat-block{padding:2rem 0;border-top:1px solid var(--sn-border);}
.stat-block:last-child{border-bottom:1px solid var(--sn-border);}
.stat-block__num{font-family:var(--sn-display);font-size:clamp(2.5rem,5vw,4rem);font-weight:500;line-height:1;letter-spacing:-0.02em;}
.stat-block__label{font-size:.9375rem;color:var(--sn-text-soft);margin-top:.5rem;}

/* ── CTA banner ───────────────────────── */
.cta-banner{background:var(--sn-text);color:var(--sn-bg);padding:6rem 3rem;text-align:center;}
.cta-banner__title{font-family:var(--sn-display);font-size:clamp(2rem,5vw,4rem);font-weight:500;line-height:1.05;letter-spacing:-0.02em;margin-bottom:2rem;}
.cta-banner__title em{color:var(--sn-accent);font-style:italic;}
.cta-banner .btn{border-color:var(--sn-bg);color:var(--sn-bg);background:transparent;}
.cta-banner .btn:hover{background:var(--sn-accent);color:var(--sn-text);border-color:var(--sn-accent);}

/* ── Case study ───────────────────────── */
.case-hero{padding:8rem 0 4rem;border-bottom:1px solid var(--sn-border);}
.case-hero__meta{display:flex;gap:3rem;margin-top:3rem;flex-wrap:wrap;}
.case-hero__meta div{font-size:.875rem;}
.case-hero__meta-label{color:var(--sn-text-soft);font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;margin-bottom:.25rem;}
.case-image{background:#1a1a1a;color:#fff;aspect-ratio:16/9;display:flex;align-items:center;justify-content:center;font-family:var(--sn-display);font-style:italic;font-size:1.25rem;opacity:.6;margin:3rem 0;}
.case-image--accent{background:var(--sn-accent);color:var(--sn-text);opacity:1;}

/* ── Contact form ─────────────────────── */
.form-control,.form-select{border-radius:0;border:0;border-bottom:1.5px solid var(--sn-border);padding:.75rem 0;background:transparent;color:var(--sn-text);font-size:1rem;}
.form-control:focus,.form-select:focus{border-color:var(--sn-text);box-shadow:none;background:transparent;}
.form-label{font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;color:var(--sn-text-soft);margin-bottom:.25rem;}

/* ── Footer ───────────────────────────── */
.footer{background:var(--sn-text);color:var(--sn-bg);padding:6rem 0 2rem;}
.footer h6{color:var(--sn-bg);font-family:var(--sn-display);font-size:1rem;font-weight:500;margin-bottom:1rem;}
.footer a{color:var(--sn-bg);opacity:.7;text-decoration:none;}
.footer a:hover{opacity:1;text-decoration:underline;}
.footer ul{list-style:none;padding:0;}
.footer ul li{padding:.25rem 0;font-size:.9375rem;}
.footer__brand{font-family:var(--sn-display);font-size:3rem;font-weight:500;margin-bottom:1rem;letter-spacing:-0.02em;}
.footer__bottom{margin-top:4rem;padding-top:1.5rem;border-top:1px solid rgba(248,245,242,.15);font-size:.875rem;opacity:.7;}

/* ── Page hero ────────────────────────── */
.page-hero{padding:9rem 0 4rem;}
.page-hero__title{font-family:var(--sn-display);font-size:clamp(2.5rem,5vw,4rem);font-weight:500;letter-spacing:-0.02em;line-height:1.05;margin-bottom:1rem;}

/* ── 404 ──────────────────────────────── */
.error-page{padding:10rem 0 6rem;text-align:center;}
.error-page__code{font-family:var(--sn-display);font-style:italic;font-size:clamp(7rem,18vw,14rem);font-weight:500;line-height:1;}
.error-page__code em{background:var(--sn-accent);padding:0 .15em;}

@media(max-width:767.98px){
    section{padding:4rem 0;}
    .hero{padding:8rem 0 3rem;}
    .cta-banner{padding:3rem 1.5rem;}
}
