/* ============================================================
   LORELEI WEB DESIGN — Article & Gutenberg blocks
   ============================================================ */

/* ---------- SINGLE POST HEADER ---------- */
.single-head{padding:clamp(56px,7vw,104px) var(--pad) clamp(40px,5vw,60px);border-bottom:.5px solid var(--rule);max-width:var(--maxw);margin:0 auto;}
.single-head .crumb{font-family:var(--fu);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--mid);font-weight:500;margin-bottom:34px;}
.single-head .crumb a{text-decoration:none;color:var(--periw);}
.single-cat{display:inline-flex;align-items:center;gap:14px;margin-bottom:22px;}
.single-cat span{font-family:var(--fu);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--periw);font-weight:600;}
.single-cat::after{content:'';width:42px;height:.5px;background:var(--periw);}
.single-title{font-family:var(--fd);font-weight:400;font-size:clamp(42px,6.4vw,92px);line-height:.96;letter-spacing:-.02em;max-width:16ch;}
.single-title em{font-style:italic;color:var(--periw);}
.single-sub{font-family:var(--fb);font-style:italic;font-weight:300;font-size:clamp(18px,2vw,24px);line-height:1.5;color:var(--soft);max-width:60ch;margin-top:26px;}
.single-meta{display:flex;gap:clamp(28px,4vw,52px);margin-top:38px;flex-wrap:wrap;}
.single-meta .item{display:flex;flex-direction:column;gap:5px;}
.single-meta .ml{font-family:var(--fu);font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--mid);font-weight:500;}
.single-meta .mv{font-family:var(--fb);font-size:14px;color:var(--ink);}
.single-meta .mv a{text-decoration:none;color:var(--periw);}

/* hero image */
.single-hero-img{position:relative;height:clamp(320px,46vw,560px);background:var(--bg2);overflow:hidden;border-bottom:.5px solid var(--rule);}
.single-hero-img img{width:100%;height:100%;object-fit:cover;}
.single-hero-img .cap{position:absolute;bottom:16px;right:var(--pad);font-family:var(--fu);font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--mid);}

/* reading progress (top bar) */
.read-progress{position:fixed;top:0;left:0;height:3px;width:0;background:var(--periw);z-index:200;transition:width .1s linear;}

/* ---------- BODY LAYOUT ---------- */
.single-body{display:grid;grid-template-columns:210px minmax(0,1fr);gap:clamp(40px,6vw,84px);max-width:var(--maxw);margin:0 auto;padding:clamp(56px,7vw,90px) var(--pad);border-bottom:.5px solid var(--rule);}
.single-aside{position:sticky;top:108px;align-self:start;}
.aside-sec{margin-bottom:40px;}
.aside-label{font-family:var(--fu);font-size:9px;letter-spacing:.24em;text-transform:uppercase;color:var(--mid);font-weight:600;margin-bottom:16px;}
.toc{list-style:none;display:flex;flex-direction:column;gap:11px;}
.toc a{font-family:var(--fu);font-size:11.5px;color:var(--mid);text-decoration:none;display:flex;gap:10px;line-height:1.4;font-weight:400;transition:color .25s;}
.toc a:hover,.toc a.active{color:var(--periw);}
.toc .tn{font-family:var(--fd);font-style:italic;font-size:11px;color:var(--faint);flex-shrink:0;}
.share{list-style:none;display:flex;flex-direction:column;gap:10px;}
.share a{font-family:var(--fu);font-size:11px;letter-spacing:.04em;color:var(--mid);text-decoration:none;display:flex;align-items:center;gap:10px;transition:color .25s;}
.share a::before{content:'';width:14px;height:.5px;background:currentColor;transition:width .25s;}
.share a:hover{color:var(--periw);}
.share a:hover::before{width:22px;}

/* ---------- ARTICLE CONTENT (Gutenberg) ---------- */
.entry{max-width:680px;}
.entry>*{margin-bottom:28px;}
.entry>*:last-child{margin-bottom:0;}
.entry p{font-family:var(--fb);font-size:19px;line-height:1.78;color:var(--ink);}
.entry .has-drop-cap:first-letter,.entry>p:first-of-type::first-letter{font-family:var(--fd);font-weight:400;font-size:88px;float:left;line-height:.72;margin:8px 12px 0 0;color:var(--periw);}
.entry a{color:var(--periw);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:.5px;}
.entry a:hover{color:var(--bright);}
.entry h2{font-family:var(--fd);font-weight:400;font-size:clamp(30px,3.6vw,44px);line-height:1.08;letter-spacing:-.01em;margin:56px 0 6px;}
.entry h3{font-family:var(--fu);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--periw);font-weight:600;margin:40px 0 2px;}
.entry h4{font-family:var(--fd);font-style:italic;font-weight:400;font-size:26px;margin:32px 0 2px;}
.entry strong{font-weight:600;}
.entry em{font-style:italic;}
.entry ul,.entry ol{padding-left:0;list-style:none;display:flex;flex-direction:column;gap:12px;}
.entry ul li,.entry ol li{font-family:var(--fb);font-size:18px;line-height:1.7;color:var(--ink);padding-left:26px;position:relative;}
.entry ul li::before{content:'';position:absolute;left:2px;top:13px;width:8px;height:8px;border:1.5px solid var(--periw);border-radius:50%;}
.entry ol{counter-reset:li;}
.entry ol li{counter-increment:li;}
.entry ol li::before{content:counter(li);position:absolute;left:0;top:2px;font-family:var(--fd);font-style:italic;color:var(--periw);font-size:17px;}

