/*
Theme Name: Mitad del Mundo
Theme URI: https://ecuadorianliterature.com
Author: Richard Gabela
Description: A custom theme for Ecuadorian Literature — an illuminated archive at the middle of the world (0 0 0). Andean-night palette, colonial gold, Otavalo-textile magenta; Fraunces + Hanken Grotesk + Spline Sans Mono.
Version: 1.0
Requires at least: 6.0
Tested up to: 7.0
License: GNU GPL v2 or later
Text Domain: mitad-del-mundo
*/
@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400;0,9..144,500;0,9..144,600;1,9..144,400;1,9..144,500&family=Hanken+Grotesk:wght@400;500;600;700&family=Spline+Sans+Mono:wght@400;500;600&display=swap');

:root{
  --noche:#0A1A2E; --noche-2:#11294A; --panel:#16314F; --panel-2:#1B3960;
  --oro:#D8B45A; --oro-2:#F1DCA0; --rosa:#E45C8C;
  --hueso:#ECE6D6; --niebla:#94A6C0;
  --linea:rgba(216,180,90,.28); --hair:rgba(236,230,214,.14);
  --maxw:1180px; --readw:720px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--noche);color:var(--hueso);font-family:"Hanken Grotesk",system-ui,sans-serif;font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.coord{font-family:"Spline Sans Mono",monospace;font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--oro)}
.eyebrow{font-family:"Spline Sans Mono",monospace;font-size:12px;letter-spacing:.26em;text-transform:uppercase;color:var(--niebla)}
.section-title{font-family:"Fraunces",serif;font-weight:500;font-size:clamp(28px,4.4vw,46px);line-height:1.02;letter-spacing:-.015em}
.section-title em{font-style:italic;color:var(--oro)}
:focus-visible{outline:2px solid var(--oro);outline-offset:3px;border-radius:2px}
.skip-link{position:absolute;left:-9999px}
.skip-link:focus{left:12px;top:12px;z-index:200;background:var(--oro);color:var(--noche);padding:10px 16px;border-radius:6px}

/* header */
header.top{position:sticky;top:0;z-index:50;backdrop-filter:blur(9px);background:linear-gradient(180deg,rgba(10,29,39,.93),rgba(10,29,39,.55));border-bottom:1px solid var(--hair)}
header.top .wrap{display:flex;align-items:center;justify-content:space-between;min-height:64px;gap:16px}
.brand{display:flex;align-items:center;gap:11px;font-family:"Fraunces",serif;font-weight:500;font-size:19px;letter-spacing:-.01em;color:var(--hueso)}
.brand .dot{width:9px;height:9px;border-radius:50%;background:var(--oro);box-shadow:0 0 0 4px rgba(216,180,90,.15);flex:none}
nav.menu ul{list-style:none;display:flex;gap:24px;align-items:center;margin:0;padding:0;flex-wrap:wrap;justify-content:flex-end}
nav.menu a{font-family:"Spline Sans Mono",monospace;font-size:12.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--niebla);transition:color .2s}
nav.menu a:hover{color:var(--hueso)}
nav.menu .menu-item-has-children>a::after{content:" ↓";opacity:.5}

