/* assets/app.css
   Personna Mind — Mental Tool Kit (Premium UI Kit)
   Updated to MATCH your previous Career Brain Assessment color system
   (keeps existing class names used in current PHP pages)

   Primary:   #4f46e5
   Secondary: #06b6d4
   Accent:    #f59e0b
   Success:   #16a34a
   Danger:    #dc2626

   Background: #f6f7fb
   Surface:    #ffffff
   Border:     #e5e7eb
   Text:       #1f2933
   Muted:      #6b7280

   Gradients:
     --gradient-primary: linear-gradient(135deg, #4f46e5, #06b6d4)
     --gradient-accent:  linear-gradient(135deg, #f59e0b, #f97316)
*/

/* ---------- Base Reset ---------- */
*,
*::before,
*::after { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; text-size-adjust: 100%; }
body { margin: 0; line-height: 1.5; }

img, svg, video { max-width: 100%; height: auto; display: block; }
button, input, select, textarea { font: inherit; }
a { color: inherit; text-decoration: none; }

/* ---------- Theme (matches previous app) ---------- */
:root{
  /* Brand Colors */
  --primary: #4f46e5;
  --primaryHover: #4338ca;
  --primaryFocus: #4f46e5;

  --secondary: #06b6d4;
  --secondaryHover: #0891b2;

  --accent: #f59e0b;
  --accentHover: #d97706;

  --ok: #16a34a;
  --danger: #dc2626;
  --info: #06b6d4;
  --warn: #f59e0b;

  /* Neutral Colors */
  --bg: #f6f7fb;
  --card: #ffffff;
  --card2: #ffffff;

  --stroke: #e5e7eb;
  --strokeSoft: rgba(229,231,235,.85);

  --text: #1f2933;
  --mutedText: #6b7280;

  /* Gradients */
  --gradientPrimary: linear-gradient(135deg, #4f46e5, #06b6d4);
  --gradientAccent: linear-gradient(135deg, #f59e0b, #f97316);

  /* Domain colors (optional) */
  --d-self: #4f46e5;
  --d-empathy: #16a34a;
  --d-reg: #06b6d4;
  --d-social: #a855f7;

  /* Shadows */
  --shadow: 0 6px 14px rgba(0,0,0,.08);
  --shadow2: 0 12px 24px rgba(0,0,0,.12);

  /* Radius */
  --r: 18px;

  /* Focus */
  --focus: rgba(79,70,229,.65);
  --focusRing: rgba(79,70,229,.18);

  /* Motion */
  --tFast: .2s ease-in-out;
  --tNorm: .3s ease-in-out;
}

/* Apply to pages using shared stylesheet */
body.app{
  min-height: 100vh;
  color: var(--text);
  background:
    radial-gradient(900px 520px at 12% 12%, rgba(79,70,229,.14), transparent 55%),
    radial-gradient(820px 520px at 88% 18%, rgba(6,182,212,.12), transparent 55%),
    radial-gradient(750px 520px at 50% 92%, rgba(245,158,11,.10), transparent 55%),
    linear-gradient(180deg, var(--bg), #eef2ff);
}

/* Sinhala readability (mobile + general) */
html[lang="si"] body{ line-height: 1.6; }

/* ---------- Layout ---------- */
.container{
  width: min(1100px, 100%);
  margin: 0 auto;
  padding: 18px;
}
@media (min-width: 768px){
  .container{ padding: 24px; }
}
@media (max-width: 380px){
  .container{ padding: 14px; }
}

.stack{ display: grid; gap: 14px; }

.grid{
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
}

/* ✅ FIX: cols-2 becomes 2 columns from tablets (keeps mobile 1 col) */
@media (min-width: 768px){
  .grid.cols-2{ grid-template-columns: 1.1fr .9fr; }
}
@media (min-width: 920px){
  .grid.cols-3{ grid-template-columns: repeat(3, 1fr); }
}

/* ---------- Top Bar ---------- */
.topbar{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px;
  border: 1px solid var(--strokeSoft);
  border-radius: var(--r);
  background: rgba(255,255,255,.92);
  box-shadow: var(--shadow);
  backdrop-filter: blur(10px);
}

.brand{
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
}

.logo{
  width: 44px;
  height: 44px;
  border-radius: 14px;
  background: var(--gradientPrimary);
  box-shadow: 0 10px 20px rgba(79,70,229,.18);
  position: relative;
  flex: 0 0 auto;
}
.logo::after{
  content:"";
  position:absolute;
  inset:2px;
  border-radius:12px;
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(229,231,235,.9);
}

.brandTitle{
  margin: 0;
  font-size: 16px;
  line-height: 1.2;
  font-weight: 800;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  color: var(--text);
}
.brandSub{
  margin: 4px 0 0 0;
  font-size: 12px;
  color: var(--mutedText);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.topActions{
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: flex-end;
  align-items: center;
}

/* ✅ ADDED: pill styles used by index.php */
.pill{
  display:flex;
  gap:8px;
  align-items:center;
  padding:10px;
  border-radius:16px;
  border:1px solid var(--strokeSoft);
  background: rgba(255,255,255,.70);
}
.pillLabel{
  font-size:12px;
  color: var(--mutedText);
  font-weight: 800;
}

/* ✅ Mobile topbar fixes */
@media (max-width: 560px){
  .topbar{ flex-direction: column; align-items: stretch; }
  .topActions{ width: 100%; justify-content: space-between; }
  .pill{ width: 100%; }
  .pillLabel{ display:none; }        /* cleaner on small screens */
  .pill .btn.small{ flex: 1; }       /* segmented feel */
}

/* ---------- Cards ---------- */
.card{
  border: 1px solid var(--strokeSoft);
  border-radius: var(--r);
  background: var(--card);
  box-shadow: var(--shadow);
  padding: 14px;
}
@media (min-width: 768px){
  .card{ padding: 16px; }
}

.cardTitle{
  margin: 0 0 8px 0;
  font-size: 18px;
  font-weight: 900;
  color: var(--text);
}
.cardSub{
  margin: 0;
  color: var(--mutedText);
  font-size: 13px;
}

.note{
  margin-top: 12px;
  padding: 12px;
  border-radius: 16px;
  border: 1px dashed rgba(6,182,212,.35);
  background: rgba(6,182,212,.08);
  color: var(--text);
}

/* ---------- Buttons ---------- */
.btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 10px 12px;
  border-radius: 14px;
  border: 2px solid var(--stroke);
  background: #ffffff;
  color: var(--text);
  cursor: pointer;
  font-weight: 700;
  transition: transform var(--tFast), background var(--tFast), opacity var(--tFast), border-color var(--tFast), color var(--tFast), box-shadow var(--tFast);
  user-select: none;
  -webkit-tap-highlight-color: transparent;
  box-shadow: 0 2px 4px rgba(0,0,0,.05);
}

/* ✅ Hover only on hover-capable devices (prevents jumpy tap-hover on mobile) */
@media (hover:hover) and (pointer:fine){
  .btn:hover{
    transform: translateY(-1px);
    box-shadow: 0 6px 14px rgba(0,0,0,.10);
    border-color: rgba(79,70,229,.35);
  }
  .btn:active{ transform: translateY(0px); }
}

.btn.primary{
  border: none;
  background: var(--gradientPrimary);
  color: #FFFFFF;
  font-weight: 800;
}
.btn.primary:hover{ filter: brightness(1.02); }

.btn.accent{
  border: none;
  background: var(--gradientAccent);
  color: #FFFFFF;
  font-weight: 800;
}
.btn.accent:hover{ filter: brightness(1.02); }

.btn.small{
  padding: 9px 10px;
  border-radius: 12px;
  font-size: 13px;
}

.btn.disabled,
.btn:disabled{
  opacity: .6;
  cursor: not-allowed;
  transform: none !important;
  box-shadow: 0 2px 4px rgba(0,0,0,.05) !important;
  filter: none !important;
}

.btn.ok{
  border: none;
  background: linear-gradient(135deg, #16a34a, #22c55e);
  color: #fff;
}
.btn.bad{
  border: none;
  background: linear-gradient(135deg, #dc2626, #ef4444);
  color: #fff;
}
.btn.warn{
  border: none;
  background: var(--gradientAccent);
  color: #fff;
}

/* Better touch targets on mobile */
@media (max-width: 520px){
  .btn{ padding: 12px 14px; border-radius: 16px; }
  .btn.small{ padding: 11px 12px; border-radius: 14px; }
}

/* ---------- Forms ---------- */
.form{ display: grid; gap: 10px; margin-top: 12px; }

.field label{
  display: block;
  margin-bottom: 6px;
  font-size: 12px;
  color: var(--mutedText);
  font-weight: 700;
}

.input,
input[type="text"],
input[type="email"],
input[type="password"],
input[type="tel"],
select,
textarea{
  width: 100%;
  padding: 12px 12px;
  border-radius: 14px;
  border: 1px solid var(--stroke);
  background: #FFFFFF;
  color: var(--text);
  outline: none;
  font-size: 16px; /* ✅ prevents iOS zoom */
}

.input:focus,
input:focus,
select:focus,
textarea:focus{
  border-color: rgba(79,70,229,.55);
  box-shadow: 0 0 0 4px var(--focusRing);
}

select{
  appearance: none;
  background-image:
    linear-gradient(45deg, transparent 50%, rgba(31,41,51,.55) 50%),
    linear-gradient(135deg, rgba(31,41,51,.55) 50%, transparent 50%);
  background-position:
    calc(100% - 16px) 50%,
    calc(100% - 11px) 50%;
  background-size: 6px 6px, 6px 6px;
  background-repeat: no-repeat;
  padding-right: 34px;
}

.actions{
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items: center;
  margin-top: 12px;
}

/* ---------- Toast / Alerts ---------- */
.toast{
  margin-top: 10px;
  padding: 12px;
  border-radius: 16px;
  border: 1px solid var(--strokeSoft);
  background: #ffffff;
  color: var(--text);
  display: none;
  box-shadow: var(--shadow);
}
.toast.show{ display: block; }

.toast.ok{
  border-color: rgba(22,163,74,.30);
  background: rgba(22,163,74,.08);
}
.toast.bad{
  border-color: rgba(220,38,38,.30);
  background: rgba(220,38,38,.08);
}
.toast.warn{
  border-color: rgba(245,158,11,.35);
  background: rgba(245,158,11,.10);
}
.toast.info{
  border-color: rgba(6,182,212,.35);
  background: rgba(6,182,212,.10);
}

/* ---------- Feature Cards ---------- */

/* ✅ ADDED: header row + chips used in index.php */
.featuresHeader{
  display:flex;
  justify-content: space-between;
  align-items:flex-start;
  gap: 12px;
}
@media (max-width: 560px){
  .featuresHeader{ flex-direction: column; }
}

.chip{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding: 8px 10px;
  border-radius: 999px;
  border: 1px solid var(--strokeSoft);
  background: rgba(245,158,11,.12);
  font-weight: 900;
  font-size: 12px;
  color: #92400e;
  white-space: nowrap;
}
.chip.ok{
  background: rgba(22,163,74,.10);
  color: #166534;
}
.dot{
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: var(--accent);
}
.chip.ok .dot{ background: var(--ok); }

.cards{
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
  margin-top: 12px;
}
@media (min-width: 560px){
  .cards{ grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 920px){
  .cards{ grid-template-columns: repeat(3, 1fr); }
}

.fcard{
  position: relative;
  overflow: hidden;
  min-height: 122px;
  padding: 14px;
  border-radius: 18px;
  border: 1px solid var(--strokeSoft);
  background: #FFFFFF;
  box-shadow: var(--shadow);
  transition: transform var(--tFast), box-shadow var(--tFast), border-color var(--tFast);
}
.fcard::before{
  content:"";
  position:absolute; inset:-2px;
  background:
    radial-gradient(320px 140px at 18% 0%, rgba(79,70,229,.18), transparent 60%),
    radial-gradient(320px 150px at 84% 12%, rgba(6,182,212,.16), transparent 62%),
    radial-gradient(320px 150px at 32% 110%, rgba(245,158,11,.12), transparent 60%);
  opacity: .95;
  pointer-events:none;
}
.fcard > *{ position: relative; }

/* ✅ Hover only on hover-capable devices */
@media (hover:hover) and (pointer:fine){
  .fcard:hover{
    transform: translateY(-6px);
    box-shadow: var(--shadow2);
    border-color: rgba(79,70,229,.25);
  }
}

.fcardTitle{
  margin: 10px 0 6px 0;
  font-size: 15px;
  font-weight: 900;
  color: var(--text);
}

.fcardDesc{
  margin: 0;
  font-size: 13px;
  color: var(--mutedText);
}

/* Tag pills */
.tag{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 7px 10px;
  border-radius: 999px;
  border: 1px solid var(--stroke);
  background: rgba(79,70,229,.06);
  color: #3730a3;
  font-weight: 800;
  font-size: 12px;
}
.tag.cyan{
  background: rgba(6,182,212,.10);
  border-color: rgba(6,182,212,.25);
  color: #0e7490;
}
.tag.gold{
  background: rgba(245,158,11,.16);
  border-color: rgba(245,158,11,.28);
  color: #92400e;
}
.tag.green{
  background: rgba(22,163,74,.12);
  border-color: rgba(22,163,74,.22);
  color: #166534;
}
.tag.red{
  background: rgba(220,38,38,.10);
  border-color: rgba(220,38,38,.22);
  color: #991b1b;
}

/* ✅ Mobile density fix: collapse details under 560px (accordion via JS .is-open) */
@media (max-width: 560px){
  .fcardDetails{ display:none; }
  .fcard.is-open .fcardDetails{ display:block; margin-top: 10px; }
}

/* ---------- Table (mobile friendly) ---------- */
.tableWrap{
  width: 100%;
  overflow: auto;
  border-radius: 16px;
  border: 1px solid var(--strokeSoft);
  background: #FFFFFF;
  box-shadow: var(--shadow);
}
table{
  width: 100%;
  border-collapse: collapse;
  min-width: 640px;
}
th, td{
  padding: 10px;
  border-bottom: 1px solid var(--stroke);
  text-align: left;
  font-size: 13px;
  color: var(--text);
}
th{
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--mutedText);
  font-weight: 900;
  background: #f1f5f9;
}
tr:hover td{ background: rgba(79,70,229,.04); }

/* ---------- EQ Question Blocks ---------- */
.q{
  border: 1px solid var(--strokeSoft);
  background: #FFFFFF;
  border-radius: 16px;
  padding: 12px;
  margin-top: 10px;
  box-shadow: var(--shadow);
}
.qTitle{
  font-weight: 900;
  font-size: 14px;
  margin-bottom: 10px;
  color: var(--text);
}

.opts{ display: grid; gap: 8px; }

.opt{
  display:flex;
  align-items:center;
  gap: 10px;
  padding: 10px 10px;
  border-radius: 14px;
  border: 2px solid var(--stroke);
  background: #FFFFFF;
  cursor: pointer;
  user-select: none;
  transition: var(--tFast);
  -webkit-tap-highlight-color: transparent;
}

/* ✅ Hover only on hover-capable devices */
@media (hover:hover) and (pointer:fine){
  .opt:hover{
    border-color: rgba(79,70,229,.45);
    box-shadow: 0 6px 14px rgba(0,0,0,.08);
    transform: translateY(-1px);
  }
}

input[type="radio"]{
  width: 18px;
  height: 18px;
  accent-color: var(--primary);
}

/* Selection (supports both CSS :has and JS .selected) */
.opt.selected{
  background: var(--gradientPrimary);
  color: #fff;
  border-color: transparent;
}
.opt.selected input[type="radio"]{ accent-color: #fff; }

.opt:has(input[type="radio"]:checked){
  background: var(--gradientPrimary);
  color: #fff;
  border-color: transparent;
}
.opt:has(input[type="radio"]:checked) input[type="radio"]{ accent-color: #fff; }

/* ---------- KPI / Charts ---------- */
.kpi{
  display:grid;
  grid-template-columns: 1fr;
  gap: 10px;
  margin-top: 12px;
}
@media (min-width: 560px){
  .kpi{ grid-template-columns: repeat(3, 1fr); }
}
.k{
  border: 1px solid var(--strokeSoft);
  background: #FFFFFF;
  border-radius: 16px;
  padding: 12px;
  box-shadow: var(--shadow);
}
.kValue{ font-size: 20px; font-weight: 900; color: var(--text); }
.kLabel{ font-size: 12px; color: var(--mutedText); margin-top: 2px; font-weight: 700; }

.chartWrap{
  margin-top: 12px;
  border: 1px solid var(--strokeSoft);
  background: #FFFFFF;
  border-radius: 16px;
  padding: 12px;
  box-shadow: var(--shadow);
}

/* ---------- Accessibility ---------- */
:focus-visible{
  outline: none;
  box-shadow: 0 0 0 4px var(--focusRing);
  border-color: var(--focus);
}

/* ---------- Small helpers ---------- */
.center{ text-align:center; }
.mt-8{ margin-top: 8px; }
.mt-12{ margin-top: 12px; }
.mt-16{ margin-top: 16px; }
.muted{ color: var(--mutedText); }
.footer{
  margin-top: 18px;
  color: var(--mutedText);
  font-size: 12px;
  text-align: center;
}

/* ---------- Reduce motion ---------- */
@media (prefers-reduced-motion: reduce){
  *{ transition: none !important; scroll-behavior: auto !important; }
}
