/* ============================================================
   NEW COLONIES — shared stylesheet
   Matches the index.html design language:
   Cormorant Garamond + JetBrains Mono, dark grain aesthetic
   ============================================================ */

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

:root{
  --bg:#131519;
  --fg:#d4d0c8;
  --accent:#da7b4a;
  --dim:#4a4640;
  --border:#2a2622;
  --surface:rgba(19,21,25,0.95);
  --grain-opacity:0.035;
  --font-serif:'Cormorant Garamond',Georgia,serif;
  --font-mono:'JetBrains Mono',monospace;
}

html{font-size:16px;scroll-behavior:smooth}
body{
  background:var(--bg);
  color:var(--fg);
  font-family:var(--font-serif);
  min-height:100vh;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  line-height:1.6;
}

/* ── grain overlay ── */
body::after{
  content:'';position:fixed;inset:0;z-index:9999;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  opacity:var(--grain-opacity);
  mix-blend-mode:overlay;
}

/* ── links ── */
a{color:var(--accent);text-decoration:none;transition:color 0.4s}
a:hover{color:var(--fg)}

/* ── mono label ── */
.label{
  font-family:var(--font-mono);
  font-size:0.55rem;letter-spacing:0.5em;text-transform:uppercase;
  color:var(--dim);
}

/* ── page header ── */
.page-header{
  display:flex;justify-content:space-between;align-items:center;
  padding:2rem 3rem;
}
.page-header .logo{
  font-family:var(--font-mono);
  font-size:0.65rem;letter-spacing:0.4em;text-transform:uppercase;
  color:var(--dim);text-decoration:none;
  transition:color 0.4s;
}
.page-header .logo:hover{color:var(--fg)}
.page-header .logo span{color:var(--accent)}

/* ── divider ── */
.divider{
  width:40px;height:1px;margin:0 auto;
  background:var(--dim);opacity:0.3;
}

/* ── section title ── */
.section-title{
  font-family:var(--font-mono);
  font-size:0.55rem;letter-spacing:0.5em;text-transform:uppercase;
  color:var(--accent);
  border-bottom:1px solid var(--border);
  padding-bottom:0.6rem;
  margin-bottom:2rem;
}

/* ── hero with bg image ── */
.hero{
  position:relative;width:100%;
  min-height:50vh;
  display:flex;align-items:flex-end;
  overflow:hidden;
}
.hero-bg{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
  filter:grayscale(70%) contrast(120%) brightness(0.6);
}
.hero-overlay{
  position:absolute;inset:0;
  background:
    linear-gradient(to bottom, transparent 0%, var(--bg) 100%),
    linear-gradient(to right, var(--bg) 0%, transparent 50%);
}
.hero-content{
  position:relative;z-index:2;
  padding:3rem;
  max-width:700px;
}
.hero-content h1{
  font-size:clamp(2.5rem,6vw,4rem);
  font-weight:300;line-height:0.95;
  letter-spacing:-0.02em;
}
.hero-content h1 em{
  font-style:italic;font-weight:300;
  color:var(--accent);
}
.hero-content .tagline{
  margin-top:1rem;
  font-family:var(--font-mono);
  font-size:0.6rem;letter-spacing:0.5em;text-transform:uppercase;
  color:var(--dim);
}

/* ── content area ── */
.content{
  max-width:700px;
  margin:0 auto;
  padding:4rem 3rem;
}

/* ── status block ── */
.status-block{
  border-left:2px solid var(--accent);
  padding-left:1.5rem;
  margin-bottom:3rem;
}
.status-line{
  font-family:var(--font-mono);
  font-size:0.7rem;
  margin-bottom:0.4rem;
  color:var(--dim);
  letter-spacing:0.05em;
}
.status-line .hl{color:var(--accent)}

/* ── prose ── */
.prose p{
  font-size:1.1rem;line-height:1.8;font-weight:300;
  color:color-mix(in srgb,var(--fg) 75%,transparent);
  margin-bottom:1.5rem;
}
.prose em{color:var(--accent);font-style:italic}

