/* Vibe-coding course page. Mobile-first. Cream paper + ink, lime strategic accent.
   Scoped under .vibe-page; reuses global .cp-nav / .site-footer / .brand. */
.vibe-page{background:#F4F3EE;color:#15181C;font-family:'Inter Tight','Inter',system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;-webkit-font-smoothing:antialiased;margin:0}
.vibe-page *{box-sizing:border-box}
.vibe-page .wrap{max-width:1180px;margin-inline:auto;padding-inline:clamp(20px,5vw,48px);width:100%}
.vibe-page img{max-width:100%;height:auto;display:block}

/* reveal */
.vibe-page [data-reveal]{opacity:0;transform:translateY(18px);transition:opacity .5s ease,transform .5s ease}
.vibe-page [data-reveal].is-in{opacity:1;transform:none}

/* buttons */
.vc-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:#C8F03C;color:#161a08;border:none;border-radius:14px;padding:14px 24px;font-weight:700;font-size:16px;font-family:inherit;min-height:50px;cursor:pointer;text-decoration:none;line-height:1.2;transition:background .15s,box-shadow .2s,transform .06s;width:100%}
.vc-btn:hover{background:#d4f857;box-shadow:0 10px 24px -12px rgba(151,179,46,.7)}
.vc-btn:active{transform:translateY(1px)}
.vc-btn-lg{padding:16px 28px;font-size:17px;min-height:56px}
.vc-btn-ghost{background:transparent;border:1.5px solid #CFCDC2;color:#15181C}
.vc-btn-ghost:hover{background:#15181C;color:#fff;border-color:#15181C;box-shadow:none}

/* section rhythm */
.vc-sec{padding:clamp(48px,8vw,88px) 0}
.vc-sec-alt{background:#fff;border-block:1px solid #E8E6DD}
.vc-sec h2{font-size:clamp(24px,4.4vw,38px);line-height:1.12;letter-spacing:-.02em;margin:0 0 clamp(22px,3vw,34px);max-width:18ch;font-weight:800}
.vc-eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:12px;color:#6A7178;text-transform:uppercase;letter-spacing:.12em;margin-bottom:14px;font-weight:600}
.vc-eyebrow::before{content:"";width:22px;height:2px;background:#C8F03C;border-radius:2px}
.vc-sec-lead{color:#3A4048;font-size:clamp(16px,1.6vw,19px);line-height:1.55;max-width:680px;margin:-8px 0 28px}
.vc-sec h2{max-width:24ch}

/* hero */
.vc-hero{padding:clamp(40px,7vw,80px) 0 clamp(36px,6vw,64px);background:radial-gradient(120% 80% at 100% 0,#EEF7D6 0,#F4F3EE 55%)}
.vc-plate{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid #E2E0D7;border-radius:999px;padding:8px 16px;font-size:13px;font-weight:600;color:#15181C;margin-bottom:20px}
.vc-hero h1{font-size:clamp(30px,7vw,58px);line-height:1.04;letter-spacing:-.03em;margin:0 0 18px;font-weight:800;max-width:16ch}
.vc-lead{font-size:clamp(16px,2.2vw,21px);color:#3A4048;line-height:1.5;margin:0 0 16px;max-width:620px}
.vc-hero-strong{font-size:clamp(16px,2vw,20px);font-weight:700;color:#15181C;margin:0 0 24px;max-width:560px}
.vc-chips{display:flex;flex-wrap:wrap;gap:9px;margin-bottom:28px}
.vc-chip{display:inline-flex;align-items:center;background:#fff;border:1px solid #E2E0D7;border-radius:999px;padding:8px 14px;font-size:13.5px;color:#3A4048;font-weight:500}
.vc-hero-cta{max-width:420px}
.vc-hero-fine{margin:14px 0 0;font-size:13.5px;color:#6A7178}

/* portraits */
.vc-portraits{display:grid;grid-template-columns:1fr;gap:16px}
.vc-portrait{background:#fff;border:1px solid #E2E0D7;border-top:4px solid #C8F03C;border-radius:18px;padding:24px 22px}
.vc-sec-alt .vc-portrait{background:#F4F3EE}
.vc-portrait h3{margin:0 0 10px;font-size:18px;font-weight:700;letter-spacing:-.01em}
.vc-portrait p{margin:0;color:#3A4048;font-size:15px;line-height:1.5}
.vc-notfor{margin-top:26px;background:#15181C;color:#E9EAEC;border-radius:18px;padding:24px 24px 20px}
.vc-notfor-h{font-weight:700;font-size:16px;margin-bottom:12px;color:#fff}
.vc-notfor ul{margin:0;padding:0;list-style:none}
.vc-notfor li{position:relative;padding:8px 0 8px 28px;font-size:15px;line-height:1.45;color:#C3C7CD;border-top:1px solid #262A31}
.vc-notfor li::before{content:"✕";position:absolute;left:2px;top:8px;color:#7C828B;font-weight:700}

/* cases */
.vc-cases{display:grid;grid-template-columns:1fr;gap:18px}
.vc-case{background:#fff;border:1px solid #E2E0D7;border-radius:20px;overflow:hidden;display:flex;flex-direction:column}
.vc-sec-alt .vc-case{background:#F4F3EE}
.vc-case-img{aspect-ratio:16/9;background:#0E1116;overflow:hidden}
.vc-case-img img{width:100%;height:100%;object-fit:cover}
.vc-case.no-img .vc-case-img{display:none}
.vc-case-body{padding:22px 22px 24px;display:flex;flex-direction:column;gap:8px}
.vc-case-metric{align-self:flex-start;background:#C8F03C;color:#161a08;font-weight:700;font-size:13px;border-radius:999px;padding:5px 12px}
.vc-case-body h3{margin:0;font-size:19px;font-weight:700;letter-spacing:-.01em;line-height:1.2}
.vc-case-body p{margin:0;color:#3A4048;font-size:15px;line-height:1.5}

/* reviews */
.vc-reviews{display:grid;grid-template-columns:1fr;gap:18px}
.vc-review{margin:0;background:#fff;border:1px solid #E2E0D7;border-radius:18px;padding:22px}
.vc-sec-alt .vc-review{background:#F4F3EE}
.vc-review-ph{width:56px;height:56px;border-radius:50%;overflow:hidden;margin-bottom:14px}
.vc-review-ph img{width:100%;height:100%;object-fit:cover}
.vc-review blockquote{margin:0 0 14px;font-size:16px;line-height:1.55;color:#15181C}
.vc-review figcaption{font-size:14px;color:#6A7178}
.vc-review figcaption b{display:block;color:#15181C;font-size:15px}
.vc-review-metric{display:inline-block;margin-top:6px;color:#2f6f12;font-weight:600}

/* program weeks */
.vc-weeks{display:grid;grid-template-columns:1fr;gap:14px}
.vc-week{display:flex;gap:16px;background:#fff;border:1px solid #E2E0D7;border-radius:16px;padding:20px 22px}
.vc-sec-alt .vc-week{background:#F4F3EE}
.vc-week-n{flex:0 0 auto;font-size:12px;font-weight:700;color:#6A7178;text-transform:uppercase;letter-spacing:.04em;padding-top:3px;min-width:78px}
.vc-week-body{flex:1;min-width:0}
.vc-week-body h3{margin:0 0 10px;font-size:18px;font-weight:700;letter-spacing:-.01em;line-height:1.2}
.vc-week-topics{margin:0 0 12px;padding:0;list-style:none;display:flex;flex-wrap:wrap;gap:7px}
.vc-week-topics li{background:#fff;border:1px solid #ECEAE1;border-radius:999px;padding:5px 12px;font-size:13px;color:#3A4048}
.vc-sec-alt .vc-week-topics li{background:#F4F3EE}
.vc-week-out{font-size:14.5px;color:#15181C;line-height:1.45}
.vc-week-out span{font-weight:700;color:#2f6f12}

/* projects + bonus */
.vc-projects{display:grid;grid-template-columns:1fr;gap:16px;margin-bottom:28px}
.vc-project{background:#fff;border:1px solid #E2E0D7;border-radius:18px;padding:24px 22px}
.vc-sec-alt .vc-project{background:#F4F3EE}
.vc-project-ic{font-size:32px;line-height:1;margin-bottom:14px}
.vc-project h3{margin:0 0 8px;font-size:17px;font-weight:700;letter-spacing:-.01em}
.vc-project p{margin:0;color:#3A4048;font-size:14.5px;line-height:1.5}
.vc-bonus{background:#15181C;color:#E9EAEC;border-radius:20px;padding:26px 24px}
.vc-bonus-h{font-family:var(--mono,'JetBrains Mono',monospace);font-size:13px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#C8F03C;margin-bottom:16px}
.vc-bonus-list{margin:0;padding:0;list-style:none;display:grid;grid-template-columns:1fr;gap:10px}
.vc-bonus-list li{position:relative;padding-left:28px;font-size:15px;line-height:1.4;color:#D7DADF}
.vc-bonus-list li::before{content:"";position:absolute;left:0;top:3px;width:18px;height:18px;border-radius:50%;background:#C8F03C url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='11' viewBox='0 0 24 24' fill='none' stroke='%23161a08' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 12l4 4L19 7'/%3E%3C/svg%3E") center/11px no-repeat}

/* safety */
.vc-safety-grid{display:grid;grid-template-columns:1fr;gap:14px}
.vc-safety-card{background:#fff;border:1px solid #E2E0D7;border-top:4px solid #C8F03C;border-radius:18px;padding:24px 22px}
.vc-sec-alt .vc-safety-card{background:#F4F3EE}
.vc-safety-ic{font-size:30px;line-height:1;margin-bottom:12px}
.vc-safety-card h3{margin:0 0 8px;font-size:17px;font-weight:700;letter-spacing:-.01em}
.vc-safety-card p{margin:0;color:#3A4048;font-size:14.5px;line-height:1.5}

/* understand plate (after hero) — warm beige */
.vc-understand-sec{padding:clamp(28px,4vw,52px) 0}
.vc-understand{background:#F3EEDD;border:1px solid #E8DFC4;border-radius:24px;padding:clamp(26px,4vw,48px)}
.vc-understand h2{margin:0 0 16px;font-size:clamp(22px,3.4vw,32px);line-height:1.15;letter-spacing:-.02em;font-weight:800;max-width:22ch}
.vc-understand p{margin:0 0 14px;font-size:clamp(15px,1.7vw,18px);line-height:1.6;color:#4A4636;max-width:760px}
.vc-understand .vc-understand-strong{color:#15181C;font-weight:700;margin-top:18px;margin-bottom:0}

/* how-it-works 2x2 */
.vc-how{display:grid;grid-template-columns:1fr;gap:16px}
.vc-how-card{background:#fff;border:1px solid #E2E0D7;border-radius:18px;padding:24px 22px}
.vc-sec-alt .vc-how-card{background:#F4F3EE}
.vc-how-ic{font-size:32px;line-height:1;margin-bottom:14px}
.vc-how-card h3{margin:0 0 8px;font-size:18px;font-weight:700;letter-spacing:-.01em}
.vc-how-card p{margin:0;color:#3A4048;font-size:14.5px;line-height:1.5}

/* installment strip under tariffs */
.vc-installment{margin-top:18px;background:#EFEDE6;border:1px solid #E2E0D7;border-radius:16px;padding:18px 22px;display:flex;flex-direction:column;align-items:center;gap:10px;text-align:center}
.vc-installment-logos{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}
.vc-pay-badge{display:inline-flex;align-items:center;background:#15181C;color:#fff;font-weight:700;font-size:13px;border-radius:8px;padding:6px 12px;letter-spacing:.01em}
.vc-installment-txt{color:#3A4048;font-size:14.5px;line-height:1.5}
.vc-installment-txt b{color:#15181C}

/* cost (dark) */
.vc-cost{background:#15181C;color:#E9EAEC;border-radius:24px;padding:clamp(26px,4vw,48px)}
.vc-cost h2{color:#fff;margin:0 0 24px;font-size:clamp(22px,3.4vw,32px);line-height:1.15;letter-spacing:-.02em;font-weight:800;max-width:22ch}
.vc-cost-rows{display:flex;flex-direction:column;gap:14px;margin-bottom:24px}
.vc-cost-row{display:flex;align-items:baseline;gap:8px;font-size:clamp(15px,1.7vw,17px)}
.vc-cost-l{color:#C3C7CD}
.vc-cost-dots{flex:1;border-bottom:1px dotted #3A4048;transform:translateY(-3px)}
.vc-cost-v{color:#fff;font-weight:600;white-space:nowrap}
.vc-cost-total{font-size:clamp(17px,2.2vw,22px);line-height:1.4;padding-top:18px;border-top:1px solid #2A2E35;color:#fff}
.vc-cost-total b{color:#C8F03C;font-weight:800;white-space:nowrap}
.vc-cost-foot{margin-top:16px;font-size:13.5px;line-height:1.55;color:#AEB6C0}

/* authors */
.vc-authors{display:grid;grid-template-columns:1fr;gap:18px}
.vc-author{background:#fff;border:1px solid #E2E0D7;border-radius:20px;padding:26px 24px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:16px}
.vc-sec-alt .vc-author{background:#F4F3EE}
.vc-author-ph{flex:0 0 auto;width:96px;height:96px;border-radius:50%;overflow:hidden;display:flex;align-items:center;justify-content:center;background:#2F6BFF}
.vc-author-ph img{width:100%;height:100%;object-fit:cover}
.vc-author-ini{color:#fff;font-weight:800;font-size:32px;letter-spacing:.02em;font-family:'Inter Tight',sans-serif}
.vc-author-txt{min-width:0}
.vc-author h3{margin:0 0 4px;font-size:20px;font-weight:800;letter-spacing:-.01em}
.vc-author-role{font-size:12.5px;color:#6A7178;text-transform:uppercase;letter-spacing:.05em;margin-bottom:14px}
.vc-author p{margin:0;color:#3A4048;font-size:15px;line-height:1.55}
.vc-authors-quote{margin:26px 0 0;font-size:clamp(18px,2.4vw,24px);line-height:1.4;font-weight:700;letter-spacing:-.01em;color:#15181C;border-left:4px solid #C8F03C;padding:6px 0 6px 20px;max-width:760px}
/* newbie callout after program */
.vc-newbie .vc-newbie-box{background:#15181C;color:#E9EAEC;border-radius:22px;padding:clamp(26px,4vw,44px);border-left:5px solid #C8F03C}
.vc-newbie h2{color:#fff;margin:0 0 18px;max-width:24ch}
.vc-newbie p{margin:0 0 14px;font-size:clamp(15px,1.7vw,18px);line-height:1.6;color:#C3C7CD}
.vc-newbie .vc-newbie-strong{color:#fff;font-weight:700;margin-top:18px;margin-bottom:0}

/* tariffs — equal height, button pinned to bottom */
.vc-tariffs{display:grid;grid-template-columns:1fr;gap:18px;align-items:stretch}
.vc-tariff{position:relative;display:flex;flex-direction:column;background:#fff;border:1px solid #E2E0D7;border-radius:22px;padding:28px 24px}
.vc-sec-alt .vc-tariff{background:#F4F3EE}
.vc-tariff.is-featured{border:2px solid #C8F03C;box-shadow:0 18px 40px -24px rgba(151,179,46,.6)}
.vc-tariff-badge{position:absolute;top:-12px;left:24px;background:#C8F03C;color:#161a08;font-weight:700;font-size:12px;border-radius:999px;padding:5px 14px}
.vc-tariff-name{font-size:18px;font-weight:700;letter-spacing:-.01em;margin-bottom:8px}
.vc-tariff-price{font-size:30px;font-weight:800;letter-spacing:-.02em;margin-bottom:18px}
.vc-tariff-old{font-size:16px;font-weight:600;color:#9AA0A8;text-decoration:line-through;margin-left:10px}
.vc-tariff-feats{flex:1;margin:0 0 22px;padding:0;list-style:none;display:flex;flex-direction:column;gap:11px}
.vc-tariff-feats li{position:relative;padding-left:28px;font-size:15px;line-height:1.4;color:#3A4048}
.vc-tariff-feats li::before{content:"";position:absolute;left:0;top:2px;width:18px;height:18px;border-radius:50%;background:#EAF6C8 url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='11' viewBox='0 0 24 24' fill='none' stroke='%23427a0a' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 12l4 4L19 7'/%3E%3C/svg%3E") center/11px no-repeat}
.vc-tariff-foot{margin-top:auto}
.vc-tariff-pay{margin-top:12px;font-size:12.5px;color:#6A7178;line-height:1.4;text-align:center}
.vc-tariff-pay span{color:#15181C;font-weight:600}

/* faq */
.vc-faq{display:flex;flex-direction:column;gap:10px;max-width:840px}
.vc-faq-item{background:#fff;border:1px solid #E2E0D7;border-radius:14px;padding:2px 20px}
.vc-sec-alt .vc-faq-item{background:#F4F3EE}
.vc-faq-item summary{list-style:none;cursor:pointer;padding:18px 30px 18px 0;font-size:16px;font-weight:600;color:#15181C;position:relative;line-height:1.4}
.vc-faq-item summary::-webkit-details-marker{display:none}
.vc-faq-item summary::after{content:"+";position:absolute;right:0;top:16px;font-size:22px;font-weight:400;color:#6A7178;transition:transform .2s}
.vc-faq-item[open] summary::after{transform:rotate(45deg)}
.vc-faq-a{padding:0 0 20px;color:#3A4048;font-size:15px;line-height:1.6}

/* final */
.vc-final{background:#15181C;color:#fff;text-align:center}
.vc-final h2{color:#fff;margin-inline:auto;max-width:20ch}
.vc-final p{color:#AEB6C0;font-size:17px;margin:0 0 26px}
.vc-final .vc-btn{max-width:360px;margin-inline:auto}

/* modal */
.vc-modal{position:fixed;inset:0;z-index:1000;background:rgba(12,14,18,.62);display:flex;align-items:flex-end;justify-content:center;padding:0}
.vc-modal[hidden]{display:none}
.vc-modal-box{position:relative;background:#fff;width:100%;max-width:460px;border-radius:22px 22px 0 0;padding:28px 22px calc(24px + env(safe-area-inset-bottom));max-height:92vh;overflow:auto}
.vc-modal-x{position:absolute;top:14px;right:14px;width:38px;height:38px;border:none;background:#F1EFE7;border-radius:50%;font-size:22px;line-height:1;color:#6A7178;cursor:pointer}
.vc-modal-head{margin-bottom:18px;padding-right:30px}
#vc-modal-title{font-size:21px;font-weight:800;letter-spacing:-.01em}
.vc-modal-sub{color:#3A4048;font-size:14.5px;margin-top:6px}
.vc-fld{width:100%;border:1.5px solid #DEDCD2;border-radius:12px;padding:14px 16px;font-size:16px;font-family:inherit;color:#15181C;background:#fff;margin-bottom:12px;outline:none}
.vc-fld:focus{border-color:#C8F03C;box-shadow:0 0 0 3px rgba(200,240,60,.3)}
.vc-area{resize:vertical;min-height:48px}
.vc-hp{position:absolute;left:-9999px;width:1px;height:1px;opacity:0}
.vc-form-msg{margin:6px 0 12px;font-size:14px;padding:10px 14px;border-radius:10px}
.vc-form-msg.is-err{background:#FCEBEA;color:#A8201A}
.vc-form-msg.is-ok{background:#EAF7EC;color:#1b7d2e}
.vc-pay{margin-top:6px;border-top:1px solid #ECEAE1;padding-top:16px}
.vc-pay-h{font-weight:700;font-size:16px;margin-bottom:12px}
.vc-pay .vc-btn{margin-bottom:10px}
.vc-pay-note{font-size:13px;color:#6A7178;text-align:center}
.vc-form-fine{margin-top:14px;font-size:12.5px;color:#6A7178;line-height:1.45;text-align:center}
.vc-form-fine a{color:#2f6f12}

/* thanks */
.vc-thanks{text-align:center;padding-block:clamp(60px,12vw,120px)}
.vc-thanks-mark{width:72px;height:72px;border-radius:50%;background:#C8F03C;color:#161a08;font-size:36px;display:flex;align-items:center;justify-content:center;margin:0 auto 22px}
.vc-thanks h1{font-size:clamp(26px,5vw,38px);margin:0 0 14px;font-weight:800;letter-spacing:-.02em}
.vc-thanks p{color:#3A4048;font-size:17px;line-height:1.55;max-width:520px;margin:0 auto 26px}
.vc-thanks .vc-btn{max-width:300px;margin-inline:auto}

/* ============ tablet ============ */
@media(min-width:680px){
  .vc-btn{width:auto}
  .vc-portraits{grid-template-columns:repeat(3,1fr)}
  .vc-cases{grid-template-columns:repeat(2,1fr)}
  .vc-reviews{grid-template-columns:repeat(2,1fr)}
  .vc-projects{grid-template-columns:repeat(2,1fr)}
  .vc-safety-grid{grid-template-columns:repeat(3,1fr)}
  .vc-how{grid-template-columns:repeat(2,1fr)}
  .vc-installment{flex-direction:row;justify-content:center;text-align:left;gap:18px}
  .vc-authors{grid-template-columns:repeat(2,1fr)}
  .vc-author{flex-direction:row;text-align:left;align-items:flex-start}
  .vc-bonus-list{grid-template-columns:repeat(2,1fr)}
  .vc-tariffs{grid-template-columns:repeat(3,1fr)}
  .vc-hero-cta .vc-btn{width:auto}
  .vc-modal{align-items:center;padding:20px}
  .vc-modal-box{border-radius:22px}
  .vc-pay .vc-btn,.vc-tariff .vc-btn,.vc-final .vc-btn,.vc-thanks .vc-btn{width:100%}
}

/* ============ desktop ============ */
@media(min-width:1000px){
  .vc-projects{grid-template-columns:repeat(3,1fr)}
  .vc-week-topics li{font-size:13.5px}
}
