/* Clean consolidated stylesheet
   - Registers Cera GR regular and bold via @font-face
   - Uses Roboto (loaded in index.html) as the site body font
   - Uses Cera GR (700) for headings/cluster labels
*/

/* Cera GR (regular 400) */
@font-face {
  font-family: 'Cera GR';
  src: url('https://db.onlinewebfonts.com/t/b2654d24a0afc19dabe02fba17411648.woff2') format('woff2'),
       url('https://db.onlinewebfonts.com/t/b2654d24a0afc19dabe02fba17411648.woff') format('woff'),
       url('https://db.onlinewebfonts.com/t/b2654d24a0afc19dabe02fba17411648.ttf') format('truetype');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

/* Cera GR (bold 700) */
@font-face {
  font-family: 'Cera GR';
  src: url('https://db.onlinewebfonts.com/t/d191325cfe4f374d6f43147fd57ab2d4.woff2') format('woff2'),
       url('https://db.onlinewebfonts.com/t/d191325cfe4f374d6f43147fd57ab2d4.woff') format('woff'),
       url('https://db.onlinewebfonts.com/t/d191325cfe4f374d6f43147fd57ab2d4.ttf') format('truetype');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

:root {
  --block-size: 220px;
  --gap: 2px;

  --block-1: #cf1973;
  --block-2: #fcbc17;
  --block-3: #0966b1;
  --block-4: #72c7ac;

  /* Typography */
  --cluster-label-size: 32px;
  --competency-label-size: 22px;
  --label-weight: 400;
  --info-size: 22px;
  --info-weight: 400;
  --text-color: #0b0f19;
  --info-width: 320px;
  --info-max-width: 480px;

  --radius: 5px;
  --border: 1px solid rgba(255,255,255,0.1);

  --footer-text-width: 460px;
  --modal-tab-border-width: 2px;
  --modal-tab-border-color: rgba(15,23,42,0.18);
  --modal-tab-gap: 12px;
  --modal-tab-side-inset: 24px;
  --modal-level-gap: 18px;
  --modal-level-divider-gap: 36px;
  --modal-level-card-bg: #f8f1e4;
  --modal-level-card-border: rgba(125, 89, 32, 0.12);
  --modal-level-card-heading-color: #636363;
  --modal-level-card-text-color: #2f2f2f;
}

/* Reset */
*{box-sizing:border-box;margin:0;padding:0}

/* Site font: Roboto (loaded via Google Fonts in index.html) */
body{
  font-family: 'Roboto', system-ui, -apple-system, 'Segoe UI', 'Helvetica Neue', Arial, sans-serif;
  font-weight:400;
  color:var(--text-color);
  background:#ffffff;
  min-height:100vh;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  align-items:stretch;
}

.scene{
  display:grid;
  place-items:center;
  padding:32px;
  flex:1;
}

.animal{
  display:grid;
  grid-template-columns:repeat(2,var(--block-size));
  grid-template-rows:repeat(2,var(--block-size));
  gap:var(--gap);
  position:relative;
  transform:rotate(45deg);
  transform-origin:center;
  isolation:isolate;
}

.block{
  width:var(--block-size);
  height:var(--block-size);
  border-radius:var(--radius);
  border:var(--border);
  position:relative;
  z-index:2;
  overflow:hidden;
  display:grid;
  place-items:center;
  text-align:center;
  font-weight:var(--label-weight);
  letter-spacing:0.4px;
  transition:opacity .35s ease, transform .35s ease;
}

/* Dim sibling clusters when a block is hovered */
.animal:not([data-expanded="true"]).is-focusing .block{opacity:0.25}
.animal.is-focusing .block.is-hovered{opacity:1}

.label{display:inline-block;transform:rotate(-45deg);text-align:center;font-size:var(--label-size);font-weight:var(--label-weight)}

/* Cluster titles use Cera GR bold */
.label-cluster{--label-size:var(--cluster-label-size);font-family:'Cera GR','Roboto',system-ui,sans-serif;font-weight:700}

/* Competency labels use Roboto regular */
.label-competency{--label-size:var(--competency-label-size);font-family:'Cera GR','Roboto',system-ui,sans-serif;font-weight:700}

.spawn-toggle{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:68px;height:68px;padding:0;border-radius:8px;border:none;background:transparent;display:grid;grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(2,1fr);gap:2px;cursor:pointer;box-shadow:0 0 0 2px rgba(15,23,42,0.32),0 8px 24px rgba(0,0,0,0.12);transition:transform .2s ease,box-shadow .2s ease;z-index:4}
.spawn-toggle:hover{transform:translate(-50%,-50%) scale(1.04);box-shadow:0 12px 28px rgba(0,0,0,0.16)}
.spawn-toggle.is-active{box-shadow:0 0 0 3px rgba(15,23,42,0.38),0 12px 28px rgba(0,0,0,0.25)}
.spawn-toggle-tooltip{position:absolute;left:50%;top:50%;transform:translate(-50%,-150%) rotate(-45deg) scale(.95);transform-origin:center;background:#f8f9fb;color:#0b0f19;padding:12px 24px;border-radius:18px;border:1px solid rgba(15,15,15,0.85);font-family:'Cera GR','Roboto',system-ui,sans-serif;font-weight:700;font-size:15px;letter-spacing:0.18px;box-shadow:0 18px 34px rgba(15,23,42,0.18);opacity:0;transition:opacity .12s ease,transform .12s ease;pointer-events:none;white-space:nowrap;z-index:6}
.spawn-toggle-tooltip[data-visible="true"]{opacity:1;transform:translate(-50%,-185%) rotate(-45deg) scale(1)}
.toggle-tile{width:100%;height:100%;border-radius:4px}
.toggle-tile.t1{background:var(--block-1)}
.toggle-tile.t2{background:var(--block-2)}
.toggle-tile.t3{background:var(--block-3)}
.toggle-tile.t4{background:var(--block-4)}

.spawn-block{position:absolute;left:50%;top:50%;width:var(--block-size);height:var(--block-size);border-radius:var(--radius);border:var(--border);display:grid;place-items:center;font-weight:700;letter-spacing:0.2px;color:#0b0f19;opacity:0;transform:translate(-50%,-50%) scale(0.4);pointer-events:auto;cursor:pointer;box-shadow:0 10px 26px rgba(0,0,0,0.18);transition:transform .18s ease;z-index:8}
.animal:not([data-expanded="true"]) .spawn-block{pointer-events:none;cursor:default}
.spawn-block-tooltip{position:absolute;left:50%;top:10%;transform:translate(-50%,-120%) rotate(-45deg) scale(.92);transform-origin:center;background:#f8f9fb;color:#0b0f19;padding:10px 18px;border-radius:16px;border:1px solid rgba(15,15,15,0.85);font-family:'Cera GR','Roboto',system-ui,sans-serif;font-weight:700;font-size:14px;letter-spacing:0.12px;box-shadow:0 12px 24px rgba(15,23,42,0.16);opacity:0;transition:opacity .12s ease,transform .12s ease;pointer-events:none;white-space:nowrap;z-index:12}
.spawn-block-tooltip b{font-weight:700}
.spawn-block-tooltip[data-visible="true"]{opacity:1;transform:translate(-50%,-158%) rotate(-45deg) scale(1)}

.info{position:absolute;left:50%;top:50%;padding:0;background:transparent;color:var(--text-color);font-size:var(--info-size);font-weight:var(--info-weight);line-height:1.2;opacity:0;pointer-events:none;transform:rotate(-45deg) translateY(6px);transition:opacity .2s ease,transform .2s ease;z-index:5;width:var(--info-width);max-width:var(--info-max-width)}

.animal:not([data-expanded="true"]) .block-1:hover ~ .info-1,
.animal:not([data-expanded="true"]) .block-2:hover ~ .info-2,
.animal:not([data-expanded="true"]) .block-3:hover ~ .info-3,
.animal:not([data-expanded="true"]) .block-4:hover ~ .info-4{opacity:1;transform:rotate(-45deg) translateY(0)}

/* Spawn colours */
.spawn-1a{background:#f1d5e3}
.spawn-1b{background:#df98ba}
.spawn-1c{background:#e4acc7}
.spawn-2a{background:#fcf0da}
.spawn-2b{background:#fadca8}
.spawn-2c{background:#fbe4bb}
.spawn-3a{background:#d5e1ed;color:#0b1222}
.spawn-3b{background:#96b2d7;color:#0b1222}
.spawn-3c{background:#acc1de;color:#0b1222}
.spawn-4a{background:#9bd8c6}
.spawn-4b{background:#b9e3d5}
.spawn-4c{background:#d8efe7}

.block-1{background:var(--block-1);color:#e8edf7}
.block-2{background:var(--block-2)}
.block-3{background:var(--block-3);color:#e8edf7}
.block-4{background:var(--block-4)}

.block::after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,0.14),transparent 45%);mix-blend-mode:screen;pointer-events:none}

.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.55);display:none;align-items:center;justify-content:center;padding:24px;z-index:999}
.modal-overlay.is-open{display:flex}
.modal{background:#ffffff;color:#0b0f19;width:88vw;max-width:1200px;max-height:86vh;border-radius:18px;border:1px solid rgba(15,23,42,0.06);box-shadow:0 28px 80px rgba(0,0,0,0.3);padding:34px 40px 38px;overflow:auto;position:relative}
.modal-title{font-family:'Cera GR','Roboto',system-ui,sans-serif;font-size:32px;margin-bottom:14px;letter-spacing:-0.3px;font-weight:700}
.modal-summary{font-size:20px;font-weight:700;margin-bottom:18px;line-height:1.5;color:#1f2937}
.modal-body{
  display:flex;
  flex-direction:column;
  gap:24px;
  padding:24px;
  background:#ffffff;
  border-radius:12px;
  box-shadow:none;
}

.modal-description{
  font-size:16px;
  line-height:1.7;
  display:grid;
  gap:14px;
}

.modal-tabs{
  display:flex;
  flex-direction:column;
  border-radius:16px;
  background:#ffffff;
  overflow:visible;
  position:relative;
}

.modal-tablist{
  display:flex;
  flex-wrap:wrap;
  gap:var(--modal-tab-gap);
  padding-left:calc(var(--modal-tab-side-inset) + var(--modal-tab-border-width));
  padding-right:calc(var(--modal-tab-gap) + var(--modal-tab-border-width));
  background:transparent;
  position:relative;
  align-items:flex-end;
  justify-content:flex-start;
  z-index:auto;
}

.modal-tab{
  flex:0 1 200px;
  padding:12px 18px;
  background:rgba(9,102,177,0.08);
  color:#0b0f19;
  font-family:'Cera GR','Roboto',system-ui,sans-serif;
  font-weight:700;
  font-size:15px;
  letter-spacing:0.2px;
  transition:background .18s ease,color .18s ease,opacity .18s ease,border-color .18s ease,filter .18s ease;
  cursor:pointer;
  position:relative;
  opacity:0.85;
  border-radius:14px 14px 0 0;
  border:var(--modal-tab-border-width) solid var(--modal-tab-border-color);
  margin-bottom:calc(-1 * var(--modal-tab-border-width));
  z-index:0;
}

.modal-tab:hover{
  background:rgba(9,102,177,0.18);
  opacity:1;
}

.modal-tab:focus-visible{
  outline:3px solid rgba(37,99,235,0.45);
  outline-offset:-3px;
}

.modal-tab.is-active{
  background:#ffffff;
  color:#0b0f19;
  opacity:1;
  border-color:var(--modal-tab-border-color);
  border-bottom-color:#ffffff;
  margin-bottom:-4px;
  z-index:3;
  filter:none;
  border-bottom-left-radius:0;
  border-bottom-right-radius:0;
}



.modal-tab:not(.is-active){
  z-index:0;
  border-bottom-color:transparent;
  clip-path:inset(0 0 var(--modal-tab-border-width) 0 round 14px 14px 0 0);
}

.modal-tab:not(.is-active)::after{display:none}

.modal-tab.is-active::after{
  content:"";
  position:absolute;
  left:calc(-1 * var(--modal-tab-border-width));
  right:calc(-1 * var(--modal-tab-border-width));
  bottom:calc(-1 * var(--modal-tab-border-width));
  height:var(--modal-tab-border-width);
  background:#ffffff;
  pointer-events:none;
  z-index:-1;
}

.modal-tabpanel{
  padding:22px 24px;
  background:#ffffff;
  border:var(--modal-tab-border-width) solid rgba(15,23,42,0.12);
  border-radius:10px 10px 16px 16px;
  margin-top:calc(-1 * var(--modal-tab-border-width));
  position:relative;
  z-index:1;
}

.modal-levels{
  display:flex;
  flex-direction:column;
  gap:var(--modal-level-divider-gap);
}

.modal-level-bar{
  display:flex;
  flex-wrap:wrap;
  gap:var(--modal-level-divider-gap);
  align-items:stretch;
}

.modal-level-group{
  display:flex;
  flex-direction:column;
  gap:var(--modal-level-gap);
  min-width:0;
}

.modal-level-group--intercultural{
  flex:1 1 220px;
}

.modal-level-group--transcultural{
  flex:3 1 420px;
}

.modal-level-heading{
  font-family:'Cera GR','Roboto',system-ui,sans-serif;
  font-size:16px;
  font-weight:700;
  letter-spacing:0.25px;
  color:var(--modal-level-card-heading-color);
}

.modal-level-group-cards{
  display:flex;
  flex:1 1 auto;
  gap:var(--modal-level-gap);
  flex-wrap:nowrap;
}

.modal-level-card{
  background:var(--modal-level-card-bg);
  border:1px solid var(--modal-level-card-border);
  border-radius:12px;
  padding:16px 18px;
  display:flex;
  flex-direction:column;
  gap:10px;
  min-width:0;
  flex:1 1 0;
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.45);
  transition:transform .18s ease;
}

.modal-level-card-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  font-family:'Cera GR','Roboto',system-ui,sans-serif;
  font-weight:700;
  font-size:17px;
  letter-spacing:0.2px;
  color:var(--modal-level-card-heading-color);
}

.modal-level-card-score{
  font-family:'Cera GR','Roboto',system-ui,sans-serif;
  font-weight:700;
  font-size:18px;
  color:#7d5920;
  letter-spacing:2px;
  display:inline-flex;
  align-items:center;
  line-height:1;
}

.modal-level-card-body{
  font-family:'Roboto',system-ui,-apple-system,'Segoe UI','Helvetica Neue',Arial,sans-serif;
  font-size:15px;
  line-height:1.6;
  color:var(--modal-level-card-text-color);
}

.modal-level-card--intercultural{
  max-width:360px;
}

.modal-levels-placeholder{
  background:rgba(249,250,251,0.9);
  border:1px dashed rgba(15,23,42,0.3);
  border-radius:10px;
  padding:18px;
  font-weight:600;
  text-align:center;
  color:#475569;
}
.modal-close{position:absolute;top:14px;right:14px;background:transparent;border:none;font-size:22px;cursor:pointer;color:#0b0f19;transition:transform .15s ease,color .15s ease}
.modal-close:hover{transform:scale(1.1)}
.modal-icon{position:absolute;top:16px;right:48px;width:122px;height:122px;color:#0b0f19;display:grid;place-items:center;font-family:'Cera GR','Roboto',system-ui,sans-serif;font-weight:800;pointer-events:none}
.modal-icon img{width:100px;height:100px;object-fit:contain;display:block}
.modal-icon-fallback{font-size:36px} 

.site-header{
  width:100%;
  padding:24px 32px 16px;
  display:flex;
  align-items:center;
  justify-content:flex-start;
}
.site-logo{height:150px;width:auto}
.site-footer{
  width:100%;
  padding:24px 32px 32px;
  display:flex;
  justify-content:flex-end;
}
.footer-content{
  display:flex;
  align-items:flex-end;
  gap:18px;
  flex-direction:column;
  text-align:left;
  width:var(--footer-text-width);
  max-width:100%;
}
.footer-images{
  display:flex;
  justify-content:flex-end;
  gap:12px;
  margin-bottom:12px;
}
.footer-images img{
  width:min(calc(var(--footer-text-width)/2),100%);
  height:auto;
}
.footer-logo{
  height:48px;
  width:auto;
  flex-shrink:0;
  margin-bottom:8px;
}
.footer-text{
  color:#2c3076;
  font-size:14px;
  line-height:1.45;
  max-width:var(--footer-text-width);
}
.footer-credit{
  margin-top:10px;
  font-size:12px;
  line-height:1.4;
  color:#475569;
}

.modal-level-card:hover{
  transform:translateY(-4px);
}

@media (max-width:960px){
  .modal-level-bar{
    flex-direction:column;
    gap:var(--modal-level-gap);
  }

  .modal-level-group--transcultural{
    flex:1 1 auto;
  }

  .modal-level-group--transcultural .modal-level-group-cards{
    flex-wrap:wrap;
  }

  .modal-level-group--transcultural .modal-level-card{
    flex:1 1 calc(50% - var(--modal-level-gap));
  }
}

@media (max-width:640px){
  .modal-level-group--transcultural .modal-level-card{
    flex:1 1 100%;
  }

  .modal-level-card--intercultural{
    max-width:none;
  }
}

@media (max-width:560px){
  :root{--block-size:96px;--gap:10px}
  .site-header,
  .site-footer{padding:16px 20px}
  .footer-content{flex-direction:column;align-items:flex-end;gap:12px;width:100%}
  .site-logo{height:44px}
  .footer-logo{height:40px}
  .footer-images{
    justify-content:flex-end;
  }
  .footer-images img{
    width:min(calc(var(--footer-text-width)/2),100%);
  }
}

@media (max-width:768px){
  .modal-body{padding:20px}
}