:root {
  --paper: #f1ede3;
  --paper-2: #e8e2d4;
  --ink: #111111;
  --ink-2: #2a2723;
  --muted: #6f6a5e;
  --line: #d9d3c4;
  --brique: #c24a2c;
  --brique-2: #a83b21;
  --violet: #4b2671;
  --acid: #d7ff3a;
  --paper-pure: #fbf8f0;
  --display: "Space Grotesk", ui-sans-serif, system-ui, sans-serif;
  --mono: "JetBrains Mono", ui-monospace, Menlo, monospace;
  --serif: "Instrument Serif", "Times New Roman", serif;
}
* { box-sizing: border-box; }
html, body { margin:0; padding:0; background: var(--paper); color: var(--ink); font-family: var(--display); }
.container { max-width: 1000px; margin: 0 auto; padding: 24px; }
.site-header { border-bottom: 1px solid var(--line); background: linear-gradient(180deg, var(--paper-pure), var(--paper)); }
.site-header .container { display:flex; align-items:center; justify-content:space-between; }
.brand { margin:0; font-weight:700; letter-spacing:1px; }
.nav a { margin-left:16px; color:var(--ink-2); text-decoration:none; }
.hero { padding:64px 0; }
.hero-title { font-size:36px; margin:0 0 8px 0; }
.hero-sub { margin:0; color:var(--muted); }
.services .grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:16px; margin-top:16px; }
.card { background:var(--paper-pure); border:1px solid var(--line); padding:20px; border-radius:6px; }
.portfolio-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:14px; margin-top:12px; }
.portfolio-card { display:block; text-decoration:none; color:var(--ink-2); border:1px solid var(--line); background:var(--paper-pure); border-radius:8px; overflow:hidden; }
.portfolio-card .thumb { height:110px; background:linear-gradient(90deg,var(--paper-2),var(--paper)); display:flex; align-items:center; justify-content:center; color:var(--muted); font-weight:600; }
.portfolio-card .meta { padding:12px; font-size:14px; }
.contact label { display:block; margin-bottom:12px; }
.contact input[type="text"], .contact input[type="email"], .contact textarea { width:100%; padding:10px; border:1px solid var(--line); border-radius:4px; background:white; }
.contact button { background:var(--brique); color:white; border:none; padding:12px 18px; border-radius:6px; cursor:pointer; }
.site-footer { border-top:1px solid var(--line); padding:16px 0; margin-top:40px; background:transparent; }
.mono { font-family: var(--mono); }
.serif-it { font-family: var(--serif); font-style: italic; }

@media (max-width:600px){
  .hero-title{ font-size:28px; }
  .site-header .container{ padding:12px; }
}

