/* ============================================
   TradeMaster FX — Forex/CFD Broker Platform
   Unique broker aesthetic (eToro/IC Markets style)
   Accent: Gold/Amber #F59E0B
   Fonts: Outfit + Source Sans 3
   ============================================ */

@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@400;500;600;700;800;900&family=Source+Sans+3:wght@300;400;500;600;700&display=swap');

:root{
  --gold:#F59E0B;
  --gold-hover:#EAB308;
  --gold-dim:rgba(245,158,11,.1);
  --gold-glow:rgba(245,158,11,.2);
  --profit:#22C55E;
  --loss:#EF4444;
  --profit-bg:rgba(34,197,94,.08);
  --loss-bg:rgba(239,68,68,.08);
  --blue:#3B82F6;
  --cyan:#06B6D4;

  --bg:#0F1117;
  --surface:#161921;
  --raised:#1D2028;
  --muted:#262A34;
  --border:#2A2E38;
  --border-light:#333842;

  --t1:#F0F1F3;
  --t2:#9DA3AE;
  --t3:#5C6370;
  --t4:#3C4150;
}

[data-theme="light"]{
  --bg:#F9FAFB;--surface:#FFFFFF;--raised:#F3F4F6;--muted:#E5E7EB;
  --border:#D1D5DB;--border-light:#E5E7EB;
  --t1:#111827;--t2:#6B7280;--t3:#9CA3AF;--t4:#D1D5DB;
  --gold:#D97706;--gold-hover:#B45309;
  --gold-dim:rgba(217,119,6,.08);--gold-glow:rgba(217,119,6,.12);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:15px;scroll-behavior:smooth}
