/* ==========================================================================
   Cock Collection - brand styles
   Palette: #3A0519 burgundy · #670D2F wine · #A53860 rose · #EF88AD pink
   ========================================================================== */

:root {
    --cc-burgundy: #3A0519;
    --cc-wine: #670D2F;
    --cc-rose: #A53860;
    --cc-pink: #EF88AD;
    --cc-pink-soft: #f6b9d0;
    --cc-ink: #1a0410;
    --cc-cream: #fff6fa;
    --cc-white: #ffffff;

    --cc-radius: 18px;
    --cc-radius-sm: 12px;
    --cc-shadow: 0 10px 30px rgba(58, 5, 25, 0.18);
    --cc-shadow-soft: 0 6px 18px rgba(58, 5, 25, 0.12);
    --cc-grad: linear-gradient(135deg, #3A0519 0%, #670D2F 55%, #A53860 100%);
    --cc-grad-hot: linear-gradient(135deg, #670D2F 0%, #A53860 60%, #EF88AD 100%);

    --bs-body-font-family: 'Fredoka', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
}

* { scroll-behavior: smooth; }
html { overflow-x: clip; }
body { overflow-x: clip; max-width: 100%; }

@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after { animation: none !important; transition: none !important; scroll-behavior: auto !important; }
}

body {
    font-family: var(--bs-body-font-family);
    background:
        radial-gradient(1200px 600px at 100% -10%, rgba(165, 56, 96, 0.18), transparent 60%),
        radial-gradient(900px 500px at -10% 10%, rgba(239, 136, 173, 0.12), transparent 55%),
        var(--cc-ink);
    color: #2b2530;
    min-height: 100vh;
}

main { width: 100%; max-width: 100%; }

/* Honeypot (hidden from users, not display:none inline) */
.cc-honeypot {
    position: absolute;
    left: -9999px;
    width: 1px;
    height: 1px;
    opacity: 0;
    pointer-events: none;
}

a { color: var(--cc-rose); text-decoration: none; }
a:hover { color: var(--cc-wine); }

/* Skip link ------------------------------------------------------------- */
.skip-link {
    position: absolute; left: -999px; top: 0; z-index: 2000;
    background: var(--cc-wine); color: #fff; padding: .6rem 1rem; border-radius: 0 0 12px 0;
}
.skip-link:focus { left: 0; color: #fff; }

/* Navbar ---------------------------------------------------------------- */
.cc-navbar {
    background: rgba(26, 4, 16, 0.85);
    backdrop-filter: blur(12px);
    border-bottom: 1px solid rgba(239, 136, 173, 0.18);
}
.cc-brand {
    font-weight: 700; font-size: 1.35rem; letter-spacing: .3px;
    background: linear-gradient(90deg, #EF88AD, #fff);
    -webkit-background-clip: text; background-clip: text; color: transparent;
    display: inline-flex; align-items: center; gap: .45rem;
}
.cc-brand i { color: var(--cc-pink); -webkit-text-fill-color: var(--cc-pink); }
.cc-navbar .nav-link { color: rgba(255,255,255,.82) !important; font-weight: 500; border-radius: 10px; padding: .4rem .8rem !important; }
.cc-navbar .nav-link:hover, .cc-navbar .nav-link.active { color: #fff !important; background: rgba(239,136,173,.16); }
.cc-navbar .navbar-toggler { border-color: rgba(239,136,173,.4); }

/* Buttons --------------------------------------------------------------- */
.btn { border-radius: 999px; font-weight: 600; padding: .6rem 1.3rem; transition: transform .12s ease, box-shadow .15s ease, filter .15s ease; }
.btn:active { transform: translateY(1px); }
.btn-cc-primary { background: var(--cc-grad-hot); color: #fff; border: none; box-shadow: 0 8px 20px rgba(165,56,96,.4); }
.btn-cc-primary:hover { color: #fff; filter: brightness(1.06); box-shadow: 0 10px 26px rgba(165,56,96,.5); }
.btn-cc-secondary { background: rgba(255,255,255,.9); color: var(--cc-wine); border: 1.5px solid var(--cc-pink); }
.btn-cc-secondary:hover { background: #fff; color: var(--cc-burgundy); }
.btn-cc-danger { background: linear-gradient(135deg,#7a0b1f,#c0264b); color:#fff; border:none; }
.btn-cc-danger:hover { color:#fff; filter:brightness(1.08); }
.btn-cc-ghost { background: transparent; color: #fff; border: 1.5px solid rgba(255,255,255,.5); }
.btn-cc-ghost:hover { background: rgba(255,255,255,.12); color: #fff; }

/* Cards ----------------------------------------------------------------- */
.cc-card {
    background: var(--cc-white);
    border-radius: var(--cc-radius);
    box-shadow: var(--cc-shadow-soft);
    border: 1px solid rgba(165,56,96,.08);
    overflow: hidden;
}
.cc-card-pad { padding: 1.5rem; }

/* Hero ------------------------------------------------------------------ */
.cc-hero {
    background: var(--cc-grad);
    border-radius: 0 0 36px 36px;
    color: #fff;
    position: relative;
    overflow: hidden;
}
.cc-hero::after {
    content: ""; position: absolute; inset: 0;
    background: radial-gradient(600px 300px at 80% 0%, rgba(239,136,173,.35), transparent 60%);
    pointer-events: none;
}
.cc-hero h1 { font-weight: 700; font-size: clamp(2.2rem, 6vw, 4rem); line-height: 1.05; }
.cc-hero .lead { color: rgba(255,255,255,.92); font-size: clamp(1.05rem,2.5vw,1.4rem); }
.cc-hero-intro { font-size: 1.02rem; line-height: 1.65; max-width: 42rem; }

/* Home content blocks --------------------------------------------------- */
.cc-home-block {
    background: #fff;
    border-radius: var(--cc-radius);
    box-shadow: var(--cc-shadow-soft);
    padding: 2rem 1.75rem;
    border: 1px solid rgba(165,56,96,.08);
}
@media (min-width: 768px) {
    .cc-home-block { padding: 2.25rem 2.5rem; }
}
.cc-home-block-icon {
    font-size: 2.75rem;
    color: var(--cc-rose);
    line-height: 1;
    margin-bottom: .75rem;
}
.cc-home-block-title {
    font-weight: 700;
    color: var(--cc-burgundy);
    margin-bottom: 0;
}
.cc-home-block-lead {
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--cc-wine);
    margin-bottom: .75rem;
}
.cc-home-block-text {
    color: #5c4d56;
    line-height: 1.7;
    margin-bottom: .85rem;
}
.cc-home-block--submit {
    background:
        linear-gradient(135deg, rgba(255,246,250,.95), #fff 55%),
        #fff;
}
.cc-home-block--browse {
    background:
        linear-gradient(225deg, rgba(246,185,208,.12), transparent 45%),
        #fff;
}
.cc-home-cta {
    text-align: center;
    max-width: 720px;
    margin: 0 auto;
}
.cc-home-cta-inner {
    background: var(--cc-grad);
    color: #fff;
    border-radius: 28px;
    padding: 2.5rem 1.75rem;
    box-shadow: var(--cc-shadow);
    position: relative;
    overflow: hidden;
}
.cc-home-cta-inner::after {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(500px 220px at 90% 0%, rgba(239,136,173,.35), transparent 65%);
    pointer-events: none;
}
.cc-home-cta-inner > * { position: relative; z-index: 1; }
.cc-home-cta-inner h2 { font-weight: 700; color: #fff; }
.cc-home-cta-lead {
    font-size: 1.15rem;
    color: rgba(255,255,255,.95);
    margin-bottom: .85rem;
}
.cc-home-cta-text {
    color: rgba(255,255,255,.82);
    line-height: 1.65;
    margin-bottom: .75rem;
}
.cc-home-cta-text strong { color: #fff; }

/* Badges ---------------------------------------------------------------- */
.cc-badge { display: inline-flex; align-items: center; gap: .3rem; font-size: .72rem; font-weight: 700; padding: .28rem .65rem; border-radius: 999px; letter-spacing: .3px; text-transform: uppercase; }
.cc-badge-verified { background: linear-gradient(135deg,#2e7d32,#66bb6a); color: #fff; }
.cc-badge-new { background: linear-gradient(135deg,#A53860,#EF88AD); color: #fff; }
.cc-badge-pending { background: #fff3cd; color: #8a6d00; }
.cc-badge-rejected { background: #f8d7da; color: #842029; }
.cc-badge-approved { background: #d1e7dd; color: #0f5132; }
.cc-badge-private { background: #e2e3e5; color: #41464b; }
.cc-badge-suspended { background:#3a3a3a; color:#fff; }
.cc-badge-draft { background:#eee; color:#555; }

/* 18+ notice ------------------------------------------------------------ */
.cc-adult-notice { display:inline-flex; align-items:center; gap:.5rem; background: rgba(239,136,173,.16); border:1px solid rgba(239,136,173,.4); color:#fff; padding:.4rem .9rem; border-radius:999px; font-size:.85rem; font-weight:600; }

/* Gallery grid ---------------------------------------------------------- */
.cc-gallery-grid { display:grid; grid-template-columns: repeat(auto-fill, minmax(165px,1fr)); gap: 1rem; }
@media (min-width: 768px) { .cc-gallery-grid { grid-template-columns: repeat(auto-fill, minmax(220px,1fr)); gap:1.25rem; } }

.cc-tile { position: relative; display:block; border-radius: var(--cc-radius); overflow:hidden; background:#2a0a18; box-shadow: var(--cc-shadow-soft); transition: transform .18s ease, box-shadow .18s ease; }
.cc-tile:hover { transform: translateY(-4px); box-shadow: var(--cc-shadow); }
.cc-tile-img { aspect-ratio: 4/5; width: 100%; object-fit: cover; display:block; background:#3a0519; }
.cc-tile-body { padding: .7rem .85rem .9rem; background:#fff; }
.cc-tile-name { font-weight:700; color: var(--cc-burgundy); display:flex; align-items:center; gap:.35rem; font-size:1rem; }
.cc-tile-badges { position:absolute; top:.6rem; left:.6rem; display:flex; gap:.35rem; flex-wrap:wrap; }
.cc-tile-stats { display:flex; flex-wrap:wrap; gap:.3rem; margin-top:.45rem; }
.cc-stat-chip { font-size:.68rem; background: var(--cc-cream); color: var(--cc-wine); padding:.18rem .5rem; border-radius:999px; border:1px solid rgba(165,56,96,.15); }
.cc-fav-btn { position:absolute; top:.5rem; right:.5rem; background:rgba(26,4,16,.55); color:#fff; border:none; width:34px; height:34px; border-radius:50%; display:flex; align-items:center; justify-content:center; }
.cc-fav-btn.is-fav { background: var(--cc-grad-hot); }

/* Loading skeletons ----------------------------------------------------- */
.cc-skeleton { border-radius: var(--cc-radius); overflow:hidden; background:#fff; box-shadow: var(--cc-shadow-soft); }
.cc-skeleton .sk-img { aspect-ratio:4/5; background: linear-gradient(100deg,#eee 30%,#f5f5f5 50%,#eee 70%); background-size:200% 100%; animation: ccshimmer 1.2s infinite; }
.cc-skeleton .sk-line { height:12px; margin:.6rem .8rem; border-radius:6px; background: linear-gradient(100deg,#eee 30%,#f5f5f5 50%,#eee 70%); background-size:200% 100%; animation: ccshimmer 1.2s infinite; }
@keyframes ccshimmer { 0%{background-position:200% 0} 100%{background-position:-200% 0} }

/* Empty state ----------------------------------------------------------- */
.cc-empty { text-align:center; padding:3rem 1rem; color:#6b5560; }
.cc-empty i { font-size:3rem; color: var(--cc-pink); }

/* Filters --------------------------------------------------------------- */
.cc-filters { background:#fff; border-radius: var(--cc-radius); padding:1.25rem; box-shadow: var(--cc-shadow-soft); position: sticky; top: 90px; }
.cc-filters label { font-size:.8rem; font-weight:600; color: var(--cc-wine); }
.form-control, .form-select { border-radius: 12px; border:1.5px solid #ead7e0; }
.form-control:focus, .form-select:focus { border-color: var(--cc-pink); box-shadow: 0 0 0 .2rem rgba(239,136,173,.25); }

/* Age gate -------------------------------------------------------------- */
.cc-agegate-overlay { position: fixed; inset:0; z-index: 3000; background: rgba(10,2,7,.92); backdrop-filter: blur(8px); display:flex; align-items:center; justify-content:center; padding:1rem; }
.cc-agegate-card { max-width: 480px; width:100%; background:#fff; border-radius: 24px; padding:2rem; text-align:center; box-shadow: var(--cc-shadow); }
.cc-agegate-card h2 { color: var(--cc-burgundy); font-weight:700; }
.cc-agegate-confirm {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    max-width: 400px;
    text-align: left;
    padding: 1.1rem 1.2rem;
    border: 2px solid var(--cc-rose);
    border-radius: var(--cc-radius-sm);
    background: var(--cc-cream);
    box-shadow: var(--cc-shadow-soft);
    cursor: pointer;
    transition: border-color .2s ease, box-shadow .2s ease, background-color .2s ease;
    margin-bottom: 0;
}
.cc-agegate-confirm:hover {
    border-color: var(--cc-wine);
    background: #fff;
}
.cc-agegate-confirm:has(.cc-agegate-check-input:focus-visible) {
    border-color: var(--cc-wine);
    box-shadow: 0 0 0 4px rgba(165, 56, 96, 0.25);
}
.cc-agegate-check-input {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}
.cc-agegate-check-box {
    flex: 0 0 auto;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2.25rem;
    height: 2.25rem;
    margin-top: .1rem;
    border: 3px solid var(--cc-wine);
    border-radius: 8px;
    background: #fff;
    color: transparent;
    font-size: 1.35rem;
    line-height: 1;
    box-shadow: inset 0 0 0 1px rgba(58, 5, 25, 0.08);
    transition: background-color .15s ease, border-color .15s ease, color .15s ease, transform .15s ease;
}
.cc-agegate-confirm:hover .cc-agegate-check-box {
    border-color: var(--cc-burgundy);
    box-shadow: 0 2px 8px rgba(58, 5, 25, 0.15);
}
.cc-agegate-check-input:checked + .cc-agegate-check-box {
    background: var(--cc-wine);
    border-color: var(--cc-wine);
    color: #fff;
    transform: scale(1.05);
}
.cc-agegate-check-text {
    font-size: .98rem;
    line-height: 1.5;
    color: var(--cc-burgundy);
}
.cc-agegate-confirm.is-invalid {
    border-color: #dc3545;
    background: #fff5f5;
    animation: cc-agegate-shake .35s ease;
}
.cc-agegate-confirm.is-invalid .cc-agegate-check-box {
    border-color: #dc3545;
    box-shadow: 0 0 0 3px rgba(220, 53, 69, 0.2);
}
@keyframes cc-agegate-shake {
    0%, 100% { transform: translateX(0); }
    25% { transform: translateX(-4px); }
    75% { transform: translateX(4px); }
}

/* Section helpers ------------------------------------------------------- */
.cc-section-title { font-weight:700; color: var(--cc-wine); display:flex; align-items:center; gap:.5rem; }
.cc-hero .cc-section-title { color:#fff; }
.cc-hero-stat { color: rgba(255,255,255,.95); }
.cc-hero-stat strong { color:#fff; }
.cc-on-dark { color: #fff; }
.cc-muted-light,
.bg-cc-grad .cc-muted-light,
.cc-hero .cc-muted-light,
.cc-footer .cc-muted-light,
.cc-status-banner .cc-muted-light { color: rgba(255,255,255,.75); }
.cc-panel { background:#fff; border-radius: var(--cc-radius); box-shadow: var(--cc-shadow-soft); padding: 1.5rem; }

/* Auth pages (login, verify code) --------------------------------------- */
.cc-auth-body {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}
.cc-auth-header {
    flex-shrink: 0;
    text-align: center;
    padding: 1.5rem 1rem .75rem;
}
.cc-auth-brand {
    justify-content: center;
    font-size: 1.3rem;
}
.cc-auth-main {
    flex: 1 1 auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    width: 100%;
    max-width: 100%;
    padding: 1rem 1rem 2rem;
    box-sizing: border-box;
}
.cc-auth-alerts {
    width: 100%;
    max-width: 440px;
    margin: 0 auto 1rem;
}
.cc-auth-card {
    width: 100%;
    max-width: 440px;
    margin: 0 auto;
    flex-shrink: 0;
}
.cc-auth-icon {
    font-size: 2.4rem;
    color: var(--cc-rose);
    line-height: 1;
}
.cc-auth-footer {
    flex-shrink: 0;
    text-align: center;
    padding: 1rem;
    font-size: .85rem;
    color: rgba(255,255,255,.55);
}
.cc-auth-footer a {
    color: rgba(255,255,255,.78);
    text-decoration: none;
}
.cc-auth-footer a:hover { color: var(--cc-pink); }
.cc-auth-footer span { margin: 0 .35rem; opacity: .5; }
.cc-auth-footer-link { color: rgba(255,255,255,.72) !important; text-decoration: none; }
.cc-auth-footer-link:hover { color: var(--cc-pink) !important; }

/* Profile detail -------------------------------------------------------- */
.cc-profile-photo { width:100%; border-radius: var(--cc-radius); object-fit: cover; box-shadow: var(--cc-shadow-soft); background:#3a0519; }
.cc-thumb-row img { width:72px; height:90px; object-fit:cover; border-radius:10px; cursor:pointer; border:2px solid transparent; }
.cc-thumb-row img.active { border-color: var(--cc-pink); }
.cc-spec-list { display:grid; grid-template-columns: 1fr 1fr; gap:.5rem 1rem; }
.cc-spec-list .k { color:#8a7480; font-size:.8rem; }
.cc-spec-list .v { font-weight:600; color: var(--cc-burgundy); }

/* Toasts ---------------------------------------------------------------- */
.cc-toast-wrap { position: fixed; bottom: 1rem; right: 1rem; z-index: 4000; display:flex; flex-direction:column; gap:.5rem; }
.cc-toast { background:#fff; border-left:4px solid var(--cc-rose); padding:.8rem 1rem; border-radius:12px; box-shadow: var(--cc-shadow); min-width:240px; animation: ccpop .25s ease; }
.cc-toast.ok { border-color:#2e7d32; }
.cc-toast.err { border-color:#c0264b; }
@keyframes ccpop { from{ transform: translateY(10px); opacity:0 } to{ transform:none; opacity:1 } }

/* Footer ---------------------------------------------------------------- */
.cc-footer { color: rgba(255,255,255,.72); padding: 2.5rem 0 1.5rem; }
.cc-footer a { color: rgba(255,255,255,.85); }
.cc-footer a:hover { color: var(--cc-pink); }
.cc-footer h6 { color:#fff; font-weight:700; }

/* Dashboard ------------------------------------------------------------- */
.cc-status-banner { border-radius: var(--cc-radius); padding:1.25rem 1.5rem; color:#fff; background: var(--cc-grad); }
.cc-checklist { list-style:none; padding:0; margin:0; }
.cc-checklist li { display:flex; align-items:center; gap:.6rem; padding:.5rem 0; border-bottom:1px solid #f1e3ea; }
.cc-checklist li .ico { width:26px; height:26px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:.8rem; }
.cc-checklist li.done .ico { background:#d1e7dd; color:#0f5132; }
.cc-checklist li.todo .ico { background:#f8d7da; color:#842029; }

.cc-progress { height:10px; border-radius:999px; background:#f1e3ea; overflow:hidden; }
.cc-progress > span { display:block; height:100%; background: var(--cc-grad-hot); }

/* Admin ----------------------------------------------------------------- */
.cc-admin-body { background: #f5eef2; }
.cc-admin-sidebar { background: var(--cc-burgundy); min-height:100vh; }
.cc-admin-sidebar a { color: rgba(255,255,255,.8); display:flex; align-items:center; gap:.6rem; padding:.7rem 1rem; border-radius:12px; margin:.15rem .5rem; font-weight:500; }
.cc-admin-sidebar a:hover, .cc-admin-sidebar a.active { background: rgba(239,136,173,.2); color:#fff; }
.cc-stat-card { background:#fff; border-radius: var(--cc-radius-sm); padding:1.1rem 1.25rem; box-shadow: var(--cc-shadow-soft); }
.cc-stat-card .num { font-size:1.8rem; font-weight:700; color: var(--cc-wine); }
.cc-stat-card .lbl { color:#8a7480; font-size:.85rem; }
.cc-blur { filter: blur(18px); transition: filter .2s; }
.cc-blur:hover { filter: none; }

/* Utility --------------------------------------------------------------- */
.cc-link-muted { color:#8a7480; }
.text-cc-wine { color: var(--cc-wine) !important; }
.bg-cc-grad { background: var(--cc-grad); }
.cc-divider { height:1px; background: linear-gradient(90deg, transparent, rgba(165,56,96,.3), transparent); margin:1.5rem 0; }
.cc-pill-input { display:inline-flex; gap:.25rem; }

/* Profile form grids ---------------------------------------------------- */
.cc-measure-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .85rem 1rem;
}
@media (min-width: 768px) {
    .cc-measure-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}
@media (min-width: 992px) {
    .cc-measure-grid {
        grid-template-columns: minmax(130px, 0.9fr) repeat(4, minmax(0, 1fr));
    }
}
.cc-measure-field .form-label {
    font-size: .82rem;
    line-height: 1.25;
    min-height: 2.5rem;
    display: flex;
    align-items: flex-end;
}

.cc-color-section { margin-top: .25rem; }
.cc-color-panel {
    background: #fff8fb;
    border: 1px solid rgba(165,56,96,.1);
    border-radius: var(--cc-radius-sm);
    padding: .85rem .9rem 1rem;
}
.cc-color-palette {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(68px, 1fr));
    gap: .45rem;
}
.cc-color-swatch {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    gap: .3rem;
    min-width: 0;
    padding: .4rem .25rem .45rem;
    border-radius: 10px;
    border: 1.5px solid #ead7e0;
    background: #fff;
    cursor: pointer;
    text-align: center;
    transition: border-color .15s ease, box-shadow .15s ease, transform .12s ease;
}
.cc-color-swatch:hover { border-color: var(--cc-pink); transform: translateY(-1px); }
.cc-color-swatch input { position: absolute; opacity: 0; pointer-events: none; }
.cc-color-swatch:has(input:checked) {
    border-color: var(--cc-rose);
    box-shadow: 0 0 0 .15rem rgba(239,136,173,.25);
    background: #fff;
}
.cc-color-dot {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    border: 2px solid rgba(26,4,16,.12);
    box-shadow: inset 0 0 0 1px rgba(255,255,255,.35);
    flex-shrink: 0;
}
.cc-color-label {
    font-size: .62rem;
    line-height: 1.2;
    color: #6b5560;
    font-weight: 600;
    width: 100%;
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    word-break: break-word;
}
@media (min-width: 1200px) {
    .cc-color-palette {
        grid-template-columns: repeat(7, minmax(0, 1fr));
    }
}

/* Chip fields (turn-ons, tags) ------------------------------------------ */
.cc-chip-item {
    display:inline-flex; align-items:center; gap:.35rem; padding:.28rem .55rem .28rem .7rem;
    border-radius:999px; font-size:.78rem; font-weight:600;
}
.cc-turnon-chip { background:#fff0f5; color: var(--cc-wine); border:1px solid rgba(165,56,96,.18); }
.cc-tag-chip { background: var(--cc-cream); color: var(--cc-burgundy); border:1px solid rgba(165,56,96,.15); }
.cc-chip-remove {
    border:none; background:transparent; color:inherit; opacity:.65; font-size:1rem; line-height:1;
    padding:0 .1rem; cursor:pointer;
}
.cc-chip-remove:hover { opacity:1; }

.cc-chip-input-wrap { position: relative; }
.cc-chip-suggest {
    position: absolute;
    left: 0;
    right: 0;
    top: calc(100% + 4px);
    z-index: 20;
    background: #fff;
    border: 1px solid rgba(165,56,96,.18);
    border-radius: 12px;
    box-shadow: var(--cc-shadow-soft);
    padding: .35rem;
    max-height: 220px;
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    gap: .2rem;
}
.cc-chip-suggest-item {
    display: block;
    width: 100%;
    text-align: left;
    border: none;
    background: transparent;
    border-radius: 8px;
    padding: .45rem .65rem;
    font-size: .85rem;
    color: var(--cc-wine);
    cursor: pointer;
}
.cc-chip-suggest-item:hover,
.cc-chip-suggest-item:focus {
    background: #fff0f5;
    color: var(--cc-burgundy);
}
