/* ── GOALS TAB ────────────────────────────────────────────────────────────── */

.goals-tab{padding:0 4px;padding-bottom:40vh;overflow-anchor:none}

/* ── New Goal button — accent tint + hover shine ─────────────────────────── */
.btn-new-goal{
  background:color-mix(in srgb,var(--accent) 12%,transparent);
  color:var(--accent);
  border:1px solid color-mix(in srgb,var(--accent) 24%,transparent);
}
.btn-new-goal:hover{
  background:color-mix(in srgb,var(--accent) 16%,transparent);
  border-color:color-mix(in srgb,var(--accent) 30%,transparent);
}

/* ── Info banner ──────────────────────────────────────────────────────────── */
.goal-info-banner{display:flex;align-items:flex-start;gap:10px;padding:12px 16px;border-radius:var(--radius);background:color-mix(in srgb, var(--accent) 8%, transparent);border:1px solid color-mix(in srgb, var(--accent) 24%, transparent);margin-bottom:24px}
.goal-info-icon{font-size:15px;flex-shrink:0;margin-top:1px}
.goal-info-text{font-size:12.5px;color:var(--text2);line-height:1.5}
.goal-info-text strong{color:var(--text)}

/* ── Sections ─────────────────────────────────────────────────────────────── */
.goals-section{margin-bottom:24px}
.goals-section-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:0.06em;color:var(--text3);margin-bottom:10px;display:flex;align-items:center;gap:8px}
.goals-section-title::after{content:'';flex:1;height:1px;background:var(--border)}
.goal-count-pill{font-family:var(--font-mono);font-size:10px;background:var(--surface2);border:1px solid var(--border);padding:1px 6px;border-radius:10px;color:var(--text3)}

/* ── Goal list ────────────────────────────────────────────────────────────── */
.goal-list{display:flex;flex-direction:column;gap:2px;overflow-anchor:none}

/* ── Grid column template ─────────────────────────────────────────────────── */
/* S1: Name (dot + info) · S2: Type · S3: Platforms · S4: Portfolios · chevron */
:root{
  --gcol-name: 450px; /* JS sets this on drag */
  --ggrid:
    /* S1 — dot + name */
    8px var(--gcol-name)
    /* divider */
    16px
    /* S2 — type (metric badge) */
    minmax(80px, 1fr)
    /* divider */
    16px
    /* S3 — platforms */
    minmax(70px, 1fr)
    /* divider */
    16px
    /* S4 — portfolios (badges) */
    minmax(80px, 1fr)
    /* chevron */
    20px;
}

/* ── Sticky header (matching portfolio pattern) ──────────────────────────── */
#goals-sticky-sentinel{height:1px;pointer-events:none}
.goals-sticky{
  position:sticky;top:56px;z-index:10;
  background:var(--header-bg);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  margin-left:-32px;margin-right:-32px;
  padding-left:32px;padding-right:32px;
  padding-top:12px;
  transition:border-color 0.15s;
  border-bottom:1px solid transparent;
}
.goals-sticky::after{
  content:'';position:absolute;bottom:0;left:0;right:0;
  height:1px;background:var(--header-shine);pointer-events:none;
}
.goals-sticky.is-stuck{
  border-bottom-color:var(--border);
}

/* ── Table header row ────────────────────────────────────────────────────── */
.goal-table-header{
  display:grid;grid-template-columns:var(--ggrid);align-items:center;gap:0 12px;
  padding:8px 16px;
}
.goal-th{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:0.06em;color:var(--text3)}
.goal-th-c{text-align:center}
.goal-th-divider{width:2px;height:16px;background:var(--border);justify-self:center}

/* ── Goal row (accordion) ─────────────────────────────────────────────────── */
.goal-row{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);transition:box-shadow .15s}
.goal-row:hover{box-shadow:0 2px 12px rgba(0,0,0,.08)}
.goal-row-expanded{border-color:color-mix(in srgb, var(--accent) 30%, transparent)}

.goal-row-header{display:grid;grid-template-columns:var(--ggrid);align-items:center;gap:0 12px;padding:14px 16px;cursor:pointer;border-radius:var(--radius);transition:background .12s}
.goal-row-header:hover{background:var(--surface2)}
.goal-row-expanded .goal-row-header{border-radius:var(--radius) var(--radius) 0 0;border-bottom:1px solid var(--border)}

