/* =========================================================
   MyBrigitte — Graphics kit
   Editorial cream paper. Instrument Serif + IBM Plex Sans + JetBrains Mono.
   ========================================================= */

:root{
  --paper: #F4EFE6;
  --paper-2: #ECE5D7;
  --paper-3: #E2D9C5;
  --paper-soft: #EFE9DA;
  --ink: #16201C;
  --ink-2: #2D3833;
  --ink-3: #5C645F;
  --ink-4: #8a8f87;
  --forest: #2E4A45;
  --forest-2: #1F3531;
  --terracotta: #B8654A;
  --cap-blue: #8FB4C7;
  --cap-blue-2: #6E97AC;
  --rule: rgba(22,32,28,0.14);
  --rule-strong: rgba(22,32,28,0.32);
  --rule-soft: rgba(22,32,28,0.07);

  --serif: "Instrument Serif", Georgia, serif;
  --sans: "IBM Plex Sans", -apple-system, system-ui, sans-serif;
  --mono: "JetBrains Mono", ui-monospace, monospace;
  --script: "Caveat", "Instrument Serif", cursive;
}

*{ box-sizing:border-box; }
html, body{
  margin:0; padding:0;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--sans);
  font-size:16px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
::selection{ background:var(--ink); color:var(--paper); }
a{ color:inherit; text-decoration:none; border-bottom:1px solid var(--rule-strong); }
em{ font-family:var(--serif); font-style:italic; font-size:1.05em; }
.mono{ font-family:var(--mono); font-size:10px; letter-spacing:0.16em; text-transform:uppercase; color:var(--ink-3); }

/* ---------- top bar ---------- */
.kit-bar{
  position:sticky; top:0; z-index:50;
  background:rgba(244,239,230,0.92);
  backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid var(--rule);
  padding:18px 40px;
  display:grid; grid-template-columns:1fr auto 1fr; gap:24px; align-items:center;
}
.kit-bar .brand{ font-family:var(--serif); font-size:22px; letter-spacing:-0.01em; border:0; }
.kit-bar .brand sup{ font-family:var(--mono); font-size:9px; color:var(--ink-3); margin-left:4px; vertical-align:top; letter-spacing:0.08em; }
.kit-bar .center{ font-family:var(--mono); font-size:10px; letter-spacing:0.14em; text-transform:uppercase; color:var(--ink-3); justify-self:center; }
.kit-bar .right{ justify-self:end; font-family:var(--mono); font-size:10px; letter-spacing:0.1em; text-transform:uppercase; color:var(--ink-2); border:1px solid var(--rule-strong); border-radius:999px; padding:8px 14px; }
.kit-bar .right:hover{ background:var(--ink); color:var(--paper); border-color:var(--ink); }

/* ---------- intro ---------- */
.kit-intro{
  max-width:1320px; margin:0 auto;
  padding:80px 40px 56px;
  display:grid; grid-template-columns:1.1fr 1fr; gap:64px;
  border-bottom:1px solid var(--rule);
}
.kit-intro h1{
  font-family:var(--serif); font-weight:400;
  font-size:clamp(40px, 5vw, 64px); line-height:1.0; letter-spacing:-0.02em;
  margin:14px 0 0; color:var(--ink);
}
.kit-intro p{ margin:0 0 1em; max-width:60ch; color:var(--ink-2); font-size:16px; }
.kit-intro .eyebrow{ font-family:var(--mono); font-size:10px; letter-spacing:0.18em; text-transform:uppercase; color:var(--terracotta); }
@media (max-width: 900px){
  .kit-intro{ grid-template-columns:1fr; gap:24px; padding:48px 22px 40px; }
}

/* ---------- module wrapper ---------- */
.kit-mod{
  max-width:1440px; margin:0 auto;
  padding:80px 40px 80px;
  border-bottom:1px solid var(--rule);
}
.kit-mod-head{
  display:grid; grid-template-columns:1fr auto; gap:48px; align-items:end;
  margin-bottom:40px;
  padding-bottom:24px;
  border-bottom:1px solid var(--ink);
}
.kit-mod-head .num{
  font-family:var(--mono); font-size:10px; letter-spacing:0.18em; text-transform:uppercase;
  color:var(--terracotta); display:block; margin-bottom:10px;
}
.kit-mod-head h2{
  font-family:var(--serif); font-weight:400;
  font-size:clamp(34px, 3.6vw, 48px); line-height:1.0; letter-spacing:-0.018em;
  margin:0 0 14px; color:var(--ink);
}
.kit-mod-head .use{ margin:0; max-width:62ch; color:var(--ink-2); font-size:15px; line-height:1.6; }
.kit-mod-head .tags{
  list-style:none; padding:0; margin:0;
  display:flex; flex-direction:column; align-items:flex-end; gap:6px;
  font-family:var(--mono); font-size:10px; letter-spacing:0.12em; text-transform:uppercase; color:var(--ink-3);
  white-space:nowrap;
}
.kit-mod-head .tags li{ border:1px solid var(--rule); padding:5px 10px; border-radius:999px; white-space:nowrap; }

.kit-mod-foot{
  margin-top:20px;
  padding-top:16px;
  border-top:1px solid var(--rule);
  display:flex; justify-content:space-between; align-items:baseline; gap:24px;
  font-size:13px; color:var(--ink-3);
}
.kit-mod-foot em{ color:var(--ink); }
@media (max-width: 900px){
  .kit-mod{ padding:56px 22px; }
  .kit-mod-head{ grid-template-columns:1fr; gap:16px; }
  .kit-mod-head .tags{ flex-direction:row; flex-wrap:wrap; align-items:flex-start; }
  .kit-mod-foot{ flex-direction:column; gap:8px; }
}

