/* Modern refresh for Partner pages */
/* Theme variables */
/* Light (default) */
:root,
html[data-theme="light"] {
  --bg-grad-1: #f6f8fc;
  --bg-grad-2: #eef2f9;
  --panel: #ffffff;
  --card: #ffffff;
  --text: #0f172a;
  --muted: #475569;
  --brand: #2563eb;
  --brand-2: #38bdf8;
  --accent: #0ea5e9;
  --danger: #dc2626;
  --success: #16a34a;
  --ring: rgba(37, 99, 235, 0.28);
  --border: rgba(15, 23, 42, 0.08);
  --panel-grad: linear-gradient(180deg, rgba(0,0,0,.02), rgba(0,0,0,0));
  --shadow: 0 10px 25px rgba(2, 6, 23, 0.08);
}

/* Dark */
html[data-theme="dark"] {
  --bg-grad-1: #0b1220;
  --bg-grad-2: #0a1326;
  --panel: #131c2b;
  --card: #0f1725;
  --text: #e6eefc;
  --muted: #a9b7d0;
  --brand: #4f8cff;
  --brand-2: #7dd3fc;
  --accent: #22d3ee;
  --danger: #ff6b6b;
  --success: #34d399;
  --ring: rgba(79, 140, 255, 0.35);
  --border: rgba(255, 255, 255, 0.08);
  --panel-grad: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,0));
  --shadow: 0 10px 25px rgba(0,0,0,.35);
}

/* Respect system preference if user hasn't chosen */
@media (prefers-color-scheme: dark) {
  :root:not([data-theme]) {
    --bg-grad-1: #0b1220;
    --bg-grad-2: #0a1326;
    --panel: #131c2b;
    --card: #0f1725;
    --text: #e6eefc;
    --muted: #a9b7d0;
    --brand: #4f8cff;
    --brand-2: #7dd3fc;
    --accent: #22d3ee;
    --danger: #ff6b6b;
    --success: #34d399;
    --ring: rgba(79, 140, 255, 0.35);
    --border: rgba(255,255,255,.08);
    --panel-grad: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,0));
    --shadow: 0 10px 25px rgba(0,0,0,.35);
  }
}

html, body { background: linear-gradient(180deg, var(--bg-grad-1) 0%, var(--bg-grad-2) 100%); color: var(--text); font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; font-size: 15px; }

/* Layout wrappers from legacy templates */
#wrapper_r { max-width: 1200px; margin: 0 auto; padding: 28px 20px 64px; }

#header_r { background: var(--panel-grad); border: 1px solid var(--border); border-radius: 16px; padding: 16px 20px; box-shadow: var(--shadow); display: flex; align-items: center; gap: 20px; }
.brand { display: inline-flex; align-items: center; line-height: 0; }
.brand img { height: 36px; width: auto; max-width: 100%; filter: drop-shadow(0 4px 12px rgba(0,0,0,.35)); }

.site-nav { margin-left: auto; }
.menu_r, .nav_r { display: flex; gap: 12px; flex-wrap: wrap; align-items: center; margin: 0; padding: 0; list-style: none; }
.nav_r { flex-direction: row; }
.nav_r li { display: flex; }
.menu_r li a, .nav_r li a { display: inline-block; padding: 10px 14px; border-radius: 10px; color: var(--text); text-decoration: none; transition: all .2s ease; border: 1px solid transparent; background: transparent; }
/* Use theme vars for hover, works in both light and dark */
.menu_r li a:hover, .nav_r li a:hover { background: color-mix(in srgb, var(--text) 8%, transparent); border-color: var(--border); box-shadow: 0 6px 16px rgba(0,0,0,.25); transform: translateY(-1px); }

/* Hamburger */
.menu-toggle { margin-left: auto; display: none; width: 44px; height: 38px; border-radius: 10px; border: 1px solid var(--border); background: linear-gradient(180deg, var(--panel), var(--card)); cursor: pointer; align-items: center; justify-content: center; box-shadow: var(--shadow); position: relative; }
.menu-toggle .bar { display: none; width: 22px; height: 2px; background: var(--text); margin: 3px 0; border-radius: 2px; }
.menu-toggle .icon-menu, .menu-toggle .icon-close { color: var(--text); }
.menu-toggle .icon-close { display: none; }
.menu-toggle.open .icon-menu { display: none; }
.menu-toggle.open .icon-close { display: inline; }

#main_t { margin-top: 22px; }

