/* Korppi Mail — estilos */

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
:root {
    --bg:#050505; --surface:#0a0a0a; --surface-2:#0f0f0f; --surface-3:#141414; --surface-4:#1a1a1a;
    --border:#1a1a1a; --border-2:#222; --border-3:#2a2a2a;
    --text:#e8e8e8; --text-2:#a0a0a0; --text-3:#666; --text-4:#444; --text-ghost:#2a2a2a;
    --white:#fff; --black:#000;
    --red:#ff4444; --red-dim:rgba(255,68,68,.08);
    --green:#44ff88; --green-dim:rgba(68,255,136,.08);
    --amber:#ffaa00;
    --accent-dim:rgba(255,255,255,.04);
    --serif:'Instrument Serif',Georgia,serif;
    --sans:'Archivo',system-ui,sans-serif;
    --mono:'IBM Plex Mono','SF Mono',monospace;
    --ease:cubic-bezier(.22,1,.36,1);
}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:var(--sans);min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased}
::selection{background:rgba(255,255,255,.15)}
::-webkit-scrollbar{width:4px} ::-webkit-scrollbar-track{background:transparent} ::-webkit-scrollbar-thumb{background:var(--border-2);border-radius:4px}

@keyframes up{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes pulse{0%,100%{opacity:.3}50%{opacity:.8}}
@keyframes lockSpin{0%{transform:rotate(0) scale(1)}25%{transform:rotate(90deg) scale(1.1)}50%{transform:rotate(180deg) scale(1)}75%{transform:rotate(270deg) scale(1.1)}100%{transform:rotate(360deg) scale(1)}}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
@keyframes checkPop{0%{transform:scale(0) rotate(-45deg);opacity:0}50%{transform:scale(1.2) rotate(0deg);opacity:1}100%{transform:scale(1) rotate(0deg);opacity:1}}
@keyframes barGrow{from{width:0}to{width:100%}}
@keyframes dotPulse{0%,80%,100%{opacity:.2}40%{opacity:1}}

.bg-grid{position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.03;background-image:linear-gradient(rgba(255,255,255,.1) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.1) 1px,transparent 1px);background-size:60px 60px}
.bg-fade{position:fixed;inset:0;z-index:0;pointer-events:none;background:radial-gradient(ellipse 70% 50% at 50% 0%,rgba(255,255,255,.02) 0%,transparent 70%)}

/* Landing */
.landing{min-height:100vh;display:flex;flex-direction:column;position:relative;z-index:1}
.landing.hidden{display:none}

.nav{display:flex;justify-content:space-between;align-items:center;padding:28px 48px;animation:up .6s var(--ease)}
.logo{display:flex;align-items:center;gap:10px;text-decoration:none;color:inherit;cursor:pointer}
.logo-mark{width:32px;height:32px;border:1.5px solid var(--border-3);border-radius:8px;display:flex;align-items:center;justify-content:center;transition:border-color .3s}
.logo:hover .logo-mark{border-color:var(--text-3)}
.logo-mark svg{opacity:.7}
.logo-name{font-family:var(--sans);font-size:15px;font-weight:600;letter-spacing:-.3px}

.nav-actions{display:flex;gap:6px;align-items:center}
.lang-btn{background:none;border:1px solid var(--border-2);color:var(--text-3);padding:5px 10px;border-radius:6px;font-family:var(--mono);font-size:10px;font-weight:600;cursor:pointer;transition:all .2s;letter-spacing:.5px}
.lang-btn:hover{border-color:var(--border-3);color:var(--text)}

.hero{flex:1;display:flex;align-items:center;justify-content:center;padding:0 48px 40px}
.hero-inner{display:grid;grid-template-columns:1fr 1fr;gap:80px;max-width:1100px;width:100%;align-items:center}
.hero-left{animation:up .7s var(--ease) .1s both}
.hero-label{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:10px;font-weight:500;letter-spacing:2px;text-transform:uppercase;color:var(--text-3);margin-bottom:32px}
.hero-label-dot{width:5px;height:5px;border-radius:50%;background:var(--text-3);animation:pulse 2.5s ease-in-out infinite}

