/* ==========================================================================
   MadeBySarz — Prototype Aesthetic v1
   Foundation inspired by your planning image:
   - deep charcoal canvas
   - thin hairline borders
   - framed panels + grid rhythm
   - bold, spaced typography
   - circular arrow buttons
   - subtle glow + micro-lifts
   ========================================================================== */

/* ------------------------------- Reset ---------------------------------- */
*,
*::before,
*::after { box-sizing: border-box; }

html, body { height: 100%; }

body {
  margin: 0;
  font-family: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont,
    "SF Pro Text", "Segoe UI", Roboto, Arial, sans-serif;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  color: var(--ink);
  background: var(--bg);
}

img, svg, video { max-width: 100%; display: block; }
button, input, select, textarea { font: inherit; }
a { color: inherit; text-decoration: none; }
:focus-visible { outline: 3px solid rgba(255,255,255,0.26); outline-offset: 2px; }

/* ------------------------------ Tokens ---------------------------------- */
:root{
  --container: 1180px;
  --gutter: 22px;

  --r-sm: 12px;
  --r-md: 16px;
  --r-lg: 22px;
  --r-xl: 28px;
  --r-2xl: 34px;
  --r-pill: 999px;

  --ease: cubic-bezier(.2,.8,.2,1);
  --dur-1: 120ms;
  --dur-2: 180ms;
  --dur-3: 260ms;
  --dur-4: 420ms;

  --bg0: #070707;
  --bg1: #0a0a0a;
  --bg2: #0f0f0f;

  --ink: rgba(255,255,255,0.92);
  --muted: rgba(255,255,255,0.62);
  --faint: rgba(255,255,255,0.44);

  --hair: rgba(255,255,255,0.08);
  --hair2: rgba(255,255,255,0.12);

  --panel: rgba(255,255,255,0.03);
  --panel2: rgba(255,255,255,0.05);

  --accent: rgba(255,255,255,0.92); /* keep monochrome like the reference */
  --shadow-1: 0 18px 50px rgba(0,0,0,0.45);
  --shadow-2: 0 30px 90px rgba(0,0,0,0.62);

  --bg:
    radial-gradient(1200px 700px at 22% 8%, rgba(255,255,255,0.06), transparent 60%),
    radial-gradient(900px 580px at 84% 20%, rgba(255,255,255,0.04), transparent 62%),
    linear-gradient(180deg, var(--bg0) 0%, var(--bg1) 40%, var(--bg2) 100%);
}

/* Optional cross-page view transitions (supported browsers) */
@view-transition { navigation: auto; }

/* ----------------------------- Layout ----------------------------------- */
.container{
  width: min(var(--container), calc(100% - (var(--gutter) * 2)));
  margin: 0 auto;
}

.section{ padding: 78px 0; }
.section--tight{ padding: 52px 0; }
.section--flush{ padding-top: 28px; }

/* Subtle micro-grid like the planning image */
.gridlines{
  position: fixed;
  inset: 0;
  pointer-events: none;
  opacity: 0.42;
  z-index: 0;
  background:
    linear-gradient(to right, rgba(255,255,255,0.045) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,0.045) 1px, transparent 1px);
  background-size: 140px 140px;
  mask-image: radial-gradient(900px 600px at 50% 16%, black, transparent 70%);
}

/* Cursor glow (very subtle, monochrome) */
.cursor-glow{
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 1;
  background: radial-gradient(260px 260px at 50% 50%, rgba(255,255,255,0.10), rgba(255,255,255,0.05), transparent 72%);
  transform: translate3d(-9999px,-9999px,0);
  opacity: 0.75;
  mix-blend-mode: screen;
}