/* Section dividers (matching portfolio pcard-vdivider pattern) */
.goal-vdivider{width:2px;height:24px;background:var(--border);justify-self:center;align-self:center;transition:background 0.2s}
.goal-row:hover .goal-row-header .goal-vdivider:not(.goal-vdivider-resize){background:var(--accent-border)}
.goal-row:hover .goal-row-header .goal-vdivider-resize::after{background:var(--accent-border)}

/* Name column resize handle — full track is click target, visual line via ::after */
.goal-vdivider.goal-vdivider-resize{
  width:100%;height:100%;
  justify-self:stretch;align-self:stretch;
  background:transparent;
  cursor:col-resize;
  position:relative;
  transition:none;
}
.goal-vdivider.goal-vdivider-resize::after{
  content:'';position:absolute;
  top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:2px;height:24px;
  background:var(--border);
  transition:background 0.12s;
  pointer-events:none;
}
.goal-vdivider.goal-vdivider-resize:hover::after,
.goal-vdivider.goal-vdivider-resize.dragging::after{
  background:var(--accent-border);
}
/* Header resize handle */
.goal-th-divider.goal-vdivider-resize{
  width:100%;height:100%;
  justify-self:stretch;align-self:stretch;
  background:transparent;
  cursor:col-resize;
  position:relative;
  transition:none;
}
.goal-th-divider.goal-vdivider-resize::after{
  content:'';position:absolute;
  top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:2px;height:16px;
  background:var(--border);
  transition:background 0.12s;
  pointer-events:none;
}
.goal-th-divider.goal-vdivider-resize:hover::after,
.goal-th-divider.goal-vdivider-resize.dragging::after{
  background:var(--accent-border);
}

/* Type dot */
.goal-row-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;align-self:center}
.goal-row-dot.system{background:var(--text3)}
.goal-row-dot.custom{background:var(--text3)}
.goal-row-dot.in-use{background:var(--green);box-shadow:0 0 6px color-mix(in srgb, var(--green) 40%, transparent)}

/* Name block */
.goal-row-info{min-width:0;overflow:hidden}
.goal-row-name{font-size:13.5px;font-weight:600;color:var(--text);line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.goal-row-sub{font-size:11px;color:var(--text3);margin-top:1px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* Metric badge */
.goal-metric-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:4px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:0.04em;white-space:nowrap;justify-self:center}
.goal-metric-badge.revenue{background:color-mix(in srgb, var(--green) 15%, transparent);color:var(--green)}
.goal-metric-badge.conversions{background:color-mix(in srgb, var(--accent) 15%, transparent);color:var(--accent)}

/* Platform icons (icon-only, like portfolio cards) */
.goal-row-platforms{display:flex;gap:4px;align-items:center;justify-self:center}
.goal-row-plat{display:flex;align-items:center;opacity:.75;transition:opacity .15s;cursor:default}
.goal-row-plat:hover{opacity:1}
.goal-row-plat.unmapped{opacity:.25;filter:grayscale(1)}

/* Usage / built-in badges — single cell with flex layout */
.goal-row-badges{display:flex;gap:6px;align-items:center;justify-self:center}
.goal-row-badge{font-size:10.5px;font-weight:500;padding:3px 9px;border-radius:20px;white-space:nowrap}
.goal-row-badge.builtin{color:var(--text3);background:var(--surface3);border:1px solid var(--border)}
.goal-row-badge.usage{background:color-mix(in srgb, var(--accent) 10%, transparent);border:1px solid color-mix(in srgb, var(--accent) 25%, transparent);color:var(--accent)}
.goal-row-badge.unused{color:var(--text3);background:var(--surface2);border:1px solid var(--border)}

/* Chevron */
.goal-row-chevron{color:var(--text3);font-size:11px;transition:transform .2s;justify-self:center}
.goal-row-expanded .goal-row-chevron{transform:rotate(90deg)}

/* Body wrapper (spring-animated) */
.goal-row-body{border-radius:0 0 var(--radius) var(--radius)}

/* ── Detail panel ─────────────────────────────────────────────────────────── */
.goal-detail{padding:20px;background:var(--bg);border-radius:0 0 var(--radius) var(--radius);display:flex;flex-direction:column;gap:16px}

/* ── Source toggle ────────────────────────────────────────────────────────── */
.goal-source-toggle{display:flex;background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:3px;gap:2px;width:fit-content}
.goal-source-btn{padding:5px 16px;border-radius:6px;font-size:11.5px;font-weight:500;color:var(--text3);cursor:pointer;transition:all .15s;border:1px solid transparent;background:none;font-family:inherit}
.goal-source-btn.active{background:var(--surface);border-color:var(--border);color:var(--text);box-shadow:var(--shadow)}
.goal-source-btn.disabled{opacity:.5;cursor:not-allowed}
.goal-coming-soon{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;background:var(--surface3);border:1px solid var(--border);padding:1px 5px;border-radius:4px;margin-left:4px;color:var(--text3)}

/* ── Name editing ─────────────────────────────────────────────────────────── */
.goal-name-edit{display:flex;gap:12px}
.goal-name-edit-field{flex:1;display:flex;flex-direction:column;gap:4px}
.goal-name-edit-field label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text3)}
.goal-name-edit-field input{width:100%;padding:8px 10px;border:1px solid var(--border);border-radius:6px;background:var(--surface);color:var(--text);font-size:13px;outline:none;font-family:inherit}
.goal-name-edit-field input:focus{border-color:var(--accent)}

