/* =========================================================
   FICUS — shared stylesheet (v5: red field / blue type / editorial cool)
   Palette: RED background, BLUE primary text, white + ink accents
   Type: Inter Black display, Fraunces italic accents, Space Mono labels
   Layout: top nav, magazine grid, sharp edges, photos float natural
   ========================================================= */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;700;800;900&family=Fraunces:ital,wght@1,400;1,600;1,700;1,900&family=Space+Mono:wght@400;700&display=swap');

:root {
  --red:    #E10600;
  --red-2:  #B30500;
  --red-3:  #FF1A1A;
  --blue:   #1D3FFF;
  --blue-2: #0A2C9E;

  --white:  #FFFFFF;
  --ink:    #0E0E10;
  --muted:  rgba(29,63,255,.55);

  --display: 'Inter', system-ui, sans-serif;
  --body:    'Inter', system-ui, sans-serif;
  --italic:  'Fraunces', Georgia, serif;
  --mono:    'Space Mono', ui-monospace, monospace;

  --maxw: 1280px;
  --nav-h: 64px;
}

* { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  background: var(--ink);
  color: var(--white);
  font-family: var(--body);
  font-size: 16px;
  font-weight: 400;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

::selection { background: var(--blue); color: var(--red); }

main, header, footer, section, aside { position: relative; }

a { color: inherit; }
img { max-width: 100%; display: block; }

/* ---------- Typography ---------- */
h1, h2, h3, h4 {
  font-family: var(--display);
  font-weight: 900;
  letter-spacing: -.035em;
  line-height: .9;
  margin: 0 0 .35em;
  color: var(--blue);
  text-transform: uppercase;
}
h1 { font-size: clamp(3rem, 8vw, 6.5rem); }
h2 { font-size: clamp(1.8rem, 4vw, 3.4rem); }
h3 { font-size: clamp(1.1rem, 1.6vw, 1.4rem); font-weight: 800; letter-spacing: -.01em; }
h4 { font-size: .9rem; font-family: var(--mono); font-weight: 400; letter-spacing: .14em; text-transform: uppercase; color: var(--blue); }

p { margin: 0 0 1em; max-width: 64ch; }
em, .italic { font-family: var(--italic); font-style: italic; font-weight: 600; letter-spacing: -.01em; }

.mono { font-family: var(--mono); }
.white { color: var(--white); }
.red { color: var(--red); }
.blue { color: var(--blue); }
.ink { color: var(--ink); }

.eyebrow {
  font-family: var(--mono);
  font-size: .72rem;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--blue);
  margin-bottom: 1rem;
  display: inline-flex;
  align-items: center;
  gap: .55rem;
}
.eyebrow::before {
  content: "";
  width: 28px; height: 1px;
  background: var(--blue);
  display: inline-block;
}

/* ---------- Layout helpers ---------- */
.wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 1.5rem; }
.section { padding: 5rem 0; position: relative; }
.section.tight { padding: 3rem 0; }
.section.invert { background: var(--blue); color: var(--red); }
.section.invert h1, .section.invert h2, .section.invert h3, .section.invert h4, .section.invert .eyebrow { color: var(--red); }
.section.invert .eyebrow::before { background: var(--red); }
.section.invert p { color: var(--white); }
.section.white-bg { background: var(--white); }
.section.ink-bg { background: var(--ink); color: var(--white); }
.section.ink-bg h1, .section.ink-bg h2, .section.ink-bg h3 { color: var(--white); }

.rule { height: 1px; background: var(--blue); margin: 0; border: 0; }
.rule.thick { height: 3px; }

