/* =========================================================
   2tmeinung — Design tokens
   Palette: near-black / off-white, one pure-white accent used
   sparingly. Display: Archivo (900). Body: Inter. Utility/eyebrow: IBM Plex Mono.
   ========================================================= */

:root{
  --bg:        #0a0a0a;
  --bg-alt:    #121212;
  --surface:   #181818;
  --line:      #2a2a2a;
  --text:      #f2f2ee;
  --text-dim:  #8f8f89;
  --white:     #ffffff;
  --black:     #000000;

  --font-display: 'Archivo', sans-serif;
  --font-body:    'Inter', sans-serif;
  --font-mono:    'IBM Plex Mono', monospace;

  --radius: 2px;
  --gap: clamp(1.25rem, 3vw, 2.5rem);
  --container: 1200px;

  --ease: cubic-bezier(.16,.8,.24,1);
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:var(--font-body);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }

h1,h2,h3,h4{
  font-family:var(--font-display);
  font-weight:900;
  line-height:1.05;
  letter-spacing:-0.02em;
  margin:0 0 .5em;
  text-transform:uppercase;
}
h1{ font-size:clamp(2.4rem,6vw,5rem); }
h2{ font-size:clamp(1.8rem,4vw,3rem); }
h3{ font-size:clamp(1.2rem,2.4vw,1.6rem); }
p{ margin:0 0 1em; color:var(--text-dim); }

.eyebrow{
  font-family:var(--font-mono);
  font-size:.75rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--text-dim);
  display:inline-flex;
  align-items:center;
  gap:.6em;
  margin-bottom:1em;
}
.eyebrow::before{
  content:'';
  width:1.4em; height:1px; background:var(--text-dim);
}

.container{ max-width:var(--container); margin:0 auto; padding:0 var(--gap); }
.section{ padding:clamp(3rem,8vw,7rem) 0; }
.line{ border:none; border-top:1px solid var(--line); margin:0; }

/* Buttons */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.6em;
  font-family:var(--font-mono);
  font-size:.85rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  padding:1em 1.8em;
  border:1px solid var(--text);
  background:transparent;
  color:var(--text);
  cursor:pointer;
  transition:background .25s var(--ease), color .25s var(--ease), border-color .25s var(--ease);
  border-radius:var(--radius);
}
.btn:hover{ background:var(--text); color:var(--bg); }
.btn-solid{ background:var(--text); color:var(--bg); }
.btn-solid:hover{ background:transparent; color:var(--text); }
.btn-ghost{ border-color:var(--line); color:var(--text-dim); }
.btn-ghost:hover{ border-color:var(--text); color:var(--text); background:transparent; }

/* =========================================================
   Site header
   ========================================================= */
.site-header{
  position:fixed; top:0; left:0; right:0; z-index:100;
  display:flex; align-items:center; justify-content:space-between;
  padding:1.4rem var(--gap);
  background:linear-gradient(to bottom, rgba(10,10,10,.9), transparent);
  backdrop-filter:blur(6px);
}
.site-logo{
  font-family:var(--font-display); font-weight:900; text-transform:uppercase;
  font-size:1.1rem; letter-spacing:.02em;
}
.site-logo span{ color:var(--text-dim); }
.main-nav ul{ display:flex; gap:2rem; list-style:none; margin:0; padding:0; }
.main-nav a{
  font-family:var(--font-mono); font-size:.8rem; letter-spacing:.06em;
  text-transform:uppercase; color:var(--text-dim);
  transition:color .2s var(--ease);
}
.main-nav a:hover{ color:var(--text); }
.nav-toggle{ display:none; background:none; border:none; color:var(--text); font-size:1.4rem; cursor:pointer; }

@media (max-width:820px){
  .main-nav{
    position:fixed; inset:0; background:var(--bg); display:flex; align-items:center; justify-content:center;
    transform:translateY(-100%); transition:transform .4s var(--ease); z-index:99;
  }
  .main-nav.is-open{ transform:translateY(0); }
  .main-nav ul{ flex-direction:column; text-align:center; gap:1.6rem; }
  .main-nav a{ font-size:1.1rem; }
  .nav-toggle{ display:block; }
}