.hero h1{font-family:var(--serif);font-size:clamp(48px,6vw,76px);font-weight:400;line-height:1.05;letter-spacing:-1.5px;margin-bottom:24px}
.hero h1 em{font-style:italic;color:var(--text-3)}
.hero-desc{font-size:15px;color:var(--text-3);line-height:1.75;max-width:380px;margin-bottom:40px}

.hero-cta{display:inline-flex;align-items:center;gap:10px;background:var(--white);color:var(--black);border:none;border-radius:8px;padding:14px 28px;font-family:var(--sans);font-size:13px;font-weight:600;cursor:pointer;transition:all .25s var(--ease);letter-spacing:-.2px}
.hero-cta:hover{transform:translateY(-1px);box-shadow:0 8px 30px rgba(255,255,255,.08)}
.hero-cta:active{transform:translateY(0)}
.hero-cta svg{transition:transform .25s}
.hero-cta:hover svg{transform:translateX(3px)}

.hero-right{animation:up .7s var(--ease) .25s both}
.action-stack{display:flex;flex-direction:column;gap:8px}
.action-card{background:var(--surface-2);border:1px solid var(--border);border-radius:12px;padding:20px 22px;cursor:pointer;transition:all .25s var(--ease);display:flex;align-items:center;gap:16px;position:relative;overflow:hidden}
.action-card::after{content:'';position:absolute;right:20px;top:50%;transform:translateY(-50%);width:20px;height:20px;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23444' stroke-width='2'%3E%3Cpolyline points='9 18 15 12 9 6'/%3E%3C/svg%3E") no-repeat center;opacity:0;transition:all .25s}
.action-card:hover{border-color:var(--border-3);background:var(--surface-3)}
.action-card:hover::after{opacity:1;transform:translateY(-50%) translateX(3px)}
.action-icon{width:40px;height:40px;border-radius:10px;border:1px solid var(--border-2);display:flex;align-items:center;justify-content:center;color:var(--text-3);flex-shrink:0;background:var(--surface)}
.action-text{flex:1}
.action-title{font-size:13px;font-weight:600;margin-bottom:2px}
.action-sub{font-size:11px;color:var(--text-4)}

.sessions-section{animation:up .7s var(--ease) .4s both;margin-top:16px}
.sessions-label{font-family:var(--mono);font-size:10px;font-weight:500;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-4);margin-bottom:10px;padding-left:2px}
.session-item{display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:12px 16px;cursor:pointer;transition:all .2s;margin-bottom:6px}
.session-item:hover{border-color:var(--border-3);background:var(--surface-2)}
.session-dot{width:6px;height:6px;border-radius:50%;background:var(--green);flex-shrink:0}
.session-email{font-family:var(--mono);font-size:12px;flex:1;color:var(--text-2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.session-delete{background:none;border:none;color:var(--text-4);cursor:pointer;padding:2px;border-radius:4px;transition:color .2s;display:flex}
.session-delete:hover{color:var(--red)}

.hero-stats{display:flex;gap:32px;margin-top:48px;animation:up .7s var(--ease) .5s both}
.stat-num{font-family:var(--mono);font-size:13px;font-weight:600;color:var(--text)}
.stat-label{font-size:11px;color:var(--text-4);margin-top:2px}

/* Footer */
.footer{border-top:1px solid var(--border);padding:40px 48px 32px;position:relative;z-index:1}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px;max-width:1100px;margin:0 auto 32px}
.footer-brand p{font-size:12px;color:var(--text-4);line-height:1.7;margin-top:12px;max-width:260px}
.footer-col h4{font-family:var(--mono);font-size:10px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-3);margin-bottom:14px}
.footer-col a{display:block;font-size:12px;color:var(--text-4);text-decoration:none;margin-bottom:8px;transition:color .2s;cursor:pointer}
.footer-col a:hover{color:var(--text-2)}
.footer-bottom{text-align:center;padding-top:24px;border-top:1px solid var(--border);font-family:var(--mono);font-size:10px;color:var(--text-ghost);letter-spacing:.5px}

