/* =================================================================
   Dana Duhok — Home page section system
   -----------------------------------------------------------------
   The homepage used to repeat ONE card grid (.bento) for almost every
   section, so the page read as a loop. Each content section now has
   its OWN distinct layout so the page reads as a composed sequence:

     Services      → editorial index list (sticky split)
     Solutions     → numbered capability matrix
     Products      → horizontal snap rail
     How it works  → connected process timeline
     Why           → divided value pillars
     Stats         → full-bleed gradient band
     Main Team     → portrait row (no boxes)
     Clients       → hairline logo wall
     News          → editorial lead + list

   Everything derives from the same design tokens, so the admin Brand
   accent still re-skins the whole page.
   ================================================================= */

/* Left-aligned section head variant (used by the split layouts) */
.section-head--left { text-align: left; max-width: 480px; margin-left: 0; margin-right: 0; }
.section-head--left .section-title { text-align: left; }
.section-head--left .section-lead  { margin-left: 0; margin-right: 0; text-align: left; }

/* =================================================================
   SERVICES — editorial index list (sticky split)
   ================================================================= */
.svc-split {
    display: grid;
    grid-template-columns: minmax(0, 360px) 1fr;
    gap: clamp(32px, 5vw, 76px);
    align-items: start;
}
.svc-split__intro { position: sticky; top: 116px; }
.svc-split__intro .btn { margin-top: 6px; }

.svc-list { list-style: none; margin: 0; padding: 0; }
.svc-row__link {
    display: grid;
    grid-template-columns: auto 54px 1fr auto;
    align-items: center;
    gap: clamp(14px, 2vw, 26px);
    padding: clamp(20px, 2.4vw, 28px) 6px;
    border-top: 1px solid var(--c-border);
    color: var(--c-text);
    transition: padding-left .28s cubic-bezier(.2,.7,.2,1), background-color .25s ease;
}
.svc-row:last-child .svc-row__link { border-bottom: 1px solid var(--c-border); }
.svc-row__link:hover {
    padding-left: 18px; color: var(--c-text);
    background: linear-gradient(90deg, var(--c-accent-tint), transparent 72%);
}
.svc-row__no {
    font-size: .82rem; font-weight: 700; letter-spacing: .04em;
    color: var(--c-text-3); font-variant-numeric: tabular-nums;
    transition: color .25s;
}
.svc-row__link:hover .svc-row__no { color: var(--c-primary); }
.svc-row__icon {
    width: 54px; height: 54px; border-radius: var(--radius-md);
    display: inline-flex; align-items: center; justify-content: center;
    background: var(--c-tint); color: var(--c-primary);
    transition: background .25s, color .25s, transform .25s, box-shadow .25s;
}
.svc-row__link:hover .svc-row__icon {
    background: var(--grad-primary); color: #fff;
    box-shadow: var(--shadow-btn); transform: rotate(-4deg);
}
.svc-row__icon svg { width: 26px; height: 26px; }
.svc-row__body h3 { font-size: 1.18rem; margin: 0 0 3px; }
.svc-row__body p  { margin: 0; color: var(--c-text-2); font-size: .92rem; }
.svc-row__arrow {
    width: 40px; height: 40px; border-radius: 999px;
    border: 1px solid var(--c-border-strong); color: var(--c-text-2);
    display: inline-flex; align-items: center; justify-content: center;
    transition: transform .25s, background-color .25s, color .25s, border-color .25s;
}
.svc-row__arrow svg { width: 17px; height: 17px; }
.svc-row__link:hover .svc-row__arrow {
    background: var(--c-primary); border-color: var(--c-primary);
    color: #fff; transform: translateX(4px);
}
@media (max-width: 860px) {
    .svc-split { grid-template-columns: 1fr; gap: 28px; }
    .svc-split__intro { position: static; }
}
@media (max-width: 560px) {
    .svc-row__link { grid-template-columns: auto 1fr auto; gap: 14px; }
    .svc-row__icon { display: none; }
}