/* Additional landing styles */
.site-root { background: var(--paper); color: var(--ink); }
.site-width { max-width: 1200px; margin: 0 auto; }
.nav-main { display:flex; align-items:center; justify-content:space-between; padding:22px 32px; border-bottom:1px solid var(--line); position:sticky; top:0; background:var(--paper); z-index:20; }
.nav-left { display:flex; align-items:baseline; gap:8px; }
.brand-large { font-weight:700; font-size:28px; }
.brand-fn { font-family:var(--mono); font-size:16px; color:var(--brique); }
.nav-center { display:flex; gap:28px; font-weight:500; }
.nav-center a { color:var(--ink); text-decoration:none; cursor:pointer; }
.nav-right { display:flex; align-items:center; gap:16px; }
.notice { font-family:var(--mono); font-size:12px; color:var(--muted); display:flex; align-items:center; gap:8px; }
.notice .dot { width:7px; height:7px; border-radius:50%; background:#1F8A4A; display:inline-block; }
.btn-primary { background:var(--ink); color:var(--paper); border:0; padding:12px 18px; border-radius:6px; cursor:pointer; font-weight:500; }
.btn-outline { background:transparent; color:var(--ink); border:1px solid var(--ink); padding:12px 18px; border-radius:6px; cursor:pointer; }
.hero-landing { padding:96px 32px 64px; background:var(--paper); }
.meta-row { font-family:var(--mono); font-size:12px; color:var(--muted); margin-bottom:36px; display:flex; gap:22px; }
.hero-h1 { font-size:128px; line-height:0.92; margin:0; font-weight:700; max-width:1100px; }
.hero-accent { font-family:var(--serif); font-style:italic; color:var(--brique); font-weight:400; }
.hero-cta { margin-top:56px; display:grid; grid-template-columns:1.2fr 1fr; gap:48px; align-items:end; }
.hero-copy { font-size:20px; color:var(--ink-2); margin:0; }
.hero-actions { display:flex; gap:12px; justify-content:flex-end; }
.hero-stats { margin-top:56px; border-top:1px solid var(--line); border-bottom:1px solid var(--line); display:grid; grid-template-columns:repeat(4,1fr); }
.stat-num { font-size:48px; font-weight:600; }
.stat-desc { font-family:var(--mono); font-size:12px; color:var(--muted); margin-top:8px; }
.code-strip { display:flex; align-items:center; justify-content:space-between; gap:24px; padding:44px 32px; background:var(--ink); color:var(--paper); }
.code-strip code { font-family:var(--mono); color:#D7FF3A; }
.code-quote { font-family:var(--serif); font-style:italic; font-size:28px; max-width:420px; text-align:right; }
.services-section { padding:120px 32px; background:var(--paper); }
.services-head, .section-head { display:flex; justify-content:space-between; align-items:baseline; margin-bottom:64px; }
.kicker { font-family:var(--mono); font-size:12px; color:var(--muted); }
.section-title { font-size:64px; font-weight:700; margin:12px 0 0; line-height:0.95; }
.dot-accent { font-size:0; }
.dot-accent::before { content:'🧱'; font-size:44px; line-height:1; }
.services-intro, .section-intro { max-width:460px; color:var(--ink-2); }
.services-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:40px; }
.service-card { background:transparent; border-top:2px solid var(--ink); padding-top:22px; }
.service-meta { display:flex; justify-content:space-between; font-family:var(--mono); font-size:12px; color:var(--muted); margin-bottom:12px; }
.service-card h3 { font-size:34px; margin:0 0 8px 0; }
.studio-section, .journal-section { padding:100px 32px; background:var(--paper-2); }
.studio-grid, .journal-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:24px; }
.studio-card, .journal-card { background:var(--paper-pure); border:1px solid var(--line); padding:30px; min-height:220px; }
.studio-card h3, .journal-card h3 { font-size:28px; margin:0 0 16px 0; }
.studio-card p, .journal-card p { margin:0; font-size:16px; line-height:1.7; color:var(--ink-2); }

.portfolio-section { padding:120px 32px; background:var(--paper-2); }
.portfolio-head { display:flex; justify-content:space-between; align-items:baseline; margin-bottom:56px; }
.filters { display:flex; gap:8px; }
.filter { padding:8px 14px; border:1px solid var(--line); cursor:pointer; }
.filter.active { background:var(--ink); color:var(--paper); border:0; }
.portfolio-grid-wide { display:grid; grid-template-columns:1.4fr 1fr; gap:24px; }
.portfolio-large,
.portfolio-small { display:block; position:relative; background:var(--paper-pure); border:1px solid var(--line); text-decoration:none; color:var(--ink); overflow:hidden; box-shadow:0 18px 50px rgba(0,0,0,0.08); transform:translateZ(0); transition: transform 220ms ease, box-shadow 220ms ease, border-color 220ms ease; }
.portfolio-large { grid-row: span 2; min-height:520px; }
.portfolio-small { min-height:300px; }
.portfolio-large:hover,
.portfolio-small:hover { border-color: transparent; box-shadow:0 30px 70px rgba(0,0,0,0.12); transform: translateY(-6px); }
.portfolio-img-wrap { position:relative; overflow:hidden; }
.portfolio-img-wrap::after { content:''; position:absolute; inset:0; background:linear-gradient(to bottom, transparent 40%, rgba(0,0,0,0.28) 100%); pointer-events:none; }
.portfolio-image { width:100%; height:100%; object-fit:cover; display:block; }
.portfolio-large:hover .portfolio-img-wrap::after,
.portfolio-small:hover .portfolio-img-wrap::after { background:linear-gradient(to bottom, transparent 30%, rgba(0,0,0,0.38) 100%); }
.portfolio-details { padding:18px 22px; }
.portfolio-tag { font-family:var(--mono); font-size:12px; color:var(--muted); margin-bottom:12px; }
.portfolio-title { font-size:24px; font-weight:600; margin-bottom:8px; }
.portfolio-client { font-family:var(--mono); font-size:12px; color:var(--muted); }.hidden { display:none !important; }