/* ---------- TOP NAV ---------- */
.site-nav {
  position: sticky;
  top: 0;
  z-index: 100;
  background: var(--ink);
  border-bottom: 2px solid var(--blue);
  display: flex;
  align-items: center;
  gap: 1.5rem;
  padding: .8rem 1.5rem;
  min-height: var(--nav-h);
}
.site-nav .logo {
  display: inline-flex;
  align-items: baseline;
  gap: .5rem;
  text-decoration: none;
  color: var(--blue);
  margin-right: auto;
  font-family: var(--display);
  font-weight: 900;
  font-size: 1.6rem;
  letter-spacing: -.04em;
  line-height: 1;
}
.site-nav .logo .italic {
  font-family: var(--italic);
  font-style: italic;
  font-weight: 700;
  font-size: .85rem;
  letter-spacing: 0;
  color: var(--blue);
}
.site-nav .nav {
  display: flex;
  gap: 1.5rem;
  font-family: var(--mono);
  font-size: .78rem;
  letter-spacing: .14em;
  text-transform: uppercase;
}
.site-nav .nav a {
  position: relative;
  color: var(--blue);
  text-decoration: none;
  padding: .25rem 0;
  transition: color .12s;
}
.site-nav .nav a:hover { color: var(--white); }
.site-nav .nav a.is-active::after {
  content: "";
  position: absolute;
  inset: auto 0 -3px 0;
  height: 3px;
  background: var(--blue);
}
.site-nav .cta {
  background: var(--blue);
  color: var(--red);
  padding: .7rem 1rem;
  text-decoration: none;
  font-family: var(--mono);
  font-size: .76rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  font-weight: 700;
  border: 0;
  transition: background .15s, color .15s;
}
.site-nav .cta:hover { background: var(--ink); color: var(--white); }

.nav-toggle {
  display: none;
  background: var(--blue);
  color: var(--red);
  border: 0;
  font-family: var(--mono);
  font-size: .75rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  font-weight: 700;
  padding: .6rem .85rem;
  cursor: pointer;
}

@media (max-width: 900px) {
  .site-nav { flex-wrap: wrap; gap: 1rem; }
  .site-nav .cta { display: none; }
  .nav-toggle { display: inline-block; order: 3; }
  .site-nav .nav {
    display: none;
    order: 4;
    flex-direction: column;
    gap: .9rem;
    width: 100%;
    padding-top: .8rem;
    border-top: 1px solid var(--blue);
  }
  .site-nav .nav.is-open { display: flex; }
  .site-nav .nav a.is-active::after { display: none; }
  .site-nav .nav a.is-active { color: var(--white); }
}

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  font-family: var(--mono);
  text-transform: uppercase;
  letter-spacing: .14em;
  font-size: .78rem;
  font-weight: 700;
  text-decoration: none;
  padding: .9rem 1.4rem;
  background: var(--blue);
  color: var(--red);
  border: 2px solid var(--blue);
  cursor: pointer;
  transition: transform .12s, background .15s, color .15s, border-color .15s;
}
.btn:hover { background: var(--white); color: var(--blue); border-color: var(--white); }
.btn.ghost { background: transparent; color: var(--blue); border-color: var(--blue); }
.btn.ghost:hover { background: var(--blue); color: var(--red); }
.btn.white { background: var(--white); color: var(--red); border-color: var(--white); }
.btn.white:hover { background: var(--blue); color: var(--red); border-color: var(--blue); }
.btn.red { background: var(--red); color: var(--blue); border-color: var(--blue); }
.btn.red:hover { background: var(--blue); color: var(--red); }
.btn.sm { font-size: .7rem; padding: .65rem 1rem; }

/* ---------- Marquee ---------- */
.marquee {
  font-family: var(--display);
  font-weight: 900;
  font-size: clamp(2rem, 6vw, 5rem);
  background: var(--red);
  color: var(--blue);
  letter-spacing: -.03em;
  white-space: nowrap;
  overflow: hidden;
  line-height: 1;
  padding: .25em 0;
  border-block: 2px solid var(--blue);
  text-transform: uppercase;
}
.marquee.invert { background: var(--blue); color: var(--red); }
.marquee.ink    { background: var(--ink); color: var(--red); }
.marquee.white  { background: var(--white); color: var(--red); }
.marquee span {
  display: inline-block;
  animation: marquee 28s linear infinite;
  padding-left: 100%;
}
@keyframes marquee { from { transform: translateX(0); } to { transform: translateX(-100%); } }

/* Legacy aliases so older markup still works during transition */
.hash-row, .wave-marquee, .marquee-row { font-family: var(--display); font-weight: 900; font-size: clamp(2rem, 6vw, 5rem); background: var(--ink); color: var(--red); letter-spacing: -.03em; white-space: nowrap; overflow: hidden; line-height: 1; padding: .25em 0; border-block: 2px solid var(--blue); text-transform: uppercase; }
.hash-row span, .wave-marquee span, .marquee-row span { display: inline-block; animation: marquee 28s linear infinite; padding-left: 100%; }
.hash-row.blue, .marquee-row.blue, .wave-marquee.blue { background: var(--blue); color: var(--red); }
.hash-row.ink, .marquee-row.ink, .wave-marquee.ink { background: var(--ink); color: var(--red); }