/* =================================================================
   SOLUTIONS — numbered capability matrix
   ================================================================= */
.sol-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1px;
    background: var(--c-border);
    border: 1px solid var(--c-border);
    border-radius: var(--radius-xl);
    overflow: hidden;
}
.sol-item {
    position: relative; overflow: hidden;
    padding: clamp(28px, 3vw, 42px);
    background: var(--c-surface); color: var(--c-text);
    display: flex; flex-direction: column;
    transition: background-color .28s ease;
}
.sol-item::before {
    content: ''; position: absolute; left: 0; top: 0; height: 3px; width: 0;
    background: var(--grad-primary);
    transition: width .4s cubic-bezier(.2,.7,.2,1);
}
.sol-item:hover { background: var(--c-bg-2); }
.sol-item:hover::before { width: 100%; }
.sol-item__no {
    position: absolute; top: 14px; right: 22px;
    font-size: 3.6rem; font-weight: 800; line-height: 1; letter-spacing: -.05em;
    color: var(--c-text); opacity: .06; pointer-events: none;
}
.sol-item__icon {
    width: 52px; height: 52px; border-radius: var(--radius-md);
    display: inline-flex; align-items: center; justify-content: center;
    background: var(--c-tint); color: var(--c-primary); margin-bottom: 18px;
}
.sol-item__icon svg { width: 26px; height: 26px; }
.sol-item h3 { font-size: 1.24rem; margin: 0 0 8px; }
.sol-item p  { margin: 0 0 18px; color: var(--c-text-2); font-size: .95rem; flex: 1; }
.sol-item__more {
    display: inline-flex; align-items: center; gap: 7px;
    font-weight: 600; font-size: .9rem; color: var(--c-accent-ink);
}
.sol-item__more svg { width: 16px; height: 16px; transition: transform .25s; }
.sol-item:hover .sol-item__more svg { transform: translateX(4px); }
@media (max-width: 680px) { .sol-grid { grid-template-columns: 1fr; } }

/* =================================================================
   PRODUCTS — horizontal snap rail (reuses the carousel JS + nav)
   ================================================================= */
.prail { position: relative; }
.prail__track {
    display: flex; gap: 18px;
    overflow-x: auto; scroll-snap-type: x mandatory; scroll-behavior: smooth;
    padding: 6px 2px 18px;
    scrollbar-width: none; -ms-overflow-style: none;
}
.prail__track::-webkit-scrollbar { display: none; }
.pcard {
    scroll-snap-align: start;
    flex: 0 0 clamp(258px, 78vw, 320px);
    background: var(--c-surface); border: 1px solid var(--c-border);
    border-radius: var(--radius-xl); overflow: hidden; box-shadow: var(--shadow-sm);
    color: var(--c-text); display: flex; flex-direction: column;
    transition: transform .28s, box-shadow .28s;
}
.pcard:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); color: var(--c-text); }
.pcard__media {
    height: 178px; background: var(--c-bg-2) center / cover no-repeat;
    border-bottom: 1px solid var(--c-border);
}
.pcard__media--ph {
    display: flex; align-items: center; justify-content: center;
    background: var(--c-tint); color: var(--c-primary);
}
.pcard__media--ph svg { width: 46px; height: 46px; }
.pcard__body { padding: 22px; display: flex; flex-direction: column; flex: 1; }
.pcard__body h3 { font-size: 1.12rem; margin: 0 0 6px; }
.pcard__body p  { margin: 0 0 16px; font-size: .9rem; color: var(--c-text-2); flex: 1; }
.pcard__more {
    display: inline-flex; align-items: center; gap: 7px;
    font-weight: 600; font-size: .88rem; color: var(--c-accent-ink);
}
.pcard__more svg { width: 16px; height: 16px; transition: transform .25s; }
.pcard:hover .pcard__more svg { transform: translateX(4px); }