/* ---------- shared stage ---------- */
.stage{
  position:relative;
  margin:0;
  background:var(--paper-2);
  border:1px solid var(--rule);
  border-radius:8px;
  overflow:hidden;
  aspect-ratio: 1320 / 820;
}
.stage-tall{ aspect-ratio: 720 / 1200; max-width:780px; margin:0 auto; }

/* ============================================================
   G1 · Hero composite
   ============================================================ */
.g1{
  aspect-ratio: 1320 / 900;
  container-type:inline-size;
  background:
    radial-gradient(ellipse at 30% 20%, rgba(143,180,199,0.18), transparent 55%),
    radial-gradient(ellipse at 80% 70%, rgba(184,101,74,0.12), transparent 50%),
    var(--paper-2);
}
.g1-bg{
  position:absolute; inset:0;
  background-image:
    linear-gradient(to right, rgba(22,32,28,0.06) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(22,32,28,0.06) 1px, transparent 1px);
  background-size: 80px 80px;
  opacity:0.45;
  pointer-events:none;
}
.g1-cross{
  position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  font-family:var(--mono); font-size:22px; color:var(--terracotta); opacity:0.6;
}
.g1-mono{ position:absolute; font-family:var(--mono); font-size:0.85cqi; letter-spacing:0.18em; text-transform:uppercase; color:var(--ink-3); }
.g1-mono-tl{ top:3%; left:3%; }
.g1-mono-br{ bottom:3%; right:3%; }

.g1-sig{
  position:absolute; bottom:5%; left:5%;
  font-family:var(--script); font-size:3.5cqi; color:var(--cap-blue-2);
  transform:rotate(-3deg);
}

/* phone */
.phone{
  position:absolute;
  width:17%; aspect-ratio: 240 / 480;
  border-radius:8% / 4%;
  background:var(--ink);
  padding:1%;
  box-shadow:
    0 30px 50px -20px rgba(22,32,28,0.35),
    0 12px 24px -10px rgba(22,32,28,0.25);
  border:1px solid rgba(22,32,28,0.4);
}
.phone-screen{
  width:100%; height:100%;
  border-radius:7% / 3.5%;
  background:var(--paper);
  padding:8% 6%;
  display:flex; flex-direction:column; gap:5%;
  overflow:hidden;
  position:relative;
  container-type:inline-size;
}
.phone-status{
  display:flex; justify-content:space-between;
  font-family:var(--mono); font-size:4.5cqi; color:var(--ink-3);
  letter-spacing:0.06em;
  padding:0 4px 2px;
}
.phone-header{
  display:flex; align-items:center; gap:5%;
  padding:3% 0 6%;
  border-bottom:1px solid var(--rule);
  margin-bottom:2%;
}
.pn-logo{
  width:12cqi; height:12cqi; border-radius:50%;
  background:var(--paper-3);
  border:1px solid var(--cap-blue);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--serif); font-size:5cqi; letter-spacing:0.06em; color:var(--cap-blue-2);
  flex-shrink:0;
}
.pn-name{ font-family:var(--serif); font-size:7.5cqi; line-height:1; color:var(--ink); }
.pn-sub{ font-family:var(--mono); font-size:3.8cqi; letter-spacing:0.12em; text-transform:uppercase; color:var(--ink-3); margin-top:3px; }
.pn-tag{
  display:inline-block; font-family:var(--mono); font-size:3.8cqi; letter-spacing:0.1em; text-transform:uppercase;
  color:var(--cap-blue-2); padding:3px 7px; border:1px solid var(--cap-blue); border-radius:999px;
  background:rgba(143,180,199,0.1);
}
.pn-tag-tc{ color:var(--terracotta); border-color:var(--terracotta); background:rgba(184,101,74,0.08); }

.bubble{
  font-size:5cqi; line-height:1.4;
  padding:4% 5%; border-radius:14px;
  max-width:92%;
  word-wrap:break-word;
}
.bubble b{ font-weight:500; color:var(--ink); }
.bubble-in{
  background:var(--paper-2); color:var(--ink-2);
  border:1px solid var(--rule-soft);
  align-self:flex-start; border-bottom-left-radius:4px;
}
.bubble-out{
  background:var(--ink); color:var(--paper);
  align-self:flex-end; border-bottom-right-radius:4px;
}
.bubble.small{ padding:4px 0; background:transparent; border:0; }

/* phone placements */
.phone-en{ left:32%; top:48%; transform:translate(-50%,-50%) rotate(-6deg); z-index:3; }
.phone-fr{ left:52%; top:50%; transform:translate(-50%,-50%) rotate(2deg); z-index:2; }
.phone-de{ left:72%; top:48%; transform:translate(-50%,-50%) rotate(8deg); z-index:1; }

/* ============================================================
   G2 · Day timeline
   ============================================================ */