/* hero */
.hero{position:relative;min-height:92vh;display:flex;flex-direction:column;justify-content:center;background:radial-gradient(120% 80% at 50% -10%,#1B3A5E 0%,var(--noche-2) 38%,var(--noche) 80%);overflow:hidden;padding:110px 0 90px}
.stars{position:absolute;inset:0 0 50% 0;pointer-events:none;opacity:.7;background-image:radial-gradient(1.4px 1.4px at 12% 30%,rgba(236,230,214,.7),transparent),radial-gradient(1.2px 1.2px at 28% 14%,rgba(236,230,214,.55),transparent),radial-gradient(1.6px 1.6px at 47% 38%,rgba(241,220,160,.6),transparent),radial-gradient(1.1px 1.1px at 63% 20%,rgba(236,230,214,.5),transparent),radial-gradient(1.5px 1.5px at 78% 33%,rgba(236,230,214,.6),transparent),radial-gradient(1.2px 1.2px at 88% 12%,rgba(241,220,160,.55),transparent),radial-gradient(1.1px 1.1px at 38% 8%,rgba(236,230,214,.45),transparent),radial-gradient(1.3px 1.3px at 70% 6%,rgba(236,230,214,.45),transparent);animation:twinkle 6s ease-in-out infinite alternate}
@keyframes twinkle{from{opacity:.45}to{opacity:.8}}
.andes{position:absolute;left:0;right:0;bottom:0;width:100%;height:34%;display:block}
.hero .wrap{position:relative;z-index:3;text-align:center}
.hero .eyebrow{display:inline-block;margin-bottom:24px}
.hero h1{font-family:"Fraunces",serif;font-weight:400;font-size:clamp(46px,9vw,104px);line-height:.92;letter-spacing:-.025em}
.hero h1 .gold{color:var(--oro);font-style:italic;font-weight:500}
.equator{position:relative;height:0;margin:32px 0 30px}
.equator .line{height:1px;background:linear-gradient(90deg,transparent,var(--oro) 14%,var(--oro-2) 50%,var(--oro) 86%,transparent);box-shadow:0 0 22px 1px rgba(216,180,90,.5);transform-origin:center;animation:draw 1.5s cubic-bezier(.2,.7,.2,1) both}
@keyframes draw{from{transform:scaleX(0);opacity:0}to{transform:scaleX(1);opacity:1}}
.equator .badge{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);background:var(--noche);border:1px solid var(--linea);border-radius:999px;padding:5px 14px;font-family:"Spline Sans Mono",monospace;font-size:11.5px;letter-spacing:.2em;color:var(--oro);white-space:nowrap}
.hero .thesis{max-width:660px;margin:0 auto;font-size:clamp(17px,2vw,20px);opacity:.92}
.hero .meta{margin-top:28px;font-family:"Spline Sans Mono",monospace;font-size:12.5px;letter-spacing:.06em;color:var(--niebla)}
.hero .meta b{color:var(--oro);font-weight:600}
.hero-search{display:flex;gap:10px;max-width:480px;margin:30px auto 0}
.hero-search input{flex:1;background:rgba(22,49,79,.72);border:1px solid var(--linea);border-radius:999px;padding:13px 20px;color:var(--hueso);font-family:"Hanken Grotesk",sans-serif;font-size:15px}
.hero-search input::placeholder{color:var(--niebla)}
.hero-search input:focus{outline:none;border-color:var(--oro)}
.scrollcue{margin-top:44px;font-family:"Spline Sans Mono",monospace;font-size:11px;letter-spacing:.2em;color:var(--niebla);text-transform:uppercase}
.scrollcue span{display:block;margin-top:8px;font-size:15px;animation:bob 2s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(5px)}}

/* sections */
.section{padding:88px 0;position:relative}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:44px;flex-wrap:wrap}
.sec-head .coord{margin-bottom:10px;display:block}
.sec-head .note{max-width:330px;color:var(--niebla);font-size:15px}
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
.readlink{display:inline-flex;align-items:center;gap:8px;font-family:"Spline Sans Mono",monospace;font-size:12.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--oro);border-bottom:1px solid var(--linea);padding-bottom:3px}
.readlink:hover{color:var(--oro-2)}

