:root{
    --white:#FFFFFF;
    --limestone:#F8EFE0;       /* South East limestone */
    --ink:#140F50;             /* Dark blue (primary ink + survey lines) */
    --ink-soft:#5A5478;        /* muted indigo */
    --purple:#836BFF;          /* North Terrace purple (feature) */
    --purple-deep:#5B45D6;     /* legible purple for small text */
    --blue:#1448FF;            /* Bright blue (highlight / river) */
    --hair:rgba(20,15,80,.16);
    --hair-soft:rgba(20,15,80,.09);
  }
  *{box-sizing:border-box;}
  html{scroll-behavior:smooth;}
  body{
    margin:0;
    background:
      radial-gradient(900px 620px at 80% 24%, rgba(131,107,255,.10), transparent 62%),
      radial-gradient(760px 540px at 70% 16%, rgba(248,239,224,.7), transparent 60%),
      var(--white);
    color:var(--ink);
    font-family:"Spectral",Georgia,serif;
    -webkit-font-smoothing:antialiased;
    line-height:1.5;
    overflow-x:hidden;
  }
  .wrap{max-width:1140px;margin:0 auto;padding:0 28px;}

  /* ---- top bar ---- */
  .topbar{
    display:flex;justify-content:space-between;align-items:baseline;gap:18px;
    padding:24px 0 14px;
    font-family:"IBM Plex Mono",monospace;
    font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;
    color:var(--ink-soft);
    border-bottom:1px solid var(--hair-soft);
  }
  .topbar .brand{color:var(--purple-deep);font-weight:500;}
  .topbar .coords{white-space:nowrap;}
  @media (max-width:560px){ .topbar .coords{display:none;} }

  /* ---- hero ---- */
  .hero{
    display:grid;grid-template-columns:1.04fr .96fr;gap:52px;align-items:center;
    padding:54px 0 64px;
  }
  .eyebrow{
    font-family:"IBM Plex Mono",monospace;
    font-size:clamp(.7rem,1.5vw,.8rem);
    letter-spacing:.24em;text-transform:uppercase;color:var(--purple-deep);
    margin:0 0 22px;
  }
  h1{
    font-weight:400;
    font-size:clamp(3rem,8vw,5.7rem);
    line-height:.98;letter-spacing:-.01em;
    margin:0 0 26px;color:var(--ink);
  }
  h1 .dot{color:var(--purple);}
  h1 em{font-style:italic;color:var(--purple);}
  .lede{
    font-weight:300;
    font-size:clamp(1.06rem,2.1vw,1.32rem);
    line-height:1.55;color:#3A3660;max-width:34ch;margin:0 0 30px;
  }
  .lede b{font-weight:500;color:var(--ink);}

  .soon{
    font-family:"IBM Plex Mono",monospace;
    font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;
    color:var(--purple-deep);display:inline-flex;align-items:center;gap:10px;margin:0 0 18px;
  }
  .soon .pip{width:7px;height:7px;border-radius:50%;background:var(--purple);
    box-shadow:0 0 0 0 rgba(131,107,255,.6);animation:ping 2.4s ease-out infinite;}
  @keyframes ping{0%{box-shadow:0 0 0 0 rgba(131,107,255,.5);}70%,100%{box-shadow:0 0 0 9px rgba(131,107,255,0);}}

  .countdown{display:flex;gap:18px;align-items:flex-end;flex-wrap:wrap;}
  .cd-unit{display:flex;flex-direction:column;gap:4px;}
  .cd-num{
    font-family:"IBM Plex Mono",monospace;font-weight:500;
    font-size:clamp(1.4rem,3vw,2rem);color:var(--ink);line-height:1;
    font-variant-numeric:tabular-nums;
  }
  .cd-lab{
    font-family:"IBM Plex Mono",monospace;font-size:.62rem;
    letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft);
  }
  .cd-sep{font-family:"IBM Plex Mono",monospace;color:var(--hair);font-size:1.6rem;align-self:center;padding-bottom:14px;}

  /* ---- map signature ---- */
  .mapwrap{position:relative;}
  .mapwrap::before{
    content:"";position:absolute;inset:-6% -4% -6% -8%;
    background:radial-gradient(closest-side, rgba(131,107,255,.14), rgba(20,72,255,.05) 55%, transparent 75%);
    filter:blur(8px);z-index:0;
  }
  .plan{position:relative;z-index:1;width:100%;height:auto;display:block;}

  /* ---- photo banner ---- */
  .banner{
    position:relative;
    width:100vw;margin-left:calc(50% - 50vw);
    aspect-ratio:24/9;max-height:520px;min-height:300px;
    margin-top:8px;margin-bottom:24px;
    overflow:hidden;background:#F1ECFA;
  }
  .banner-ph{
    position:absolute;inset:0;z-index:0;
    display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;
    text-align:center;padding:24px;
    background:
      radial-gradient(120% 150% at 50% -25%, rgba(131,107,255,.20), transparent 60%),
      linear-gradient(180deg,#F3EFFB 0%, var(--limestone) 100%);
  }
  .banner-ph .frame{position:absolute;inset:18px;border:1.5px dashed rgba(91,69,214,.45);border-radius:12px;pointer-events:none;}
  .banner-ph svg{width:40px;height:40px;color:var(--purple-deep);opacity:.9;}
  .banner-ph p{margin:0;font-family:"IBM Plex Mono",monospace;}
  .banner-ph .lab{font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;color:var(--purple-deep);}
  .banner-ph .hint{font-size:.72rem;letter-spacing:.03em;color:var(--ink-soft);}
  .banner-ph code{background:rgba(91,69,214,.1);padding:1px 6px;border-radius:4px;}
  .banner-img{position:absolute;inset:0;z-index:1;width:100%;height:100%;object-fit:cover;object-position:center 42%;display:block;}
  .banner-img.is-missing{display:none;}
  .banner-cap{
    position:absolute;left:0;right:0;bottom:0;z-index:2;
    padding:46px 0 16px;
    background:linear-gradient(0deg, rgba(20,15,80,.5), transparent);
  }
  .banner-cap span{
    display:block;max-width:1140px;margin:0 auto;padding:0 28px;box-sizing:border-box;
    font-family:"IBM Plex Mono",monospace;font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:#fff;
  }
  @media (max-width:620px){ .banner{aspect-ratio:16/10;min-height:240px;} }

  /* ---- facts band ---- */
  .facts{
    display:grid;grid-template-columns:repeat(4,1fr);gap:26px;
    padding:34px 0;border-top:1px solid var(--hair);border-bottom:1px solid var(--hair);
  }
  .fact .k{
    font-family:"IBM Plex Mono",monospace;font-size:.68rem;letter-spacing:.2em;
    text-transform:uppercase;color:var(--purple-deep);margin:0 0 9px;
  }
  .fact .v{font-size:1.06rem;line-height:1.35;color:var(--ink);font-weight:400;}
  .fact .v small{display:block;color:var(--ink-soft);font-size:.9rem;}

  /* ---- about + notify ---- */
  .panel{
    display:grid;grid-template-columns:1.2fr .8fr;gap:56px;
    padding:64px 0 56px;align-items:start;
  }
  .about h2{
    font-family:"IBM Plex Mono",monospace;font-weight:500;font-size:.74rem;
    letter-spacing:.22em;text-transform:uppercase;color:var(--purple-deep);margin:0 0 18px;
  }
  .about p{font-size:1.12rem;line-height:1.65;color:#3A3660;font-weight:300;margin:0 0 18px;max-width:54ch;}
  .chairs{margin-top:30px;}
  .chairs .k{
    font-family:"IBM Plex Mono",monospace;font-size:.82rem;letter-spacing:.18em;
    text-transform:uppercase;color:var(--ink-soft);margin:0 0 16px;
  }
  .chair-row{display:flex;gap:34px;flex-wrap:wrap;}
  .chair{display:flex;align-items:center;gap:14px;}
  .avatar{
    position:relative;width:62px;height:62px;border-radius:50%;overflow:hidden;flex:none;
    background:radial-gradient(120% 120% at 30% 20%, rgba(131,107,255,.24), rgba(248,239,224,.95));
    border:1px solid var(--hair);display:flex;align-items:center;justify-content:center;
  }
  .avatar .initials{font-family:"IBM Plex Mono",monospace;font-size:1rem;letter-spacing:.03em;color:var(--purple-deep);}
  .avatar img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;}
  .avatar img.is-missing{display:none;}
  .cname{margin:0;font-size:1.08rem;color:var(--ink);line-height:1.2;}

  .notify{
    border:1px solid var(--hair);border-radius:14px;padding:28px;
    background:linear-gradient(180deg, var(--limestone), #FCF7EF);
  }
  .notify h3{font-weight:400;font-size:1.45rem;margin:0 0 8px;color:var(--ink);}
  .notify p{font-size:.96rem;color:var(--ink-soft);margin:0 0 20px;line-height:1.5;}
  .field{display:flex;gap:10px;flex-wrap:wrap;}
  .field input{
    flex:1 1 180px;min-width:0;
    background:var(--white);border:1px solid var(--hair);border-radius:9px;
    padding:13px 14px;color:var(--ink);font-family:"IBM Plex Mono",monospace;font-size:.86rem;
  }
  .field input::placeholder{color:#9b97b5;}
  .field input:focus-visible{outline:2px solid var(--purple);outline-offset:1px;border-color:transparent;}
  .field button{
    background:var(--purple-deep);color:#FFFFFF;border:0;border-radius:9px;
    padding:13px 20px;font-family:"IBM Plex Mono",monospace;font-size:.78rem;letter-spacing:.12em;
    text-transform:uppercase;font-weight:500;cursor:pointer;transition:background .18s ease,transform .18s ease;
  }
  .field button:hover{background:var(--purple);}
  .field button:active{transform:translateY(1px);}
  .field button:focus-visible{outline:2px solid var(--ink);outline-offset:2px;}
  .confirm{font-size:1rem;color:var(--purple-deep);line-height:1.5;}

  /* ---- footer ---- */
  footer{border-top:1px solid var(--hair-soft);padding:40px 0 56px;}
  .ack{
    font-size:.96rem;line-height:1.6;color:#403C66;font-weight:300;
    max-width:70ch;margin:0 0 26px;
  }
  .ack b{color:var(--ink);font-weight:500;}
  .foot-row{
    display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;
    font-family:"IBM Plex Mono",monospace;font-size:.7rem;letter-spacing:.16em;
    text-transform:uppercase;color:var(--ink-soft);
  }
  .foot-row a{color:var(--blue);text-decoration:none;}
  .foot-row a:hover{text-decoration:underline;}
  
  footer.wrap{
	  padding-top:64px;   /* gap between the divider line and the text */
	}

  /* ---- reveal animations ---- */
  .rise{opacity:0;transform:translateY(14px);animation:rise .9s cubic-bezier(.2,.7,.2,1) forwards;}
  @keyframes rise{to{opacity:1;transform:none;}}

  .draw{stroke-dasharray:1;stroke-dashoffset:1;animation:draw 1s ease forwards;}
  @keyframes draw{to{stroke-dashoffset:0;}}
  .pop{opacity:0;transform:scale(.35);transform-box:fill-box;transform-origin:center;
    animation:pop .7s cubic-bezier(.2,.8,.3,1.4) forwards;}
  @keyframes pop{to{opacity:1;transform:scale(1);}}
  .sfade{opacity:0;animation:sfade .9s ease forwards;}
  @keyframes sfade{to{opacity:1;}}
  .pulse{animation:pulse 3.6s ease-in-out infinite;transform-box:fill-box;transform-origin:center;}
  @keyframes pulse{0%,100%{opacity:.45;}50%{opacity:.9;}}

  @media (max-width:900px){
    .hero{grid-template-columns:1fr;gap:36px;padding:40px 0 48px;}
    .mapwrap{order:-1;max-width:440px;margin:0 auto;}
    .panel{grid-template-columns:1fr;gap:40px;padding:48px 0;}
  }
  @media (max-width:620px){
    .facts{grid-template-columns:1fr 1fr;gap:24px;}
  }

  @media (prefers-reduced-motion:reduce){
    .rise,.draw,.pop,.sfade,.pulse,.soon .pip{animation:none;}
    .rise{opacity:1;transform:none;}
    .draw{stroke-dashoffset:0;}
    .pop{opacity:1;transform:none;}
    .sfade{opacity:1;}
    html{scroll-behavior:auto;}
  }
  
  .notify a{ color:var(--purple-deep); font-weight:500; text-decoration:none; }
  .notify a:hover{ text-decoration:underline; }
  
  