/* InfoDev · Drakoyuda — Premium newspaper-style design */
*{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#fafaf6;
  --paper:#ffffff;
  --ink:#0E1A0F;
  --muted:#5a6260;
  --line:#e5e0d3;
  --green:#2E7D32;
  --green-dark:#1B5E20;
  --green-light:#81C784;
  --orange:#E65100;
  --highlight:#FFF59D;
  --shadow:0 6px 20px rgba(14,26,15,0.05);
  --shadow-lg:0 18px 50px rgba(14,26,15,0.08);
}
html,body{height:100%}
body{font-family:'Inter',system-ui,sans-serif;background:var(--bg);color:var(--ink);line-height:1.6;font-size:15px;-webkit-font-smoothing:antialiased;letter-spacing:-0.01em}
button{font-family:inherit;cursor:pointer}
input,textarea,select{font-family:inherit}

/* ===== LOGIN ===== */
.login-page{background:radial-gradient(circle at top right,rgba(46,125,50,0.05),transparent 50%),radial-gradient(circle at bottom left,rgba(230,81,0,0.04),transparent 50%),var(--bg)}
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem 1rem}
.login-card{background:var(--paper);border:1px solid var(--line);border-radius:24px;padding:3rem 2.5rem;max-width:420px;width:100%;text-align:center;box-shadow:var(--shadow-lg);position:relative;overflow:hidden}
.login-card::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--green),var(--orange))}
.login-logo{display:flex;justify-content:center;margin-bottom:1.2rem}
.login-tag{display:inline-block;font-size:.66rem;letter-spacing:2.5px;font-weight:800;text-transform:uppercase;color:var(--green-dark);background:rgba(46,125,50,0.08);padding:.3rem .75rem;border-radius:30px;border:1px solid rgba(46,125,50,0.2);margin-bottom:1rem}
.login-card h1{font-family:'Fraunces',serif;font-size:1.95rem;font-weight:500;letter-spacing:-0.8px;line-height:1.1;margin-bottom:.6rem;color:var(--ink)}
.login-card h1 em{font-style:italic;color:var(--green-dark);font-weight:500}
.login-sub{font-size:.88rem;color:var(--muted);margin-bottom:1.8rem;line-height:1.5}
.fld{margin-bottom:1rem;text-align:left}
.fld label{display:block;font-size:.7rem;letter-spacing:1.5px;font-weight:700;text-transform:uppercase;color:var(--muted);margin-bottom:.4rem}
.fld input,.fld textarea,.fld select{width:100%;padding:.75rem 1rem;border:1.5px solid var(--line);background:var(--paper);border-radius:10px;font-size:.92rem;color:var(--ink);transition:.15s;outline:none}
.fld input:focus,.fld textarea:focus,.fld select:focus{border-color:var(--green);box-shadow:0 0 0 4px rgba(46,125,50,0.1)}
.err{padding:.7rem .9rem;background:#fee;color:#8b0000;border:1px solid #fbb;border-radius:8px;font-size:.85rem;margin-bottom:1rem;text-align:left}
.btn-primary{width:100%;padding:.85rem 1.5rem;background:linear-gradient(135deg,var(--green),var(--green-dark));color:#fff;border:none;border-radius:10px;font-size:.92rem;font-weight:700;letter-spacing:.3px;box-shadow:0 8px 22px rgba(46,125,50,0.25);transition:.2s}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 12px 28px rgba(46,125,50,0.35)}
.btn-primary:active{transform:translateY(0)}
.login-foot{margin-top:2rem;font-size:.72rem;color:var(--muted);letter-spacing:1px}

/* ===== DASHBOARD ===== */
.dash-page{background:var(--bg);min-height:100vh}
.topbar{position:sticky;top:0;z-index:50;background:rgba(250,250,246,0.92);border-bottom:1px solid var(--line);padding:.85rem 1.5rem;display:flex;align-items:center;justify-content:space-between;backdrop-filter:blur(12px)}
.topbar .brand{display:flex;align-items:center;gap:.6rem;font-family:'Fraunces',serif;font-weight:600;font-size:1.05rem;color:var(--ink);text-decoration:none}
.topbar .brand svg{width:28px;height:28px}
.topbar .brand small{font-family:'Inter',sans-serif;font-weight:600;font-size:.62rem;letter-spacing:2px;color:var(--green-dark);background:rgba(46,125,50,0.1);padding:.18rem .5rem;border-radius:4px;margin-left:.4rem;text-transform:uppercase}
.topbar-actions{display:flex;gap:.5rem;align-items:center}
.btn-ghost{padding:.5rem 1rem;background:transparent;color:var(--muted);border:1px solid var(--line);border-radius:8px;font-size:.82rem;font-weight:600;text-decoration:none;transition:.15s}
.btn-ghost:hover{background:var(--paper);color:var(--ink);border-color:var(--ink)}

.dash{max-width:1100px;margin:0 auto;padding:2rem 1.5rem 4rem}
.hero-h1{font-family:'Fraunces',serif;font-size:clamp(1.8rem,3.5vw,2.4rem);font-weight:500;letter-spacing:-0.6px;line-height:1.1;color:var(--ink);margin-bottom:.4rem}
.hero-h1 em{font-style:italic;color:var(--green-dark)}
.hero-sub{font-size:1rem;color:var(--muted);margin-bottom:2rem;max-width:600px}

.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:2rem}
.stat-card{background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:1.1rem 1.2rem;box-shadow:var(--shadow);transition:.2s}
.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.stat-card .lbl{font-size:.66rem;letter-spacing:1.5px;font-weight:700;text-transform:uppercase;color:var(--muted);margin-bottom:.45rem}
.stat-card .val{font-family:'Fraunces',serif;font-size:1.85rem;font-weight:600;color:var(--ink);line-height:1}
.stat-card.green .val{color:var(--green-dark)}
.stat-card.orange .val{color:var(--orange)}
.stat-card .sub{font-size:.74rem;color:var(--muted);margin-top:.3rem}

.col-layout{display:grid;grid-template-columns:1fr 1fr;gap:2rem}
@media(max-width:880px){.col-layout{grid-template-columns:1fr}}

.panel{background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:1.6rem 1.6rem 1.4rem;box-shadow:var(--shadow)}
.panel h2{font-family:'Fraunces',serif;font-size:1.3rem;font-weight:600;color:var(--ink);margin-bottom:.4rem;letter-spacing:-0.3px}
.panel p.sub{font-size:.85rem;color:var(--muted);margin-bottom:1.2rem}

.entry-form textarea{width:100%;padding:.85rem 1rem;border:1.5px solid var(--line);border-radius:10px;font-size:.93rem;min-height:120px;resize:vertical;font-family:inherit;line-height:1.5}
.entry-form textarea:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 4px rgba(46,125,50,0.1)}
.file-input{display:block;padding:.6rem .85rem;border:1.5px dashed var(--line);border-radius:8px;font-size:.82rem;color:var(--muted);cursor:pointer;background:rgba(46,125,50,0.02);transition:.15s}
.file-input:hover{border-color:var(--green);color:var(--green-dark)}
.file-input input{display:none}

