/* ================================================================
   Circle Ledger — home.css
   Home page (index.html) specific styles.
   Loaded with: shared.css
================================================================ */

/* ── Hero — desktop split layout ── */
.hero_inner {
    max-width: 68.75rem;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-12);
    align-items: center;
}
@media (max-width: 960px) {
    .hero_inner {
        grid-template-columns: 1fr;
        max-width: 42rem;
        text-align: center;
    }
    .hero_visual { display: none; }
    .hero_actions { justify-content: center; }
}

/* ── Hero copy ── */
.hero_eyebrow {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    background: rgba(255,255,255,.07);
    border: var(--border-thin) solid rgba(255,255,255,.15);
    color: var(--teal-200);
    font-size: var(--text-sm);
    font-weight: 600;
    padding: var(--space-1-5) var(--space-4);
    border-radius: var(--radius-pill);
    margin-bottom: var(--space-5);
}
.hero_eyebrow_dot {
    width: 0.5rem; height: 0.5rem; border-radius: 50%;
    background: var(--amber-400); flex-shrink: 0;
    animation: cl-spin 0s linear infinite;
    animation: hero-dot-pulse 2s ease-in-out infinite;
}
@keyframes hero-dot-pulse {
    0%, 100% { opacity: 1; transform: scale(1); }
    50%       { opacity: .5; transform: scale(.8); }
}
.hero_title {
    font-family: var(--font-display);
    font-size: clamp(var(--text-4xl), 5vw, 3.5rem);
    font-weight: 700; color: #fff; line-height: 1.1;
    letter-spacing: -0.03em; margin-bottom: var(--space-5);
}
.hero_title .highlight { color: var(--amber-300); }
.hero_sub {
    font-size: var(--text-2xl); color: var(--teal-200);
    line-height: 1.65; margin-bottom: var(--space-4); max-width: 36rem;
}
@media (max-width: 960px) { .hero_sub { margin-left: auto; margin-right: auto; } }
.hero_actions { justify-content: flex-start; margin-top: var(--space-6); }
@media (max-width: 960px) { .hero_actions { justify-content: center; } }

