/* hafiz.css — HafizOnLove.com */
@import url('https://fonts.googleapis.com/css2?family=EB+Garamond:ital,wght@0,400;0,500;1,400&family=Vazirmatn:wght@400;500;700&display=swap');
:root {
  --ink:#111010; --ink-2:#2c2b28; --ink-3:#5a5855;
  --rule:rgba(17,16,16,.15);
  --surf:rgba(255,255,255,.90); --surf-2:rgba(245,242,235,.93); --surf-3:rgba(234,229,218,.96);
  --accent:#8b2500; --accent-bg:rgba(139,37,0,.08); --hover:#c04a00;
  --font-ui:'Vazirmatn',system-ui,sans-serif;
  --font-lit:'EB Garamond',Georgia,serif;
  --r-md:8px; --r-lg:12px; --trans:160ms ease; --max:1100px; --prose:860px;
}
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { font-size:16px; scroll-behavior:smooth; }
body {
  background-image:url('images/back.gif');
  background-repeat:repeat; background-attachment:fixed;
  color:var(--ink); font-family:var(--font-ui); line-height:1.7;
  min-height:100vh; display:flex; flex-direction:column;
}
img { display:block; max-width:100%; height:auto; }
a { color:inherit; text-decoration:none; }
a:hover { color:var(--hover); }
ul,ol { list-style:none; }
button { font:inherit; cursor:pointer; background:none; border:none; }
h1,h2,h3 { font-weight:500; line-height:1.25; }
h1 { font-size:1.5rem; } h2 { font-size:1.1rem; }
p { line-height:1.75; }
.label { font-size:.6875rem; font-weight:600; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-3); }
.tiny { font-size:.75rem; color:var(--ink-3); }
.muted { color:var(--ink-2); font-size:.875rem; }
/* SHELL */
.site-header { background:var(--surf); border-bottom:1px solid var(--rule); position:sticky; top:0; z-index:100; backdrop-filter:blur(4px); }
.hdr-inner { max-width:var(--max); margin:0 auto; padding:0 1.5rem; height:54px; display:flex; align-items:center; justify-content:space-between; gap:1rem; }
main { flex:1; width:100%; margin:0 auto; padding:.75rem 1.5rem 3rem; }
main.narrow { max-width:var(--prose); }
main.wide   { max-width:var(--max); }
main.home   { max-width:var(--prose); padding-top:2rem; }
.panel { background:var(--surf); border-radius:var(--r-lg); border:.5px solid var(--rule); padding:1.5rem 2rem; margin-bottom:1.5rem; }
.site-footer { border-top:1px solid var(--rule); background:var(--surf); padding:.75rem 1.5rem; backdrop-filter:blur(4px); }
.ftr-inner { max-width:var(--max); margin:0 auto; display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:.5rem; }
.copyright { font-size:.75rem; color:var(--ink-3); }
/* LOGO */
.logo { display:flex; align-items:center; gap:.625rem; text-decoration:none; color:var(--ink); flex-shrink:0; }
.logo img { border-radius:50%; object-fit:cover; border:1px solid var(--rule); }
.logo .en { font-size:.9375rem; font-weight:600; color:var(--ink); }
.logo .fa-name { font-family:var(--font-lit); font-size:.9375rem; color:var(--ink-2); }
.logo:hover .en, .logo:hover .fa-name { color:var(--hover); }
/* NAV */
.site-nav { display:flex; gap:3px; align-items:center; }
.nav-link { font-size:.875rem; font-weight:500; color:var(--ink-2); padding:.375rem .625rem; border-radius:var(--r-md); transition:background var(--trans),color var(--trans); white-space:nowrap; }
.nav-link:hover { background:var(--accent-bg); color:var(--hover); }
.nav-link.active { background:var(--surf-3); color:var(--ink); font-weight:700; }
.more-wrap { position:relative; }
.more-btn { font-size:.875rem; font-weight:500; color:var(--ink-2); padding:.375rem .625rem; border-radius:var(--r-md); cursor:pointer; transition:background var(--trans),color var(--trans); white-space:nowrap; user-select:none; }
.more-btn:hover { background:var(--accent-bg); color:var(--hover); }
.more-menu { display:none; position:absolute; top:calc(100% + 6px); right:0; background:var(--surf); border:1px solid var(--rule); border-radius:var(--r-lg); box-shadow:0 4px 16px rgba(0,0,0,.12); min-width:160px; z-index:200; padding:.5rem 0; }
.more-wrap:hover .more-menu, .more-wrap:focus-within .more-menu { display:block; }
.more-menu a { display:block; padding:.5rem 1rem; font-size:.875rem; color:var(--ink-2); transition:background var(--trans),color var(--trans); }
.more-menu a:hover { background:var(--accent-bg); color:var(--hover); }
.more-menu hr { border:none; border-top:.5px solid var(--rule); margin:.375rem 0; }
/* BREADCRUMB */
.bc { display:flex; align-items:center; gap:.5rem; padding:.625rem 0 1rem; }
.bc span { font-size:.8125rem; color:var(--ink-3); }
.bc a { color:var(--ink-3); }
.bc a:hover { color:var(--hover); }
.bc .cur { color:var(--ink-2); }
/* PAGE HEADER */
.ph { padding:1.25rem 0; border-bottom:1px solid var(--rule); margin-bottom:1.5rem; display:flex; align-items:baseline; justify-content:space-between; gap:1rem; }
.ph h1 { font-size:1.5rem; font-weight:600; }
.ph .sub { font-size:.875rem; color:var(--ink-3); margin-top:.125rem; }
.ph .fa-h { font-family:var(--font-lit); font-size:1.25rem; color:var(--ink-2); flex-shrink:0; direction:rtl; text-align:right; }
/* HOME */
.home-logo-wrap { text-align:center; padding:2rem 0 1.5rem; border-bottom:1px solid var(--rule); margin-bottom:1.5rem; }
.home-logo-wrap img { width:140px; height:140px; border-radius:50%; object-fit:cover; border:2px solid var(--rule); margin:0 auto 1rem; }
.home-logo-wrap .name-en  { font-size:2.25rem; font-weight:700; line-height:1.1; }
.home-logo-wrap .name-fa  { font-family:var(--font-lit); font-size:1.625rem; color:var(--ink-2); margin-top:.25rem; }
.home-logo-wrap .name-full { font-size:.875rem; color:var(--ink-3); margin-top:.375rem; }
.verse-bi { display:grid; grid-template-columns:1fr 1fr; gap:2rem; margin:1.5rem 0; padding:1.5rem 1.75rem; background:rgba(122,62,30,.055); border:1px solid rgba(122,62,30,.2); border-radius:var(--r-lg); }
.verse-bi .v-en { font-family:var(--font-lit); font-size:1.1rem; line-height:2.1; color:var(--ink); }
.verse-bi .v-fa { font-family:var(--font-lit); font-size:1.2rem; line-height:2.1; direction:rtl; text-align:right; color:var(--ink); padding-top:2.1rem; }
.home-more { display:flex; justify-content:center; gap:1.25rem; padding:.75rem 0; border-top:.5px solid var(--rule); flex-wrap:wrap; }
.home-more a { font-size:.8125rem; color:var(--ink-3); transition:color var(--trans); }
.home-more a:hover { color:var(--hover); }
/* NAV BUTTONS */
.nav-imgs { display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:.75rem; margin-bottom:1.5rem; }
.nav-img-btn { display:flex; flex-direction:column; align-items:center; text-decoration:none; border-radius:var(--r-lg); overflow:hidden; border:1px solid var(--rule); background:var(--surf); transition:border-color var(--trans),box-shadow var(--trans),background var(--trans); }
.nav-img-btn:hover { border-color:var(--accent); background:var(--accent-bg); box-shadow:0 2px 12px rgba(139,37,0,.12); }
.nav-img-btn__swap { position:relative; width:100%; aspect-ratio:5/2; overflow:hidden; }
.nav-img-btn__bw, .nav-img-btn__col { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; transition:opacity var(--trans); }
.nav-img-btn__col { opacity:0; }
.nav-img-btn:hover .nav-img-btn__bw { opacity:0; }
.nav-img-btn:hover .nav-img-btn__col { opacity:1; }
.nav-img-btn__text { padding:.5rem .75rem .625rem; text-align:center; width:100%; }
.nav-img-btn__en   { display:block; font-size:.9375rem; font-weight:600; color:var(--ink-2); transition:color var(--trans); }
.nav-img-btn__fa   { display:block; font-family:var(--font-lit); font-size:1rem; color:var(--ink-3); direction:rtl; transition:color var(--trans); }
.nav-img-btn__note { display:block; font-size:.6875rem; color:var(--ink-3); margin-top:.125rem; transition:color var(--trans); }
.nav-img-btn:hover .nav-img-btn__en,
.nav-img-btn:hover .nav-img-btn__fa,
.nav-img-btn:hover .nav-img-btn__note { color:var(--hover); }
.also { margin-bottom:1.25rem; }
.also .lbl { font-size:.6875rem; font-weight:600; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-3); margin-bottom:.625rem; }
.also-links { display:flex; gap:.5rem; flex-wrap:wrap; }
.pill { font-size:.875rem; color:var(--ink-2); border:1px solid var(--rule); border-radius:20px; padding:.375rem 1rem; background:var(--surf); font-weight:500; transition:background var(--trans),color var(--trans),border-color var(--trans); }
.pill:hover { background:var(--accent-bg); border-color:var(--accent); color:var(--hover); }
/* POETRY INDEX */
.group-grid { display:grid; grid-template-columns:1fr 1fr; gap:.5rem; margin-bottom:1.5rem; }
.group-card { background:var(--surf); border:1px solid var(--rule); border-radius:var(--r-lg); padding:.45rem 1rem; display:flex; align-items:center; gap:.75rem; text-decoration:none; color:var(--ink); font-weight:500; transition:border-color var(--trans),color var(--trans),box-shadow var(--trans); }
.group-card:hover { border-color:var(--accent); color:var(--hover); box-shadow:0 2px 8px rgba(139,37,0,.08); }
.group-card .t { font-size:.9rem; font-weight:600; flex-shrink:0; color:var(--ink); transition:color var(--trans); }
.group-card .f { font-family:var(--font-lit); font-size:1rem; color:var(--ink-3); direction:rtl; text-align:right; unicode-bidi:embed; flex:1; transition:color var(--trans); }
.group-card:hover .t, .group-card:hover .f { color:var(--hover); }
.group-card .arr { font-size:.875rem; color:var(--ink-3); flex-shrink:0; }
.misc-row  { display:grid; grid-template-columns:1fr 1fr; gap:.5rem; margin-bottom:1.5rem; }
.misc-card { background:var(--surf); border:1px solid var(--rule); border-radius:var(--r-lg); padding:.45rem 1rem; display:flex; align-items:center; gap:.75rem; text-decoration:none; transition:border-color var(--trans),color var(--trans),box-shadow var(--trans); }
.misc-card:hover { border-color:var(--accent); box-shadow:0 2px 8px rgba(139,37,0,.08); }
.misc-card .t { font-size:.9rem; font-weight:600; color:var(--ink-2); flex-shrink:0; transition:color var(--trans); }
.misc-card .f { font-family:var(--font-lit); font-size:1rem; color:var(--ink-3); direction:rtl; text-align:right; unicode-bidi:embed; flex:1; transition:color var(--trans); }
.misc-card:hover .t, .misc-card:hover .f { color:var(--hover); }
/* GHAZAL SUB-INDEX */
.g-list { margin-bottom:1.5rem; }
.g-item { display:flex; align-items:baseline; justify-content:space-between; padding:.5rem .625rem; border:1px solid transparent; border-radius:var(--r-md); gap:1rem; transition:background var(--trans),border-color var(--trans); }
.g-item:hover { background:var(--accent-bg); border-color:rgba(139,37,0,.15); }
.g-item + .g-item { border-top:.5px solid var(--rule); }
.g-link { font-size:1rem; font-weight:500; color:var(--ink-2); transition:color var(--trans); }
.g-item:hover .g-link { color:var(--hover); }
.g-fa { font-family:var(--font-lit); font-size:1.1rem; font-weight:500; color:var(--ink-2); direction:rtl; text-align:right; transition:color var(--trans); }
.g-item:hover .g-fa { color:var(--hover); }
.idx-nav { display:flex; align-items:center; justify-content:space-between; padding:1.25rem 0 .25rem; border-top:1px solid var(--rule); margin-top:.75rem; }
/* GHAZAL PAGE */
.gz-hdr { padding:1.25rem 0; border-bottom:1px solid var(--rule); margin-bottom:1.5rem; display:flex; align-items:baseline; justify-content:space-between; gap:1rem; }
.gz-hdr h1 { font-size:1.5rem; font-weight:600; }
.gz-hdr .fa-n { font-family:var(--font-lit); font-size:1.25rem; color:var(--ink-2); }
.v-cols { position:relative; }
.v-cols::after { content:''; position:absolute; top:0; bottom:0; left:calc(50% - .25px); width:.5px; background:var(--rule); pointer-events:none; }
.v-row { display:grid; grid-template-columns:1fr 1fr; gap:2rem; padding:1.25rem 0; border-bottom:.5px solid var(--rule); align-items:start; }
.v-row:last-child { border-bottom:none; }
.v-row .v-en { font-family:var(--font-lit); font-size:1.1rem; line-height:2.05; color:var(--ink); }
.v-row .v-fa { font-family:var(--font-lit); font-size:1.25rem; line-height:2.2; direction:rtl; text-align:right; color:var(--ink); font-weight:500; }
/* RUBAIYAT / MISC rows */
.rub-row { display:grid; grid-template-columns:1fr 1fr; gap:2rem; padding:1.5rem 0; border-bottom:1px solid var(--rule); align-items:start; }
.rub-row:last-child { border-bottom:none; }
.rub-num { font-size:.75rem; font-weight:700; color:var(--ink-3); margin-bottom:.375rem; letter-spacing:.05em; }
.rub-row .v-en { font-family:var(--font-lit); font-size:1.05rem; line-height:1.95; color:var(--ink); }
.rub-row .v-fa { font-family:var(--font-lit); font-size:1.2rem; line-height:2.1; direction:rtl; text-align:right; unicode-bidi:embed; color:var(--ink); font-weight:500; }
/* CONTINUOUS POEM rows (Saghi-Nameh, Wild Deer) */
.prose-row { display:grid; grid-template-columns:1fr 1fr; gap:2rem; padding:1.25rem 0; border-bottom:.5px solid var(--rule); align-items:start; }
.prose-row:last-child { border-bottom:none; }
.prose-row .v-en { font-family:var(--font-lit); font-size:1.05rem; line-height:2; color:var(--ink); }
.prose-row .v-fa { font-family:var(--font-lit); font-size:1.2rem; line-height:2.2; direction:rtl; text-align:right; unicode-bidi:embed; color:var(--ink); font-weight:500; }
/* POEM NAV */
.p-nav { display:flex; align-items:center; justify-content:space-between; padding:1.5rem 0; border-top:1px solid var(--rule); margin-top:.75rem; }
.p-btn { display:inline-flex; align-items:center; gap:.5rem; font-size:.9rem; font-weight:500; color:var(--ink-2); border:1px solid var(--rule); border-radius:var(--r-md); padding:.5rem 1.25rem; background:var(--surf); transition:color var(--trans),border-color var(--trans),background var(--trans),box-shadow var(--trans); text-decoration:none; }
.p-btn:hover { border-color:var(--accent); color:var(--hover); background:var(--accent-bg); box-shadow:0 2px 8px rgba(139,37,0,.10); }
.p-btn.off { opacity:.3; pointer-events:none; }
.p-mid { font-size:.8125rem; color:var(--ink-3); }
.p-mid:hover { color:var(--hover); }
/* GALLERY */
.gallery { display:grid; grid-template-columns:repeat(5,minmax(0,1fr)); gap:.625rem; margin-bottom:1.5rem; }
.g-thumb { background:var(--surf-3); border:1px solid var(--rule); border-radius:var(--r-md); overflow:hidden; cursor:pointer; transition:border-color var(--trans),box-shadow var(--trans); }
.g-thumb:hover { border-color:var(--accent); box-shadow:0 2px 12px rgba(139,37,0,.12); }
.g-thumb img { width:100%; aspect-ratio:1/1; object-fit:cover; display:block; border-bottom:1px solid var(--rule); }
.g-thumb span { font-size:.75rem; font-weight:500; color:var(--ink-2); padding:.375rem .5rem; display:block; }
/* LIGHTBOX */
.lightbox { display:none; position:fixed; inset:0; background:rgba(0,0,0,.85); z-index:1000; align-items:center; justify-content:center; }
.lightbox.open { display:flex; }
.lightbox-inner { position:relative; max-width:90vw; max-height:90vh; background:#111; border-radius:var(--r-lg); overflow:hidden; display:flex; align-items:center; justify-content:center; }
.lightbox-inner img { max-width:90vw; max-height:85vh; object-fit:contain; display:block; }
.lb-close { position:absolute; top:.625rem; right:.75rem; width:32px; height:32px; border-radius:50%; background:rgba(0,0,0,.6); color:#fff; font-size:1.25rem; line-height:32px; text-align:center; cursor:pointer; border:1px solid rgba(255,255,255,.2); transition:background var(--trans); }
.lb-close:hover { background:var(--accent); }
.lb-prev, .lb-next { position:absolute; top:50%; transform:translateY(-50%); width:40px; height:40px; border-radius:50%; background:rgba(0,0,0,.55); color:#fff; font-size:1.25rem; line-height:40px; text-align:center; cursor:pointer; border:1px solid rgba(255,255,255,.2); transition:background var(--trans); user-select:none; }
.lb-prev { left:.75rem; } .lb-next { right:.75rem; }
.lb-prev:hover, .lb-next:hover { background:var(--accent); }
/* BIOGRAPHY */
.bio-intro { font-size:1rem; line-height:1.85; color:var(--ink-2); margin-bottom:1.5rem; }
.bio-sec { margin-bottom:1.5rem; }
.bio-sec h2 { font-size:1rem; font-weight:600; color:var(--ink); padding-bottom:.625rem; border-bottom:1px solid var(--rule); margin-bottom:.875rem; }
.bio-ev { display:grid; grid-template-columns:9rem 1fr; gap:.25rem 1.5rem; padding:.625rem 0; border-bottom:.5px solid var(--rule); }
.bio-ev:last-child { border-bottom:none; }
.bio-ev .dt { font-size:.8125rem; color:var(--ink-3); padding-top:2px; font-weight:500; }
.bio-ev .dd { font-size:.875rem; line-height:1.7; color:var(--ink-2); }
.bio-ev .dd strong { font-weight:600; color:var(--ink); }
.tomb { display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:.5rem; margin-top:.875rem; }
.tomb-item { border:1px solid var(--rule); border-radius:var(--r-md); overflow:hidden; cursor:pointer; transition:border-color var(--trans); }
.tomb-item:hover { border-color:var(--accent); }
.tomb-item img { width:100%; aspect-ratio:4/3; object-fit:cover; display:block; max-height:100px; }
.bio-q { padding:.875rem 0; border-bottom:.5px solid var(--rule); }
.bio-q:last-child { border-bottom:none; }
.bio-q .qt { font-family:var(--font-lit); font-size:1.05rem; line-height:1.8; color:var(--ink-2); font-style:italic; margin-bottom:.375rem; }
.bio-q .at { font-size:.875rem; color:var(--ink-3); font-weight:500; }
.bio-refs { font-size:.875rem; line-height:1.75; color:var(--ink-3); }
.bio-refs li { padding:.375rem 0; border-bottom:.5px solid var(--rule); }
.bio-refs li:last-child { border-bottom:none; }
.oracle-verse { margin:1rem 0; }
/* FAL */
.fal-intro-txt { font-size:1rem; line-height:1.85; color:var(--ink-2); margin-bottom:1.5rem; }
.fal-steps { margin-bottom:1.5rem; }
.fal-step { display:flex; gap:1rem; align-items:flex-start; padding:.875rem 0; border-bottom:.5px solid var(--rule); }
.fal-step:last-child { border-bottom:none; }
.fal-sn { width:24px; height:24px; border-radius:50%; background:var(--surf-3); border:1px solid var(--rule); display:flex; align-items:center; justify-content:center; font-size:.75rem; font-weight:700; color:var(--ink-2); flex-shrink:0; margin-top:2px; }
.fal-st { font-size:.9375rem; line-height:1.75; color:var(--ink-2); }
.fal-act { text-align:center; padding:2rem 0; border-top:1px solid var(--rule); border-bottom:1px solid var(--rule); margin-bottom:1.5rem; }
.fal-act p { font-family:var(--font-lit); font-size:1.1rem; color:var(--ink-3); font-style:italic; margin-bottom:1.5rem; }
.fal-go { display:inline-flex; align-items:center; justify-content:center; gap:.75rem; padding:1rem 2rem; border:1px solid var(--rule); border-radius:var(--r-lg); background:var(--surf); font-size:1rem; font-weight:600; color:var(--ink); cursor:pointer; width:100%; max-width:380px; transition:border-color var(--trans),background var(--trans),color var(--trans),box-shadow var(--trans); }
.fal-go:hover { border-color:var(--accent); background:var(--accent-bg); color:var(--hover); box-shadow:0 2px 10px rgba(139,37,0,.12); }
.fal-go .fgfa { font-family:var(--font-lit); font-size:1rem; color:var(--ink-3); }
.fal-res { background:var(--surf); border:1px solid var(--rule); border-radius:var(--r-lg); padding:1.5rem; margin-bottom:1.5rem; display:none; }
.fal-res.show { display:block; }
.fal-res-hdr { display:flex; align-items:baseline; justify-content:space-between; padding-bottom:.875rem; border-bottom:1px solid var(--rule); margin-bottom:1rem; }
.fal-res-hdr .n { font-size:.9375rem; font-weight:600; }
.fal-full-btn { display:inline-flex; align-items:center; gap:.5rem; font-size:.9375rem; font-weight:600; color:var(--surf); background:var(--accent); border:none; border-radius:var(--r-md); padding:.75rem 1.75rem; cursor:pointer; transition:background var(--trans),box-shadow var(--trans); text-decoration:none; margin-top:.75rem; }
.fal-full-btn:hover { background:var(--hover); box-shadow:0 2px 10px rgba(139,37,0,.25); }
/* SECONDARY PAGES */
.sec-page { max-width:640px; }
.sec-page h2 { font-size:1rem; font-weight:600; margin:1.5rem 0 .625rem; padding-bottom:.5rem; border-bottom:1px solid var(--rule); }
.sec-page p { font-size:.9rem; line-height:1.8; color:var(--ink-2); margin-bottom:1rem; }
.sec-page a { color:var(--accent); text-decoration:underline; text-underline-offset:2px; }
.sec-page hr { border:none; border-top:.5px solid var(--rule); margin:1.5rem 0; }
.sec-site-link { display:flex; flex-direction:column; gap:.125rem; padding:.75rem 0; border-bottom:.5px solid var(--rule); }
.sec-site-link:last-child { border-bottom:none; }
.sec-site-link .t { font-size:.9375rem; font-weight:600; color:var(--ink); }
.sec-site-link .u { font-size:.8125rem; color:var(--accent); text-decoration:underline; }
.sec-site-link .d { font-size:.8125rem; color:var(--ink-3); }
/* RESPONSIVE */
@media (max-width:700px) {
  main { padding:.75rem .875rem 2rem; }
  .panel { padding:1rem; }
  .verse-bi, .v-row, .rub-row, .prose-row { grid-template-columns:1fr; }
  .v-cols::after { display:none; }
  .verse-bi .v-fa { padding-top:0; }
  .nav-imgs { grid-template-columns:1fr 1fr; }
  .group-grid, .misc-row { grid-template-columns:1fr; }
  .gallery { grid-template-columns:repeat(3,minmax(0,1fr)); }
  .bio-ev { grid-template-columns:1fr; gap:.125rem; }
  .tomb { grid-template-columns:1fr 1fr; }
}
@media print and (orientation:landscape) {
  body { background-image:none; background:#fff; }
  .site-header, .site-footer, .bc, .p-nav { display:none; }
  .panel { border:none; padding:0; }
  .v-row { page-break-inside:avoid; }
  main.wide { max-width:100%; padding:0; }
}