/* ── archive grid ── */
.archive-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(200px, 1fr));
  gap:1rem;
}
.archive-card{
  border:1px solid var(--border);
  padding:1.5rem;
  transition:border-color 0.4s;
}
.archive-card:hover{border-color:var(--accent)}
.archive-card h3{
  font-family:var(--font-mono);
  font-size:0.55rem;letter-spacing:0.4em;text-transform:uppercase;
  color:var(--dim);margin-bottom:0.5rem;
}
.archive-card .title{
  font-size:1rem;font-weight:400;
  margin-bottom:1rem;line-height:1.3;
}
.archive-card .status{
  font-family:var(--font-mono);
  font-size:0.55rem;letter-spacing:0.3em;text-transform:uppercase;
}
.archive-card .status.complete{color:var(--accent)}
.archive-card .status.progress{color:var(--dim)}

/* ── gallery ── */
.gallery-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(280px, 1fr));
  gap:3px;
}
.gallery-grid img{
  width:100%;height:260px;
  object-fit:cover;
  filter:grayscale(100%) contrast(120%);
  transition:filter 0.6s;cursor:pointer;display:block;
}
.gallery-grid img:hover{filter:grayscale(0%) contrast(100%)}

/* ── tool interface (QR etc) ── */
.tool-interface{
  border:1px solid var(--border);
  padding:2rem;
  margin-top:2rem;
  background:var(--surface);
}
.input-group{display:flex;gap:1rem;margin-bottom:2rem}
.input-group input[type="text"]{
  background:var(--bg);
  border:1px solid var(--border);
  color:var(--fg);
  font-family:var(--font-mono);
  font-size:0.8rem;
  padding:0.8rem 1rem;
  flex-grow:1;outline:none;
  transition:border-color 0.3s;
}
.input-group input[type="text"]:focus{border-color:var(--accent)}
.input-group button{
  background:var(--accent);color:var(--bg);
  border:none;padding:0 2rem;
  font-family:var(--font-mono);
  font-size:0.65rem;letter-spacing:0.3em;font-weight:400;
  cursor:pointer;text-transform:uppercase;
  transition:background 0.3s;
}
.input-group button:hover{background:var(--fg)}
#canvas-container{
  display:flex;justify-content:center;align-items:center;
  min-height:300px;
  border:1px solid var(--border);
  background-image:radial-gradient(color-mix(in srgb,var(--dim) 20%,transparent) 1px, transparent 1px);
  background-size:10px 10px;
}
canvas{max-width:100%}
.controls{
  margin-top:1rem;display:flex;justify-content:space-between;
  font-family:var(--font-mono);
  font-size:0.6rem;letter-spacing:0.2em;
  color:var(--dim);
}

/* ── footer ── */
footer{
  padding:3rem;text-align:center;
  font-family:var(--font-mono);
  font-size:0.55rem;letter-spacing:0.3em;text-transform:uppercase;
  color:var(--dim);
}
footer a{color:var(--dim);text-decoration:none;transition:color 0.4s}
footer a:hover{color:var(--fg)}

/* ── fade-in on scroll ── */
.fade-in{
  opacity:0;transform:translateY(20px);
  transition:opacity 0.8s ease,transform 0.8s ease;
}
.fade-in.visible{opacity:1;transform:translateY(0)}

/* ── animations ── */
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes riseIn{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}

/* ── responsive ── */
@media(max-width:640px){
  .page-header{padding:1.5rem;flex-direction:column;gap:1rem;align-items:flex-start}
  .hero-content{padding:1.5rem}
  .hero-content h1{font-size:2rem}
  .content{padding:2.5rem 1.5rem}
  .archive-grid{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:1fr 1fr}
  .gallery-grid img{height:160px}
  .input-group{flex-direction:column}
  .input-group button{padding:0.8rem}
}
