/* ═══════════════════════════════════════════════════════════════
   ProfTutoring Pillar Pages — dedicated styles v1
   Layered on top of styles.css
   ═══════════════════════════════════════════════════════════════ */

body.pillar-subject, body.pillar-language, body.pillar-special{background:var(--cream)}

/* ═══════ BREADCRUMB ═══════ */
.breadcrumb{padding:calc(var(--header-h) + var(--s-5)) 0 var(--s-3);background:var(--paper);font-size:13px;color:var(--ink-50);border-bottom:1px solid var(--border)}
.breadcrumb .container{display:flex;align-items:center;gap:var(--s-2);flex-wrap:wrap}
.breadcrumb a{color:var(--ink-50);transition:color var(--t-fast)}
.breadcrumb a:hover{color:var(--g3)}
.breadcrumb .bc-sep{color:var(--ink-30)}
.breadcrumb span:last-child{color:var(--ink);font-weight:600}

/* ═══════ PILLAR HERO ═══════ */
.pillar-hero{
  position:relative;
  padding:var(--s-11) 0 var(--s-13);
  background:linear-gradient(180deg,var(--ink) 0%,var(--ink-90) 100%);
  color:var(--cream);
  overflow:hidden;
  isolation:isolate;
}
.pillar-hero-bg{position:absolute;inset:0;z-index:0;overflow:hidden}
.pillar-hero-bg .orb{mix-blend-mode:screen}

/* Cosmic star field over pillar hero */
.pillar-hero-bg::after{
  content:"";position:absolute;inset:0;
  background-image:
    radial-gradient(1.5px 1.5px at 15% 25%, rgba(249,200,67,.75), transparent 50%),
    radial-gradient(1px 1px at 55% 15%, rgba(255,253,247,.65), transparent 50%),
    radial-gradient(1.5px 1.5px at 80% 45%, rgba(249,200,67,.6), transparent 50%),
    radial-gradient(1px 1px at 30% 75%, rgba(255,253,247,.75), transparent 50%),
    radial-gradient(2px 2px at 70% 80%, rgba(249,200,67,.85), transparent 50%),
    radial-gradient(1px 1px at 8% 85%, rgba(255,253,247,.6), transparent 50%),
    radial-gradient(1.5px 1.5px at 45% 10%, rgba(240,112,32,.65), transparent 50%),
    radial-gradient(1px 1px at 92% 8%, rgba(255,253,247,.7), transparent 50%),
    radial-gradient(1.5px 1.5px at 25% 50%, rgba(249,200,67,.7), transparent 50%),
    radial-gradient(1px 1px at 65% 60%, rgba(255,253,247,.65), transparent 50%);
  background-size:100% 100%;
  opacity:.55;
  animation:pillarTwinkle 5s ease-in-out infinite;
  pointer-events:none;
}
@keyframes pillarTwinkle{
  0%,100%{opacity:.35;transform:scale(1)}
  50%{opacity:.75;transform:scale(1.02)}
}

/* Light rays glow from bottom of pillar hero */
.pillar-hero::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(ellipse 80% 40% at 50% 100%, rgba(249,200,67,.14) 0%, transparent 60%),
    radial-gradient(ellipse 40% 30% at 20% 100%, rgba(240,112,32,.1) 0%, transparent 60%),
    radial-gradient(ellipse 30% 25% at 80% 100%, rgba(249,200,67,.08) 0%, transparent 60%);
  pointer-events:none;
  z-index:1;
  animation:pillarRayPulse 7s ease-in-out infinite;
}
@keyframes pillarRayPulse{
  0%,100%{opacity:.7}
  50%{opacity:1}
}
.pillar-hero-inner{position:relative;z-index:1;max-width:920px;margin:0 auto;padding:0 var(--s-6)}

.pillar-hero-image{
  position:relative;
  width:100%;
  max-width:720px;
  margin:0 auto var(--s-7);
  border-radius:28px;
  overflow:hidden;
  box-shadow:0 20px 60px rgba(0,0,0,.45),0 0 40px rgba(249,200,67,.12),inset 0 0 0 1px rgba(249,200,67,.15);
  animation:heroImgReveal 1.1s cubic-bezier(.25,.8,.25,1) both;
}
.pillar-hero-image::before{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 0%,transparent 55%,rgba(26,23,19,.45) 100%);
  z-index:2;
  pointer-events:none;
}
.pillar-hero-image img{
  display:block;
  width:100%;
  height:auto;
  aspect-ratio:3/2;
  object-fit:cover;
  transform:scale(1.02);
  transition:transform 8s ease-out;
  filter:contrast(1.04) saturate(1.08);
}
.pillar-hero-image:hover img{transform:scale(1.05)}
@keyframes heroImgReveal{
  from{opacity:0;transform:translateY(24px) scale(.96);filter:blur(8px)}
  to{opacity:1;transform:translateY(0) scale(1);filter:blur(0)}
}
@media (max-width:640px){
  .pillar-hero-image{border-radius:18px;margin-bottom:var(--s-5)}
}