/* =========================================================
   Footer
   ========================================================= */
.site-footer{
  border-top:1px solid var(--line);
  padding:3rem var(--gap) 2rem;
  font-family:var(--font-mono); font-size:.8rem; color:var(--text-dim);
  display:flex; flex-wrap:wrap; gap:1.5rem; justify-content:space-between; align-items:center;
}
.site-footer a{ color:var(--text-dim); }
.site-footer a:hover{ color:var(--text); }

/* =========================================================
   HOMEPAGE — the fork (signature element)
   Two full-height panels; hovered panel inverts to white.
   ========================================================= */
.fork{
  display:flex; min-height:100svh; width:100%;
}
.fork-panel{
  position:relative;
  flex:1;
  display:flex; flex-direction:column; align-items:flex-start; justify-content:flex-end;
  padding:clamp(2rem,6vw,5rem);
  min-height:60svh;
  overflow:hidden;
  background:var(--bg);
  color:var(--text);
  transition:background .5s var(--ease), color .5s var(--ease), flex-grow .5s var(--ease);
  border-right:1px solid var(--line);
}
.fork-panel:last-child{ border-right:none; }
.fork-panel .eyebrow{ color:inherit; opacity:.6; }
.fork-panel .eyebrow::before{ background:currentColor; }
.fork-panel h2{ margin-bottom:.3em; }
.fork-panel p{ color:inherit; opacity:.7; max-width:32ch; }
.fork-panel .btn{ margin-top:1.5em; border-color:currentColor; color:inherit; }
.fork-panel .btn:hover{ background:currentColor; }

.fork-panel::before{
  content:attr(data-index);
  position:absolute; top:clamp(1.5rem,4vw,3rem); right:clamp(1.5rem,4vw,3rem);
  font-family:var(--font-mono); font-size:.8rem; opacity:.5;
}

@media (hover:hover){
  .fork-panel:hover{ flex-grow:1.35; }
  .fork:has(.fork-panel:hover) .fork-panel:not(:hover){ flex-grow:.75; }
  .fork-panel.is-light:hover,
  .fork-panel.is-light{ }
}
.fork-panel[data-variant="professional"]{ background:var(--bg); }
.fork-panel[data-variant="private"]:hover{ background:var(--white); color:var(--black); }
.fork-panel[data-variant="professional"]:hover{ background:var(--white); color:var(--black); }
.fork-panel[data-variant="private"]:hover .btn:hover,
.fork-panel[data-variant="professional"]:hover .btn:hover{ background:var(--black); color:var(--white); }

@media (max-width:820px){
  .fork{ flex-direction:column; }
  .fork-panel{ border-right:none; border-bottom:1px solid var(--line); }
  .fork-panel:hover{ flex-grow:1; }
}

.fork-intro{
  position:absolute; top:0; left:0; right:0;
  padding:2rem var(--gap) 0;
  z-index:2;
  text-align:center;
  pointer-events:none;
}
.fork-intro .eyebrow{ justify-content:center; }

/* =========================================================
   Generic hero (non-homepage pages)
   ========================================================= */
.hero{
  padding:clamp(7rem,14vw,10rem) 0 clamp(3rem,6vw,5rem);
  border-bottom:1px solid var(--line);
}
.hero .eyebrow{ }
.hero h1{ max-width:16ch; }
.hero .lede{ max-width:52ch; font-size:1.1rem; }

/* =========================================================
   Step / process list (used on private & professional templates)
   ========================================================= */
.steps{ counter-reset:step; display:grid; gap:0; }
.step{
  counter-increment:step;
  display:grid; grid-template-columns:80px 1fr; gap:2rem;
  padding:2.5rem 0; border-top:1px solid var(--line);
}
.step:last-child{ border-bottom:1px solid var(--line); }
.step::before{
  content:counter(step,decimal-leading-zero);
  font-family:var(--font-mono); font-size:.9rem; color:var(--text-dim); padding-top:.2em;
}
.step h3{ margin-bottom:.4em; }

/* =========================================================
   Option cards (professional page: Option A / Option B)
   ========================================================= */