body{font-family:'Source Sans 3',sans-serif;background:var(--bg);color:var(--t1);line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4,h5,h6{font-family:'Outfit',sans-serif;font-weight:700;color:var(--t1);line-height:1.2}
a{color:var(--gold);text-decoration:none;transition:color .15s}
a:hover{color:var(--gold-hover)}
ul{list-style:none}
button,input,select,textarea{font-family:'Source Sans 3',sans-serif;border:none;outline:none}

/* === DEMO BANNER === */
.demo-banner{
  background:linear-gradient(90deg,#92400E,var(--gold),#92400E);
  color:#000;text-align:center;padding:7px 12px;font-size:12px;font-weight:600;
}
.demo-banner a{color:#000;text-decoration:underline}

/* === NAVBAR (Transparent hero nav + solid on scroll) === */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:0 32px;height:60px;
  display:flex;align-items:center;justify-content:space-between;
  background:rgba(15,17,23,.85);backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(255,255,255,.06);
  transition:background .3s;
}
.nav.scrolled{background:var(--surface);border-bottom-color:var(--border)}
.nav-logo{
  display:flex;align-items:center;gap:10px;
  font-family:'Outfit',sans-serif;font-weight:800;font-size:18px;
}
.nav-logo svg{width:32px;height:32px}
.nav-logo .tm{color:var(--gold)}
.nav-logo .fx{color:var(--t1)}
.nav-links{display:flex;align-items:center;gap:28px}
.nav-links a{
  font-size:14px;font-weight:500;color:var(--t2);
  transition:color .15s;position:relative;
}
.nav-links a:hover,.nav-links a.active{color:var(--t1)}
.nav-links a.active::after{
  content:'';position:absolute;bottom:-2px;left:0;right:0;
  height:2px;background:var(--gold);border-radius:1px;
}
.nav-right{display:flex;align-items:center;gap:10px}
.nav-theme{
  width:34px;height:34px;border-radius:8px;background:var(--muted);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;color:var(--t2);font-size:13px;border:none;
  transition:all .15s;
}
.nav-theme:hover{background:var(--border);color:var(--t1)}

/* Hamburger */
.hamburger{display:none;flex-direction:column;gap:4px;cursor:pointer;padding:4px;background:none}
.hamburger span{width:20px;height:2px;background:var(--t1);border-radius:1px;transition:all .3s}
.hamburger.active span:nth-child(1){transform:rotate(45deg) translate(4px,4px)}
.hamburger.active span:nth-child(2){opacity:0}
.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(4px,-4px)}

/* === BUTTONS === */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  padding:10px 22px;border-radius:8px;font-weight:600;font-size:14px;
  cursor:pointer;transition:all .2s;border:none;font-family:'Outfit',sans-serif;
}
.btn:active{transform:scale(.97)}
.btn-gold{background:var(--gold);color:#000;box-shadow:0 4px 16px var(--gold-glow)}
.btn-gold:hover{background:var(--gold-hover);color:#000;transform:translateY(-1px)}
.btn-outline{background:transparent;color:var(--gold);border:1.5px solid var(--gold)}
.btn-outline:hover{background:var(--gold);color:#000}
.btn-dark{background:var(--raised);color:var(--t1);border:1px solid var(--border)}
.btn-dark:hover{background:var(--muted)}
.btn-profit{background:var(--profit);color:#fff}
.btn-loss{background:var(--loss);color:#fff}
.btn-sm{padding:7px 14px;font-size:12px;border-radius:6px}
.btn-lg{padding:14px 28px;font-size:16px;border-radius:10px}
.btn-block{width:100%}

/* === HERO (Full-width with gradient mesh bg) === */
.hero{
  position:relative;padding:140px 0 80px;overflow:hidden;
  background:linear-gradient(135deg,var(--bg) 0%,#1a1520 50%,var(--bg) 100%);
}
.hero::before{
  content:'';position:absolute;top:-20%;right:-10%;
  width:600px;height:600px;border-radius:50%;
  background:radial-gradient(circle,rgba(245,158,11,.08),transparent 70%);
}
.hero::after{
  content:'';position:absolute;bottom:-30%;left:-15%;
  width:500px;height:500px;border-radius:50%;
  background:radial-gradient(circle,rgba(59,130,246,.05),transparent 70%);
}
.hero-inner{max-width:1200px;margin:0 auto;padding:0 32px;position:relative;z-index:1}
.hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.hero h1{font-size:48px;font-weight:900;line-height:1.05;margin-bottom:16px;letter-spacing:-.02em}
.hero h1 span{color:var(--gold)}
.hero .sub{font-size:17px;color:var(--t2);margin-bottom:28px;line-height:1.7;max-width:460px}
.hero-ctas{display:flex;gap:12px;margin-bottom:24px}
.hero-badges{display:flex;gap:20px;font-size:13px;color:var(--t3)}
.hero-badges span{display:flex;align-items:center;gap:6px}

/* Spread ticker on hero */
.spread-ticker{
  background:var(--surface);border:1px solid var(--border);
  border-radius:12px;padding:20px;overflow:hidden;
}
.spread-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:10px 0;border-bottom:1px solid var(--border);
  font-size:13px;
}
.spread-row:last-child{border-bottom:none}
.spread-pair{font-weight:700;font-family:'Outfit',sans-serif}
.spread-val{font-family:'Outfit',monospace;font-weight:600}
.spread-spread{color:var(--gold);font-weight:600;font-size:12px}

/* === ASSET CLASSES BAR === */
.assets-bar{
  display:flex;justify-content:center;gap:40px;
  padding:32px 0;border-bottom:1px solid var(--border);
  background:var(--surface);
}
.asset-item{text-align:center;cursor:pointer;transition:all .2s}
.asset-item:hover{transform:translateY(-2px)}
.asset-icon{
  width:48px;height:48px;border-radius:12px;margin:0 auto 8px;
  display:flex;align-items:center;justify-content:center;
  background:var(--gold-dim);
}
.asset-icon svg{width:22px;height:22px}
.asset-label{font-size:12px;font-weight:600;color:var(--t2)}

/* === ACCOUNT TYPE CARDS (Broker-style comparison) === */
.acct-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.acct-card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:12px;padding:32px 24px;text-align:center;
  position:relative;transition:all .3s;
}
.acct-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(0,0,0,.3)}
.acct-card.featured{border-color:var(--gold);box-shadow:0 0 0 1px var(--gold)}
.acct-card.featured .acct-badge{
  position:absolute;top:-12px;left:50%;transform:translateX(-50%);
  background:var(--gold);color:#000;padding:3px 14px;
  border-radius:20px;font-size:11px;font-weight:700;
}
.acct-card h3{font-size:20px;margin-bottom:4px}
.acct-card .price{font-family:'Outfit',sans-serif;font-size:36px;font-weight:900;color:var(--gold);margin:16px 0}
.acct-card .price sub{font-size:14px;font-weight:400;color:var(--t3)}
.acct-card ul{text-align:left;margin:20px 0}
.acct-card ul li{padding:8px 0;border-bottom:1px solid var(--border);font-size:13px;color:var(--t2);display:flex;align-items:center;gap:8px}
.acct-card ul li:last-child{border-bottom:none}
.acct-card ul li .check{color:var(--profit);font-weight:700}

/* === COPY TRADING CARDS === */
.trader-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.trader-card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:12px;padding:20px;transition:all .25s;
}
.trader-card:hover{border-color:var(--gold);transform:translateY(-2px)}
.trader-top{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.trader-avatar{
  width:40px;height:40px;border-radius:50%;
  background:var(--gold-dim);display:flex;align-items:center;
  justify-content:center;font-weight:700;font-size:14px;color:var(--gold);
  font-family:'Outfit',sans-serif;
}
.trader-name{font-weight:700;font-size:14px}
.trader-tag{font-size:11px;color:var(--t3)}
.trader-stats{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px}
.trader-stat{text-align:center;padding:8px;background:var(--raised);border-radius:6px}
.trader-stat .val{font-family:'Outfit',sans-serif;font-weight:700;font-size:15px}
.trader-stat .lbl{font-size:10px;color:var(--t3);margin-top:2px}
.risk-badge{
  display:inline-block;padding:2px 8px;border-radius:4px;
  font-size:10px;font-weight:600;
}
.risk-low{background:var(--profit-bg);color:var(--profit)}
.risk-med{background:rgba(245,158,11,.1);color:var(--gold)}
.risk-high{background:var(--loss-bg);color:var(--loss)}

/* === SECTIONS === */
.sec{padding:64px 0}
.sec-inner{max-width:1200px;margin:0 auto;padding:0 32px}
.sec-head{text-align:center;margin-bottom:40px}
.sec-head h2{font-size:28px;margin-bottom:6px}
.sec-head p{color:var(--t2);font-size:14px;max-width:480px;margin:0 auto}

/* === DASHBOARD LAYOUT (Split pane, not sidebar) === */
.dash-wrap{max-width:1200px;margin:0 auto;padding:80px 32px 48px}
.dash-header{margin-bottom:24px}
.dash-header h1{font-size:24px;margin-bottom:4px}
.dash-header p{color:var(--t2);font-size:14px}
.dash-grid{display:grid;grid-template-columns:280px 1fr;gap:20px}
.dash-side{display:flex;flex-direction:column;gap:12px}
.dash-main{display:flex;flex-direction:column;gap:16px}

/* Stat cards */
.stat-card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:10px;padding:18px;
}
.stat-card .label{font-size:12px;color:var(--t3);margin-bottom:4px}
.stat-card .value{font-family:'Outfit',sans-serif;font-size:22px;font-weight:800}
.stat-card .sub{font-size:12px;margin-top:4px}

/* === PANEL === */
.panel{background:var(--surface);border:1px solid var(--border);border-radius:10px;overflow:hidden}
.panel-head{padding:14px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.panel-head h3{font-size:15px}
.panel-body{padding:18px}

/* === FORMS === */
.fg{margin-bottom:12px}
.fl{display:block;font-size:12px;font-weight:600;color:var(--t3);margin-bottom:4px}
.fi{
  width:100%;padding:10px 14px;background:var(--raised);
  border:1px solid var(--border);border-radius:6px;
  color:var(--t1);font-size:14px;transition:border-color .15s;
}
.fi:focus{border-color:var(--gold)}
.fi::placeholder{color:var(--t4)}
select.fi{cursor:pointer}

/* === TABLES === */
.tbl{width:100%;border-collapse:collapse}
.tbl thead{background:var(--raised)}
.tbl th{text-align:left;padding:10px 14px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--t3);white-space:nowrap}
.tbl td{padding:10px 14px;font-size:13px;border-bottom:1px solid var(--border)}
.tbl tr:last-child td{border-bottom:none}
.tbl tr:hover td{background:var(--raised)}
.r{text-align:right}
.mono{font-family:'Outfit',monospace}

/* === TABS (Pill style for broker) === */
.tabs{display:flex;gap:4px;margin-bottom:16px;background:var(--raised);padding:3px;border-radius:8px;overflow-x:auto}
.tab{
  padding:8px 16px;border-radius:6px;font-size:13px;font-weight:600;
  color:var(--t3);cursor:pointer;background:none;border:none;
  transition:all .15s;white-space:nowrap;font-family:'Outfit',sans-serif;
}
.tab:hover{color:var(--t2)}
.tab.on{background:var(--surface);color:var(--gold);box-shadow:0 1px 4px rgba(0,0,0,.2)}

/* === BADGES === */
.tag{display:inline-block;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600}
.tag-green{background:var(--profit-bg);color:var(--profit)}
.tag-red{background:var(--loss-bg);color:var(--loss)}
.tag-gold{background:var(--gold-dim);color:var(--gold)}
.tag-dim{background:var(--muted);color:var(--t3)}
.tag-blue{background:rgba(59,130,246,.1);color:var(--blue)}

/* === TOGGLE === */
.sw{width:38px;height:20px;border-radius:10px;background:var(--muted);cursor:pointer;position:relative;transition:background .2s}
.sw.on{background:var(--gold)}
.sw::after{content:'';position:absolute;width:16px;height:16px;background:#fff;border-radius:50%;top:2px;left:2px;transition:transform .2s}
.sw.on::after{transform:translateX(18px)}

/* === SETTINGS ROW === */
.s-row{display:flex;align-items:center;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--border)}
.s-row:last-child{border-bottom:none}
.s-left{display:flex;align-items:center;gap:10px}
.s-ico{width:34px;height:34px;border-radius:8px;background:var(--gold-dim);display:flex;align-items:center;justify-content:center;font-size:14px}
.s-info h4{font-size:13px;font-weight:600}.s-info p{font-size:11px;color:var(--t3)}

/* === TESTIMONIALS === */
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.testi-card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:10px;padding:20px;
}
.testi-stars{color:var(--gold);font-size:14px;margin-bottom:8px;letter-spacing:2px}
.testi-text{font-size:13px;color:var(--t2);line-height:1.6;margin-bottom:12px;font-style:italic}
.testi-author{font-weight:700;font-size:13px}
.testi-role{font-size:11px;color:var(--t3)}

/* === ECONOMIC CALENDAR === */
.cal-item{
  display:flex;align-items:center;gap:14px;
  padding:12px 0;border-bottom:1px solid var(--border);
}
.cal-item:last-child{border-bottom:none}
.cal-date{text-align:center;min-width:48px}
.cal-date .day{font-family:'Outfit',sans-serif;font-size:18px;font-weight:800}
.cal-date .month{font-size:10px;color:var(--t3);text-transform:uppercase}
.cal-info h4{font-size:13px;font-weight:600}
.cal-info p{font-size:11px;color:var(--t3)}
.cal-impact{width:8px;height:8px;border-radius:50%;margin-left:auto;flex-shrink:0}
.cal-impact.high{background:var(--loss)}.cal-impact.med{background:var(--gold)}.cal-impact.low{background:var(--profit)}

/* === DEPOSIT METHODS === */
.method-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.method-card{
  background:var(--raised);border:1px solid var(--border);
  border-radius:8px;padding:16px;text-align:center;
  cursor:pointer;transition:all .2s;
}
.method-card:hover{border-color:var(--gold);background:var(--surface)}
.method-card .ico{font-size:24px;margin-bottom:6px}
.method-card .name{font-size:12px;font-weight:600}
.method-card .sub{font-size:10px;color:var(--t3)}

/* === EDUCATION CARDS === */
.edu-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.edu-card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:10px;overflow:hidden;transition:all .25s;
}
.edu-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.2)}
.edu-thumb{height:140px;background:var(--raised);display:flex;align-items:center;justify-content:center;font-size:28px}
.edu-body{padding:16px}
.edu-body h4{font-size:14px;margin-bottom:4px}
.edu-body p{font-size:12px;color:var(--t2);line-height:1.5}
.edu-meta{display:flex;gap:8px;margin-top:8px}

