:root{
  --pos:#27d07a; --neu:#2f7fd1; --neg:#e6403f; --nodata:#3a4a5a;
  --ink:#dfeaf5; --dim:#7d93a8; --glow:#4aa8ff;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;background:#000006;overflow:hidden;
  font-family:'Segoe UI',-apple-system,Roboto,Helvetica,Arial,sans-serif;color:var(--ink)}
#globe{position:fixed;inset:0}

/* ---------- top-center clock ---------- */
.clock{position:fixed;top:20px;left:50%;transform:translateX(-50%);z-index:5;text-align:center;
  pointer-events:none;text-shadow:0 1px 14px #000}
.clk-time{font-size:27px;font-weight:300;letter-spacing:.14em;color:#eaf3fc;
  font-variant-numeric:tabular-nums;filter:drop-shadow(0 0 12px rgba(74,168,255,.35))}
.clk-meta{font-size:11px;letter-spacing:.08em;color:var(--dim);margin-top:3px}
@media(max-width:640px){.clock{top:auto;bottom:64px}.clk-time{font-size:20px}}

/* ---------- LEFT HUD ---------- */
#hud{position:fixed;top:24px;left:30px;z-index:5;width:340px;text-shadow:0 1px 12px #000}
.title{font-size:32px;font-weight:800;letter-spacing:.18em;
  background:linear-gradient(90deg,#fff,#7fc4ff);-webkit-background-clip:text;
  background-clip:text;color:transparent;filter:drop-shadow(0 0 18px rgba(74,168,255,.45))}
.subtitle{font-size:12px;letter-spacing:.03em;color:var(--dim);margin-top:4px}

.world-now{margin-top:18px;background:rgba(10,18,30,.45);border:1px solid rgba(90,150,210,.18);
  border-radius:12px;padding:12px 14px;backdrop-filter:blur(9px)}
.wn-label{font-size:9.5px;letter-spacing:.2em;color:var(--dim);font-weight:700}
.wn-head{font-size:17px;font-weight:700;margin-top:7px;display:flex;align-items:center;gap:9px}
.wn-counts{display:flex;gap:13px;margin-top:9px;flex-wrap:wrap}
.wn-counts .gc{display:flex;align-items:center;gap:6px;font-size:12px;color:#c7d6e6}
.wn-counts .gc i{width:9px;height:9px;border-radius:50%;display:inline-block}
/* update progress bar */
.upd{position:relative;height:22px;margin-top:11px;border-radius:7px;cursor:pointer;
  background:rgba(20,34,52,.7);border:1px solid rgba(90,150,210,.22);overflow:hidden}
.upd:hover{border-color:rgba(120,180,235,.45)}
.upd-fill{position:absolute;inset:0;width:0%;border-radius:6px;
  background:linear-gradient(90deg,rgba(74,168,255,.35),rgba(74,168,255,.75));
  transition:width 1s linear}
.upd-text{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-size:11px;letter-spacing:.05em;color:#dceaf8;font-variant-numeric:tabular-nums;
  text-shadow:0 1px 4px #000}
.upd-fill::after{content:'';position:absolute;inset:0;border-radius:6px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.35),transparent);
  transform:translateX(-100%);animation:updshine 2.2s ease-in-out infinite}
@keyframes updshine{0%{transform:translateX(-100%)}60%,100%{transform:translateX(220%)}}
.upd.updating .upd-fill{width:100%!important;
  background:repeating-linear-gradient(45deg,#e6403f 0 12px,#ff7a5a 12px 24px);
  background-size:34px 34px;animation:updmove .55s linear infinite}
.upd.updating .upd-fill::after{display:none}
.upd.updating .upd-text{color:#fff;font-weight:700;letter-spacing:.08em}
@keyframes updmove{from{background-position:0 0}to{background-position:34px 0}}
.dot{width:13px;height:13px;border-radius:50%;display:inline-block;
  box-shadow:0 0 12px 2px currentColor;background:currentColor}

.about-toggle{margin-top:14px;background:rgba(20,32,50,.5);border:1px solid rgba(90,150,210,.25);
  color:var(--ink);font-size:12.5px;padding:7px 12px;border-radius:9px;cursor:pointer;letter-spacing:.03em}
.about-toggle:hover{background:rgba(40,70,110,.55)}
.about{max-height:0;overflow:hidden;opacity:0;transition:max-height .35s ease,opacity .3s}
.about.open{max-height:560px;opacity:1;margin-top:10px;padding:14px 15px;
  background:rgba(10,18,30,.55);border-radius:12px;backdrop-filter:blur(9px);
  border:1px solid rgba(90,150,210,.18)}
.about p{font-size:12.6px;line-height:1.62;color:#c4d4e6}
.about .muted{color:var(--dim);font-size:11.6px;margin-top:9px}
.about .how{list-style:none;margin:11px 0;font-size:12.4px}
.about .how li{display:flex;align-items:center;gap:9px;padding:3px 0;color:#cddcec}
.sw{width:12px;height:12px;border-radius:3px;display:inline-block;flex:none}

/* ---------- RIGHT continents ---------- */
#continents{position:fixed;top:24px;right:24px;z-index:5;width:236px;
  background:rgba(10,18,30,.42);border:1px solid rgba(90,150,210,.18);border-radius:14px;
  padding:14px 6px 8px;backdrop-filter:blur(9px);box-shadow:0 8px 40px rgba(0,0,0,.5)}
.panel-h{font-size:11px;letter-spacing:.2em;color:var(--dim);padding:0 12px 10px;font-weight:700;
  display:flex;justify-content:space-between;align-items:baseline}
.panel-h .hint{font-size:9.5px;letter-spacing:.06em;color:#5a6f84;font-weight:500}
.crow{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:9px;cursor:pointer;transition:background .15s}
.crow:hover{background:rgba(90,150,210,.12)}
.cmid{flex:1;display:grid;grid-template-columns:1fr auto;gap:1px 8px;align-items:center}
.cname{font-size:13.5px}.cword{font-size:11px;font-weight:600;text-align:right}
.cbar{grid-column:1/3;position:relative;height:4px;border-radius:3px;margin-top:5px;
  background:linear-gradient(90deg,#e6403f,#2f7fd1,#27d07a)}
.cbar i{position:absolute;top:50%;width:9px;height:9px;border-radius:50%;transform:translate(-50%,-50%);
  box-shadow:0 0 7px 1px currentColor;border:1.5px solid #0b1320}

/* compact world-mood trend at the foot of the continents card */
.trend-sec{margin:10px 12px 4px;padding-top:10px;border-top:1px solid rgba(90,150,210,.14)}
.trend-h{font-size:9.5px;letter-spacing:.18em;color:var(--dim);font-weight:700;margin-bottom:6px}
.trend-sub{display:block;font-size:8.5px;letter-spacing:.03em;color:#5a6f84;font-weight:500;margin-top:3px;text-transform:none}
.trend-row{display:flex;align-items:center;gap:8px;margin-top:5px}
.trend-lab{font-size:10px;color:var(--dim);width:20px;flex:none}
.trend-row canvas{flex:1;width:100%;height:28px}
.trend-delta{font-size:10px;width:62px;flex:none;text-align:right;font-weight:600}

/* trademark footer */
#copyright{position:fixed;bottom:14px;left:50%;transform:translateX(-50%);z-index:6;
  font-size:11.5px;letter-spacing:.14em;color:rgba(176,198,222,.92);pointer-events:none;
  text-shadow:0 1px 8px #000, 0 0 14px rgba(0,0,0,.8);white-space:nowrap;font-weight:500}
@media(max-width:640px){#copyright{font-size:9px;bottom:6px}}

/* ---------- right-bottom selected-country contour ---------- */
.shape-card{position:fixed;right:24px;bottom:22px;z-index:5;width:210px;
  background:rgba(10,18,30,.42);border:1px solid rgba(90,150,210,.18);border-radius:14px;
  padding:12px 12px 10px;backdrop-filter:blur(9px);box-shadow:0 8px 40px rgba(0,0,0,.5)}
.shape-name{font-size:14.5px;font-weight:700;margin:4px 0 7px}
.shape-cv{width:100%;height:150px;display:block;
  background:radial-gradient(ellipse at center,rgba(40,70,110,.18),rgba(8,14,24,0));border-radius:10px}
@media(max-width:640px){.shape-card{display:none}}

/* ---------- hover tooltip ---------- */
.tip{position:fixed;z-index:9;pointer-events:none;padding:8px 12px;background:rgba(7,14,24,.92);
  border:1px solid rgba(110,170,230,.3);border-radius:9px;font-size:13px;line-height:1.5;
  box-shadow:0 6px 26px rgba(0,0,0,.6);transform:translate(-50%,-130%);white-space:nowrap}
.tip .tname{font-weight:700}.tip .tmood{font-size:11.5px}

/* ---------- detail card ---------- */
.detail{position:fixed;left:30px;bottom:26px;z-index:8;width:320px;background:rgba(9,16,28,.72);
  border:1px solid rgba(90,150,210,.22);border-radius:14px;padding:16px 18px;backdrop-filter:blur(12px);
  box-shadow:0 10px 50px rgba(0,0,0,.6);max-height:72vh;overflow:auto}
#detailClose{position:absolute;top:8px;right:10px;background:none;border:none;color:var(--dim);font-size:22px;cursor:pointer;line-height:1}
.d-name{font-size:22px;font-weight:700}
.d-cont{font-size:10.5px;letter-spacing:.13em;color:var(--dim);text-transform:uppercase;margin-top:2px}
.d-shape{width:100%;height:130px;margin-top:10px;display:block;
  background:radial-gradient(ellipse at center,rgba(40,70,110,.18),rgba(8,14,24,0));border-radius:10px}
.d-sentence{font-size:13.3px;line-height:1.55;margin-top:11px;color:#d6e3f1}
.d-sentence .ital{color:var(--dim);font-style:italic}
.meter{position:relative;height:24px;margin:16px 2px 4px}
.meter-track{position:absolute;top:9px;left:0;right:0;height:6px;border-radius:4px;
  background:linear-gradient(90deg,#e6403f,#2f7fd1,#27d07a)}
.meter-mark{position:absolute;top:5px;width:13px;height:13px;border-radius:50%;transform:translateX(-50%);
  border:2px solid #0b1320;box-shadow:0 0 9px 1px currentColor;transition:left .5s}
.meter-end{position:absolute;top:16px;font-size:9.5px;color:var(--dim)}
.meter-end.l{left:0}.meter-end.r{right:0}
.d-basis{font-size:12px;color:var(--dim);margin-top:13px}
.toggle{display:flex;align-items:center;gap:9px;margin-top:13px;cursor:pointer;font-size:12px;color:#cddcec}
.toggle input{display:none}
.tslider{width:38px;height:20px;border-radius:11px;background:rgba(90,120,150,.45);position:relative;transition:background .2s;flex:none}
.tslider::after{content:'';position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#dfeaf5;transition:left .2s}
.toggle input:checked + .tslider{background:#4aa8ff}
.toggle input:checked + .tslider::after{left:20px}
.links-hint{font-size:11px;line-height:1.5;color:var(--dim);margin-top:7px}
.links-hint b{color:#cddcec;font-weight:600}
.links-list{display:flex;flex-wrap:wrap;gap:5px 7px;margin-top:9px}
.links-list .ll-h{flex-basis:100%;font-size:9.5px;letter-spacing:.16em;color:var(--dim);font-weight:700}
.links-list .ll{display:flex;align-items:center;gap:5px;font-size:11.5px;color:#d2e0ef;
  background:rgba(60,100,150,.16);padding:3px 8px;border-radius:7px}
.links-list .ll i{width:8px;height:8px;border-radius:50%;display:inline-block}
.news-h{font-size:9.5px;letter-spacing:.16em;color:var(--dim);font-weight:700;margin-top:14px}
.d-news{margin-top:7px}
.nl{display:block;padding:7px 0;border-top:1px solid rgba(90,150,210,.12);text-decoration:none}
.nl:first-child{border-top:none}
.nl-t{display:block;font-size:12.3px;line-height:1.4;color:#dbe7f4}
.nl:hover .nl-t{color:#fff}
.nl-d{display:block;font-size:10px;color:#647c92;margin-top:2px}
.nl-loading{font-size:11.5px;color:var(--dim);padding:6px 0}
.d-tech{font-size:10px;color:#566b80;margin-top:10px;font-variant-numeric:tabular-nums}
.hidden{display:none}

@media(max-width:640px){
  #hud{left:14px;top:12px;width:64vw}.title{font-size:23px}
  #continents{width:172px;top:auto;bottom:12px;right:12px;max-height:42vh;overflow:auto}
  .detail{left:12px;right:12px;width:auto;bottom:auto;top:60px;max-height:62vh}
  .about.open{max-height:56vh;overflow:auto}
}

/* ============ MOBILE / TABLET (comprehensive, wins as last block) ============ */
@media (max-width:640px){
  /* globe centered in the page by default (clear of the top card); moves up when a
     country is selected (card hidden, detail sheet at bottom) */
  #globe{top:19vh!important;bottom:auto!important;height:62vh!important;transition:top .3s ease,height .3s ease}
  body.sel #globe{top:0!important;height:56vh!important}
  /* clock -> top-right, compact */
  .clock{top:10px!important;right:12px!important;left:auto!important;bottom:auto!important;
    transform:none!important;text-align:right;max-width:40vw}
  .clk-time{font-size:16px;letter-spacing:.05em}
  .clk-meta{font-size:8px;letter-spacing:.02em;white-space:normal;line-height:1.35;margin-left:auto}
  /* title / world summary -> top-left, compact */
  #hud{top:10px!important;left:12px!important;width:58vw!important}
  .title{font-size:19px;letter-spacing:.1em}
  .subtitle{font-size:9.5px}
  .world-now{margin-top:9px;padding:9px 11px}
  .wn-label{font-size:8.5px}
  .wn-head{font-size:13.5px}
  .wn-counts{gap:8px}.wn-counts .gc{font-size:10px}
  .about-toggle{margin-top:9px;font-size:11px;padding:6px 10px}
  /* about -> bottom overlay sheet */
  .about.open{position:fixed!important;left:10px!important;right:10px!important;bottom:10px!important;
    top:auto!important;width:auto!important;max-height:68vh;overflow:auto;z-index:10;margin-top:0}
  /* continents (+trend) -> compact scrollable bottom card */
  #continents{top:auto!important;bottom:22px!important;left:10px!important;right:10px!important;
    width:auto!important;max-height:27vh!important;overflow:auto;padding:10px 4px 6px!important;
    transition:transform .3s ease,opacity .3s ease}
  #continents.collapsed{transform:translateY(135%)!important;opacity:0;pointer-events:none}
  .panel-h{padding:0 12px 7px}.panel-h .hint{display:none}
  .crow{padding:6px 12px}.cname{font-size:12.5px}.cbar{margin-top:4px}
  .trend-sec{margin:7px 12px 2px;padding-top:8px}
  /* focus mode: when a country is selected, fade chrome so the globe is fully visible */
  #hud,.clock{transition:opacity .3s ease,transform .3s ease}
  body.sel #hud{opacity:0;transform:translateY(-16px);pointer-events:none}
  body.sel .clock{opacity:0;pointer-events:none}
  body.sel #continents{transform:translateY(135%)!important;opacity:0;pointer-events:none}
  /* selected-country contour card is redundant on mobile (shown in detail) */
  .shape-card{display:none!important}
  /* country detail -> bottom sheet that leaves the TOP HALF (globe + flow arcs) visible */
  .detail{left:0!important;right:0!important;bottom:0!important;top:auto!important;width:auto!important;
    max-height:40vh!important;overflow:auto;border-radius:16px 16px 0 0;padding:13px 16px 20px;z-index:11}
  .d-shape{height:66px}
  /* no hover tooltip on touch devices */
  .tip{display:none!important}
  /* trademark peeks in the gap below the continents card */
  #copyright{bottom:7px!important;font-size:8.5px!important;z-index:3}
}

/* ---------- contact link + modal ---------- */
#copyright a{pointer-events:auto;color:#7fc4ff;text-decoration:none;cursor:pointer}
#copyright a:hover{text-decoration:underline}
.contact-modal{position:fixed;inset:0;z-index:20;display:none;align-items:center;justify-content:center;
  background:rgba(2,6,14,.66);backdrop-filter:blur(4px)}
.contact-modal.show{display:flex;animation:cfade .2s ease}
@keyframes cfade{from{opacity:0}to{opacity:1}}
.contact-card{width:380px;max-width:92vw;background:rgba(10,18,30,.94);border:1px solid rgba(90,150,210,.28);
  border-radius:16px;padding:24px 22px 20px;box-shadow:0 20px 70px rgba(0,0,0,.6);position:relative;
  animation:crise .25s cubic-bezier(.2,.8,.3,1)}
@keyframes crise{from{transform:translateY(14px);opacity:0}to{transform:translateY(0);opacity:1}}
.contact-close{position:absolute;top:9px;right:13px;background:none;border:none;color:#7d93a8;
  font-size:24px;line-height:1;cursor:pointer}
.contact-close:hover{color:#dfeaf5}
.contact-h{font-size:15px;font-weight:800;letter-spacing:.16em;
  background:linear-gradient(90deg,#fff,#7fc4ff);-webkit-background-clip:text;background-clip:text;color:transparent}
.contact-sub{font-size:12px;color:#7d93a8;margin:5px 0 16px}
#contactForm input,#contactForm textarea{width:100%;margin-bottom:11px;padding:11px 13px;font-size:13.5px;
  border-radius:10px;border:1px solid rgba(90,150,210,.25);background:rgba(20,34,52,.7);color:#eaf3fc;
  outline:none;font-family:inherit;resize:vertical}
#contactForm input:focus,#contactForm textarea:focus{border-color:#4aa8ff}
#contactForm input::placeholder,#contactForm textarea::placeholder{color:#5f7488}
.contact-hp{position:absolute!important;left:-9999px!important;width:1px!important;height:1px!important;opacity:0}
#contactForm button{width:100%;padding:12px;border:none;border-radius:10px;cursor:pointer;font-size:13.5px;
  font-weight:700;letter-spacing:.06em;color:#04101e;background:linear-gradient(90deg,#4aa8ff,#27d07a)}
#contactForm button:disabled{opacity:.6;cursor:default}
.c-status{font-size:12px;margin-top:10px;min-height:14px;text-align:center}
.c-status.ok{color:#27d07a}.c-status.bad{color:#e6403f}
