/*
Theme Name: Chin Chin
Description: Pinterest masonry layout — Food · Fashion · Design
Version: 11.0
*/

@import url('https://fonts.googleapis.com/css2?family=Instrument+Serif:ital@0;1&family=Libre+Franklin:wght@300;400;500;600&display=swap');

* { margin: 0; padding: 0; box-sizing: border-box; }
body { background: #fff; font-family: 'Libre Franklin', sans-serif; color: #24072f; }
a { color: inherit; }

/* ═══ HEADER ═══ */
.cc-header { position: sticky; top: 0; z-index: 300; background: #fff; }
.cc-logo-bar { padding: 22px 0 10px; }
.cc-logo-link { text-decoration: none; display: block; }
.cc-logo-img { width: 100%; display: block; }

.cc-nav-bar { display: flex; justify-content: center; gap: 44px; padding: 0 24px 16px; }
.cc-nav-word {
    font-family: 'Libre Franklin', sans-serif; font-size: 10px; letter-spacing: 3px;
    text-transform: uppercase; color: #24072f; opacity: 0.3;
    text-decoration: none; transition: all 0.35s; display: inline-block;
}
.cc-nav-word:hover { opacity: 0.7; }
.cc-nav-word.active { opacity: 1; font-weight: 600; transform: rotate(-13deg); }

/* ═══ MASONRY FEED ═══ */
.cc-feed { max-width: 1400px; margin: 0 auto; padding: 8px 0 60px; position: relative; }
.cc-card {
    position: absolute; cursor: pointer; transition: opacity 0.3s;
    text-decoration: none; color: inherit; display: block; visibility: hidden;
}
.cc-card:hover { opacity: 0.85; }
.cc-card-img { width: 100%; overflow: hidden; position: relative; }
.cc-card-img img { width: 100%; height: auto; display: block; }

/* Corner tab */
.cc-corner {
    position: absolute; top: 0; left: 0; width: 0; height: 0;
    border-style: solid; border-width: 16px 16px 0 0; z-index: 2;
}
.cc-corner-aperitif { border-color: #24072f transparent transparent transparent; }
.cc-corner-digestif { border-color: #6b8f62 transparent transparent transparent; }

.cc-card-info { padding: 10px 2px 6px; }
.cc-card-label {
    font-family: 'Instrument Serif', serif; font-style: italic;
    font-size: 11px; color: rgba(36,7,47,0.3); margin-bottom: 3px;
}
.cc-card-title {
    font-family: 'Libre Franklin', sans-serif; font-size: 13px;
    font-weight: 600; color: #24072f; line-height: 1.4;
}

/* Featured Digestif */
.cc-featured-digestif {
    display: grid; grid-template-columns: 1.6fr 1fr; gap: 0;
    align-items: end; background: #faf9f7; overflow: hidden;
}
.cc-featured-digestif .cc-corner { border-width: 20px 20px 0 0; }
.cc-featured-digestif .cc-card-img img { aspect-ratio: 3/2; object-fit: cover; }
.cc-featured-digestif .cc-card-info { padding: 32px 40px 36px; }
.cc-featured-digestif .cc-card-label { font-size: 13px; margin-bottom: 8px; }
.cc-featured-digestif .cc-card-title {
    font-family: 'Instrument Serif', serif; font-size: 28px;
    font-weight: 400; line-height: 1.25; margin-bottom: 16px;
}
.cc-card-excerpt { font-size: 13px; line-height: 1.7; color: rgba(36,7,47,0.5); }
.cc-card-read {
    display: inline-block; margin-top: 20px; font-size: 10px; font-weight: 600;
    letter-spacing: 2px; text-transform: uppercase; color: #24072f; opacity: 0.4;
    transition: opacity 0.3s;
}
.cc-featured-digestif:hover .cc-card-read,
.cc-featured-aperitif:hover .cc-card-read { opacity: 1; }

/* Featured Apéritif */
.cc-featured-aperitif { background: #faf9f7; padding: 28px 32px; overflow: hidden; }
.cc-featured-aperitif .cc-corner { border-width: 20px 20px 0 0; }
.cc-featured-aperitif .cc-board-header { margin-bottom: 16px; }
.cc-featured-aperitif .cc-card-label { font-size: 12px; margin-bottom: 4px; }
.cc-featured-aperitif .cc-card-title {
    font-family: 'Instrument Serif', serif; font-size: 24px;
    font-weight: 400; line-height: 1.25;
}
.cc-featured-aperitif .cc-card-excerpt {
    font-size: 12px; line-height: 1.6; color: rgba(36,7,47,0.4);
    margin-bottom: 20px; max-width: 500px;
}
.cc-board-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; }
.cc-board-thumb { width: 100%; aspect-ratio: 4/5; overflow: hidden; border-radius: 3px; }
.cc-board-thumb img { width: 100%; height: 100%; object-fit: cover; }

/* ═══ ARTICLE ═══ */
.cc-article-hero { width: 100%; max-height: 70vh; object-fit: cover; display: block; }
.cc-article { max-width: 680px; margin: 0 auto; padding: 40px 20px 80px; }
.cc-article-label {
    font-family: 'Instrument Serif', serif; font-style: italic;
    font-size: 14px; color: rgba(36,7,47,0.35); margin-bottom: 8px;
}
.cc-article-title {
    font-family: 'Instrument Serif', serif; font-size: 38px;
    font-weight: 400; line-height: 1.2; margin-bottom: 28px;
}
.cc-article-body p { font-size: 15px; line-height: 1.8; margin-bottom: 20px; color: rgba(36,7,47,0.7); }
.cc-mention-link { color: #24072f; text-decoration: none; border-bottom: 1.5px dotted rgba(36,7,47,0.2); }
.cc-article-mentions { margin-top: 40px; padding-top: 20px; border-top: 1px solid rgba(36,7,47,0.06); }
.cc-article-mentions-label {
    font-size: 10px; letter-spacing: 2px; text-transform: uppercase;
    color: rgba(36,7,47,0.25); margin-bottom: 10px; display: block;
}
.cc-article-mention-tag {
    display: inline-block; padding: 5px 14px; font-size: 11px;
    color: rgba(36,7,47,0.5); border: 1px solid rgba(36,7,47,0.08);
    border-radius: 20px; text-decoration: none; margin: 4px 4px 0 0;
}

/* ═══ DOSSIER ARCHIVE ═══ */
.cc-dossier-archive { max-width: 1000px; margin: 0 auto; padding: 20px 32px 60px; }
.cc-dossier-header { text-align: center; margin-bottom: 32px; }
.cc-dossier-title { font-family: 'Instrument Serif', serif; font-size: 38px; font-weight: 400; margin-bottom: 8px; }
.cc-dossier-subtitle { font-size: 12px; color: rgba(36,7,47,0.35); letter-spacing: 0.5px; }
.cc-dossier-filters { display: flex; flex-wrap: wrap; justify-content: center; gap: 8px; margin-bottom: 40px; }
.cc-dossier-filter {
    font-size: 10px; font-weight: 500; letter-spacing: 1px; text-transform: uppercase;
    color: rgba(36,7,47,0.35); padding: 6px 14px; border: 1px solid rgba(36,7,47,0.08);
    border-radius: 20px; text-decoration: none; transition: all 0.25s;
}
.cc-dossier-filter:hover { color: #24072f; border-color: rgba(36,7,47,0.2); }
.cc-dossier-filter.active { background: #24072f; color: #fff; border-color: #24072f; }

.cc-dossier-list { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0 32px; }
.cc-dossier-letter {
    font-family: 'Instrument Serif', serif; font-size: 28px; color: rgba(36,7,47,0.12);
    margin: 36px 0 12px; padding-bottom: 8px; border-bottom: 1px solid rgba(36,7,47,0.04);
    grid-column: 1 / -1;
}
.cc-dossier-letter:first-of-type { margin-top: 0; }
.cc-dossier-card {
    padding: 14px 0; border-bottom: 1px solid rgba(36,7,47,0.04);
    text-decoration: none; display: block; transition: opacity 0.2s;
}
.cc-dossier-card:hover { opacity: 0.65; }
.cc-dossier-card-name {
    font-size: 15px; font-weight: 600; color: #24072f; margin-bottom: 3px;
    display: flex; align-items: center; gap: 8px;
}
.cc-dossier-card-spec {
    font-size: 9px; font-weight: 500; letter-spacing: 1px; text-transform: uppercase;
    color: rgba(36,7,47,0.3); padding: 2px 8px; border: 1px solid rgba(36,7,47,0.08);
    border-radius: 12px; white-space: nowrap; display: inline-block;
}
.cc-dossier-card-bio { font-size: 11px; color: rgba(36,7,47,0.35); line-height: 1.5; }
.cc-dossier-empty { font-size: 13px; color: rgba(36,7,47,0.3); grid-column: 1 / -1; text-align: center; padding: 60px 0; }

/* Single dossier profile — aligned with feed */
.cc-profile-header { max-width: 1400px; margin: 0 auto; padding: 32px 32px 0; }
.cc-profile-name { font-family: 'Instrument Serif', serif; font-size: 38px; font-weight: 400; line-height: 1.2; margin-bottom: 12px; }
.cc-profile-specs { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 24px; }
.cc-profile-body { max-width: 680px; }
.cc-profile-body p { font-size: 15px; line-height: 1.8; margin-bottom: 20px; color: rgba(36,7,47,0.7); }
.cc-profile-mentioned-label { font-size: 10px; letter-spacing: 2px; text-transform: uppercase; color: rgba(36,7,47,0.25); margin-top: 40px; padding-top: 20px; border-top: 1px solid rgba(36,7,47,0.06); margin-bottom: 8px; }

/* ═══ FOOTER ═══ */
.cc-footer-wrap { border-top: 1px solid rgba(36,7,47,0.04); }
.cc-subscribe { max-width: 480px; margin: 0 auto; padding: 48px 20px 36px; text-align: center; }
.cc-subscribe-note { font-size: 13px; line-height: 1.7; color: rgba(36,7,47,0.35); margin-bottom: 6px; }
.cc-subscribe-cta { font-family: 'Instrument Serif', serif; font-style: italic; font-size: 18px; color: rgba(36,7,47,0.55); margin-bottom: 20px; }
.cc-subscribe-form { display: flex; gap: 8px; max-width: 340px; margin: 0 auto; }
.cc-subscribe-input { flex: 1; padding: 10px 14px; border: 1px solid rgba(36,7,47,0.1); font-family: 'Libre Franklin', sans-serif; font-size: 12px; outline: none; }
.cc-subscribe-btn { padding: 10px 20px; background: #24072f; color: #fff; border: none; font-size: 10px; letter-spacing: 2px; text-transform: uppercase; cursor: pointer; }
.cc-footer-bottom { display: flex; justify-content: center; align-items: center; gap: 16px; padding: 20px; font-size: 11px; opacity: 0.45; }
.cc-footer-bottom a { color: rgba(0,0,0,0.28); letter-spacing: 1.5px; text-transform: uppercase; text-decoration: none; }
.cc-footer-bottom a:hover { opacity: 0.7; }
.cc-fdot { color: rgba(0,0,0,0.1); }
.cc-footer-ig { display: inline-flex; align-items: center; }

/* ═══ HAMBURGER ═══ */
.cc-hamburger {
    display: none; background: none; border: none; cursor: pointer;
    padding: 10px 0; z-index: 210; width: 28px; height: 20px; position: relative;
}
.cc-hamburger span {
    display: block; width: 28px; height: 1.5px; background: #24072f;
    position: absolute; left: 0; transition: all 0.3s;
}
.cc-hamburger span:first-child { top: 4px; }
.cc-hamburger span:last-child { bottom: 4px; }
.cc-hamburger.open span:first-child { top: 50%; transform: translateY(-50%) rotate(45deg); }
.cc-hamburger.open span:last-child { bottom: auto; top: 50%; transform: translateY(-50%) rotate(-45deg); }

.cc-mobile-bar { display: none; justify-content: center; padding: 0 0 14px; position: relative; z-index: 210; }

.cc-mobile-overlay {
    position: fixed; inset: 0; background: #fff; z-index: 200;
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    opacity: 0; pointer-events: none; transition: opacity 0.3s;
}
.cc-mobile-overlay.open { opacity: 1; pointer-events: all; }
.cc-mobile-nav-links { position: relative; width: 280px; height: 360px; }
.cc-mobile-nav-links a {
    font-size: 11px; letter-spacing: 3px; text-transform: uppercase;
    color: #24072f; text-decoration: none; opacity: 0.45;
    transition: opacity 0.3s; position: absolute;
}
.cc-mobile-nav-links a:hover { opacity: 1; }
.cc-mob-1 { top: 0; left: 20px; transform: rotate(-8deg); }
.cc-mob-2 { top: 55px; left: 140px; transform: rotate(5deg); }
.cc-mob-3 { top: 115px; left: 30px; transform: rotate(-3deg); }
.cc-mob-4 { top: 170px; left: 120px; transform: rotate(7deg); }
.cc-mob-5 { top: 230px; left: 10px; transform: rotate(-6deg); }
.cc-mob-6 { top: 280px; left: 150px; transform: rotate(4deg); }
.cc-mob-7 { top: 335px; left: 60px; transform: rotate(-5deg); }

/* ═══ RESPONSIVE ═══ */
@media (max-width: 1024px) {
    .cc-featured-digestif { grid-template-columns: 1.4fr 1fr; }
    .cc-featured-digestif .cc-card-img img { aspect-ratio: 5/6; }
}

@media (max-width: 768px) {
    .cc-nav-bar { display: none; }
    .cc-mobile-bar { display: flex; }
    .cc-hamburger { display: block; }

    .cc-featured-digestif { grid-template-columns: 1fr; }
    .cc-featured-digestif .cc-card-img img { aspect-ratio: 16/9; }
    .cc-featured-digestif .cc-card-info { padding: 20px 16px; }
    .cc-featured-digestif .cc-card-title { font-size: 20px; }
    .cc-featured-digestif .cc-card-excerpt { font-size: 12px; }
    .cc-featured-aperitif { padding: 20px 16px; }
    .cc-featured-aperitif .cc-card-title { font-size: 20px; }
    .cc-featured-aperitif .cc-board-grid { gap: 6px; }
    .cc-card-title { font-size: 12px; }

    .cc-dossier-archive { padding: 20px 20px 60px; }
    .cc-dossier-title { font-size: 28px; }
    .cc-dossier-list { grid-template-columns: 1fr; }

    .cc-footer-bottom { flex-wrap: wrap; gap: 12px; }
}