/* === ACCORDION === */
.acc-item{border:1px solid var(--border);border-radius:8px;margin-bottom:8px;overflow:hidden}
.acc-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 18px;cursor:pointer;font-weight:600;font-size:14px;
  background:var(--surface);transition:background .15s;
}
.acc-head:hover{background:var(--raised)}
.acc-arrow{transition:transform .3s;font-size:12px;color:var(--t3)}
.acc-item.open .acc-arrow{transform:rotate(180deg)}
.acc-body{max-height:0;overflow:hidden;transition:max-height .3s,padding .3s;padding:0 18px}
.acc-item.open .acc-body{max-height:400px;padding:0 18px 14px}
.acc-body p{font-size:13px;color:var(--t2);line-height:1.6}

/* === PROGRESS BAR === */
.prog{width:100%;height:6px;background:var(--muted);border-radius:6px;overflow:hidden;margin:6px 0}
.prog-fill{height:100%;background:linear-gradient(90deg,var(--gold),var(--gold-hover));border-radius:6px;width:0;transition:width 1.2s ease}

/* === ALERT === */
.alert{display:none;padding:10px 14px;border-radius:6px;font-size:13px;font-weight:600;background:var(--profit-bg);border:1px solid rgba(34,197,94,.2);color:var(--profit);align-items:center;gap:6px}
.alert.show{display:flex}