/* ----------------------------- Header / Nav ----------------------------- */
.site-header{
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(7,7,7,0.68);
  border-bottom: 1px solid var(--hair);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.site-header__inner{
  display: grid;
  grid-template-columns: 1fr auto 1fr; /* brand | centred nav | toggle (or spacer) */
  align-items: center;
  gap: 14px;
  padding: 14px 0;
}

.brand{
  display:flex;
  align-items:center;
  gap: 12px;
  min-width: 260px;
}

.brand__mark{
  width: 42px;
  height: 42px;
  border-radius: 14px;
  display:grid;
  place-items:center;
  font-weight: 950;
  letter-spacing: 0.06em;
  border: 1px solid var(--hair2);
  background: rgba(255,255,255,0.04);
  box-shadow: var(--shadow-1);
}

.brand__name{ font-weight: 950; font-size: 0.98rem; line-height: 1.1; }
.brand__tag{ font-size: 0.82rem; color: var(--muted); margin-top: 2px; }

.site-nav{
  /* Minimal pill nav (desktop) */
  display:inline-flex;
  gap: 4px;
  align-items:center;
  padding: 6px;
  border-radius: var(--r-pill);
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(255,255,255,0.03);
  box-shadow: 0 14px 46px rgba(0,0,0,0.40);
}

.nav-link{
  font-weight: 900;
  font-size: 0.86rem;
  padding: 10px 12px;
  border-radius: var(--r-pill);
  border: 1px solid transparent;
  background: transparent;
  transition: transform var(--dur-2) var(--ease),
              background var(--dur-2) var(--ease),
              border-color var(--dur-2) var(--ease),
              box-shadow var(--dur-2) var(--ease);
  color: rgba(255,255,255,0.84);
  letter-spacing: 0.02em;
}

.nav-link:hover{
  background: rgba(255,255,255,0.06);
  border-color: rgba(255,255,255,0.08);
  transform: translateY(-1px);
}

.nav-link--cta{
  border-color: rgba(255,255,255,0.18);
  background: rgba(255,255,255,0.10);
  color: rgba(255,255,255,0.92);
}

.nav-toggle{
  display:none;
  width: 44px;
  height: 44px;
  border-radius: 14px;
  border: 1px solid var(--hair2);
  background: rgba(255,255,255,0.04);
  box-shadow: var(--shadow-1);
  cursor:pointer;
}
.nav-toggle span{
  display:block;
  height: 2px;
  width: 18px;
  margin: 0 auto;
  background: rgba(255,255,255,0.88);
  border-radius: 999px;
}
.nav-toggle span + span{ margin-top: 6px; opacity: 0.82; }

@media (max-width: 900px){
  .brand{ min-width: 0; }
  .nav-toggle{ display:inline-grid; place-items:center; }

  .site-nav{
    position:absolute;
    top: 64px;
    right: calc(var(--gutter));
    width: min(380px, calc(100% - (var(--gutter) * 2)));
    display:none;
    flex-direction: column;
    align-items: stretch;
    gap: 6px;
    padding: 10px;
    border-radius: 18px;
    border: 1px solid rgba(255,255,255,0.14);
    background: rgba(10,10,10,0.90);
    box-shadow: var(--shadow-2);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
  }
  .site-nav.is-open{ display:flex; }

  .nav-link{
    padding: 12px 12px;
    border-radius: 16px;
  }
}

/* ----------------------------- Typography ------------------------------- */
.eyebrow{
  margin: 0 0 12px;
  display:inline-flex;
  align-items:center;
  gap: 10px;
  padding: 7px 10px;
  border-radius: var(--r-pill);
  border: 1px solid var(--hair);
  background: rgba(255,255,255,0.03);
  font-weight: 900;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  font-size: 0.74rem;
  color: rgba(255,255,255,0.66);
}

.h1{
  margin: 0 0 14px;
  font-size: clamp(2.25rem, 4.8vw, 3.45rem);
  line-height: 1.02;
  letter-spacing: -0.02em;
  text-transform: uppercase;
}

.h2{
  margin: 0 0 12px;
  font-size: clamp(1.9rem, 3.6vw, 2.65rem);
  line-height: 1.06;
  letter-spacing: -0.02em;
  text-transform: uppercase;
}

.lead{
  margin: 0;
  color: var(--muted);
  font-size: 1.05rem;
  line-height: 1.75;
  max-width: 72ch;
}

.mini{
  margin: 0;
  color: var(--muted);
  font-size: 0.95rem;
  line-height: 1.7;
}

/* ----------------------------- Framed grid blocks ------------------------ */
.frame{
  border: 1px solid var(--hair);
  background: rgba(255,255,255,0.015);
  border-radius: var(--r-2xl);
  overflow: hidden;
  box-shadow: var(--shadow-1);
}

.frame__top{
  padding: 14px 16px;
  border-bottom: 1px solid var(--hair);
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 14px;
}

.frame__nav{
  display:flex;
  gap: 14px;
  flex-wrap: wrap;
  color: rgba(255,255,255,0.58);
  font-weight: 800;
  font-size: 0.82rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.frame__nav a{
  padding: 8px 8px;
  border-radius: 12px;
  border: 1px solid transparent;
}
.frame__nav a:hover{
  border-color: rgba(255,255,255,0.06);
  background: rgba(255,255,255,0.03);
}

.frame__inner{
  padding: 18px;
}

/* A “panel grid” like your planning image */
.panel-grid{
  display:grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap: 14px;
}

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

.panel{
  border: 1px solid var(--hair);
  background: rgba(255,255,255,0.02);
  border-radius: var(--r-xl);
  padding: 16px;
  min-height: 140px;
  transition: transform var(--dur-2) var(--ease),
              border-color var(--dur-2) var(--ease),
              background var(--dur-2) var(--ease),
              box-shadow var(--dur-2) var(--ease);
}

/* --------------------------- Premium panel shine -------------------------- */
.panel{
  --mx: 50%;
  --my: 50%;
  transform: translateZ(0);
}
.panel::after{
  content:"";
  position:absolute;
  inset:-1px;
  border-radius: inherit;
  background: radial-gradient(520px 220px at var(--mx) var(--my),
    rgba(255,255,255,0.12), transparent 62%);
  opacity: 0;
  transition: opacity var(--dur-2) var(--ease);
  pointer-events:none;
}
.panel:hover::after{ opacity: 1; }

.panel:hover{
  transform: translateY(-3px);
  border-color: rgba(255,255,255,0.14);
  background: rgba(255,255,255,0.03);
  box-shadow: var(--shadow-1);
}

.panel--media{
  padding: 0;
  min-height: 220px;
  background:
    radial-gradient(700px 380px at 35% 20%, rgba(255,255,255,0.08), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.015));
}
.panel--media .media-ph{
  height: 100%;
  min-height: 220px;
  border-radius: var(--r-xl);
  border: 0;
  background:
    linear-gradient(90deg, rgba(255,255,255,0.03), rgba(255,255,255,0.02));
  opacity: 0.9;
}

/* Column helpers to match the planning image rhythm */
.col-5{ grid-column: span 5; }
.col-7{ grid-column: span 7; }
.col-4{ grid-column: span 4; }
.col-6{ grid-column: span 6; }
.col-8{ grid-column: span 8; }
.col-12{ grid-column: span 12; }

@media (max-width: 960px){
  .col-5,.col-7,.col-4,.col-6,.col-8,.col-12{ grid-column: span 1; }
}

/* ----------------------------- Buttons ---------------------------------- */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap: 10px;
  padding: 12px 14px;
  border-radius: 16px;
  border: 1px solid var(--hair2);
  background: rgba(255,255,255,0.04);
  color: rgba(255,255,255,0.90);
  font-weight: 900;
  cursor: pointer;
  user-select: none;
  transition: transform var(--dur-2) var(--ease),
              background var(--dur-2) var(--ease),
              border-color var(--dur-2) var(--ease),
              box-shadow var(--dur-2) var(--ease);
}
.btn:hover{ transform: translateY(-2px); box-shadow: var(--shadow-1); }
.btn:active{ transform: translateY(1px) scale(0.99); }