/* =================================================================
   HOW IT WORKS — connected process timeline
   ================================================================= */
.proc {
    display: grid; grid-template-columns: repeat(4, 1fr);
    gap: clamp(24px, 3vw, 36px); position: relative;
}
.proc::before {
    content: ''; position: absolute; top: 27px; left: 12.5%; right: 12.5%; height: 2px;
    background: repeating-linear-gradient(90deg, var(--c-border-strong) 0 7px, transparent 7px 15px);
    z-index: 0;
}
.proc__step { position: relative; z-index: 1; }
.proc__node {
    width: 56px; height: 56px; border-radius: 999px;
    background: var(--grad-primary); color: #fff;
    display: inline-flex; align-items: center; justify-content: center;
    font-weight: 800; font-size: 1.15rem; box-shadow: var(--shadow-btn);
    margin-bottom: 20px; position: relative;
}
.proc__node::after {
    content: ''; position: absolute; inset: -5px; border-radius: inherit;
    border: 1px solid var(--c-border-strong);
}
.proc__step h3 { font-size: 1.18rem; margin: 0 0 8px; }
.proc__step p  { margin: 0; color: var(--c-text-2); }
@media (max-width: 760px) {
    .proc { grid-template-columns: repeat(2, 1fr); gap: 34px 28px; }
    .proc::before { display: none; }
}
@media (max-width: 440px) { .proc { grid-template-columns: 1fr; } }

/* =================================================================
   WHY — divided value pillars (no boxes)
   ================================================================= */
.pillars { display: grid; grid-template-columns: repeat(4, 1fr); }
.pillar { padding: 4px clamp(20px, 2.4vw, 34px); border-left: 1px solid var(--c-border); }
.pillar:first-child { border-left: 0; padding-left: 0; }
.pillar__icon {
    width: 52px; height: 52px; border-radius: var(--radius-md);
    display: inline-flex; align-items: center; justify-content: center;
    background: var(--c-tint); color: var(--c-primary); margin-bottom: 18px;
}
.pillar__icon svg { width: 26px; height: 26px; }
.pillar h3 { font-size: 1.16rem; margin: 0 0 8px; }
.pillar p  { margin: 0; color: var(--c-text-2); font-size: .93rem; }
@media (max-width: 860px) {
    .pillars { grid-template-columns: repeat(2, 1fr); gap: 34px 0; }
    .pillar:nth-child(odd)  { border-left: 0; padding-left: 0; }
}
@media (max-width: 480px) {
    .pillars { grid-template-columns: 1fr; gap: 0; }
    .pillar { border-left: 0; padding: 0; }
    .pillar + .pillar { border-top: 1px solid var(--c-border); padding-top: 28px; margin-top: 28px; }
}

/* =================================================================
   STATS — full-bleed gradient band (uses .section--band)
   ================================================================= */
.statband { display: grid; grid-template-columns: repeat(4, 1fr); }
.statband__item {
    text-align: center; padding: 6px clamp(16px, 2vw, 28px);
    border-left: 1px solid rgba(255,255,255,.2);
}
.statband__item:first-child { border-left: 0; }
.statband__value {
    display: block; font-size: clamp(2.2rem, 1.4rem + 2.4vw, 3.3rem);
    font-weight: 800; line-height: 1; letter-spacing: -.035em; color: #fff;
}
.statband__label {
    display: block; margin-top: 10px; font-size: .86rem;
    letter-spacing: .02em; color: rgba(255,255,255,.82);
}
@media (max-width: 680px) {
    .statband { grid-template-columns: repeat(2, 1fr); gap: 32px 0; }
    .statband__item:nth-child(odd) { border-left: 0; }
}

/* =================================================================
   MAIN TEAM — portrait row (no boxes)
   ================================================================= */