.pillar-eyebrow{
  display:inline-flex;align-items:center;gap:var(--s-3);
  padding:var(--s-2) var(--s-4);
  background:rgba(255,253,247,.08);
  backdrop-filter:blur(12px);
  border:1px solid rgba(255,253,247,.18);
  border-radius:var(--r-round);
  font:600 12px/1 var(--font-sans);
  letter-spacing:.12em;text-transform:uppercase;
  color:var(--g1);
  margin-bottom:var(--s-6);
}
.pillar-eyebrow .eyebrow-dot{width:8px;height:8px;border-radius:50%;background:var(--g1);box-shadow:0 0 14px var(--g1);animation:pulseDot 2s ease-in-out infinite}

.pillar-h1{
  font-family:var(--font-serif);
  font-weight:400;
  font-size:clamp(36px, 5.5vw, 72px);
  line-height:1.05;
  letter-spacing:-.022em;
  margin-bottom:var(--s-5);
  color:var(--cream);
  text-wrap:balance;
}
.pillar-h1 em{
  font-style:italic;
  background:linear-gradient(120deg,var(--g1) 0%,#FFDD7A 50%,var(--g2) 100%);
  background-size:200% 100%;
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
  animation:textShimmer 5s ease-in-out infinite;
}

.pillar-lead{
  font-size:clamp(16px,1.9vw,22px);
  line-height:1.55;
  color:rgba(255,253,247,.85);
  margin-bottom:var(--s-8);
  max-width:720px;
}

.pillar-cta-row{display:flex;gap:var(--s-4);flex-wrap:wrap;align-items:center;margin-bottom:var(--s-8)}
.pillar-cta-row .btn-ghost-gold{color:rgba(255,253,247,.85);border-color:rgba(255,253,247,.3)}
.pillar-cta-row .btn-ghost-gold:hover{border-color:var(--g1);color:var(--g1);background:rgba(249,200,67,.08)}

.pillar-trust{
  display:flex;gap:var(--s-8);flex-wrap:wrap;
  padding:var(--s-5) 0;
  border-top:1px solid rgba(255,253,247,.12);
  border-bottom:1px solid rgba(255,253,247,.12);
  margin-bottom:var(--s-7);
  list-style:none;
}
.pillar-trust li{display:flex;flex-direction:column;gap:2px}
.pillar-trust strong{font-family:var(--font-accent);font-size:clamp(20px,2.2vw,26px);color:var(--g1);line-height:1;font-variant-numeric:tabular-nums}
.pillar-trust span{font-size:12px;color:rgba(255,253,247,.65);text-transform:uppercase;letter-spacing:.08em}

.pillar-testi-inline{
  max-width:720px;
  padding:var(--s-5) var(--s-6);
  background:rgba(255,253,247,.05);
  backdrop-filter:blur(10px);
  border-left:3px solid var(--g1);
  border-radius:var(--r-s);
}
.pillar-testi-inline p{
  font-family:var(--font-accent);
  font-style:italic;
  font-size:clamp(16px,1.7vw,20px);
  line-height:1.5;
  color:rgba(255,253,247,.94);
  margin-bottom:var(--s-3);
}
.pillar-testi-inline p strong{color:var(--g1);font-weight:600;font-style:italic}
.pillar-testi-inline footer{font-size:13px;color:rgba(255,253,247,.6)}
.pillar-testi-inline footer strong{color:var(--cream);font-weight:700}

/* ═══════ INTRO SECTION ═══════ */
.pillar-intro-section{padding:var(--s-13) 0;background:var(--cream)}
.pillar-body{max-width:820px;margin:0 auto;padding:0 var(--s-6)}
.pillar-intro{position:relative}
.intro-card{
  background:var(--white);
  border:1px solid var(--border);
  border-radius:var(--r-xl);
  padding:var(--s-10) var(--s-8);
  box-shadow:var(--sh-2);
  position:relative;
}
.intro-card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:4px;
  background:var(--grad-primary);
  border-radius:var(--r-xl) var(--r-xl) 0 0;
}
.intro-card p{
  font-size:17px;
  line-height:1.8;
  color:var(--ink-70);
  margin-bottom:var(--s-5);
}
.intro-card p:first-of-type::first-letter{
  font-family:var(--font-serif);
  font-size:72px;
  font-weight:400;
  float:left;
  line-height:.85;
  padding:8px 14px 0 0;
  color:var(--g2);
}
.intro-card p:last-child{margin-bottom:0}
.intro-card strong{color:var(--ink);font-weight:700}
@media (max-width:720px){
  .intro-card{padding:var(--s-7) var(--s-5)}
  .intro-card p:first-of-type::first-letter{font-size:56px;padding:4px 10px 0 0}
}