.btn--ghost{
  background: rgba(255,255,255,0.02);
  border-color: rgba(255,255,255,0.08);
  color: rgba(255,255,255,0.84);
}

/* Circular arrow button like the planning image */
.orb{
  width: 44px;
  height: 44px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.16);
  background: rgba(255,255,255,0.04);
  display:grid;
  place-items:center;
  cursor:pointer;
  transition: transform var(--dur-2) var(--ease),
              background var(--dur-2) var(--ease),
              border-color var(--dur-2) var(--ease);
}
.orb:hover{
  transform: translateY(-2px);
  background: rgba(255,255,255,0.06);
  border-color: rgba(255,255,255,0.22);
}
.orb:active{ transform: translateY(-1px) scale(0.99); }

.orb svg{ width: 16px; height: 16px; opacity: 0.92; }

/* ----------------------------- Lists ------------------------------------ */
.bullets{
  margin: 12px 0 0;
  padding: 0 0 0 18px;
  color: var(--muted);
  line-height: 1.7;
}
.bullets li{ margin: 6px 0; }

/* ----------------------------- Form ------------------------------------- */
.form{
  display:grid;
  gap: 12px;
}
.form__row{
  display:grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 12px;
}
@media (max-width: 900px){ .form__row{ grid-template-columns: 1fr; } }

.label{
  display:block;
  margin: 0 0 8px;
  font-weight: 900;
  color: rgba(255,255,255,0.86);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 0.78rem;
}
.input, .textarea, .select{
  width: 100%;
  padding: 12px 12px;
  border-radius: 16px;
  border: 1px solid var(--hair2);
  background: rgba(255,255,255,0.03);
  color: rgba(255,255,255,0.90);
  outline: none;
  transition: border-color var(--dur-2) var(--ease), box-shadow var(--dur-2) var(--ease), background var(--dur-2) var(--ease);
}
.textarea{ min-height: 150px; resize: vertical; }
.input:focus, .textarea:focus, .select:focus{
  border-color: rgba(255,255,255,0.22);
  box-shadow: 0 0 0 6px rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.04);
}

/* ----------------------------- Footer ----------------------------------- */
.site-footer{
  position: relative;
  z-index: 2;
  padding: 34px 0;
  border-top: 1px solid var(--hair);
  background: rgba(255,255,255,0.01);
}