/* ---------- Grids ---------- */
.grid { display: grid; gap: 1.5rem; }
.grid.cols-2 { grid-template-columns: repeat(2, 1fr); }
.grid.cols-3 { grid-template-columns: repeat(3, 1fr); }
.grid.cols-4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 880px) {
  .grid.cols-2, .grid.cols-3, .grid.cols-4 { grid-template-columns: 1fr; }
}

/* ---------- Editorial blocks (replace cards) ---------- */
.block {
  border-top: 2px solid var(--blue);
  padding-top: 1rem;
  color: var(--blue);
}
.block .num {
  font-family: var(--mono);
  font-weight: 700;
  font-size: .72rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--blue);
  display: block;
  margin-bottom: .4rem;
}
.block h3 { color: var(--blue); margin-bottom: .4rem; }
.block p { color: var(--white); font-size: .92rem; max-width: 36ch; }

/* Legacy card alias — restyled for new theme */
.card {
  background: transparent;
  border: 0;
  border-top: 2px solid var(--blue);
  padding: 1rem 0 0;
  position: relative;
  color: var(--blue);
}
.card.blue, .card.red, .card.ink { color: var(--white); }
.card .when {
  font-family: var(--mono);
  font-size: .72rem;
  color: var(--blue);
  letter-spacing: .14em;
  text-transform: uppercase;
}
.card.blue .when, .card.red .when, .card.ink .when { color: var(--white); }
.card h3 { margin: .45rem 0 .3rem; }
.card p { font-size: .92rem; color: var(--white); }
.card.blue p, .card.red p, .card.ink p { color: var(--white); }
.card .meta {
  font-family: var(--mono);
  font-size: .72rem;
  color: rgba(255,255,255,.6);
  letter-spacing: .08em;
  text-transform: uppercase;
  margin-top: .55rem;
}

/* ---------- Hero ---------- */
.hero {
  padding: 4rem 0 4rem;
  position: relative;
  overflow: hidden;
}
.hero .wrap { display: grid; grid-template-columns: 1.4fr .9fr; gap: 3rem; align-items: end; }
@media (max-width: 980px) { .hero .wrap { grid-template-columns: 1fr; } }

.hero .wordmark {
  font-family: var(--display);
  font-weight: 900;
  font-size: clamp(5rem, 18vw, 14rem);
  line-height: .82;
  letter-spacing: -.06em;
  color: var(--blue);
  margin: 0 0 .15em;
  text-transform: uppercase;
}
.hero .wordmark .italic {
  font-family: var(--italic);
  font-style: italic;
  font-weight: 900;
  letter-spacing: -.04em;
}
.hero .tagline {
  font-family: var(--italic);
  font-style: italic;
  font-weight: 700;
  font-size: clamp(1.4rem, 3vw, 2.4rem);
  line-height: 1.05;
  color: var(--blue);
  margin: 0 0 1.4rem;
  letter-spacing: -.01em;
  max-width: 20ch;
}
.hero .lede {
  font-family: var(--body);
  font-weight: 500;
  font-size: 1rem;
  max-width: 44ch;
  line-height: 1.55;
  margin-bottom: 1.6rem;
  color: var(--blue);
}
.hero .ctas { display: flex; gap: .7rem; flex-wrap: wrap; }

/* ---------- Image holders ---------- */
.img-frame {
  position: relative;
  border: 0;
  background: var(--ink);
  overflow: hidden;
}
.img-frame img { width: 100%; height: 100%; object-fit: cover; display: block; }
.img-frame.tilt-l { transform: rotate(-1.4deg); }
.img-frame.tilt-r { transform: rotate(1.2deg); }
.img-frame.outline { outline: 2px solid var(--blue); outline-offset: -2px; }

/* ---------- Footer ---------- */
.site-footer {
  background: var(--ink);
  color: var(--white);
  padding: 4rem 0 1.5rem;
  margin-top: 5rem;
  border-top: 2px solid var(--blue);
}
.site-footer h4 { color: var(--red); font-size: .92rem; }
.site-footer a { color: var(--blue); text-decoration: none; }
.site-footer a:hover { color: var(--white); }
.site-footer .wrap > .grid { gap: 2rem; }
.site-footer ul { list-style: none; padding: 0; margin: 0; font-family: var(--mono); font-size: .82rem; line-height: 1.95; }
.site-footer p { color: var(--white); }
.site-footer .colophon {
  margin-top: 2.5rem;
  border-top: 1px solid rgba(29,63,255,.3);
  padding-top: 1.2rem;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  font-family: var(--mono);
  font-size: .7rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--blue);
}

