:root{
  --green:#234569;
  --green-strong:#1a3455;
  --bg:#E0E8ED;
  --accent:#00BCD4;
  --cta:#FF9800;
  --text:#212121;
  --muted:#6B7280;
  --card:#FFFFFF;
  --shadow:0 10px 30px rgba(0,0,0,0.08);
  --radius:16px;
  
  /* Dark mode colors (will be used when [data-theme="dark"] is set) */
  --bg-dark:#121212;
  --card-dark:#1E1E1E;
  --input-bg-dark:#2A2A2A;
  --text-dark:#B8B8B8;
  --muted-dark:#808080;
  --shadow-dark:0 10px 30px rgba(0,0,0,0.3);
  --border-dark:rgba(255,255,255,0.1);
}

[data-theme="dark"]{
  --bg:var(--bg-dark);
  --card:var(--card-dark);
  --text:var(--text-dark);
  --muted:var(--muted-dark);
  --shadow:var(--shadow-dark);
  --green:#6A8BAD;
  --green-strong:#5A7B9D;
  --cta:#6A8BAD;
  --button-bg-dark:rgba(106,139,173,.15);
  --button-text-dark:#9BB5D5;
  --button-hover-dark:rgba(106,139,173,.25);
}

[data-theme="dark"] body{
  background:var(--bg);
  color:var(--text);
}

*{box-sizing:border-box}
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial;
  color:var(--text);
  background:var(--bg);
  line-height:1.45;
  position:relative;
}
body::before{
  content:'';
  position:fixed;
  top:0;
  left:0;
  width:100%;
  height:100%;
  background-image:url('/assets/background.png');
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  opacity:0.3;
  z-index:-1;
  pointer-events:none;
}

/* Topbar */
.topbar{
  position:sticky;
  top:0;
  z-index:100;
  backdrop-filter:blur(8px);
  background:rgba(255,255,255,.85);
  border-bottom:1px solid rgba(0,0,0,.06);
  /* Prevent layout shift */
  min-height:60px;
}