/* ═══════ FEATURES ═══════ */
.pillar-features{padding:var(--s-13) 0;background:linear-gradient(180deg,var(--cream) 0%,var(--paper) 100%)}
.pillar-features:nth-of-type(even){background:var(--paper)}
.feat-grid{display:grid;grid-template-columns:1fr;gap:var(--s-5);max-width:1100px;margin:0 auto}
@media (min-width:720px){.feat-grid{grid-template-columns:1fr 1fr}}

.feat-card{
  position:relative;
  background:var(--white);
  border:1px solid var(--border);
  border-radius:var(--r-xl);
  padding:var(--s-7);
  box-shadow:var(--sh-1);
  transition:transform var(--t-spring),box-shadow var(--t-std),border-color var(--t-std);
  overflow:hidden;
}
.feat-card::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--grad-primary);transform:scaleX(0);transform-origin:left;transition:transform var(--t-std)}
.feat-card:hover{transform:translateY(-6px);border-color:var(--g1);box-shadow:var(--sh-3)}
.feat-card:hover::before{transform:scaleX(1)}
.feat-num{
  font-family:var(--font-accent);
  font-size:56px;font-weight:700;
  line-height:1;
  color:transparent;
  background:var(--grad-primary);
  -webkit-background-clip:text;background-clip:text;
  letter-spacing:-.02em;
  margin-bottom:var(--s-3);
}
.feat-card h3{font-family:var(--font-serif);font-size:24px;line-height:1.2;color:var(--ink);margin-bottom:var(--s-3)}
.feat-card p{font-size:15px;line-height:1.65;color:var(--ink-50)}

/* ═══════ STATS ROW ═══════ */
.pillar-stats{padding:var(--s-11) 0;background:var(--ink);color:var(--cream);position:relative;overflow:hidden}
.pillar-stats::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 50%,rgba(249,200,67,.1) 0%,transparent 60%);pointer-events:none}
.stats-row{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--s-6);text-align:center;list-style:none;max-width:1000px;margin:0 auto;padding:0 var(--s-6);position:relative}
@media (min-width:720px){.stats-row{grid-template-columns:repeat(4,1fr)}}
.stats-row strong{display:block;font-family:var(--font-accent);font-size:clamp(44px,6vw,72px);font-weight:700;color:var(--g1);line-height:1;letter-spacing:-.02em;margin-bottom:var(--s-3);text-shadow:0 0 40px rgba(249,200,67,.3);font-variant-numeric:tabular-nums}
.stats-row span{display:block;font-size:13px;color:rgba(255,253,247,.65);text-transform:uppercase;letter-spacing:.08em;line-height:1.4}

/* ═══════ PROCESS STEPS (3 kroki) ═══════ */
.pillar-process{padding:var(--s-13) 0;background:var(--cream)}
.process-steps{display:grid;grid-template-columns:1fr;gap:var(--s-7);max-width:1100px;margin:0 auto;list-style:none;padding:0 var(--s-6)}
@media (min-width:720px){.process-steps{grid-template-columns:repeat(3,1fr)}}

.p-step{
  position:relative;
  background:var(--white);
  border:1px solid var(--border);
  border-radius:var(--r-xl);
  padding:var(--s-8) var(--s-6);
  box-shadow:var(--sh-1);
  text-align:center;
  transition:transform var(--t-spring),box-shadow var(--t-std);
}
.p-step:hover{transform:translateY(-6px);box-shadow:var(--sh-3)}
.p-num{
  display:inline-flex;align-items:center;justify-content:center;
  width:64px;height:64px;border-radius:50%;
  background:var(--grad-primary);
  color:var(--white);
  font-family:var(--font-serif);font-size:28px;font-weight:700;
  box-shadow:var(--sh-gold);
  margin-bottom:var(--s-4);
}
.p-step h3{font-family:var(--font-serif);font-size:22px;line-height:1.2;color:var(--ink);margin-bottom:var(--s-3)}
.p-step p{font-size:15px;line-height:1.55;color:var(--ink-50)}