/* blockquote */
.entry blockquote,.wp-block-quote{border-left:2px solid var(--periw);padding:6px 0 6px 30px;margin:44px 0;}
.entry blockquote p,.wp-block-quote p{font-family:var(--fd);font-style:italic;font-weight:400;font-size:clamp(24px,3vw,32px);line-height:1.28;color:var(--ink);}
.wp-block-quote cite,.entry cite{display:block;font-family:var(--fu);font-style:normal;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--mid);margin-top:16px;}

/* pullquote */
.wp-block-pullquote{border-top:2px solid var(--periw);border-bottom:.5px solid var(--rule);padding:38px 0;margin:52px 0;text-align:left;}
.wp-block-pullquote p{font-family:var(--fd);font-style:italic;font-weight:400;font-size:clamp(28px,4vw,44px);line-height:1.18;color:var(--ink);}
.wp-block-pullquote cite{margin-top:18px;}

/* images / figures */
.entry figure,.wp-block-image{margin:44px 0;}
.entry figure img,.wp-block-image img{width:100%;border-radius:2px;}
.entry figcaption,.wp-block-image figcaption{font-family:var(--fu);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--mid);margin-top:12px;text-align:center;}
.wp-block-image.alignwide{width:min(1000px,92vw);margin-left:50%;transform:translateX(-50%);}
.wp-block-image.alignfull{width:100vw;margin-left:50%;transform:translateX(-50%);}
figure.ph-figure .ph-img{position:relative;height:clamp(240px,32vw,420px);border-radius:2px;}

/* gallery */
.wp-block-gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin:44px 0;}
.wp-block-gallery figure{margin:0;}