[data-theme="dark"] .topbar{
  background:rgba(30,30,30,.85);
  border-bottom:1px solid var(--border-dark);
}
[data-theme="dark"] .card{
  background:rgba(30,30,30,0.85);
}
.nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:12px 24px;
  max-width:1440px;
  margin:0 auto;
  /* Prevent layout shift */
  min-height:36px;
}
.menu{display:flex;gap:12px;align-items:center}
.brand{display:inline-flex;align-items:center;gap:10px;font-weight:700;color:var(--green-strong);text-decoration:none;font-size:18px}
.brand .logo{width:28px;height:28px;border-radius:8px;display:inline-block;box-shadow:var(--shadow)}
.menu a{text-decoration:none;color:var(--text);padding:8px 10px;border-radius:10px}
.menu a.active,.menu a:hover{background:#fff;box-shadow:var(--shadow)}

[data-theme="dark"] .menu a.active,
[data-theme="dark"] .menu a:hover{
  background:var(--card);
  box-shadow:var(--shadow);
}

/* Header right section */
.header-right{display:flex;align-items:center;gap:16px}

/* Exchange rates */
.exchange-rates{
  display:flex;
  align-items:center;
  gap:12px;
  font-size:13px;
  color:var(--muted);
  min-height:20px; /* Prevent layout shift */
  min-width:140px; /* Prevent layout shift */
}
.rate-item{
  white-space:nowrap;
  font-weight:600;
  color:var(--text);
  min-width:60px; /* Prevent layout shift when value loads */
}
.rate-item .rate-value{
  margin-left:4px;
  color:var(--text);
  display:inline-block;
  min-width:40px; /* Prevent layout shift */
  text-align:right;
}
.rate-item .rate-value .rate-number{font-size:16px;font-weight:700}
.rate-item.loading{color:var(--muted)}
.rate-item.loading .rate-value{color:var(--muted)}


/* Lang */
.lang{display:flex;align-items:center;gap:8px}
.lang button{border:1px solid rgba(0,0,0,.08);background:#fff;color:var(--text);padding:8px 12px;border-radius:12px;cursor:pointer;font-weight:600}
.lang button.active{border-color:var(--green);color:#fff;background:var(--green)}

[data-theme="dark"] .lang button{
  border:1px solid var(--border-dark);
  background:var(--card);
  color:var(--text);
}

[data-theme="dark"] .lang button.active{
  border-color:var(--green);
  color:var(--button-text-dark);
  background:var(--button-bg-dark);
}

[data-theme="dark"] .lang button:hover:not(.active){
  background:var(--input-bg-dark);
}

/* Dark mode toggle button */
.btn-dark-mode{
  display:flex;
  align-items:center;
  justify-content:center;
  width:36px;
  height:36px;
  padding:0;
  border:1px solid rgba(0,0,0,.08);
  background:#fff;
  color:var(--text);
  border-radius:12px;
  cursor:pointer;
  font-weight:600;
  transition:all 0.2s;
  flex-shrink:0;
}

.btn-dark-mode:hover{
  background:#f5f5f5;
  border-color:rgba(0,0,0,.15);
}

[data-theme="dark"] .btn-dark-mode{
  border:1px solid var(--border-dark);
  background:var(--card);
  color:var(--text);
}

[data-theme="dark"] .btn-dark-mode:hover{
  background:var(--input-bg-dark);
  border-color:var(--border-dark);
}

.btn-dark-mode svg{
  width:20px;
  height:20px;
  stroke-width:2;
}

@media (max-width: 700px){
  .exchange-rates{font-size:12px;gap:8px}
  .exchange-rates .rate-item .rate-value .rate-number{font-size:14px}
  .header-right{gap:12px}
  .intro-content{
    flex-direction:column;
    align-items:center;
    text-align:center;
    gap:24px;
  }
  .intro-logo{
    order:0;
  }
  .intro-text{
    min-width:auto;
    width:100%;
    order:1;
  }
  .fire-logo{
    width:auto;
    height:140px;
  }
}

/* Layout */
.container{max-width:1440px;margin:24px auto;padding:0 24px}
.grid{display:grid;grid-template-columns:1.4fr 1fr;gap:24px}

/* Cards */
.card{background:rgba(255,255,255,0.85);border-radius:var(--radius);box-shadow:var(--shadow);padding:22px}
.card h1{
  margin:0 0 16px;
  font-size:26px;
  font-weight:800;
  color:var(--green);
  /* Prevent layout shift when i18n text loads */
  min-height:1.2em;
  line-height:1.2;
}
.card h2{
  margin:0 0 10px;
  font-size:22px;
  color:var(--green);
  /* Prevent layout shift when i18n text loads */
  min-height:1.2em;
  line-height:1.2;
}
.muted{
  color:var(--muted);
  font-size:14px;
  /* Prevent layout shift when i18n text loads */
  min-height:1.2em;
  display:inline-block;
}

/* Page H1 (outside cards) */
#page-h1{margin:0 0 24px 0;font-size:28px;font-weight:800;color:var(--green);line-height:1.2}
#calc-section > #page-h1{margin-bottom:24px}

/* Portfolio page - lighter blue for headings (except main title) */
.portfolio-form-container h2,
.portfolio-list-header h2{
  color:#4A6A8D !important;
}
[data-theme="dark"] .portfolio-form-container h2,
[data-theme="dark"] .portfolio-list-header h2{
  color:#6A8BAD !important;
}

/* Intro text card */
.intro-card{
  margin-bottom:24px;
  /* Prevent layout shift when i18n text loads */
  min-height:180px;
}
.intro-content{
  display:flex;
  align-items:stretch;
  gap:32px;
  flex-wrap:wrap;
}
.intro-logo{
  flex-shrink:0;
  display:flex;
  align-items:center;
  justify-content:center;
  order:-1;
}
.fire-logo{
  width:auto !important;
  height:180px !important;
  max-width:none !important;
  object-fit:contain;
  opacity:0.9;
  transition:opacity 0.3s ease;
}
.fire-logo:hover{
  opacity:1;
}
[data-theme="dark"] .fire-logo{
  opacity:1;
  filter:brightness(1.5);
}
[data-theme="dark"] .fire-logo:hover{
  opacity:1;
  filter:brightness(1.6);
}
.intro-text{
  flex:1;
  min-width:300px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.intro-paragraph{
  margin:0 0 16px;
  font-size:16px;
  line-height:1.7;
  color:var(--text);
  /* Prevent layout shift - reserve space for text */
  min-height:1.7em;
}
.intro-paragraph:last-child{
  margin-bottom:0;
}

/* Guide card */
.guide-card{
  margin-top:24px;
}
.guide-card h2{
  margin:0 0 16px;
  font-size:22px;
  font-weight:800;
  color:var(--green);
}
.guide-intro{
  margin:0 0 24px;
  font-size:16px;
  line-height:1.7;
  color:var(--text);
}
.guide-steps{
  display:flex;
  flex-direction:column;
  gap:20px;
  margin-bottom:24px;
}
.guide-step{
  padding:0;
}
.guide-step-title{
  margin:0 0 8px;
  font-size:16px;
  font-weight:700;
  color:var(--green);
}
.guide-step-text{
  margin:0;
  font-size:15px;
  line-height:1.6;
  color:var(--text);
}
.guide-conclusion{
  margin:0 0 12px;
  font-size:15px;
  line-height:1.7;
  color:var(--text);
}
.guide-conclusion:last-child{
  margin-bottom:0;
}

/* Share section */
.share-section{
  margin-top:20px;
  padding-top:20px;
  border-top:1px solid rgba(0,0,0,.1);
  display:flex;
  justify-content:flex-end;
  gap:12px;
}

[data-theme="dark"] .share-section{
  border-top:1px solid var(--border-dark);
}
.btn-share{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:10px 16px;
  font-size:14px;
  font-weight:600;
  border-radius:8px;
  border:1px solid rgba(0,0,0,.15);
  background-color:#fff;
  color:var(--green-strong);
  cursor:pointer;
  transition:all 0.2s;
  text-decoration:none;
}
.btn-share:hover{
  background-color:#f5f5f5;
  border-color:rgba(0,0,0,.25);
  transform:translateY(-1px);
  box-shadow:0 2px 8px rgba(0,0,0,.1);
}

[data-theme="dark"] .btn-share{
  border:1px solid var(--border-dark);
  background-color:var(--card);
  color:var(--green);
}

[data-theme="dark"] .btn-share:hover{
  background-color:var(--input-bg-dark);
  border-color:var(--border-dark);
  color:var(--green-strong);
}
.btn-share:active{
  transform:translateY(0);
  background-color:#eeeeee;
}
.btn-share svg{
  flex-shrink:0;
  stroke-width:2.5;
}
.btn-share:disabled{
  opacity:0.6;
  cursor:not-allowed;
}
.btn-share:disabled:hover{
  transform:none;
  box-shadow:none;
}

/* Form */
.field{margin-bottom:16px}

.input-with-button {
  display: flex;
  align-items: center;
  gap: 8px;
}

.input-with-button .amount {
  flex: 1;
}

.btn-portfolio-load {
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--green);
  color: white;
  border: none;
  border-radius: 8px;
  cursor: pointer;
  transition: all 0.2s;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

.btn-portfolio-load:hover {
  background: var(--green-strong);
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.15);
  transform: translateY(-1px);
}

[data-theme="dark"] .btn-portfolio-load {
  background: var(--button-bg-dark);
  color: var(--button-text-dark);
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.3);
}

[data-theme="dark"] .btn-portfolio-load:hover {
  background: var(--button-hover-dark);
  box-shadow: 0 4px 8px rgba(107, 165, 220, .15);
}

.btn-portfolio-load:active {
  transform: translateY(0);
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

.btn-portfolio-load svg {
  width: 18px;
  height: 18px;
}
.label{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap}
.label label{font-weight:700;color:var(--green)}
.hint{color:var(--muted);font-weight:400;font-size:12px}
input[type=number], input[type=text]{width:100%;padding:12px 14px;border:1px solid rgba(0,0,0,.12);border-radius:12px;background:#fff;outline:none;color:var(--text)}
input[type=number]:focus, input[type=text]:focus{border-color:var(--green);box-shadow:0 0 0 3px rgba(35,69,105,.15)}

[data-theme="dark"] input[type=number],
[data-theme="dark"] input[type=text]{
  border:1px solid var(--border-dark);
  background:var(--input-bg-dark);
  color:var(--text);
}

[data-theme="dark"] input[type=number]:focus,
[data-theme="dark"] input[type=text]:focus{
  border-color:var(--green);
  box-shadow:0 0 0 3px rgba(35,69,105,.2);
  background:var(--input-bg-dark);
}

.row{display:grid;grid-template-columns:1fr 1fr;gap:16px}

.actions{display:flex;gap:12px;align-items:center;margin-top:10px;flex-wrap:wrap}
.btn{border:none;cursor:pointer;padding:8px 16px;border-radius:12px;font-weight:700;font-size:14px;height:36px;display:inline-flex;align-items:center;justify-content:center;white-space:nowrap}
.btn-cta{background:var(--cta);color:#fff}

[data-theme="dark"] .btn-cta{
  background:var(--button-bg-dark);
  color:var(--button-text-dark);
}

[data-theme="dark"] .btn-cta:hover{
  background:var(--button-hover-dark);
}
.btn-ghost{background:#fff;color:var(--text);border:1px solid rgba(0,0,0,.08)}

[data-theme="dark"] .btn-ghost{
  background:var(--card);
  color:var(--text);
  border:1px solid var(--border-dark);
}

[data-theme="dark"] .btn-ghost:hover{
  background:var(--input-bg-dark);
}

/* Results */
.kpi-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.kpi{background:rgba(255,255,255,0.85);border:1px solid rgba(0,0,0,.06);border-radius:14px;padding:16px}

[data-theme="dark"] .kpi{
  background:rgba(30,30,30,0.85);
  border:1px solid var(--border-dark);
}
.kpi .title{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.04em}
.kpi .value{font-size:24px;font-weight:800;color:var(--green)}
.kpi .sub{color:var(--muted);font-size:12px;margin-top:4px}

.progress{height:10px;background:#BBDEFB;border-radius:999px;overflow:hidden;margin-top:10px}

[data-theme="dark"] .progress{
  background:rgba(35,69,105,.2);
}
.progress>div{height:100%;width:0;background:linear-gradient(90deg,var(--green),var(--accent))}

.note{margin-top:12px;font-size:12px;color:var(--muted)}
footer{text-align:center;padding:30px 10px;color:var(--muted)}

/* FAQ */
.faq-content{margin-top:24px}
.faq-item{margin-bottom:28px;padding-bottom:28px;border-bottom:1px solid rgba(0,0,0,.08)}
.faq-item:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}
.faq-question{font-size:18px;font-weight:700;color:var(--green);margin:0 0 12px 0}
.faq-answer{color:var(--text);line-height:1.6}
.faq-answer p{margin:0 0 12px 0}
.faq-answer p:last-child{margin-bottom:0}
.faq-answer ul{margin:12px 0;padding-left:24px}
.faq-answer li{margin-bottom:8px;line-height:1.6}
.faq-answer li:last-child{margin-bottom:0}
.faq-formula{background:#f5f5f5;padding:12px 16px;border-radius:8px;font-family:monospace;font-size:14px;color:var(--green);font-weight:600;margin:8px 0!important;border-left:3px solid var(--green)}
.faq-answer strong{color:var(--green);font-weight:700}

@media (max-width: 1000px){
  .grid{grid-template-columns:1fr}
  .kpi-grid{grid-template-columns:1fr}
  .row{grid-template-columns:1fr}
}
/* --- Label layout tweak: one-line on desktop, stack on mobile --- */
.label{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:baseline;gap:12px;flex-wrap:unset}
.label label{font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--green)}
.hint{white-space:nowrap}
@media (max-width: 700px){
  .label{grid-template-columns:1fr}
  .hint{white-space:normal}
}

/* Amount inputs: tidy numeric look */
input.amount{
  text-align:right;
  font-variant-numeric: tabular-nums;
  font-feature-settings: 'tnum' 1, 'lnum' 1;
  letter-spacing: .02em;
}

/* Range slider styles */
.slider-container{
  display: flex;
  align-items: center;
  gap: 12px;
  width: 100%;
}

input[type=range]{
  flex: 1;
  height: 8px;
  border-radius: 4px;
  background: #E0E0E0;
  outline: none;
  -webkit-appearance: none;
  appearance: none;
}

[data-theme="dark"] input[type=range]{
  background: var(--input-bg-dark);
}

input[type=range]::-webkit-slider-thumb{
  -webkit-appearance: none;
  appearance: none;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: var(--green);
  cursor: pointer;
  border: 2px solid #fff;
  box-shadow: 0 2px 4px rgba(0,0,0,0.2);
  transition: all 0.2s;
}

[data-theme="dark"] input[type=range]::-webkit-slider-thumb{
  border: 2px solid var(--input-bg-dark);
  box-shadow: 0 2px 4px rgba(0,0,0,0.4);
}

input[type=range]::-webkit-slider-thumb:hover{
  background: var(--green-strong);
  transform: scale(1.1);
}

input[type=range]::-moz-range-thumb{
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: var(--green);
  cursor: pointer;
  border: 2px solid #fff;
  box-shadow: 0 2px 4px rgba(0,0,0,0.2);
  transition: all 0.2s;
}

[data-theme="dark"] input[type=range]::-moz-range-thumb{
  border: 2px solid var(--input-bg-dark);
  box-shadow: 0 2px 4px rgba(0,0,0,0.4);
}

input[type=range]::-moz-range-thumb:hover{
  background: var(--green-strong);
  transform: scale(1.1);
}

input[type=range]:focus{
  outline: none;
}

input[type=range]:focus::-webkit-slider-thumb{
  box-shadow: 0 0 0 3px rgba(35,69,105,.25);
}

input[type=range]:focus::-moz-range-thumb{
  box-shadow: 0 0 0 3px rgba(35,69,105,.25);
}

[data-theme="dark"] input[type=range]:focus::-webkit-slider-thumb{
  box-shadow: 0 0 0 3px rgba(35,69,105,.15);
}

[data-theme="dark"] input[type=range]:focus::-moz-range-thumb{
  box-shadow: 0 0 0 3px rgba(35,69,105,.15);
}

.slider-value{
  min-width: 50px;
  text-align: right;
  font-weight: 700;
  color: var(--green);
  font-size: 16px;
  font-variant-numeric: tabular-nums;
}


/* Contact form */
textarea{width:100%;padding:12px 14px;border:1px solid rgba(0,0,0,.12);border-radius:12px;background:#fff;outline:none;resize:vertical;color:var(--text)}
textarea:focus{border-color:var(--green);box-shadow:0 0 0 3px rgba(35,69,105,.15)}

[data-theme="dark"] textarea{
  border:1px solid var(--border-dark);
  background:var(--input-bg-dark);
  color:var(--text);
}

[data-theme="dark"] textarea:focus{
  border-color:var(--green);
  box-shadow:0 0 0 3px rgba(35,69,105,.15);
  background:var(--input-bg-dark);
}

/* Contact form inputs use the same styles as calculator inputs via input[type=email] */
#contact-status.success{color:#0d47a1}
#contact-status.error{color:#b71c1c}
/* reCAPTCHA v3 is invisible - no styling needed */


/* Routing visibility */
body.route-calc #calc-section{ display:block; }
body.route-calc #contact{ display:none; }
body.route-contact #calc-section{ display:none; }
body.route-contact #contact{ display:block; }

/* Email input unified styling */
input[type=email]{
  width:100%;
  padding:12px 14px;
  border:1px solid rgba(0,0,0,.12);
  border-radius:12px;
  background:#fff;
  outline:none;
  color:var(--text);
}
input[type=email]:focus{
  border-color:var(--green);
  box-shadow:0 0 0 3px rgba(35,69,105,.15);
}

[data-theme="dark"] input[type=email]{
  border:1px solid var(--border-dark);
  background:var(--input-bg-dark);
  color:var(--text);
}

[data-theme="dark"] input[type=email]:focus{
  border-color:var(--green);
  box-shadow:0 0 0 3px rgba(35,69,105,.15);
  background:var(--input-bg-dark);
}

/* Contact – Küldés gomb: ugyanaz a kék, mint az aktív nyelvválasztón */
#btn-contact-send{
  background: var(--green);
  color: #fff;
  border: 1px solid var(--green);
}
#btn-contact-send:hover{
  background: var(--green-strong);
  border-color: var(--green-strong);
}
#btn-contact-send:focus{
  outline: none;
  box-shadow: 0 0 0 3px rgba(25, 118, 210, .25); /* kék fókuszgyűrű */
}
#btn-contact-send:disabled{
  opacity: .7;
  cursor: not-allowed;
}

[data-theme="dark"] #btn-contact-send{
  background: var(--button-bg-dark);
  color: var(--button-text-dark);
  border-color: var(--green);
}

[data-theme="dark"] #btn-contact-send:hover{
  background: var(--button-hover-dark);
  border-color: var(--green);
  box-shadow: 0 2px 8px rgba(35,69,105,.15);
}

[data-theme="dark"] #btn-contact-send:focus{
  box-shadow: 0 0 0 3px rgba(35,69,105,.15);
}

