*{box-sizing:border-box;margin:0;padding:0;font-family:Arial,Helvetica,sans-serif}
body{background:#ffffff;color:#111827;min-height:100vh;display:flex;flex-direction:column}

a{color:inherit;text-decoration:none}

.top-bar{background:#ffffff;padding:14px 32px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #e5e7eb}
.logo{font-weight:700;font-size:20px;color:#f97316}
.logo span{color:#f9fafb}
.nav-links a{margin-left:18px;color:#6b7280;font-size:14px}
.nav-links a.active,.nav-links a:hover{color:#111827}
.auth-buttons .btn{margin-left:8px;padding:7px 16px;border-radius:999px;border:1px solid #d1d5db;background:#ffffff;color:#374151;font-size:13px;cursor:pointer}
.auth-buttons .btn.primary{background:#f97316;border-color:#f97316;color:#111827;font-weight:600}

.layout{flex:1;display:flex;gap:24px;padding:24px 32px;background:#f3f4f6}

.login-panel{width:320px}
.panel-inner{background:#ffffff;border-radius:12px;padding:20px;border:1px solid #e5e7eb}
.panel-header h2{font-size:18px;margin-bottom:6px}
.panel-header .subtitle{font-size:12px;color:#6b7280}

.tab-row{display:flex;margin:16px 0 10px;border-bottom:1px solid #e5e7eb}
.tab{flex:1;padding:8px 0;border:none;background:transparent;color:#6b7280;font-size:13px;cursor:pointer}
.tab.active{color:#f97316;border-bottom:2px solid #f97316;font-weight:600}
.tab:disabled{opacity:.4;cursor:not-allowed}

.login-form .form-group{margin-bottom:12px}
.login-form label{display:block;font-size:12px;margin-bottom:4px;color:#4b5563}
 .login-form input{width:100%;padding:8px 10px;border-radius:6px;border:1px solid #d1d5db;background:#ffffff;color:#111827;font-size:13px}
 .login-form input:focus{outline:none;border-color:#f97316;box-shadow:0 0 0 1px #f97316}

.btn.login-btn{width:100%;margin-top:6px;background:#f97316;border:1px solid #f97316;color:#111827;font-weight:600;padding:9px 0;border-radius:999px;font-size:14px;cursor:pointer}
.btn.login-btn:hover{filter:brightness(1.05)}

.alt-links{display:flex;justify-content:space-between;margin-top:8px}
.alt-link{font-size:11px;color:#6b7280}
.alt-link:hover{color:#111827}

.social-row{display:flex;align-items:center;justify-content:space-between;margin-top:14px}
.social-row span{font-size:11px;color:#6b7280}
.social-icons{display:flex;gap:6px}
.social{width:26px;height:26px;border-radius:999px;border:1px solid #d1d5db;background:#ffffff;color:#374151;font-size:13px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-weight:700}
.social.google{background:#ffffff;color:#ea4335;border-color:#e5e7eb}
.social.fb{background:#1877f2;color:#ffffff;border-color:#1877f2}
.social.apple{background:#000000;color:#ffffff;border-color:#000000;overflow:hidden}
.social.apple img{width:300%;height:300%;object-fit:contain;display:block}

.auto-login{display:flex;align-items:center;font-size:11px;color:#6b7280;margin-top:10px;gap:6px}
.auto-login input{width:auto}

.disclaimer{margin-top:14px;font-size:11px;color:#92400e;background:#fffbeb;border-radius:8px;padding:8px 10px;border:1px solid #fed7aa}

.hero-and-feed{flex:1;display:flex;flex-direction:column;gap:18px}
.hero{position:relative;border-radius:16px;overflow:hidden;min-height:210px;background:#e5e7eb}
.hero-overlay{position:absolute;inset:0;background:radial-gradient(circle at top left,rgba(248,113,113,.5),transparent),radial-gradient(circle at bottom right,rgba(59,130,246,.5),transparent);mix-blend-mode:screen;opacity:.8}
.hero-content{position:relative;padding:20px 22px;max-width:520px}
.hero .badge{display:inline-block;background:#f97316;color:#111827;font-size:11px;font-weight:600;padding:3px 10px;border-radius:999px;text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px}
.hero h1{font-size:26px;margin-bottom:8px}
.hero p{font-size:13px;color:#4b5563;margin-bottom:10px}
.hero-list{list-style:none;font-size:12px;color:#4b5563}
.hero-list li{margin-bottom:2px}

.feed h2,.attacker-log h2{font-size:16px;margin-bottom:8px}
.cards{display:flex;gap:12px;flex-wrap:wrap}
.card{flex:1;min-width:180px;background:#ffffff;border-radius:12px;border:1px solid #e5e7eb;padding:10px 12px}
.card h3{font-size:13px;margin-bottom:4px}
.card p{font-size:12px;color:#6b7280}

.news-list{list-style:none;margin:0;padding:0;border-top:1px solid #e5e7eb}
.news-item{padding:10px 0;border-bottom:1px solid #e5e7eb}
.news-title{display:block;font-size:13px;font-weight:600;color:#111827;margin-bottom:4px}
.news-title:hover{color:#2563eb}
.news-meta{font-size:11px;color:#6b7280}
.news-tag{color:#2563eb;font-weight:600;margin-right:6px}
.news-author{color:#6b7280}

.weapons{margin-top:16px}
.weapons h2{font-size:16px;margin-bottom:4px}
.weapons-note{font-size:11px;color:#6b7280;margin-bottom:6px}
.weapons-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}
.weapon-tile{background:#ffffff;border:1px solid #e5e7eb;border-radius:14px;padding:10px 12px;display:flex;flex-direction:column;align-items:stretch;gap:8px;cursor:pointer;transition:background-color .15s,border-color .15s,transform .1s;text-align:center}
.weapon-tile:hover{border-color:#f97316;transform:translateY(-1px)}
.weapon-tile.selected{background:#f97316;border-color:#f97316;color:#111827}
.weapon-img{width:100%;height:110px;border-radius:10px;background:linear-gradient(135deg,#1f2937,#4b5563);flex-shrink:0;position:relative;overflow:hidden}
.weapon-img::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at top left,rgba(248,113,113,.7),transparent),radial-gradient(circle at bottom right,rgba(59,130,246,.7),transparent);mix-blend-mode:screen;opacity:.9}
.weapon-name{font-size:12px;color:inherit;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}
.weapon-img img{width:100%;height:100%;object-fit:contain;display:block;position:relative;z-index:1}

.characters{margin-top:20px}
.characters h2{font-size:16px;margin-bottom:4px}
.characters-note{font-size:11px;color:#6b7280;margin-bottom:6px}
.characters-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}
.character-tile{background:#ffffff;border:1px solid #e5e7eb;border-radius:14px;padding:10px 12px;display:flex;flex-direction:column;align-items:stretch;gap:8px;cursor:pointer;transition:background-color .15s,border-color .15s,transform .1s;text-align:center}
.character-tile:hover{border-color:#f97316;transform:translateY(-1px)}
.character-tile.selected{background:#f97316;border-color:#f97316;color:#111827}
.character-img{width:100%;height:150px;border-radius:10px;background:#111827;position:relative;overflow:hidden}
.character-img img{width:100%;height:100%;object-fit:contain;display:block}
.character-name{font-size:12px;color:inherit;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}

.attacker-log{background:#ffffff;border-radius:12px;border:1px solid #e5e7eb;padding:10px 12px;margin-top:4px}
.log-desc{font-size:11px;color:#6b7280;margin-bottom:6px}
.log-output{background:#f9fafb;border-radius:8px;border:1px solid #e5e7eb;padding:8px 10px;font-size:11px;color:#1f2937;max-height:120px;overflow:auto;white-space:pre-wrap}

.attacker-layout{flex-direction:column;gap:20px;padding:28px;max-width:980px;margin:0 auto}
.attacker-section{background:#ffffff;border-radius:14px;border:1px solid #e5e7eb;padding:18px 20px;margin-top:4px;box-shadow:0 12px 30px rgba(15,23,42,.08)}
.attacker-section h2{font-size:18px;margin-bottom:6px}
.attacker-section h2+p{font-size:11px;color:#6b7280;margin-bottom:10px}
.attacker-error{font-size:12px;color:#b91c1c}
.attacker-empty{font-size:12px;color:#6b7280}
.attacker-table-wrapper{overflow:auto;max-height:260px;margin-top:8px;border-radius:10px;border:1px solid #e5e7eb;background:#f9fafb}
.attacker-table{width:100%;border-collapse:collapse;font-size:12px}
.attacker-table th,.attacker-table td{border-bottom:1px solid #e5e7eb;padding:6px 10px;text-align:left}
.attacker-table th{background:#f3f4f6;font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:#6b7280}
.attacker-table tr:nth-child(even) td{background:#ffffff}
.attacker-table tr:nth-child(odd) td{background:#f9fafb}
.attacker-table tr:hover td{background:#e5f2ff}
.attacker-message{font-size:12px;color:#065f46;margin-bottom:8px}
.attacker-forms{display:flex;flex-wrap:wrap;gap:12px;margin-top:6px}
.attacker-form{flex:1;min-width:240px;background:#f9fafb;border-radius:12px;border:1px solid #e5e7eb;padding:12px 14px}
.attacker-form h3{font-size:14px;margin-bottom:8px}
.attacker-form label{display:block;font-size:11px;color:#4b5563;margin-bottom:6px}
.attacker-form input{width:100%;padding:5px 7px;border-radius:6px;border:1px solid #d1d5db;font-size:11px}
.attacker-vip-lists{display:flex;flex-wrap:wrap;gap:12px;margin-top:10px}
.attacker-vip-column{flex:1;min-width:220px}
.attacker-vip-list{list-style:none;padding:0;margin:0;font-size:11px}
.attacker-vip-list li{padding:6px 8px;border-radius:999px;border:1px solid #e5e7eb;margin-bottom:4px;display:flex;justify-content:space-between;align-items:center;background:#f9fafb}
.attacker-vip-main{display:flex;align-items:center;gap:6px}
.attacker-vip-thumb{width:40px;height:40px;border-radius:10px;object-fit:contain;border:1px solid #d1d5db;background:#111827}
.attacker-vip-list li strong{font-size:11px}
.vip-meta{color:#2563eb;margin-left:8px;font-size:10px;padding:1px 8px;border-radius:999px;background:#e0f2fe;border:1px solid #bfdbfe}
.vip-delete-form{margin-left:6px}
.vip-delete-btn{border:none;background:transparent;color:#9ca3af;font-size:11px;cursor:pointer;padding:0 4px}
.vip-delete-btn:hover{color:#ef4444}

.footer{padding:10px 20px;font-size:11px;color:#6b7280;border-top:1px solid #e5e7eb;text-align:center;background:#ffffff}

@media(max-width:900px){
  .layout{flex-direction:column;padding:16px}
  .login-panel{width:100%;max-width:380px;margin:0 auto}
}

/* Login result modal */
.login-modal.hidden{display:none}
.login-modal{position:fixed;inset:0;z-index:50;display:flex;align-items:center;justify-content:center}
.login-modal-backdrop{position:absolute;inset:0;background:rgba(15,23,42,.65)}
.login-modal-dialog{position:relative;background:#ffffff;border-radius:16px;border:1px solid #e5e7eb;box-shadow:0 20px 40px rgba(15,23,42,.25);padding:18px 20px;max-width:420px;width:90%}
.login-modal-title{font-size:16px;margin-bottom:6px;color:#111827}
.login-modal-body{font-size:12px;color:#4b5563;margin-bottom:12px}
.login-modal-actions{text-align:right}
.login-modal .login-btn{width:auto;padding-inline:18px}

/* Dedicated login page */
.login-page-body{background:#f3f4f6;color:#111827;min-height:100vh;display:flex;flex-direction:column}
.login-page-layout{flex:1;display:flex;align-items:center;justify-content:center;padding:32px}
.login-page-card{width:100%;max-width:760px;background:#ffffff;border-radius:16px;border:1px solid #e5e7eb;box-shadow:0 12px 30px rgba(15,23,42,.08);overflow:hidden}
.login-page-tabs{display:flex;border-bottom:1px solid #e5e7eb;background:#f9fafb}
.login-tab{flex:1;padding:12px 0;border:none;background:transparent;font-size:14px;color:#6b7280;cursor:pointer}
.login-tab.active{color:#111827;font-weight:600;border-bottom:2px solid #f97316}
.login-tab:disabled{opacity:.5;cursor:not-allowed}
.login-page-body{display:flex;padding:24px 32px}
.login-page-left{flex:1;min-width:0}
.login-page-links{display:flex;justify-content:space-between;margin-top:10px;font-size:11px}
.login-page-links a{color:#6b7280}
.login-page-links a:hover{color:#111827}
.login-page-social{display:flex;align-items:center;justify-content:space-between;margin-top:14px;font-size:11px;color:#6b7280}
.login-page-disclaimer{font-size:11px;color:#6b7280;background:#f9fafb;border-top:1px solid #e5e7eb;padding:10px 16px}
.login-page-back{padding:8px 16px 12px;font-size:11px}
.login-page-back a{color:#3b82f6}
.login-page-back a:hover{text-decoration:underline}

@media(max-width:800px){
  .login-page-layout{padding:16px}
  .login-page-card{max-width:420px}
  .login-page-body{padding:20px}
}
