/* static/css/profitpal-styles.css*/

/* ===============================
   ProfitPal — base theme + dashboard add-ons
   =============================== */

/* Palette */
:root{
  --profitpal-bg:#0a0e27;
  --profitpal-primary:#32cd32;
  --profitpal-danger:#e74c3c;
  --profitpal-warning:#f39c12;
  --profitpal-info:#3498db;

  --profitpal-light:#fff;
  --profitpal-gray:#95a5a6;
  --profitpal-dark:#2c3e50;

  --profitpal-gradient-success:linear-gradient(135deg,#32cd32 0%,#27ae60 100%);
  --profitpal-gradient-danger:linear-gradient(135deg,#e74c3c 0%,#c0392b 100%);
  --profitpal-gradient-bg:linear-gradient(135deg,#0a0e27 0%,#1a1e3a 100%);
  --profitpal-gradient-card:linear-gradient(135deg,rgba(255,255,255,.10) 0%,rgba(255,255,255,.05) 100%);
}

/* приглушенный текст — действует на оба места */
.muted{
  color:#9fb6cc;      /* мягкий голубо-серый */
  opacity:.85;
  font-size:12px;
}

/* оформление строки источника под таблицей */
.pp-source{
  display:block;
  margin:14px 0 6px;           /* оттолкнуть от таблицы и от следующего блока */
  padding-top:8px;
  border-top:1px solid rgba(255,215,0,.15);
  color:#ffb1b1;
  line-height:1.35;
}
.pp-source a{ color:#ffcece; text-decoration:underline dotted; }
.pp-source a:hover{ text-decoration:underline; }

/* чуть больше зазор под таблицей, чтобы Source не прилипал */
.data-table{ margin-bottom:10px; }

/* Делаем Source частью футера секции Financial Overview */
#financialSection { 
  padding-bottom: 22px;      /* немного “воздуха” внутри секции */
  margin-bottom: 44px;       /* увеличим зазор до следующего блока */
}

#financialSection .pp-source{
  margin-top: 12px;          /* отступ от таблицы */
  margin-bottom: 0;          /* не выталкиваем секцию вниз за счёт Source */
  padding-top: 8px;          /* отделим линией внутри секции */
  border-top: 1px solid rgba(255,255,255,.15);
}

/* ===== Public Navigation (прибито к правому краю index.html) ===== */
.header-nav {
  display: flex;
  justify-content: flex-end;  /* прибивает всё к правому краю */
  align-items: center;
  gap: 24px;
  padding: 20px 40px;
  background: transparent;
}

.header-nav .nav-link {
  color: #94a3b8;
  text-decoration: none;
  font-weight: 500;
  font-size: 15px;
  transition: color 0.2s ease;
}

.header-nav .nav-link:hover {
  color: #32cd32;
}

/* ===== GENERIC STYLES =====*/
/* Reset bits */
*{margin:0;padding:0;box-sizing:border-box;}
body{
  font-family:'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
  background:var(--profitpal-gradient-bg);
  color:var(--profitpal-light);
  min-height:100vh; line-height:1.6;
}

/* Generic components (cards/containers/buttons/etc.) */
.profitpal-container{max-width:800px;width:100%;margin:0 auto;padding:20px;min-height:100vh;display:flex;align-items:center;justify-content:center;}
.profitpal-card{
  background:var(--profitpal-gradient-card);
  backdrop-filter:blur(10px);
  border-radius:20px; padding:60px 40px; text-align:center;
  box-shadow:0 20px 40px rgba(0,0,0,.3);
  border:1px solid rgba(255,255,255,.1); width:100%;
}
.profitpal-title{
  font-size:2.5rem; margin-bottom:20px; font-weight:700;
  background:linear-gradient(45deg,var(--profitpal-light),var(--profitpal-gray));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.profitpal-subtitle{font-size:1.2rem;margin-bottom:15px;color:var(--profitpal-gray);opacity:.9;}
.profitpal-description{font-size:1.1rem;margin-bottom:15px;opacity:.8;line-height:1.6;}

.profitpal-btn{
  display:inline-block;padding:15px 30px;margin:10px;font-size:1.1rem;font-weight:600;
  border-radius:12px;transition:.3s;border:none;cursor:pointer;min-width:200px;text-decoration:none;
}
.profitpal-btn.success{background:var(--profitpal-gradient-success);color:var(--profitpal-light);box-shadow:0 5px 15px rgba(50,205,50,.3);}
.profitpal-btn.success:hover{transform:translateY(-3px);box-shadow:0 8px 25px rgba(50,205,50,.4);}
.profitpal-btn.primary{background:var(--profitpal-gradient-bg);color:var(--profitpal-primary);border:2px solid var(--profitpal-primary);box-shadow:0 5px 15px rgba(52,152,219,.3);}
.profitpal-btn.primary:hover{background:var(--profitpal-primary);color:var(--profitpal-bg);transform:translateY(-3px);box-shadow:0 8px 25px rgba(52,152,219,.4);}
.profitpal-btn.danger{background:var(--profitpal-gradient-danger);color:var(--profitpal-light);box-shadow:0 5px 15px rgba(231,76,60,.3);}
.profitpal-btn.danger:hover{transform:translateY(-3px);box-shadow:0 8px 25px rgba(231,76,60,.4);}

/* Lists / info */
.profitpal-features{background:rgba(255,255,255,.05);border-radius:15px;padding:25px;margin:30px 0;border:1px solid rgba(255,255,255,.1);}
.profitpal-features h3{margin-bottom:15px;font-size:1.3rem;color:var(--profitpal-primary);}
.profitpal-features ul{list-style:none;text-align:left;}
.profitpal-features li{padding:8px 0 8px 25px;position:relative;font-size:1rem;}
.profitpal-features li::before{content:"✓";position:absolute;left:0;color:var(--profitpal-primary);font-weight:700;font-size:1.2rem;}

.profitpal-info-box{background:rgba(255,255,255,.08);border-radius:15px;padding:20px;margin:20px 0;border-left:4px solid var(--profitpal-primary);}
.profitpal-info-box.warning{border-left-color:var(--profitpal-warning);}
.profitpal-info-box.danger{border-left-color:var(--profitpal-danger);}
.profitpal-session{margin-top:30px;padding:15px;background:rgba(0,0,0,.3);border-radius:10px;font-family:'Courier New',monospace;font-size:.9rem;opacity:.7;border:1px solid rgba(255,255,255,.1);}

/* Icons + animations (used on success pages, etc.) */
.profitpal-icon{font-size:100px;margin-bottom:30px;display:block;}
.profitpal-icon.success{animation:pp-bounce 2s infinite;}
.profitpal-icon.error{animation:pp-shake 1s ease-in-out;}
@keyframes pp-bounce{0%,20%,50%,80%,100%{transform:translateY(0)}40%{transform:translateY(-20px)}60%{transform:translateY(-10px)}}
@keyframes pp-shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-10px)}75%{transform:translateX(10px)}}
.profitpal-loading{display:inline-block;width:20px;height:20px;border:3px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:var(--profitpal-primary);animation:pp-spin 1s ease-in-out infinite;}
@keyframes pp-spin{to{transform:rotate(360deg)}}
.profitpal-bg-animate{animation:pp-bg 10s ease-in-out infinite;}
@keyframes pp-bg{
  0%,100%{background:linear-gradient(135deg,#0a0e27 0%,#1a1e3a 100%)}
  50%{background:linear-gradient(135deg,#0a0e27 0%,#2a2e4a 50%,#1a1e3a 100%)}
}

/* Responsive */
@media (max-width:768px){
  .profitpal-container{padding:10px;}
  .profitpal-card{padding:40px 20px;}
  .profitpal-title{font-size:2rem;}
  .profitpal-btn{width:100%;max-width:300px;margin:5px 0;}
  .profitpal-features li{font-size:.95rem;}
}

/* ===== Dashboard add-ons ===== */
.hidden{display:none!important;}
.clickable{cursor:pointer;}
.copy-success{
  position:fixed;left:50%;top:20px;transform:translateX(-50%);
  background:rgba(50,205,50,.12);border:1px solid rgba(50,205,50,.35);
  color:#fff;padding:10px 14px;border-radius:10px;z-index:9999;backdrop-filter:blur(6px);
}

.dashboard-card{
  background:var(--profitpal-gradient-card);
  border:1px solid rgba(255,255,255,.08);
  border-radius:18px;padding:18px;box-shadow:0 8px 24px rgba(0,0,0,.25);
}

.referral-banner{
  background:linear-gradient(135deg,rgba(255,255,255,.08),rgba(255,255,255,.04));
  border:1px solid rgba(255,255,255,.10);
  border-radius:18px;padding:18px;transition:.2s;
}
.referral-banner:active{transform:scale(.998);}

/* Loading state для карточки цены */
.current-price-card.loading {
  opacity: 0.7;
  pointer-events: none;
}

.current-price-card.loading #currentPrice {
  animation: pulse 1.5s ease-in-out infinite;
}

@keyframes pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.5; }
}

.spinner {
  display: inline-block;
  animation: spin 1s linear infinite;
}

@keyframes spin {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}

/* ===== Boost / Donations ===== */
.boost-banner{
  background:linear-gradient(135deg,rgba(255,107,53,.10),rgba(255,193,7,.06));
  border:1px solid rgba(255,107,53,.28);color:#fff;border-radius:18px;padding:16px;transition:.2s;
}
.boost-expand-hint{color:#ffc107;opacity:.85;font-size:.95rem;}
#boostOptions{display:none;margin-top:12px;}

/* Layout for tiles */
.donation-group,
.donation-grid{display:flex;flex-wrap:wrap;gap:10px;}

/* Tile button */
.donation-btn{
  position:relative;z-index:1;pointer-events:auto;cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center;
  min-width:88px;padding:12px 16px;border-radius:12px;outline:0;
  border:1px solid rgba(255,255,255,.16);
  background:linear-gradient(135deg,rgba(255,255,255,.08),rgba(255,255,255,.05));
  color:#fff;user-select:none;transition:.15s;
}
/* чтобы вложенные span/иконки не «крали» клик */
.donation-btn *{pointer-events:none;}
.donation-btn { cursor: pointer; }
.donation-btn:hover{transform:translateY(-1px);border-color:rgba(255,255,255,.32);}
.donation-btn:active{transform:translateY(0);}
/* выбранная плитка */
.donation-btn.selected{
  border-color:#ff6b35;
  background:linear-gradient(135deg,rgba(255,107,53,.35),rgba(255,193,7,.20));
  box-shadow:0 6px 18px rgba(255,107,53,.25);
}

/* Custom amount input */
#customAmount{
  appearance:textfield;-moz-appearance:textfield;
  background:rgba(0,0,0,.35);color:#fff;border:1px solid rgba(255,255,255,.18);
  padding:12px 14px;border-radius:12px;width:140px;transition:.15s;
}
#customAmount:focus{border-color:var(--profitpal-primary);outline:none;box-shadow:0 0 0 3px rgba(50,205,50,.25);}
#customAmount.has-value{border-color:#ff6b35;box-shadow:0 0 0 2px rgba(255,107,53,.20) inset;}

/* Consent + submit */
#donationConsent,#authorizeDonation{accent-color:var(--profitpal-primary);}
#submitDonation{
  padding:12px 18px;border-radius:12px;border:none;font-weight:700;
  background:var(--profitpal-gradient-success);color:#0a0e27;
  box-shadow:0 8px 24px rgba(50,205,50,.30);transition:.15s;
}
#submitDonation:disabled{
  opacity:.55;filter:grayscale(.2);cursor:not-allowed;
  box-shadow:none;background:linear-gradient(135deg,#3b3f5c,#2a2e4a);
}