/* Auth section */
.auth-section{
  display:flex;
  align-items:center;
  gap:8px;
}
.btn-auth{
  padding:8px 16px;
  border-radius:12px;
  border:none;
  cursor:pointer;
  font-weight:700;
  font-size:14px;
  transition:all 0.2s;
  white-space:nowrap;
  height:36px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  box-sizing:border-box;
  line-height:1;
}
.btn-auth-primary{
  background:var(--green);
  color:#fff;
}
.btn-auth-primary:hover:not(:disabled){
  background:var(--green-strong);
  transform:translateY(-1px);
  box-shadow:0 2px 8px rgba(35,69,105,.3);
}
.btn-auth-primary:disabled{
  background:#e0e0e0;
  color:#9e9e9e;
  cursor:not-allowed;
  opacity:1;
}

[data-theme="dark"] .btn-auth-primary{
  background:var(--button-bg-dark);
  color:var(--button-text-dark);
}

[data-theme="dark"] .btn-auth-primary:hover:not(:disabled){
  background:var(--button-hover-dark);
  box-shadow:0 2px 8px rgba(35,69,105,.15);
}
[data-theme="dark"] .btn-auth-primary:disabled{
  background:#424242;
  color:#757575;
  cursor:not-allowed;
  opacity:1;
}
.btn-auth-secondary{
  background:#fff;
  color:var(--text);
  border:1px solid rgba(0,0,0,.15);
  padding:6px 12px;
  font-size:13px;
}
.btn-auth-secondary:hover{
  background:#f5f5f5;
  border-color:rgba(0,0,0,.25);
}

[data-theme="dark"] .btn-auth-secondary{
  background:var(--card);
  border:1px solid var(--border-dark);
}

[data-theme="dark"] .btn-auth-secondary:hover{
  background:var(--input-bg-dark);
}
.auth-user{
  display:flex;
  align-items:center;
  gap:12px;
}
.auth-user-info{
  display:flex;
  align-items:center;
  gap:12px;
}
.auth-user-email{
  font-size:13px;
  color:var(--text);
  font-weight:500;
  max-width:150px;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.btn-settings{
  display:flex;
  align-items:center;
  justify-content:center;
  width:36px;
  height:36px;
  padding:0;
  border-radius:8px;
  border:none;
  background:transparent;
  color:var(--text);
  cursor:pointer;
  transition:all 0.2s;
  text-decoration:none;
}
.btn-settings:hover{
  background:var(--input-bg);
  color:var(--text);
}
.btn-settings svg{
  width:20px;
  height:20px;
  stroke-width:2;
}
[data-theme="dark"] .btn-settings{
  color:var(--text);
}
[data-theme="dark"] .btn-settings:hover{
  background:var(--input-bg-dark);
}

/* Settings Dropdown Menu */
.settings-dropdown-wrapper{
  position:relative;
  display:inline-block;
}
.settings-dropdown-menu{
  position:absolute;
  top:100%;
  right:0;
  background:var(--card);
  border:1px solid var(--border);
  border-radius:12px;
  box-shadow:0 8px 24px rgba(0,0,0,0.12);
  min-width:180px;
  padding:12px 0 8px 0;
  display:none;
  z-index:1000;
  overflow:visible;
}
.settings-dropdown-wrapper:hover .settings-dropdown-menu,
.settings-dropdown-menu:hover{
  display:block;
}
.settings-dropdown-item{
  display:block;
  padding:12px 16px;
  color:var(--text);
  text-decoration:none;
  font-size:14px;
  font-weight:500;
  transition:background 0.2s;
  cursor:pointer;
}
.settings-dropdown-item:hover{
  background:var(--input-bg);
  color:var(--text);
}
.settings-dropdown-item:first-child{
  border-top-left-radius:12px;
  border-top-right-radius:12px;
}
.settings-dropdown-item:last-child{
  border-bottom-left-radius:12px;
  border-bottom-right-radius:12px;
}
[data-theme="dark"] .settings-dropdown-menu{
  background:var(--card);
  border-color:var(--border-dark);
  box-shadow:0 8px 24px rgba(0,0,0,0.3);
}
[data-theme="dark"] .settings-dropdown-item:hover{
  background:var(--input-bg-dark);
}

/* Auth Modal */
.auth-modal{
  position:fixed;
  top:0;
  left:0;
  width:100%;
  height:100%;
  background:rgba(0,0,0,.5);
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:1000;
  backdrop-filter:blur(4px);
}
.auth-modal-content{
  background:#fff;
  border-radius:16px;
  max-width:400px;
  width:90%;
  max-height:90vh;
  overflow-y:auto;
  box-shadow:0 20px 60px rgba(0,0,0,.3);
  animation:authModalSlideIn 0.3s ease-out;
}

[data-theme="dark"] .auth-modal{
  background:rgba(0,0,0,.7);
}

[data-theme="dark"] .auth-modal-content{
  background:var(--card);
  box-shadow:0 20px 60px rgba(0,0,0,.5);
}
@keyframes authModalSlideIn{
  from{
    opacity:0;
    transform:translateY(-20px) scale(0.95);
  }
  to{
    opacity:1;
    transform:translateY(0) scale(1);
  }
}
.auth-modal-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:20px 24px;
  border-bottom:1px solid rgba(0,0,0,.1);
}

[data-theme="dark"] .auth-modal-header{
  border-bottom:1px solid var(--border-dark);
}
.auth-modal-header h2{
  margin:0;
  font-size:20px;
  font-weight:700;
  color:var(--text);
}
.auth-modal-close{
  background:none;
  border:none;
  font-size:28px;
  color:var(--muted);
  cursor:pointer;
  padding:0;
  width:32px;
  height:32px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:8px;
  transition:all 0.2s;
}
.auth-modal-close:hover{
  background:#f5f5f5;
  color:var(--text);
}

[data-theme="dark"] .auth-modal-close:hover{
  background:var(--bg);
}
.auth-modal-body{
  padding:24px;
}
.auth-tabs{
  display:flex;
  gap:8px;
  margin-bottom:24px;
  border-bottom:2px solid rgba(0,0,0,.1);
}

[data-theme="dark"] .auth-tabs{
  border-bottom:2px solid var(--border-dark);
}
.auth-tab{
  flex:1;
  padding:12px;
  background:none;
  border:none;
  border-bottom:2px solid transparent;
  cursor:pointer;
  font-weight:600;
  color:var(--muted);
  transition:all 0.2s;
  margin-bottom:-2px;
}
.auth-tab:hover{
  color:var(--text);
}
.auth-tab.active{
  color:var(--green-strong);
  border-bottom-color:var(--green);
}
.auth-form{
  display:flex;
  flex-direction:column;
  gap:16px;
}
.auth-form .field{
  display:flex;
  flex-direction:column;
  gap:8px;
}
.auth-form label{
  font-weight:600;
  font-size:14px;
  color:var(--text);
}
.auth-form input[type=email],
.auth-form input[type=password]{
  padding:12px 14px;
  border:1px solid rgba(0,0,0,.12);
  border-radius:8px;
  font-size:14px;
  transition:all 0.2s;
  width:100%;
}
.auth-form input[type=email]:focus,
.auth-form input[type=password]:focus{
  outline:none;
  border-color:var(--green);
  box-shadow:0 0 0 3px rgba(35,69,105,.15);
}

[data-theme="dark"] .auth-form input[type=email],
[data-theme="dark"] .auth-form input[type=password]{
  border:1px solid var(--border-dark);
  background:var(--input-bg-dark);
  color:var(--text);
}

[data-theme="dark"] .auth-form input[type=email]:focus,
[data-theme="dark"] .auth-form input[type=password]:focus{
  border-color:var(--green);
  box-shadow:0 0 0 3px rgba(35,69,105,.15);
  background:var(--input-bg-dark);
}

.auth-form .hint{
  font-size:12px;
  color:var(--muted);
  margin-top:-4px;
}
.btn-auth-submit{
  width:100%;
  padding:12px;
  margin-top:8px;
  background:var(--green);
  color:#fff;
  border:none;
  border-radius:8px;
  font-weight:600;
  cursor:pointer;
  transition:all 0.2s;
}
.btn-auth-submit:hover{
  background:var(--green-strong);
  transform:translateY(-1px);
  box-shadow:0 2px 8px rgba(35,69,105,.3);
}
.btn-auth-submit:disabled{
  opacity:0.6;
  cursor:not-allowed;
  transform:none !important;
}

[data-theme="dark"] .btn-auth-submit{
  background:var(--button-bg-dark);
  color:var(--button-text-dark);
}

[data-theme="dark"] .btn-auth-submit:hover{
  background:var(--button-hover-dark);
  box-shadow:0 2px 8px rgba(35,69,105,.15);
}
.auth-status{
  padding:12px;
  border-radius:8px;
  font-size:14px;
  display:none;
}
.auth-status.error{
  display:block;
  background:#ffebee;
  color:#c62828;
  border:1px solid #ef5350;
}
.auth-status.success{
  display:block;
  background:#E3F2FD;
  color:#1565c0;
  border:1px solid #1976d2;
}

/* Google Sign-In button */
.btn-auth-google{
  width:100%;
  background:#fff;
  color:#3c4043;
  border:1px solid #dadce0;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:12px;
  padding:12px;
  margin-bottom:16px;
  font-weight:500;
  transition:all 0.2s;
}
.btn-auth-google:hover{
  background:#f8f9fa;
  box-shadow:0 1px 3px rgba(0,0,0,.1);
  border-color:#dadce0;
}
.btn-auth-google:active{
  background:#f1f3f4;
}

[data-theme="dark"] .btn-auth-google{
  background:var(--card);
  color:var(--text);
  border:1px solid var(--border-dark);
}

[data-theme="dark"] .btn-auth-google:hover{
  background:var(--input-bg-dark);
  border-color:var(--border-dark);
  box-shadow:0 1px 3px rgba(0,0,0,.2);
}

[data-theme="dark"] .btn-auth-google:active{
  background:var(--bg);
}
.btn-auth-google svg{
  flex-shrink:0;
  width:18px;
  height:18px;
}

/* Auth divider */
.auth-divider{
  display:flex;
  align-items:center;
  text-align:center;
  margin:20px 0;
  color:var(--muted);
  font-size:14px;
}
.auth-divider::before,
.auth-divider::after{
  content:'';
  flex:1;
  border-bottom:1px solid rgba(0,0,0,.1);
}
.auth-divider span{
  padding:0 12px;
}

/* Portfolio Styles */
.portfolio-form-container{
  margin-top:24px;
  padding:24px;
  background:rgba(255,255,255,0.85);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}
.portfolio-form-container h2{
  margin:0 0 20px;
  font-size:20px;
  font-weight:700;
  color:var(--text);
}
.portfolio-form{
  display:flex;
  flex-direction:column;
  gap:16px;
}
.portfolio-form .field{
  display:flex;
  flex-direction:column;
  gap:8px;
}
.portfolio-form label{
  font-weight:600;
  font-size:14px;
  color:var(--green);
}
.portfolio-form input[type=text],
.portfolio-form input[type=number],
.portfolio-form input[type=date],
.portfolio-form select{
  padding:12px 14px;
  border:1px solid rgba(0,0,0,.12);
  border-radius:8px;
  font-size:14px;
  transition:all 0.2s;
  width:100%;
  font-family:inherit;
}
.portfolio-form input[type=text]:focus,
.portfolio-form input[type=number]:focus,
.portfolio-form input[type=date]:focus,
.portfolio-form select:focus{
  outline:none;
  border-color:var(--green);
  box-shadow:0 0 0 3px rgba(35,69,105,.15);
}