/* Left promo card */
/* Legacy left promo hidden on new layout */
#join_r { display: none; }

/* Content card */
#content_r { background: transparent; border: 0; padding: 0; box-shadow: none; }
#left_r { max-width: 100%; }

/* New partner landing layout */
.partner-hero { background: linear-gradient(180deg, var(--panel), var(--card)); border: 1px solid var(--border); border-radius: 18px; padding: 24px; box-shadow: var(--shadow); display: grid; grid-template-columns: 1.5fr 1fr; gap: 16px; align-items: center; }
.partner-hero h2 { font-size: 28px; margin-bottom: 6px; }
.partner-hero p { color: var(--muted); }
.partner-hero .badge { display: inline-block; background: color-mix(in srgb, var(--brand) 14%, transparent); color: var(--brand); border: 1px solid color-mix(in srgb, var(--brand) 38%, transparent); padding: 4px 10px; border-radius: 999px; font-weight: 600; font-size: 12px; margin-bottom: 10px; }

.partner-grid { margin-top: 18px; display: grid; grid-template-columns: 1fr 1.3fr; gap: 18px; }
.auth-card { background: linear-gradient(180deg, var(--panel), var(--card)); border: 1px solid var(--border); border-radius: 16px; box-shadow: var(--shadow); }
.auth-card .card__head { padding: 16px 18px; border-bottom: 1px solid var(--border); display: flex; align-items: baseline; justify-content: space-between; }
.auth-card .card__body { padding: 18px; }
.auth-card h3 { font-size: 18px; }
.muted { color: var(--muted); }

.field { margin-bottom: 12px; }
.field label { display: block; font-weight: 600; margin-bottom: 6px; color: var(--text); }
.row { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.row-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 10px; }

.actions { display: flex; gap: 10px; align-items: center; }
.link { color: var(--brand); text-decoration: none; }
.link:hover { text-decoration: underline; }

/* Forms modernized */
.form_r { background: transparent !important; color: var(--text); }
.form_r table { width: 100%; border-collapse: collapse; }
.form_r td { padding: 10px 8px; vertical-align: middle; }
.form_r td:first-child { width: 32%; color: var(--muted); }

input.text, input.text_01, input.text_02, input[type="text"], input[type="password"], select { width: 100%; box-sizing: border-box; background: color-mix(in srgb, var(--card) 94%, transparent); color: var(--text); border: 1px solid var(--border); padding: 10px 12px; border-radius: 12px; outline: none; transition: border-color .15s ease, box-shadow .15s ease, transform .05s ease; }
input:focus, select:focus { border-color: var(--brand); box-shadow: 0 0 0 4px var(--ring); }
input.text_01, .text_01 { width: 100%; }
input.text_02, .text_02, select.text_02 { width: 100%; }