.g2{
  aspect-ratio: 720 / 1200;
  background:var(--paper);
  padding:48px 56px 56px;
  display:flex; flex-direction:column;
}
.g2-rail{
  position:absolute; left:84px; top:240px; bottom:96px;
  width:1px; background:var(--ink); opacity:0.5;
}
.g2-title{
  font-family:var(--serif); font-weight:400;
  font-size:64px; line-height:0.92; letter-spacing:-0.02em;
  margin:0 0 8px; color:var(--ink);
}
.g2-title em{ color:var(--terracotta); font-size:1em; }
.g2-sub{
  margin:0 0 36px; max-width:46ch; color:var(--ink-2); font-size:14px; line-height:1.55;
  padding-left:0;
}
.g2-timeline{
  list-style:none; padding:0; margin:0;
  display:flex; flex-direction:column; gap:28px;
  position:relative;
  padding-left:40px;
}
.g2-timeline > li{
  display:grid; grid-template-columns:54px 18px 1fr; gap:0;
  align-items:start;
  position:relative;
}
.g2-time{
  font-family:var(--mono); font-size:11px; letter-spacing:0.12em; color:var(--terracotta);
  padding-top:14px;
  text-align:right; padding-right:8px;
}
.g2-dot{
  width:9px; height:9px; border-radius:50%; background:var(--paper);
  border:1.5px solid var(--ink);
  margin-top:18px; margin-left:4px;
  position:relative; z-index:2;
}
.g2-dot-end{ background:var(--terracotta); border-color:var(--terracotta); }
.g2-card{
  background:var(--paper-2);
  border:1px solid var(--rule);
  border-radius:6px;
  padding:14px 16px 12px;
  margin-left:8px;
}
.g2-q{
  font-family:var(--serif); font-style:italic;
  font-size:18px; line-height:1.3; color:var(--ink);
  margin:0 0 8px;
}
.g2-q-quiet{
  font-family:var(--serif); font-style:italic;
  font-size:17px; line-height:1.4; color:var(--ink-3);
  margin:0;
}
.g2-a{
  margin:0 0 8px; font-size:13px; line-height:1.5; color:var(--ink-2);
}
.g2-a b{ color:var(--ink); font-weight:500; }
.g2-meta{
  font-family:var(--mono); font-size:9px; letter-spacing:0.12em; text-transform:uppercase;
  color:var(--ink-3); display:block;
}
.g2-card-quiet{ background:transparent; border:1px dashed var(--rule-strong); }
.g2-end .g2-time{ color:var(--ink-3); }

/* ============================================================
   G3 · Diagram — one bot vs one bot per property
   ============================================================ */
.g3{
  aspect-ratio: 1320 / 640;
  background:var(--paper);
  display:grid; grid-template-columns:1fr 60px 1fr;
  padding:40px 48px;
}
.g3-col{ display:flex; flex-direction:column; gap:14px; padding:8px 24px; }
.g3-col-left{ border-right:0; }
.g3-col-right{}
.g3-divider{
  position:relative;
  display:flex; align-items:center; justify-content:center;
}
.g3-divider::before, .g3-divider::after{
  content:""; position:absolute; left:50%; transform:translateX(-50%);
  width:1px; background:var(--ink); opacity:0.4;
}
.g3-divider::before{ top:0; height:42%; }
.g3-divider::after{ bottom:0; height:42%; }
.g3-divider span{
  font-family:var(--serif); font-style:italic; font-size:22px; color:var(--ink-3);
}
.g3-mono-accent{ color:var(--terracotta) !important; }

.g3-formula{
  font-family:var(--serif); font-size:26px; line-height:1.2; letter-spacing:-0.01em;
  color:var(--ink); margin:0 0 18px;
}
.g3-formula .g3-arr{ color:var(--terracotta); padding:0 6px; }

.g3-diagram{ position:relative; flex:1; min-height:200px; padding:12px 0; }
.g3-diagram-gen{
  display:flex; flex-direction:column; align-items:center; justify-content:flex-start;
}
.g3-node{
  width:78px; height:78px; border-radius:50%;
  background:var(--paper-2); border:1.5px solid var(--ink);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--mono); font-size:13px; letter-spacing:0.14em; color:var(--ink);
  position:relative; z-index:2;
}
.g3-rays{
  position:relative; width:100%; height:60px; margin-top:-4px;
}
.g3-rays span{
  position:absolute; top:0; left:50%;
  width:1px; height:60px;
  background:var(--ink); opacity:0.32;
  transform-origin:top center;
}
.g3-rays span:nth-child(1){ transform:translateX(-50%) rotate(-42deg); }
.g3-rays span:nth-child(2){ transform:translateX(-50%) rotate(-28deg); }
.g3-rays span:nth-child(3){ transform:translateX(-50%) rotate(-14deg); }
.g3-rays span:nth-child(4){ transform:translateX(-50%) rotate(0deg); }
.g3-rays span:nth-child(5){ transform:translateX(-50%) rotate(14deg); }
.g3-rays span:nth-child(6){ transform:translateX(-50%) rotate(28deg); }
.g3-rays span:nth-child(7){ transform:translateX(-50%) rotate(42deg); }

.g3-leaves{
  display:flex; flex-wrap:wrap; justify-content:center; gap:6px 10px;
  margin-top:8px;
}
.g3-leaves span{
  font-family:var(--mono); font-size:10px; letter-spacing:0.1em; text-transform:uppercase;
  color:var(--ink-3);
  padding:5px 10px; border:1px solid var(--rule);
  border-radius:999px;
}

.g3-diagram-bri{
  display:flex; gap:18px; align-items:flex-start;
}
.g3-property{
  flex:0 0 120px;
  display:flex; flex-direction:column; align-items:center; gap:8px;
  padding-top:6px;
}
.g3-house{
  width:78px; height:78px;
  background:var(--paper-2);
  border:1.5px solid var(--ink);
  position:relative;
  clip-path: polygon(0% 35%, 50% 0%, 100% 35%, 100% 100%, 0% 100%);
  flex-shrink:0;
}
.g3-house::after{
  content:""; position:absolute; bottom:0; left:50%; transform:translateX(-50%);
  width:18px; height:24px;
  background:var(--terracotta);
}
.g3-sig{
  font-family:var(--script); font-size:22px; color:var(--cap-blue-2);
  transform:rotate(-3deg);
  text-align:center;
  line-height:1;
}