[data-theme="dark"] .portfolio-form-container{
  background:rgba(30,30,30,0.85);
  box-shadow:var(--shadow);
}

[data-theme="dark"] .portfolio-form input[type=text],
[data-theme="dark"] .portfolio-form input[type=number],
[data-theme="dark"] .portfolio-form input[type=date],
[data-theme="dark"] .portfolio-form select{
  border:1px solid var(--border-dark);
  background:var(--input-bg-dark);
  color:var(--text);
}

[data-theme="dark"] .portfolio-form input[type=text]:focus,
[data-theme="dark"] .portfolio-form input[type=number]:focus,
[data-theme="dark"] .portfolio-form input[type=date]:focus,
[data-theme="dark"] .portfolio-form select:focus{
  border-color:var(--green);
  box-shadow:0 0 0 3px rgba(106,139,173,.15);
  background:var(--input-bg-dark);
}

/* Date input specific styling */
.portfolio-form input[type=date] {
  color-scheme: light;
}

[data-theme="dark"] .portfolio-form input[type=date] {
  color-scheme: dark;
}

.portfolio-form-actions{
  display:flex;
  gap:12px;
  margin-top:8px;
}
.portfolio-form-actions button{
  flex:1;
}
.portfolio-status{
  padding:12px;
  border-radius:8px;
  font-size:14px;
  display:none;
  margin-top:8px;
}
.portfolio-status.error{
  display:block;
  background:#ffebee;
  color:#c62828;
  border:1px solid #ef5350;
}
.portfolio-status.success{
  display:block;
  background:#E3F2FD;
  color:#1565c0;
  border:1px solid #1976d2;
}
.portfolio-list-container{
  margin-top:24px;
}
.portfolio-list-header{
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-bottom:20px;
}
.portfolio-list-header h2{
  margin:0;
  font-size:20px;
  font-weight:700;
  color:var(--text);
}

[data-theme="dark"] .portfolio-table-header{
  background:var(--card);
  border-bottom:1px solid var(--border-dark);
}

[data-theme="dark"] .portfolio-table-header .portfolio-table-cell{
  color:var(--muted);
}

[data-theme="dark"] .portfolio-list-header h2{
  color:var(--text);
}

.portfolio-list{
  display:flex;
  flex-direction:column;
}
.portfolio-table{
  background:rgba(255,255,255,0.85);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  overflow:hidden;
  width:100%;
}

[data-theme="dark"] .portfolio-table{
  background:rgba(30,30,30,0.85);
}
.portfolio-table-header{
  display:grid;
  grid-template-columns:2.5fr 1.2fr 1.2fr 1.2fr 1fr 1.2fr 1.2fr 90px;
  gap:20px;
  padding:14px 20px;
  background:#f8f9fa;
  border-bottom:1px solid rgba(0,0,0,.12);
  font-weight:600;
  font-size:11px;
  color:#6c757d;
  text-transform:uppercase;
  letter-spacing:0.8px;
  align-items:center;
}
.portfolio-table-body{
  display:flex;
  flex-direction:column;
}
.portfolio-table-row{
  display:grid;
  grid-template-columns:2.5fr 1.2fr 1.2fr 1.2fr 1fr 1.2fr 1.2fr 90px;
  gap:20px;
  padding:16px 20px;
  border-bottom:1px solid rgba(0,0,0,.08);
  align-items:center;
  transition:background-color 0.15s ease;
  background:rgba(255,255,255,0.85);
}
.portfolio-table-row:last-child{
  border-bottom:none;
}
.portfolio-table-row:hover{
  background-color:rgba(248,249,250,0.9);
}

[data-theme="dark"] .portfolio-table-row{
  background:rgba(30,30,30,0.85);
  border-bottom:1px solid var(--border-dark);
}

[data-theme="dark"] .portfolio-table-row:hover{
  background-color:rgba(255,255,255,.05);
}
.portfolio-table-row.portfolio-item-gain{
  background-color:#f1f8f4;
}
.portfolio-table-row.portfolio-item-gain:hover{
  background-color:#e8f5e9;
}
.portfolio-table-row.portfolio-item-loss{
  background-color:#fff5f5;
}
.portfolio-table-row.portfolio-item-loss:hover{
  background-color:#ffebee;
}

[data-theme="dark"] .portfolio-table-row.portfolio-item-profit{
  background-color:#f1f8f4;
}

[data-theme="dark"] .portfolio-table-row.portfolio-item-loss{
  background-color:#fff5f5;
}

[data-theme="dark"] .portfolio-table-row.portfolio-item-profit:hover{
  background-color:#e8f5e9;
}

[data-theme="dark"] .portfolio-table-row.portfolio-item-loss:hover{
  background-color:#ffebee;
}
.portfolio-cell-current-price.portfolio-refreshing,
.portfolio-cell-gain.portfolio-refreshing,
.portfolio-cell-change.portfolio-refreshing,
.portfolio-cell-value.portfolio-refreshing,
.portfolio-cell-fire-target.portfolio-refreshing,
.portfolio-summary-total.portfolio-refreshing,
.portfolio-summary-profit-loss.portfolio-refreshing{
  filter:blur(4px);
  transition:filter 0.3s ease;
  pointer-events:none;
  user-select:none;
}
[data-theme="dark"] .portfolio-cell-current-price.portfolio-refreshing,
[data-theme="dark"] .portfolio-cell-gain.portfolio-refreshing,
[data-theme="dark"] .portfolio-cell-change.portfolio-refreshing,
[data-theme="dark"] .portfolio-cell-value.portfolio-refreshing,
[data-theme="dark"] .portfolio-cell-fire-target.portfolio-refreshing,
[data-theme="dark"] .portfolio-summary-total.portfolio-refreshing,
[data-theme="dark"] .portfolio-summary-profit-loss.portfolio-refreshing{
  filter:blur(5px);
}
.portfolio-table-cell{
  display:flex;
  align-items:center;
  font-size:14px;
  color:#212529;
  line-height:1.5;
}

[data-theme="dark"] .portfolio-table-cell{
  color:var(--text);
}
.portfolio-cell-name{
  gap:12px;
  justify-content:flex-start;
}
.portfolio-cell-purchase-price,
.portfolio-cell-current-price,
.portfolio-cell-gain,
.portfolio-cell-change,
.portfolio-cell-value,
.portfolio-cell-fire-target{
  justify-content:flex-end;
  text-align:right;
  font-weight:500;
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
}

.portfolio-cell-current-price{
  flex-direction:column;
  align-items:flex-end;
}

.portfolio-price-timestamp{
  display:block;
  margin-top:4px;
  font-size:12px;
  line-height:1.2;
  color:#6c757d;
  font-style:italic;
  font-weight:400;
}

[data-theme="dark"] .portfolio-price-timestamp{
  color:var(--muted);
}
.portfolio-sortable{
  cursor:pointer;
  user-select:none;
  position:relative;
  padding-right:20px;
  transition:background-color 0.2s;
}
.portfolio-sortable:hover{
  background-color:rgba(0,0,0,.05);
}

[data-theme="dark"] .portfolio-sortable:hover{
  background-color:rgba(255,255,255,.05);
}
.portfolio-sort-icon{
  position:absolute;
  right:4px;
  top:50%;
  transform:translateY(-50%);
  font-size:12px;
  color:#6c757d;
  margin-left:4px;
  opacity:0.6;
}
.portfolio-sortable:hover .portfolio-sort-icon{
  opacity:1;
}
.portfolio-sort-asc,
.portfolio-sort-desc{
  opacity:1;
  color:#1976d2;
  font-weight:bold;
}
.portfolio-asset-icon{
  width:44px;
  height:44px;
  border-radius:10px;
  display:flex;
  align-items:center;
  justify-content:center;
  color:#fff;
  font-weight:700;
  font-size:20px;
  flex-shrink:0;
  box-shadow:0 2px 4px rgba(0,0,0,.1);
}
.portfolio-asset-icon.has-logo{
  background:#fff;
  box-shadow:none;
  padding:0;
}
.portfolio-asset-icon.has-logo img{
  width:100%;
  height:100%;
  object-fit:contain;
  border-radius:inherit;
  display:block;
}
.portfolio-asset-icon .portfolio-asset-initial{
  display:block;
}
.portfolio-asset-icon.has-logo .portfolio-asset-initial{
  display:none;
}
.portfolio-asset-info{
  display:flex;
  flex-direction:row;
  align-items:center;
  gap:12px;
  min-width:0;
  flex:1;
}
.portfolio-asset-name{
  font-weight:600;
  font-size:14px;
  color:#212529;
  line-height:1.4;
}
.portfolio-asset-meta{
  font-size:12px;
  color:#6c757d;
  line-height:1.4;
  font-weight:400;
}

[data-theme="dark"] .portfolio-asset-name{
  color:var(--text);
}

[data-theme="dark"] .portfolio-asset-meta{
  color:var(--muted);
}
.portfolio-positive{
  color:#2e7d32;
  font-weight:600;
}
.portfolio-negative{
  color:#c62828;
  font-weight:600;
}

/* Keep green/red colors in dark mode too - use !important to override any text color */
[data-theme="dark"] .portfolio-positive,
[data-theme="dark"] .portfolio-table-cell.portfolio-positive{
  color:#2e7d32 !important;
}

[data-theme="dark"] .portfolio-negative,
[data-theme="dark"] .portfolio-table-cell.portfolio-negative{
  color:#c62828 !important;
}
.portfolio-cell-actions{
  justify-content:flex-end;
  gap:6px;
}
.portfolio-item-action{
  padding:8px;
  border:none;
  border-radius:8px;
  cursor:pointer;
  font-size:13px;
  font-weight:600;
  transition:all 0.2s;
  background:#f5f5f5;
  color:var(--text);
  display:flex;
  align-items:center;
  justify-content:center;
  min-width:32px;
  min-height:32px;
}

[data-theme="dark"] .portfolio-item-action{
  background:var(--bg);
  color:var(--text);
}
.portfolio-item-action svg{
  width:16px;
  height:16px;
  stroke-width:2;
}
.portfolio-item-action.delete:hover,
.portfolio-item-action.portfolio-item-action-delete:hover{
  background:#ffebee;
  color:#c62828;
}
.portfolio-item-action.portfolio-item-action-edit:hover{
  background:#e3f2fd;
  color:#1976d2;
}

[data-theme="dark"] .portfolio-item-action.delete:hover,
[data-theme="dark"] .portfolio-item-action.portfolio-item-action-delete:hover{
  background:rgba(198,40,40,.2);
  color:#ef5350;
}