/* cover */
.wp-block-cover{position:relative;min-height:380px;display:flex;align-items:center;justify-content:center;padding:48px;margin:44px 0;overflow:hidden;color:#fff;border-radius:2px;}
.wp-block-cover .ph-img{z-index:0;}
.wp-block-cover .wp-block-cover__inner-container,.wp-block-cover .cover-inner{position:relative;z-index:2;text-align:center;}
.wp-block-cover::after{content:'';position:absolute;inset:0;background:rgba(28,25,38,.45);z-index:1;}
.wp-block-cover p{font-family:var(--fd);font-style:italic;font-size:clamp(28px,4vw,46px);color:#fff;}

/* buttons block */
.wp-block-buttons{display:flex;gap:14px;flex-wrap:wrap;margin:36px 0;}
.wp-block-button__link{font-family:var(--fu);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:#fff;background:var(--periw);padding:15px 28px;text-decoration:none;font-weight:600;border-radius:40px;display:inline-block;transition:transform .3s,background .3s;}
.wp-block-button__link:hover{transform:translateY(-3px);background:var(--bright);color:#fff;}
.wp-block-button.is-style-outline .wp-block-button__link{background:transparent;color:var(--ink);border:1px solid var(--rule);}

/* code / preformatted */
.entry pre,.wp-block-code{font-family:'SFMono-Regular',ui-monospace,Menlo,Consolas,monospace;font-size:14px;line-height:1.7;background:var(--ink);color:#E6E2D8;padding:28px;border-radius:3px;overflow-x:auto;margin:36px 0;}
.entry code{font-family:ui-monospace,Menlo,Consolas,monospace;font-size:.86em;background:var(--bg2);padding:2px 7px;border-radius:3px;color:var(--bright);}
.entry pre code{background:none;padding:0;color:inherit;}

/* table */
.entry table,.wp-block-table table{width:100%;border-collapse:collapse;margin:36px 0;font-family:var(--fb);font-size:16px;}
.entry th,.wp-block-table th{font-family:var(--fu);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--mid);text-align:left;padding:14px;border-bottom:1px solid var(--rule);font-weight:600;}
.entry td,.wp-block-table td{padding:14px;border-bottom:.5px solid var(--rule2);color:var(--ink);}

/* separator / hr */
.entry hr,.wp-block-separator{border:none;height:.5px;background:var(--rule);margin:52px 0;}
.wp-block-separator.is-style-dots{background:none;text-align:center;}
.wp-block-separator.is-style-dots::before{content:'\2726 \2726 \2726';color:var(--faint);font-size:12px;letter-spacing:1em;}

/* table of contents callout / verse / etc */
.wp-block-verse{font-family:var(--fd);font-style:italic;font-size:22px;line-height:1.5;padding:24px 30px;background:var(--bg2);border-radius:3px;}

/* tags */
.entry-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:52px;padding-top:26px;border-top:.5px solid var(--rule);}
.entry-tags a{font-family:var(--fu);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--soft);border:.5px solid var(--rule);padding:7px 14px;border-radius:40px;text-decoration:none;transition:all .2s;}
.entry-tags a:hover{border-color:var(--periw);color:var(--periw);}

/* ---------- AUTHOR BOX ---------- */
.author-box{display:grid;grid-template-columns:auto 1fr;gap:28px;align-items:start;max-width:var(--maxw);margin:0 auto;padding:clamp(44px,5vw,72px) var(--pad);border-bottom:.5px solid var(--rule);}
.author-box .ava{width:84px;height:84px;border-radius:50%;overflow:hidden;background:var(--bg2);border:.5px solid var(--rule);position:relative;}
.author-box .role{font-family:var(--fu);font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:var(--periw);font-weight:600;margin-bottom:10px;}
.author-box h3{font-family:var(--fd);font-style:italic;font-weight:400;font-size:30px;margin-bottom:12px;}
.author-box p{font-family:var(--fb);font-size:15px;line-height:1.7;color:var(--soft);max-width:60ch;font-style:italic;}

/* ---------- RELATED ---------- */
.related{border-bottom:.5px solid var(--rule);}

/* ---------- COMMENTS ---------- */
.comments{max-width:760px;margin:0 auto;padding:clamp(48px,6vw,84px) var(--pad);}
.comments-title{font-family:var(--fd);font-style:italic;font-weight:400;font-size:clamp(26px,3vw,38px);margin-bottom:36px;}
.comment{display:flex;gap:18px;padding:24px 0;border-bottom:.5px solid var(--rule2);}
.comment .ava{width:48px;height:48px;border-radius:50%;background:var(--bg2);flex-shrink:0;overflow:hidden;border:.5px solid var(--rule);position:relative;}
.comment .who{font-family:var(--fu);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink);font-weight:600;}
.comment .when{font-family:var(--fu);font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--faint);margin-left:10px;}
.comment .body{font-family:var(--fb);font-size:16px;line-height:1.7;color:var(--soft);margin-top:10px;}
.comment .reply{font-family:var(--fu);font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--periw);text-decoration:none;margin-top:10px;display:inline-block;}
.comment-form{margin-top:44px;display:flex;flex-direction:column;gap:18px;}
.comment-form .row{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.comment-form input,.comment-form textarea{font-family:var(--fb);font-size:16px;background:transparent;border:none;border-bottom:1px solid var(--rule);padding:12px 0;color:var(--ink);outline:none;transition:border-color .25s;}
.comment-form input:focus,.comment-form textarea:focus{border-color:var(--periw);}
.comment-form textarea{min-height:120px;resize:vertical;font-style:italic;}

/* ---------- PAGE / CONTACT ---------- */
.page-content{max-width:760px;margin:0 auto;padding:clamp(48px,6vw,84px) var(--pad);}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,5vw,72px);max-width:var(--maxw);margin:0 auto;padding:clamp(48px,6vw,90px) var(--pad);border-bottom:.5px solid var(--rule);}
.contact-info h2{font-family:var(--fd);font-weight:400;font-size:clamp(28px,3.4vw,42px);line-height:1.05;margin-bottom:22px;}
.contact-info h2 em{font-style:italic;color:var(--periw);}
.contact-info p{font-family:var(--fb);font-style:italic;font-size:17px;line-height:1.7;color:var(--soft);max-width:42ch;margin-bottom:32px;}
.contact-detail{margin-bottom:24px;}
.contact-detail .l{font-family:var(--fu);font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:var(--mid);font-weight:600;margin-bottom:8px;}
.contact-detail .v{font-family:var(--fd);font-size:22px;}
.contact-detail .v a{text-decoration:none;color:var(--ink);}
.contact-form{display:flex;flex-direction:column;gap:22px;}
.contact-form label{font-family:var(--fu);font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--mid);font-weight:600;display:block;margin-bottom:8px;}
.contact-form input,.contact-form textarea,.contact-form select{width:100%;font-family:var(--fb);font-size:17px;background:transparent;border:none;border-bottom:1px solid var(--rule);padding:12px 0;color:var(--ink);outline:none;transition:border-color .25s;}
.contact-form input:focus,.contact-form textarea:focus{border-color:var(--periw);}
.contact-form textarea{min-height:130px;resize:vertical;font-style:italic;}

@media(max-width:860px){
  .single-body{grid-template-columns:1fr;}
  .single-aside{position:static;display:flex;gap:40px;flex-wrap:wrap;border-bottom:.5px solid var(--rule);padding-bottom:8px;margin-bottom:8px;}
  .contact-grid{grid-template-columns:1fr;}
  .wp-block-gallery{grid-template-columns:1fr;}
}
@media(max-width:560px){
  .comment-form .row{grid-template-columns:1fr;}
}