.option-grid{ display:grid; grid-template-columns:1fr 1fr; gap:1px; background:var(--line); }
.option-card{
  background:var(--bg); padding:clamp(2rem,4vw,3rem); display:flex; flex-direction:column; gap:1rem;
}
.option-card .tag{ font-family:var(--font-mono); font-size:.75rem; color:var(--text-dim); letter-spacing:.1em; text-transform:uppercase; }
.option-card h3{ margin:0; }
.option-card ul{ margin:0; padding-left:1.1em; color:var(--text-dim); }
@media (max-width:760px){ .option-grid{ grid-template-columns:1fr; } }

/* =========================================================
   Forms (WPForms wrapper styling — monochrome override)
   ========================================================= */
.form-shell{
  background:var(--surface); border:1px solid var(--line); padding:clamp(1.5rem,4vw,3rem); border-radius:var(--radius);
}
.form-shell .wpforms-container,
.form-shell .gform_wrapper{ --wp-form-accent:var(--white); }
.upload-note{
  display:flex; gap:.8em; align-items:flex-start; font-family:var(--font-mono); font-size:.8rem; color:var(--text-dim);
  border:1px dashed var(--line); padding:1em; margin-top:1.5em;
}

/* =========================================================
   Tutorials grid
   ========================================================= */
.tutorial-filters{ display:flex; gap:.6rem; flex-wrap:wrap; margin-bottom:2.5rem; }
.tutorial-filters button{
  font-family:var(--font-mono); font-size:.75rem; text-transform:uppercase; letter-spacing:.06em;
  background:transparent; border:1px solid var(--line); color:var(--text-dim); padding:.6em 1.1em; cursor:pointer;
}
.tutorial-filters button.is-active,
.tutorial-filters button:hover{ border-color:var(--text); color:var(--text); }

.tutorial-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:1px; background:var(--line); }
.tutorial-card{ background:var(--bg); padding:1.8rem; display:flex; flex-direction:column; gap:.6rem; transition:background .2s; }
.tutorial-card:hover{ background:var(--surface); }
.tutorial-card .kind{ font-family:var(--font-mono); font-size:.7rem; color:var(--text-dim); text-transform:uppercase; letter-spacing:.08em; }
.tutorial-card h3{ font-size:1.1rem; margin:.2em 0; }
.tutorial-card .meta{ margin-top:auto; font-family:var(--font-mono); font-size:.75rem; color:var(--text-dim); }
.lock-icon{ opacity:.5; }

/* =========================================================
   Dashboard
   ========================================================= */
.dash-shell{ display:grid; grid-template-columns:240px 1fr; min-height:100vh; }
.dash-side{
  border-right:1px solid var(--line); padding:8rem 2rem 2rem;
  display:flex; flex-direction:column; gap:.5rem;
}
.dash-side a{
  font-family:var(--font-mono); font-size:.85rem; color:var(--text-dim); padding:.7em 0; letter-spacing:.03em;
}
.dash-side a.is-active, .dash-side a:hover{ color:var(--text); }
.dash-main{ padding:8rem var(--gap) 4rem; }
.dash-card{ background:var(--surface); border:1px solid var(--line); padding:1.6rem; margin-bottom:1rem; }
.dash-row{ display:flex; justify-content:space-between; align-items:center; gap:1rem; flex-wrap:wrap; }
.status-pill{
  font-family:var(--font-mono); font-size:.7rem; text-transform:uppercase; letter-spacing:.06em;
  padding:.3em .8em; border:1px solid var(--line); border-radius:99px; color:var(--text-dim);
}
.status-pill.confirmed{ color:var(--white); border-color:var(--white); }
@media (max-width:820px){
  .dash-shell{ grid-template-columns:1fr; }
  .dash-side{ flex-direction:row; overflow-x:auto; padding:6rem 1.5rem 1rem; border-right:none; border-bottom:1px solid var(--line); }
  .dash-main{ padding:2rem var(--gap) 3rem; }
}

/* login gate */
.login-gate{
  min-height:100svh; display:flex; align-items:center; justify-content:center; padding:2rem;
}
.login-box{ width:100%; max-width:400px; text-align:center; }
