:root{
    --ink:#111;
    --paper:#fbfaf7;
    --gray:#444;
    --hair:#cfcac2;
    --shadow: rgba(0,0,0,.08);
  }
  
  *{ box-sizing:border-box; }
  html,body{ margin:0; padding:0; background: var(--paper); color:var(--ink); }
  
  body{
    font-family: "Cormorant Garamond", serif;
    letter-spacing: .2px;
    line-height: 1.5;
  }
  
  /* “coalpen” paper grain (pure CSS, no images) */
  .paper{
    min-height:100vh;
    padding: 28px 16px 60px;
    background:
      radial-gradient(circle at 10% 20%, rgba(0,0,0,.04), transparent 35%),
      radial-gradient(circle at 70% 10%, rgba(0,0,0,.03), transparent 40%),
      radial-gradient(circle at 30% 80%, rgba(0,0,0,.03), transparent 45%),
      repeating-linear-gradient(0deg, rgba(0,0,0,.015), rgba(0,0,0,.015) 1px, transparent 1px, transparent 7px);
  }
  
  .top{
    max-width: 920px;
    margin: 0 auto 18px;
    text-align:center;
  }
  
  .monogram{
    font-size: 14px;
    letter-spacing: 3px;
    color: var(--gray);
    text-transform: uppercase;
  }
  
  .names{
    font-family: "Great Vibes", cursive;
    font-weight: 400;
    margin: 8px 0 4px;
    font-size: clamp(44px, 8vw, 78px);
  }
  
  .sub{
    margin: 0 0 12px;
    color: var(--gray);
    font-size: 18px;
  }
  
  .sketch-rule{
    height: 10px;
    max-width: 560px;
    margin: 14px auto 0;
    background:
      radial-gradient(circle at 10% 50%, rgba(0,0,0,.35) 0 1px, transparent 2px),
      radial-gradient(circle at 30% 50%, rgba(0,0,0,.25) 0 1px, transparent 2px),
      radial-gradient(circle at 50% 50%, rgba(0,0,0,.35) 0 1px, transparent 2px),
      radial-gradient(circle at 70% 50%, rgba(0,0,0,.25) 0 1px, transparent 2px),
      radial-gradient(circle at 90% 50%, rgba(0,0,0,.35) 0 1px, transparent 2px);
    filter: blur(.2px);
    opacity: .9;
  }
  
  main{
    max-width: 920px;
    margin: 0 auto;
    display: grid;
    gap: 18px;
  }
  
  .card{
    background: rgba(255,255,255,.45);
    border: 1px solid var(--hair);
    border-radius: 18px;
    padding: 18px 18px 16px;
    box-shadow: 0 10px 30px var(--shadow);
    position: relative;
  }
  
  /* hand-drawn-ish “wobbly” edge illusion */
  .card:before{
    content:"";
    position:absolute;
    inset: 8px;
    border: 1px dashed rgba(0,0,0,.18);
    border-radius: 16px;
    pointer-events:none;
  }
  
  h2{
    margin: 0 0 10px;
    font-size: 24px;
    font-weight: 600;
    letter-spacing: .6px;
  }
  
  .label{
    margin: 0;
    font-weight: 600;
    letter-spacing: .8px;
    text-transform: uppercase;
    font-size: 13px;
    color: var(--gray);
  }
  
  .muted{ color: var(--gray); }
  .tiny{ font-size: 13px; }
  
  .grid{
    display:grid;
    grid-template-columns: 1fr;
    gap: 14px;
  }
  @media (min-width: 720px){
    .grid{ grid-template-columns: 1fr 1fr; }
  }
  
  .links{
    margin-top: 8px;
    display:flex;
    gap: 14px;
    flex-wrap: wrap;
  }
  
  .ink-link{
    color: var(--ink);
    text-decoration: none;
    border-bottom: 2px solid rgba(0,0,0,.35);
    padding-bottom: 2px;
  }
  .ink-link:hover{ border-bottom-color: rgba(0,0,0,.75); }
  
  .mapbox{
    width:100%;
    aspect-ratio: 16/9;
    border-radius: 14px;
    overflow:hidden;
    border: 1px solid var(--hair);
    background: rgba(0,0,0,.03);
  }
  .mapbox iframe{
    width:100%;
    height:100%;
    border:0;
    filter: grayscale(1) contrast(1.05);
  }
  
  .gallery{
    display:grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 10px;
  }
  .frame{
    border-radius: 14px;
    overflow:hidden;
    border: 1px solid var(--hair);
    background: rgba(0,0,0,.03);
    aspect-ratio: 1/1;
    box-shadow: 0 8px 20px var(--shadow);
  }
  .frame img{
    width:100%;
    height:100%;
    object-fit: cover;
    filter: grayscale(1) contrast(1.1);
  }
  .placeholder{
    background:
      repeating-linear-gradient(135deg, rgba(0,0,0,.05) 0 6px, transparent 6px 12px);
  }
  
  .form{
    display:grid;
    gap: 10px;
    margin-top: 6px;
  }
  label span{
    display:block;
    font-size: 13px;
    letter-spacing: .7px;
    text-transform: uppercase;
    color: var(--gray);
    margin-bottom: 4px;
  }
  input,select,textarea{
    width:100%;
    padding: 10px 12px;
    border-radius: 12px;
    border: 1px solid var(--hair);
    background: rgba(255,255,255,.7);
    color: var(--ink);
    font-family: inherit;
    font-size: 18px;
    outline: none;
  }
  input:focus,select:focus,textarea:focus{
    border-color: rgba(0,0,0,.35);
  }
  
  .btn{
    justify-self:start;
    padding: 10px 14px;
    border-radius: 999px;
    border: 1px solid rgba(0,0,0,.35);
    background: transparent;
    color: var(--ink);
    font-family: inherit;
    font-size: 18px;
    cursor: pointer;
  }
  .btn:hover{
    background: rgba(0,0,0,.04);
  }
  
  .hp{ display:none; }
  
  .foot{
    text-align:center;
    padding-top: 2px;
  }