/* ── Hero visual / mockup widget ── */
.hero_visual { display: flex; align-items: center; justify-content: flex-end; }
.hero_mockup {
    background: var(--surface);
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-xl), 0 0 0 var(--border-thin) rgba(255,255,255,.08);
    padding: var(--space-5);
    width: 100%; max-width: 22rem;
}
.mockup_topbar {
    display: flex; gap: var(--space-1-5);
    margin-bottom: var(--space-4); padding-bottom: var(--space-4);
    border-bottom: var(--border-thin) solid var(--slate-100);
}
.mockup_dot {
    width: 0.625rem; height: 0.625rem; border-radius: 50%;
    background: var(--slate-200);
}
.mockup_dot:nth-child(1) { background: #ff5f57; }
.mockup_dot:nth-child(2) { background: #febc2e; }
.mockup_dot:nth-child(3) { background: #28c840; }
.mockup_stat_row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-3); margin-bottom: var(--space-4); }
.mockup_stat {
    background: var(--teal-50); border-radius: var(--radius-md);
    padding: var(--space-3);
}
.mockup_stat_label { font-size: var(--text-xs); color: var(--slate-400); font-weight: 500; margin-bottom: var(--space-1); }
.mockup_stat_value { font-family: var(--font-display); font-size: var(--text-xl); font-weight: 700; color: var(--teal-900); }
.mockup_divider { height: var(--border-thin); background: var(--slate-100); margin-bottom: var(--space-3); }
.mockup_section_label { font-size: var(--text-xs); font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: var(--slate-400); margin-bottom: var(--space-3); }
.mockup_payment {
    display: flex; justify-content: space-between; align-items: flex-start;
    padding: var(--space-2-5) 0; border-bottom: var(--border-thin) solid var(--slate-50);
}
.mockup_payment:last-of-type { border-bottom: none; }
.mockup_name { font-size: var(--text-md); font-weight: 600; color: var(--teal-900); }
.mockup_date { font-size: var(--text-xs); color: var(--slate-400); margin-top: var(--space-0-5); }
.mockup_right { text-align: right; }
.mockup_amount { font-size: var(--text-md); font-weight: 700; color: var(--teal-900); margin-bottom: var(--space-1); }
.mockup_pill {
    display: inline-flex; align-items: center; gap: var(--space-1);
    font-size: var(--text-xs); font-weight: 700; padding: var(--space-0-5) var(--space-2);
    border-radius: var(--radius-pill);
}
.mockup_pill.approved { background: var(--green-100); color: var(--green-700); }
.mockup_pill.pending  { background: var(--amber-100); color: var(--amber-600); }
.mockup_rotation {
    margin-top: var(--space-4); padding: var(--space-3);
    background: var(--teal-50); border-radius: var(--radius-md);
    border: var(--border-thin) solid var(--teal-100);
}
.mockup_rotation_label { font-size: var(--text-xs); font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: var(--teal-600); margin-bottom: var(--space-1); display: flex; align-items: center; gap: var(--space-1-5); }
.mockup_rotation_name { font-family: var(--font-display); font-size: var(--text-xl); font-weight: 700; color: var(--teal-900); }
.mockup_rotation_sub { font-size: var(--text-xs); color: var(--slate-500); margin-top: var(--space-0-5); }

/* ── Problem section ── */
.problem_grid {
    display: grid; grid-template-columns: repeat(3,1fr);
    gap: var(--space-6); margin-top: var(--space-10);
}
@media (max-width: 900px) { .problem_grid { grid-template-columns: 1fr; max-width: 32rem; margin-left: auto; margin-right: auto; } }
.problem_card {
    background: var(--surface); border: var(--border-thin) solid var(--border);
    border-radius: var(--radius-lg); padding: var(--space-6);
    box-shadow: var(--shadow-xs);
}
.card_icon_wrap {
    width: 2.75rem; height: 2.75rem; border-radius: var(--radius-md);
    display: flex; align-items: center; justify-content: center;
    font-size: var(--icon-xl); margin-bottom: var(--space-4); flex-shrink: 0;
}
.card_icon_wrap.slate { background: var(--slate-100); color: var(--slate-600); }
.problem_icon { margin-bottom: var(--space-4); }
.problem_title { font-family: var(--font-display); font-size: var(--text-xl); font-weight: 700; color: var(--teal-900); letter-spacing: -0.015em; margin-bottom: var(--space-2); }
.problem_desc { font-size: var(--text-md); color: var(--slate-500); line-height: 1.75; }

/* ── Features section (home-specific list layout) ── */
.features_layout {
    display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-16); align-items: flex-start;
}
@media (max-width: 900px) { .features_layout { grid-template-columns: 1fr; } }
.features_list { display: flex; flex-direction: column; gap: var(--space-6); }
.feature_item { display: flex; align-items: flex-start; gap: var(--space-4); }
.feature_icon_wrap {
    width: 2.5rem; height: 2.5rem; border-radius: var(--radius-md); flex-shrink: 0;
    background: var(--teal-50); color: var(--teal-600);
    display: flex; align-items: center; justify-content: center;
    font-size: var(--icon-lg); margin-top: var(--space-0-5);
}
.feature_title { font-family: var(--font-display); font-size: var(--text-xl); font-weight: 700; color: var(--teal-900); margin-bottom: var(--space-1-5); }
.feature_desc { font-size: var(--text-md); color: var(--slate-500); line-height: 1.7; }