/* ═══════ PAIN POINTS ═══════ */
.pillar-pain{padding:var(--s-13) 0;background:var(--paper)}
.pain-list{max-width:780px;margin:0 auto;padding:0 var(--s-6);list-style:none}
.pain-item{
  display:flex;align-items:flex-start;gap:var(--s-4);
  padding:var(--s-5);
  background:var(--white);
  border:1px solid var(--border);
  border-left:4px solid var(--err);
  border-radius:var(--r-l);
  margin-bottom:var(--s-4);
  box-shadow:var(--sh-1);
}
.pain-icon{
  flex-shrink:0;
  width:32px;height:32px;
  border-radius:50%;
  background:rgba(220,38,38,.1);
  color:var(--err);
  display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:16px;
}
.pain-item span:last-child{font-size:16px;line-height:1.55;color:var(--ink-70)}

/* ═══════ LEVELS (languages) ═══════ */
.levels-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--s-4);max-width:900px;margin:0 auto;padding:0 var(--s-6)}
@media (min-width:560px){.levels-grid{grid-template-columns:repeat(3,1fr)}}
@media (min-width:900px){.levels-grid{grid-template-columns:repeat(6,1fr);gap:var(--s-3)}}
.level-card{
  padding:var(--s-5);
  background:var(--white);
  border:1.5px solid var(--border);
  border-radius:var(--r-l);
  text-align:center;
  font-family:var(--font-serif);
  font-size:20px;
  color:var(--g3);
  box-shadow:var(--sh-1);
  transition:transform var(--t-spring),border-color var(--t-std);
}
.level-card:hover{transform:translateY(-4px);border-color:var(--g1)}

