/* ProAlert Feedback Portal — Main Stylesheet */
:root {
  --black:        #000000;
  --accent:       #37ca37;
  --accent-dark:  #2aaa2a;
  --text-dark:    #1a1a1a;
  --text-mid:     #555555;
  --text-light:   #999999;
  --border:       #e8e8e8;
  --bg-alt:       #f7f7f6;
  --white:        #ffffff;
  --font-head:    'Montserrat', Arial, sans-serif;
  --font-body:    'Lato', Arial, sans-serif;
  --max-width:    1160px;
  --radius:       6px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
body{font-family:var(--font-body);font-size:15px;line-height:1.7;color:var(--text-dark);background:#f0f0ef;min-height:100vh;display:flex;flex-direction:column}

/* === LAYOUT === */
.container{max-width:var(--max-width);margin:0 auto;padding:0 20px}
.site-main{flex:1}

/* === HEADER === */
.site-header{background:var(--black);position:sticky;top:0;z-index:100;border-bottom:2px solid var(--accent)}
.header-inner{max-width:var(--max-width);margin:0 auto;padding:0 20px;height:64px;display:flex;align-items:center;gap:24px}
.site-brand{display:flex;flex-direction:column;gap:0;text-decoration:none}
.brand-logo{height:34px;width:auto;display:block}
.brand-sub{font-size:10px;color:var(--accent);text-transform:uppercase;letter-spacing:.06em;line-height:1;margin-top:2px}
.header-nav{margin-left:auto;display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.header-nav a{color:rgba(255,255,255,.75);font-size:14px;font-weight:700;transition:color .15s}
.header-nav a:hover{color:#fff}
.btn-submit-nav{display:inline-flex;align-items:center;gap:5px;background:var(--accent);color:#fff !important;padding:7px 16px;border-radius:var(--radius);transition:background .15s !important}
.btn-submit-nav:hover{background:var(--accent-dark) !important}
.btn-submit-nav svg{width:13px;height:13px}

/* === FLASH MESSAGES === */
.flash{padding:12px 0;font-size:14px}
.flash-success{background:#e8f5e9;color:#2e7d32;border-bottom:1px solid #c8e6c9}
.flash-error{background:#ffebee;color:#c62828;border-bottom:1px solid #ffcdd2}

/* === HERO === */
.hero{background:var(--black);color:#fff;padding:64px 20px;text-align:center}
.hero h1{font-family:var(--font-head);font-size:clamp(28px,4vw,44px);font-weight:700;margin-bottom:16px;line-height:1.2}
.hero h1 span{color:var(--accent)}
.hero p{font-size:17px;color:rgba(255,255,255,.7);max-width:600px;margin:0 auto 32px}
.hero-cards{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-top:8px}
.type-card{background:rgba(255,255,255,.07);border:1.5px solid rgba(255,255,255,.12);border-radius:8px;padding:20px 28px;text-align:center;text-decoration:none;color:#fff;transition:border-color .2s,background .2s;min-width:160px}
.type-card:hover{border-color:var(--accent);background:rgba(55,202,55,.1)}
.type-card .type-icon{margin-bottom:8px;display:flex;align-items:center;justify-content:center}
.type-card .type-icon svg{width:34px;height:34px;stroke:var(--accent);stroke-width:1.5}
.type-card .type-label{font-family:var(--font-head);font-size:13px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--accent);display:block;margin-bottom:4px}
.type-card .type-desc{font-size:12px;color:rgba(255,255,255,.55)}

/* === SEARCH BAR === */
.search-bar-wrap{background:#fff;border-bottom:1px solid var(--border);padding:16px 0}
.search-form{display:flex;gap:8px;max-width:640px;margin:0 auto}
.search-form input{flex:1;padding:10px 14px;border:1.5px solid var(--border);border-radius:var(--radius);font-size:15px;font-family:inherit}
.search-form input:focus{outline:none;border-color:var(--accent)}
.search-form button{padding:10px 20px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius);font-family:var(--font-head);font-size:13px;font-weight:700;cursor:pointer;transition:background .15s}
.search-form button:hover{background:var(--accent-dark)}

/* === SECTION LAYOUT === */
.section{padding:40px 0}
.section-title{font-family:var(--font-head);font-size:20px;font-weight:700;color:var(--text-dark);margin-bottom:20px}
.two-col{display:grid;grid-template-columns:1fr 280px;gap:32px;align-items:start}
@media(max-width:780px){.two-col{grid-template-columns:1fr}}

/* === MODULE GRID === */
.module-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}
.module-chip{background:#fff;border:1.5px solid var(--border);border-radius:var(--radius);padding:10px 14px;font-size:13px;font-weight:700;text-align:center;transition:border-color .15s,color .15s;cursor:pointer;text-decoration:none;color:var(--text-dark)}
.module-chip:hover,.module-chip.active{border-color:var(--accent);color:var(--accent)}

/* === SUBMISSION CARDS === */
.submission-list{display:flex;flex-direction:column;gap:12px}
.submission-card{background:#fff;border:1.5px solid var(--border);border-radius:8px;padding:16px 20px;display:flex;gap:16px;align-items:flex-start;transition:border-color .15s}
.submission-card:hover{border-color:var(--accent)}
.card-type-badge{flex-shrink:0;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em}
.badge-bug{background:#ffebee;color:#c62828}
.badge-issue{background:#fff3e0;color:#e65100}
.badge-suggestion{background:#e8f5e9;color:#2e7d32}
.card-body{flex:1;min-width:0}
.card-title{font-family:var(--font-head);font-size:15px;font-weight:700;color:var(--text-dark);margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.card-title a{color:inherit}
.card-title a:hover{color:var(--accent)}
.card-meta{font-size:12px;color:var(--text-light);display:flex;gap:12px;flex-wrap:wrap}
.card-summary{font-size:13px;color:var(--text-mid);margin-top:4px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.card-right{flex-shrink:0;text-align:right}
.vote-count{font-family:var(--font-head);font-size:20px;font-weight:700;color:var(--accent);line-height:1}
.vote-label{font-size:10px;color:var(--text-light);text-transform:uppercase;letter-spacing:.05em}

/* === STATUS BADGE === */
.status-badge{display:inline-block;padding:2px 10px;border-radius:20px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;background:var(--bg-alt);color:var(--text-mid)}
.status-blue{background:#e3f2fd;color:#1565c0}
.status-yellow{background:#fffde7;color:#f57f17}
.status-orange{background:#fff3e0;color:#e65100}
.status-red{background:#ffebee;color:#c62828}
.status-green{background:#e8f5e9;color:#2e7d32}
.status-purple{background:#f3e5f5;color:#6a1b9a}
.status-indigo{background:#e8eaf6;color:#283593}
.status-teal{background:#e0f2f1;color:#00695c}
.status-gray{background:#f5f5f5;color:#616161}

/* === FILTERS === */
.filter-bar{background:#fff;border:1.5px solid var(--border);border-radius:8px;padding:16px;margin-bottom:20px;display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.filter-bar label{font-size:12px;font-weight:700;color:var(--text-mid);text-transform:uppercase;letter-spacing:.04em}
.filter-bar select{padding:6px 10px;border:1.5px solid var(--border);border-radius:var(--radius);font-size:13px;font-family:inherit;background:#fff}
.filter-bar select:focus{outline:none;border-color:var(--accent)}

/* === PAGINATION === */
.pagination{display:flex;gap:8px;justify-content:center;margin-top:24px;flex-wrap:wrap}
.page-btn{padding:6px 12px;border:1.5px solid var(--border);border-radius:var(--radius);font-size:13px;font-weight:700;background:#fff;color:var(--text-dark);text-decoration:none}
.page-btn:hover,.page-btn.active{border-color:var(--accent);color:var(--accent)}

/* === DETAIL PAGE === */
.detail-header{background:var(--black);color:#fff;padding:40px 0 32px}
.detail-header .container{max-width:var(--max-width)}
.detail-type-module{font-size:12px;color:rgba(255,255,255,.55);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}
.detail-header h1{font-family:var(--font-head);font-size:clamp(20px,3vw,30px);font-weight:700;line-height:1.25;max-width:760px}
.detail-meta{display:flex;gap:16px;flex-wrap:wrap;margin-top:16px;font-size:13px;color:rgba(255,255,255,.6)}
.detail-layout{display:grid;grid-template-columns:1fr 280px;gap:32px;align-items:start;padding-top:32px}
@media(max-width:780px){.detail-layout{grid-template-columns:1fr}}
.detail-sidebar{display:flex;flex-direction:column;gap:16px}
.sidebar-card{background:#fff;border:1.5px solid var(--border);border-radius:8px;padding:20px}
.sidebar-card h3{font-family:var(--font-head);font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-mid);margin-bottom:12px}
.sidebar-row{display:flex;justify-content:space-between;align-items:center;font-size:13px;padding:4px 0;border-bottom:1px solid var(--bg-alt)}
.sidebar-row:last-child{border-bottom:none}
.sidebar-row .label{color:var(--text-light)}
.sidebar-row .value{font-weight:700;color:var(--text-dark)}

/* === VOTE BUTTON === */
.vote-btn{width:100%;padding:12px;border-radius:var(--radius);font-family:var(--font-head);font-size:14px;font-weight:700;cursor:pointer;border:2px solid var(--accent);transition:all .15s;text-align:center}
.vote-btn.not-voted{background:#fff;color:var(--accent)}
.vote-btn.not-voted:hover{background:var(--accent);color:#fff}
.vote-btn.voted{background:var(--accent);color:#fff}

/* === COMMENTS === */
.comments-section{margin-top:32px}
.comment-item{background:#fff;border:1.5px solid var(--border);border-radius:8px;padding:16px 20px;margin-bottom:12px}
.comment-header{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.comment-avatar{width:32px;height:32px;border-radius:50%;object-fit:cover;border:1.5px solid var(--border);flex-shrink:0}
.comment-author{font-size:13px;font-weight:700;color:var(--text-dark)}
.comment-date{font-size:12px;color:var(--text-light);margin-left:4px}
.comment-body{margin-top:0;font-size:14px;color:var(--text-mid);white-space:pre-wrap;padding-left:42px}
.comment-form textarea{width:100%;padding:12px;border:1.5px solid var(--border);border-radius:var(--radius);font-family:inherit;font-size:14px;resize:vertical;min-height:90px}
.comment-form textarea:focus{outline:none;border-color:var(--accent)}
.btn{padding:10px 20px;border-radius:var(--radius);font-family:var(--font-head);font-size:13px;font-weight:700;cursor:pointer;border:none;transition:background .15s}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent-dark)}
.btn-outline{background:#fff;color:var(--text-dark);border:1.5px solid var(--border)}
.btn-outline:hover{border-color:var(--accent);color:var(--accent)}

/* === FORMS === */
.form-card{background:#fff;border-radius:8px;border:1.5px solid var(--border);padding:28px;margin-bottom:24px}
.form-card h2{font-family:var(--font-head);font-size:17px;font-weight:700;margin-bottom:20px;color:var(--text-dark)}
.form-group{margin-bottom:20px}
.form-group label{display:block;font-size:13px;font-weight:700;color:#333;margin-bottom:6px}
.form-group input,.form-group textarea,.form-group select{width:100%;padding:10px 12px;border:1.5px solid var(--border);border-radius:var(--radius);font-size:15px;font-family:inherit;background:#fff;transition:border-color .2s}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--accent)}
.form-group textarea{resize:vertical;min-height:90px}
.field-error{font-size:12px;color:#d32f2f;margin-top:4px}
.form-hint{font-size:12px;color:var(--text-light);margin-top:4px}
.required-mark{color:#c62828;margin-left:2px}

/* === CHOOSE PAGE === */
.choose-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;margin-top:8px}
.choose-card{background:#fff;border:2px solid var(--border);border-radius:10px;padding:28px;text-decoration:none;color:var(--text-dark);transition:border-color .2s,box-shadow .2s;display:block}
.choose-card:hover{border-color:var(--accent);box-shadow:0 4px 16px rgba(55,202,55,.1)}
.choose-card .icon{margin-bottom:12px;display:flex;align-items:center}
.choose-card .icon svg{width:40px;height:40px;stroke:var(--accent);stroke-width:1.5}
.choose-card h3{font-family:var(--font-head);font-size:17px;font-weight:700;margin-bottom:8px;color:var(--text-dark)}
.choose-card p{font-size:14px;color:var(--text-mid);line-height:1.6}
.choose-card .examples{margin-top:12px;font-size:12px;color:var(--text-light)}

/* === SIDEBAR SMALL LISTS === */
.mini-list{list-style:none}
.mini-list li{padding:8px 0;border-bottom:1px solid var(--bg-alt);font-size:13px}
.mini-list li:last-child{border-bottom:none}
.mini-list a{color:var(--text-dark);font-weight:700}
.mini-list a:hover{color:var(--accent)}
.mini-list .meta{font-size:11px;color:var(--text-light);margin-top:2px}

/* === FOOTER === */
.site-footer{background:var(--black);color:rgba(255,255,255,.5);padding:24px 0;margin-top:auto}
.footer-inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;font-size:13px}
.footer-brand{display:flex;align-items:center;gap:14px}
.footer-logo{height:26px;width:auto;filter:invert(1) brightness(1.4)}
.footer-inner nav{display:flex;gap:20px}
.footer-inner a{color:rgba(255,255,255,.5)}
.footer-inner a:hover{color:#fff}
.footer-recaptcha{font-size:11px;color:rgba(255,255,255,.3);margin-top:10px;text-align:center;width:100%}
.footer-recaptcha a{color:rgba(255,255,255,.4)}
/* Hide floating badge — disclosure text shown in footer per Google ToS */
.grecaptcha-badge{visibility:hidden!important}

/* === ADMIN NAV (shared) === */
.admin-bar{background:#111;color:#fff;padding:0;border-bottom:2px solid #333}
.admin-bar-inner{max-width:var(--max-width);margin:0 auto;padding:0 20px;height:48px;display:flex;align-items:center;gap:20px;font-size:13px}
.admin-bar a{color:rgba(255,255,255,.6);font-weight:700;padding:4px 0}
.admin-bar a:hover,.admin-bar a.active{color:var(--accent)}

/* === ALERTS === */
.alert{padding:12px 16px;border-radius:var(--radius);margin-bottom:20px;font-size:14px}
.alert-success{background:#e8f5e9;color:#2e7d32;border:1px solid #c8e6c9}
.alert-error{background:#ffebee;color:#c62828;border:1px solid #ffcdd2}
.alert-info{background:#e3f2fd;color:#1565c0;border:1px solid #bbdefb}

/* === PUBLIC MOBILE NAV === */
.public-mobile-nav{display:none}

/* === RESPONSIVE === */
@media(max-width:600px){
  .header-nav a:not(.btn-submit-nav){display:none}
  .hero{padding:40px 16px}
  .hero-cards{gap:10px}
  .type-card{padding:16px 18px;min-width:120px}
  .public-mobile-nav{display:flex;overflow-x:auto;-webkit-overflow-scrolling:touch;background:#111;border-bottom:1px solid #333;padding:0 8px}
  .public-mobile-nav a{display:block;padding:10px 12px;font-size:13px;font-weight:700;color:rgba(255,255,255,.65);white-space:nowrap;text-decoration:none;border-bottom:3px solid transparent}
  .public-mobile-nav a:hover,.public-mobile-nav a.active{color:var(--accent);border-bottom-color:var(--accent)}
  .footer-inner{flex-direction:column;align-items:center;text-align:center}
  .footer-inner nav{justify-content:center;flex-wrap:wrap}
  .footer-brand{flex-direction:column;gap:8px}
}