/* === MODAL === */
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.6);display:none;align-items:center;justify-content:center;z-index:200}
.modal-bg.show{display:flex}
.modal-box{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:24px;max-width:420px;width:92%;max-height:85vh;overflow-y:auto}
.modal-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.modal-x{width:28px;height:28px;border-radius:6px;background:var(--raised);color:var(--t3);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}
.modal-x:hover{background:var(--loss);color:#fff}

/* === FOOTER (Broker-style with regulated notices) === */
.foot{background:var(--surface);border-top:1px solid var(--border);padding:48px 0 20px}
.foot-inner{max-width:1200px;margin:0 auto;padding:0 32px}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:32px;margin-bottom:32px}
.foot-brand{font-family:'Outfit',sans-serif;font-weight:800;font-size:18px;margin-bottom:10px;display:flex;align-items:center;gap:8px}
.foot-brand .tm{color:var(--gold)}.foot-brand .fx{color:var(--t1)}
.foot-desc{font-size:12px;color:var(--t3);max-width:280px;line-height:1.7}
.foot h4{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--t3);margin-bottom:10px}
.foot-links li{margin-bottom:5px}.foot-links a{font-size:13px;color:var(--t2)}.foot-links a:hover{color:var(--gold)}
.foot-bar{border-top:1px solid var(--border);padding-top:16px;display:flex;justify-content:space-between;align-items:center}
.foot-bar p{font-size:11px;color:var(--t4)}
.foot-socials{display:flex;gap:6px}
.foot-socials a{width:30px;height:30px;border-radius:6px;background:var(--raised);display:flex;align-items:center;justify-content:center;color:var(--t3);font-size:11px;transition:all .15s}
.foot-socials a:hover{color:var(--gold);background:var(--muted)}
.foot-risk{margin-top:12px;padding:12px 16px;background:var(--raised);border-radius:6px;font-size:10px;color:var(--t3);line-height:1.6}

