/* =========================================================================
   LILY BISSET — "What Matters to Me" essay modal (matters.css)
   Depends on: styles.css tokens (--pink, --ink, --paper, --white,
               --font-display, --font-head, --font-mono,
               --accent-orange, --accent-teal)
   ========================================================================= */

/* ── overlay ── */
.emodal{position:fixed;inset:0;z-index:300;display:none;}
.emodal.is-open{display:block;}
.emodal__backdrop{
  position:absolute;inset:0;
  background:rgba(12,11,10,.76);backdrop-filter:blur(4px);
}

/* ── panel ── */
.emodal__panel{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:min(1500px,94vw);max-height:92vh;
  background:var(--paper);border:2px solid var(--ink);
  box-shadow:8px 8px 0 var(--ink);
  display:flex;flex-direction:column;overflow:hidden;
}

/* ── close button ── */
.emodal__close{
  position:absolute;top:12px;right:12px;z-index:20;
  width:38px;height:38px;min-width:38px;
  border:2px solid var(--ink);background:var(--paper);
  font-family:var(--font-mono);font-size:15px;color:var(--ink);
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  transition:background .18s,color .18s,border-color .18s;
}
.emodal__close:hover{background:var(--ink);color:var(--white);}

/* ── corner ornaments ── */
.emodal__orn-tl{
  position:absolute;top:14px;left:16px;z-index:10;
  display:flex;align-items:center;gap:5px;
}
.eorn-sq{display:block;width:11px;height:11px;flex:none;}
.eorn-plus{
  font-family:var(--font-mono);font-size:13px;font-weight:700;
  color:var(--ink);line-height:1;margin-left:3px;
}
.emodal__orn-tr{
  position:absolute;top:10px;right:60px;z-index:10;
  display:flex;align-items:center;gap:8px;
}
.eorn-counter{
  display:flex;flex-direction:column;align-items:flex-start;
  font-family:var(--font-mono);font-weight:700;font-size:11px;
  color:var(--pink);line-height:1.1;letter-spacing:.08em;
}
.eorn-counter b{font-weight:700;}

/* ── scrollable content ── */
.emodal__scroll{flex:1;min-height:0;overflow-y:auto;}

/* ── two-column body ── */
.emodal__body{
  display:grid;
  grid-template-columns:55fr 45fr;
}

/* ────────────────────────────────────────────────
   LEFT COLUMN
   ──────────────────────────────────────────────── */
.emodal__left{
  padding:clamp(52px,5vw,80px) clamp(24px,3vw,52px) clamp(28px,3vw,48px);
  border-right:2px solid var(--ink);
  display:flex;flex-direction:column;gap:clamp(18px,2vw,28px);
}

/* headline */
.em-headline{
  font-family:var(--font-display);
  font-size:clamp(48px,6.5vw,104px);
  text-transform:uppercase;line-height:.96;letter-spacing:-.01em;
  margin:0;color:var(--ink);
}
.em-hpink{color:var(--pink);}

/* short pink underline */
.em-hrule-short{
  width:clamp(48px,5vw,72px);height:3px;
  background:var(--pink);flex:none;
}

/* intro two sub-columns */
.em-2col{
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(16px,2.4vw,36px);
}
.em-2col p{
  font-family:var(--font-mono);font-size:clamp(11.5px,0.88vw,13.5px);
  line-height:1.76;color:#2e2c27;margin:0 0 .8em;text-wrap:pretty;
}
.em-2col p:last-child{margin-bottom:0;}

/* full-width rule */
.em-hrule{height:1.5px;background:var(--ink);flex:none;}

/* section label bar */
.em-section-label{
  display:flex;align-items:center;gap:.7em;
  background:var(--ink);color:var(--white);
  padding:.55em .9em;
  font-family:var(--font-head);font-weight:700;font-size:clamp(9px,0.75vw,11px);
  text-transform:uppercase;letter-spacing:.16em;line-height:1.2;
}
.em-lbl-sq{
  display:block;width:.65em;height:.65em;flex:none;
  background:var(--pink);
}

/* three sub-columns */
.em-3col{
  display:grid;grid-template-columns:repeat(3,1fr);
  border-top:1.5px solid #c5c0b3;
  flex:1;
}
.em-3col__col{
  padding:clamp(14px,1.6vw,22px) clamp(12px,1.2vw,18px);
  border-right:1.5px solid #c5c0b3;
}
.em-3col__col:last-child{border-right:0;}
.em-3col__col p{
  font-family:var(--font-mono);font-size:clamp(10.5px,0.82vw,12.5px);
  line-height:1.72;color:#2e2c27;margin:0 0 .9em;text-wrap:pretty;
}
.em-3col__col p:last-child{margin-bottom:0;}

/* inline pink accent */
.em-pink{color:var(--pink);}

/* ────────────────────────────────────────────────
   RIGHT COLUMN
   ──────────────────────────────────────────────── */
.emodal__right{
  background:var(--white);
  display:flex;flex-direction:column;
  border-left:0;
}

/* black header bar */
.em-right-head{
  background:var(--ink);color:var(--white);
  display:flex;align-items:center;gap:.7em;
  padding:.7em clamp(16px,1.8vw,26px);
  font-family:var(--font-head);font-weight:700;
  font-size:clamp(9.5px,0.78vw,11.5px);
  text-transform:uppercase;letter-spacing:.16em;
  flex:none;
}
.em-rh-sq{
  display:block;width:.65em;height:.65em;flex:none;
  background:var(--pink);
}