/* Upgrade / Downgrade sections (hidden by default) */
#proOptions,#downgradeOptions{display:none;margin-top:12px;}

/* ===============================
   PP Analysis page (financial tables)
   =============================== */

/* Отступы секций, чтобы футноты не прилипали к следующей секции */
.data-section{ padding-bottom: 22px; }
.data-section + .data-section{ margin-top: 28px; }

/* Бейджи-пометки рядом с метриками (SEC reported / Calculated) */
.pp-metric-tag{
  display:inline-block; margin-left:8px; padding:2px 8px;
  font-size:12px; line-height:1; border-radius:999px;
  background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.18);
  color:#bcd1ff; vertical-align:middle;
}
.pp-metric-tag--sec{ color:#9fdcff; }
.pp-metric-tag--calc{ color:#ffc07a; border-color:rgba(255,192,122,.35); }

/* Строка "Source" под таблицей */
.pp-source{
  margin-top:14px; margin-bottom:4px; padding:10px 12px;
  color:#ff8a8a; font-size:12px;
  border-top:1px dashed rgba(255,255,255,.18);
  background:linear-gradient(180deg,rgba(255,255,255,.02),rgba(255,255,255,0));
  border-radius:0 0 10px 10px;
}
.pp-source__title{ font-weight:700; margin-right:6px; color:#ffb3b3; }
.pp-source a{ color:#ffb3b3; text-decoration:underline dotted; }
.pp-source a:hover{ text-decoration:underline; }

/* Примечания в строке Source */
.pp-note{ color:#c9d6ff; margin-left:10px; }
.pp-note--calc{ color:#ffd38a; }

/* На очень узких экранах переносим Source построчно */
@media (max-width: 640px){
  .pp-source{ font-size:11px; line-height:1.4; }
  .pp-note{ display:block; margin:6px 0 0 0; }
}
/* выравнивание чисел */
.data-table td.right { text-align: right; }

/* стрелочка у Total Debt */
[data-expand="debt"] td:first-child::before { content:'▸'; margin-right:6px; }
[data-expand="debt"].open td:first-child::before { content:'▾'; }

/* футер-источник — уже предлагал, повторю ключевые */
.pp-source{ margin-top:14px;margin-bottom:4px;padding:10px 12px;
  color:#ff8a8a;font-size:12px;border-top:1px dashed rgba(255,255,255,.18);
  background:linear-gradient(180deg,rgba(255,255,255,.02),transparent);
  border-radius:0 0 10px 10px;
}
.pp-source__title{ font-weight:700; margin-right:6px; color:#ffb3b3; }
.pp-note{ color:#c9d6ff; margin-left:10px; }
.pp-note--calc{ color:#ffd38a; }
.pp-metric-tag{
  display:inline-block;margin-left:8px;padding:2px 8px;font-size:12px;line-height:1;
  border-radius:999px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);
  color:#bcd1ff;vertical-align:middle;
}
.pp-metric-tag--calc{ color:#ffc07a; border-color:rgba(255,192,122,.35); }
.pp-metric-tag--sec { color:#9fdcff; }

/* ===============================
   PP Analysis — panels + period controls
   =============================== */

/* панель с «ободком» (применим и к твоему #financialSection на всякий случай) */
.pp-panel,
#financialSection{
  border:1px solid rgba(255,255,255,.10);
  border-radius:18px;
  background:rgba(8,20,40,.55);
  box-shadow:
    0 0 0 1px rgba(255,255,255,.06) inset,
    0 12px 30px rgba(0,0,0,.35);
  overflow:hidden;
}

/* шапка панели: заголовок слева, контролы справа */
.pp-panel__header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:16px 20px;
}
.pp-panel__title{
  display:flex;
  align-items:center;
  gap:10px;
  font-weight:800;
  letter-spacing:.5px;
}

/* тулбар периода (год + кварталы) */
.pp-toolbar{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}
.pp-select{
  height:36px;
  padding:0 12px;
  border-radius:10px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(15,32,58,.65);
  color:#EAF0FE;
  outline:none;
  line-height:36px; /* ровно по высоте с кнопками */
}
.pp-quarters{
  display:flex;
  align-items:center;
  gap:6px;
}
.pp-quarter-btn{
  height:36px;
  min-width:44px;
  padding:0 10px;
  border-radius:10px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(15,32,58,.65);
  color:#EAF0FE;
  font-weight:600;
  cursor:pointer;
  transition:transform .06s ease, box-shadow .12s ease, border-color .12s ease;
  line-height:36px;   /* текст по центру */
}
.pp-quarter-btn:hover{ transform:translateY(-1px); }
.pp-quarter-btn.active{
  border-color:#FFC83D;
  box-shadow:0 0 0 2px rgba(255,200,61,.35);
  background:rgba(255,200,61,.12);
  color:#FFD873;
}

/* чуть отступов внутри панелей для таблиц */
.pp-panel .table-wrap{ padding:6px 12px 18px 12px; }

/* «ободок» не пропадал на вложенных секциях */
.data-section.pp-panel{ margin-top: 0; }

/* scoring badges (цвета) */
.metric-value.good { color:#3ddc84; }
.metric-value.warn { color:#f7d154; }
.metric-value.bad  { color:#ff6b6b; }

/* чуть плотнее сетка, чтобы 8 плиток ровно садились */
.score-grid { gap: 12px; }

/* === Diamond Rating Scale === */
.pp-rating {
  background: rgba(44,62,80,.30);
  border-radius: 15px;
  padding: 25px;
  margin-top: 30px;
}

.pp-rating__title {
  color: #ffd700;
  margin: 0 0 20px;
  font-size: 20px;
  font-weight: 700;
}

.pp-rating__list {
  text-align: left;
  color: #95a5a6;
  font-size: 16px;
  line-height: 2;
}

/* необязательно: делаем эмодзи ровнее на разных платформах */
.pp-rating__list .em {
  font-family: "Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji",system-ui,sans-serif;
  font-size: 1.05em;
}

/* тёмной теме чуть добавим контраста при наведении (если надо) */
.pp-rating:hover { background: rgba(44,62,80,.36); }

/* мини-стили для бейджа */
#provenance { font: 14px/1.4 system-ui, sans-serif; margin: 8px 0 16px; }
.prov-row { margin: 4px 0; }
.prov-badge { display: inline-block; padding: 2px 8px; border-radius: 12px; color: #fff; margin-right: 8px; font-weight: 600; }
.prov-badge.ok   { background: #0a8a3b; }
.prov-badge.warn { background: #b87300; }
.prov-text b { font-weight: 700; }

/* ============================================================
   Important Information Footer — pp-info-*
   Используется на index.html через important_information.js
   ============================================================ */

.pp-info-footer {
  max-width: 1100px;
  margin: 60px auto 40px;
  padding: 0 20px;
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
}

.pp-info-header {
  text-align: center;
  margin-bottom: 40px;
}

.pp-info-header h2 {
  font-size: clamp(1.6rem, 3vw, 2.2rem);
  font-weight: 800;
  color: #ffd700;
  letter-spacing: -0.5px;
  margin-bottom: 10px;
}

.pp-info-header p {
  color: #87ceeb;
  font-size: 15px;
  opacity: 0.8;
}

.pp-info-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 20px;
  margin-bottom: 30px;
}

.pp-info-card {
  background: linear-gradient(135deg, rgba(15, 35, 65, 0.7), rgba(10, 14, 39, 0.9));
  border-radius: 16px;
  padding: 28px 24px;
  border: 1px solid rgba(34, 139, 34, 0.2);
  backdrop-filter: blur(10px);
  transition: border-color 0.3s ease, transform 0.3s ease;
  position: relative;
  overflow: hidden;
}

.pp-info-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  border-radius: 16px 16px 0 0;
}

.pp-info-card.green::before  { background: linear-gradient(90deg, #228b22, #32cd32); }
.pp-info-card.gold::before   { background: linear-gradient(90deg, #b8860b, #ffd700); }
.pp-info-card.orange::before { background: linear-gradient(90deg, #cc5200, #ff6b35); }
.pp-info-card.blue::before   { background: linear-gradient(90deg, #1a5276, #87ceeb); }
.pp-info-card.purple::before { background: linear-gradient(90deg, #6c3483, #a569bd); }

.pp-info-card:hover {
  border-color: rgba(50, 205, 50, 0.4);
  transform: translateY(-3px);
}

.pp-info-card-icon {
  font-size: 28px;
  margin-bottom: 12px;
  display: block;
}

.pp-info-card h4 {
  font-size: 16px;
  font-weight: 700;
  margin-bottom: 12px;
  letter-spacing: 0.3px;
}

.pp-info-card.green h4  { color: #32cd32; }
.pp-info-card.gold h4   { color: #ffd700; }
.pp-info-card.orange h4 { color: #ff6b35; }
.pp-info-card.blue h4   { color: #87ceeb; }
.pp-info-card.purple h4 { color: #a569bd; }

.pp-info-card p {
  color: #9aabbb;
  font-size: 14px;
  line-height: 1.7;
}

.pp-info-card p strong {
  color: #cdd8e3;
}

.pp-info-card ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.pp-info-card ul li {
  color: #9aabbb;
  font-size: 14px;
  line-height: 1.7;
  padding: 4px 0;
  border-bottom: 1px solid rgba(255,255,255,0.04);
  display: flex;
  align-items: flex-start;
  gap: 8px;
}

.pp-info-card ul li:last-child {
  border-bottom: none;
}

.pp-info-card ul li .li-dot {
  color: #32cd32;
  flex-shrink: 0;
  margin-top: 2px;
}

.pp-info-warning {
  background: linear-gradient(135deg, rgba(255, 107, 53, 0.08), rgba(10, 14, 39, 0.6));
  border: 1px solid rgba(255, 107, 53, 0.35);
  border-radius: 14px;
  padding: 22px 28px;
  display: flex;
  align-items: flex-start;
  gap: 16px;
  margin-bottom: 20px;
}

.pp-info-warning .warn-icon {
  font-size: 28px;
  flex-shrink: 0;
  margin-top: 2px;
}

.pp-info-warning p {
  color: #bdc3c7;
  font-size: 14px;
  line-height: 1.7;
  margin: 0;
}

.pp-info-warning p strong {
  color: #ff6b35;
}

.pp-info-footnote {
  text-align: center;
  padding: 20px;
  border-top: 1px solid rgba(255,255,255,0.06);
  margin-top: 20px;
}

.pp-info-footnote p {
  color: #5d6d7e;
  font-size: 13px;
  line-height: 1.6;
}

.pp-info-footnote p a {
  color: #32cd32;
  text-decoration: none;
  font-weight: 600;
}

@media (max-width: 600px) {
  .pp-info-grid {
    grid-template-columns: 1fr;
  }
  .pp-info-warning {
    flex-direction: column;
    gap: 10px;
  }
}