[data-theme="dark"] .portfolio-item-action.portfolio-item-action-edit:hover{
  background:rgba(106,139,173,.2);
  color:var(--green);
}

.portfolio-summary{
  margin:0 0 32px;
  padding:32px;
  background:rgba(255,255,255,0.85);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  text-align:center;
}

[data-theme="dark"] .portfolio-summary{
  background:rgba(30,30,30,0.85);
}
.portfolio-summary-content{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:8px;
}
.portfolio-summary-header{
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-bottom:24px;
  flex-wrap:wrap;
  gap:16px;
}
.portfolio-summary-header h3{
  margin:0;
  font-size:20px;
  font-weight:600;
  color:#212529;
}

[data-theme="dark"] .portfolio-summary-header h3{
  color:var(--text);
}
.portfolio-info-box{
  margin-bottom:24px;
  padding:16px 20px;
  background:#f5f5f5;
  border-left:4px solid var(--green);
  border-radius:var(--radius);
  font-size:14px;
  line-height:1.6;
  color:var(--green);
  display:flex;
  align-items:flex-start;
  gap:12px;
}

[data-theme="dark"] .portfolio-info-box{
  background:rgba(255,255,255,0.05);
  border-left:4px solid var(--green);
  color:var(--green);
}

.portfolio-custom-info{
  margin-bottom:24px;
  padding:16px 20px;
  background:#f5f5f5;
  border-left:4px solid var(--green);
  border-radius:var(--radius);
  font-size:14px;
  line-height:1.6;
  color:var(--green);
  display:none;
  align-items:flex-start;
  gap:12px;
}

[data-theme="dark"] .portfolio-custom-info{
  background:rgba(255,255,255,0.05);
  border-left:4px solid var(--green);
  color:var(--green);
}

.portfolio-symbol-error{
  margin-bottom:24px;
  padding:16px 20px;
  background:#ffebee;
  border-left:4px solid #c62828;
  border-radius:var(--radius);
  font-size:14px;
  line-height:1.6;
  color:#c62828;
  display:none;
  align-items:flex-start;
  gap:12px;
}

[data-theme="dark"] .portfolio-symbol-error{
  background:rgba(198,40,40,0.15);
  border-left:4px solid #c62828;
  color:#ff5252;
}

.symbol-input-wrapper{
  display:flex;
  align-items:center;
  gap:8px;
}
.symbol-input-wrapper input{
  flex:1;
}
.symbol-search-button{
  width:44px;
  height:44px;
  border-radius:12px;
  border:1px solid rgba(0,0,0,.08);
  background:#fff;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:18px;
  cursor:pointer;
  transition:background .2s, border-color .2s;
}
.symbol-search-button:hover{
  background:#f5f5f5;
}
.symbol-search-button:disabled{
  opacity:0.6;
  cursor:not-allowed;
}
[data-theme="dark"] .symbol-search-button{
  border:1px solid var(--border-dark);
  background:var(--card);
  color:var(--text);
}
[data-theme="dark"] .symbol-search-button:hover:not(:disabled){
  background:var(--input-bg-dark);
}

.symbol-lookup-modal{
  position:fixed;
  top:0;
  left:0;
  width:100%;
  height:100%;
  display:none;
  align-items:center;
  justify-content:center;
  background:rgba(0,0,0,0.55);
  z-index:1000;
  padding:20px;
}
.symbol-lookup-modal-dialog{
  background:#fff;
  border-radius:20px;
  width:100%;
  max-width:520px;
  max-height:80vh;
  overflow:hidden;
  box-shadow:0 20px 60px rgba(0,0,0,0.2);
  display:flex;
  flex-direction:column;
}
.symbol-lookup-modal-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:20px 24px 0;
}
.symbol-lookup-modal-header h3{
  margin:0;
  font-size:20px;
  font-weight:600;
}
.symbol-lookup-modal-close{
  border:none;
  background:transparent;
  font-size:28px;
  cursor:pointer;
  line-height:1;
  color:#6c757d;
}
.symbol-lookup-modal-body{
  padding:16px 24px 24px;
  overflow-y:auto;
  display:flex;
  flex-direction:column;
  gap:12px;
}
.symbol-lookup-result{
  border:1px solid rgba(0,0,0,0.08);
  border-radius:16px;
  padding:16px;
  display:flex;
  align-items:center;
  gap:16px;
  cursor:pointer;
  background:#fff;
  transition:border-color .2s, box-shadow .2s;
  text-align:left;
}
.symbol-lookup-result:hover{
  border-color:var(--green);
  box-shadow:0 8px 20px rgba(0,0,0,0.08);
}
.symbol-lookup-result-logo{
  width:56px;
  height:56px;
  border-radius:14px;
  background:#f5f5f5;
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
  overflow:hidden;
  font-weight:700;
  font-size:18px;
  color:#6c757d;
}
.symbol-lookup-result-logo img{
  width:100%;
  height:100%;
  object-fit:contain;
  border-radius:inherit;
  background:#fff;
}
.symbol-lookup-result-logo span{
  font-weight:700;
  font-size:18px;
}
.symbol-lookup-result-logo.has-logo{
  background:#fff;
  border:1px solid rgba(0,0,0,0.04);
}
.symbol-lookup-result-logo.has-logo span{
  display:none;
}
.symbol-lookup-result-content{
  display:flex;
  flex-direction:column;
  gap:6px;
  flex:1;
  min-width:0;
}
.symbol-lookup-result-symbol{
  font-size:18px;
  font-weight:700;
  color:#212529;
}
.symbol-lookup-result-name{
  font-size:14px;
  color:#6c757d;
}
.symbol-lookup-result-meta{
  display:flex;
  gap:12px;
  font-weight:600;
  font-size:14px;
  color:#212529;
}
.symbol-lookup-empty,
.symbol-lookup-loading{
  text-align:center;
  padding:32px 0;
  font-size:15px;
  color:#6c757d;
}
[data-theme="dark"] .symbol-lookup-modal-dialog{
  background:var(--card);
  color:var(--text);
  border:1px solid var(--border-dark);
}
[data-theme="dark"] .symbol-lookup-result{
  background:var(--card);
  border:1px solid #B8D4F0;
  color:var(--text);
}
[data-theme="dark"] .symbol-lookup-result-logo{
  background:var(--input-bg-dark);
  color:var(--muted-text-dark);
  border:1px solid var(--border-dark);
}
[data-theme="dark"] .symbol-lookup-result-logo.has-logo{
  background:var(--card);
}
[data-theme="dark"] .symbol-lookup-result:hover{
  border-color:#B8D4F0;
  background:rgba(184,212,240,0.2);
  box-shadow:0 8px 20px rgba(0,0,0,0.25);
}
[data-theme="dark"] .symbol-lookup-result-symbol{
  color:#B8D4F0;
}
[data-theme="dark"] .symbol-lookup-result-name{
  color:var(--muted-text-dark);
}
[data-theme="dark"] .symbol-lookup-result-meta{
  color:#B8D4F0;
}
[data-theme="dark"] .symbol-lookup-modal-close{
  color:var(--muted-text-dark);
}

body.modal-open{
  overflow:hidden;
}

.portfolio-hungarian-bond-warning{
  margin-bottom:24px;
  padding:12px 16px;
  background:#ffebee;
  border-left:4px solid #c62828;
  border-radius:var(--radius);
  font-size:14px;
  line-height:1.5;
  color:#c62828;
  display:none;
}

