/* ===========================================================
   Gitxperts — Neobrutalist Editorial Theme
   Cream paper · ink borders + hard offset shadows
   Accents: yellow / pink / blue / teal
   Fonts: Fraunces (serif display) · Space Grotesk (sans) · JetBrains Mono (labels)
   =========================================================== */

:root {
  --paper: #f2ede3;
  --paper-card: #fbf9f3;
  --beige: #e7ddcb;
  --ink: #16130f;
  --ink-2: #211d18;
  --yellow: #02d077;
  --pink: #ec4c97;
  --blue: #3a4fd8;
  --teal: #5fcb9f;
  --text: #2e2a24;
  --muted: #6e665b;
  --line: #dbd2c2;

  /* legacy aliases so old class names keep working */
  --accent: var(--yellow);
  --accent-dark: #e0a92f;
  --accent-soft: #fdf1d6;
  --brand: var(--yellow);
  --brand-dark: #e0a92f;
  --brand-soft: #fdf1d6;
  --navy: var(--ink);
  --navy-soft: var(--ink-2);

  --serif: 'Fraunces', Georgia, 'Times New Roman', serif;
  --sans: 'Space Grotesk', system-ui, -apple-system, "Segoe UI", sans-serif;
  --mono: 'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, monospace;
  --bs-primary: #02d077;
}

/* ---------- Base ---------- */
* { scroll-behavior: smooth; }
html { scroll-padding-top: 96px; }

body {
  font-family: var(--sans);
  color: var(--text);
  background: var(--paper);
  overflow-x: hidden;
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--serif);
  font-weight: 600;
  color: var(--ink);
  letter-spacing: -0.02em;
}
p { color: var(--text); line-height: 1.7; }
a { text-decoration: none; }

.section { padding: 90px 0; }
.section-sm { padding: 56px 0; }
.bg-paper { background: var(--paper) !important; }
.bg-beige { background: var(--beige) !important; }
.bg-ink { background: var(--ink) !important; color: var(--paper); }
.bg-soft { background: var(--beige) !important; }
.bg-navy { background: var(--ink) !important; }
.text-ink { color: var(--ink) !important; }
.text-cream { color: var(--paper) !important; }
.text-brand { color: var(--ink) !important; }

/* ---------- Neobrutalist primitives ---------- */
.nb { border: 2px solid var(--ink); box-shadow: 5px 5px 0 var(--ink); }