/* ── Platform mapping grid ────────────────────────────────────────────────── */
.goal-mapping-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}
.goal-mapping-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px;display:flex;flex-direction:column;gap:10px}
.goal-mapping-card.has-mapping{border-color:color-mix(in srgb, var(--accent) 30%, transparent);background:color-mix(in srgb, var(--accent) 5%, var(--surface))}

.goal-mapping-card-header{display:flex;align-items:center;gap:8px}
.goal-mapping-card-logo{display:flex;align-items:center;flex-shrink:0}
.goal-mapping-card-name{font-size:12px;font-weight:600;color:var(--text)}
.goal-mapping-card-dot{width:6px;height:6px;border-radius:50%;background:var(--green);margin-left:auto}

.goal-mapping-card-label{font-size:10.5px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text3)}

.goal-mapping-card-select{width:100%;padding:7px 10px;background:var(--surface2);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:12px;font-family:inherit;cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%237d8fbb'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;outline:none}
.goal-mapping-card-select:focus{border-color:color-mix(in srgb, var(--accent) 40%, transparent);box-shadow:0 0 0 3px color-mix(in srgb, var(--accent) 10%, transparent)}

.goal-mapping-card-value{display:flex;align-items:center;justify-content:space-between;font-size:12px;font-family:var(--font-mono);color:var(--accent);background:var(--surface2);border:1px solid color-mix(in srgb, var(--accent) 25%, transparent);padding:7px 10px;border-radius:8px}
.goal-mapping-card-clear{background:none;border:none;cursor:pointer;color:var(--text3);font-size:14px;padding:0 0 0 8px;line-height:1;transition:color .12s}
.goal-mapping-card-clear:hover{color:var(--text)}

.goal-mapping-card-hint{font-size:10.5px;color:var(--text3);line-height:1.4}
.goal-mapping-card-hint.warn{color:var(--amber)}

/* ── Compatibility banner ─────────────────────────────────────────────────── */
.goal-compat-banner{display:flex;align-items:flex-start;gap:8px;padding:10px 14px;border-radius:8px;font-size:12px}
.goal-compat-banner.ok{background:color-mix(in srgb, var(--green) 8%, transparent);border:1px solid color-mix(in srgb, var(--green) 25%, transparent);color:var(--green)}
.goal-compat-banner.warn{background:color-mix(in srgb, var(--amber) 8%, transparent);border:1px solid color-mix(in srgb, var(--amber) 25%, transparent);color:var(--amber)}

/* ── Detail footer ────────────────────────────────────────────────────────── */
.goal-detail-footer{display:flex;align-items:center;justify-content:space-between;padding-top:14px;border-top:1px solid var(--border);margin-top:4px}
.goal-detail-footer-right{display:flex;gap:8px}
.btn.btn-ghost-danger{background:transparent;border:1px solid transparent;color:var(--red);font-size:12px;font-weight:500;padding:5px 10px;border-radius:8px;cursor:pointer;transition:all .15s}
.btn.btn-ghost-danger:hover{background:color-mix(in srgb, var(--red) 10%, transparent);border-color:color-mix(in srgb, var(--red) 25%, transparent)}
.btn.btn-ghost-danger:disabled{opacity:.4;cursor:not-allowed}
.btn.btn-ghost-danger:disabled:hover{background:transparent;border-color:transparent}

/* ── Portfolio usage list ─────────────────────────────────────────────────── */
.goal-usage-section{margin-bottom:0}
.goal-usage-toggle{display:flex;align-items:center;gap:8px;padding:9px 13px;border-radius:8px;background:var(--surface);border:1px solid var(--border);cursor:pointer;transition:all .14s;width:100%;font-size:12px;font-weight:600;color:var(--text2);font-family:inherit}
.goal-usage-toggle:hover{background:var(--surface2);border-color:var(--border2)}
.goal-usage-toggle-icon{font-size:13px}

.goal-usage-count{font-size:10.5px;font-weight:600;padding:1px 7px;border-radius:10px;background:color-mix(in srgb, var(--accent) 10%, transparent);border:1px solid color-mix(in srgb, var(--accent) 25%, transparent);color:var(--accent)}
.goal-usage-count.zero{background:var(--surface2);border-color:var(--border);color:var(--text3)}

.goal-usage-arrow{margin-left:auto;color:var(--text3);font-size:10px;transition:transform .2s}
.goal-usage-toggle.open .goal-usage-arrow{transform:rotate(180deg)}

.goal-usage-list{margin-top:6px;border:1px solid var(--border);border-radius:8px;overflow:hidden}
.goal-usage-row{display:flex;align-items:center;gap:10px;padding:10px 14px;border-bottom:1px solid var(--border);font-size:12.5px;transition:background .1s}
.goal-usage-row:last-child{border-bottom:none}
.goal-usage-row:hover{background:var(--surface2)}

.goal-usage-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.goal-usage-dot.ok{background:var(--green)}
.goal-usage-dot.warn{background:var(--amber)}

.goal-usage-name{font-weight:500;color:var(--text)}
.goal-usage-platforms{display:flex;gap:3px}
.goal-usage-plat{display:flex;align-items:center}
.goal-usage-cams{font-size:11px;color:var(--text3);white-space:nowrap;margin-left:auto}
.goal-usage-status{font-size:10.5px;font-weight:500;padding:2px 8px;border-radius:10px;white-space:nowrap;flex-shrink:0}
.goal-usage-status.ok{background:color-mix(in srgb, var(--green) 10%, transparent);color:var(--green)}
.goal-usage-status.warn{background:color-mix(in srgb, var(--amber) 10%, transparent);color:var(--amber)}

.goal-usage-empty{padding:14px;text-align:center;font-size:12px;color:var(--text3)}

/* ── Empty state ──────────────────────────────────────────────────────────── */
.goals-empty{text-align:center;padding:32px 16px;color:var(--text3);font-size:13px}
.goals-empty p{margin:4px 0}

/* ── Modal form (shared by create modal) ──────────────────────────────────── */
.goal-modal-form{display:flex;flex-direction:column;gap:14px}
.goal-modal-field label{display:block;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:0.04em;color:var(--text3);margin-bottom:4px}
.goal-modal-field input,.goal-modal-field textarea,.goal-modal-field select{width:100%;padding:8px 10px;border:1px solid var(--border);border-radius:6px;background:var(--surface);color:var(--text);font-size:13px;outline:none;font-family:inherit}
.goal-modal-field input:focus,.goal-modal-field textarea:focus,.goal-modal-field select:focus{border-color:var(--accent)}
.goal-modal-field textarea{resize:vertical;min-height:50px}
.goal-modal-hint{font-size:11px;color:var(--text3);margin-top:3px;display:block}

/* ── Metric type selector (radio-style) ───────────────────────────────────── */
.goal-metric-selector{display:flex;gap:8px}
.goal-metric-option{display:flex;align-items:center;gap:6px;padding:6px 12px;border:1px solid var(--border);border-radius:6px;cursor:pointer;font-size:12px;font-weight:500;color:var(--text2);transition:border-color .12s,background .12s}
.goal-metric-option:hover{border-color:color-mix(in srgb, var(--accent) 30%, transparent)}
.goal-metric-option.active{border-color:var(--accent);background:color-mix(in srgb, var(--accent) 8%, transparent);color:var(--accent)}
.goal-metric-option input{display:none}

/* ── Staggered fade-in ────────────────────────────────────────────────────── */
@keyframes goalFadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.goal-row{animation:goalFadeUp .28s ease both}
.goal-row:nth-child(1){animation-delay:.04s}
.goal-row:nth-child(2){animation-delay:.08s}
.goal-row:nth-child(3){animation-delay:.12s}
.goal-row:nth-child(4){animation-delay:.16s}
.goal-row:nth-child(5){animation-delay:.20s}