[data-theme="dark"] .portfolio-hungarian-bond-warning{
  background:rgba(198,40,40,0.15);
  border-left:4px solid #c62828;
  color:#ff5252;
}
.portfolio-info-icon{
  font-size:20px;
  flex-shrink:0;
  line-height:1;
}
.portfolio-info-content{
  flex:1;
  display:flex;
  flex-direction:column;
  gap:4px;
}
.portfolio-info-time{
  font-weight: normal;
  margin: 0;
  font-size: 14px;
  line-height: 1.6;
}
.portfolio-info-box p{
  margin:0;
  font-weight:400;
}
.portfolio-data-notice{
  margin-bottom:24px;
  padding:16px 20px;
  background:#fff3cd;
  border-left:4px solid #ffc107;
  border-radius:var(--radius);
  font-size:14px;
  line-height:1.6;
  color:#856404;
}
.portfolio-data-notice p{
  margin:0;
}
.portfolio-last-update{
  margin-top:24px;
  padding-top:16px;
  border-top:1px solid #e0e0e0;
  text-align:center;
  font-size:13px;
  color:#6c757d;
  font-style:italic;
}
.portfolio-currency-selector{
  display:flex;
  gap:8px;
  align-items:center;
}
.portfolio-currency-btn{
  padding:8px 16px;
  border:1px solid rgba(0,0,0,.08);
  border-radius:12px;
  background:#fff;
  color:var(--text);
  font-size:14px;
  font-weight:600;
  cursor:pointer;
  transition:all 0.2s;
  font-family:inherit;
  height:36px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.portfolio-currency-btn:hover:not(.active){
  background:#f8f9fa;
}
.portfolio-currency-btn.active{
  border-color:var(--green);
  color:#fff;
  background:var(--green);
}

[data-theme="dark"] .portfolio-currency-btn{
  border:1px solid var(--border-dark);
  background:var(--card);
  color:var(--text);
}

[data-theme="dark"] .portfolio-currency-btn:hover:not(.active){
  background:var(--input-bg-dark);
}

[data-theme="dark"] .portfolio-currency-btn.active{
  border-color:var(--green);
  color:var(--button-text-dark);
  background:var(--button-bg-dark);
}

.portfolio-currency-btn[data-lang="hu"]{
  display:none;
}
.portfolio-currency-btn[data-lang="en"]{
  display:none;
}
body[data-lang="hu"] .portfolio-currency-btn[data-lang="hu"]{
  display:inline-block;
}
body[data-lang="en"] .portfolio-currency-btn[data-lang="en"]{
  display:inline-block;
}
.portfolio-summary-total-wrapper{
  display:flex;
  align-items:flex-start;
  justify-content:center;
  gap:24px;
  width:100%;
  flex-wrap:wrap;
}
.portfolio-summary-total{
  font-size:48px;
  font-weight:700;
  color:#4A6A8D;
  line-height:1.2;
  letter-spacing:-0.5px;
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
  text-align:center;
  flex:0 0 auto;
}

[data-theme="dark"] .portfolio-summary-total{
  color:#9AB5D8;
}
.portfolio-summary-currency{
  font-size:20px;
  font-weight:600;
  margin-left:8px;
  color:inherit;
}
.portfolio-summary-returns{
  display:flex;
  flex-direction:column;
  gap:8px;
  flex:0 0 auto;
  margin-top:0;
  min-width:200px;
}
.portfolio-summary-return-item{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:4px 0;
  border-bottom:1px solid rgba(0,0,0,.05);
}
.portfolio-summary-return-item:last-child{
  border-bottom:none;
}
.portfolio-summary-return-label{
  font-size:12px;
  color:#90A4C1;
  letter-spacing:0.5px;
  text-transform:uppercase;
  margin-right:12px;
  white-space:nowrap;
}
.portfolio-summary-return-value{
  font-size:18px;
  font-weight:600;
  color:#4A6A8D;
  white-space:nowrap;
}
.portfolio-summary-return-value .portfolio-summary-currency{
  font-size:14px;
  margin-left:4px;
}
[data-theme="dark"] .portfolio-summary-return-label{
  color:#7C90B0;
}
[data-theme="dark"] .portfolio-summary-return-value{
  color:#9AB5D8;
}
[data-theme="dark"] .portfolio-summary-return-item{
  border-bottom-color:rgba(255,255,255,.1);
}
@media (max-width: 768px) {
  .portfolio-summary-total-wrapper{
    flex-direction:column;
    align-items:center;
    gap:16px;
  }
  .portfolio-summary-returns{
    width:100%;
    min-width:auto;
  }
  .portfolio-summary-return-item{
    justify-content:center;
    gap:12px;
  }
}
.portfolio-summary-fire-target{
  margin-top:12px;
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:4px;
  text-align:left;
  width:100%;
}
.portfolio-summary-fire-label{
  font-size:12px;
  letter-spacing:0.6px;
  text-transform:uppercase;
  color:#90A4C1;
}
.portfolio-summary-fire-value{
  font-size:20px;
  font-weight:600;
  color:#4A6A8D;
}
.portfolio-summary-fire-note{
  font-size:12px;
  color:#6c757d;
  line-height:1.4;
}
[data-theme="dark"] .portfolio-summary-fire-note{
  color:var(--muted);
}
.portfolio-summary-fire-rate{
  color:#4A6A8D;
  font-weight:700;
}
[data-theme="dark"] .portfolio-summary-fire-rate{
  color:#9AB5D8;
}
.portfolio-summary-fire-diff{
  font-size:12px;
  color:#6c757d;
  margin-left:6px;
}
[data-theme="dark"] .portfolio-summary-fire-diff{
  color:var(--muted);
}
.portfolio-summary-fire-diff-amount{
  font-weight:600;
}
.portfolio-summary-fire-diff-currency{
  color:inherit;
  margin-left:4px;
}
[data-theme="dark"] .portfolio-summary-fire-diff{
  color:var(--muted);
}
[data-theme="dark"] .portfolio-summary-fire-value{
  color:#9AB5D8;
}
[data-theme="dark"] .portfolio-summary-fire-label{
  color:#7C90B0;
}
.portfolio-summary-profit-loss{
  font-size:18px;
  font-weight:500;
  line-height:1.4;
  margin-top:4px;
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:6px;
}
.portfolio-summary-profit-loss.positive{
  color:#28a745;
}
.portfolio-summary-profit-loss.negative{
  color:#dc3545;
}
[data-theme="dark"] .portfolio-summary-profit-loss.positive{
  color:#4caf50;
}
[data-theme="dark"] .portfolio-summary-profit-loss.negative{
  color:#f44336;
}
.portfolio-summary-profit-loss-info{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:16px;
  height:16px;
  margin-left:4px;
  cursor:help;
  opacity:0.5;
  transition:all 0.2s ease;
  color:inherit;
  vertical-align:middle;
}
.portfolio-summary-profit-loss-info:hover{
  opacity:0.9;
  transform:scale(1.1);
}
.portfolio-summary-profit-loss-info svg{
  width:100%;
  height:100%;
  display:block;
}
.portfolio-summary-profit-loss.positive .portfolio-summary-profit-loss-info{
  color:#28a745;
}
.portfolio-summary-profit-loss.negative .portfolio-summary-profit-loss-info{
  color:#dc3545;
}
[data-theme="dark"] .portfolio-summary-profit-loss.positive .portfolio-summary-profit-loss-info{
  color:#4caf50;
}
[data-theme="dark"] .portfolio-summary-profit-loss.negative .portfolio-summary-profit-loss-info{
  color:#f44336;
}
.portfolio-summary-item{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:12px 0;
  border-bottom:1px solid rgba(0,0,0,.08);
}
.portfolio-summary-item:last-child{
  border-bottom:none;
  font-weight:700;
  font-size:16px;
  color:#4A6A8D;
}

[data-theme="dark"] .portfolio-summary-item:last-child{
  color:#6A8BAD;
}
.portfolio-summary-label{
  color:var(--muted);
  font-size:14px;
}
.portfolio-summary-value{
  font-weight:600;
  color:var(--text);
  font-size:14px;
}
.portfolio-loading,
.portfolio-empty{
  text-align:center;
  padding:40px 20px;
  color:var(--muted);
  display:none; /* Hidden by default */
}
.portfolio-loading{
  display:block; /* Shown initially, will be hidden when portfolio loads */
}
.portfolio-empty p{
  margin:0 0 20px;
  font-size:16px;
}

/* Portfolio Price Section */
.portfolio-price-section{
  display:flex;
  flex-direction:column;
  gap:10px;
}
.portfolio-price-main,
.portfolio-total-main{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:8px 12px;
  align-items:start;
}
.portfolio-price-item,
.portfolio-total-item{
  display:flex;
  flex-direction:column;
  gap:2px;
}
.portfolio-total-item.highlight{
  grid-column:span 2;
  padding:8px;
  background:rgba(0,0,0,.02);
  border-radius:6px;
  border:1px solid rgba(0,0,0,.06);
}
.portfolio-price-label,
.portfolio-total-label{
  color:var(--muted);
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:0.5px;
  font-weight:600;
}
.portfolio-price-value,
.portfolio-total-value{
  font-weight:600;
  font-size:14px;
  color:var(--text);
  line-height:1.4;
}
.portfolio-price-value.purchase,
.portfolio-total-value.purchase{
  color:var(--muted);
  font-weight:500;
  font-size:13px;
}
.portfolio-price-value.current,
.portfolio-total-value.current{
  font-size:16px;
  font-weight:700;
}
.portfolio-total-item.highlight .portfolio-total-value.current{
  font-size:18px;
}
.portfolio-price-value.portfolio-gain,
.portfolio-total-value.portfolio-gain{
  color:#2e7d32;
}
.portfolio-price-value.portfolio-loss,
.portfolio-total-value.portfolio-loss{
  color:#c62828;
}
.portfolio-price-value.current.portfolio-loss,
.portfolio-total-value.current.portfolio-loss{
  color:#c62828;
}
.portfolio-change-percent{
  font-size:0.85em;
  opacity:0.85;
  margin-left:6px;
  font-weight:600;
}
.portfolio-total-item.highlight .portfolio-change-percent{
  font-size:0.9em;
}

/* Legacy support for price not available */
.portfolio-price-comparison,
.portfolio-total-comparison{
  display:flex;
  flex-direction:column;
  gap:8px;
}
.portfolio-price-row,
.portfolio-total-row{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
}
.portfolio-price-value.loading{
  color:var(--muted);
  font-style:italic;
  font-weight:400;
}

/* Disabled form fields */
.portfolio-form input:disabled,
.portfolio-form select:disabled,
.portfolio-form textarea:disabled{
  background-color:#f5f5f5;
  color:#999;
  cursor:not-allowed;
  opacity:0.6;
}
.portfolio-form button:disabled{
  opacity:0.5;
  cursor:not-allowed;
}

/* Settings Page */
.settings-loading{
  padding:24px 0;
  text-align:center;
}
.settings-section{
  display:flex;
  flex-direction:column;
  gap:0;
}
.settings-item{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:16px 0;
  border-bottom:1px solid var(--border);
}
.settings-item:last-child{
  border-bottom:none;
}
.settings-item-content{
  flex:1;
  min-width:0;
}
.settings-label{
  display:flex;
  flex-direction:column;
  gap:4px;
  cursor:pointer;
}
.settings-label-text{
  font-size:16px;
  font-weight:500;
  color:var(--text);
  line-height:1.4;
}
.settings-label-description{
  font-size:14px;
  color:var(--text-muted);
  line-height:1.4;
}

/* iOS Toggle Switch */
.ios-toggle{
  position:relative;
  display:inline-block;
  width:51px;
  height:31px;
  flex-shrink:0;
  margin-left:16px;
}
.ios-toggle input{
  opacity:0;
  width:0;
  height:0;
}
.ios-toggle-slider{
  position:absolute;
  cursor:pointer;
  top:0;
  left:0;
  right:0;
  bottom:0;
  background-color:#ccc;
  transition:0.3s;
  border-radius:31px;
}
.ios-toggle-slider:before{
  position:absolute;
  content:"";
  height:27px;
  width:27px;
  left:2px;
  bottom:2px;
  background-color:white;
  transition:0.3s;
  border-radius:50%;
  box-shadow:0 2px 4px rgba(0,0,0,0.2);
}
.ios-toggle input:checked + .ios-toggle-slider{
  background-color:var(--green);
}
.ios-toggle input:checked + .ios-toggle-slider:before{
  transform:translateX(20px);
}
.ios-toggle input:focus + .ios-toggle-slider{
  box-shadow:0 0 1px var(--green);
}
.ios-toggle input:disabled + .ios-toggle-slider{
  opacity:0.5;
  cursor:not-allowed;
}

[data-theme="dark"] .ios-toggle-slider{
  background-color:#555;
}
[data-theme="dark"] .ios-toggle input:checked + .ios-toggle-slider{
  background-color:var(--green);
}
[data-theme="dark"] .ios-toggle-slider:before{
  background-color:#fff;
}

@media (max-width: 700px){
  .auth-user-email{
    display:none;
  }
  .auth-modal-content{
    width:95%;
    margin:20px;
  }
  .portfolio-list-header{
    flex-direction:column;
    align-items:flex-start;
    gap:12px;
  }
  .settings-item{
    padding:14px 0;
  }
  .settings-label-text{
    font-size:15px;
  }
  .settings-label-description{
    font-size:13px;
  }
  .ios-toggle{
    width:47px;
    height:29px;
  }
  .ios-toggle-slider:before{
    height:25px;
    width:25px;
  }
  .ios-toggle input:checked + .ios-toggle-slider:before{
    transform:translateX(18px);
  }
  .blog-post-card{
    flex-direction:column;
    margin-bottom:20px;
  }
  .blog-post-card-image{
    width:100%;
    max-width:100%;
    min-width:100%;
    height:200px;
    align-self:auto;
  }
}

/* Blog styles */
.blog-loading,
.blog-post-loading,
.admin-blog-loading{
  text-align:center;
  padding:40px 20px;
}
.blog-empty,
.blog-error,
.blog-post-error{
  text-align:center;
  padding:40px 20px;
}
.blog-posts-list{
  display:flex;
  flex-direction:column;
  gap:24px;
  margin-top:24px;
}
/* Blog list cards - use article selector to be more specific */
article.blog-post-card,
.blog-posts-list .blog-post-card{
  background:var(--card);
  border-radius:var(--radius);
  box-shadow:0 4px 12px rgba(0,0,0,0.1);
  overflow:hidden;
  transition:transform 0.2s,box-shadow 0.2s;
  display:flex;
  flex-direction:row;
  align-items:stretch;
  cursor:pointer;
  min-height:200px;
}
article.blog-post-card:hover,
.blog-posts-list .blog-post-card:hover{
  transform:translateY(-4px);
  box-shadow:0 15px 40px rgba(0,0,0,0.18);
}
.blog-post-card-image{
  width:20%;
  max-width:300px;
  min-width:0;
  min-height:100%;
  height:100%;
  overflow:hidden;
  background:var(--bg);
  flex-shrink:0;
  align-self:stretch;
  display:flex;
  align-items:stretch;
}
.blog-post-card-image img{
  width:100%;
  height:100%;
  min-height:100%;
  object-fit:cover;
  display:block;
  flex-shrink:0;
}
.blog-post-card-content{
  padding:24px;
  flex:1;
  display:flex;
  flex-direction:column;
}
.blog-post-card-title{
  margin:0 0 12px 0;
  font-size:24px;
  line-height:1.3;
}
.blog-post-card-title a{
  color:var(--green);
  text-decoration:none;
  transition:color 0.2s;
}
.blog-post-card-title a:hover{
  color:var(--green-strong);
}
.blog-post-card-excerpt{
  color:var(--muted);
  font-size:16px;
  line-height:1.6;
  margin:0;
  flex:1;
}
.blog-tags-list{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  margin-top:8px;
}
.blog-tag{
  display:inline-block;
  border:1px solid rgba(0,0,0,0.08);
  background:#fff;
  color:var(--text);
  padding:4px 8px;
  border-radius:8px;
  font-size:11px;
  font-weight:600;
  text-decoration:none;
  cursor:pointer;
  transition:all 0.2s;
}
.blog-tag:hover{
  background:var(--bg);
}
.blog-tag-active{
  border-color:var(--green);
  color:#fff;
  background:var(--green);
}
.blog-tag-small{
  font-size:10px;
  padding:3px 6px;
  border-radius:6px;
}
.blog-filter-clear{
  display:inline-block;
  padding:4px 8px;
  border-radius:8px;
  transition:background 0.2s;
}
.blog-filter-clear:hover{
  background:rgba(0,0,0,0.05);
}
[data-theme="dark"] .blog-tag{
  border:1px solid var(--border-dark);
  background:var(--card);
  color:var(--text);
}
[data-theme="dark"] .blog-tag:hover:not(.blog-tag-active){
  background:var(--input-bg-dark);
}
[data-theme="dark"] .blog-tag-active{
  border-color:var(--green);
  color:var(--button-text-dark);
  background:var(--button-bg-dark);
}
[data-theme="dark"] .blog-filter-clear:hover{
  background:rgba(255,255,255,0.1);
}

/* Blog post page - specific selector to avoid overriding list cards */
section.card.blog-post-card{
  margin-bottom:0;
  padding:0;
  background:rgba(255,255,255,0.85);
  box-shadow:var(--shadow);
}
[data-theme="dark"] section.card.blog-post-card{
  background:rgba(30,30,30,0.85);
  box-shadow:var(--shadow);
}
.blog-post-wrapper{
  position:relative;
  display:flex;
  align-items:flex-start;
  gap:24px;
  padding:22px 22px 22px 0;
}
.blog-post-sidebar{
  display:flex;
  flex-direction:column;
  gap:12px;
  flex-shrink:0;
}
.blog-post-back-btn,
.blog-post-edit-btn{
  position:sticky;
  top:100px;
  align-self:flex-start;
  flex-shrink:0;
  display:flex;
  align-items:center;
  gap:8px;
  padding:12px 16px;
  margin-left:22px;
  background:var(--card);
  color:var(--green);
  text-decoration:none;
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  font-size:14px;
  font-weight:500;
  transition:all 0.2s;
  border:1px solid rgba(0,0,0,0.08);
  white-space:nowrap;
}
.blog-post-back-btn:hover,
.blog-post-edit-btn:hover{
  background:var(--green);
  color:#fff;
  transform:translateX(4px);
  box-shadow:0 12px 40px rgba(0,0,0,0.15);
}
.blog-post-back-btn svg,
.blog-post-edit-btn svg{
  flex-shrink:0;
}
@media (max-width:1024px){
  .blog-post-wrapper{
    gap:16px;
  }
  .blog-post-back-btn,
  .blog-post-edit-btn{
    top:80px;
    padding:10px 14px;
    font-size:13px;
  }
}
@media (max-width:768px){
  .blog-post-wrapper{
    gap:12px;
  }
  .blog-post-back-btn,
  .blog-post-edit-btn{
    top:60px;
    padding:8px 12px;
    font-size:12px;
  }
  .blog-post-back-btn span,
  .blog-post-edit-btn span{
    display:none;
  }
}
[data-theme="dark"] .blog-post-back-btn,
[data-theme="dark"] .blog-post-edit-btn{
  background:var(--card);
  border-color:var(--border-dark);
}
[data-theme="dark"] .blog-post-back-btn:hover,
[data-theme="dark"] .blog-post-edit-btn:hover{
  background:var(--green);
  color:#fff;
}
.blog-post-content{
  width:100%;
  max-width:none;
  margin:0;
  padding:22px;
}
.blog-post-header{
  margin-bottom:32px;
  max-width:750px;
  margin-left:auto;
  margin-right:auto;
}
.blog-post-title{
  font-size:36px;
  line-height:1.2;
  margin:0 0 16px 0;
  color:var(--green);
}
.blog-post-featured-image{
  margin:32px 0;
  border-radius:var(--radius);
  overflow:hidden;
}
.blog-post-featured-image img{
  width:100%;
  height:auto;
  display:block;
}
.blog-post-body{
  font-size:16px;
  line-height:1.8;
  color:var(--text);
  max-width:750px;
  margin:0 auto;
}
.blog-post-body h1,
.blog-post-body h2,
.blog-post-body h3{
  margin-top:32px;
  margin-bottom:16px;
  color:var(--green);
  line-height:1.3;
}
.blog-post-body h1{
  font-size:28px;
}
.blog-post-body h2{
  font-size:24px;
}
.blog-post-body h3{
  font-size:20px;
}
.blog-post-body p{
  margin-bottom:16px;
}
/* Remove margin from empty paragraphs (Quill generates <p><br></p> for empty lines) */
.blog-post-body p:empty,
.blog-post-body p:has(> br:only-child){
  margin-bottom:0;
  height:0;
  line-height:0;
}
.blog-post-body ul,
.blog-post-body ol{
  margin:16px 0;
  padding-left:32px;
}
.blog-post-body li{
  margin-bottom:8px;
}
.blog-post-body a{
  color:var(--green);
  text-decoration:none;
  border-bottom:1px solid transparent;
  transition:border-color 0.2s;
}
.blog-post-body a:hover{
  border-bottom-color:var(--green);
}
.blog-post-body strong{
  font-weight:600;
  color:var(--text);
}
.blog-post-body em{
  font-style:italic;
}
.blog-post-footer{
  margin-top:48px;
  padding-top:32px;
  border-top:1px solid rgba(0,0,0,0.08);
}
.blog-post-share{
  margin-bottom:32px;
}
.blog-post-related{
  margin-top:32px;
}
.blog-post-related-title{
  font-size:20px;
  margin-bottom:20px;
  color:var(--text);
}
.blog-post-related-list{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
  gap:20px;
}

/* Admin blog styles */
.admin-blog-actions{
  margin-bottom:24px;
}
.admin-blog-posts-list{
  margin-top:24px;
}
.admin-blog-post-row{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:16px 0;
  border-bottom:1px solid var(--border);
}
.admin-blog-post-row:last-child{
  border-bottom:none;
}
.admin-blog-post-info{
  flex:1;
  min-width:0;
}
.admin-blog-post-info h3{
  margin:0 0 4px 0;
  font-size:16px;
  font-weight:500;
  color:var(--text);
  line-height:1.4;
}
.admin-blog-post-info p{
  margin:0;
  font-size:14px;
  color:var(--muted);
  line-height:1.4;
}
.admin-blog-post-actions{
  display:flex;
  gap:12px;
  flex-shrink:0;
  margin-left:16px;
}
.admin-blog-editor{
  margin-top:24px;
}
.admin-blog-form{
  max-width:800px;
}
.admin-blog-form-actions{
  display:flex;
  gap:12px;
  margin-top:24px;
}
.admin-blog-status-message{
  margin-top:16px;
  padding:12px 16px;
  border-radius:8px;
  font-size:14px;
  line-height:1.5;
}
.admin-blog-status-message.success{
  background:#d4edda;
  color:#155724;
  border:1px solid #c3e6cb;
}
.admin-blog-status-message.error{
  background:#f8d7da;
  color:#721c24;
  border:1px solid #f5c6cb;
}

/* Dark mode blog styles */
[data-theme="dark"] .blog-post-card{
  background:var(--card);
  box-shadow:var(--shadow);
}
[data-theme="dark"] .blog-post-card:hover{
  box-shadow:0 15px 40px rgba(0,0,0,0.5);
}
[data-theme="dark"] .blog-post-footer{
  border-top:1px solid var(--border-dark);
}
[data-theme="dark"] .blog-post-body a{
  color:var(--button-text-dark);
}
[data-theme="dark"] .blog-post-body a:hover{
  border-bottom-color:var(--button-text-dark);
}
[data-theme="dark"] .admin-blog-post-row{
  border-bottom-color:var(--border-dark);
}
[data-theme="dark"] .admin-blog-status-message.success{
  background:rgba(40,167,69,0.2);
  color:#90ee90;
  border:1px solid rgba(40,167,69,0.3);
}
[data-theme="dark"] .admin-blog-status-message.error{
  background:rgba(220,53,69,0.2);
  color:#ff6b6b;
  border:1px solid rgba(220,53,69,0.3);
}

/* Admin Users Styles */
.admin-users-loading{
  text-align:center;
  padding:40px 20px;
}
.admin-users-list{
  margin-top:24px;
}
.admin-users-search{
  margin-bottom:24px;
}
.admin-users-search input{
  width:100%;
  max-width:400px;
  padding:12px 16px;
  border:1px solid var(--border);
  border-radius:8px;
  font-size:15px;
}
.admin-users-table{
  width:100%;
  border-collapse:collapse;
  background:var(--card);
  border-radius:8px;
  overflow:hidden;
}
.admin-users-table thead{
  background:var(--bg);
}
.admin-users-table th{
  padding:16px;
  text-align:left;
  font-weight:700;
  font-size:14px;
  color:var(--text);
  border-bottom:2px solid var(--border);
}
.admin-users-table td{
  padding:16px;
  border-bottom:1px solid var(--border);
  font-size:14px;
  color:var(--text);
}
.admin-users-table tbody tr:last-child td{
  border-bottom:none;
}
.admin-users-table tbody tr:hover{
  background:var(--bg);
}
.admin-users-subscription-toggle{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:6px 12px;
  border-radius:6px;
  border:1px solid var(--border);
  background:var(--card);
  cursor:pointer;
  transition:all 0.2s;
  font-size:14px;
}
.admin-users-subscription-toggle.active{
  background:var(--green);
  color:#fff;
  border-color:var(--green);
}
.admin-users-subscription-toggle:hover{
  opacity:0.8;
}
[data-theme="dark"] .admin-users-table{
  background:var(--card);
  border:1px solid var(--border-dark);
}
[data-theme="dark"] .admin-users-table thead{
  background:var(--bg);
}
[data-theme="dark"] .admin-users-table th{
  border-bottom-color:var(--border-dark);
}
[data-theme="dark"] .admin-users-table td{
  border-bottom-color:var(--border-dark);
}
[data-theme="dark"] .admin-users-table tbody tr:hover{
  background:var(--bg);
}
[data-theme="dark"] .admin-users-subscription-toggle{
  border-color:var(--border-dark);
  background:var(--card);
}
[data-theme="dark"] .admin-users-subscription-toggle.active{
  background:var(--green);
  border-color:var(--green);
}

/* Quill Editor Styles */
.ql-container{
  font-family:inherit;
  font-size:16px;
  line-height:1.6;
}
.ql-editor{
  min-height:350px;
  color:var(--text);
}
.ql-toolbar{
  border-top-left-radius:var(--radius);
  border-top-right-radius:var(--radius);
  background:var(--bg);
  border:1px solid var(--border);
}
.ql-container{
  border-bottom-left-radius:var(--radius);
  border-bottom-right-radius:var(--radius);
  border:1px solid var(--border);
  border-top:none;
  background:var(--card);
}
.ql-editor.ql-blank::before{
  color:var(--muted);
  font-style:normal;
}
[data-theme="dark"] .ql-toolbar{
  background:var(--input-bg-dark);
  border-color:var(--border-dark);
}
[data-theme="dark"] .ql-container{
  background:var(--card-dark);
  border-color:var(--border-dark);
}
[data-theme="dark"] .ql-editor{
  color:var(--text-dark);
}
[data-theme="dark"] .ql-stroke{
  stroke:var(--text-dark);
}
[data-theme="dark"] .ql-fill{
  fill:var(--text-dark);
}
[data-theme="dark"] .ql-picker-label{
  color:var(--text-dark);
}
[data-theme="dark"] .ql-snow .ql-picker.ql-expanded .ql-picker-label{
  color:var(--text-dark);
}

/* Portfolio Purchase Modal - Larger size */
#portfolio-purchase-modal .auth-modal-content{
  max-width:800px;
  width:90%;
}