/* === RESPONSIVE === */
@media(max-width:1024px){
  .hero-grid{grid-template-columns:1fr;gap:32px}
  .hero h1{font-size:36px}
  .acct-grid{grid-template-columns:1fr}
  .trader-grid{grid-template-columns:1fr 1fr}
  .dash-grid{grid-template-columns:1fr}
  .testi-grid{grid-template-columns:1fr}
  .edu-grid{grid-template-columns:1fr 1fr}
  .method-grid{grid-template-columns:1fr 1fr}
  .assets-bar{flex-wrap:wrap;gap:20px;padding:24px 32px}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  .nav-links{
    display:none;position:fixed;top:60px;left:0;right:0;
    background:var(--surface);flex-direction:column;
    padding:12px 0;border-bottom:1px solid var(--border);
    box-shadow:0 8px 24px rgba(0,0,0,.3);
  }
  .nav-links.open{display:flex}
  .nav-links a{padding:10px 32px}
  .hamburger{display:flex}
  .hero{padding:100px 0 48px}
  .hero h1{font-size:28px}
  .hero-ctas{flex-direction:column}
  .hero-inner,.sec-inner,.dash-wrap,.foot-inner{padding-left:16px;padding-right:16px}
  .nav{padding:0 16px}
  .acct-grid,.trader-grid,.testi-grid,.edu-grid{grid-template-columns:1fr}
  .method-grid{grid-template-columns:1fr 1fr}
  .foot-grid{grid-template-columns:1fr;gap:20px}
  .dash-wrap{padding-top:72px}
  .spread-ticker{display:none}
}
@media(max-width:480px){
  .hero h1{font-size:24px}
  .nav{height:52px}
  .assets-bar{gap:16px}
}

/* Utils */
.center{text-align:center}.right{text-align:right}
.mt-1{margin-top:8px}.mt-2{margin-top:16px}.mt-3{margin-top:24px}
.mb-1{margin-bottom:8px}.mb-2{margin-bottom:16px}.mb-3{margin-bottom:24px}
.hidden{display:none!important}
.grid{display:grid;gap:14px}.grid-2{grid-template-columns:1fr 1fr}.grid-3{grid-template-columns:1fr 1fr 1fr}
.flex-between{display:flex;align-items:center;justify-content:space-between}
.green{color:var(--profit)}.red{color:var(--loss)}.gold{color:var(--gold)}
.anim{opacity:0;transform:translateY(12px);transition:opacity .5s,transform .5s}
.anim.in{opacity:1;transform:translateY(0)}