/* ── How it works ── */
.how_section {
    background: linear-gradient(135deg, var(--teal-900), var(--teal-700));
    padding: var(--space-20) var(--space-6);
}
.how_grid {
    display: grid; grid-template-columns: repeat(3,1fr);
    gap: var(--space-8); margin-top: var(--space-10);
}
@media (max-width: 768px) { .how_grid { grid-template-columns: 1fr; gap: var(--space-6); } }
.how_step { position: relative; }
.how_num {
    width: 3rem; height: 3rem; border-radius: 50%;
    background: var(--amber-400); color: var(--teal-900);
    font-family: var(--font-display); font-size: var(--text-xl); font-weight: 700;
    display: flex; align-items: center; justify-content: center;
    margin-bottom: var(--space-4); box-shadow: 0 0 0 var(--space-2) rgba(245,158,11,.15);
}
.how_title { font-family: var(--font-display); font-size: var(--text-xl); font-weight: 700; color: #fff; margin-bottom: var(--space-2); }
.how_desc { font-size: var(--text-md); color: var(--teal-200); line-height: 1.7; }

/* ── Use cases ── */
.usecases_grid {
    display: grid; grid-template-columns: repeat(3,1fr); gap: var(--space-5); margin-top: var(--space-10);
}
@media (max-width: 900px) { .usecases_grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 560px) { .usecases_grid { grid-template-columns: 1fr; } }
.usecase_card {
    background: var(--surface); border: var(--border-thin) solid var(--border);
    border-radius: var(--radius-lg); padding: var(--space-6); box-shadow: var(--shadow-xs);
    transition: box-shadow var(--t), transform var(--t);
}
.usecase_card:hover { box-shadow: var(--shadow-md); transform: translateY(-0.125rem); }
.usecase_icon {
    font-size: var(--icon-2xl); color: var(--teal-600);
    margin-bottom: var(--space-4); display: block;
}
.usecase_title { font-family: var(--font-display); font-size: var(--text-xl); font-weight: 700; color: var(--teal-900); margin-bottom: var(--space-2); }
.usecase_desc { font-size: var(--text-md); color: var(--slate-500); line-height: 1.7; margin-bottom: var(--space-4); }
.usecase_tags { display: flex; flex-wrap: wrap; gap: var(--space-1-5); }
.usecase_tag {
    background: var(--teal-50); color: var(--teal-700);
    border: var(--border-thin) solid var(--teal-100);
    border-radius: var(--radius-pill); padding: var(--space-0-5) var(--space-2-5);
    font-size: var(--text-xs); font-weight: 600; letter-spacing: .02em;
}

/* ================================================================
   FEATURE GRID (home page features section)
================================================================ */
.feature_grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-6);
}
@media (max-width: 900px) { .feature_grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .feature_grid { grid-template-columns: 1fr; } }

.feature_card {
    background: var(--surface);
    border: var(--border-thin) solid var(--border);
    border-radius: var(--radius-lg);
    padding: var(--space-6);
    transition: box-shadow var(--t), transform var(--t);
}
.feature_card:hover { box-shadow: var(--shadow-md); transform: translateY(-0.125rem); }

.feature_icon {
    width: 3rem;
    height: 3rem;
    border-radius: var(--radius-md);
    background: var(--teal-50);
    color: var(--teal-600);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--icon-xl);
    margin-bottom: var(--space-4);
}
.feature_icon.amber { background: var(--amber-50); color: var(--amber-600); }
.feature_title {
    font-family: var(--font-display);
    font-size: var(--text-xl);
    font-weight: 700;
    color: var(--teal-900);
    margin-bottom: var(--space-2);
}
.feature_body { font-size: var(--text-md); color: var(--slate-500); line-height: 1.7; }

/* ================================================================
   STEPS GRID (how it works — light bg variant)
================================================================ */
.steps_grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-8);
    position: relative;
}
@media (max-width: 768px) { .steps_grid { grid-template-columns: 1fr; gap: var(--space-6); } }

.step { text-align: center; position: relative; }
.step_number {
    width: 3rem;
    height: 3rem;
    border-radius: 50%;
    background: var(--teal-600);
    color: #fff;
    font-family: var(--font-display);
    font-size: var(--text-xl);
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto var(--space-4);
    box-shadow: 0 0 0 var(--space-2) rgba(30,107,107,.12);
}
.step_title {
    font-family: var(--font-display);
    font-size: var(--text-xl);
    font-weight: 700;
    color: var(--teal-900);
    margin-bottom: var(--space-2);
}
.step_body { font-size: var(--text-md); color: var(--slate-500); line-height: 1.7; }

/* ================================================================
   TESTIMONIALS (home page)
================================================================ */
.testimonial_grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-5);
}
@media (max-width: 900px) { .testimonial_grid { grid-template-columns: 1fr; } }

.testimonial_card {
    background: var(--surface);
    border: var(--border-thin) solid var(--border);
    border-radius: var(--radius-lg);
    padding: var(--space-6);
}
.testimonial_stars {
    color: var(--amber-400);
    font-size: var(--text-base);
    margin-bottom: var(--space-4);
    display: flex;
    gap: var(--space-1);
}
.testimonial_quote {
    font-size: var(--text-md);
    color: var(--slate-600);
    line-height: 1.75;
    margin-bottom: var(--space-5);
    font-style: italic;
}
.testimonial_author {
    display: flex;
    align-items: center;
    gap: var(--space-3);
}
.testimonial_author_avatar {
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 50%;
    background: var(--teal-100);
    color: var(--teal-800);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: var(--text-md);
    flex-shrink: 0;
}
.testimonial_author_name { font-weight: 600; color: var(--slate-800); font-size: var(--text-md); }
.testimonial_author_title { font-size: var(--text-sm); color: var(--slate-400); }