.team-row { display: flex; flex-wrap: wrap; justify-content: center; gap: clamp(22px, 4vw, 56px); }
.tmember { width: 180px; text-align: center; transition: transform .28s ease; }
.tmember:hover { transform: translateY(-6px); }
.tmember__photo {
    width: 104px; height: 104px; border-radius: 999px; margin: 0 auto 16px;
    background: var(--grad-primary); color: #fff;
    display: inline-flex; align-items: center; justify-content: center;
    font-weight: 800; font-size: 1.7rem; box-shadow: var(--shadow-md); position: relative;
}
.tmember__photo::after {
    content: ''; position: absolute; inset: -6px; border-radius: inherit;
    border: 1px solid var(--c-border-strong); transition: border-color .28s;
}
.tmember:hover .tmember__photo::after { border-color: var(--c-primary); }
.tmember h3 { font-size: 1.1rem; margin: 0 0 2px; }
.tmember p  { margin: 0; font-size: .86rem; color: var(--c-text-3); }

/* =================================================================
   CLIENTS — hairline logo wall
   ================================================================= */
.logo-wall {
    display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px;
    background: var(--c-border); border: 1px solid var(--c-border);
    border-radius: var(--radius-xl); overflow: hidden;
}
.logo-cell {
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    gap: 10px; padding: clamp(26px, 3vw, 38px) 18px; text-align: center;
    background: var(--c-surface); color: var(--c-text);
    transition: background-color .25s, color .25s;
}
.logo-cell:hover { background: var(--c-tint); }
.logo-cell__mark {
    width: 52px; height: 52px; border-radius: 999px;
    display: inline-flex; align-items: center; justify-content: center;
    font-weight: 800; font-size: 1.02rem;
    border: 1px solid var(--c-border-strong); color: var(--c-text-2);
    transition: border-color .25s, color .25s;
}
.logo-cell:hover .logo-cell__mark { border-color: var(--c-primary); color: var(--c-primary); }
.logo-cell__name { font-size: .92rem; font-weight: 600; color: var(--c-text); }
.logo-cell__meta { font-size: .76rem; color: var(--c-text-3); }
@media (max-width: 820px) { .logo-wall { grid-template-columns: repeat(2, 1fr); } }

/* =================================================================
   NEWS — editorial lead + list
   ================================================================= */
.news-ed {
    display: grid; grid-template-columns: 1.25fr 1fr;
    gap: clamp(24px, 4vw, 48px); align-items: start;
}
.news-lead {
    display: flex; flex-direction: column;
    background: var(--c-surface); border: 1px solid var(--c-border);
    border-radius: var(--radius-2xl); padding: clamp(26px, 3vw, 40px);
    box-shadow: var(--shadow-sm); color: var(--c-text);
    transition: transform .28s, box-shadow .28s;
}
.news-lead:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); color: var(--c-text); }
.news-lead__meta {
    font-size: .78rem; letter-spacing: .06em; text-transform: uppercase;
    color: var(--c-primary); font-weight: 600;
}
.news-lead__title { font-size: clamp(1.4rem, 1rem + 1.4vw, 2.05rem); margin: 14px 0 12px; }
.news-lead p { color: var(--c-text-2); margin: 0 0 20px; flex: 1; }
.news-lead .bento__more { color: var(--c-accent-ink); }

.news-side { list-style: none; margin: 0; padding: 0; }
.news-row {
    display: block; padding: 20px 2px;
    border-top: 1px solid var(--c-border); color: var(--c-text);
    transition: padding-left .25s ease, color .2s;
}
.news-side li:last-child .news-row { border-bottom: 1px solid var(--c-border); }
.news-row:hover { padding-left: 10px; color: var(--c-primary); }
.news-row__meta {
    font-size: .74rem; letter-spacing: .05em; text-transform: uppercase;
    color: var(--c-text-3);
}
.news-row h4 { font-size: 1.06rem; margin: 8px 0 0; color: inherit; }
@media (max-width: 820px) { .news-ed { grid-template-columns: 1fr; } }
