/* Computer Touchers — MSP partner program with attitude. Punk-purple + lime accent,
   chunky condensed display sans, irreverent. Persona 11 (channel partners). */
/* Design review: Yves Chamberlain-Kapoor. Brief: tier badges, refactor display-stack, holographic
   sweep on the primary CTA, refactor !important, deflate the dashed-border table. */

:root[data-site="computertouchers"] {
    --ct-bg: #1a0c2e;
    --ct-surface: #281547;
    --ct-fg: #f5edff;
    --ct-muted: #b8a4d6;
    --ct-accent: #a855f7;
    --ct-lime: #d9f99d;
    --ct-rule: #3a1f5e;
    --ct-rule-strong: #5a3296;
    /* Tier palette — Yves's signature. Each tier reads metallic. */
    --ct-tier-bronze:   linear-gradient(120deg, #cd7f32, #f5b97e, #cd7f32);
    --ct-tier-silver:   linear-gradient(120deg, #9aa0a6, #e8eaed, #9aa0a6);
    --ct-tier-gold:     linear-gradient(120deg, #c5a93f, #f7e29a, #c5a93f);
    --ct-tier-platinum: linear-gradient(120deg, #e5e4e2, #b9c5d0, #e5e4e2);
    --ct-display: "Archivo Black", "Bebas Neue", "Inter", system-ui, sans-serif;
    --ct-sans: "Inter", system-ui, sans-serif;
}
html[data-site="computertouchers"], body { background: var(--ct-bg); color: var(--ct-fg); }
body { font-family: var(--ct-sans); margin: 0; line-height: 1.55; -webkit-font-smoothing: antialiased; }

.ct-container { max-width: 1080px; margin: 0 auto; padding: 0 1.5rem; }

.ct-header { background: var(--ct-bg); padding: 1rem 0; border-bottom: 2px dashed var(--ct-rule); }
.ct-header .ct-container { display: flex; justify-content: space-between; align-items: center; }
.ct-brand {
    display: inline-flex; align-items: center; gap: .5rem;
    color: var(--ct-fg); text-decoration: none;
    font-family: var(--ct-display); font-size: 1.2rem;
    text-transform: uppercase; letter-spacing: .03em;
}
.ct-brand-zap { color: var(--ct-lime); }
.ct-brand-strong { color: var(--ct-lime); }
.ct-nav { display: flex; align-items: center; gap: .25rem; }
.ct-nav a {
    color: var(--ct-muted); text-decoration: none; margin-left: 1.25rem;
    font-weight: 500;
    transition: color .12s ease;
}
.ct-nav a:hover { color: var(--ct-fg); }
.ct-nav a:focus-visible { outline: 2px solid var(--ct-lime); outline-offset: 4px; border-radius: 4px; }

/* Yves: no !important. */
.ct-nav a.ct-cta {
    background: var(--ct-lime); color: var(--ct-bg);
    padding: .55rem 1.1rem; border-radius: 4px; font-weight: 700;
    text-transform: uppercase; letter-spacing: .06em; font-size: .8rem;
}
.ct-nav a.ct-cta:hover { background: #c8e970; color: var(--ct-bg); }

.ct-main { padding: 0; }
.ct-hero { padding: 5rem 0; }
.ct-tag {
    display: inline-block; background: rgba(217,249,157,.15);
    color: var(--ct-lime); padding: .35rem .8rem; border-radius: 999px;
    font-size: .8rem; letter-spacing: .12em; text-transform: uppercase; font-weight: 600;
}
h1 {
    font-family: var(--ct-display); font-size: clamp(2.6rem, 6vw, 5rem);
    line-height: 1.0; margin: 1rem 0 1rem;
    text-transform: uppercase; letter-spacing: -.01em;
}
/* Yves: only the primary display element gets all-caps. */
h2 { font-family: var(--ct-display); text-transform: uppercase; letter-spacing: -.005em; }
.ct-accent { color: var(--ct-lime); }
.ct-lede { color: var(--ct-muted); max-width: 55ch; font-size: 1.1rem; }

.ct-btn {
    display: inline-block; padding: 1rem 1.85rem;
    border-radius: 4px; text-decoration: none; font-weight: 700;
    text-transform: uppercase; letter-spacing: .06em;
    margin-top: 1.75rem; font-family: var(--ct-display);
    border: 3px solid transparent;
    position: relative; overflow: hidden;
    transition: background-color .15s ease, color .15s ease;
}
.ct-btn-primary { background: var(--ct-lime); color: var(--ct-bg); border-color: var(--ct-lime); }
.ct-btn-primary:hover { background: transparent; color: var(--ct-lime); }
/* Yves: holographic sweep across the primary CTA on hover. */
.ct-btn-primary::after {
    content: ""; position: absolute; inset: 0;
    background: linear-gradient(
        110deg,
        transparent 0%, transparent 35%,
        rgba(255,255,255,.5) 50%,
        transparent 65%, transparent 100%
    );
    transform: translateX(-120%);
    transition: transform .8s ease;
    pointer-events: none;
}
.ct-btn-primary:hover::after { transform: translateX(120%); }
.ct-btn:focus-visible { outline: 3px solid var(--ct-lime); outline-offset: 4px; }

/* Tier badges — Yves's signature ribbon. Drop one anywhere with .ct-tier .ct-tier-platinum. */
.ct-tier {
    display: inline-flex; align-items: center; gap: .35rem;
    padding: .25rem .7rem; border-radius: 999px;
    font-family: var(--ct-display); font-size: .7rem;
    text-transform: uppercase; letter-spacing: .12em;
    color: #1a0c2e;
    background: var(--ct-tier-silver);
    background-size: 200% 100%; animation: ct-shimmer 4s linear infinite;
    box-shadow: inset 0 1px 0 rgba(255,255,255,.5);
}
.ct-tier-bronze   { background-image: var(--ct-tier-bronze); }
.ct-tier-silver   { background-image: var(--ct-tier-silver); }
.ct-tier-gold     { background-image: var(--ct-tier-gold); }
.ct-tier-platinum { background-image: var(--ct-tier-platinum); }
@keyframes ct-shimmer { from { background-position: 200% 50%; } to { background-position: 0% 50%; } }
@media (prefers-reduced-motion: reduce) { .ct-tier { animation: none; } }

.ct-table { padding: 1rem 0 5rem; }
.ct-table h2 { font-size: 1.6rem; margin: 0 0 1.5rem; }
/* Yves: solid border, not dashed. The table reads cleaner. */
.ct-table-grid {
    display: grid; gap: 0; grid-template-columns: 1fr 1fr;
    border: 2px solid var(--ct-lime);
}
@media (max-width: 720px) { .ct-table-grid { grid-template-columns: 1fr; } }
.ct-cell { padding: 1.85rem; background: var(--ct-surface); }
.ct-cell + .ct-cell { border-left: 2px solid var(--ct-lime); }
@media (max-width: 720px) {
    .ct-cell + .ct-cell { border-left: 0; border-top: 2px solid var(--ct-lime); }
}
.ct-cell h3 {
    /* Yves: only ONE display element in the cell, not two. h3 stays sans, lime, regular case. */
    font-family: var(--ct-sans);
    margin: 0 0 .75rem; color: var(--ct-lime);
    font-size: 1.05rem; font-weight: 700; letter-spacing: -.005em;
}
.ct-cell ul { margin: 0; padding-left: 1.25rem; color: var(--ct-muted); }
.ct-cell ul li { margin-bottom: .35rem; }
.ct-cell ul li::marker { color: var(--ct-lime); }
.ct-cell-deep { background: rgba(168,85,247,.12); }

::selection { background: var(--ct-lime); color: var(--ct-bg); }

.ct-footer { padding: 2rem 0 3rem; border-top: 2px dashed var(--ct-rule); color: var(--ct-muted); font-size: .9rem; }
.ct-footer-meta { display: flex; flex-wrap: wrap; justify-content: space-between; gap: 1rem; margin-top: 1rem; }
.ct-footer a { color: var(--ct-muted); text-decoration: none; }
.ct-footer a:hover { color: var(--ct-lime); }

.skip-to-content {
    position: absolute; left: -9999px;
    background: var(--ct-lime); color: var(--ct-bg);
    padding: .55rem 1.1rem; border-radius: 4px;
    font-family: var(--ct-display); font-weight: 700;
    text-transform: uppercase; letter-spacing: .08em;
    z-index: 1000;
}
.skip-to-content:focus { left: 1rem; top: 1rem; }

@media (prefers-reduced-motion: reduce) {
    * { transition: none !important; animation: none !important; }
    .ct-btn-primary::after { display: none; }
}