.entries-list{display:flex;flex-direction:column;gap:.7rem;max-height:520px;overflow-y:auto;padding-right:.3rem}
.entries-list::-webkit-scrollbar{width:6px}
.entries-list::-webkit-scrollbar-thumb{background:var(--line);border-radius:6px}
.entry{padding:.85rem 1rem;background:rgba(46,125,50,0.03);border:1px solid var(--line);border-radius:10px;font-size:.88rem;line-height:1.5;position:relative}
.entry .meta{font-size:.7rem;color:var(--muted);margin-bottom:.4rem;display:flex;align-items:center;gap:.5rem}
.entry .meta b{color:var(--green-dark);font-weight:700;text-transform:uppercase;letter-spacing:.8px;font-size:.62rem;background:rgba(46,125,50,0.1);padding:.12rem .42rem;border-radius:4px}
.entry .content{color:var(--ink)}
.entry .files{margin-top:.5rem;font-size:.72rem;color:var(--muted)}
.entry .files a{color:var(--green-dark);text-decoration:none;font-weight:600}
.entry-empty{padding:2rem 1rem;text-align:center;color:var(--muted);font-size:.88rem;border:1.5px dashed var(--line);border-radius:10px}

.callout{background:linear-gradient(135deg,rgba(46,125,50,0.05),rgba(46,125,50,0.02));border:1px solid rgba(46,125,50,0.2);border-radius:14px;padding:1.2rem;margin-bottom:1.4rem;display:flex;gap:.85rem;align-items:flex-start}
.callout-icon{font-size:1.4rem;line-height:1;flex-shrink:0}
.callout-body b{color:var(--green-dark);display:block;margin-bottom:.2rem;font-weight:700}
.callout-body small{font-size:.82rem;color:var(--muted);line-height:1.5}