/* pill / badge label */
.pill {
  display: inline-flex; align-items: center; gap: .5rem;
  font-family: var(--mono); font-size: .72rem; font-weight: 600;
  letter-spacing: .12em; text-transform: uppercase; color: var(--ink);
  background: var(--yellow); border: 2px solid var(--ink); border-radius: 50rem;
  padding: .42rem .95rem; box-shadow: 3px 3px 0 var(--ink); line-height: 1;
}
.pill-yellow { background: var(--yellow); }
.pill-pink   { background: var(--pink); color: #fff; }
.pill-blue   { background: var(--blue); color: #fff; }
.pill-teal   { background: var(--teal); }
.pill-cream  { background: var(--paper-card); }
.pill-rot    { transform: rotate(-2.5deg); }
.pill-rot-r  { transform: rotate(2.5deg); }

/* number circle badge */
.numb {
  width: 48px; height: 48px; border-radius: 50%; border: 2px solid var(--ink);
  display: grid; place-items: center; font-family: var(--serif); font-weight: 700;
  font-size: 1.1rem; color: var(--ink); flex: none; box-shadow: 2px 2px 0 var(--ink);
}
.numb-yellow { background: var(--yellow); }
.numb-pink   { background: var(--pink); color: #fff; }
.numb-blue   { background: var(--blue); color: #fff; }
.numb-teal   { background: var(--teal); }

/* card */
.nb-card {
  background: var(--paper-card); border: 2px solid var(--ink); border-radius: 7px;
  box-shadow: 6px 6px 0 var(--ink); padding: 1.9rem; height: 100%;
  transition: transform .14s ease, box-shadow .14s ease;
}
.nb-card:hover { transform: translate(-3px,-3px); box-shadow: 9px 9px 0 var(--ink); }
.nb-card.on-ink { background: var(--ink-2); border-color: #000; box-shadow: 6px 6px 0 #000; }
.nb-card.on-ink h3, .nb-card.on-ink h4, .nb-card.on-ink h5 { color: var(--paper); }
.nb-card.on-ink p { color: rgba(242,237,227,.72); }

/* dotted divider + mono list */
.dotted { border: 0; border-top: 2px dotted rgba(22,19,15,.45); margin: 1.1rem 0; }
.mono-list { list-style: none; padding: 0; margin: 0; }
.mono-list li { font-family: var(--mono); font-size: .76rem; letter-spacing: .04em; text-transform: uppercase; color: var(--ink); margin-bottom: .45rem; }
.mono-list li::before { content: "— "; color: var(--ink); }
.on-ink .mono-list li, .on-ink .mono-list li::before { color: rgba(242,237,227,.8); }

/* mono label */
.mono-label { font-family: var(--mono); font-size: .72rem; letter-spacing: .14em; text-transform: uppercase; color: var(--muted); }
.field-note { font-family: var(--mono); font-size: .68rem; letter-spacing: .14em; text-transform: uppercase; color: var(--muted); }

/* ---------- Buttons (neobrutalist) ---------- */
.btn-nb {
  display: inline-flex; align-items: center; gap: .5rem;
  font-family: var(--mono); font-weight: 600; letter-spacing: .1em; text-transform: uppercase;
  font-size: .76rem; border: 2px solid var(--ink); border-radius: 50rem; padding: .8rem 1.4rem;
  box-shadow: 4px 4px 0 var(--ink); color: var(--ink); background: var(--paper-card);
  transition: transform .12s ease, box-shadow .12s ease; cursor: pointer;
}
.btn-nb:hover { transform: translate(-2px,-2px); box-shadow: 6px 6px 0 var(--ink); color: var(--ink); }
.btn-nb:active { transform: translate(2px,2px); box-shadow: 1px 1px 0 var(--ink); }
.btn-yellow { background: var(--yellow); }
.btn-pink { background: var(--pink); color: #fff; }
.btn-pink:hover { color: #fff; }
.btn-ink { background: var(--ink); color: var(--paper); }
.btn-ink:hover { color: var(--paper); }
.btn-cream { background: var(--paper-card); }
.btn-lg-nb { padding: .95rem 1.7rem; font-size: .82rem; }

/* legacy bootstrap button remaps → neobrutalist */
.btn { font-family: var(--mono); font-weight: 600; letter-spacing: .08em; text-transform: uppercase; font-size: .78rem; border-radius: 50rem; padding: .8rem 1.4rem; border: 2px solid var(--ink); box-shadow: 4px 4px 0 var(--ink); transition: transform .12s, box-shadow .12s; }
.btn:hover { transform: translate(-2px,-2px); box-shadow: 6px 6px 0 var(--ink); }
.btn-brand, .btn-primary { background: var(--yellow); color: var(--ink); }
.btn-brand:hover { background: var(--yellow); color: var(--ink); }
.btn-dark { background: var(--ink); color: var(--paper); }
.btn-dark:hover { background: var(--ink); color: var(--paper); }
.btn-outline-brand, .btn-ghost-navy, .btn-outline-light { background: var(--paper-card); color: var(--ink); }
.btn-glow { box-shadow: 4px 4px 0 var(--ink); }
.btn-glow:hover { box-shadow: 6px 6px 0 var(--ink); }

/* ---------- Top marquee ---------- */
.topbar { background: var(--ink); color: var(--paper); overflow: hidden; white-space: nowrap; padding: .7rem 0; border: 0; }
.topbar .marq { display: inline-block; animation: marquee 30s linear infinite; }
.topbar .marq span { font-family: var(--mono); font-size: .74rem; letter-spacing: .16em; text-transform: uppercase; margin: 0 1.4rem; opacity: .9; }
.topbar .marq .star { color: var(--yellow); }
@keyframes marquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* ---------- Header / Navbar ---------- */
.navbar { background: var(--paper); border-bottom: 2px solid var(--ink); padding-top: .7rem; padding-bottom: .7rem; transition: box-shadow .25s ease; }
.navbar.is-stuck { box-shadow: 0 6px 0 -2px var(--ink); }
.navbar > .container { background: transparent; border: 0; box-shadow: none; border-radius: 0; padding-left: var(--bs-gutter-x,1.5rem); padding-right: var(--bs-gutter-x,1.5rem); }
.navbar-brand img { height: 34px; }
.navbar .nav-link { font-family: var(--mono); font-weight: 500; font-size: .78rem; letter-spacing: .1em; text-transform: uppercase; color: var(--ink); margin: 0 .15rem; padding: .5rem .9rem !important; border-radius: 50rem; transition: background .18s, color .18s; }
.navbar .nav-link:hover { color: var(--ink); background: var(--paper-card); }
.navbar .nav-link.active { background: var(--ink); color: var(--paper); }
.navbar .dropdown-toggle::after { vertical-align: .12em; }
.navbar-toggler { border: 2px solid var(--ink) !important; border-radius: 8px; box-shadow: 3px 3px 0 var(--ink); padding: .3rem .5rem; }
.dropdown-menu { border: 2px solid var(--ink); box-shadow: 5px 5px 0 var(--ink); border-radius: 8px; padding: .5rem; background: var(--paper-card); }
.dropdown-item { border-radius: 6px; font-family: var(--mono); font-size: .78rem; text-transform: uppercase; letter-spacing: .06em; padding: .55rem .8rem; color: var(--ink); }
.dropdown-item:hover, .dropdown-item:focus { background: var(--yellow); color: var(--ink); }
@media (max-width: 991.98px) {
  .navbar-collapse { padding-top: .6rem; }
  .navbar .nav-link { margin: .15rem 0; }
}

/* ---------- Hero ---------- */
.hero-ed { position: relative; background: var(--paper); padding: 60px 0 0; overflow: hidden; }
.hero-ed .display { font-family: var(--serif); font-weight: 600; font-size: clamp(3rem, 9vw, 7rem); line-height: .94; letter-spacing: -.03em; color: var(--ink); margin: 1.6rem 0 0; }
.hero-ed .display em { font-style: italic; font-weight: 500; }
.hl { background: linear-gradient(180deg, transparent 56%, var(--yellow) 56%, var(--yellow) 92%, transparent 92%); padding: 0 .06em; }
.hero-ed .lead { font-size: 1.18rem; line-height: 1.6; color: var(--text); max-width: 46ch; }
.hero-float { position: absolute; z-index: 3; }
.hero-float.f1 { top: 16%; right: 2%; }
.hero-float.f2 { bottom: 24%; left: -1%; }
@media (max-width: 991.98px){ .hero-float{ display: none; } }

/* meta row */
.hero-meta-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.5rem; border-top: 2px solid var(--ink); border-bottom: 2px solid var(--ink); }
.hero-meta-grid .mi { padding: 1.1rem 0; }
.hero-meta-grid .k { font-family: var(--mono); font-size: .68rem; letter-spacing: .14em; text-transform: uppercase; color: var(--muted); }
.hero-meta-grid .v { font-family: var(--serif); font-size: 1.1rem; color: var(--ink); margin-top: .2rem; }

/* hero figure */
.hero-figure { position: relative; border: 2px solid var(--ink); border-radius: 7px; box-shadow: 8px 8px 0 var(--ink); overflow: hidden; }
.hero-figure img { display: block; width: 100%; height: 100%; object-fit: cover; }
.hero-figure .stamp { position: absolute; top: 1rem; left: 1rem; }

/* ---------- Section header (label + big serif) ---------- */
.ed-head h2 { font-size: clamp(2.1rem, 4.6vw, 3.4rem); line-height: 1.02; font-weight: 600; }
.ed-head .sub { font-size: 1.02rem; color: var(--muted); max-width: 46ch; margin-top: 1rem; }
.section-num { font-family: var(--serif); font-weight: 700; font-size: 3rem; line-height: 1; }
.num-pink { color: var(--pink); } .num-blue { color: var(--blue); } .num-yellow { color: var(--yellow); } .num-teal { color: var(--teal); }

/* card title / desc */
.nb-card h3, .nb-card h4 { font-family: var(--serif); font-weight: 600; color: #16130f;}
.nb-card .desc { color: var(--muted); font-size: .98rem; margin: .6rem 0 0; }

/* ---------- Work cards ---------- */
.work-card { background: var(--paper-card); border: 2px solid var(--ink); border-radius: 7px; box-shadow: 6px 6px 0 var(--ink); overflow: hidden; transition: transform .14s, box-shadow .14s; }
.work-card:hover { transform: translate(-3px,-3px); box-shadow: 9px 9px 0 var(--ink); }
.work-card .img-wrap { position: relative; border-bottom: 2px solid var(--ink); aspect-ratio: 4/3; overflow: hidden; }
.work-card .img-wrap img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s; }
.work-card:hover .img-wrap img { transform: scale(1.05); }
.work-card .img-wrap .pill { position: absolute; top: .9rem; left: .9rem; }
.work-card .body { padding: 1.3rem 1.4rem 1.6rem; }
.work-card .row-meta { display: flex; justify-content: space-between; font-family: var(--mono); font-size: .68rem; letter-spacing: .1em; text-transform: uppercase; color: var(--muted); margin-bottom: .6rem; }
.work-card h4 { font-size: 1.4rem; margin: 0; }
.work-card .desc { color: var(--muted); font-size: .92rem; margin-top: .5rem; }

/* ---------- Journal cards ---------- */
.journal-card { background: var(--paper-card); border: 2px solid var(--ink); border-radius: 7px; box-shadow: 6px 6px 0 var(--ink); overflow: hidden; transition: transform .14s, box-shadow .14s; height: 100%; }
.journal-card:hover { transform: translate(-3px,-3px); box-shadow: 9px 9px 0 var(--ink); }
.journal-card .img-wrap { border-bottom: 2px solid var(--ink); aspect-ratio: 16/10; overflow: hidden; }
.journal-card .img-wrap img { width: 100%; height: 100%; object-fit: cover; }
.journal-card .body { padding: 1.3rem 1.4rem; }
.journal-card .row-meta { display: flex; justify-content: space-between; font-family: var(--mono); font-size: .68rem; letter-spacing: .1em; text-transform: uppercase; color: var(--muted); }
.journal-card h4 { font-size: 1.3rem; margin: .6rem 0 .5rem; }
.journal-card .foot { display: flex; justify-content: space-between; align-items: center; font-family: var(--mono); font-size: .68rem; letter-spacing: .1em; text-transform: uppercase; color: var(--ink); }

/* ---------- Statement ---------- */
.ed-statement { font-family: var(--serif); font-size: clamp(1.7rem, 3.8vw, 2.9rem); line-height: 1.28; font-weight: 500; color: var(--ink); letter-spacing: -.01em; }
.ed-statement em { font-style: italic; background: linear-gradient(180deg, transparent 58%, var(--yellow) 58%, var(--yellow) 92%, transparent 92%); }

/* ---------- Contact / form ---------- */
.contact-icon { width: 46px; height: 46px; border: 2px solid var(--ink); border-radius: 8px; box-shadow: 3px 3px 0 var(--ink); display: grid; place-items: center; font-size: 1.1rem; color: var(--ink); background: var(--paper-card); flex: none; }
.contact-info-item { display: flex; gap: 1rem; align-items: center; margin-bottom: 1.4rem; }
.contact-info-item .k { font-family: var(--mono); font-size: .68rem; letter-spacing: .12em; text-transform: uppercase; color: var(--muted); }
.contact-info-item .v { font-family: var(--serif); font-size: 1.05rem; color: var(--ink); }
.form-card { background: var(--paper-card); border: 2px solid var(--ink); border-radius: 8px; box-shadow: 8px 8px 0 var(--ink); padding: 2rem; }
.form-label { font-family: var(--mono); font-size: .68rem; letter-spacing: .12em; text-transform: uppercase; color: var(--ink); font-weight: 500; }
.form-control, .form-select { border-radius: 6px; padding: .75rem .9rem; border: 2px solid var(--ink); background: var(--paper); font-family: var(--sans); color: var(--ink); }
.form-control:focus, .form-select:focus { border-color: var(--ink); box-shadow: 3px 3px 0 var(--yellow); background: #fff; }
.thankyou-box { background: var(--yellow); border: 2px solid var(--ink); box-shadow: 6px 6px 0 var(--ink); border-radius: 8px; padding: 2.5rem; text-align: center; }
.thankyou-box i { font-size: 3rem; color: var(--ink); }

/* contact info card (legacy interior pages) */
.contact-info-card { background: var(--ink); color: var(--paper); border: 2px solid var(--ink); box-shadow: 8px 8px 0 var(--ink); border-radius: 8px; padding: 2.2rem; height: 100%; }
.contact-info-card h4 { color: var(--paper); }
.contact-info-card a { color: var(--yellow); }
.contact-info-card .ci-icon { width:46px; height:46px; border-radius:8px; background: rgba(245,194,75,.18); color: var(--yellow); display:grid; place-items:center; font-size:1.2rem; flex:none; }
.social-links a { width: 42px; height: 42px; color: #16130f; border: 2px solid #16130f; border-radius: 50%; display: grid; place-items: center; transition: all .2s; }
.site-footer .social-links a { color: var(--paper); }
.site-footer .social-links a:hover { background: var(--yellow); color: var(--ink); border-color: var(--ink); }
.contact-info-card .social-links a { color: var(--paper); }
.contact-info-card .social-links a:hover { background: var(--yellow); color: var(--ink); }

/* ---------- Footer ---------- */
.site-footer { background: var(--ink); color: rgba(242,237,227,.7); padding: 70px 0 0; border-top: 2px solid var(--ink); }
.site-footer h6 { color: var(--paper); font-family: var(--mono); font-weight: 500; text-transform: uppercase; letter-spacing: .12em; font-size: .76rem; margin-bottom: 1.2rem; }
.site-footer img { height: 34px; margin-bottom: 1rem; }
.site-footer .footer-about { filter: none; color: rgba(242,237,227,.7); }
.site-footer ul { list-style: none; padding: 0; margin: 0; }
.site-footer ul li { margin-bottom: .6rem; }
.site-footer a { color: rgba(242,237,227,.7); font-family: var(--mono); font-size: .82rem; letter-spacing: .03em; transition: color .2s, padding-left .2s; }
.site-footer a:hover { color: var(--yellow); padding-left: 4px; }
.footer-bottom { border-top: 1px solid rgba(255,255,255,.12); margin-top: 50px; padding: 22px 0; font-size: .78rem; font-family: var(--mono); letter-spacing: .06em; text-transform: uppercase; color: rgba(242,237,227,.5); }

/* ---------- list-check (services/about) ---------- */
.list-check { list-style: none; padding: 0; margin: 0; }
.list-check li { position: relative; padding-left: 1.9rem; margin-bottom: .7rem; color: var(--text); }
.list-check li::before { content: "\F26E"; font-family: "bootstrap-icons"; position: absolute; left: 0; top: 0; color: var(--ink); font-weight: 700; }

/* chip */
.chip { display:inline-flex; align-items:center; gap:.5rem; background:var(--paper-card); border:2px solid var(--ink); border-radius:50rem; padding:.5rem 1.05rem; font-family: var(--mono); font-size:.74rem; text-transform:uppercase; letter-spacing:.06em; color: var(--ink); margin:.3rem; box-shadow: 2px 2px 0 var(--ink); transition: all .12s; }
.chip:hover { transform: translate(-2px,-2px); box-shadow: 4px 4px 0 var(--ink); }
.chip i { color: var(--ink); }
.filter-chip { cursor:pointer; }
.filter-chip.active { background: var(--yellow); }

/* eyebrow (legacy interior) → pill-like mono */
.eyebrow { display:inline-block; font-family: var(--mono); font-weight:600; font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color: var(--ink); background: var(--yellow); border:2px solid var(--ink); box-shadow:3px 3px 0 var(--ink); border-radius:50rem; padding:.4rem .9rem; margin-bottom:1.2rem; }
.section-title { font-size: clamp(2rem, 4.4vw, 3rem); margin-bottom:.6rem; }
.section-sub { max-width: 680px; margin: 0 auto; font-size: 1.05rem; color: var(--muted); }

/* interior page banner */
.page-hero { background: var(--paper); border-bottom: 2px solid var(--ink); padding: 70px 0 60px; position: relative; }
.page-hero h1 { font-size: clamp(2.6rem, 6vw, 5rem); line-height: 1; }
.page-hero h1 em { font-style: italic; }
.page-hero .breadcrumb { margin:0; font-family: var(--mono); font-size:.74rem; text-transform:uppercase; letter-spacing:.08em; }
.page-hero .breadcrumb a { color: var(--ink); }
.page-hero .breadcrumb-item.active { color: var(--muted); }
.page-hero .breadcrumb-item + .breadcrumb-item::before { color: var(--muted); }

/* service detail blocks */
.service-block { padding: 70px 0; }
.service-block img { border:2px solid var(--ink); border-radius:7px; box-shadow:8px 8px 0 var(--ink); width:100%; height:100%; object-fit:cover; min-height:320px; }
.service-tagline { font-family: var(--serif); font-style: italic; font-weight:500; color: var(--ink); font-size:1.25rem; margin-bottom:.8rem; }
.service-num { font-family: var(--serif); font-weight:700; font-size:3.2rem; line-height:1; }

/* legacy feature/usp cards → nb */
.card { border:2px solid var(--ink); border-radius:7px; box-shadow:6px 6px 0 var(--ink); background: var(--paper-card); transition: transform .14s, box-shadow .14s; }
.feature-card, .usp-card { padding:1.8rem 1.6rem; height:100%; background: var(--paper-card); }
.feature-card:hover, .usp-card:hover, .card:hover { transform: translate(-3px,-3px); box-shadow: 9px 9px 0 var(--ink); }
.feature-icon { width:54px; height:54px; border:2px solid var(--ink); border-radius:10px; box-shadow:2px 2px 0 var(--ink); display:grid; place-items:center; background:var(--yellow); color:var(--ink); font-size:1.4rem; margin-bottom:1.1rem; }
.usp-card h6 { font-family: var(--serif); font-weight:600; color: var(--ink); font-size:1.05rem; }
.feature-card .learn-more { font-family: var(--mono); font-weight:500; text-transform:uppercase; letter-spacing:.08em; color: var(--ink); font-size:.76rem; }
.badge-soft { background: var(--yellow); color: var(--ink); font-family: var(--mono); font-weight:600; font-size:.68rem; letter-spacing:.08em; text-transform:uppercase; border:2px solid var(--ink); border-radius:50rem; padding:.3rem .7rem; }

/* portfolio cards reuse work-card look */
.portfolio-card { position: relative; overflow: hidden; border:2px solid var(--ink); border-radius:7px; box-shadow:6px 6px 0 var(--ink); transition: transform .14s, box-shadow .14s; }
.portfolio-card:hover { transform: translate(-3px,-3px); box-shadow:9px 9px 0 var(--ink); }
.portfolio-card img { width:100%; height:260px; object-fit:cover; transition: transform .4s; }
.portfolio-card:hover img { transform: scale(1.06); }
.portfolio-overlay { position:absolute; inset:0; background: linear-gradient(to top, rgba(22,19,15,.92), rgba(22,19,15,0) 60%); display:flex; flex-direction:column; justify-content:flex-end; padding:1.4rem; opacity:0; transition: opacity .3s; }
.portfolio-card:hover .portfolio-overlay { opacity:1; }
.portfolio-overlay h5 { color:#fff; margin-bottom:.3rem; }

/* stats */
.stat h2 { font-family: var(--serif); color: var(--yellow); font-size: 2.8rem; margin-bottom:.2rem; }
.stat p { color: rgba(242,237,227,.72); margin:0; font-family: var(--mono); font-size:.74rem; text-transform:uppercase; letter-spacing:.1em; }

.text-balance { text-wrap: balance; }

/* ---------- Responsive ---------- */
@media (max-width: 991.98px) {
  .section { padding: 60px 0; }
  .service-block { padding: 44px 0; }
  .hero-meta-grid { grid-template-columns: 1fr; }
  .hero-meta-grid .mi { border-bottom: 1px solid var(--line); }
}
@media (max-width: 575.98px) {
  .nb-card, .form-card { padding: 1.4rem; }
}