/* century timeline */
.timeline{position:relative;padding-top:14px}
.timeline .axis{position:absolute;left:0;right:0;bottom:64px;height:1px;background:var(--hair)}
.cents{display:flex;align-items:flex-end;gap:14px}
.cent{flex:1;display:flex;flex-direction:column;align-items:center;text-align:center;color:var(--hueso)}
.cent .bar{width:60%;max-width:64px;border-radius:7px 7px 0 0;background:linear-gradient(180deg,var(--oro),rgba(216,180,90,.25));transition:filter .25s,transform .25s;min-height:10px}
.cent:hover .bar{filter:brightness(1.2);transform:scaleY(1.03)}
.cent .num{font-family:"Spline Sans Mono",monospace;font-size:13px;color:var(--oro-2);margin:10px 0 2px}
.cent .yr{font-family:"Fraunces",serif;font-size:18px;font-weight:500}
.cent .lbl{font-size:12.5px;color:var(--niebla);margin-top:64px}
.cent.peak .bar{background:linear-gradient(180deg,var(--rosa),rgba(228,92,140,.3))}
.cent.peak .num{color:#F7B6CE}

/* chips */
.chips{display:flex;flex-wrap:wrap;gap:12px}
.chip{display:inline-flex;align-items:baseline;gap:10px;border:1px solid var(--hair);border-radius:999px;padding:11px 18px;transition:border-color .2s,background .2s,transform .2s;color:var(--hueso)}
.chip:hover{border-color:var(--oro);background:rgba(216,180,90,.07);transform:translateY(-2px)}
.chip .name{font-size:15.5px}
.chip .n{font-family:"Spline Sans Mono",monospace;font-size:12px;color:var(--oro)}

/* featured translation */
.feature{background:linear-gradient(180deg,var(--noche-2),var(--noche));border-top:1px solid var(--hair);border-bottom:1px solid var(--hair)}
.poem-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.poem h3{font-family:"Fraunces",serif;font-style:italic;font-weight:500;font-size:30px;margin-bottom:4px}
.poem .who{font-family:"Spline Sans Mono",monospace;font-size:12px;color:var(--niebla);letter-spacing:.04em;margin-bottom:22px}
.poem .tag{font-family:"Spline Sans Mono",monospace;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--oro);margin-bottom:16px;display:block}
.stanza{font-family:"Fraunces",serif;font-size:19px;line-height:1.78;margin-bottom:18px}
.poem.es .stanza{font-style:italic;opacity:.9}
.feature .credit{margin-top:34px;font-size:15px;color:var(--niebla);max-width:680px}
.feature .credit b{color:var(--hueso);font-weight:600}

/* post cards grid */
.grid-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:16px}
.card{position:relative;border:1px solid var(--hair);border-radius:14px;padding:22px 20px 20px;background:linear-gradient(180deg,var(--panel),var(--noche-2));overflow:hidden;transition:transform .25s,border-color .25s;display:block;color:var(--hueso)}
.card:hover{transform:translateY(-4px);border-color:var(--linea)}
.card::before{content:"";position:absolute;left:0;top:0;width:100%;height:2px;background:linear-gradient(90deg,var(--oro),var(--rosa));transform:scaleX(0);transform-origin:left;transition:transform .3s}
.card:hover::before{transform:scaleX(1)}
.card .role{font-family:"Spline Sans Mono",monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--oro);margin-bottom:14px}
.card .name{font-family:"Fraunces",serif;font-size:22px;font-weight:500;line-height:1.15;margin-bottom:6px}
.card .ex{font-size:14px;color:var(--niebla);margin-top:8px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}

/* about */
.about-wrap{max-width:760px}
.about-wrap p{font-family:"Fraunces",serif;font-size:clamp(20px,2.4vw,27px);line-height:1.5}
.about-wrap p em{color:var(--oro);font-style:italic}
.sign{margin-top:24px;font-family:"Spline Sans Mono",monospace;font-size:12.5px;color:var(--niebla);letter-spacing:.05em}