/* Modais */
.overlay{display:none;position:fixed;inset:0;z-index:1000;background:rgba(0,0,0,.85);backdrop-filter:blur(4px);align-items:center;justify-content:center}
.overlay.open{display:flex}
.modal{background:var(--surface-2);border:1px solid var(--border-2);border-radius:14px;width:92%;max-width:440px;padding:32px;animation:up .3s var(--ease);position:relative;max-height:90vh;overflow-y:auto}
.modal-x{position:absolute;top:16px;right:16px;background:none;border:none;color:var(--text-4);cursor:pointer;padding:4px;border-radius:4px}
.modal-x:hover{color:var(--text)}
.modal h2{font-family:var(--serif);font-size:28px;font-weight:400;margin-bottom:4px}
.modal .mdesc{font-size:13px;color:var(--text-3);margin-bottom:24px;line-height:1.5}

.field{margin-bottom:16px}
.field label{display:block;font-family:var(--mono);font-size:10px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--text-4);margin-bottom:6px}
.input-wrap{display:flex;align-items:center;background:var(--bg);border:1px solid var(--border-2);border-radius:8px;overflow:hidden;transition:border-color .2s}
.input-wrap:focus-within{border-color:var(--text-3)}
.input-wrap input{flex:1;background:none;border:none;outline:none;color:var(--text);font-family:var(--mono);font-size:13px;padding:12px 14px}
.input-wrap input::placeholder{color:var(--text-ghost)}
.input-suffix{font-family:var(--mono);font-size:12px;color:var(--text-4);padding-right:14px;white-space:nowrap;user-select:none}
.select{width:100%;background:var(--bg);border:1px solid var(--border-2);border-radius:8px;color:var(--text);font-family:var(--sans);font-size:13px;padding:12px 14px;outline:none;cursor:pointer;appearance:none;transition:border-color .2s;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23444' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}
.select:focus{border-color:var(--text-3)}
.select option{background:var(--surface-2)}
.field-error{font-size:11px;color:var(--red);margin-top:5px;display:none}
.field-error.show{display:block}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;border-radius:8px;padding:12px 20px;font-family:var(--sans);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s var(--ease)}
.btn-w{background:var(--white);color:var(--black);width:100%}
.btn-w:hover{opacity:.9}
.btn-w:disabled{opacity:.3;cursor:not-allowed}
.btn-g{background:var(--accent-dim);border:1px solid var(--border-2);color:var(--text-2)}
.btn-g:hover{background:rgba(255,255,255,.06);border-color:var(--border-3)}
.btn-r{background:var(--red-dim);border:1px solid rgba(255,68,68,.12);color:var(--red)}
.btn-r:hover{background:rgba(255,68,68,.14)}
.btn-sm{padding:7px 14px;font-size:11px;border-radius:6px}

/* Animação de encriptação */
.encrypt-screen{display:none;flex-direction:column;align-items:center;justify-content:center;gap:20px;padding:40px 32px;text-align:center}
.encrypt-screen.active{display:flex}
.encrypt-icon{width:56px;height:56px;border:2px solid var(--border-3);border-radius:14px;display:flex;align-items:center;justify-content:center;color:var(--text-2);animation:lockSpin 2s ease-in-out infinite}
.encrypt-icon.done{animation:none;border-color:rgba(68,255,136,.3);color:var(--green)}
.encrypt-steps{display:flex;flex-direction:column;gap:10px;width:100%;max-width:280px}
.encrypt-step{display:flex;align-items:center;gap:10px;font-size:12px;color:var(--text-4);transition:color .3s}
.encrypt-step.active{color:var(--text-2)}
.encrypt-step.done{color:var(--green)}
.encrypt-step-dot{width:18px;height:18px;border-radius:50%;border:1.5px solid var(--border-2);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .3s;font-size:9px}
.encrypt-step.active .encrypt-step-dot{border-color:var(--text-3)}
.encrypt-step.done .encrypt-step-dot{border-color:var(--green);background:rgba(68,255,136,.1)}
.encrypt-bar{height:2px;background:var(--border);border-radius:2px;overflow:hidden;margin-top:8px;width:100%;max-width:280px}
.encrypt-bar-fill{height:100%;background:var(--green);border-radius:2px;width:0;transition:width .4s var(--ease)}
.encrypt-dots{display:flex;gap:4px;margin-top:4px}
.encrypt-dots span{width:4px;height:4px;border-radius:50%;background:var(--text-3);animation:dotPulse 1.4s ease-in-out infinite}
.encrypt-dots span:nth-child(2){animation-delay:.2s}
.encrypt-dots span:nth-child(3){animation-delay:.4s}

