/* === Auth & Reviews === */

/* User badge in top nav */
.nav-login{font-size:14px;color:var(--ink-2);padding:8px 16px;border:1px solid var(--ink-2);border-radius:999px;cursor:pointer;transition:all .15s;background:transparent;font-weight:500}
.nav-login:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.user-badge{display:flex;align-items:center;gap:10px;padding:6px 12px 6px 6px;border:1px solid var(--line-2);border-radius:999px;background:var(--paper)}
.user-badge .avatar{width:28px;height:28px;border-radius:50%;background:var(--forest);color:var(--paper);display:flex;align-items:center;justify-content:center;font-family:"JetBrains Mono",monospace;font-size:11px;font-weight:600;letter-spacing:.04em}
.user-badge .name{font-size:13px;color:var(--ink);font-weight:500}
.user-badge .logout{margin-left:4px;font-size:14px;color:var(--ink-3);background:none;border:none;cursor:pointer;padding:0 4px;line-height:1}
.user-badge .logout:hover{color:var(--clay)}

/* Modal */
.modal-overlay{position:fixed;inset:0;background:rgba(28,26,21,.5);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:200;padding:24px;animation:fade-in .18s ease-out}
@keyframes fade-in{from{opacity:0}to{opacity:1}}
.modal{background:var(--paper);border:1px solid var(--line);max-width:440px;width:100%;padding:36px 36px 28px;position:relative;box-shadow:0 24px 60px rgba(28,26,21,.25);animation:rise .25s ease-out}
@keyframes rise{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
.modal-close{position:absolute;top:14px;right:18px;font-size:24px;color:var(--ink-3);background:none;border:none;cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;line-height:1}
.modal-close:hover{color:var(--ink)}
.modal-brand{display:flex;justify-content:center;margin-bottom:24px}
.modal-tabs{display:flex;gap:2px;background:var(--paper-2);padding:3px;border-radius:8px;margin-bottom:20px}
.modal-tabs button{flex:1;padding:10px 16px;font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);border-radius:6px;background:transparent;cursor:pointer;border:none;font-weight:500}
.modal-tabs button.active{background:var(--paper);color:var(--ink);box-shadow:0 1px 3px rgba(0,0,0,.06)}
.modal-lead{font-family:"Newsreader",serif;font-size:16px;line-height:1.45;color:var(--ink-2);margin:0 0 24px}
.modal-form{display:flex;flex-direction:column;gap:14px}
.modal-form label{display:flex;flex-direction:column;gap:6px}
.modal-form label span{font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:var(--ink-3)}
.modal-form input{padding:12px 14px;border:1px solid var(--line-2);background:var(--paper);font:inherit;font-size:14px;color:var(--ink);border-radius:4px;transition:border-color .15s}
.modal-form input:focus{outline:none;border-color:var(--forest)}
.modal-error{padding:10px 12px;background:#f4dccd;color:#7a3019;font-size:13px;border-radius:4px;border-left:3px solid var(--clay)}
.modal-submit{justify-content:center;margin-top:8px}
.modal-foot{display:flex;justify-content:space-between;align-items:center;margin-top:20px;padding-top:18px;border-top:1px solid var(--line);font-size:13px}
.modal-foot a{color:var(--forest);cursor:pointer;font-weight:500}
.modal-foot a:hover{text-decoration:underline}

/* Reviews section */
.reviews{padding:48px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.reviews-head{margin-bottom:32px}
.reviews-summary{display:grid;grid-template-columns:240px 1fr;gap:48px;padding:28px 32px;background:var(--paper-2);border:1px solid var(--line);margin-bottom:32px;align-items:center}
.rs-score{text-align:center;padding-right:32px;border-right:1px solid var(--line-2)}
.rs-avg{font-family:"Newsreader",serif;font-size:64px;line-height:1;letter-spacing:-.025em;color:var(--ink);margin-bottom:8px}
.rs-count{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--ink-3);letter-spacing:.05em;margin-top:8px}
.rs-dist{display:flex;flex-direction:column;gap:6px}
.rs-row{display:grid;grid-template-columns:48px 1fr 30px;align-items:center;gap:14px;font-family:"JetBrains Mono",monospace;font-size:12px;color:var(--ink-2)}
.rs-row-lbl{display:flex;align-items:center;gap:4px}
.rs-bar{height:6px;background:var(--paper);border-radius:3px;overflow:hidden;position:relative}
.rs-bar span{display:block;height:100%;background:var(--forest);border-radius:3px;transition:width .3s}
.rs-row-count{text-align:right;color:var(--ink-3)}

/* Review form */
.review-form{background:var(--paper);border:1px solid var(--line);padding:24px;margin-bottom:32px}
.rf-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px;padding-bottom:14px;border-bottom:1px solid var(--line)}
.rf-user{display:flex;align-items:center;gap:10px;font-size:14px;font-weight:500;color:var(--ink)}
.rf-user .avatar{width:32px;height:32px;border-radius:50%;background:var(--forest);color:var(--paper);display:flex;align-items:center;justify-content:center;font-family:"JetBrains Mono",monospace;font-size:11px;font-weight:600}
.rf-stars{display:flex;align-items:center;gap:6px;margin-bottom:14px}
.rf-star{font-size:32px;line-height:1;color:var(--line-2);background:none;border:none;cursor:pointer;padding:0 2px;transition:color .12s;font-family:inherit}
.rf-star.active{color:var(--forest)}
.rf-star:hover{transform:scale(1.05)}
.rf-stars-lbl{margin-left:10px;font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--ink-3);letter-spacing:.05em;text-transform:uppercase}
.review-form textarea{width:100%;padding:14px;border:1px solid var(--line-2);background:var(--paper-2);font:inherit;font-size:14px;line-height:1.55;color:var(--ink);border-radius:4px;resize:vertical;min-height:100px;font-family:"Hanken Grotesk",sans-serif}
.review-form textarea:focus{outline:none;border-color:var(--forest);background:var(--paper)}
.rf-foot{display:flex;justify-content:space-between;align-items:center;margin-top:14px}
.rf-foot .btn:disabled{opacity:.4;cursor:not-allowed}