/* ---- interior: single / page / archive ---- */
.page-head{padding:118px 0 0}
.page-head .eyebrow,.page-head .coord{display:block;margin-bottom:16px}
.entry-title{font-family:"Fraunces",serif;font-weight:500;font-size:clamp(32px,5.2vw,58px);line-height:1.04;letter-spacing:-.02em;max-width:16ch}
.entry-meta{margin-top:22px;display:flex;flex-wrap:wrap;gap:8px 18px;font-family:"Spline Sans Mono",monospace;font-size:12px;letter-spacing:.05em;color:var(--niebla)}
.entry-meta a{color:var(--oro)}
.entry-divider{height:1px;background:linear-gradient(90deg,var(--linea),transparent);margin:40px 0;position:relative}
.entry-divider::after{content:"0°0′0″";position:absolute;left:0;top:50%;transform:translateY(-50%);background:var(--noche);padding-right:12px;font-family:"Spline Sans Mono",monospace;font-size:10.5px;letter-spacing:.2em;color:var(--oro)}
.reading{max-width:var(--readw);margin:0 auto;padding:18px 28px 40px}
.entry-content{font-size:18.5px;line-height:1.8;color:var(--hueso)}
.entry-content p{margin:0 0 1.25em}
.entry-content h2{font-family:"Fraunces",serif;font-weight:500;font-size:30px;line-height:1.1;margin:1.8em 0 .5em;color:var(--hueso)}
.entry-content h3{font-family:"Fraunces",serif;font-weight:500;font-size:23px;margin:1.6em 0 .4em}
.entry-content a{color:var(--oro-2);text-decoration:underline;text-decoration-color:var(--linea);text-underline-offset:3px}
.entry-content a:hover{text-decoration-color:var(--oro)}
.entry-content em,.entry-content i{font-family:"Fraunces",serif;font-style:italic}
.entry-content strong{color:var(--oro-2);font-weight:600}
.entry-content blockquote{margin:1.4em 0;padding:.2em 0 .2em 24px;border-left:2px solid var(--oro);font-family:"Fraunces",serif;font-style:italic;font-size:21px;color:var(--hueso)}
.entry-content ul,.entry-content ol{margin:0 0 1.25em 1.3em}
.entry-content li{margin-bottom:.4em}
.entry-content img{border-radius:12px;border:1px solid var(--hair);margin:1.5em auto}
.entry-content hr{border:0;height:1px;background:var(--hair);margin:2em 0}
.entry-content table{width:100%;border-collapse:collapse;margin:1.4em 0;font-size:15px}
.entry-content th,.entry-content td{border-bottom:1px solid var(--hair);padding:9px 12px;text-align:left}
.backlink{display:inline-block;margin:18px 0 0;font-family:"Spline Sans Mono",monospace;font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--niebla)}
.backlink:hover{color:var(--oro)}

/* archive header + list */
.archive-head{padding:120px 0 14px;text-align:center}
.archive-head .count{margin-top:14px;font-family:"Spline Sans Mono",monospace;font-size:13px;color:var(--oro);letter-spacing:.06em}
.pagination{display:flex;gap:10px;justify-content:center;margin-top:54px;flex-wrap:wrap}
.pagination .page-numbers{font-family:"Spline Sans Mono",monospace;font-size:13px;padding:9px 14px;border:1px solid var(--hair);border-radius:8px;color:var(--niebla)}
.pagination .page-numbers.current{background:var(--oro);color:var(--noche);border-color:var(--oro);font-weight:600}
.pagination a.page-numbers:hover{border-color:var(--oro);color:var(--hueso)}

/* comments */
.comments{max-width:var(--readw);margin:0 auto;padding:10px 28px 70px}
.comments h2.comments-title{font-family:"Fraunces",serif;font-weight:500;font-size:26px;margin-bottom:8px}
.comments .coord{margin-bottom:26px;display:block}
.commentlist{list-style:none;margin:0;padding:0}
.commentlist li{border-top:1px solid var(--hair);padding:22px 0}
.commentlist .c-author{font-family:"Fraunces",serif;font-size:18px;font-weight:500}
.commentlist .c-date{font-family:"Spline Sans Mono",monospace;font-size:11px;color:var(--niebla);letter-spacing:.05em;margin-left:10px}
.commentlist .c-body{margin-top:8px;color:var(--hueso);opacity:.92}
.commentlist .children{list-style:none;margin:14px 0 0 26px;padding:0;border-left:1px solid var(--hair);padding-left:20px}
.comment-respond{margin-top:40px;border-top:1px solid var(--hair);padding-top:30px}
.comment-respond .comment-reply-title{font-family:"Fraunces",serif;font-size:22px;font-weight:500;margin-bottom:6px}
.comment-form{display:grid;gap:14px;margin-top:18px}
.comment-form p{margin:0}
.comment-form label{display:block;font-family:"Spline Sans Mono",monospace;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--niebla);margin-bottom:6px}
.comment-form input[type=text],.comment-form input[type=email],.comment-form input[type=url],.comment-form textarea{width:100%;background:var(--panel);border:1px solid var(--hair);border-radius:9px;padding:12px 14px;color:var(--hueso);font-family:"Hanken Grotesk",sans-serif;font-size:16px}
.comment-form textarea{min-height:130px;resize:vertical}
.comment-form input:focus,.comment-form textarea:focus{border-color:var(--oro);outline:none}
.btn,.comment-form input[type=submit]{display:inline-block;background:var(--oro);color:var(--noche);border:0;border-radius:999px;padding:12px 26px;font-family:"Spline Sans Mono",monospace;font-size:12.5px;letter-spacing:.08em;text-transform:uppercase;font-weight:600;cursor:pointer;transition:background .2s}
.btn:hover,.comment-form input[type=submit]:hover{background:var(--oro-2)}

