/* =========================================================
   Midhun J Francis, SJ — bold / minimalist
   Space Grotesk (display) · Spectral (reading) · Ultramarine
   ========================================================= */
:root{
  --paper:#FBFAF7;
  --paper-2:#F0EEE8;
  --ink:#0E0E0D;
  --ink-2:#33322E;
  --muted:#76746C;
  --line:#E2DFD7;
  --line-2:#CDC9BF;
  --blue:#1E22B8;        /* ultramarine accent */
  --blue-deep:#15188C;
  --blue-ink:#0C0E5A;

  --max:1120px;
  --radius:2px;
  --font-d:"Space Grotesk",system-ui,sans-serif;   /* display / UI */
  --font-r:"Spectral",Georgia,serif;               /* reading       */
}

*,*::before,*::after{box-sizing:border-box;margin:0}
html{-webkit-text-size-adjust:100%}
body{
  background:var(--paper);color:var(--ink);
  font-family:var(--font-r);font-size:18px;line-height:1.6;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}
:focus-visible{outline:2px solid var(--blue);outline-offset:3px}
::selection{background:var(--blue);color:#fff}

.wrap{max-width:var(--max);margin-inline:auto;padding-inline:clamp(20px,5vw,44px)}

.eyebrow{
  font-family:var(--font-d);font-size:.72rem;font-weight:600;
  letter-spacing:.22em;text-transform:uppercase;color:var(--blue);
}

/* =========================================================
   Masthead
   ========================================================= */
.masthead{border-bottom:2px solid var(--ink)}
.masthead__inner{
  display:flex;justify-content:space-between;align-items:flex-end;gap:28px;flex-wrap:wrap;
  padding-block:clamp(30px,6vw,64px) clamp(20px,3vw,30px);
}
.brand{max-width:18ch}
.brand__kicker{
  font-family:var(--font-d);font-size:.74rem;font-weight:600;letter-spacing:.2em;
  text-transform:uppercase;color:var(--muted);display:block;margin-bottom:14px;
}
.brand__name{
  font-family:var(--font-d);font-weight:700;
  font-size:clamp(2.6rem,8vw,5.4rem);line-height:.9;letter-spacing:-.03em;
}
.brand__name .sj{color:var(--blue)}
.masthead__side{
  display:flex;flex-direction:column;gap:6px;text-align:right;
  font-family:var(--font-d);font-size:.82rem;color:var(--muted);padding-bottom:6px;
}
.masthead__side .desc{max-width:30ch;line-height:1.5;margin-bottom:8px;color:var(--ink-2)}
.masthead__side a{border-bottom:1px solid var(--line-2);padding-bottom:1px}
.masthead__side a:hover{color:var(--blue);border-color:var(--blue)}

/* =========================================================
   Featured — full-bleed ultramarine
   ========================================================= */
.featured{background:var(--blue);color:#fff}
.featured__inner{
  display:grid;gap:clamp(18px,3vw,28px);
  padding-block:clamp(40px,7vw,84px);
}
.featured .eyebrow{color:rgba(255,255,255,.72)}
.featured__title{
  font-family:var(--font-d);font-weight:700;
  font-size:clamp(2.2rem,5.6vw,4.4rem);line-height:1;letter-spacing:-.025em;
  max-width:16ch;
}
.featured__title a:hover{text-decoration:underline;text-underline-offset:6px;text-decoration-thickness:2px}
.featured__intro{
  font-family:var(--font-r);font-size:clamp(1.1rem,2vw,1.4rem);line-height:1.5;
  max-width:54ch;color:rgba(255,255,255,.92);
}
.featured__meta{
  display:flex;align-items:center;gap:14px;flex-wrap:wrap;
  font-family:var(--font-d);font-size:.8rem;letter-spacing:.04em;color:rgba(255,255,255,.8);
}
.featured__actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:6px}

/* =========================================================
   Filters
   ========================================================= */
.filters{border-bottom:1px solid var(--line);position:sticky;top:0;z-index:30;
  background:color-mix(in srgb,var(--paper) 88%,transparent);backdrop-filter:blur(8px)}
.filters__inner{display:flex;gap:6px;flex-wrap:wrap;align-items:center;padding-block:12px}
.filter{
  font-family:var(--font-d);font-size:.82rem;font-weight:500;color:var(--ink-2);
  padding:7px 13px;border-radius:999px;border:1px solid transparent;
  transition:color .15s,background .15s,border-color .15s;
}
.filter:hover{background:var(--paper-2)}
.filter[aria-pressed="true"]{background:var(--ink);color:var(--paper)}
.filter .count{opacity:.5;margin-left:5px;font-variant-numeric:tabular-nums}

/* =========================================================
   Index list (bold typographic rows)
   ========================================================= */
.index{padding-block:clamp(20px,3vw,40px) clamp(50px,8vw,90px)}
.index__head{
  display:flex;align-items:baseline;justify-content:space-between;gap:16px;
  padding-block:22px 8px;
}
.index__head h2{font-family:var(--font-d);font-weight:700;font-size:1.1rem;letter-spacing:-.01em}
.index__head span{font-family:var(--font-d);font-size:.78rem;color:var(--muted)}

.piece{
  display:grid;grid-template-columns:1fr auto;gap:18px 28px;align-items:start;
  padding-block:clamp(22px,3vw,32px);border-top:1px solid var(--line);
  opacity:0;transform:translateY(10px);
  transition:opacity .5s ease,transform .5s cubic-bezier(.2,.7,.2,1);
}
.piece.in{opacity:1;transform:none}
.piece:last-child{border-bottom:1px solid var(--line)}

.piece__meta{
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:12px;
  font-family:var(--font-d);font-size:.74rem;letter-spacing:.03em;color:var(--muted);
}
.piece__meta .dot{width:3px;height:3px;border-radius:50%;background:var(--line-2)}
.piece__source{color:var(--ink-2)}
.piece__title{
  font-family:var(--font-d);font-weight:600;
  font-size:clamp(1.45rem,3vw,2.15rem);line-height:1.06;letter-spacing:-.02em;
  max-width:24ch;
}
.piece__title a{
  background-image:linear-gradient(var(--blue),var(--blue));
  background-size:0% 2px;background-repeat:no-repeat;background-position:0 100%;
  transition:background-size .3s ease,color .2s ease;
}
.piece:hover .piece__title a{color:var(--blue)}
.piece__intro{
  margin-top:12px;color:var(--ink-2);font-size:1.04rem;line-height:1.55;max-width:64ch;
}
.piece__actions{
  display:flex;flex-direction:column;align-items:flex-end;gap:10px;
  min-width:0;
}
@media (max-width:680px){
  .piece{grid-template-columns:1fr}
  .piece__actions{flex-direction:row;align-items:center;justify-content:flex-start}
}

.tag{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--font-d);font-size:.66rem;font-weight:600;letter-spacing:.1em;
  text-transform:uppercase;color:var(--ink);
  border:1px solid var(--line-2);padding:4px 8px;border-radius:999px;
}
.tag svg{width:12px;height:12px}
.tag--pdf{color:var(--blue);border-color:color-mix(in srgb,var(--blue) 35%,var(--line-2))}
.tag--video{color:var(--blue)}
.featured .tag{color:#fff;border-color:rgba(255,255,255,.45)}

/* =========================================================
   Buttons
   ========================================================= */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-d);font-size:.82rem;font-weight:600;letter-spacing:.01em;
  padding:10px 16px;border-radius:999px;border:1.5px solid var(--ink);white-space:nowrap;
  transition:background .16s,color .16s,border-color .16s,transform .08s;
}
.btn svg{width:15px;height:15px}
.btn:active{transform:translateY(1px)}
.btn--primary{background:var(--ink);color:var(--paper)}
.btn--primary:hover{background:var(--blue);border-color:var(--blue)}
.btn--ghost:hover{border-color:var(--blue);color:var(--blue)}
.btn--onblue{background:#fff;color:var(--blue-ink);border-color:#fff}
.btn--onblue:hover{background:transparent;color:#fff}
.btn--onblue-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.6)}
.btn--onblue-ghost:hover{border-color:#fff}

.share-btn{
  display:inline-flex;align-items:center;gap:7px;
  font-family:var(--font-d);font-size:.78rem;font-weight:600;color:var(--ink-2);
  padding:8px 12px;border-radius:999px;border:1px solid var(--line-2);
  transition:border-color .15s,color .15s;
}
.share-btn svg{width:14px;height:14px}
.share-btn:hover{border-color:var(--blue);color:var(--blue)}
.featured .share-btn{color:#fff;border-color:rgba(255,255,255,.5)}
.featured .share-btn:hover{border-color:#fff;background:rgba(255,255,255,.12)}

/* =========================================================
   About
   ========================================================= */
.about{border-top:2px solid var(--ink);background:var(--paper)}
.about__inner{
  display:grid;grid-template-columns:minmax(0,1fr) 220px;gap:clamp(28px,5vw,60px);
  padding-block:clamp(44px,7vw,80px);align-items:start;
}
@media (max-width:760px){.about__inner{grid-template-columns:1fr}}
.about h2{font-family:var(--font-d);font-weight:700;font-size:clamp(1.8rem,4vw,2.6rem);
  letter-spacing:-.02em;margin-bottom:20px}
.about p{font-size:1.1rem;line-height:1.65;color:var(--ink-2);max-width:60ch;margin-bottom:14px}
.about__roles{display:flex;flex-wrap:wrap;gap:8px;margin-top:22px}
.about__roles span{
  font-family:var(--font-d);font-size:.74rem;letter-spacing:.02em;color:var(--ink-2);
  border:1px solid var(--line-2);border-radius:999px;padding:6px 11px;
}
.portrait{
  aspect-ratio:4/5;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  background:var(--blue);display:grid;place-items:center;
}
.portrait img{width:100%;height:100%;object-fit:cover}
.portrait .mono{font-family:var(--font-d);font-weight:700;font-size:4rem;color:#fff;letter-spacing:-.03em}

/* =========================================================
   Share popover + toast (shared)
   ========================================================= */
.pop{position:fixed;z-index:80;min-width:212px;background:var(--paper);
  border:1px solid var(--line-2);border-radius:10px;
  box-shadow:0 24px 60px -24px rgba(14,14,13,.5);padding:7px;display:flex;flex-direction:column;
  opacity:0;transform:translateY(6px) scale(.98);transform-origin:top right;
  transition:opacity .14s,transform .14s}
.pop.in{opacity:1;transform:none}
.pop__head{font-family:var(--font-d);font-size:.62rem;font-weight:700;letter-spacing:.16em;
  text-transform:uppercase;color:var(--muted);padding:8px 10px 6px}
.pop button{display:flex;align-items:center;gap:11px;width:100%;text-align:left;
  font-family:var(--font-d);font-size:.85rem;font-weight:500;color:var(--ink);
  padding:9px 10px;border-radius:7px;transition:background .14s}
.pop button:hover{background:var(--paper-2)}
.pop button svg{width:17px;height:17px;flex:0 0 17px;color:var(--ink-2)}
.pop__backdrop{position:fixed;inset:0;z-index:79}
.toast{position:fixed;left:50%;bottom:26px;transform:translate(-50%,16px);
  background:var(--ink);color:var(--paper);font-family:var(--font-d);font-size:.85rem;font-weight:500;
  padding:11px 18px;border-radius:999px;z-index:90;opacity:0;
  transition:opacity .2s,transform .2s;box-shadow:0 18px 40px -20px rgba(0,0,0,.6)}
.toast.in{opacity:1;transform:translate(-50%,0)}

/* =========================================================
   Empty state
   ========================================================= */
.empty{text-align:center;padding:80px 20px;color:var(--muted)}
.empty h2{font-family:var(--font-d);font-weight:700;font-size:1.5rem;color:var(--ink-2);margin-bottom:8px}

/* =========================================================
   Article / detail reader
   ========================================================= */
.reader{padding-block:clamp(22px,4vw,40px) clamp(60px,9vw,110px)}
.reader__back{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-d);
  font-size:.8rem;font-weight:600;color:var(--muted);margin-bottom:clamp(24px,4vw,42px)}
.reader__back:hover{color:var(--blue)}
.reader__back svg{width:15px;height:15px}

.doc{max-width:780px;margin-inline:auto}
.doc__meta{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:20px;
  font-family:var(--font-d);font-size:.78rem;letter-spacing:.03em;color:var(--muted)}
.doc__meta .piece__source{color:var(--ink-2)}
.doc__title{font-family:var(--font-d);font-weight:700;
  font-size:clamp(2.1rem,5.4vw,3.6rem);line-height:1.02;letter-spacing:-.025em;margin-bottom:20px}
.doc__intro{font-family:var(--font-r);font-size:clamp(1.2rem,2.4vw,1.5rem);line-height:1.45;
  color:var(--ink-2);font-style:italic;max-width:60ch}
.doc__tools{display:flex;gap:10px;flex-wrap:wrap;align-items:center;
  padding-block:22px;margin-block:24px;border-block:1px solid var(--line)}

.doc__cover{margin-block:8px 30px;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.prose{font-size:1.18rem;line-height:1.74;color:var(--ink)}
.prose>*+*{margin-top:1.25em}
.prose p{max-width:68ch}
.prose h2{font-family:var(--font-d);font-weight:700;font-size:1.6rem;letter-spacing:-.01em;margin-top:1.9em}
.prose blockquote{border-left:3px solid var(--blue);padding-left:22px;font-style:italic;
  color:var(--ink-2);font-size:1.3rem;line-height:1.5}
.prose figure{margin-block:2em}
.prose figure img{width:100%;border-radius:var(--radius);border:1px solid var(--line)}
.prose figcaption{font-family:var(--font-d);font-size:.76rem;color:var(--muted);margin-top:10px}
.prose a:not(.btn){color:var(--blue);text-decoration:underline;text-underline-offset:3px}

.frame--pdf{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  aspect-ratio:1/1.25;max-height:88vh;background:var(--paper-2)}
.frame--pdf iframe{width:100%;height:100%;border:0;display:block}
.docblock{
  border:1px solid var(--line-2);border-radius:var(--radius);padding:clamp(24px,4vw,40px);
  background:var(--paper);display:flex;flex-direction:column;gap:18px;
}
.docblock .eyebrow{color:var(--blue)}
.docblock h3{font-family:var(--font-d);font-weight:700;font-size:1.3rem;letter-spacing:-.01em}
.docblock .actions-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:4px}

.video-embed{position:relative;aspect-ratio:16/9;background:#000;border-radius:var(--radius);
  overflow:hidden;border:1px solid var(--line)}
.video-embed iframe,.video-embed video{position:absolute;inset:0;width:100%;height:100%;border:0}
.coming-soon{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;
  text-align:center;aspect-ratio:16/9;background:var(--paper-2);
  border:1px dashed var(--line-2);border-radius:var(--radius);color:var(--muted)}
.coming-soon svg{width:34px;height:34px;color:var(--blue)}
.coming-soon strong{font-family:var(--font-d);font-weight:700;font-size:1.3rem;color:var(--ink-2)}

/* =========================================================
   Footer
   ========================================================= */
.foot{border-top:1px solid var(--line)}
.foot__inner{display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;
  padding-block:30px;font-family:var(--font-d);font-size:.8rem;color:var(--muted)}
.foot a:hover{color:var(--blue)}

@media (prefers-reduced-motion:reduce){
  *{transition:none!important;animation:none!important}
  .piece{opacity:1;transform:none}
}