/* ---------- Instagram strip ---------- */
.ig-strip { display: grid; grid-template-columns: repeat(6, 1fr); gap: 2px; }
@media (max-width: 880px) { .ig-strip { grid-template-columns: repeat(3, 1fr); } }
.ig-strip .ig {
  aspect-ratio: 1/1;
  background: var(--ink);
  position: relative;
  overflow: hidden;
}
.ig-strip .ig img { width: 100%; height: 100%; object-fit: cover; }
.ig-strip .ig::after {
  content: "@ficus";
  position: absolute;
  inset: auto 0 0 0;
  padding: .35rem .45rem;
  font-family: var(--mono);
  font-size: .6rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--white);
  background: linear-gradient(180deg, transparent, rgba(0,0,0,.7));
}

/* ---------- Page title strip ---------- */
.page-title {
  padding: 4rem 0 2.4rem;
  background: var(--ink);
  border-bottom: 2px solid var(--blue);
  position: relative;
}
.page-title h1 { margin: 0; color: var(--blue); font-size: clamp(3rem, 9vw, 6rem); }
.page-title h1 em, .page-title h1 .italic { font-family: var(--italic); font-style: italic; font-weight: 900; }
.page-title .crumbs {
  font-family: var(--mono);
  font-size: .72rem;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--blue);
  margin-bottom: .9rem;
  display: inline-flex; align-items: center; gap: .5rem;
}
.page-title .crumbs::before { content: ""; width: 28px; height: 1px; background: var(--blue); }

/* ---------- Pricing ---------- */
.price-card {
  background: transparent;
  border: 2px solid var(--blue);
  padding: 1.8rem 1.4rem;
  position: relative;
  color: var(--white);
}
.price-card.feat { background: var(--blue); color: var(--red); }
.price-card.feat h3, .price-card.feat .num { color: var(--red); }
.price-card.feat li { border-color: rgba(225,6,0,.3); color: var(--red); }
.price-card h3 { color: var(--blue); }
.price-card .num {
  font-family: var(--display);
  font-weight: 900;
  font-size: 3.2rem;
  line-height: 1;
  color: var(--blue);
  letter-spacing: -.04em;
}
.price-card .num small { font-family: var(--mono); font-size: .8rem; color: var(--blue); letter-spacing: .14em; font-weight: 400; }
.price-card ul { padding: 0; margin: 1rem 0; list-style: none; }
.price-card li {
  font-family: var(--mono);
  font-size: .82rem;
  padding: .4rem 0;
  border-bottom: 1px dashed rgba(29,63,255,.3);
  color: var(--white);
}
.price-card.feat .num { color: var(--red); }
.price-card .sticker { position: absolute; top: -12px; right: 12px; }

/* ---------- Stickers ---------- */
.sticker {
  display: inline-block;
  padding: .4rem .8rem;
  font-family: var(--mono);
  font-size: .68rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  font-weight: 700;
  background: var(--blue);
  color: var(--red);
  border: 0;
}
.sticker.red    { background: var(--red); color: var(--blue); border: 2px solid var(--blue); }
.sticker.white  { background: var(--white); color: var(--red); }
.sticker.ink    { background: var(--ink); color: var(--red); }

/* ---------- Gallery (kept structure, restyled) ---------- */
.gallery-hero {
  position: relative;
  background: var(--ink);
  overflow: hidden;
  aspect-ratio: 16/7;
  margin-bottom: 6px;
}
.gallery-hero img { width:100%; height:100%; object-fit: cover; display: block; }
.gallery-hero .caption {
  position: absolute;
  left: 14px; bottom: 14px;
  display: inline-flex; align-items: center; gap: .5rem;
  background: var(--blue);
  color: var(--red);
  font-family: var(--mono);
  font-size: .72rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  font-weight: 700;
  padding: .5rem .75rem;
}

