@import url("https://fonts.googleapis.com/css2?family=Michroma&display=swap");

:root {
  --bg: #f3f4f5;
  --surface: #f8f9fa;
  --surface-strong: #ffffff;
  --text: #111214;
  --muted: #60636b;
  --accent: #e1122f;
  --dark: #24262a;
  --line: rgba(17, 18, 20, 0.11);
  --shadow-raised: 9px 9px 22px rgba(174, 181, 189, 0.58),
    -9px -9px 22px rgba(255, 255, 255, 0.92);
  --shadow-pressed: inset 7px 7px 16px rgba(174, 181, 189, 0.42),
    inset -7px -7px 16px rgba(255, 255, 255, 0.86);
  font-family: "Gill Sans", "Gill Sans MT", Calibri, sans-serif;
}

/* Home hub motion, billboard, previews and explicit theme */
body { animation:page-arrive 520ms cubic-bezier(.22,1,.36,1) both; transition:opacity 220ms ease,transform 220ms ease,background 400ms ease,color 300ms ease }
body::before { content:"";position:fixed;inset:-30%;z-index:-1;background:linear-gradient(120deg,rgba(225,18,47,.12),rgba(85,185,243,.12),rgba(255,255,255,.05),rgba(225,18,47,.1));background-size:300% 300%;animation:gradient-drift 18s ease infinite;pointer-events:none }
body.is-leaving { opacity:0;transform:translateY(8px) scale(.995) }
@keyframes page-arrive { from{opacity:0;transform:translateY(12px) scale(.992)} to{opacity:1;transform:none} }
@keyframes gradient-drift { 0%,100%{background-position:0 50%} 50%{background-position:100% 50%} }
.theme-switch{align-self:end;min-height:42px;padding:0 14px;border:1px solid var(--line);border-radius:14px;color:var(--text);background:var(--surface);box-shadow:var(--shadow-raised);cursor:pointer;font:inherit;font-weight:700}
.billboard{position:relative;grid-column:1/-1;min-height:clamp(240px,38vw,470px);border:1px solid rgba(255,255,255,.18);border-radius:32px;color:#fff;background:linear-gradient(90deg,rgba(0,0,0,.78) 0%,rgba(0,0,0,.43) 47%,rgba(0,0,0,.08) 76%),url("Media Ressources/Logo/very important panda.jpg") center/cover no-repeat;box-shadow:var(--shadow-raised);overflow:hidden}
.billboard::after{content:"";position:absolute;width:260px;height:260px;right:-60px;top:-110px;border-radius:50%;background:rgba(255,255,255,.1);box-shadow:0 0 80px rgba(255,255,255,.13);animation:billboard-float 7s ease-in-out infinite alternate}
@keyframes billboard-float{to{transform:translate(-45px,45px) scale(1.15)}}
.billboard>*{position:relative;z-index:1}.billboard-link{display:flex;min-height:inherit;align-items:flex-end;justify-content:space-between;gap:24px;padding:clamp(24px,5vw,48px);color:#fff;text-decoration:none}.billboard-kicker{margin:0 0 8px;color:#ff9baa;font-weight:800;text-transform:uppercase;letter-spacing:.12em;font-size:.72rem}.billboard h1{font-size:clamp(2.5rem,8vw,5.8rem);line-height:.86}.billboard p:not(.billboard-kicker){max-width:650px;margin:14px 0 0;color:rgba(255,255,255,.82)}.billboard-cta{flex:0 0 auto;padding:13px 17px;border-radius:999px;color:#111;background:#fff;font-weight:800}
.icon-card:hover{transform:translateY(-7px) scale(1.025);box-shadow:14px 16px 30px rgba(174,181,189,.55),-9px -9px 22px rgba(255,255,255,.92)}.icon-symbol{transition:transform 260ms cubic-bezier(.22,1,.36,1)}.icon-card:hover .icon-symbol{transform:rotate(-5deg) scale(1.1)}
.desktop-preview{display:none;color:var(--muted);font-size:.74rem;line-height:1.25}
.home-item.is-open .widget-panel{max-height:1400px}
html[data-theme="dark"]{--bg:#191a1d;--surface:#222428;--surface-strong:#2b2e33;--text:#f4f5f6;--muted:#b8bcc5;--dark:#08090a;--line:rgba(255,255,255,.12);--shadow-raised:8px 8px 20px rgba(0,0,0,.42),-7px -7px 18px rgba(255,255,255,.05);--shadow-pressed:inset 7px 7px 16px rgba(0,0,0,.34),inset -7px -7px 16px rgba(255,255,255,.05)}
html[data-theme="dark"] body{background:radial-gradient(circle at top right,rgba(225,18,47,.18),transparent 30rem),linear-gradient(145deg,#24262a,var(--bg))}
html[data-theme="dark"] .cookie-message{background:rgba(34,36,40,.94)}
@media(min-width:760px){.preview-shortcut{grid-column:span 3}.preview-shortcut .icon-card{min-height:170px;align-content:center}.desktop-preview{display:block}.chronoplime-widget.is-open .widget-panel{min-height:430px;max-height:none;overflow:visible}}
@media(min-width:1060px){.preview-shortcut{grid-column:span 4}}
@media(max-width:620px){.billboard{min-height:340px;background-position:62% center}.billboard-link{display:grid;align-content:end}.billboard-cta{justify-self:start}.theme-switch{grid-column:1/-1}}
@media(prefers-reduced-motion:reduce){body,body::before,.billboard::after{animation:none!important}.icon-card:hover{transform:none}}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  min-height: 100vh;
  margin: 0;
  color: var(--text);
  background:
    radial-gradient(circle at top right, rgba(225, 18, 47, 0.08), transparent 30rem),
    linear-gradient(145deg, #fbfbfc, var(--bg));
}

a {
  color: inherit;
}

.topbar {
  position: fixed;
  z-index: 20;
  top: 0;
  left: 0;
  width: 100%;
  pointer-events: none;
}

.top-controls {
  position: absolute;
  top: 14px;
  left: 84px;
  display: flex;
  height: 58px;
  align-items: center;
  gap: 8px;
  pointer-events: auto;
}

.top-controls .theme-switch {
  display: grid;
  width: 44px;
  min-height: 44px;
  padding: 0;
  place-items: center;
  border-radius: 15px;
  font-size: 1.2rem;
}

.language-control select {
  height: 44px;
  padding: 0 12px;
  border: 1px solid var(--line);
  border-radius: 15px;
  color: var(--text);
  background: var(--surface);
  box-shadow: var(--shadow-raised);
  font: inherit;
  font-weight: 800;
}

.sr-only { position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0 }

.logo-button {
  position: absolute;
  top: 14px;
  left: 14px;
  width: 58px;
  height: 58px;
  padding: 7px;
  border: 0;
  border-radius: 18px;
  background: var(--surface);
  box-shadow: var(--shadow-raised);
  cursor: pointer;
  pointer-events: auto;
}

/* Larger, unified home controls */
.logo-button{width:116px;height:116px;padding:0;border-radius:0;background:transparent;box-shadow:none}
.logo-mark{border-radius:24px}
.top-controls{position:fixed;top:20px;right:20px;left:auto;height:52px}
.top-controls .theme-switch,.language-control select{width:52px;height:52px;min-height:52px;border-radius:17px;padding:0;text-align:center}
.language-control select{width:74px;appearance:none;background-image:none}
.language-control select,.hub-controls select{text-align:center;text-align-last:center;color:var(--text);background-color:var(--surface)}
.panda-bubble{top:144px;width:min(360px,calc(100vw - 32px));text-align:center}
.bubble-actions{justify-items:stretch}
.bubble-actions a{display:flex;align-items:center;justify-content:center;text-align:center;font-weight:800}
.home-shell{padding-top:164px}

.logo-button:focus-visible,
.icon-card:focus-visible,
.collapse-widget:focus-visible,
.panda-bubble a:focus-visible,
.panel-link:focus-visible,
.map-grid a:focus-visible {
  outline: 3px solid rgba(225, 18, 47, 0.45);
  outline-offset: 4px;
}

.logo-mark {
  width: 100%;
  height: 100%;
  border-radius: 13px;
  object-fit: cover;
  display: block;
}

.panda-bubble {
  position: absolute;
  top: 84px;
  left: 16px;
  width: min(330px, calc(100vw - 32px));
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: 20px;
  background: rgba(248, 249, 250, 0.94);
  box-shadow: var(--shadow-raised);
  backdrop-filter: blur(16px);
  pointer-events: auto;
}

.panda-bubble::before {
  content: "";
  position: absolute;
  top: -10px;
  left: 24px;
  width: 20px;
  height: 20px;
  background: inherit;
  border-top: 1px solid var(--line);
  border-left: 1px solid var(--line);
  transform: rotate(45deg);
}

.bubble-question {
  margin: 0 0 14px;
  font-weight: 700;
}

.bubble-actions {
  display: grid;
  gap: 8px;
}

.bubble-actions a {
  min-height: 42px;
  padding: 11px 13px;
  border-radius: 14px;
  background: var(--surface-strong);
  text-decoration: none;
  box-shadow: inset 0 0 0 1px var(--line);
}

.home-shell {
  width: min(1180px, 100%);
  margin: 0 auto;
  padding: 112px 20px 48px;
}

.hub-controls {
  display: flex;
  grid-column: 1 / -1;
  justify-content: center;
  gap: 10px;
  margin: 2px 0 12px;
}

.hub-controls label {
  display: grid;
  gap: 5px;
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
}

.hub-controls select {
  min-height: 42px;
  padding: 0 38px 0 14px;
  border: 1px solid var(--line);
  border-radius: 14px;
  color: var(--text);
  background: var(--surface);
  box-shadow: var(--shadow-raised);
  font: inherit;
  text-transform: none;
}

.eyebrow,
.panel-head p,
.section-title p {
  margin: 0 0 7px;
  color: var(--accent);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0;
  text-transform: uppercase;
}

h1,
h2,
h3,
p {
  overflow-wrap: anywhere;
}

h1 {
  margin: 0;
  font-family: Microgramma, Michroma, Eurostile, "Arial Black", sans-serif;
  font-size: clamp(2.9rem, 13vw, 7.5rem);
  line-height: 0.9;
}

.home-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
  align-items: start;
}

.home-item {
  min-width: 0;
}

.icon-card {
  display: grid;
  width: 100%;
  max-height: 150px;
  min-height: 116px;
  padding: 16px;
  border: 0;
  border-radius: 24px;
  place-items: center;
  gap: 10px;
  color: var(--text);
  background: var(--surface);
  box-shadow: var(--shadow-raised);
  text-align: center;
  text-decoration: none;
  cursor: pointer;
  overflow: hidden;
  transform: scale(1);
  opacity: 1;
  transition:
    max-height 260ms ease,
    min-height 260ms ease,
    padding 260ms ease,
    opacity 180ms ease,
    transform 260ms ease,
    box-shadow 260ms ease;
}

.icon-symbol {
  display: grid;
  width: 58px;
  height: 58px;
  border-radius: 18px;
  place-items: center;
  color: var(--surface-strong);
  background: var(--accent);
  font-size: 2rem;
  font-weight: 700;
  line-height: 1;
}

.page-shortcut[data-type="music"] .icon-symbol { background:#e1122f }
.page-shortcut[data-type="music"] .icon-symbol { background:#04b9d8 }
.page-shortcut[data-type="media"] .icon-symbol { background:#d6488f }
.page-shortcut[data-type="languages"] .icon-symbol { background:#168c78 }
.page-shortcut[data-type="games"] .icon-symbol { background:#7657d5 }
.page-shortcut[data-type="utilities"] .icon-symbol { background:#2878c8 }
.page-shortcut[data-type="community"] .icon-symbol { background:#d77b18 }
.external-shortcut[data-type] .icon-symbol { background:color-mix(in srgb,currentColor 0%,var(--type-color,#24262a)) }
.page-shortcut[data-type="music"] { --type-color:#e1122f }
.page-shortcut[data-type="music"] { --type-color:#04b9d8 }
.page-shortcut[data-type="media"] { --type-color:#d6488f }
.page-shortcut[data-type="languages"] { --type-color:#168c78 }
.page-shortcut[data-type="games"] { --type-color:#7657d5 }
.page-shortcut[data-type="utilities"] { --type-color:#2878c8 }
.page-shortcut[data-type="community"] { --type-color:#d77b18 }
.external-shortcut .icon-symbol { background:var(--type-color) }

body.has-wallpaper {
  background-image:linear-gradient(rgba(243,244,245,.42),rgba(243,244,245,.64)),var(--hub-wallpaper);
  background-size:cover;
  background-repeat:no-repeat;
  background-position:center, var(--wallpaper-x,50%) calc(var(--wallpaper-y,50%) + var(--wallpaper-scroll,0px));
  background-attachment:fixed;
  transition:background-position 120ms ease-out;
}
html[data-theme="dark"] body.has-wallpaper {
  background-image:linear-gradient(rgba(15,16,18,.46),rgba(15,16,18,.68)),var(--hub-wallpaper);
}

.emoji-word{display:inline-block;vertical-align:baseline;text-align:center;white-space:nowrap;transition:transform .3s ease,filter .3s ease}
.emoji-word.is-reading{transform:translateY(-2px) scale(1.18);filter:drop-shadow(0 4px 7px rgba(225,18,47,.28))}

/* Dark surfaces use the same tokens as the rest of the hub. */
html[data-theme="dark"] .widget-panel,
html[data-theme="dark"] .site-map,
html[data-theme="dark"] .panda-bubble{background:rgba(34,36,40,.92)}
html[data-theme="dark"] .link-groups a,
html[data-theme="dark"] .panel-link,
html[data-theme="dark"] .map-grid a,
html[data-theme="dark"] .calendar-list li,
html[data-theme="dark"] .collapse-widget,
html[data-theme="dark"] .bubble-actions a{background:var(--surface-strong);color:var(--text)}
html[data-theme="dark"] .calendar-list span{color:var(--text)}

/* Gill Sans remains regular; emphasis uses the display face. */
body,button,select,input,textarea{font-weight:400}
strong,b,.bubble-question,.bubble-actions a,.icon-label,.panel-link,.map-grid a,.hub-controls label,.calendar-list time,.photo-grid figcaption,.cookie-message a{font-family:Microgramma,Michroma,Eurostile,"Arial Black",sans-serif;font-weight:400}

.hub-controls,.hub-controls label,.hub-controls select{text-align:center}
.hub-controls label{align-items:center}

.photo-shell{width:min(1180px,calc(100% - 32px));margin:0 auto;padding:110px 0 70px}.photo-intro{max-width:760px;margin-bottom:28px}.photo-intro p{color:var(--muted);font-size:1.08rem}.photo-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:20px}.photo-grid figure{margin:0;padding:12px;border-radius:26px;background:var(--surface);box-shadow:var(--shadow-raised)}.photo-grid img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:18px}.photo-grid figcaption{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 4px 2px;font-weight:800}.photo-grid button,.wallpaper-reset{padding:10px 13px;border:0;border-radius:999px;color:#fff;background:var(--accent);cursor:pointer;font:inherit;font-weight:800}.photo-grid button.is-selected{background:#168c78}

.icon-label {
  font-size: 0.95rem;
  font-weight: 700;
}

.icon-note {
  color: var(--muted);
  font-size: 0.68rem;
  font-weight: 700;
}

.icon-symbol--emoji{font-size:1.35rem;letter-spacing:-.18em;padding-right:.18em}
.ipand-panel,.live-widget-panel{display:flex;flex-direction:column}
.ipand{display:grid;justify-items:center;gap:12px;margin:auto;width:min(100%,280px);padding:14px;border-radius:28px;background:#04b9d8;box-shadow:inset 4px 4px 10px rgba(255,255,255,.35),inset -5px -5px 12px rgba(0,0,0,.16)}
.ipand-screen{width:100%;height:168px;padding:10px;border:5px solid #202326;border-radius:15px;background:#eef6ed;color:#151515;overflow:hidden}
.ipand-menu,.ipand-view{display:none;height:100%}.ipand-menu.is-active,.ipand-view.is-active{display:grid}
.ipand-menu{align-content:start}.ipand-menu button,.ipand-menu a{display:flex;min-height:36px;align-items:center;padding:6px 9px;border:0;border-bottom:1px solid rgba(0,0,0,.14);background:transparent;color:#151515;text-align:left;text-decoration:none;font:400 .78rem Microgramma,Michroma,sans-serif;cursor:pointer}.ipand-menu button:hover,.ipand-menu a:hover{color:#fff;background:#04b9d8}
.ipand-view{align-content:start;gap:4px}.ipand-view iframe{width:100%;height:96px;border:0}.ipand-game canvas{width:100%;height:auto;border-radius:6px}.ipand-game small{text-align:center}
.ipand-wheel{position:relative;width:150px;height:150px;border-radius:50%;background:#f7f7f5;box-shadow:inset 4px 4px 10px rgba(0,0,0,.12),inset -4px -4px 10px #fff}.ipand-wheel button{position:absolute;border:0;color:#555;background:transparent;font:400 .67rem Microgramma,Michroma,sans-serif;cursor:pointer}.ipand-wheel [data-ipand-action="menu"]{top:15px;left:50%;transform:translateX(-50%)}.ipand-wheel [data-ipand-action="left"]{left:13px;top:50%;transform:translateY(-50%)}.ipand-wheel [data-ipand-action="right"]{right:13px;top:50%;transform:translateY(-50%)}.ipand-wheel [data-ipand-action="play"]{bottom:14px;left:50%;transform:translateX(-50%)}.ipand-wheel [data-ipand-action="select"]{left:50%;top:50%;width:58px;height:58px;border-radius:50%;transform:translate(-50%,-50%);color:#04b9d8;background:#d9dadd;box-shadow:inset 2px 2px 5px rgba(0,0,0,.12)}
.video-frame{position:relative;width:100%;aspect-ratio:16/9;margin-bottom:12px;border-radius:16px;overflow:hidden;background:#111}.video-frame iframe{position:absolute;inset:0;width:100%;height:100%}

.external-shortcut .icon-symbol {
  background: var(--dark);
}

.page-shortcut[hidden] {
  display: none;
}

.cookie-message {
  position: fixed;
  z-index: 30;
  right: 18px;
  bottom: 18px;
  display: flex;
  max-width: min(520px, calc(100vw - 36px));
  align-items: center;
  gap: 12px;
  padding: 13px 14px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: rgba(248, 249, 250, 0.94);
  box-shadow: var(--shadow-raised);
  backdrop-filter: blur(18px);
}

.cookie-message[hidden] { display: none; }
.cookie-message a { color: var(--accent); font-weight: 700; }
.cookie-message button {
  width: 30px;
  height: 30px;
  border: 0;
  border-radius: 50%;
  color: var(--accent);
  background: var(--surface-strong);
  cursor: pointer;
  font-size: 1.2rem;
}

.recipe-shell {
  width: min(720px, calc(100% - 28px));
  margin: 0 auto;
  padding: 110px 0 60px;
}

.recipe-card {
  padding: clamp(24px, 6vw, 54px);
  border: 1px solid var(--line);
  border-radius: 34px;
  background: var(--surface);
  box-shadow: var(--shadow-raised);
}

.recipe-card h1 { font-size: clamp(3rem, 12vw, 6rem); }
.recipe-intro { color: var(--muted); font-size: 1.1rem; }
.ingredients { display: grid; gap: 10px; padding: 0; list-style: none; }
.ingredients li {
  padding: 14px 16px;
  border-radius: 16px;
  background: var(--surface-strong);
  box-shadow: inset 0 0 0 1px var(--line);
}
.ingredients strong { color: var(--accent); }
.recipe-home {
  display: inline-flex;
  margin-top: 18px;
  padding: 12px 16px;
  border-radius: 999px;
  color: white;
  background: var(--accent);
  text-decoration: none;
  font-weight: 700;
}

.icon-symbol--text {
  font-size: 1.25rem;
  letter-spacing: -0.04em;
}
.icon-symbol--wide { display:grid; align-content:center; gap:0; font-size:clamp(.72rem,2vw,1rem); line-height:1.05; letter-spacing:.02em; }
.icon-logo {
  width: min(82px, 72%);
  height: 72px;
  object-fit: contain;
  filter: drop-shadow(0 6px 9px rgba(17,18,20,.12));
  transition: transform 260ms cubic-bezier(.22,1,.36,1);
}
.icon-card:hover .icon-logo { transform: rotate(-3deg) scale(1.08); }

.widget-panel {
  max-height: 0;
  margin-top: 0;
  padding: 0 20px;
  border: 0 solid var(--line);
  border-radius: 24px;
  background: rgba(248, 249, 250, 0.78);
  box-shadow: var(--shadow-pressed);
  opacity: 0;
  overflow: hidden;
  transform: translateY(10px) scale(0.985);
  transform-origin: top center;
  transition:
    max-height 360ms cubic-bezier(0.22, 1, 0.36, 1),
    margin-top 260ms ease,
    padding 260ms ease,
    border-width 260ms ease,
    opacity 220ms ease,
    transform 320ms cubic-bezier(0.22, 1, 0.36, 1);
}

.home-item.is-open .widget-panel {
  max-height: 900px;
  margin-top: 14px;
  padding: 20px;
  border-width: 1px;
  opacity: 1;
  transform: translateY(0) scale(1);
}

.home-item.is-open .icon-card {
  max-height: 0;
  min-height: 0;
  padding-top: 0;
  padding-bottom: 0;
  opacity: 0;
  pointer-events: none;
  transform: translateY(-6px) scale(0.94);
}

.home-item.is-settled.is-open .icon-card {
  display: none;
}

.home-item.is-settled:not(.is-open) .widget-panel {
  display: none;
}

.panel-head h2,
.section-title h2 {
  margin: 0 0 14px;
  font-size: 1.6rem;
}

.panel-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.collapse-widget {
  flex: 0 0 auto;
  width: 34px;
  height: 34px;
  border: 0;
  border-radius: 50%;
  color: var(--accent);
  background: var(--surface-strong);
  box-shadow: inset 0 0 0 1px var(--line);
  cursor: pointer;
  font-size: 1.3rem;
  line-height: 1;
}

.widget-panel p {
  margin: 0 0 12px;
  color: var(--muted);
  line-height: 1.5;
}

.link-groups {
  display: grid;
  gap: 16px;
}

.link-groups h3 {
  margin: 0 0 8px;
  font-size: 1rem;
}

.link-groups a,
.panel-link,
.map-grid a {
  display: flex;
  min-height: 40px;
  align-items: center;
  padding: 9px 12px;
  border-radius: 14px;
  background: var(--surface-strong);
  color: var(--dark);
  text-decoration: none;
  box-shadow: inset 0 0 0 1px var(--line);
}

.link-groups a + a {
  margin-top: 8px;
}

.time-readout {
  display: grid;
  grid-template-columns: minmax(0,1fr) auto;
  align-items: center;
  gap: 16px;
  margin: 6px 0 14px;
  padding: 18px;
  border-radius: 20px;
  background: var(--dark);
  color: white;
}

.time-readout > div:first-child { display:grid; }
.time-readout span {
  font-size: clamp(1.55rem, 4vw, 2.65rem);
  font-weight: 700;
  line-height: 1;
  white-space: nowrap;
}

.time-readout small {
  margin-top: 7px;
  color: rgba(255, 255, 255, 0.72);
}
.chronoplime-pulse { width:58px; height:58px; }
.chronoplime-pulse svg { display:block; width:100%; height:100%; transform:rotate(-90deg); }
.chronoplime-pulse circle {
  fill:none;
  stroke:var(--accent);
  stroke-width:5;
  stroke-linecap:round;
  stroke-dasharray:138.23;
  stroke-dashoffset:138.23;
  animation:chronoplime-close 5.4s linear infinite;
}
@keyframes chronoplime-close {
  0% { stroke-dashoffset:138.23; opacity:.35; }
  92% { stroke-dashoffset:0; opacity:1; }
  100% { stroke-dashoffset:0; opacity:0; }
}

.calendar-list {
  display: grid;
  gap: 10px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.calendar-list li {
  display: block;
}
.calendar-list a {
  display: grid;
  grid-template-columns: minmax(82px, 0.7fr) minmax(0, 1.3fr);
  gap: 10px;
  align-items: center;
  min-height: 46px;
  padding: 10px 12px;
  border-radius: 15px;
  background: var(--surface-strong);
  box-shadow: inset 0 0 0 1px var(--line);
  color:inherit;
  text-decoration:none;
  transition:transform 180ms ease,box-shadow 180ms ease;
}
.calendar-list a:hover { transform:translateY(-2px); box-shadow:inset 0 0 0 1px var(--accent); }

.calendar-list time {
  color: var(--accent);
  font-weight: 700;
}

.calendar-list span {
  color: var(--dark);
}

.site-map {
  margin-top: 28px;
  padding: 24px;
  border-radius: 28px;
  background: rgba(248, 249, 250, 0.76);
  box-shadow: var(--shadow-pressed);
}

.map-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 10px;
}

@media (min-width: 760px) {
  .home-grid {
    grid-template-columns: repeat(6, minmax(0, 1fr));
  }

  .page-shortcut {
    grid-column: span 2;
  }

  .about-widget,
  .links-widget,
  .chronoplime-widget,
  .faq-widget,
  .calendar-widget {
    grid-column: span 2;
  }

  .about-widget .widget-panel,
  .links-widget .widget-panel,
  .chronoplime-widget .widget-panel,
  .faq-widget .widget-panel,
  .calendar-widget .widget-panel {
    min-height: 0;
  }

  .about-widget.is-open .widget-panel,
  .links-widget.is-open .widget-panel,
  .chronoplime-widget.is-open .widget-panel,
  .faq-widget.is-open .widget-panel,
  .calendar-widget.is-open .widget-panel {
    min-height: 360px;
  }

  .about-widget {
    grid-column: span 3;
  }

  .links-widget {
    grid-column: span 3;
  }

  .chronoplime-widget {
    grid-column: span 3;
  }

  .faq-widget {
    grid-column: span 3;
  }

  .chronoplime-widget .widget-panel {
    margin: 0;
  }

  .link-groups {
    grid-template-columns: 1fr 1fr;
  }
}

@media (min-width: 1060px) {
  .home-grid {
    grid-template-columns: repeat(12, minmax(0, 1fr));
  }

  .page-shortcut {
    grid-column: span 2;
  }

  .about-widget {
    grid-column: 1 / span 5;
    grid-row: 3;
  }

  .links-widget {
    grid-column: span 4;
  }

  .chronoplime-widget {
    grid-column: 6 / span 3;
    grid-row: 3;
  }

  .faq-widget {
    grid-column: span 3;
  }

  .calendar-widget {
    grid-column: 9 / span 4;
    grid-row: 3;
  }

  .chronoplime-widget .widget-panel {
    margin-top: 0;
  }
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    scroll-behavior: auto !important;
    transition-duration: 1ms !important;
    animation-duration: 1ms !important;
  }
}

@media (max-width: 520px) {
  .home-shell { padding:138px 14px 34px }

  .home-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
  }

  .hub-controls {
    display: grid;
    grid-template-columns: 1fr 1fr;
  }

  .logo-button{top:10px;left:10px;width:88px;height:88px}
  .top-controls{top:18px;right:12px;left:auto;height:52px}
  .panda-bubble{top:118px}

  .about-widget{grid-column:1/-1;order:-1}
  .about-widget .icon-card{min-height:138px}
  .photo-grid{grid-template-columns:1fr}

  .hub-controls select { width: 100%; }

  .cookie-message {
    right: 10px;
    bottom: 10px;
    left: 10px;
    max-width: none;
    flex-wrap: wrap;
  }

  .icon-card {
    min-height: 104px;
    padding: 12px 8px;
    border-radius: 20px;
  }

  .icon-symbol {
    width: 48px;
    height: 48px;
    border-radius: 15px;
    font-size: 1.65rem;
  }

  .icon-label {
    font-size: 0.82rem;
  }

  .home-item.is-open {
    grid-column: 1 / -1;
  }
}

/* Flexible mini-page widgets and dense icon packing */
.home-grid{grid-auto-flow:dense}
.mini-widget .panel-head h2{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:clamp(1.3rem,3vw,2rem)}
.ipand-library{display:grid;align-content:start;overflow:auto;border-right:2px solid #20322b}
.ipand-library button{min-height:28px;padding:5px 7px;border:0;border-bottom:1px dashed #789083;color:#183125;background:transparent;text-align:left;font:400 .64rem Microgramma,Michroma,sans-serif;cursor:pointer}
.ipand-library button.is-selected,.ipand-menu .is-selected{color:#e8ffe9;background:#183125!important}
.ipand-now{display:grid;align-content:start;gap:4px;min-width:0;padding-left:8px}.ipand-now strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.7rem}.ipand-now iframe{display:block;width:100%;height:120px;min-height:120px;border:0}
.ipand-view[data-ipand-screen="music"].is-active{grid-template-columns:minmax(92px,.75fr) minmax(125px,1.25fr)}
.ipand-screen{font-family:"Courier New",monospace;background:#c9dec8;background-image:linear-gradient(rgba(24,49,37,.05) 50%,transparent 50%);background-size:100% 4px;box-shadow:inset 0 0 18px rgba(20,50,30,.28)}

.hub-wallpaper-layer{position:fixed;inset:-38px;z-index:-2;background-size:cover;background-repeat:no-repeat;background-position:center;transform:translate3d(var(--wallpaper-shift-x,0px),calc(var(--wallpaper-shift-y,0px) + var(--wallpaper-scroll,0px)),0) scale(1.08);transition:transform 120ms ease-out;will-change:transform;pointer-events:none}
.hub-wallpaper-layer::after{content:"";position:absolute;inset:0;background:linear-gradient(rgba(243,244,245,.34),rgba(243,244,245,.56))}
html[data-theme="dark"] .hub-wallpaper-layer::after{background:linear-gradient(rgba(15,16,18,.38),rgba(15,16,18,.62))}
body.has-wallpaper{background-image:none!important;background-color:transparent!important}

@media (min-width:760px){
  .music-widget.is-open,.live-widget.is-open{grid-column:span 3}
  .music-widget.is-open .widget-panel,.live-widget.is-open .widget-panel{height:430px;min-height:430px;max-height:430px;padding:20px;overflow:hidden}
  .ipand{grid-template-columns:minmax(230px,1fr) 150px;align-items:center;width:100%;max-width:none;margin:auto 0}
  .ipand-screen{height:260px}
  .live-widget-panel .video-frame{max-height:265px}
}
@media (min-width:1060px){
  .music-widget.is-open,.live-widget.is-open{grid-column:span 6}
}
@media (max-width:759px){
  .music-widget.is-open .widget-panel,.live-widget.is-open .widget-panel{max-height:none}
}

/* Scrollable and sliding mini-page interiors */
.links-widget .widget-panel{display:flex;flex-direction:column}
.links-widget .link-groups{flex:1 1 auto;min-height:0;overflow-y:auto;overscroll-behavior:contain;padding-right:6px;scrollbar-width:thin;scrollbar-color:var(--accent) transparent}
.teny-panel{display:flex;flex-direction:column}.teny-slider{flex:1;min-height:0;overflow:hidden;border-radius:18px}.teny-track{display:flex;width:max-content;height:100%;gap:10px;will-change:transform}.teny-track.is-looping{animation:teny-slide 52s linear infinite}.teny-slider:hover .teny-track{animation-play-state:paused}.teny-set{display:flex;height:100%;gap:10px}.teny-track article{display:grid;width:180px;min-height:190px;grid-template-rows:auto minmax(0,1fr) auto;align-content:center;justify-items:center;gap:8px;padding:12px;border-radius:18px;color:var(--text);background:var(--surface-strong);box-shadow:inset 0 0 0 1px var(--line);text-align:center}.teny-track article span{color:var(--accent);font-family:Microgramma,Michroma,sans-serif}.teny-track article img{width:100%;height:118px;border-radius:12px;object-fit:contain;background:#eee}.teny-track h3{margin:0;font-size:.72rem}@keyframes teny-slide{to{transform:translateX(calc(-50% - 5px))}}

/* Widgets expand in place, anchored to the location of their icon. */
@media(min-width:760px){
  .links-widget.is-open .widget-panel,.teny-widget.is-open .widget-panel{height:390px;min-height:390px;max-height:390px;overflow:hidden}
  .teny-widget.is-open{grid-column:span 6}
}

@media (max-width: 759px) {
  .about-widget{grid-column:1/-1}
  .about-widget .icon-card{min-height:138px}
}

@media (prefers-color-scheme: dark) {
  :root:not([data-theme]) {
    --bg: #191a1d;
    --surface: #222428;
    --surface-strong: #2b2e33;
    --text: #f4f5f6;
    --muted: #b8bcc5;
    --dark: #08090a;
    --line: rgba(255, 255, 255, 0.12);
    --shadow-raised: 8px 8px 20px rgba(0, 0, 0, 0.42),
      -7px -7px 18px rgba(255, 255, 255, 0.05);
    --shadow-pressed: inset 7px 7px 16px rgba(0, 0, 0, 0.34),
      inset -7px -7px 16px rgba(255, 255, 255, 0.05);
  }

  :root:not([data-theme]) body {
    background:
      radial-gradient(circle at top right, rgba(225, 18, 47, 0.18), transparent 30rem),
      linear-gradient(145deg, #24262a, var(--bg));
  }
}

/* Final home-hub layout contract */
body, body * { font-weight: 400 !important; }
h1,h2,h3,h4,h5,h6,strong,b,.icon-label,.bubble-question,.bubble-actions a,
.panel-link,.map-grid a,.hub-controls label,.calendar-list time {
  font-family: Microgramma, Michroma, Eurostile, "Arial Black", sans-serif !important;
  font-weight: 400 !important;
}

.logo-button {
  top: 14px;
  left: 14px;
  width: 76px;
  height: 76px;
  padding: 0;
  border: 0;
  border-radius: 18px;
  background: transparent;
  box-shadow: none;
}
.logo-mark { border-radius: 18px; }
.top-controls { top: 18px; right: 18px; height: 48px; }
.top-controls .theme-switch,
.language-button {
  display: grid;
  width: 48px;
  height: 48px;
  min-height: 48px;
  padding: 0;
  border: 1px solid var(--line);
  border-radius: 15px;
  place-items: center;
  color: var(--text);
  background: var(--surface);
  box-shadow: var(--shadow-raised);
  cursor: pointer;
  font-family: Microgramma, Michroma, Eurostile, sans-serif !important;
}
.language-button { width: 68px; font-size: .82rem; }
.panda-bubble { top: 102px; left: 14px; }
.home-shell { padding-top: 112px; }

@media (min-width: 760px) {
  .about-widget.is-open .widget-panel,
  .links-widget.is-open .widget-panel,
  .chronoplime-widget.is-open .widget-panel,
  .faq-widget.is-open .widget-panel,
  .calendar-widget.is-open .widget-panel {
    height: 390px;
    min-height: 390px;
    max-height: 390px;
    overflow: hidden;
  }
  .calendar-widget .widget-panel { display: flex; flex-direction: column; }
  .calendar-widget .panel-head { flex: 0 0 auto; }
  .calendar-list {
    flex: 1 1 auto;
    min-height: 0;
    overflow-y: auto;
    overscroll-behavior: contain;
    padding-right: 6px;
    scrollbar-color: var(--accent) transparent;
    scrollbar-width: thin;
  }
  .calendar-list::-webkit-scrollbar { width: 7px; }
  .calendar-list::-webkit-scrollbar-thumb { background: var(--accent); border-radius: 10px; }
  .chronoplime-widget.is-open .widget-panel {
    height: 390px;
    min-height: 390px;
    max-height: 390px;
    overflow: hidden;
  }
}

@media (max-width: 759px) {
  .home-grid { align-items: start; }
  .billboard { order: 0; }
  .hub-controls { order: 1; }
  .about-widget { order: 2; grid-column: 1 / -1; }
  .page-shortcut { order: 3; }
  .chronoplime-widget,.calendar-widget,.links-widget,.faq-widget { order: 4; }
  .about-widget .icon-card { min-height: 132px; }
  .emoji-word{width:auto!important}
  .about-widget.is-open .widget-panel{max-height:none;overflow:visible}
}

@media (max-width: 520px) {
  .logo-button { top: 10px; left: 10px; width: 68px; height: 68px; }
  .top-controls { top: 14px; right: 10px; }
  .panda-bubble { top: 90px; left: 10px; }
  .home-shell { padding-top: 94px; }
}

/* The iPand keeps its classic vertical silhouette on wide screens. */
@media (min-width: 760px) {
  .music-widget.is-open .widget-panel {
    height: 470px;
    min-height: 470px;
    max-height: 470px;
  }
  .ipand {
    grid-template-columns: 1fr;
    width: min(100%, 430px);
    max-width: 430px;
    margin: auto;
    padding: 10px;
    transform: scale(var(--ipand-scale, 1));
    transform-origin: top center;
  }
  .ipand-screen { height: 210px; }
}

.chronoplime-widget .icon-label,
.chronoplime-widget .panel-head h2 {
  display: block;
  width: 100%;
  min-width: 0;
  white-space: nowrap;
}
.chronoplime-widget .panel-head > div { min-width: 0; }

@media (prefers-reduced-motion: reduce) {
  .teny-track.is-looping {
    animation: none !important;
    transform: none !important;
  }
}
