/* ═══════════════════════════════════════════════════════════════════════════
   assets/css/style.css — Studio JBATISTAMA
   Palette : noir #0A0A0A · cartes #111 · or #C9A84C / #E8C97A · texte #EDEDED
   Typo    : Bebas Neue (display) · Inter (corps)
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── Variables ─────────────────────────────────────────────────────────────── */
:root {
    --color-bg          : #0A0A0A;
    --color-surface     : #111111;
    --color-surface-2   : #1A1A1A;
    --color-border      : #282828;
    --color-gold        : #C9A84C;
    --color-gold-light  : #E8C97A;
    --color-gold-dim    : rgba(201, 168, 76, 0.15);
    --color-text        : #EDEDED;
    --color-text-muted  : #888888;
    --color-text-dim    : #555555;
    --color-error       : #E05050;

    --font-display      : 'Bebas Neue', 'Arial Narrow', Arial, sans-serif;
    --font-body         : 'Inter', system-ui, sans-serif;

    --radius-sm         : 4px;
    --radius-md         : 8px;
    --radius-lg         : 12px;

    --shadow-card       : 0 2px 16px rgba(0, 0, 0, 0.5);
    --shadow-card-hover : 0 8px 32px rgba(201, 168, 76, 0.12);

    --transition        : 0.22s ease;
    --container-width   : 1280px;
    --grid-gap          : 1.5rem;
}

/* ── Reset & base ──────────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }

body {
    background-color : var(--color-bg);
    color            : var(--color-text);
    font-family      : var(--font-body);
    font-size        : 15px;
    line-height      : 1.6;
    -webkit-font-smoothing : antialiased;
    min-height       : 100vh;
    display          : flex;
    flex-direction   : column;
}

img { max-width: 100%; display: block; }

a { color: inherit; text-decoration: none; }

/* Utilitaires */
.sr-only {
    position: absolute; width: 1px; height: 1px;
    padding: 0; overflow: hidden; clip: rect(0,0,0,0);
    white-space: nowrap; border: 0;
}

/* ── Container ──────────────────────────────────────────────────────────────── */
.container {
    width     : 100%;
    max-width : var(--container-width);
    margin    : 0 auto;
    padding   : 0 1.5rem;
}

/* ════════════════════════════════════════════════════════════
   HEADER
   ════════════════════════════════════════════════════════════ */
.site-header {
    position   : relative;
    padding    : 3.5rem 0 2.5rem;
    background : var(--color-bg);
}

/* Ligne dorée animée — signature visuelle */
.header__line {
    position   : absolute;
    top        : 0;
    left       : 0;
    width      : 0;
    height     : 2px;
    background : linear-gradient(90deg, var(--color-gold), var(--color-gold-light), transparent);
    animation  : lineDraw 1.2s cubic-bezier(0.22, 1, 0.36, 1) forwards;
}
.header__line--bottom {
    top        : auto;
    bottom     : 0;
    animation-delay : 0.3s;
}

@keyframes lineDraw {
    to { width: 100%; }
}

.header__inner {
    display         : flex;
    align-items     : flex-end;
    justify-content : space-between;
    gap             : 1.5rem;
    flex-wrap       : wrap;
}

/* Branding */
.header__brand { display: flex; flex-direction: column; gap: 0.1rem; }

.brand__eyebrow {
    font-family     : var(--font-body);
    font-size       : 0.7rem;
    font-weight     : 600;
    letter-spacing  : 0.25em;
    text-transform  : uppercase;
    color           : var(--color-gold);
}