.footer__grid{
  display:grid;
  grid-template-columns: 1.2fr 1fr 1fr;
  gap: 14px;
  align-items: start;
}
@media (max-width: 900px){ .footer__grid{ grid-template-columns: 1fr; } }

.footer__brand{ font-weight: 1000; text-transform: uppercase; letter-spacing: 0.10em; }
.footer__meta{ margin-top: 6px; color: var(--muted); line-height: 1.7; }
.footer__links{ display:flex; flex-wrap:wrap; gap: 10px; justify-content: flex-end; }
@media (max-width: 900px){ .footer__links{ justify-content:flex-start; } }
.footer__links a{
  font-weight: 900;
  padding: 8px 10px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.02);
  color: rgba(255,255,255,0.78);
}
.footer__links a:hover{ transform: translateY(-1px); }

/* --------------------------- Reveal on Scroll ---------------------------- */
.reveal{
  opacity: 0;
  transform: translateY(14px);
  filter: blur(6px);
  transition:
    opacity var(--dur-4) var(--ease),
    transform var(--dur-4) var(--ease),
    filter var(--dur-4) var(--ease);
  transition-delay: var(--delay, 0ms);
}
.reveal.is-visible{
  opacity: 1;
  transform: translateY(0);
  filter: blur(0);
}
.stagger .reveal{ transition-delay: var(--delay, 0ms); }

@media (prefers-reduced-motion: reduce){
  .reveal{ opacity: 1; transform: none; filter: none; transition: none; }
}

/* --------------------------- Modal -------------------------------------- */
.modal{
  position: fixed;
  inset: 0;
  z-index: 90;
  display: none;
  place-items: center;
  padding: 20px;
  background: rgba(0,0,0,0.62);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.modal.is-open{ display: grid; }

.modal__dialog{
  width: min(960px, 100%);
  border-radius: var(--r-2xl);
  border: 1px solid rgba(255,255,255,0.12);
  background:
    radial-gradient(900px 420px at 20% 20%, rgba(255,255,255,0.08), transparent 62%),
    linear-gradient(180deg, rgba(14,14,14,0.92), rgba(10,10,10,0.94));
  box-shadow: var(--shadow-2);
  overflow: hidden;
}

.modal__top{
  padding: 16px 16px 12px;
  display:flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}

.modal__title{
  margin: 0;
  font-size: 1.1rem;
  font-weight: 1000;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.modal__close{
  width: 42px; height: 42px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,0.16);
  background: rgba(255,255,255,0.04);
  color: rgba(255,255,255,0.92);
  cursor: pointer;
}
.modal__body{
  padding: 14px 16px 16px;
  display:grid;
  gap: 12px;
}
.modal__pill{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  padding: 7px 10px;
  border-radius: var(--r-pill);
  border: 1px solid rgba(255,255,255,0.14);
  background: rgba(255,255,255,0.03);
  font-weight: 900;
  color: rgba(255,255,255,0.78);
  text-transform: uppercase;
  letter-spacing: 0.10em;
  font-size: 0.78rem;
}
.modal__grid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 10px;
}
@media (max-width: 900px){ .modal__grid{ grid-template-columns: 1fr; } }

.modal__box{
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,0.10);
  background: rgba(255,255,255,0.03);
  padding: 12px;
}
.modal__box strong{
  display:block;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 0.86rem;
}
.modal__box p{ margin: 6px 0 0; color: var(--muted); line-height: 1.65; }

/* --------------------------- Small utilities ----------------------------- */
.hr{ height: 1px; background: rgba(255,255,255,0.10); border: 0; margin: 18px 0; }
.mt-1{ margin-top: .6rem; }
.mt-2{ margin-top: 1.1rem; }
.mt-3{ margin-top: 1.7rem; }
.center{ text-align:center; }
.row-between{ display:flex; justify-content:space-between; align-items:center; gap: 14px; }


/* Header alignment helpers (centred pill nav) */
.brand{ justify-self: start; }
.site-nav{ justify-self: center; }
.nav-toggle{ justify-self: end; }


/* Header without brand (nav-only) */
.site-header__inner{ grid-template-columns: 1fr auto 1fr; }
.site-nav{ justify-self: center; }
.nav-toggle{ justify-self: end; }

/* --------------------------- Page fade (fallback) ------------------------- */
html{
  opacity: 1;
  transition: opacity var(--dur-3) var(--ease);
}
html.is-leaving{ opacity: 0; }

/* --------------------------- Parallax targets ----------------------------- */
[data-parallax]{
  will-change: transform;
  transform: translate3d(0,0,0);
}