.g3-knows{
  flex:1;
  display:flex; flex-direction:column; gap:8px;
  padding-left:14px;
  border-left:1px solid var(--rule);
  padding-top:6px;
}
.g3-knows span{
  font-family:var(--serif); font-style:italic;
  font-size:17px; line-height:1.25; color:var(--ink);
  display:flex; align-items:baseline; gap:8px;
}
.g3-knows span::before{
  content:""; display:inline-block;
  width:14px; height:1px; background:var(--terracotta);
  flex-shrink:0; transform:translateY(-4px);
}

.g3-caption{
  margin:14px 0 0; font-size:13px; line-height:1.5; color:var(--ink-3);
  max-width:38ch;
}

/* ============================================================
   G4 · Before / After — owner inbox
   ============================================================ */
.g4{
  aspect-ratio: 1320 / 760;
  background:var(--paper);
  display:grid; grid-template-columns:1fr 1fr;
  gap:0;
}
.g4-side{ padding:36px 40px; display:flex; flex-direction:column; gap:18px; position:relative; }
.g4-before{ background:#1F2622; color:var(--paper); border-right:1px solid rgba(244,239,230,0.1); }
.g4-after{ background:var(--paper); }

.g4-head .mono{ color:rgba(244,239,230,0.55); }
.g4-after .g4-head .mono{ color:var(--terracotta); }
.g4-headline{
  font-family:var(--serif); font-weight:400;
  font-size:46px; line-height:1.0; letter-spacing:-0.018em;
  margin:8px 0 4px;
}
.g4-before .g4-headline{ color:var(--paper); }
.g4-after .g4-headline{ color:var(--ink); }
.g4-mono-accent{ color:var(--terracotta) !important; }

.g4-list{
  list-style:none; padding:0; margin:8px 0 0;
  display:flex; flex-direction:column;
  border-top:1px solid rgba(244,239,230,0.12);
}
.g4-list li{
  display:grid; grid-template-columns:120px 1fr 56px;
  gap:14px; padding:14px 0; align-items:baseline;
  border-bottom:1px solid rgba(244,239,230,0.10);
}
.g4-from{ font-family:var(--mono); font-size:10px; letter-spacing:0.1em; text-transform:uppercase; color:rgba(244,239,230,0.55); }
.g4-msg{ font-family:var(--serif); font-style:italic; font-size:17px; line-height:1.3; color:var(--paper); }
.g4-when{ font-family:var(--mono); font-size:10px; color:rgba(244,239,230,0.45); text-align:right; }
.g4-dim .g4-msg{ font-style:normal; font-family:var(--mono); font-size:11px; letter-spacing:0.1em; color:rgba(244,239,230,0.45); text-transform:uppercase; }

.g4-resolved{
  list-style:none; padding:0; margin:8px 0 0;
  display:flex; flex-direction:column;
  border-top:1px solid var(--rule);
}
.g4-resolved li{
  display:grid; grid-template-columns:24px 1fr; gap:12px;
  padding:11px 0; border-bottom:1px solid var(--rule);
  align-items:baseline;
  font-size:13px; line-height:1.45; color:var(--ink-2);
}
.g4-resolved li b{ color:var(--ink); font-weight:500; }
.g4-tick{
  font-family:var(--mono); font-size:14px; color:var(--terracotta);
}
.g4-lang{
  display:inline-block; font-family:var(--mono); font-size:9px; letter-spacing:0.12em;
  color:var(--cap-blue-2); border:1px solid var(--cap-blue); border-radius:999px;
  padding:2px 7px; margin-left:6px;
}
.g4-foot{
  margin-top:auto; padding-top:14px;
  border-top:1px solid var(--ink); opacity:0.7;
  display:flex; gap:32px;
  font-family:var(--mono); font-size:11px; letter-spacing:0.12em; text-transform:uppercase;
  color:var(--ink-3);
}
.g4-foot b{ color:var(--ink); font-family:var(--serif); font-style:italic; font-size:15px; letter-spacing:0; text-transform:none; }

/* ============================================================
   G5 · Numbers
   ============================================================ */
.g5{
  aspect-ratio: 1320 / 440;
  background:var(--paper);
  display:grid; grid-template-columns:repeat(4, 1fr); gap:0;
  padding:36px 0;
}
.g5-item{
  padding:8px 32px;
  border-right:1px solid var(--ink);
  display:flex; flex-direction:column; gap:8px;
  position:relative;
}
.g5-item-last{ border-right:0; }
.g5-num{
  font-family:var(--serif); font-weight:400;
  font-size:88px; line-height:0.95; letter-spacing:-0.03em;
  color:var(--ink);
  display:inline-flex; align-items:baseline; gap:4px;
}
.g5-num .g5-unit{
  font-size:28px; color:var(--terracotta); letter-spacing:0; font-style:italic;
  margin-left:2px;
}
.g5-item .mono{ display:block; margin-top:6px; }
.g5-note{
  font-size:13px; line-height:1.45; color:var(--ink-2);
  font-family:var(--serif); font-style:italic;
  margin-top:auto;
  max-width:22ch;
}

/* ============================================================
   G6 · Trust strip
   ============================================================ */
.g6{
  aspect-ratio: 1320 / 200;
  background:var(--paper);
  padding:0;
}
.g6-band{
  width:100%; height:100%;
  display:grid; grid-template-columns:repeat(4,1fr);
  border-top:1px solid var(--ink);
  border-bottom:1px solid var(--ink);
}
.g6-cell{
  padding:24px 28px;
  border-right:1px solid var(--rule);
  display:flex; flex-direction:column; gap:6px;
  position:relative;
}
.g6-cell:last-child{ border-right:0; }
.g6-cell::before{
  content:""; position:absolute; top:18px; right:18px;
  width:6px; height:6px; border-radius:50%; background:var(--terracotta);
}
.g6-h{
  font-family:var(--serif); font-weight:400;
  font-size:26px; line-height:1.1; letter-spacing:-0.012em;
  margin:4px 0 6px; color:var(--ink);
}
.g6-h em{ color:var(--terracotta); }
.g6-p{
  margin:0; font-size:12px; line-height:1.5; color:var(--ink-3);
  max-width:30ch;
}

/* ============================================================
   G7 · Postcard map
   ============================================================ */
.g7{
  aspect-ratio: 960 / 780;
  background:var(--paper-2);
  padding:32px;
  max-width:1100px; margin:0 auto;
}
.g7-card{
  position:relative;
  width:100%; height:100%;
  background:var(--paper);
  border:1px solid var(--rule-strong);
  box-shadow: 0 2px 0 var(--rule), 6px 8px 0 -2px var(--paper-3);
  overflow:hidden;
}
.g7-bg{ position:absolute; inset:0; }
.g7-bg svg{ width:100%; height:100%; display:block; }
.g7-eyebrow{
  position:absolute; top:18px; left:24px; right:24px;
  display:flex; justify-content:space-between;
  color:var(--ink-3) !important;
}
.g7-pin{
  position:absolute;
  transform:translate(-50%,-50%);
  display:flex; align-items:center; gap:8px;
}
.g7-dot{
  width:7px; height:7px; border-radius:50%;
  background:var(--ink);
  outline:3px solid var(--paper);
  flex-shrink:0;
}
.g7-dot-tc{ background:var(--terracotta); }
.g7-pin-label{
  font-family:var(--serif); font-size:14px; line-height:1.15; color:var(--ink);
  white-space:nowrap;
}
.g7-pin-label i{
  display:block;
  font-family:var(--mono); font-style:normal; font-size:9px; letter-spacing:0.1em; text-transform:uppercase;
  color:var(--ink-3); margin-top:2px;
}
.g7-pin-label-r{
  order:-1; text-align:right;
}
.g7-pin-home{
  display:flex; flex-direction:column; align-items:center; gap:6px;
  transform:translate(-50%,-100%);
}
.g7-house{
  width:22px; height:22px;
  background:var(--terracotta);
  clip-path: polygon(0% 45%, 50% 0%, 100% 45%, 100% 100%, 0% 100%);
}
.g7-pin-label-home{
  font-family:var(--script); font-size:22px;
  color:var(--terracotta);
  white-space:normal; text-align:center; line-height:1;
}
.g7-pin-label-home i{ font-family:var(--mono); font-size:8px; color:var(--terracotta); margin-top:4px; }

.g7-caption{
  position:absolute; bottom:20px; left:24px; right:24px;
  display:flex; align-items:center; justify-content:space-between; gap:18px;
}
.g7-caption .mono{ color:var(--ink-3); }
.g7-cap-h{
  font-family:var(--serif); font-style:italic;
  font-size:16px; color:var(--ink-2);
  text-align:right;
}

/* ============================================================
   G8 · Product captures triptych
   ============================================================ */
.g8{
  aspect-ratio: 1320 / 1100;
  background:var(--paper-2);
  display:grid; grid-template-columns:repeat(3, 1fr); gap:14px;
  padding:14px;
  container-type:inline-size;
}
/* Stack vertically when the host column is narrow */
@container (max-width: 760px) {
  .g8{ grid-template-columns:1fr; aspect-ratio:auto; gap:12px; }
  .g8-frame{ min-height:280px; }
}
.g8-frame{
  background:var(--paper);
  border:1px solid var(--rule-strong);
  border-radius:6px;
  overflow:hidden;
  display:flex; flex-direction:column;
  container-type:inline-size;
}
.g8-frame-mid{ background:var(--paper-soft); }
.g8-chrome{
  border-bottom:1px solid var(--rule);
  padding:2.2cqi 3.5cqi;
  display:flex; justify-content:flex-start; align-items:center;
  background:rgba(22,32,28,0.03);
}
.g8-chrome .mono{ font-size:2.4cqi; letter-spacing:0.12em; }
.g8-screen{
  padding:4.5cqi 4cqi 4cqi;
  display:flex; flex-direction:column; gap:1.8cqi;
  flex:1; min-height:0;
  overflow:hidden;
}
.g8-mark{
  font-size:4.5cqi; color:var(--cap-blue-2); text-align:center;
  margin-bottom:-1cqi;
}
.g8-h{
  font-family:var(--serif); font-weight:400;
  font-size:8cqi; line-height:1.0; letter-spacing:-0.015em;
  text-align:center; margin:0 0 0.4cqi; color:var(--ink);
}
.g8-sub{
  font-family:var(--serif); font-style:italic;
  font-size:4cqi; line-height:1.4; color:var(--ink-2);
  text-align:center; margin:0 0 3cqi;
  max-width:30ch; margin-left:auto; margin-right:auto;
}

/* g8 — Top 5 */
.g8-weather{
  display:grid; grid-template-columns:repeat(3,1fr);
  background:var(--paper-2);
  border-radius:6px; padding:2.5cqi;
  gap:1cqi;
  margin-bottom:1.5cqi;
}
.g8-weather > div{
  text-align:center; display:flex; flex-direction:column; gap:0.3cqi;
  border-right:1px solid var(--rule);
  padding:0 0.8cqi;
}
.g8-weather > div:last-child{ border-right:0; }
.g8-weather .mono{ font-size:2.2cqi; letter-spacing:0.14em; color:var(--cap-blue-2); }
.g8-weather b{ font-family:var(--serif); font-weight:400; font-size:5cqi; letter-spacing:-0.01em; color:var(--ink); }
.g8-weather i{ font-family:var(--serif); font-style:italic; font-size:2.8cqi; color:var(--ink-3); }

.g8-list{ list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:1.5cqi; }
.g8-list li{
  display:grid; grid-template-columns:6cqi 1fr; gap:2cqi;
  padding:2cqi 2.5cqi; background:var(--paper-2); border-radius:6px;
}
.g8-list li > span{
  font-family:var(--serif); font-size:6cqi; line-height:1; color:var(--ink); font-style:italic;
}
.g8-list .mono{ display:block; font-size:2cqi; letter-spacing:0.12em; color:var(--cap-blue-2); margin-bottom:0.5cqi; }
.g8-list b{ font-family:var(--serif); font-weight:400; font-size:3.8cqi; letter-spacing:-0.005em; color:var(--ink); line-height:1.1; }

/* g8 — Beyond the crowd */
.g8-theme{
  background:var(--paper);
  border-radius:6px;
  padding:2cqi 2.5cqi;
  display:flex; flex-direction:column; gap:0.6cqi;
  border:1px solid var(--rule-soft);
}
.g8-theme .mono{ font-size:2.2cqi; letter-spacing:0.14em; color:var(--cap-blue-2); }
.g8-theme b{ font-family:var(--serif); font-weight:400; font-size:4cqi; letter-spacing:-0.005em; color:var(--ink); line-height:1.1; }
.g8-theme p{ font-size:2.8cqi; line-height:1.4; color:var(--ink-2); margin:0.4cqi 0 0; }

/* g8 — Brigitte chat */
.g8-chat{ display:flex; flex-direction:column; gap:1.2cqi; flex:1; }
.g8-bub{
  font-size:2.8cqi; line-height:1.45; padding:1.5cqi 2.2cqi; border-radius:10px; max-width:90%;
}
.g8-bub b{ font-weight:500; color:var(--ink); }
.g8-bub-in{ background:var(--paper-2); color:var(--ink-2); align-self:flex-start; }
.g8-bub-out{ background:var(--ink); color:var(--paper); align-self:flex-end; }
.g8-bub-in:first-child{ background:rgba(143,180,199,0.18); font-style:italic; font-family:var(--serif); font-size:3.4cqi; color:var(--ink); }
.g8-input{
  margin-top:1.5cqi; display:flex; justify-content:space-between; align-items:center;
  border:1px solid var(--rule); border-radius:999px; padding:1.4cqi 2.5cqi;
  font-size:2.8cqi; color:var(--ink-3);
}
.g8-send{
  width:5cqi; height:5cqi; border-radius:50%; background:var(--ink); color:var(--paper);
  display:flex; align-items:center; justify-content:center; font-size:2.8cqi;
}

/* ============================================================
   Footer
   ============================================================ */
.kit-foot{
  max-width:1320px; margin:0 auto;
  padding:64px 40px 96px;
  color:var(--ink-3);
}
.kit-foot p{ margin:6px 0; max-width:70ch; }
.kit-foot a{ color:var(--ink); }

/* ============================================================
   Utilities — accessibility + photo slots
   ============================================================ */
.sr-only{
  position:absolute !important; width:1px; height:1px;
  padding:0; margin:-1px; overflow:hidden;
  clip:rect(0,0,0,0); white-space:nowrap; border:0;
}

/* photo slot — shown as a typed placeholder until CoWork swaps for <img> */
.photo-slot{
  display:flex; align-items:center; justify-content:center;
  position:relative; overflow:hidden;
  background:
    repeating-linear-gradient(
      45deg,
      var(--paper-3) 0, var(--paper-3) 1px,
      transparent 1px, transparent 12px
    ),
    var(--paper-2);
  border:1px dashed var(--rule-strong);
  border-radius:4px;
}
.photo-slot > .photo-slot-label{
  font-family:var(--mono); font-size:9px; letter-spacing:0.12em; text-transform:uppercase;
  color:var(--ink); text-align:center; padding:8px 12px;
  background:var(--paper); border:1px solid var(--ink);
  line-height:1.4; max-width:84%;
  position:relative;
  z-index:1;
}
.photo-slot.photo-slot-cqi > .photo-slot-label{
  font-size:1.1cqi;
  padding:0.8cqi 1.2cqi;
}
.photo-slot img{
  width:100%; height:100%; object-fit:cover; display:block;
  position:absolute; inset:0;
}

/* ============================================================
   G0 · Logo set
   ============================================================ */
.g0{
  aspect-ratio: 1320 / 760;
  background:var(--paper);
  container-type:inline-size;
  padding:24px;
}
.g0-grid{
  width:100%; height:100%;
  display:grid;
  grid-template-columns:2fr 1.2fr 1.2fr;
  grid-template-rows:1.4fr 1fr;
  gap:14px;
}
.g0-cell{
  background:var(--paper-2);
  border:1px solid var(--rule);
  border-radius:6px;
  padding:3cqi 3cqi 2.4cqi;
  display:flex; flex-direction:column; gap:1cqi;
  position:relative;
  overflow:hidden;
}
.g0-cell-wide{
  grid-row:span 2;
  background:var(--paper);
  border:1px solid var(--ink);
}
.g0-cell .mono{ font-size:0.85cqi; }
.g0-cap{
  margin-top:auto;
  font-family:var(--serif); font-style:italic;
  font-size:1.15cqi; line-height:1.4; color:var(--ink-3);
  max-width:36ch;
}

/* primary wordmark */
.g0-wm{
  flex:1;
  display:flex; align-items:center; justify-content:center; gap:0.6cqi;
  padding:2cqi 0;
  overflow:hidden;
}
.g0-wm-name{
  font-family:var(--serif); font-style:italic;
  font-size:10cqi; line-height:0.95; letter-spacing:-0.02em;
  color:var(--ink);
}
.g0-wm-tm{
  font-family:var(--mono); font-size:1cqi;
  letter-spacing:0.1em; color:var(--ink-3);
  vertical-align:top; align-self:flex-start;
  padding-top:1cqi;
}

/* monogram */
.g0-mono-row{
  display:flex; align-items:center; gap:2cqi;
  flex:1; justify-content:flex-start;
}
.g0-mono{
  position:relative; flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
}
.g0-mono-lg{ width:11cqi; height:11cqi; }
.g0-mono-sm{
  width:5cqi; height:5cqi;
  background:var(--ink); border-radius:50%;
}
.g0-mono-sm .g0-mono-letter{
  font-family:var(--serif); font-style:italic;
  font-size:3.4cqi; color:var(--paper); line-height:1;
}
.g0-mono-lg .g0-mono-letter{
  font-family:var(--serif); font-style:italic;
  font-size:6.4cqi; color:var(--ink); line-height:1;
  position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
}
.g0-mono-ring{
  position:absolute; inset:0; width:100%; height:100%;
  animation: g0-spin 24s linear infinite;
}
@keyframes g0-spin{ to{ transform:rotate(360deg); } }

/* postcard stamp */
.g0-stamp{
  flex:1;
  display:flex; align-items:center; justify-content:center;
  padding:1cqi 0;
}
.g0-stamp-inner{
  width:14cqi; aspect-ratio:1/1.3;
  border:1.5px solid var(--ink);
  outline:3px dashed var(--ink); outline-offset:3px;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  padding:1cqi 0.6cqi; gap:0.4cqi;
  background:var(--paper);
  text-align:center;
}
.g0-stamp-top{
  font-family:var(--mono); font-size:0.75cqi; letter-spacing:0.16em; text-transform:uppercase;
  color:var(--ink-3);
}
.g0-stamp-name{
  font-family:var(--serif); font-style:italic;
  font-size:3.4cqi; line-height:0.95; letter-spacing:-0.015em; color:var(--ink);
}
.g0-stamp-rule{
  width:60%; height:1px; background:var(--ink); margin:0.4cqi 0;
}
.g0-stamp-bottom{
  font-family:var(--mono); font-size:0.7cqi; letter-spacing:0.15em; text-transform:uppercase;
  color:var(--ink-2);
}
.g0-stamp-est{
  font-family:var(--mono); font-size:0.65cqi; letter-spacing:0.16em; text-transform:uppercase;
  color:var(--terracotta);
}

/* lockup */
.g0-lockup{
  flex:1;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  padding:0.6cqi 0; gap:0.6cqi;
  min-height:0;
}
.g0-lockup-host{
  font-family:var(--mono); font-size:0.85cqi; letter-spacing:0.18em; text-transform:uppercase;
  color:var(--ink); padding:0.8cqi 1.4cqi; border:1px dashed var(--rule-strong); border-radius:4px;
}
.g0-lockup-sig{
  font-family:var(--script); font-size:3.6cqi;
  color:var(--cap-blue-2); transform:rotate(-2deg);
  line-height:1;
}

/* swatches */
.g0-swatches{
  display:flex; gap:0.8cqi; flex:1; align-items:center;
  padding:1cqi 0;
}
.g0-sw{
  width:5cqi; aspect-ratio:1/1; border-radius:50%;
  display:inline-block; flex-shrink:0;
}

/* ============================================================
   G9 · Onboarding timeline
   ============================================================ */
.g9{
  aspect-ratio: 1320 / 680;
  background:var(--paper);
  container-type:inline-size;
  padding:3cqi 3.5cqi 2.5cqi;
  display:flex; flex-direction:column;
  gap:1.5cqi;
}
.g9-axis{
  position:relative;
  height:3cqi;
  display:flex; align-items:center;
  margin-top:1cqi;
}
.g9-line{
  position:absolute; left:0; right:0; top:50%;
  height:1px; background:var(--ink); opacity:0.32;
}
.g9-fill{
  position:absolute; left:0; top:calc(50% - 1.5px);
  height:3px; background:var(--terracotta);
  width:100%;
}
.g9-day{
  position:absolute; top:50%; transform:translate(-50%,-50%);
  font-family:var(--mono); display:flex; align-items:center; gap:0.6cqi;
  z-index:2;
}
.g9-day::before{
  content:""; width:0.9cqi; height:0.9cqi; border-radius:50%;
  background:var(--paper); border:1.5px solid var(--ink);
}
.g9-day-0{ left:0; }
.g9-day-0::before{ background:var(--ink); }
.g9-day-mid{ left:50%; }
.g9-day-end{ left:100%; }
.g9-day-end::before{ background:var(--terracotta); border-color:var(--terracotta); }
.g9-day .mono{ font-size:0.85cqi; letter-spacing:0.14em; color:var(--ink-2); background:var(--paper); padding:0 0.4cqi; }

.g9-steps{
  display:grid;
  grid-template-columns:3.5fr 7fr 2.5fr;
  gap:1.5cqi;
  flex:1; min-height:0;
}
.g9-step{
  background:var(--paper-2);
  border:1px solid var(--rule);
  border-radius:6px;
  padding:1.6cqi 1.8cqi;
  display:flex; flex-direction:column; gap:0.5cqi;
  position:relative;
  min-width:0;
}
.g9-step-num{
  font-family:var(--serif); font-style:italic;
  font-size:3cqi; line-height:1; color:var(--terracotta);
}
.g9-step-len{
  font-size:0.8cqi; letter-spacing:0.14em; color:var(--ink-3);
}
.g9-step-h{
  font-family:var(--serif); font-weight:400;
  font-size:2.6cqi; line-height:1; letter-spacing:-0.018em;
  margin:0.3cqi 0 0.2cqi; color:var(--ink);
}
.g9-step-p{
  margin:0; font-size:1.05cqi; line-height:1.5; color:var(--ink-2);
}
.g9-step-list{
  list-style:none; padding:0; margin:auto 0 0;
  display:flex; flex-wrap:wrap; gap:0.4cqi;
  padding-top:0.8cqi;
}
.g9-step-list li{
  font-family:var(--mono); font-size:0.7cqi; letter-spacing:0.1em; text-transform:uppercase;
  color:var(--ink-3);
  padding:0.35cqi 0.7cqi;
  background:var(--paper);
  border:1px solid var(--rule);
  border-radius:999px;
}

.g9-foot{
  display:flex; justify-content:space-between; align-items:baseline;
  padding-top:0.8cqi;
  border-top:1px solid var(--rule);
  gap:2cqi;
  flex-shrink:0;
}
.g9-foot .mono{ font-size:0.85cqi; color:var(--ink-3); }
.g9-foot-quote{
  font-family:var(--serif); font-style:italic;
  font-size:1.4cqi; color:var(--ink);
  text-align:right;
}

/* ============================================================
   G10 · Four archetypes
   ============================================================ */
.g10{
  aspect-ratio: 1320 / 880;
  background:var(--paper);
  container-type:inline-size;
  padding:2cqi;
  display:grid;
  grid-template-columns:1fr 1fr;
  grid-template-rows:1fr 1fr;
  gap:1.5cqi;
}
.g10-card{
  background:var(--paper);
  border:1px solid var(--rule-strong);
  border-radius:6px;
  padding:2.4cqi 2.6cqi 2cqi;
  display:flex; flex-direction:column; gap:1cqi;
  position:relative;
  overflow:hidden;
}
.g10-card-a{ background:var(--paper-2); border-color:var(--ink); }
.g10-card-a::before{
  content:""; position:absolute; top:0; left:0; right:0; height:3px;
  background:var(--terracotta);
}
.g10-card header{
  display:flex; justify-content:space-between; align-items:baseline;
  padding-bottom:1cqi;
  border-bottom:1px solid var(--rule);
}
.g10-card header .mono{ font-size:0.9cqi; color:var(--ink-3); }
.g10-stat{
  font-family:var(--serif); font-weight:400;
  font-size:3.8cqi; line-height:1; letter-spacing:-0.02em;
  color:var(--ink);
}
.g10-stat i{
  font-family:var(--mono); font-style:normal;
  font-size:0.85cqi; letter-spacing:0.12em; text-transform:uppercase;
  color:var(--ink-3); margin-left:0.6cqi;
  vertical-align:middle;
}
.g10-card h3{
  font-family:var(--serif); font-weight:400;
  font-size:3.4cqi; line-height:1.0; letter-spacing:-0.018em;
  margin:0.4cqi 0 0;
  color:var(--ink);
}
.g10-card p{
  margin:0; font-size:1.2cqi; line-height:1.5; color:var(--ink-2);
  max-width:42ch;
}
.g10-card footer{
  margin-top:auto;
  padding-top:1cqi;
  border-top:1px solid var(--rule);
  display:flex; flex-direction:column; gap:0.4cqi;
}
.g10-card footer .mono{ font-size:0.85cqi; letter-spacing:0.14em; color:var(--ink-3); }
.g10-pin{
  font-family:var(--serif); font-style:italic;
  font-size:1.25cqi; line-height:1.4; color:var(--ink);
}
.g10-pin b{ font-style:normal; font-weight:500; color:var(--terracotta); }

/* ============================================================
   G11 · Photo strip
   ============================================================ */
.g11{
  aspect-ratio: 1320 / 560;
  background:var(--paper);
  container-type:inline-size;
  padding:2.5cqi 3cqi 2cqi;
  display:flex; flex-direction:column;
  gap:1.5cqi;
}
.g11-strip{
  flex:1; min-height:0;
  display:grid;
  grid-template-columns: 1.1fr 1fr 1fr 1fr 1.1fr;
  gap:1.2cqi;
}
.g11-slot{
  display:flex; flex-direction:column; gap:0.6cqi;
  min-width:0;
}
.g11-slot .mono{
  font-size:0.8cqi; letter-spacing:0.16em; color:var(--terracotta);
}
.g11-slot .photo-slot{
  flex:1; aspect-ratio: 4/3;
  width:100%;
}
.g11-slot-tall .photo-slot{
  aspect-ratio: 4/5;
}
.g11-cap{
  font-family:var(--serif); font-style:italic;
  font-size:1.1cqi; line-height:1.3; color:var(--ink-2);
}
.g11-foot{
  display:flex; justify-content:space-between; align-items:baseline;
  padding-top:1cqi;
  border-top:1px solid var(--rule);
  gap:2cqi;
  flex-shrink:0;
}
.g11-foot .mono{ font-size:0.85cqi; color:var(--ink-3); }
.g11-foot-quote{
  font-family:var(--serif); font-style:italic;
  font-size:1.4cqi; color:var(--ink);
  text-align:right;
}

/* Real photo override */
.photo-slot.photo-filled{ border:1px solid var(--rule); background:var(--paper-2); }
.photo-slot.photo-filled::before, .photo-slot.photo-filled::after{ display:none; }
.photo-slot.photo-filled > img{ width:100%; height:100%; object-fit:cover; display:block; }