/* Contact Form 7 + generic forms in content */
.wpcf7{max-width:560px}
.wpcf7-form{display:grid;gap:16px;margin-top:8px}
.wpcf7-form p{margin:0}
.wpcf7-form label{display:block;font-family:"Spline Sans Mono",monospace;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--niebla);margin-bottom:6px}
.wpcf7-form input[type=text],.wpcf7-form input[type=email],.wpcf7-form input[type=url],.wpcf7-form input[type=tel],.wpcf7-form input[type=number],.wpcf7-form textarea,.wpcf7-form select,
.entry-content input[type=text],.entry-content input[type=email],.entry-content input[type=url],.entry-content input[type=tel],.entry-content textarea,.entry-content select{
  width:100%;background:var(--panel);border:1px solid var(--hair);border-radius:9px;padding:12px 14px;color:var(--hueso);font-family:"Hanken Grotesk",sans-serif;font-size:16px}
.wpcf7-form textarea,.entry-content textarea{min-height:150px;resize:vertical}
.wpcf7-form input:focus,.wpcf7-form textarea:focus,.wpcf7-form select:focus,
.entry-content input:focus,.entry-content textarea:focus,.entry-content select:focus{border-color:var(--oro);outline:none}
.wpcf7-form input[type=submit],.wpcf7-submit,
.entry-content input[type=submit],.entry-content button[type=submit]{
  display:inline-block;width:auto;background:var(--oro);color:var(--noche);border:0;border-radius:999px;padding:13px 32px;font-family:"Spline Sans Mono",monospace;font-size:12.5px;letter-spacing:.08em;text-transform:uppercase;font-weight:600;cursor:pointer;transition:background .2s}
.wpcf7-form input[type=submit]:hover,.wpcf7-submit:hover,
.entry-content input[type=submit]:hover,.entry-content button[type=submit]:hover{background:var(--oro-2)}
.wpcf7 .wpcf7-response-output{border:1px solid var(--linea);border-radius:8px;padding:10px 14px;margin:16px 0 0;font-size:14.5px;color:var(--hueso)}
.wpcf7-not-valid-tip{color:var(--rosa);font-size:13px;margin-top:5px}
.wpcf7-spinner{margin-left:10px}

/* footer */
footer.site{border-top:1px solid var(--hair);padding:54px 0 40px;background:var(--noche-2)}
.foot-eq{height:1px;background:linear-gradient(90deg,transparent,var(--linea),transparent);margin-bottom:34px;position:relative}
.foot-eq::after{content:"0°0′0″";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);background:var(--noche-2);padding:0 12px;font-family:"Spline Sans Mono",monospace;font-size:11px;letter-spacing:.2em;color:var(--oro)}
.foot-row{display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap;align-items:center}
.foot-row .b{font-family:"Fraunces",serif;font-size:18px}
.foot-row .m{font-family:"Spline Sans Mono",monospace;font-size:12px;color:var(--niebla);letter-spacing:.04em}

@media(max-width:820px){
  nav.menu{display:none}
  .poem-grid{grid-template-columns:1fr;gap:30px}
  .section{padding:60px 0}
  .cent .yr{font-size:14px}.cent .lbl{font-size:10.5px}
  .reading,.comments{padding-left:22px;padding-right:22px}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;scroll-behavior:auto}
  .reveal{opacity:1;transform:none;transition:none}
  .equator .line{transform:none}
}