/* Symbol Lookup Modal */
.symbol-lookup-modal {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.5);
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 1001;
}

.symbol-lookup-modal-dialog {
  background: var(--card);
  border-radius: var(--radius);
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15);
  max-width: 600px;
  width: 90%;
  max-height: 80vh;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

.symbol-lookup-modal-header {
  padding: 20px;
  border-bottom: 1px solid var(--border);
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.symbol-lookup-modal-header h3 {
  margin: 0;
  color: var(--text);
  font-size: 1.25rem;
}

.symbol-lookup-modal-close {
  background: none;
  border: none;
  font-size: 24px;
  cursor: pointer;
  color: var(--muted);
  padding: 0;
  width: 30px;
  height: 30px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  transition: background-color 0.2s;
}

.symbol-lookup-modal-close:hover {
  background-color: var(--hover);
  color: var(--text);
}

.symbol-lookup-modal-body {
  padding: 20px;
  overflow-y: auto;
  flex: 1;
}

.symbol-lookup-results {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.symbol-lookup-result-item {
  padding: 12px 16px;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  cursor: pointer;
  transition: all 0.2s;
  background: var(--bg);
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.symbol-lookup-result-item:hover {
  background: rgba(59, 130, 246, 0.1); /* Light blue hover */
  border-color: rgba(59, 130, 246, 0.3);
}

.symbol-lookup-result-main {
  flex: 1;
}

.symbol-lookup-result-symbol {
  font-weight: 600;
  color: var(--text);
  font-size: 1rem;
  margin-bottom: 4px;
}

.symbol-lookup-result-name {
  color: var(--muted);
  font-size: 0.9rem;
  margin-bottom: 2px;
}

.symbol-lookup-result-type {
  color: var(--muted);
  font-size: 0.8rem;
  text-transform: uppercase;
  font-weight: 500;
}

.symbol-lookup-result-price {
  text-align: right;
  margin-left: 16px;
}

.symbol-lookup-result-currency {
  color: var(--muted);
  font-size: 0.8rem;
  font-weight: 500;
  margin-bottom: 2px;
}

.symbol-lookup-result-amount {
  color: var(--text);
  font-size: 0.95rem;
  font-weight: 600;
}

/* Loading state */
.symbol-lookup-loading {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 40px 20px;
  text-align: center;
}

.symbol-lookup-loading-logo {
  width: auto;
  height: 120px;
  animation: logoFade 2s ease-in-out infinite;
  margin-bottom: 16px;
  object-fit: contain;
  opacity: 0.9;
}

@keyframes logoFade {
  0% { 
    opacity: 0.3;
  }
  50% { 
    opacity: 1;
  }
  100% { 
    opacity: 0.3;
  }
}

.symbol-lookup-loading-text {
  color: var(--muted);
  font-size: 0.9rem;
}

/* Error and no results states */
.symbol-lookup-error,
.symbol-lookup-no-results {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 40px 20px;
  text-align: center;
}

.symbol-lookup-error-text,
.symbol-lookup-no-results-text {
  color: var(--muted);
  font-size: 0.9rem;
}

/* Dark mode styles */
[data-theme="dark"] .symbol-lookup-modal-dialog {
  background: var(--card-dark);
}

[data-theme="dark"] .symbol-lookup-modal-header {
  border-bottom-color: var(--border-dark);
}

[data-theme="dark"] .symbol-lookup-modal-header h3 {
  color: var(--text-dark);
}

[data-theme="dark"] .symbol-lookup-modal-close {
  color: var(--muted-dark);
}

[data-theme="dark"] .symbol-lookup-modal-close:hover {
  background-color: var(--hover-dark);
  color: var(--text-dark);
}

[data-theme="dark"] .symbol-lookup-result-item {
  border-color: var(--border-dark);
  background: var(--bg-dark);
}

[data-theme="dark"] .symbol-lookup-result-item:hover {
  background: rgba(59, 130, 246, 0.15); /* Slightly more visible in dark mode */
  border-color: rgba(59, 130, 246, 0.4);
}

[data-theme="dark"] .symbol-lookup-result-symbol {
  color: var(--text-dark);
}

[data-theme="dark"] .symbol-lookup-result-name,
[data-theme="dark"] .symbol-lookup-result-type,
[data-theme="dark"] .symbol-lookup-result-currency {
  color: var(--muted-dark);
}

[data-theme="dark"] .symbol-lookup-result-amount {
  color: var(--text-dark);
}

[data-theme="dark"] .symbol-lookup-loading-spinner {
  border-color: var(--border-dark);
  border-top-color: var(--primary);
}

[data-theme="dark"] .symbol-lookup-loading-text,
[data-theme="dark"] .symbol-lookup-error-text,
[data-theme="dark"] .symbol-lookup-no-results-text {
  color: var(--muted-dark);
}

[data-theme="dark"] .symbol-lookup-loading-logo {
  /* Keep same brightness as main site logo in dark mode */
}

/* Dark mode uses same fade animation but with brightness filter like main site */
[data-theme="dark"] .symbol-lookup-loading-logo {
  filter: brightness(1.5);
  animation: logoFade 2s ease-in-out infinite;
}

/* Portfolio Header with Selector */
.portfolio-header-left {
  display: flex;
  align-items: center;
  gap: 16px;
}

.portfolio-selector {
  padding: 8px 12px;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--bg);
  color: var(--text);
  font-size: 14px;
  font-family: inherit;
  transition: all 0.2s;
  min-width: 200px;
}

.portfolio-selector:focus {
  outline: none;
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
}

/* Dark mode styles */
[data-theme="dark"] .portfolio-selector {
  background: var(--input-bg-dark);
  border-color: var(--border-dark);
  color: var(--text-dark);
}

[data-theme="dark"] .portfolio-selector:focus {
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.15);
}

/* Portfolio Position Details */
.portfolio-detail-row {
  background: var(--hover);
  border-left: 3px solid var(--primary);
}

.portfolio-detail-info {
  padding-left: 20px;
}

.portfolio-expand-btn {
  background: none;
  border: none;
  cursor: pointer;
  padding: 4px 8px;
  border-radius: 4px;
  transition: background-color 0.2s;
}

.portfolio-expand-btn:hover {
  background: var(--hover);
}

.portfolio-expand-icon {
  font-size: 12px;
  color: var(--muted);
  transition: transform 0.2s;
}

.portfolio-delete-btn {
  background: none;
  border: none;
  cursor: pointer;
  padding: 4px 8px;
  border-radius: 4px;
  transition: background-color 0.2s;
}

.portfolio-delete-btn:hover {
  background: rgba(239, 68, 68, 0.1);
}

.portfolio-delete-icon {
  font-size: 14px;
}

/* Dark mode styles */
[data-theme="dark"] .portfolio-detail-row {
  background: var(--hover-dark);
}

[data-theme="dark"] .portfolio-expand-btn:hover {
  background: var(--hover-dark);
}

[data-theme="dark"] .portfolio-expand-icon {
  color: var(--muted-dark);
}

[data-theme="dark"] .portfolio-delete-btn:hover {
  background: rgba(239, 68, 68, 0.15);
}

/* Portfolio Asset Logos */

.portfolio-asset-logo {
  width: 64px;
  height: 64px;
  border-radius: 8px;
  object-fit: contain;
  background: var(--bg);
  border: 1px solid var(--border);
  padding: 6px;
  flex-shrink: 0;
}

.portfolio-asset-text {
  flex: 1;
  min-width: 0; /* Allow text to truncate */
  display: flex;
  flex-direction: column;
  gap: 4px;
}

/* Dark mode styles */
[data-theme="dark"] .portfolio-asset-logo {
  background: var(--bg-dark);
  border-color: var(--border-dark);
}

@media (max-width: 900px){
  #portfolio-purchase-modal .auth-modal-content{
    max-width:95%;
    width:95%;
  }
}

@media (max-width: 700px){
  .portfolio-item{
    flex-direction:column;
  }
  .portfolio-item-actions{
    width:100%;
    justify-content:flex-end;
  }
  .portfolio-form-actions{
    flex-direction:column;
  }
}