/* ═══════ FAQ ═══════ */
.pillar-faq{padding:var(--s-13) 0;background:var(--cream)}
.faq-grid{max-width:820px;margin:0 auto;padding:0 var(--s-6)}
.faq-item{
  background:var(--white);
  border:1px solid var(--border);
  border-radius:var(--r-l);
  margin-bottom:var(--s-3);
  box-shadow:var(--sh-1);
  overflow:hidden;
  transition:box-shadow var(--t-std),border-color var(--t-std);
}
.faq-item:hover{box-shadow:var(--sh-2);border-color:rgba(249,200,67,.3)}
.faq-item[open]{border-color:var(--g1);box-shadow:var(--sh-2)}
.faq-item summary{
  padding:var(--s-5) var(--s-6);
  font-family:var(--font-serif);
  font-size:18px;
  line-height:1.3;
  color:var(--ink);
  cursor:pointer;
  list-style:none;
  position:relative;
  padding-right:var(--s-9);
  transition:background var(--t-fast);
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{
  content:"+";
  position:absolute;right:var(--s-5);top:50%;
  transform:translateY(-50%);
  width:32px;height:32px;
  border-radius:50%;
  background:var(--paper);
  display:flex;align-items:center;justify-content:center;
  font-size:24px;font-weight:300;
  color:var(--g3);
  transition:transform var(--t-spring),background var(--t-std);
}
.faq-item[open] summary::after{transform:translateY(-50%) rotate(45deg);background:var(--grad-primary);color:var(--white)}
.faq-item:hover summary{background:var(--cream-2)}
.faq-answer{padding:0 var(--s-6) var(--s-5);font-size:15px;line-height:1.7;color:var(--ink-70);animation:faqOpen .3s var(--ease-out)}
.faq-answer strong{color:var(--ink);font-weight:700}
.faq-answer a{color:var(--g3);font-weight:600;text-decoration:underline}
@keyframes faqOpen{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}

/* ═══════ TESTI (dedicated) ═══════ */
.pillar-testi{padding:var(--s-11) 0;background:linear-gradient(180deg,var(--paper) 0%,var(--cream) 100%)}
.pillar-testi-inner{
  max-width:820px;margin:0 auto;
  padding:var(--s-10) var(--s-8);
  background:var(--white);
  border:1px solid var(--border);
  border-left:6px solid var(--g1);
  border-radius:var(--r-xl);
  box-shadow:var(--sh-3);
  position:relative;
}
.pillar-testi-inner::before{
  content:""";
  position:absolute;top:var(--s-5);left:var(--s-6);
  font-family:var(--font-serif);font-size:96px;font-weight:700;
  color:var(--g1);opacity:.12;line-height:1;
}
.pillar-testi-inner p{
  font-family:var(--font-accent);
  font-style:italic;
  font-size:clamp(20px,2.4vw,28px);
  line-height:1.55;
  color:var(--ink);
  margin-bottom:var(--s-6);
}
.pillar-testi-inner footer{font-size:14px;color:var(--ink-50)}
.pillar-testi-inner footer strong{color:var(--ink);font-weight:700}

/* ═══════ CTA FINAL ═══════ */
.pillar-cta-final{padding:var(--s-13) 0;background:var(--cream)}
.cta-final-card{
  max-width:820px;margin:0 auto;
  padding:var(--s-12) var(--s-8);
  text-align:center;
  background:linear-gradient(135deg,var(--ink) 0%,var(--ink-90) 100%);
  color:var(--cream);
  border-radius:var(--r-xl);
  position:relative;
  overflow:hidden;
  isolation:isolate;
  box-shadow:0 32px 80px rgba(20,14,9,.3);
}
.cta-final-card::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:radial-gradient(circle at 20% 50%,rgba(249,200,67,.18) 0%,transparent 55%),
             radial-gradient(circle at 80% 50%,rgba(240,112,32,.12) 0%,transparent 55%);
}
.cta-final-card .h2{color:var(--cream);margin-bottom:var(--s-4)}
.cta-final-card .h2 em{color:var(--g1);font-family:var(--font-serif);font-style:italic}
.cta-final-card p{font-size:17px;color:rgba(255,253,247,.78);max-width:500px;margin:0 auto var(--s-7)}
.trust-mini{margin-top:var(--s-5) !important;font-size:13px !important;color:rgba(255,253,247,.45) !important;letter-spacing:.04em}

/* ═══════ RELATED ═══════ */
.pillar-related{padding:var(--s-9) 0 var(--s-13);background:var(--paper)}
.pillar-related h3{font-family:var(--font-serif);font-size:24px;color:var(--ink);margin-bottom:var(--s-5);text-align:center;padding:0 var(--s-6)}
.related-grid{display:flex;flex-wrap:wrap;gap:var(--s-3);justify-content:center;max-width:900px;margin:0 auto;padding:0 var(--s-6)}
.related-pill{
  display:inline-flex;align-items:center;
  padding:var(--s-3) var(--s-5);
  background:var(--white);
  border:1.5px solid var(--border);
  border-radius:var(--r-round);
  color:var(--ink);
  font-size:14px;font-weight:600;
  transition:transform var(--t-spring),border-color var(--t-std),background var(--t-std);
}
.related-pill:hover{transform:translateY(-3px);border-color:var(--g1);background:var(--cream-2);color:var(--g3)}

/* ═══════ SECTION HEADER ═══════ */
.section-header{text-align:center;max-width:780px;margin:0 auto var(--s-10);padding:0 var(--s-6)}
.section-header .eyebrow{margin-bottom:var(--s-4)}
.section-header .h2{font-family:var(--font-serif);font-size:clamp(28px,4vw,52px);line-height:1.1;color:var(--ink);margin-bottom:var(--s-3)}
.section-header .h2 em{color:var(--g2);font-style:italic}

/* ═══════ MOBILE ADJUSTMENTS ═══════ */
@media (max-width:720px){
  .pillar-hero{padding:var(--s-8) 0 var(--s-10)}
  .pillar-trust{gap:var(--s-4)}
  .intro-card{padding:var(--s-6) var(--s-4)}
  .intro-card p{font-size:16px;line-height:1.7}
  .feat-card{padding:var(--s-5)}
  .feat-num{font-size:40px}
  .feat-card h3{font-size:20px}
  .cta-final-card{padding:var(--s-9) var(--s-5);border-radius:var(--r-l)}
  .p-step{padding:var(--s-6) var(--s-5)}
  .p-num{width:52px;height:52px;font-size:22px}
  .pillar-testi-inner{padding:var(--s-7) var(--s-5)}
  .faq-item summary{padding:var(--s-4) var(--s-5);padding-right:var(--s-8);font-size:16px}
  .faq-item summary::after{width:28px;height:28px;font-size:20px}
}