.send-block{background:linear-gradient(135deg,var(--green-dark),var(--green));color:#fff;padding:1.4rem 1.5rem;border-radius:14px;margin-top:1rem;text-align:center}
.send-block h3{font-family:'Fraunces',serif;font-size:1.15rem;font-weight:600;margin-bottom:.4rem}
.send-block p{font-size:.85rem;opacity:.9;margin-bottom:1rem;line-height:1.5}
.btn-send{padding:.85rem 1.6rem;background:#fff;color:var(--green-dark);border:none;border-radius:30px;font-size:.85rem;font-weight:800;letter-spacing:.5px;text-transform:uppercase;cursor:pointer;transition:.2s;box-shadow:0 10px 24px rgba(0,0,0,0.18)}
.btn-send:hover{transform:translateY(-2px);box-shadow:0 16px 30px rgba(0,0,0,0.25)}
.btn-send:disabled{opacity:.6;cursor:not-allowed}

.flash{padding:.85rem 1.1rem;background:#e8f5e9;border:1px solid var(--green-light);border-radius:10px;color:var(--green-dark);font-size:.88rem;font-weight:600;margin-bottom:1rem;display:flex;align-items:center;gap:.55rem}
.flash::before{content:"✓";font-size:1.1rem;font-weight:900}
.flash.err{background:#fee;border-color:#fbb;color:#8b0000}
.flash.err::before{content:"!"}

/* ===== JORNAL (newspaper layout) ===== */
.j-page{background:var(--bg);min-height:100vh;padding-bottom:5rem}
.j-mast{background:var(--paper);border-bottom:3px double var(--ink);padding:2rem 1.5rem 1.5rem;text-align:center;position:relative}
.j-mast::before{content:"";position:absolute;top:0;left:0;right:0;height:6px;background:linear-gradient(90deg,var(--green),var(--orange),var(--green))}
.j-mast .vol{font-family:'JetBrains Mono',monospace;font-size:.7rem;letter-spacing:2.5px;color:var(--muted);text-transform:uppercase;margin-bottom:.5rem}
.j-mast h1{font-family:'Fraunces',serif;font-size:clamp(2.4rem,5vw,3.6rem);font-weight:600;letter-spacing:-1.5px;line-height:1;color:var(--ink);margin-bottom:.4rem}
.j-mast h1 em{font-style:italic;font-weight:500}
.j-mast .sub{font-size:.85rem;color:var(--muted);font-style:italic;font-family:'Fraunces',serif}
.j-mast .meta-bar{display:flex;justify-content:center;gap:1.5rem;font-size:.72rem;color:var(--muted);letter-spacing:1.5px;text-transform:uppercase;margin-top:1rem;font-weight:600;flex-wrap:wrap}
.j-mast .meta-bar span{padding:.25rem .65rem;background:rgba(46,125,50,0.06);border-radius:30px}

.j-body{max-width:780px;margin:0 auto;padding:3rem 1.5rem 0}
.j-summary{font-family:'Fraunces',serif;font-size:1.25rem;line-height:1.55;color:var(--ink);padding:1.4rem 1.6rem;background:var(--paper);border-left:4px solid var(--green-dark);border-radius:0 12px 12px 0;margin-bottom:2.5rem;box-shadow:var(--shadow);font-style:italic}
.j-summary::before{content:"\201C";font-size:3rem;color:var(--green);line-height:0.5;display:block;font-family:'Fraunces',serif}

.j-section{margin-bottom:2.5rem}
.j-section h2{font-family:'Fraunces',serif;font-size:1.7rem;font-weight:600;color:var(--ink);margin-bottom:.6rem;letter-spacing:-0.4px;padding-bottom:.5rem;border-bottom:1px solid var(--line);position:relative}
.j-section h2::after{content:"";position:absolute;bottom:-1px;left:0;width:50px;height:2px;background:var(--orange)}
.j-entry{padding:1rem 0;border-bottom:1px solid var(--line)}
.j-entry:last-child{border-bottom:0}
.j-entry .when{font-size:.7rem;color:var(--muted);letter-spacing:1px;text-transform:uppercase;margin-bottom:.4rem;font-weight:700}
.j-entry .ctext{color:var(--ink);font-size:.98rem;line-height:1.65}
.j-entry .files{margin-top:.5rem;font-size:.78rem}
.j-entry .files a{color:var(--green-dark);text-decoration:none;font-weight:600;border-bottom:1px dashed var(--green-dark)}

.j-foot{max-width:780px;margin:0 auto;padding:3rem 1.5rem 0;text-align:center;font-size:.78rem;color:var(--muted);font-style:italic;line-height:1.55;border-top:1px solid var(--line);margin-top:2rem}

/* ===== YUDA MINI CHATBOT ===== */
.yuda-fab{position:fixed;bottom:1.6rem;right:1.6rem;width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,var(--green),var(--green-dark));color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 12px 36px rgba(46,125,50,0.4);z-index:200;transition:.25s;font-size:1.5rem}
.yuda-fab:hover{transform:scale(1.06)}
.yuda-fab::after{content:"";position:absolute;top:6px;right:6px;width:11px;height:11px;background:var(--orange);border:2px solid var(--paper);border-radius:50%}
.yuda-panel{position:fixed;bottom:5.8rem;right:1.6rem;width:380px;max-width:calc(100vw - 2rem);height:560px;max-height:calc(100vh - 8rem);background:var(--paper);border:1px solid var(--line);border-radius:20px;box-shadow:0 25px 70px rgba(14,26,15,0.18);display:none;flex-direction:column;overflow:hidden;z-index:201}
.yuda-panel.on{display:flex;animation:yudain .25s ease-out}
@keyframes yudain{from{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}
.yuda-head{padding:1rem 1.1rem;background:linear-gradient(135deg,var(--green),var(--green-dark));color:#fff;display:flex;align-items:center;gap:.7rem}
.yuda-head .av{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,0.2);display:flex;align-items:center;justify-content:center;font-family:'Fraunces',serif;font-weight:600;font-size:1.05rem;position:relative}
.yuda-head .av::after{content:"";position:absolute;bottom:0;right:0;width:11px;height:11px;background:#4ade80;border:2px solid var(--green-dark);border-radius:50%}
.yuda-head h3{font-size:.95rem;font-weight:700;font-family:'Inter',sans-serif}
.yuda-head small{font-size:.7rem;opacity:.88}
.yuda-close{margin-left:auto;background:rgba(255,255,255,0.15);color:#fff;border:none;width:28px;height:28px;border-radius:50%;cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center}
.yuda-msgs{flex:1;overflow-y:auto;padding:1rem .9rem;display:flex;flex-direction:column;gap:.75rem;background:#fafaf6}
.yuda-msgs::-webkit-scrollbar{width:5px}
.yuda-msgs::-webkit-scrollbar-thumb{background:var(--line);border-radius:5px}
.yuda-bubble{padding:.65rem .85rem;border-radius:14px;font-size:.86rem;line-height:1.5;max-width:88%;word-wrap:break-word}
.yuda-bot{background:#fff;border:1px solid var(--line);align-self:flex-start;border-bottom-left-radius:4px;color:var(--ink)}
.yuda-user{background:linear-gradient(135deg,var(--green),var(--green-dark));color:#fff;align-self:flex-end;border-bottom-right-radius:4px}
.yuda-typing{padding:.55rem .8rem;background:#fff;border:1px solid var(--line);border-radius:14px;align-self:flex-start;display:none;align-items:center;gap:.35rem}
.yuda-typing.on{display:flex}
.yuda-typing .d{width:5px;height:5px;background:var(--green);border-radius:50%;animation:yt 1.2s infinite}
.yuda-typing .d:nth-child(2){animation-delay:.2s}
.yuda-typing .d:nth-child(3){animation-delay:.4s}
@keyframes yt{0%,60%,100%{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-4px)}}
.yuda-input{padding:.85rem;border-top:1px solid var(--line);background:#fff;display:flex;gap:.5rem}
.yuda-input input{flex:1;border:1.5px solid var(--line);background:#fafaf6;border-radius:22px;padding:.6rem 1rem;font-size:.86rem;outline:none;color:var(--ink)}
.yuda-input input:focus{border-color:var(--green)}
.yuda-input button{width:38px;height:38px;border-radius:50%;background:var(--green-dark);color:#fff;border:none;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center}
.yuda-input button:disabled{opacity:.5;cursor:not-allowed}

@media(max-width:640px){
  .topbar{padding:.7rem 1rem}
  .dash{padding:1.4rem 1rem 3rem}
  .panel{padding:1.2rem 1.1rem}
  .yuda-panel{width:calc(100vw - 1.2rem);right:.6rem;bottom:5.2rem;height:calc(100vh - 7rem)}
  .yuda-fab{bottom:1.1rem;right:1.1rem;width:54px;height:54px}
}

/* === v2 ADDITIONS: brand logo image, breadcrumbs, hero cover, state pills, email logs, premium chatbot === */
.brand-logo-img{width:34px;height:34px;flex-shrink:0;display:block}
.brand-text{display:flex;align-items:baseline;gap:.45rem}
.login-logo-img{width:80px;height:80px;display:block;filter:drop-shadow(0 6px 14px rgba(46,125,50,0.25))}

/* Breadcrumb */
.breadcrumb{display:flex;align-items:center;gap:.45rem;font-size:.78rem;color:var(--muted);margin-bottom:1rem;flex-wrap:wrap}
.breadcrumb a{color:var(--green-dark);text-decoration:none;font-weight:600;transition:.15s}
.breadcrumb a:hover{text-decoration:underline}
.breadcrumb span{color:var(--muted)}
.breadcrumb .state-pill{margin-left:auto;padding:.22rem .6rem;font-size:.68rem;font-weight:700;letter-spacing:.5px;border-radius:30px;border:1px solid;text-transform:uppercase}
.breadcrumb-j{max-width:780px;margin:1.2rem auto 0;padding:0 1.5rem}

/* Email logs panel */
.email-logs{display:flex;flex-direction:column;gap:.4rem;max-height:240px;overflow-y:auto}
.elog{padding:.55rem .75rem;border-radius:8px;border:1px solid var(--line);background:#fff;font-size:.78rem}
.elog.ok{border-left:3px solid #16a34a;background:#f0fdf4}
.elog.fail{border-left:3px solid #dc2626;background:#fef2f2}
.elog b{display:block;font-weight:600;color:var(--ink)}
.elog small{display:block;color:var(--muted);margin-top:.2rem;font-size:.7rem}

/* Archive cards — placeholder cover */
.arch-no-cover-art{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f5f3eb 0%,#e8e3d4 100%);position:relative;overflow:hidden}
.arch-no-cover-art::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 30%,rgba(46,125,50,0.12),transparent 50%),radial-gradient(circle at 70% 70%,rgba(230,81,0,0.1),transparent 50%)}
.arch-no-cover-art img{width:45%;max-width:120px;opacity:.55;position:relative;z-index:1;filter:drop-shadow(0 4px 10px rgba(0,0,0,0.1))}
.arch-state{position:absolute;top:.75rem;left:.75rem;padding:.3rem .65rem;border-radius:30px;font-size:.68rem;font-weight:700;letter-spacing:.5px;backdrop-filter:blur(4px);background:rgba(255,255,255,0.96);border:1px solid var(--line);display:inline-flex;align-items:center;gap:.3rem}

/* Journal hero cover banner */
.j-hero-cover{position:relative;width:100%;max-width:1200px;margin:1rem auto 0;height:280px;overflow:hidden;border-radius:0}
.j-hero-cover img{width:100%;height:100%;object-fit:cover;display:block}
.j-hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,transparent 30%,rgba(250,250,246,0.92) 100%)}

/* Journal top nav with brand */
.j-tn-brand{display:flex;align-items:center;gap:.55rem;text-decoration:none;color:var(--ink);font-family:'Fraunces',serif;font-weight:600;font-size:.95rem}
.j-tn-brand img{width:28px;height:28px}
.j-tn-brand small{font-family:'Inter',sans-serif;font-size:.6rem;letter-spacing:2px;color:var(--green-dark);background:rgba(46,125,50,0.1);padding:.15rem .45rem;border-radius:4px;margin-left:.3rem;text-transform:uppercase;font-weight:600}
.j-tn-pos{font-family:'JetBrains Mono',monospace;font-size:.72rem;color:var(--muted);font-weight:600;padding:.32rem .65rem;background:var(--paper);border:1px solid var(--line);border-radius:6px}

/* Journal pager footer */
.j-pager{max-width:780px;margin:3rem auto 1rem;padding:0 1.5rem;display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.j-pager-btn{padding:1.1rem 1.3rem;background:var(--paper);border:1px solid var(--line);border-radius:12px;text-decoration:none;color:var(--ink);transition:.2s;display:flex;flex-direction:column;gap:.3rem;box-shadow:var(--shadow)}
.j-pager-btn:hover{border-color:var(--green);transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.j-pager-btn.next{text-align:right;align-items:flex-end}
.j-pager-btn .lbl{font-size:.7rem;color:var(--muted);letter-spacing:1px;text-transform:uppercase;font-weight:700}
.j-pager-btn strong{font-family:'Fraunces',serif;font-size:1rem;color:var(--ink);font-weight:600;line-height:1.3}

/* YUDA mini — premium upgrades */
.yuda-fab{background:linear-gradient(135deg,var(--green) 0%,var(--green-dark) 100%);font-size:1.05rem;width:62px;height:62px}
.yuda-fab svg{color:#fff}
.yuda-fab::after{content:"";position:absolute;top:8px;right:8px;width:10px;height:10px;background:var(--orange);border:2px solid var(--paper);border-radius:50%;animation:fabpulse 2s infinite}
@keyframes fabpulse{0%,100%{transform:scale(1)}50%{transform:scale(1.2)}}
.yuda-head .yh-text{flex:1}
.yuda-bubble b{font-weight:700;color:var(--green-dark)}
.yuda-user b{color:#fff}
.yuda-input button svg{display:block}


/* === v2 ADDITIONS === */
.brand-logo-img{width:34px;height:34px;flex-shrink:0;display:block;object-fit:contain}
.brand-text{display:flex;align-items:baseline;gap:.45rem}
.brand-text small{font-family:'Inter',sans-serif;font-weight:600;font-size:.62rem;letter-spacing:2px;color:var(--green-dark);background:rgba(46,125,50,0.1);padding:.18rem .5rem;border-radius:4px;text-transform:uppercase}
.login-logo-img{width:90px;height:90px;display:block;filter:drop-shadow(0 6px 16px rgba(46,125,50,0.28))}

.topnav{display:flex;gap:.3rem;flex:1;justify-content:center}
.topnav a{padding:.45rem .9rem;color:var(--muted);text-decoration:none;font-size:.85rem;font-weight:600;border-radius:8px;transition:.15s}
.topnav a:hover{background:rgba(46,125,50,0.06);color:var(--ink)}
.topnav a.on{background:rgba(46,125,50,0.12);color:var(--green-dark)}

.breadcrumb{display:flex;align-items:center;gap:.5rem;font-size:.78rem;color:var(--muted);margin-bottom:1rem;flex-wrap:wrap}
.breadcrumb a{color:var(--green-dark);text-decoration:none;font-weight:600}
.breadcrumb a:hover{text-decoration:underline}
.breadcrumb .state-pill{margin-left:auto;padding:.22rem .65rem;font-size:.7rem;font-weight:700;letter-spacing:.5px;border-radius:30px;border:1px solid;text-transform:uppercase}
.breadcrumb-j{max-width:780px;margin:1.2rem auto 0;padding:0 1.5rem}

.email-logs{display:flex;flex-direction:column;gap:.4rem;max-height:240px;overflow-y:auto}
.elog{padding:.55rem .8rem;border-radius:8px;border:1px solid var(--line);background:#fff;font-size:.78rem}
.elog.ok{border-left:3px solid #16a34a;background:#f0fdf4}
.elog.fail{border-left:3px solid #dc2626;background:#fef2f2}
.elog b{display:block;color:var(--ink)}
.elog small{display:block;color:var(--muted);margin-top:.2rem;font-size:.7rem}

.archive-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.4rem}
.arch-card{background:var(--paper);border:1px solid var(--line);border-radius:14px;overflow:hidden;text-decoration:none;color:var(--ink);transition:.2s;display:flex;flex-direction:column;box-shadow:var(--shadow)}
.arch-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--green)}
.arch-cover{aspect-ratio:16/9;background-color:#f4f3eb;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden}
.arch-no-cover-art{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f5f3eb 0%,#e8e3d4 100%);position:relative;overflow:hidden}
.arch-no-cover-art::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 30%,rgba(46,125,50,0.15),transparent 50%),radial-gradient(circle at 70% 70%,rgba(230,81,0,0.12),transparent 50%)}
.arch-no-cover-art img{width:48%;max-width:130px;opacity:.7;position:relative;z-index:1;filter:drop-shadow(0 6px 14px rgba(0,0,0,0.12))}
.arch-state{position:absolute;top:.75rem;left:.75rem;padding:.3rem .7rem;border-radius:30px;font-size:.66rem;font-weight:700;letter-spacing:.5px;backdrop-filter:blur(6px);background:rgba(255,255,255,0.95);border:1px solid;display:inline-flex;align-items:center;gap:.3rem;z-index:2}
.arch-body{padding:1.2rem;flex:1;display:flex;flex-direction:column}
.arch-edition{font-family:'JetBrains Mono',monospace;font-size:.62rem;letter-spacing:1.5px;color:var(--green-dark);text-transform:uppercase;font-weight:700;margin-bottom:.5rem}
.arch-card h3{font-family:'Fraunces',serif;font-size:1.15rem;font-weight:600;color:var(--ink);line-height:1.2;margin-bottom:.6rem}
.arch-summary{font-size:.85rem;color:var(--muted);line-height:1.5;flex:1;margin-bottom:.85rem}
.arch-meta{font-size:.72rem;color:var(--muted);font-weight:600;padding-top:.7rem;border-top:1px solid var(--line)}

.cover-picker{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:.7rem}
.cover-opt{cursor:pointer;text-align:center;border:2px solid var(--line);border-radius:10px;padding:.4rem;transition:.15s;background:var(--paper);display:flex;flex-direction:column;gap:.35rem}
.cover-opt:hover{border-color:var(--green)}
.cover-opt.on{border-color:var(--green-dark);box-shadow:0 0 0 3px rgba(46,125,50,0.15)}
.cover-opt input{display:none}
.cover-thumb{width:100%;aspect-ratio:1.5;background-size:cover;background-position:center;background-color:#f4f3eb;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:1.8rem;color:var(--muted)}
.cover-opt small{font-size:.7rem;color:var(--muted);font-weight:600;line-height:1.2;word-break:break-word}

.j-hero-cover{position:relative;width:100%;max-width:1200px;margin:1rem auto 0;height:280px;overflow:hidden}
.j-hero-cover img{width:100%;height:100%;object-fit:cover;display:block}
.j-hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,transparent 30%,rgba(250,250,246,0.95) 100%)}

.j-page{background:var(--bg);min-height:100vh;padding-bottom:5rem}
.j-topnav{background:rgba(255,255,255,0.92);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50;backdrop-filter:blur(8px)}
.j-topnav-in{max-width:1100px;margin:0 auto;padding:.8rem 1.5rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}
.j-tn-brand{display:flex;align-items:center;gap:.55rem;text-decoration:none;color:var(--ink);font-family:'Fraunces',serif;font-weight:600;font-size:1rem}
.j-tn-brand img{width:30px;height:30px;object-fit:contain}
.j-tn-brand small{font-family:'Inter',sans-serif;font-size:.6rem;letter-spacing:2px;color:var(--green-dark);background:rgba(46,125,50,0.1);padding:.18rem .45rem;border-radius:4px;margin-left:.3rem;text-transform:uppercase;font-weight:600}
.j-tn-nav{display:flex;gap:.45rem;align-items:center;flex-wrap:wrap}
.j-tn-pos{font-family:'JetBrains Mono',monospace;font-size:.72rem;color:var(--muted);font-weight:600;padding:.35rem .75rem;background:var(--paper);border:1px solid var(--line);border-radius:8px}
.j-tn-link{padding:.4rem .85rem;background:transparent;color:var(--muted);text-decoration:none;font-size:.78rem;font-weight:600;border-radius:8px;border:1px solid var(--line);transition:.15s}
.j-tn-link:hover{background:rgba(46,125,50,0.08);color:var(--green-dark);border-color:var(--green)}

.j-mast{background:var(--paper);border-bottom:3px double var(--ink);padding:2.5rem 1.5rem 1.8rem;text-align:center;position:relative}
.j-mast::before{content:"";position:absolute;top:0;left:0;right:0;height:6px;background:linear-gradient(90deg,var(--green),var(--orange),var(--green))}
.j-mast .vol{font-family:'JetBrains Mono',monospace;font-size:.7rem;letter-spacing:2.5px;color:var(--muted);text-transform:uppercase;margin-bottom:.5rem}
.j-mast h1{font-family:'Fraunces',serif;font-size:clamp(2.4rem,5vw,3.6rem);font-weight:600;letter-spacing:-1.5px;line-height:1;color:var(--ink);margin-bottom:.4rem}
.j-mast h1 em{font-style:italic;font-weight:500}
.j-mast .sub{font-size:.85rem;color:var(--muted);font-style:italic;font-family:'Fraunces',serif}
.j-mast .meta-bar{display:flex;justify-content:center;gap:1.5rem;font-size:.72rem;color:var(--muted);letter-spacing:1.5px;text-transform:uppercase;margin-top:1rem;font-weight:600;flex-wrap:wrap}
.j-mast .meta-bar span{padding:.25rem .65rem;background:rgba(46,125,50,0.06);border-radius:30px}
.j-body{max-width:780px;margin:0 auto;padding:3rem 1.5rem 0}
.j-summary{font-family:'Fraunces',serif;font-size:1.25rem;line-height:1.55;color:var(--ink);padding:1.4rem 1.6rem;background:var(--paper);border-left:4px solid var(--green-dark);border-radius:0 12px 12px 0;margin-bottom:2.5rem;box-shadow:var(--shadow);font-style:italic}
.j-section{margin-bottom:2.5rem}
.j-section h2{font-family:'Fraunces',serif;font-size:1.7rem;font-weight:600;color:var(--ink);margin-bottom:1.2rem;letter-spacing:-0.4px;padding-bottom:.5rem;border-bottom:1px solid var(--line);position:relative}
.j-section h2::after{content:"";position:absolute;bottom:-1px;left:0;width:50px;height:2px;background:var(--orange)}
.j-foot{max-width:780px;margin:3rem auto 0;padding:2rem 1.5rem 0;text-align:center;font-size:.78rem;color:var(--muted);font-style:italic;line-height:1.7;border-top:1px solid var(--line)}

.j-article{background:var(--paper);border:1px solid var(--line);border-radius:14px;overflow:hidden;margin-bottom:1.4rem;box-shadow:var(--shadow);transition:.25s}
.j-article:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}
.j-article-cover{width:100%;aspect-ratio:16/9;overflow:hidden;background:#f4f3eb}
.j-article-cover img{width:100%;height:100%;object-fit:cover;display:block}
.j-article-body{padding:1.5rem 1.6rem 1.3rem}
.j-article .when{font-size:.7rem;color:var(--muted);letter-spacing:1px;text-transform:uppercase;margin-bottom:.7rem;font-weight:700}
.j-article .ctext{color:var(--ink);font-size:1.02rem;line-height:1.7;font-family:'Fraunces',serif}
.j-article .files{margin-top:.95rem;padding-top:.85rem;border-top:1px solid var(--line);font-size:.78rem;display:flex;flex-wrap:wrap;gap:.7rem}
.j-article .files a{color:var(--green-dark);text-decoration:none;font-weight:600;border-bottom:1px dashed var(--green-dark);padding-bottom:.1rem}

.j-pager{max-width:780px;margin:3rem auto 1rem;padding:0 1.5rem;display:grid;grid-template-columns:1fr 1fr;gap:1rem}
@media(max-width:640px){.j-pager{grid-template-columns:1fr}}
.j-pager-btn{padding:1.1rem 1.3rem;background:var(--paper);border:1px solid var(--line);border-radius:12px;text-decoration:none;color:var(--ink);transition:.2s;display:flex;flex-direction:column;gap:.3rem;box-shadow:var(--shadow)}
.j-pager-btn:hover{border-color:var(--green);transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.j-pager-btn.next{text-align:right;align-items:flex-end}
.j-pager-btn .lbl{font-size:.7rem;color:var(--muted);letter-spacing:1px;text-transform:uppercase;font-weight:700}
.j-pager-btn strong{font-family:'Fraunces',serif;font-size:1rem;color:var(--ink);font-weight:600;line-height:1.3}

/* YUDA MINI premium with avatar */
.yuda-fab{position:fixed;bottom:1.6rem;right:1.6rem;width:62px;height:62px;border-radius:50%;background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 14px 36px rgba(46,125,50,0.32);z-index:200;transition:.25s;padding:0;overflow:hidden;border:2px solid var(--green-dark)}
.yuda-fab:hover{transform:scale(1.07);box-shadow:0 18px 44px rgba(46,125,50,0.45)}
.yuda-fab img{width:100%;height:100%;object-fit:cover;border-radius:50%}
.yuda-fab::after{content:"";position:absolute;top:4px;right:4px;width:12px;height:12px;background:var(--orange);border:2px solid #fff;border-radius:50%;animation:fabpulse 2s infinite}
@keyframes fabpulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.25);opacity:.7}}
.yuda-panel{position:fixed;bottom:5.8rem;right:1.6rem;width:400px;max-width:calc(100vw - 2rem);height:600px;max-height:calc(100vh - 8rem);background:var(--paper);border:1px solid var(--line);border-radius:20px;box-shadow:0 30px 80px rgba(14,26,15,0.22);display:none;flex-direction:column;overflow:hidden;z-index:201}
.yuda-panel.on{display:flex;animation:yudain .3s ease-out}
@keyframes yudain{from{opacity:0;transform:translateY(20px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}
.yuda-head{padding:1rem 1.1rem;background:linear-gradient(135deg,var(--green) 0%,var(--green-dark) 100%);color:#fff;display:flex;align-items:center;gap:.8rem}
.yuda-head .av{width:42px;height:42px;border-radius:50%;background:#fff;overflow:hidden;display:flex;align-items:center;justify-content:center;flex-shrink:0;border:2px solid rgba(255,255,255,0.5);position:relative}
.yuda-head .av img{width:100%;height:100%;object-fit:cover}
.yuda-head .av::after{content:"";position:absolute;bottom:0;right:0;width:12px;height:12px;background:#4ade80;border:2px solid var(--green-dark);border-radius:50%}
.yuda-head .yh-text{flex:1}
.yuda-head h3{font-size:1rem;font-weight:700;font-family:'Inter',sans-serif}
.yuda-head small{font-size:.72rem;opacity:.88}
.yuda-close{margin-left:auto;background:rgba(255,255,255,0.18);color:#fff;border:none;width:30px;height:30px;border-radius:50%;cursor:pointer;font-size:1.1rem;display:flex;align-items:center;justify-content:center;font-weight:700;transition:.15s}
.yuda-close:hover{background:rgba(255,255,255,0.3)}
.yuda-msgs{flex:1;overflow-y:auto;padding:1.1rem 1rem;display:flex;flex-direction:column;gap:.8rem;background:#fafaf6}
.yuda-msgs::-webkit-scrollbar{width:5px}
.yuda-msgs::-webkit-scrollbar-thumb{background:var(--line);border-radius:5px}
.yuda-bubble{padding:.75rem 1rem;border-radius:16px;font-size:.88rem;line-height:1.55;max-width:90%;word-wrap:break-word}
.yuda-bot{background:#fff;border:1px solid var(--line);align-self:flex-start;border-bottom-left-radius:4px;color:var(--ink);box-shadow:0 1px 3px rgba(0,0,0,0.04)}
.yuda-bot b{font-weight:700;color:var(--green-dark)}
.yuda-user{background:linear-gradient(135deg,var(--green),var(--green-dark));color:#fff;align-self:flex-end;border-bottom-right-radius:4px}
.yuda-typing{padding:.55rem .8rem;background:#fff;border:1px solid var(--line);border-radius:14px;align-self:flex-start;display:none;align-items:center;gap:.35rem;margin:0 1rem .5rem}
.yuda-typing.on{display:flex}
.yuda-typing .d{width:6px;height:6px;background:var(--green);border-radius:50%;animation:yt 1.2s infinite}
.yuda-typing .d:nth-child(2){animation-delay:.2s}
.yuda-typing .d:nth-child(3){animation-delay:.4s}
@keyframes yt{0%,60%,100%{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-4px)}}
.yuda-input{padding:.85rem;border-top:1px solid var(--line);background:#fff;display:flex;gap:.5rem}
.yuda-input input{flex:1;border:1.5px solid var(--line);background:#fafaf6;border-radius:22px;padding:.6rem 1rem;font-size:.88rem;outline:none;color:var(--ink)}
.yuda-input input:focus{border-color:var(--green);background:#fff}
.yuda-input button{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--green),var(--green-dark));color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.15s}
.yuda-input button:hover{transform:scale(1.06)}

@media(max-width:640px){
  .topbar{padding:.7rem 1rem;flex-wrap:wrap}
  .topnav{order:3;width:100%;justify-content:flex-start;overflow-x:auto}
  .yuda-panel{width:calc(100vw - 1.2rem);right:.6rem;bottom:5.2rem;height:calc(100vh - 7rem)}
  .yuda-fab{bottom:1.1rem;right:1.1rem;width:56px;height:56px}
  .archive-grid{grid-template-columns:1fr}
}

/* Share block in journal */
.share-block{max-width:780px;margin:2rem auto 0;padding:1.4rem 1.6rem;background:linear-gradient(135deg,rgba(46,125,50,0.06),rgba(46,125,50,0.02));border:1.5px solid rgba(46,125,50,0.25);border-radius:14px;text-align:center}
.share-block h3{font-family:'Fraunces',serif;font-size:1.1rem;color:var(--green-dark);margin-bottom:.4rem;font-weight:600}
.share-block p{font-size:.85rem;color:var(--muted);margin-bottom:1rem}
.share-row{display:flex;gap:.5rem;max-width:540px;margin:0 auto}
.share-row input{flex:1;padding:.7rem 1rem;border:1.5px solid var(--line);background:#fff;border-radius:10px;font-family:'JetBrains Mono',monospace;font-size:.78rem;color:var(--ink);outline:none}
.share-row input:focus{border-color:var(--green)}
.share-row button{padding:.7rem 1.2rem;background:var(--green-dark);color:#fff;border:none;border-radius:10px;font-weight:700;font-size:.82rem;cursor:pointer;transition:.15s;font-family:'Inter',sans-serif;letter-spacing:.3px;white-space:nowrap}
.share-row button:hover{background:var(--green);transform:translateY(-1px)}


/* Archive search toolbar */
.arch-toolbar{display:flex;gap:.7rem;align-items:center;margin-bottom:1rem;flex-wrap:wrap;background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:.75rem .85rem;box-shadow:var(--shadow)}
.arch-search{flex:1;min-width:220px;display:flex;align-items:center;gap:.6rem;padding:.55rem .9rem;background:#fafaf6;border:1.5px solid var(--line);border-radius:10px;transition:.15s}
.arch-search:focus-within{border-color:var(--green);background:#fff}
.arch-search svg{color:var(--muted);flex-shrink:0}
.arch-search input{flex:1;border:none;outline:none;background:transparent;font-size:.92rem;color:var(--ink);font-family:'Inter',sans-serif}
.arch-filter{padding:.55rem .85rem;border:1.5px solid var(--line);background:#fafaf6;border-radius:10px;font-size:.85rem;color:var(--ink);font-family:'Inter',sans-serif;font-weight:500;cursor:pointer;outline:none;transition:.15s}
.arch-filter:focus,.arch-filter:hover{border-color:var(--green);background:#fff}
.arch-count{font-size:.78rem;color:var(--muted);margin-bottom:1rem;font-weight:600;letter-spacing:.3px}
@media(max-width:640px){.arch-toolbar{flex-direction:column;align-items:stretch}.arch-search,.arch-filter{width:100%}}


/* Position pill clickable */
a.j-tn-pos{text-decoration:none;transition:.15s;cursor:pointer}
a.j-tn-pos:hover{background:rgba(46,125,50,0.1);color:var(--green-dark);border-color:var(--green)}


/* Archive list view (table-like) */
.arch-list{display:flex;flex-direction:column;gap:.45rem;background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:.6rem;box-shadow:var(--shadow)}
.arch-row{display:grid;grid-template-columns:60px 1fr 140px 90px 90px;gap:1rem;align-items:center;padding:.85rem 1rem;background:#fafaf6;border:1px solid transparent;border-radius:10px;text-decoration:none;color:var(--ink);transition:.15s}
.arch-row:hover{background:#fff;border-color:var(--green);box-shadow:0 4px 14px rgba(46,125,50,0.08);transform:translateX(2px)}
.arch-num{font-family:'JetBrains Mono',monospace;font-size:.78rem;font-weight:700;color:var(--green-dark);letter-spacing:.5px;text-align:center;background:rgba(46,125,50,0.08);padding:.35rem .45rem;border-radius:6px;border:1px solid rgba(46,125,50,0.18)}
.arch-info{min-width:0}
.arch-title{font-family:'Fraunces',serif;font-size:1.05rem;font-weight:600;color:var(--ink);line-height:1.25;margin:0 0 .25rem;letter-spacing:-0.2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.arch-snippet{font-size:.78rem;color:var(--muted);line-height:1.45;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.arch-date-col{font-size:.78rem;color:var(--muted);font-weight:600;letter-spacing:.3px;text-align:right;font-family:'Inter',sans-serif}
.arch-stats{display:flex;flex-direction:column;gap:.18rem;font-size:.7rem;color:var(--muted);font-weight:600;text-align:right;font-family:'Inter',sans-serif}
.arch-stats span{padding:.12rem .42rem;background:rgba(0,0,0,0.04);border-radius:30px;display:inline-block}
.arch-open{display:flex;align-items:center;gap:.35rem;color:var(--green-dark);font-weight:700;font-size:.78rem;letter-spacing:.3px;padding:.4rem .65rem;background:transparent;border:1px solid transparent;border-radius:8px;transition:.15s;justify-content:center}
.arch-row:hover .arch-open{background:var(--green-dark);color:#fff;border-color:var(--green-dark)}

@media(max-width:760px){
  .arch-row{grid-template-columns:50px 1fr;grid-template-areas:"num info" "num date" "num stats" "num open";gap:.4rem .8rem;padding:.75rem .85rem}
  .arch-num{grid-area:num;align-self:start}
  .arch-info{grid-area:info}
  .arch-date-col{grid-area:date;text-align:left;font-size:.74rem}
  .arch-stats{grid-area:stats;flex-direction:row;justify-content:flex-start;font-size:.68rem}
  .arch-open{grid-area:open;justify-content:flex-start;padding:.3rem 0;width:fit-content}
  .arch-title{white-space:normal}
  .arch-snippet{white-space:normal;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
}

/* Link Lista de Jornais — destaque */
.j-tn-list{background:rgba(46,125,50,0.08)!important;color:var(--green-dark)!important;border-color:var(--green)!important;font-weight:700!important}
.j-tn-list:hover{background:var(--green-dark)!important;color:#fff!important;border-color:var(--green-dark)!important}


/* Edições dropdown inline (no journal) */
.j-dropdown{position:relative;display:inline-block}
.j-dd-panel{position:absolute;top:calc(100% + .5rem);left:50%;transform:translateX(-50%) translateY(-8px);background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:0 18px 50px rgba(14,26,15,0.18);min-width:380px;max-width:90vw;max-height:540px;display:none;flex-direction:column;overflow:hidden;z-index:300;opacity:0;transition:.2s}
.j-dd-panel.on{display:flex;opacity:1;transform:translateX(-50%) translateY(0);animation:ddIn .2s ease-out}
@keyframes ddIn{from{opacity:0;transform:translateX(-50%) translateY(-8px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}
.j-dd-head{padding:.7rem;border-bottom:1px solid var(--line);background:var(--paper)}
.j-dd-head input{width:100%;padding:.55rem .9rem;border:1.5px solid var(--line);background:#fafaf6;border-radius:8px;font-size:.85rem;color:var(--ink);outline:none;font-family:'Inter',sans-serif}
.j-dd-head input:focus{border-color:var(--green);background:#fff}
.j-dd-list{overflow-y:auto;max-height:380px;padding:.35rem}
.j-dd-list::-webkit-scrollbar{width:5px}
.j-dd-list::-webkit-scrollbar-thumb{background:var(--line);border-radius:5px}
.j-dd-item{display:flex;gap:.7rem;align-items:center;padding:.65rem .8rem;border-radius:8px;text-decoration:none;color:var(--ink);transition:.12s}
.j-dd-item:hover{background:rgba(46,125,50,0.06)}
.j-dd-item.current{background:rgba(46,125,50,0.1);border-left:3px solid var(--green-dark);padding-left:calc(.8rem - 3px)}
.j-dd-num{font-family:'JetBrains Mono',monospace;font-size:.72rem;font-weight:700;color:var(--green-dark);background:rgba(46,125,50,0.1);padding:.3rem .45rem;border-radius:5px;letter-spacing:.4px;flex-shrink:0;min-width:46px;text-align:center}
.j-dd-info{flex:1;min-width:0}
.j-dd-info b{display:block;font-family:'Fraunces',serif;font-size:.92rem;font-weight:600;color:var(--ink);line-height:1.25;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:.15rem}
.j-dd-info small{font-size:.7rem;color:var(--muted);font-weight:500}
.j-dd-cur{font-size:.6rem;letter-spacing:1.2px;text-transform:uppercase;color:var(--green-dark);font-weight:700;padding:.18rem .45rem;background:#fff;border:1px solid rgba(46,125,50,0.3);border-radius:30px;flex-shrink:0}
.j-dd-foot{display:block;padding:.7rem 1rem;text-align:center;background:var(--paper);border-top:1px solid var(--line);color:var(--green-dark);font-size:.78rem;font-weight:700;text-decoration:none;letter-spacing:.3px}
.j-dd-foot:hover{background:var(--green-dark);color:#fff}

/* Archive number badge on cards */
.arch-num-badge{position:absolute;top:.75rem;right:.75rem;font-family:'JetBrains Mono',monospace;font-size:.66rem;font-weight:800;background:rgba(255,255,255,0.96);color:var(--green-dark);padding:.32rem .6rem;border-radius:6px;border:1px solid rgba(46,125,50,0.25);letter-spacing:.5px}


/* Archive actions overlay (admin) */
.arch-card-wrap{position:relative}
.arch-actions{position:absolute;top:.75rem;right:.75rem;display:flex;gap:.35rem;opacity:0;transition:.18s;z-index:5}
.arch-card-wrap:hover .arch-actions{opacity:1}
.arch-act-btn{padding:.4rem .7rem;background:rgba(255,255,255,0.96);color:var(--ink);border:1px solid var(--line);border-radius:8px;font-size:.7rem;font-weight:700;text-decoration:none;transition:.15s;font-family:'Inter',sans-serif;backdrop-filter:blur(4px);box-shadow:0 4px 12px rgba(0,0,0,0.1)}
.arch-act-btn:hover{background:var(--green-dark);color:#fff;border-color:var(--green-dark);transform:translateY(-2px)}
@media(max-width:640px){.arch-actions{opacity:1}}

/* On the archive card put state badge on the LEFT to avoid clash with actions on right */
.arch-state{left:.75rem;right:auto}
.arch-num-badge{top:auto;bottom:.75rem;right:.75rem}

/* Edit button in journal topnav (admin only) */
.j-tn-edit{background:#fef7e6!important;color:#a16207!important;border-color:#facc15!important;font-weight:700!important}
.j-tn-edit:hover{background:#facc15!important;color:#0E1A0F!important}


/* === V3 DASHBOARD/ARCHIVE CLEAN UI === */

/* Dashboard header row with big add button */
.dash-head-row{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}
.btn-bigadd{padding:.9rem 1.6rem;background:linear-gradient(135deg,var(--green-dark),var(--green));color:#fff;border:none;border-radius:14px;font-size:.95rem;font-weight:800;letter-spacing:.3px;cursor:pointer;box-shadow:0 12px 30px rgba(46,125,50,0.3);transition:.2s;font-family:'Inter',sans-serif;display:inline-flex;align-items:center;gap:.5rem}
.btn-bigadd:hover{transform:translateY(-2px);box-shadow:0 18px 40px rgba(46,125,50,0.4)}

/* Drafts list */
.draft-list{display:flex;flex-direction:column;gap:.5rem}
.draft-row{display:flex;justify-content:space-between;align-items:center;padding:.85rem 1rem;background:#fff;border:1.5px solid #facc15;border-radius:10px;gap:1rem;flex-wrap:wrap}
.draft-info h4{font-family:'Fraunces',serif;font-size:1rem;font-weight:600;color:var(--ink);margin:0 0 .25rem;line-height:1.2}
.draft-info small{font-size:.74rem;color:var(--muted)}
.draft-acts{display:flex;gap:.4rem}

/* Mini journals (dashboard side) */
.mini-journals{display:flex;flex-direction:column;gap:.6rem}
.mini-j{padding:.85rem 1rem;background:#fff;border:1px solid var(--line);border-radius:10px;transition:.15s}
.mini-j:hover{border-color:var(--green);box-shadow:0 4px 14px rgba(46,125,50,0.08)}
.mini-j-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:.4rem;flex-wrap:wrap;gap:.4rem}
.mini-j-state{padding:.22rem .55rem;border-radius:30px;font-size:.65rem;font-weight:700;letter-spacing:.5px;border:1px solid currentColor;text-transform:uppercase}
.mini-j-head small{font-size:.72rem;color:var(--muted);font-weight:600}
.mini-j h4{font-family:'Fraunces',serif;font-size:.95rem;font-weight:600;color:var(--ink);margin:0 0 .55rem;line-height:1.3}
.mini-j-acts{display:flex;gap:.35rem}
.mini-j-acts .btn-ghost{font-size:.7rem;padding:.28rem .6rem}

/* Collapsible logs */
.logs-collapsible{margin-top:2rem;background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:.4rem 1rem}
.logs-collapsible summary{cursor:pointer;font-weight:700;color:var(--muted);padding:.7rem 0;font-size:.85rem;font-family:'Inter',sans-serif;letter-spacing:.3px;list-style:none;outline:none;user-select:none}
.logs-collapsible summary::-webkit-details-marker{display:none}
.logs-collapsible[open] summary{border-bottom:1px solid var(--line);margin-bottom:.8rem}

/* === JOURNAL CARDS (NEW CLEAN GRID) === */
.archive-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:1.3rem}
.jcard{background:var(--paper);border:1px solid var(--line);border-radius:14px;overflow:hidden;display:flex;flex-direction:column;transition:.18s;box-shadow:var(--shadow);position:relative}
.jcard:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--green)}
.jcard-cover{display:block;aspect-ratio:16/9;background:#f4f3eb;position:relative;text-decoration:none;color:inherit;overflow:hidden}
.jcard-no-cover{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f5f3eb 0%,#e8e3d4 100%);position:relative;overflow:hidden}
.jcard-no-cover::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 30%,rgba(46,125,50,0.15),transparent 50%),radial-gradient(circle at 70% 70%,rgba(230,81,0,0.12),transparent 50%)}
.jcard-no-cover img{width:48%;max-width:120px;opacity:.7;position:relative;z-index:1;filter:drop-shadow(0 6px 14px rgba(0,0,0,0.12))}
.jcard-state{position:absolute;top:.75rem;left:.75rem;padding:.3rem .65rem;border-radius:30px;font-size:.64rem;font-weight:700;letter-spacing:.5px;backdrop-filter:blur(6px);background:rgba(255,255,255,0.95);border:1px solid;text-transform:uppercase;z-index:2}
.jcard-num{position:absolute;top:.75rem;right:.75rem;font-family:'JetBrains Mono',monospace;font-size:.65rem;font-weight:800;background:rgba(255,255,255,0.96);color:var(--green-dark);padding:.32rem .6rem;border-radius:6px;border:1px solid rgba(46,125,50,0.25);letter-spacing:.5px;z-index:2}
.jcard-body{padding:1.1rem 1.2rem .8rem;flex:1;display:flex;flex-direction:column}
.jcard-edition{font-family:'JetBrains Mono',monospace;font-size:.65rem;letter-spacing:1.2px;color:var(--green-dark);text-transform:uppercase;font-weight:700;margin-bottom:.5rem}
.jcard-body h3{font-family:'Fraunces',serif;font-size:1.1rem;font-weight:600;line-height:1.25;letter-spacing:-0.3px;margin:0 0 .55rem}
.jcard-body h3 a{color:var(--ink);text-decoration:none}
.jcard-body h3 a:hover{color:var(--green-dark)}
.jcard-summary{font-size:.82rem;color:var(--muted);line-height:1.5;margin:0;flex:1}
.jcard-actions{display:flex;gap:.35rem;padding:.7rem 1rem 1rem;border-top:1px solid var(--line);background:#fafaf6}
.jcard-btn{flex:1;padding:.45rem .6rem;background:#fff;border:1px solid var(--line);border-radius:8px;font-size:.74rem;font-weight:700;color:var(--ink);cursor:pointer;text-decoration:none;text-align:center;transition:.15s;font-family:'Inter',sans-serif}
.jcard-btn:hover{border-color:var(--green-dark);color:var(--green-dark);background:#fff}
.jcard-btn-send{background:linear-gradient(135deg,var(--green-dark),var(--green));color:#fff;border-color:var(--green-dark)}
.jcard-btn-send:hover{transform:translateY(-1px);box-shadow:0 6px 18px rgba(46,125,50,0.3);color:#fff!important}

/* === MODAL (Send Dialog + Add Modal) === */
.sd-overlay{position:fixed;inset:0;background:rgba(14,26,15,0.55);backdrop-filter:blur(4px);display:none;align-items:center;justify-content:center;z-index:500;padding:1rem}
.sd-overlay.on{display:flex;animation:sdIn .2s ease-out}
@keyframes sdIn{from{opacity:0}to{opacity:1}}
.sd-modal{background:var(--paper);border-radius:18px;max-width:540px;width:100%;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 30px 80px rgba(14,26,15,0.4);animation:sdSlide .25s ease-out}
@keyframes sdSlide{from{transform:translateY(20px) scale(.96);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}
.sd-head{padding:1.2rem 1.4rem;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--line);background:#fff}
.sd-head h3{font-family:'Fraunces',serif;font-size:1.25rem;font-weight:600;color:var(--ink);margin:0}
.sd-x{width:34px;height:34px;background:transparent;border:none;font-size:1.5rem;color:var(--muted);cursor:pointer;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:.15s;line-height:1;font-weight:300}
.sd-x:hover{background:rgba(0,0,0,0.06);color:var(--ink)}
.sd-body{padding:1.4rem;overflow-y:auto;flex:1}
.sd-body label{display:block;font-size:.78rem;font-weight:700;color:var(--ink);margin-bottom:.4rem;letter-spacing:.3px;font-family:'Inter',sans-serif;text-transform:uppercase;letter-spacing:1px}
.sd-body textarea{width:100%;padding:.8rem 1rem;border:1.5px solid var(--line);background:#fafaf6;border-radius:10px;font-size:.92rem;color:var(--ink);font-family:'Inter',sans-serif;outline:none;resize:vertical;line-height:1.55}
.sd-body textarea:focus{border-color:var(--green);background:#fff}
.sd-body .file-input{display:block;padding:.75rem 1rem;border:1.5px dashed var(--line);background:#fafaf6;border-radius:10px;cursor:pointer;font-size:.85rem;color:var(--muted);transition:.15s;text-align:center}
.sd-body .file-input:hover{border-color:var(--green);background:#fff;color:var(--green-dark)}
.sd-body .file-input input{display:none}
.sd-help{font-size:.74rem;color:var(--muted);margin-top:.5rem;line-height:1.5}
.sd-sub{font-size:.92rem;color:var(--muted);margin:0 0 1rem}
.sd-sub b{color:var(--ink)}
.sd-foot{padding:1rem 1.4rem;display:flex;gap:.5rem;justify-content:flex-end;border-top:1px solid var(--line);background:#fafaf6}
@media(max-width:520px){.sd-foot{flex-direction:column-reverse}.sd-foot .pv-btn{width:100%;justify-content:center}}