/* Login gate */
.login-gate{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:24px;padding:28px 32px;background:var(--paper-2);border:1px dashed var(--line-2);margin-bottom:32px}
.lg-icon{width:56px;height:56px;border-radius:50%;background:var(--paper);color:var(--forest);display:flex;align-items:center;justify-content:center;border:1px solid var(--line-2)}
.lg-body h4{font-family:"Newsreader",serif;font-weight:500;font-size:20px;margin:0 0 4px;letter-spacing:-.01em}
.lg-body p{font-size:14px;color:var(--ink-2);margin:0;max-width:480px;line-height:1.5}

/* Reviews list */
.reviews-list{display:flex;flex-direction:column;gap:0}
.review{padding:24px 0;border-bottom:1px solid var(--line)}
.review:last-child{border-bottom:0}
.rv-head{display:flex;align-items:center;gap:14px;margin-bottom:12px}
.rv-head .avatar{width:40px;height:40px;border-radius:50%;background:var(--cream);color:var(--ink-2);display:flex;align-items:center;justify-content:center;font-family:"JetBrains Mono",monospace;font-size:13px;font-weight:600;flex-shrink:0}
.rv-meta{flex:1}
.rv-name{font-size:14px;font-weight:500;color:var(--ink);margin-bottom:2px}
.rv-date{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--ink-3);letter-spacing:.04em}
.rv-rating{display:flex;align-items:center;gap:4px}
.rv-text{font-family:"Newsreader",serif;font-size:17px;line-height:1.55;color:var(--ink-2);margin:0 0 0 54px}

@media (max-width: 800px) {
  .reviews-summary{grid-template-columns:1fr;gap:24px;padding:20px}
  .rs-score{padding-right:0;border-right:0;padding-bottom:24px;border-bottom:1px solid var(--line-2)}
  .login-gate{grid-template-columns:1fr;text-align:center}
  .rv-text{margin-left:0}
}