/* intro text below head */
.em-right-intro{
  font-family:var(--font-mono);font-size:clamp(11px,0.84vw,13px);
  line-height:1.65;color:#3a3832;margin:0;text-wrap:pretty;
  padding:clamp(14px,1.6vw,22px) clamp(16px,1.8vw,26px);
  border-bottom:1.5px solid #d4d0c8;
}

/* five rows */
.em-five{
  display:flex;flex-direction:column;flex:1;
}
.em-row{
  display:flex;align-items:flex-start;gap:clamp(12px,1.2vw,16px);
  padding:clamp(12px,1.3vw,18px) clamp(16px,1.8vw,26px);
  border-bottom:1.5px solid #d4d0c8;
}
.em-row:last-child{border-bottom:0;}

/* icon tile */
.em-tile{
  flex:none;width:clamp(34px,3.2vw,44px);height:clamp(34px,3.2vw,44px);
  background:var(--tile,var(--pink));
  display:flex;align-items:center;justify-content:center;
  padding:clamp(6px,0.6vw,9px);
}
.em-tile svg{width:100%;height:100%;display:block;}

/* row body */
.em-row__body{display:flex;flex-direction:column;gap:5px;min-width:0;}
.em-lead{
  font-family:var(--font-mono);font-weight:700;
  font-size:clamp(12px,1.05vw,15px);letter-spacing:.2em;
  text-transform:uppercase;display:block;line-height:1;
}
.em-row__body p{
  font-family:var(--font-mono);font-size:clamp(10.5px,0.8vw,12px);
  line-height:1.65;color:#2e2c27;margin:0;text-wrap:pretty;
}

/* ────────────────────────────────────────────────
   GO DEEPER band (full-width)
   ──────────────────────────────────────────────── */
.em-deeper{
  display:flex;align-items:center;gap:clamp(20px,2.8vw,44px);flex-wrap:wrap;
  background:var(--ink);
  padding:clamp(22px,2.6vw,38px) clamp(24px,3vw,52px);
  border-top:2px solid var(--ink);
  position:relative;overflow:hidden;
}
/* diagonal stripe on left edge */
.em-deeper::before{
  content:"";position:absolute;left:0;top:0;bottom:0;
  width:clamp(36px,4.5vw,64px);pointer-events:none;
  background:repeating-linear-gradient(
    -45deg,
    transparent,transparent 7px,
    rgba(255,255,255,.06) 7px,rgba(255,255,255,.06) 14px
  );
}

.em-deeper__label{
  display:flex;align-items:center;gap:.7em;flex:none;
  position:relative;z-index:1;
}
.em-deeper__sq{
  display:block;width:.7em;height:.7em;flex:none;background:var(--pink);
}
.em-deeper__title{
  font-family:var(--font-head);font-weight:700;
  font-size:clamp(14px,1.3vw,20px);text-transform:uppercase;
  letter-spacing:.08em;color:var(--white);
}

.em-deeper__text{
  font-family:var(--font-mono);font-size:clamp(11.5px,0.9vw,14px);
  line-height:1.65;color:#b0aa9e;margin:0;flex:1;min-width:200px;
  text-wrap:pretty;position:relative;z-index:1;
}
.em-deeper__pink{color:var(--pink);}

.em-deeper__btn{
  flex:none;display:inline-flex;align-items:center;gap:.6em;
  font-family:var(--font-mono);font-weight:700;letter-spacing:.13em;
  font-size:clamp(10px,0.78vw,12px);text-transform:uppercase;
  color:var(--pink);border:2px solid var(--pink);
  padding:.9em 1.3em;line-height:1;
  transition:background .18s,color .18s;
  position:relative;z-index:1;
}
.em-deeper__btn:hover{background:var(--pink);color:var(--white);}
.em-deeper__btn .ar{font-size:1.1em;}

/* ────────────────────────────────────────────────
   RESPONSIVE
   ──────────────────────────────────────────────── */

/* ≤900px — single column, right column drops below left */
@media (max-width:900px){
  .emodal__body{grid-template-columns:1fr;}
  .emodal__left{border-right:0;border-bottom:2px solid var(--ink);}
  .em-2col{grid-template-columns:1fr;}
  .em-3col{grid-template-columns:1fr;}
  .em-3col__col{border-right:0;border-bottom:1.5px solid #c5c0b3;}
  .em-3col__col:last-child{border-bottom:0;}
  .em-deeper{flex-direction:column;align-items:flex-start;}
}

/* ≤560px — shrink headline, tighten */
@media (max-width:560px){
  .emodal__panel{width:100vw;max-height:100dvh;top:0;left:0;transform:none;border:none;box-shadow:none;}
  .em-headline{font-size:clamp(38px,11vw,58px);}
  .emodal__left{padding:48px clamp(16px,4vw,24px) clamp(22px,4vw,32px);}
  .emodal__orn-tl{top:10px;left:12px;}
  .emodal__orn-tr{right:52px;top:8px;}
  .em-deeper__btn{font-size:10px;letter-spacing:.1em;}
}