.brand__title {
    font-family : var(--font-display);
    font-size   : clamp(2.8rem, 8vw, 5.5rem);
    line-height : 1;
    letter-spacing : 0.02em;
    color       : var(--color-text);
    /* Légère texture sur le texte */
    background  : linear-gradient(160deg, #fff 0%, var(--color-text) 60%);
    -webkit-background-clip : text;
    -webkit-text-fill-color : transparent;
    background-clip : text;
}

.brand__sub {
    font-family    : var(--font-body);
    font-size      : 0.8rem;
    font-weight    : 300;
    letter-spacing : 0.12em;
    text-transform : uppercase;
    color          : var(--color-text-muted);
    margin-top     : 0.2rem;
}

/* Compteur de projets */
.header__count {
    display        : flex;
    flex-direction : column;
    align-items    : flex-end;
    line-height    : 1;
}
.count__num {
    font-family : var(--font-display);
    font-size   : clamp(2rem, 5vw, 3.5rem);
    color       : var(--color-gold);
}
.count__label {
    font-size   : 0.7rem;
    font-weight : 500;
    letter-spacing : 0.15em;
    text-transform : uppercase;
    color       : var(--color-text-muted);
    margin-top  : 0.15rem;
}

/* ════════════════════════════════════════════════════════════
   FILTRES
   ════════════════════════════════════════════════════════════ */
.filters {
    position   : sticky;
    top        : 0;
    z-index    : 100;
    background : rgba(10, 10, 10, 0.92);
    backdrop-filter : blur(12px);
    border-bottom   : 1px solid var(--color-border);
    padding    : 0.85rem 0;
}

.filters__inner {
    display     : flex;
    align-items : center;
    gap         : 0.5rem;
    flex-wrap   : wrap;
}

/* Boutons filtre */
.filter-btn {
    background    : transparent;
    border        : 1px solid var(--color-border);
    color         : var(--color-text-muted);
    padding       : 0.35rem 0.9rem;
    border-radius : var(--radius-sm);
    font-family   : var(--font-body);
    font-size     : 0.78rem;
    font-weight   : 500;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    cursor        : pointer;
    transition    : all var(--transition);
}
.filter-btn:hover {
    border-color : var(--color-gold-dim);
    color        : var(--color-gold-light);
    background   : var(--color-gold-dim);
}
.filter-btn--active,
.filter-btn[aria-pressed="true"] {
    background   : var(--color-gold);
    border-color : var(--color-gold);
    color        : #0A0A0A;
    font-weight  : 600;
}

/* Select tri */
.filters__sort { margin-left: auto; }

.sort-select {
    background    : var(--color-surface-2);
    border        : 1px solid var(--color-border);
    color         : var(--color-text-muted);
    padding       : 0.35rem 0.8rem;
    border-radius : var(--radius-sm);
    font-family   : var(--font-body);
    font-size     : 0.78rem;
    cursor        : pointer;
    outline       : none;
    transition    : border-color var(--transition);
}
.sort-select:hover,
.sort-select:focus { border-color: var(--color-gold); color: var(--color-text); }

/* ════════════════════════════════════════════════════════════
   MAIN & GRILLE
   ════════════════════════════════════════════════════════════ */
.main {
    flex   : 1;
    padding: 2.5rem 0 4rem;
}

.no-results {
    text-align : center;
    color      : var(--color-text-muted);
    padding    : 3rem 0;
    font-size  : 0.95rem;
}

.grid {
    display               : grid;
    grid-template-columns : repeat(3, 1fr);
    gap                   : var(--grid-gap);
}

/* ════════════════════════════════════════════════════════════
   CARTE PROJET
   ════════════════════════════════════════════════════════════ */
.card {
    background    : var(--color-surface);
    border        : 1px solid var(--color-border);
    border-radius : var(--radius-lg);
    overflow      : hidden;
    display       : flex;
    flex-direction: column;
    box-shadow    : var(--shadow-card);
    transition    : transform var(--transition), box-shadow var(--transition),
                    border-color var(--transition);
    /* Animation d'entrée */
    animation     : cardIn 0.4s ease both;
}
.card:hover {
    transform    : translateY(-4px);
    box-shadow   : var(--shadow-card-hover);
    border-color : var(--color-gold-dim);
}

@keyframes cardIn {
    from { opacity: 0; transform: translateY(16px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* Vignette */
.card__thumb {
    position : relative;
    aspect-ratio: 16 / 9;
    overflow : hidden;
    background: var(--color-surface-2);
}

.card__image {
    width      : 100%;
    height     : 100%;
    object-fit : cover;
    transition : transform 0.5s ease;
}
.card:hover .card__image { transform: scale(1.04); }

/* Placeholder (si pas d'image) */
.card__image--placeholder {
    width           : 100%;
    height          : 100%;
    display         : flex;
    align-items     : center;
    justify-content : center;
    background      : linear-gradient(135deg, var(--color-surface-2), #1E1A12);
}
.card__image--placeholder span {
    font-family : var(--font-display);
    font-size   : 3rem;
    color       : var(--color-gold);
    opacity     : 0.4;
    letter-spacing: 0.05em;
}

/* Badge catégorie */
.card__category {
    position      : absolute;
    top           : 0.65rem;
    left          : 0.65rem;
    background    : rgba(10, 10, 10, 0.82);
    backdrop-filter: blur(6px);
    border        : 1px solid var(--color-gold-dim);
    color         : var(--color-gold-light);
    font-size     : 0.65rem;
    font-weight   : 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    padding       : 0.2rem 0.55rem;
    border-radius : var(--radius-sm);
}

/* Corps */
.card__body {
    padding : 1.2rem 1.2rem 0.8rem;
    flex    : 1;
}

.card__title {
    font-family : var(--font-body);
    font-size   : 0.95rem;
    font-weight : 600;
    color       : var(--color-text);
    line-height : 1.35;
    margin-bottom: 0.5rem;
    /* Limiter à 2 lignes */
    display            : -webkit-box;
    -webkit-line-clamp : 2;
    -webkit-box-orient : vertical;
    overflow           : hidden;
}

.card__desc {
    font-size  : 0.82rem;
    color      : var(--color-text-muted);
    line-height: 1.55;
    /* Limiter à 3 lignes */
    display            : -webkit-box;
    -webkit-line-clamp : 3;
    -webkit-box-orient : vertical;
    overflow           : hidden;
}

/* Footer carte */
.card__footer {
    padding     : 0 1.2rem 1.1rem;
    margin-top  : auto;
}

.card__link {
    display        : inline-flex;
    align-items    : center;
    gap            : 0.35rem;
    color          : var(--color-gold);
    font-size      : 0.8rem;
    font-weight    : 600;
    letter-spacing : 0.05em;
    text-transform : uppercase;
    transition     : color var(--transition);
    border-bottom  : 1px solid transparent;
    padding-bottom : 1px;
}
.card__link:hover {
    color        : var(--color-gold-light);
    border-color : var(--color-gold-light);
}
.card__link svg {
    transition: transform var(--transition);
    flex-shrink: 0;
}
.card__link:hover svg { transform: translate(2px, -2px); }

/* ════════════════════════════════════════════════════════════
   BOUTON "VOIR PLUS"
   ════════════════════════════════════════════════════════════ */
.load-more__wrapper {
    display         : flex;
    justify-content : center;
    margin-top      : 3rem;
}

.load-more {
    position      : relative;
    background    : transparent;
    border        : 1px solid var(--color-gold);
    color         : var(--color-gold);
    font-family   : var(--font-body);
    font-size     : 0.82rem;
    font-weight   : 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    padding       : 0.75rem 2.5rem;
    border-radius : var(--radius-sm);
    cursor        : pointer;
    overflow      : hidden;
    transition    : background var(--transition), color var(--transition);
    min-width     : 160px;
    display       : flex;
    align-items   : center;
    justify-content: center;
    gap           : 0.5rem;
}
.load-more:hover:not(:disabled) {
    background : var(--color-gold);
    color      : #0A0A0A;
}
.load-more:disabled {
    opacity : 0.5;
    cursor  : not-allowed;
}

/* Spinner de chargement */
.load-more__spinner {
    display      : none;
    width        : 14px;
    height       : 14px;
    border       : 2px solid currentColor;
    border-top-color: transparent;
    border-radius: 50%;
    animation    : spin 0.7s linear infinite;
    flex-shrink  : 0;
}
.load-more.is-loading .load-more__text   { opacity: 0.6; }
.load-more.is-loading .load-more__spinner{ display: block; }

@keyframes spin {
    to { transform: rotate(360deg); }
}

/* ════════════════════════════════════════════════════════════
   FOOTER
   ════════════════════════════════════════════════════════════ */
.site-footer {
    border-top : 1px solid var(--color-border);
    padding    : 1.5rem 0;
    margin-top : auto;
}
.footer__copy {
    text-align  : center;
    font-size   : 0.75rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color       : var(--color-text-dim);
}

/* ════════════════════════════════════════════════════════════
   RESPONSIVE
   ════════════════════════════════════════════════════════════ */
@media (max-width: 1024px) {
    .grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 640px) {
    .grid { grid-template-columns: 1fr; }

    .filters__inner { gap: 0.4rem; }
    .filters__sort  { margin-left: 0; width: 100%; }
    .sort-select    { width: 100%; }

    .header__count  { display: none; }

    .site-header    { padding: 2rem 0 1.8rem; }
    .main           { padding: 1.5rem 0 3rem; }
}

/* ════════════════════════════════════════════════════════════
   REDUCED MOTION
   ════════════════════════════════════════════════════════════ */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
}