.process-section { padding:80px 32px; background:var(--ink); color:var(--paper); }
.process-head { margin-bottom:40px; }
.process-steps { display:grid; grid-template-columns:repeat(5,1fr); gap:8px; }
.step { background:var(--ink); padding:28px; }
.step-num { font-family:var(--mono); color:var(--brique); margin-bottom:12px; }
.step-title { font-size:24px; font-weight:600; }
.step-desc { color:#aaa9a4; }

.testimonials-section { padding:100px 32px; background:var(--paper-2); }
.test-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.test-card { background:var(--paper-pure); border:1px solid var(--line); padding:32px; min-height:280px; display:flex; flex-direction:column; justify-content:space-between; }
.test-author { margin-top:18px; font-weight:600; }

.faq-section { padding:120px 32px; background:var(--paper); }
.faq-grid { display:grid; grid-template-columns:1fr 1.4fr; gap:80px; }
.faq-item { border-top:1px solid var(--ink); padding:26px 0; }

.contact-cta { padding:120px 32px; background:var(--brique); color:var(--paper); display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:start; }
.contact-cta .kicker { color: rgba(251, 248, 240, 0.9); }
.cta-title { font-size:88px; line-height:0.95; margin:0 0 18px 0; }
.cta-copy { color: rgba(251, 248, 240, 0.95); max-width: 640px; }
.cta-right { display:flex; flex-direction:column; gap:16px; }
.cta-link { display:block; color:var(--paper); text-decoration:underline; margin-bottom:0; }
.cta-right .btn-primary { margin-top: 12px; }

.form-section { padding:80px 32px; background:var(--paper); }
.form-section h3 { font-size:28px; }
.form-section form label { display:block; margin-bottom:12px; }
.form-section input, .form-section textarea { width:100%; padding:10px; border:1px solid var(--line); border-radius:4px; }

.site-footer-large { padding:56px 32px 36px; background:var(--ink); color:var(--paper); }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:40px; }
.brand-foot { font-weight:700; font-size:36px; }
.brand-tag { font-family:var(--serif); font-style:italic; opacity:0.85; margin-top:8px; }
.footer-col-title { font-family:var(--mono); font-size:12px; color:#aaa9a4; margin-bottom:8px; }
.footer-links { display:flex; flex-wrap:wrap; gap:6px; font-size:14px; }
.footer-links a { color: var(--paper); text-decoration:none; }
.footer-links a:hover { text-decoration:underline; }
.footer-bottom { margin-top:56px; padding-top:22px; border-top:1px solid #2a2723; font-family:var(--mono); font-size:11px; color:#aaa9a4; }

@media (max-width:900px){
  .hero-h1 { font-size:56px; }
  .portfolio-grid-wide { grid-template-columns:1fr; }
  .portfolio-large { grid-row:auto; }
  .process-steps { grid-template-columns:repeat(2,1fr); }
  .nav-center { display:none; }
  .footer-grid { grid-template-columns:1fr 1fr; }
  .services-grid { grid-template-columns:1fr; }
  .test-grid { grid-template-columns:1fr 1fr; }
  .faq-grid { grid-template-columns:1fr; gap:0; }
  .contact-cta { grid-template-columns:1fr; gap:32px; }
  .cta-title { font-size:56px; }
  .hero-cta { grid-template-columns:1fr; gap:24px; }
  .hero-actions { justify-content:flex-start; }
  .hero-stats { grid-template-columns:repeat(2,1fr); }
  .studio-grid, .journal-grid { grid-template-columns:1fr; }
  .section-title { font-size:48px; }
  .dot-accent::before { font-size:32px; }
}

@media (max-width:600px){
  .nav-main { padding:16px 20px; }
  .notice { display:none; }
  .hero-landing { padding:56px 20px 40px; }
  .hero-h1 { font-size:38px; }
  .meta-row { flex-wrap:wrap; gap:10px; }
  .hero-cta { margin-top:32px; }
  .hero-copy { font-size:16px; }
  .hero-stats { margin-top:32px; }
  .stat-num { font-size:32px; }
  .code-strip { flex-direction:column; align-items:flex-start; padding:28px 20px; gap:16px; }
  .code-quote { text-align:left; font-size:20px; }
  .services-section, .portfolio-section, .faq-section, .testimonials-section { padding:64px 20px; }
  .studio-section, .journal-section { padding:64px 20px; }
  .services-head, .section-head, .portfolio-head { flex-direction:column; gap:16px; margin-bottom:36px; }
  .services-intro, .section-intro { max-width:100%; }
  .section-title { font-size:36px; }
  .dot-accent::before { font-size:26px; }
  .service-card h3 { font-size:24px; }
  .filters { flex-wrap:wrap; }
  .process-section { padding:64px 20px; }
  .process-steps { grid-template-columns:1fr; }
  .test-grid { grid-template-columns:1fr; }
  .contact-cta { padding:64px 20px; }
  .cta-title { font-size:40px; }
  .form-section { padding:48px 20px; }
  .footer-grid { grid-template-columns:1fr; }
  .site-footer-large { padding:40px 20px 24px; }
  .footer-bottom { margin-top:32px; }
}