.success-block{background:var(--green-dim);border:1px solid rgba(68,255,136,.1);border-radius:10px;padding:16px;margin:16px 0}
.success-block p{font-size:12px;color:var(--green);line-height:1.6}
.success-block .email-show{font-family:var(--mono);font-size:13px;color:var(--text);margin:8px 0 4px;word-break:break-all}
.warn-block{display:flex;align-items:flex-start;gap:8px;background:rgba(255,170,0,.05);border:1px solid rgba(255,170,0,.1);border-radius:8px;padding:12px;font-size:11px;color:var(--amber);line-height:1.5;margin-top:12px}
.warn-block svg{flex-shrink:0;margin-top:1px}
.token-reveal{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:12px;margin:12px 0;position:relative}
.token-reveal-label{font-family:var(--mono);font-size:9px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-4);margin-bottom:6px;display:block}
.token-reveal-val{font-family:var(--mono);font-size:10px;color:var(--text-3);word-break:break-all;line-height:1.6}
.token-reveal-copy{position:absolute;top:8px;right:8px;background:var(--surface-3);border:1px solid var(--border-2);color:var(--text-4);padding:3px 8px;border-radius:4px;font-size:9px;font-family:var(--sans);cursor:pointer;transition:all .2s}
.token-reveal-copy:hover{color:var(--text);border-color:var(--border-3)}

/* Modal legal */
.legal-content{font-size:13px;color:var(--text-2);line-height:1.8}
.legal-content h3{font-family:var(--serif);font-size:20px;font-weight:400;margin:24px 0 10px;color:var(--text)}
.legal-content h3:first-child{margin-top:0}
.legal-content p{margin-bottom:12px}
.legal-content ul{margin:8px 0 16px 20px}
.legal-content li{margin-bottom:6px}
.legal-content strong{color:var(--text)}

/* App */
.app{display:none;min-height:100vh;flex-direction:column}
.app.active{display:flex}
.topbar{display:flex;align-items:center;justify-content:space-between;padding:12px 24px;border-bottom:1px solid var(--border);background:rgba(5,5,5,.9);backdrop-filter:blur(20px);position:sticky;top:0;z-index:100}
.topbar-mid{display:flex;align-items:center;gap:8px}
.timer{display:flex;align-items:center;gap:5px;font-family:var(--mono);font-size:11px;font-weight:500;padding:5px 10px;border-radius:6px}
.timer.ok{background:var(--accent-dim);color:var(--text-2)}
.timer.warn{background:var(--red-dim);color:var(--red)}
.timer.inf{background:var(--green-dim);color:var(--green)}
.topbar-acts{display:flex;gap:4px}

.ebar{display:flex;align-items:center;gap:10px;padding:12px 24px;border-bottom:1px solid var(--border)}
.ebar-addr{flex:1;display:flex;align-items:center;background:var(--surface-2);border:1px solid var(--border);border-radius:8px;padding:10px 14px;min-width:0}
.ebar-addr span{font-family:var(--mono);font-size:13px;color:var(--text);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.copy-btn{display:flex;align-items:center;gap:5px;background:var(--surface-3);border:1px solid var(--border-2);color:var(--text-3);border-radius:6px;padding:5px 10px;cursor:pointer;font-size:10px;font-weight:600;font-family:var(--sans);transition:all .2s;white-space:nowrap}
.copy-btn:hover{border-color:var(--border-3);color:var(--text-2)}
.copy-btn.ok{border-color:rgba(68,255,136,.2);color:var(--green)}
.icn-btn{width:38px;height:38px;display:flex;align-items:center;justify-content:center;background:var(--surface-2);border:1px solid var(--border);border-radius:8px;color:var(--text-3);cursor:pointer;transition:all .2s;flex-shrink:0}
.icn-btn:hover{border-color:var(--border-3);color:var(--text)}
.icn-btn.spinning svg{animation:spin .7s linear infinite}

.main{flex:1;display:flex;min-height:0}
.side{width:360px;border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}
.side-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border)}
.side-head-l{display:flex;align-items:center;gap:8px}
.side-head h3{font-size:12px;font-weight:600;color:var(--text-2)}
.ubadge{background:var(--white);color:var(--black);border-radius:100px;padding:1px 6px;font-size:9px;font-weight:700;font-family:var(--mono);display:none}
.ubadge.on{display:inline}
.mcount{font-family:var(--mono);font-size:10px;color:var(--text-ghost)}
.elist{flex:1;overflow-y:auto}

.empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 24px;gap:12px}
.empty-ic{width:48px;height:48px;border-radius:12px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--text-ghost)}
.empty p{font-size:12px;color:var(--text-4);text-align:center}
.empty .mono{font-family:var(--mono);font-size:10px;color:var(--text-3)}

.eitem{display:flex;align-items:flex-start;gap:10px;padding:14px 18px;cursor:pointer;border-bottom:1px solid var(--border);border-left:2px solid transparent;transition:all .12s;animation:fadeIn .25s ease both}
.eitem:hover{background:var(--accent-dim)}
.eitem.sel{background:rgba(255,255,255,.03);border-left-color:var(--text-2)}
.eitem.unread{background:rgba(255,255,255,.015)}
.udot{width:6px;height:6px;border-radius:50%;background:var(--white);margin-top:6px;flex-shrink:0}
.udot-space{width:6px;flex-shrink:0}
.eitem-c{flex:1;min-width:0}
.eitem-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:2px}
.eitem-from{font-size:12px;font-weight:500;color:var(--text-2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.eitem.unread .eitem-from{font-weight:600;color:var(--text)}
.eitem-time{font-family:var(--mono);font-size:9px;color:var(--text-ghost);flex-shrink:0;margin-left:8px}
.eitem-subj{font-size:12px;font-weight:500;color:var(--text-2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-bottom:2px}
.eitem.unread .eitem-subj{color:var(--text)}
.eitem-pre{font-size:11px;color:var(--text-4);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

.detail{flex:1;overflow-y:auto;display:none;flex-direction:column}
.detail.active{display:flex}
.detail-nil{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px}
.detail-nil p{font-size:12px;color:var(--text-ghost)}
.dtool{display:flex;align-items:center;justify-content:space-between;padding:12px 24px;border-bottom:1px solid var(--border)}
.btn-back{display:flex;align-items:center;gap:5px;background:none;border:none;color:var(--text-3);cursor:pointer;font-size:11px;font-family:var(--sans);font-weight:500}
.btn-back:hover{color:var(--text)}
.dcontent{padding:28px;flex:1}
.dcontent h2{font-family:var(--serif);font-size:24px;font-weight:400;margin-bottom:20px;line-height:1.3}
.dmeta{display:flex;align-items:center;gap:12px;margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid var(--border)}
.davatar{width:36px;height:36px;border-radius:8px;background:var(--surface-3);border:1px solid var(--border-2);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;color:var(--text-2);flex-shrink:0;font-family:var(--serif)}
.dinfo{min-width:0}
.dinfo .dfrom{font-size:12px;font-weight:600}
.dinfo .dto{font-family:var(--mono);font-size:10px;color:var(--text-4);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dbody{font-size:14px;line-height:1.8;color:var(--text-2);white-space:pre-wrap;word-wrap:break-word}
.dbody-html{display:flex;justify-content:center;padding:0}
.dbody-html iframe{width:100%;max-width:680px;height:500px;border:1px solid var(--border-2);border-radius:8px;background:#fff;margin:0 auto;display:block}

.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:var(--surface-4);border:1px solid var(--border-3);color:var(--text);padding:10px 20px;border-radius:8px;font-size:12px;font-weight:500;z-index:9999;pointer-events:none;opacity:0;transition:opacity .3s}
.toast.on{opacity:1}

@media(max-width:900px){
    .hero-inner{grid-template-columns:1fr;gap:40px}
    .hero{padding:40px 24px 60px}
    .nav{padding:20px 24px}
    .side{width:100%}
    .side.hide-m{display:none}
    .detail{min-width:100%}
    .footer-grid{grid-template-columns:1fr 1fr;gap:24px}
}
@media(max-width:640px){
    .nav{padding:16px 20px}
    .hero{padding:20px 20px 40px}
    .ebar{flex-wrap:wrap}
    .footer{padding:32px 20px 24px}
    .footer-grid{grid-template-columns:1fr}
    .hero-stats{gap:20px;flex-wrap:wrap}
}

/* Utilitários */
.u-hidden { display: none !important }
.logo-mark-sm { width: 28px; height: 28px; border-radius: 7px }
.logo-name-sm { font-size: 14px }
.text-center { text-align: center }
.mt-8 { margin-top: 8px }
.mt-12 { margin-top: 12px }
.mt-20 { margin-top: 20px }
.token-summary {
    font-size: 11px;
    color: var(--text-4);
    cursor: pointer;
    font-family: var(--mono);
    letter-spacing: .5px;
}

/* Donate (hero) */
.hero-donate {
    margin-top: 20px;
    animation: up .7s var(--ease) .6s both;
}
.donate-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: none;
    border: 1px solid var(--border-2);
    color: var(--text-4);
    padding: 7px 16px;
    border-radius: 20px;
    font-family: var(--sans);
    font-size: 11px;
    font-weight: 500;
    cursor: pointer;
    transition: all .3s var(--ease);
    text-decoration: none;
}
.donate-btn:hover {
    border-color: var(--red);
    color: var(--red);
    background: var(--red-dim);
}
.donate-btn svg { transition: transform .3s var(--ease) }
.donate-btn:hover svg { transform: scale(1.15) }

/* Donate modal */
.donate-icon {
    width: 56px; height: 56px;
    border: 2px solid rgba(255,68,68,.2);
    border-radius: 14px;
    display: flex; align-items: center; justify-content: center;
    color: var(--red); margin: 0 auto 16px;
}
.wallet-list {
    display: flex; flex-direction: column; gap: 10px;
    margin: 16px 0; text-align: left;
}
.wallet-item {
    background: var(--bg);
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: 12px;
}
.wallet-head {
    display: flex; justify-content: space-between;
    align-items: center; margin-bottom: 6px;
}
.wallet-name {
    font-family: var(--sans);
    font-size: 11px; font-weight: 600;
    color: var(--text-2);
}
.wallet-copy {
    background: var(--surface-3);
    border: 1px solid var(--border-2);
    color: var(--text-4);
    padding: 2px 8px; border-radius: 4px;
    font-size: 9px; font-family: var(--sans);
    cursor: pointer; transition: all .2s;
}
.wallet-copy:hover { color: var(--text); border-color: var(--border-3) }
.wallet-addr {
    font-family: var(--mono);
    font-size: 10px; color: var(--text-3);
    word-break: break-all; line-height: 1.5;
    user-select: all;
}
.donate-thanks {
    font-size: 11px; color: var(--text-4);
    margin-top: 8px; line-height: 1.5;
}

/* Stats com tabular-nums para animação suave */
.stat-num {
    font-variant-numeric: tabular-nums;
}

/* PGP */
.pgp-input {
    width: 100%;
    background: var(--bg);
    border: 1px solid var(--border-2);
    border-radius: 8px;
    color: var(--text);
    font-family: var(--mono);
    font-size: 11px;
    padding: 10px 12px;
    outline: none;
    resize: vertical;
    transition: border-color .2s;
}
.pgp-input:focus { border-color: var(--text-3) }
.pgp-input::placeholder { color: var(--text-ghost) }
.pgp-notice {
    display: flex;
    align-items: center;
    gap: 8px;
    background: rgba(68,255,136,.05);
    border: 1px solid rgba(68,255,136,.12);
    border-radius: 8px;
    padding: 12px 16px;
    font-size: 12px;
    color: var(--green);
    margin-bottom: 16px;
}

/* Attachments */
.att-list { margin-top: 20px; padding-top: 16px; border-top: 1px solid var(--border) }
.att-label {
    font-family: var(--mono);
    font-size: 10px; font-weight: 600;
    letter-spacing: 1px; text-transform: uppercase;
    color: var(--text-4); margin-bottom: 8px;
}
.att-item {
    display: inline-flex; align-items: center; gap: 6px;
    background: var(--surface-2);
    border: 1px solid var(--border);
    border-radius: 6px;
    padding: 6px 12px;
    font-size: 12px; color: var(--text-2);
    text-decoration: none;
    margin: 0 6px 6px 0;
    transition: all .2s;
}
.att-item:hover { border-color: var(--border-3); color: var(--text) }
.att-size { font-size: 10px; color: var(--text-4) }