.gallery {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  grid-auto-rows: 180px;
  gap: 6px;
}
.gallery figure {
  margin: 0;
  position: relative;
  background: var(--ink);
  overflow: hidden;
}
.gallery figure img { width:100%; height:100%; object-fit: cover; display: block; transition: transform .4s ease; }
.gallery figure:hover img { transform: scale(1.04); }
.gallery .g-2x2 { grid-column: span 3; grid-row: span 2; }
.gallery .g-2x1 { grid-column: span 3; grid-row: span 1; }
.gallery .g-1x2 { grid-column: span 2; grid-row: span 2; }
.gallery .g-1x1 { grid-column: span 2; grid-row: span 1; }
.gallery figcaption {
  position: absolute;
  left: 8px; bottom: 8px;
  background: var(--blue);
  color: var(--red);
  font-family: var(--mono);
  font-size: .64rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  font-weight: 700;
  padding: .35rem .6rem;
  max-width: calc(100% - 16px);
}
.gallery figcaption.red { background: var(--red); color: var(--blue); }
.gallery figcaption.ink { background: var(--ink); color: var(--red); }
.gallery .g-placeholder {
  display: grid;
  place-items: center;
  background: repeating-linear-gradient(45deg, var(--red-2) 0 14px, var(--red) 14px 28px);
  font-family: var(--mono);
  font-size: .75rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--blue);
  text-align: center;
  padding: 1rem;
}

@media (max-width: 980px) {
  .gallery { grid-template-columns: repeat(4, 1fr); grid-auto-rows: 150px; }
  .gallery .g-2x2 { grid-column: span 2; grid-row: span 2; }
  .gallery .g-2x1 { grid-column: span 2; }
  .gallery .g-1x2 { grid-column: span 2; grid-row: span 2; }
  .gallery .g-1x1 { grid-column: span 2; }
}
@media (max-width: 600px) {
  .gallery { grid-template-columns: repeat(2, 1fr); grid-auto-rows: 160px; }
  .gallery .g-2x2, .gallery .g-2x1, .gallery .g-1x2, .gallery .g-1x1 { grid-column: span 2; grid-row: span 1; }
  .gallery .g-2x2 { grid-row: span 2; }
}

/* ---------- Forms ---------- */
.form { display: grid; gap: .9rem; max-width: 640px; }
.form label {
  display: block;
  font-family: var(--mono);
  font-size: .72rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--white);
  margin-bottom: .25rem;
}
.form input, .form textarea, .form select {
  width: 100%;
  border: 2px solid var(--blue);
  background: transparent;
  padding: .8rem .9rem;
  font-family: var(--body);
  font-size: 1rem;
  color: var(--white);
}
.form input::placeholder, .form textarea::placeholder { color: rgba(255,255,255,.5); }
.form textarea { min-height: 150px; resize: vertical; }
.form input:focus, .form textarea:focus, .form select:focus { outline: 2px solid var(--white); outline-offset: 0; background: var(--red-2); }

/* ---------- Stat row ---------- */
.stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; border-block: 2px solid var(--blue); }
@media (max-width: 880px) { .stats { grid-template-columns: repeat(2, 1fr); } }
.stats .stat { padding: 1.4rem 1rem; border-right: 1px solid rgba(29,63,255,.3); }
.stats .stat:last-child { border-right: 0; }
@media (max-width: 880px) {
  .stats .stat:nth-child(odd) { border-right: 1px solid rgba(29,63,255,.3); }
  .stats .stat:nth-child(2n) { border-right: 0; }
}
.stats .stat .n {
  font-family: var(--display);
  font-weight: 900;
  font-size: 2.6rem;
  line-height: 1;
  color: var(--blue);
  letter-spacing: -.04em;
}
.stats .stat .l {
  font-family: var(--mono);
  font-size: .68rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--blue);
  margin-top: .4rem;
}

/* ---------- Sidebar / mobile-bar — hide (legacy markup, replaced by top nav) ---------- */
.site-sidebar, .sidebar-overlay, .mobile-bar { display: none !important; }

/* ---------- Misc utility ---------- */
.center { text-align: center; }
.flex { display: flex; gap: 1rem; flex-wrap: wrap; align-items: center; }
.flex.between { justify-content: space-between; }
.dim { color: rgba(29,63,255,.6); }
.uc { text-transform: uppercase; letter-spacing: .12em; font-family: var(--mono); font-size: .78rem; color: var(--blue); }
.rotate-l { transform: rotate(-1.5deg); }
.rotate-r { transform: rotate(1.5deg); }