.button_join, .button, .btn-primary { appearance: none; background: linear-gradient(180deg, var(--brand), color-mix(in srgb, var(--brand) 76%, #000)); color: #fff; font-weight: 600; border: 1px solid rgba(0,0,0,.2); padding: 12px 18px; border-radius: 12px; cursor: pointer; box-shadow: 0 10px 20px rgba(74,120,255,.25), inset 0 1px 0 rgba(255,255,255,.25); transition: transform .08s ease, box-shadow .2s ease, filter .2s ease; }
.button_join:hover, .button:hover, .btn-primary:hover { filter: brightness(1.05); box-shadow: 0 14px 26px rgba(74,120,255,.45), inset 0 1px 0 rgba(255,255,255,.35); }
.button_join:active, .button:active, .btn-primary:active { transform: translateY(1px); box-shadow: 0 8px 16px rgba(74,120,255,.35); }
.btn-primary[disabled] { opacity: .7; cursor: not-allowed; }

.red_r { color: var(--danger); }

/* Alerts and inline messages */
.error_login, .error_login_join { display: inline-block; background: rgba(255,107,107,.12); color: #fecaca; border: 1px solid rgba(255,107,107,.35); padding: 10px 12px; border-radius: 10px; margin: 8px 0; }
.field .error-msg { display:block; margin-top:6px; font-size:12px; color: #ef9a9a; }
input.input-error, select.input-error { border-color: rgba(239, 68, 68, .8) !important; box-shadow: 0 0 0 4px rgba(239,68,68,.15) !important; }

/* Footer spacing from legacy footer include */
#footer_r { margin-top: 26px; }

/* Theme toggle */
.theme-toggle { appearance: none; border: 1px solid var(--border); background: linear-gradient(180deg, var(--panel), var(--card)); color: var(--text); padding: 8px 10px; border-radius: 10px; cursor: pointer; box-shadow: var(--shadow); display: inline-flex; align-items: center; gap: 8px; }
.theme-toggle:hover { filter: brightness(1.02); }
.theme-toggle .icon { font-size: 16px; line-height: 1; }
.theme-toggle .label { font-size: 13px; color: var(--muted); }

/* Responsive tweaks */
@media (max-width: 980px) {
  .menu-toggle { display: inline-flex; }
  .site-nav { margin-left: 0; }
  .site-nav .menu_r, .site-nav .nav_r { display: none; }
  .site-nav[data-open="true"] .menu_r, .site-nav[data-open="true"] .nav_r {
    display: flex;
    flex-direction: column;
    gap: 8px;
    position: static;
    background: transparent;
    border: 0;
    box-shadow: none;
    width: 100%;
    padding: 8px 0 0 0;
  }
  .nav_r li a { width: 100%; }
  .partner-hero { grid-template-columns: 1fr; }
  .partner-grid { grid-template-columns: 1fr; }
  .form_r td { display: block; width: 100%; padding: 6px 2px; }
  .form_r td:first-child { width: 100%; padding-top: 10px; padding-bottom: 4px; }
  .button_join, .button, .btn-primary { width: 20%; }
}

/* FAQ styles */
.faq-card { margin-top: 20px; }
.faq-list { display: grid; gap: 10px; margin-top: 20px; }
.faq-list details.faq { background: linear-gradient(180deg, var(--panel), var(--card)); border: 1px solid var(--border); border-radius: 12px; box-shadow: var(--shadow); overflow: hidden; }
.faq-list details.faq[open] { border-color: color-mix(in srgb, var(--brand) 35%, var(--border)); }
.faq-list summary { list-style: none; cursor: pointer; padding: 14px 16px; font-weight: 600; color: var(--text); position: relative; }
.faq-list summary::-webkit-details-marker { display: none; }
.faq-list summary::after { content: '\25BC'; position: absolute; right: 14px; top: 14px; font-size: 12px; opacity: .6; transition: transform .2s ease; }
.faq-list details[open] summary::after { transform: rotate(180deg); }
.faq__a { padding: 0 16px 16px 16px; color: var(--muted); }

/* Contact card tweaks */
.contact-card { margin-top: 20px; }
.contact-card .card__body .actions .button { background: linear-gradient(180deg, var(--panel), var(--card)); color: var(--text); }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.form-grid .field { margin-bottom: 0; }
.field--full { grid-column: 1 / -1; }
.field .help { margin-top: 6px; font-size: 12px; color: var(--muted); }
textarea.text { min-height: 140px; min-width: 100%; resize: both; line-height: 1.4; }
.alert { margin-bottom: 12px; padding: 10px 12px; border-radius: 10px; border: 1px solid var(--border); background: color-mix(in srgb, var(--danger) 8%, transparent); color: var(--text); }
.contact-card .alert:empty { display: none; }
.captcha-wrap { display: grid; grid-template-columns: auto 1fr; gap: 14px; align-items: start; }
.captcha-media { display: grid; gap: 8px; justify-items: start; }
.img_captcha { width: 200px; height: auto; border: 1px solid var(--border); border-radius: 8px; cursor: pointer; box-shadow: var(--shadow); }
.captcha-refresh { background: linear-gradient(180deg, var(--panel), var(--card)); color: var(--text); }
.captcha-entry { display: grid; gap: 6px; align-content: start; }
.captcha-line { display: flex; gap: 8px; align-items: center; }
.captcha-input { width: 150px!important; }

@media (max-width: 720px) {
  .form-grid { grid-template-columns: 1fr; }
  .captcha-wrap { grid-template-columns: 1fr; }
  .captcha-line { flex-wrap: wrap; }
}

/* Contact message box width */
#comment { width: 250px; max-width: 100%; }

/* Global responsive helpers */
img { max-width: 100%; height: auto; }

/* Make tables inside cards scroll on small screens */
.card__body { overflow-x: auto; }
.card__body table.modern { min-width: 600px; border-collapse: collapse; }
.card__body table.modern th, .card__body table.modern td { text-align: left; padding: 8px 10px; border-bottom: 1px solid var(--border); }
