@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;1,400;1,500&family=DM+Sans:opsz,wght@9..40,200;9..40,300;9..40,400;9..40,500&display=swap');


  .fc-life-squares {
    --bg: #f0eee6;
    --bg2: #e8e5dc;
    --fg: #1a1a18;
    --fg2: #5a5a54;
    --fg3: #9a9a90;
    --white: #fff;
    --border: rgba(26,26,24,0.1);
    --border2: rgba(26,26,24,0.22);

    --sq-pre:    #dddbd3;
    --sq-early:  #bdd4b5;
    --sq-social: #f2c898;
    --sq-crisis: #e89080;
    --sq-now:    #1a1a18;
    --sq-future: #c8c7bf;

    --red:    #b83020;
    --green:  #1a6a3a;
    --amber:  #9a5010;
    --blue:   #1a3a6a;
    --teal:   #0a5a44;
    --purple: #3a2468;

    --red-bg:    #fbeae8;
    --green-bg:  #e8f5ec;
    --amber-bg:  #fdf3e0;
    --blue-bg:   #e8eef8;
    --teal-bg:   #e4f5ee;
    --purple-bg: #eeebfb;
  }

  .fc-life-squares *, .fc-life-squares *::before, .fc-life-squares *::after { margin:0; padding:0; box-sizing:border-box; }

  .fc-life-squares {
    font-family: 'DM Sans', sans-serif;
    background: var(--bg);
    color: var(--fg);
    -webkit-font-smoothing: antialiased;
  }

  .fc-life-squares {
    max-width: none;
    margin: 0;
    padding: clamp(20px, 3vw, 40px) clamp(12px, 2.5vw, 28px) clamp(28px, 4vw, 56px);
  }

  .fc-life-squares .fc-life-layout {
    display: grid;
    grid-template-columns: minmax(0, 0.88fr) minmax(0, 1.12fr);
    gap: clamp(20px, 3.5vw, 44px);
    align-items: start;
    margin-bottom: clamp(16px, 2.5vw, 24px);
  }

  .fc-life-squares .fc-life-layout__intro {
    min-width: 0;
  }

  .fc-life-squares .fc-life-layout__grid {
    min-width: 0;
    align-self: start;
    display: flex;
    justify-content: flex-start;
    width: 100%;
  }

  .fc-life-squares .eyebrow { font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--fg3); margin-bottom:14px; }
  .fc-life-squares .headline {
    font-family:'DM Sans',sans-serif;
    font-size: clamp(1.05rem, 1.35vw, 1.35rem); font-weight:300; font-style:normal;
    line-height:1.22; margin-bottom:12px; max-width:none;
  }
  .fc-life-squares .subline { font-size:14px; color:var(--fg2); line-height:1.68; max-width:none; font-weight:300; margin-bottom: clamp(20px, 3vw, 28px); }

  .fc-life-squares .fc-life-layout__intro .controls {
    display:flex; flex-direction:column; align-items:flex-start; gap:14px;
    margin-bottom:0;
  }
  .fc-life-squares .ctrl-label { font-size:13px; color:var(--fg2); white-space:nowrap; }
  .fc-life-squares select.birth-select {
    font-family:'DM Sans',sans-serif; font-size:13px;
    background:var(--white); border:1px solid var(--border2);
    border-radius:0; padding:7px 12px; color:var(--fg); cursor:pointer; outline:none;
  }
  .fc-life-squares select.birth-select:focus { border-color:var(--fg); }

  
  .fc-life-squares .toggle-group {
    display:flex; background:var(--bg2); border-radius:0; padding:3px; gap:2px;
  }
  .fc-life-squares .toggle-btn {
    font-family:'DM Sans',sans-serif; font-size:12px; font-weight:500;
    padding:6px 14px; border-radius:0; border:none; cursor:pointer;
    background:transparent; color:var(--fg2); transition:all .18s;
    letter-spacing:.02em;
  }
  .fc-life-squares .toggle-btn.active {
    background:var(--white); color:var(--fg);
    box-shadow:0 1px 4px rgba(0,0,0,.12);
  }

  .fc-life-squares .legend {
    display:flex; gap:14px; flex-wrap:wrap; margin-left:0;
  }
  .fc-life-squares .legend-item { display:flex; align-items:center; gap:5px; font-size:11px; color:var(--fg3); }
  .fc-life-squares .legend-dot {
    width:12px; height:12px; border-radius:0; flex-shrink:0;
    border:1px solid var(--fg); background:var(--fg);
  }
  .fc-life-squares .legend-dot--early {
    background-color:var(--fg);
    background-image:var(--pat-01);
    background-size:14px 8px;
  }
  .fc-life-squares .legend-dot--social {
    background-color:var(--fg);
    background-image:var(--pat-like);
    background-size:10px 10px;
  }
  .fc-life-squares .legend-dot--crisis {
    background-color:var(--fg);
    background-image:var(--pat-x);
    background-size:6px 6px;
  }
  .fc-life-squares .legend-dot--now {
    background:var(--fg);
    position:relative;
  }
  .fc-life-squares .legend-dot--now::after {
    content:'×';
    position:absolute; inset:0;
    display:flex; align-items:center; justify-content:center;
    font-size:9px; font-weight:600; color:var(--white); line-height:1;
  }
  .fc-life-squares .legend-dot--future {
    background:var(--white);
    position:relative;
  }
  .fc-life-squares .legend-dot--future::after {
    content:'Ω';
    position:absolute; inset:0;
    display:flex; align-items:center; justify-content:center;
    font-size:8px; color:var(--fg); line-height:1;
  }

  
  .fc-life-squares .age-banner {
    background:var(--fg); color:var(--bg);
    border-radius:0; padding:14px 20px;
    display:flex; align-items:center; gap:16px; flex-wrap:wrap;
    margin-bottom:18px;
  }
  .fc-life-squares .controls .age-banner--intro {
    width:100%;
    margin-bottom:0;
    flex-direction:column;
    align-items:flex-start;
    gap:12px;
    padding:12px 14px;
  }
  .fc-life-squares .controls .age-banner--intro .age-banner-text {
    flex:none;
    min-width:0;
    width:100%;
    font-size:12px;
    line-height:1.5;
  }
  .fc-life-squares .controls .age-banner--intro .age-nums {
    width:100%;
    gap:14px;
  }
  .fc-life-squares .controls .age-banner--intro .age-stat-val {
    font-size:18px;
  }
  .fc-life-squares .fc-life-mode-bar {
    width:100%;
    margin-bottom:18px;
  }
  .fc-life-squares .fc-life-mode-bar .toggle-group {
    width:100%;
    flex-wrap:wrap;
    justify-content:stretch;
  }
  .fc-life-squares .fc-life-mode-bar .toggle-btn {
    flex:1 1 auto;
    text-align:center;
  }
  .fc-life-squares .age-banner-text { font-size:13px; font-weight:300; opacity:.75; flex:1; min-width:200px; }
  .fc-life-squares .age-nums { display:flex; gap:22px; flex-wrap:wrap; }
  .fc-life-squares .age-stat { min-width:4.5rem; }
  .fc-life-squares .age-stat-val {
    font-family:'Playfair Display',serif; font-style:italic;
    font-size:22px; line-height:1; margin-bottom:2px;
  }
  .fc-life-squares .age-stat-label { font-size:10px; opacity:1; color:var(--white); letter-spacing:.08em; text-transform:uppercase; }

  
  .fc-life-squares .squares-grid {
    container-type: inline-size;
    display:grid;
    grid-template-columns:repeat(10, minmax(0, 1fr));
    gap: clamp(2px, 0.6vw, 4px);
    width: 100%;
    max-width: 100%;
    margin-bottom:0;
  }
  .fc-life-squares {
    --pat-01: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='8' viewBox='0 0 14 8'%3E%3Ctext x='0' y='7' font-size='6' font-family='ui-monospace,monospace' fill='%23fff'%3E0%3C/text%3E%3Ctext x='7' y='7' font-size='6' font-family='ui-monospace,monospace' fill='%23fff'%3E1%3C/text%3E%3C/svg%3E");
    --pat-like: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 10 10'%3E%3Cpath fill='%23fff' d='M2 4.5V9h1.2V4.5H2zm2.2-1.4c0-.8.6-1.4 1.4-1.4.4 0 .8.2 1 .6l.5 2.3h1.4v2.6H6.2L5.4 9H3.2V3.1h1z'/%3E%3C/svg%3E");
    --pat-x: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='6' height='6' viewBox='0 0 6 6'%3E%3Ctext x='0' y='5' font-size='5' font-family='sans-serif' fill='%23fff'%3E×%3C/text%3E%3C/svg%3E");
  }

  .fc-life-squares .sq {
    aspect-ratio:1; border-radius:0; cursor:pointer; position:relative;
    border:1px solid color-mix(in srgb, var(--fg) 35%, transparent);
    background:var(--white);
    transition:transform .12s, box-shadow .12s;
  }
  .fc-life-squares .sq--gradient {
    background-image:none !important;
  }
  .fc-life-squares .sq--gradient::after {
    display:none !important;
  }
  .fc-life-squares .sq:hover { transform:scale(1.2); z-index:10; box-shadow:0 3px 14px rgba(0,0,0,.18); }
  .fc-life-squares .sq.active { border-width:2px; border-color:var(--fg); transform:scale(1.12); z-index:10; box-shadow:0 4px 16px rgba(0,0,0,.22); }
  .fc-life-squares .sq .sq-year,
  .fc-life-squares .detail-panel-placeholder__text {
    font-family:'Playfair Display',Georgia,serif;
    font-style:italic;
    font-weight:400;
    line-height:1;
    letter-spacing:0;
  }

  .fc-life-squares .sq .sq-year {
    position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
    font-size: clamp(4px, 2.35cqi, 9px);
    pointer-events:none; z-index:1;
    color:inherit;
  }

  .fc-life-squares .detail-panel-placeholder {
    border:1px solid var(--border2);
    background:transparent;
    min-height:clamp(100px, 14vw, 160px);
    display:flex;
    align-items:flex-start;
    justify-content:center;
    padding:clamp(16px, 2.5vw, 24px);
    margin-bottom:18px;
    box-sizing:border-box;
  }
  .fc-life-squares .detail-panel-placeholder.is-hidden {
    display:none;
  }
  .fc-life-squares .detail-panel-placeholder__text {
    margin:0;
    width:100%;
    text-align:center;
    font-size:clamp(18px, 2vw, 26px);
    color:var(--fg2);
  }

  
  .fc-life-squares .detail-panel {
    display:none;
    background:var(--white); border-radius:0; border:1px solid var(--border);
    overflow:hidden;
  }
  .fc-life-squares .detail-panel.visible {
    display:block;
    opacity:1;
    transform:translateY(0);
    pointer-events:all;
    animation:fc-life-panel-in .22s ease;
  }
  @keyframes fc-life-panel-in {
    from { opacity:0; transform:translateY(10px); }
    to { opacity:1; transform:translateY(0); }
  }

  
  .fc-life-squares .panel-tabs {
    display:flex; border-bottom:1px solid var(--border); padding:0 24px; gap:0;
  }
  .fc-life-squares .ptab {
    font-size:12px; font-weight:500; padding:12px 16px; cursor:pointer;
    border-bottom:2px solid transparent; color:var(--fg3);
    transition:color .15s, border-color .15s; white-space:nowrap;
    background:none; border-top:none; border-left:none; border-right:none;
    font-family:'DM Sans',sans-serif;
  }
  .fc-life-squares .ptab.active { color:var(--fg); border-bottom-color:var(--fg); }

  .fc-life-squares .panel-header {
    padding:20px 24px 16px;
    display:flex; align-items:flex-end; justify-content:space-between; gap:16px;
  }
  .fc-life-squares .panel-year-wrap {
    display:flex;
    flex-direction:column;
    align-items:flex-start;
    gap:8px;
    flex-shrink:0;
  }
  .fc-life-squares .panel-year {
    font-family:'Playfair Display',serif; font-size:50px; font-style:italic;
    color:var(--fg); line-height:1; flex-shrink:0;
  }
  .fc-life-squares .panel-year.panel-year--hint {
    font-family:'DM Sans',sans-serif;
    font-size:16px;
    font-style:normal;
    font-weight:400;
    line-height:1.35;
    max-width:22ch;
  }
  .fc-life-squares .panel-hdr-right { flex:1; display:flex; align-items:flex-end; min-height:50px; }
  .fc-life-squares .panel-era-tag {
    display:inline-block; font-size:10px; font-weight:500; letter-spacing:.1em;
    text-transform:uppercase; padding:3px 10px; border-radius:0; margin-bottom:0;
  }
  .fc-life-squares .panel-event { font-family:'Playfair Display',serif; font-style:italic; font-size:17px; line-height:1.3; margin-bottom:0; }
  .fc-life-squares .panel-event-sub { display:none; }
  .fc-life-squares .panel-close {
    background:none; border:none; cursor:pointer; font-size:22px;
    color:var(--fg3); transition:color .15s; flex-shrink:0; line-height:1;
  }
  .fc-life-squares .panel-close:hover { color:var(--fg); }

  
  .fc-life-squares .tab-content { display:none; }
  .fc-life-squares .tab-content.active { display:block; }

  
  .fc-life-squares .panel-stats {
    display:grid; grid-template-columns:repeat(5,minmax(0,1fr));
    border-top:1px solid var(--border);
  }
  .fc-life-squares .stat-cell { padding:16px 18px; border-right:1px solid var(--border); }
  .fc-life-squares .stat-cell:last-child { border-right:none; }
  .fc-life-squares .stat-label { font-size:10px; font-weight:500; letter-spacing:.1em; text-transform:uppercase; color:var(--fg3); margin-bottom:5px; }
  .fc-life-squares .stat-val { font-family:'Playfair Display',serif; font-style:italic; font-size:24px; line-height:1; margin-bottom:3px; }
  .fc-life-squares .stat-desc { font-size:11px; color:var(--fg2); line-height:1.4; font-weight:300; }
  .fc-life-squares .stat-trend { font-size:11px; margin-top:4px; font-weight:500; }
  .fc-life-squares .bad { color:var(--red); }
  .fc-life-squares .ok { color:var(--amber); }
  .fc-life-squares .good { color:var(--green); }

  
  .fc-life-squares .panel-prose { display:block; width:100%; }
  .fc-life-squares .insight-text { font-size:12px; color:var(--fg2); line-height:1.62; font-weight:300; max-width:none; }
  .fc-life-squares .insight-flow {
    padding:16px 24px;
    border-top:1px solid var(--border);
    width:100%;
    box-sizing:border-box;
  }

  
  .fc-life-squares .pos-grid { display:flex; flex-direction:column; }
  .fc-life-squares .pos-block { padding:16px 24px; border-top:1px solid var(--border); width:100%; box-sizing:border-box; }
  .fc-life-squares .pos-head { display:flex; align-items:center; gap:8px; margin-bottom:4px; }
  .fc-life-squares .pos-icon { font-size:18px; line-height:1; }
  .fc-life-squares .pos-title { font-size:13px; font-weight:500; }
  .fc-life-squares .pos-text { font-size:12px; color:var(--fg2); line-height:1.6; font-weight:300; }

  
  .fc-life-squares .global-grid { display:flex; flex-direction:column; }
  .fc-life-squares .global-block { padding:16px 24px; border-top:1px solid var(--border); width:100%; box-sizing:border-box; }
  .fc-life-squares .global-region { font-size:10px; font-weight:500; text-transform:uppercase; letter-spacing:.1em; margin-bottom:5px; }
  .fc-life-squares .global-text { font-size:12px; color:var(--fg2); line-height:1.6; font-weight:300; }

  
  .fc-life-squares .agency-intro {
    padding:18px 24px 16px; font-size:13px; color:var(--fg); line-height:1.6;
    border-bottom:none; font-weight:300;
  }
  .fc-life-squares .agency-intro strong { color:var(--fg); font-weight:500; }
  .fc-life-squares .agency-grid { display:grid; grid-template-columns:1fr 1fr 1fr; gap:0; }
  .fc-life-squares .agency-block { padding:16px 18px; border-right:1px solid var(--border); border-top:1px solid var(--border); }
  .fc-life-squares .agency-block:nth-child(3n) { border-right:none; }
  .fc-life-squares .agency-icon { font-size:20px; margin-bottom:7px; }
  .fc-life-squares .agency-title { font-size:13px; font-weight:500; margin-bottom:4px; }
  .fc-life-squares .agency-choice { font-size:12px; color:var(--fg); line-height:1.6; margin-bottom:6px; font-weight:400; }
  .fc-life-squares .agency-why { font-size:11px; color:var(--fg2); line-height:1.55; font-weight:300; }
  .fc-life-squares .agency-tag { display:inline-block; margin-top:7px; font-size:10px; padding:2px 8px; border-radius:0; font-weight:500; background:var(--teal-bg); color:var(--teal); }

  
  .fc-life-squares .fc-cta {
    margin-top:20px; background:var(--white); border-radius:0;
    border:1px solid var(--border); padding:20px 24px;
    display:flex; align-items:center; justify-content:space-between; gap:20px; flex-wrap:wrap;
  }
  .fc-life-squares .fc-cta-text { font-size:14px; line-height:1.6; max-width:500px; }
  .fc-life-squares .fc-cta-text strong { color:var(--fg); font-weight:500; }
  .fc-life-squares .fc-cta-text span { color:var(--fg2); font-weight:300; }
  .fc-life-squares .fc-btn {
    display:inline-block; background:var(--fg); color:var(--bg);
    font-family:'DM Sans',sans-serif; font-size:12px; font-weight:500;
    letter-spacing:.1em; text-transform:uppercase; padding:12px 28px;
    border-radius:0; border:none; cursor:pointer; white-space:nowrap;
    transition:opacity .18s;
  }
  .fc-life-squares .fc-btn:hover { opacity:.75; }

  @media(max-width:900px) {
    .fc-life-squares .fc-life-layout {
      grid-template-columns: 1fr;
    }
    .fc-life-squares .fc-life-layout__grid {
      width: 100%;
      justify-content: stretch;
    }
    .fc-life-squares .squares-grid {
      width: 100%;
      max-width: none;
    }
  }

  @media(max-width:640px) {
    .fc-life-squares { padding:32px 14px 70px; }
    .fc-life-squares .headline { font-size:26px; }
    .fc-life-squares .panel-stats, .fc-life-squares .agency-grid { grid-template-columns:1fr 1fr; }
    .fc-life-squares .stat-cell, .fc-life-squares .agency-block { border-right:none; }
    .fc-life-squares .legend { display:none; }
  }

.fc-life-squares a.fc-btn { text-decoration: none; display: inline-block; }
