:root{--color-primary:#ec4899;--color-primary-dark:#db2777;--color-primary-light:#f472b6;--color-accent:#a855f7;--color-accent-dark:#9333ea;--color-secondary:#64748b;--color-success:#22c55e;--color-warning:#f59e0b;--color-error:#ef4444;--color-info:#3b82f6;--color-bg:#09090b;--color-bg-secondary:#18181b;--color-bg-tertiary:#27272a;--color-bg-elevated:#1c1c20;--color-text:#fafafa;--color-text-secondary:#a1a1aa;--color-text-muted:#71717a;--color-border:#27272a;--color-border-subtle:#1e1e22;--card-shadow:0 0 0 1px rgba(255,255,255,.04);--card-shadow-hover:0 8px 30px rgba(0,0,0,.4) , 0 0 0 1px rgba(255,255,255,.06);--overlay-gradient: linear-gradient(
        0deg,
        rgba(0, 0, 0, 0.85) 0%,
        rgba(0, 0, 0, 0.4) 50%,
        transparent 100%
    );--overlay-gradient-subtle: linear-gradient(
        0deg,
        rgba(0, 0, 0, 0.6) 0%,
        transparent 60%
    );--header-bg:rgba(9,9,11,.85);--header-blur:blur(16px) saturate(180%);--font-family:"Inter" , -apple-system , BlinkMacSystemFont , "Segoe UI" , Roboto , sans-serif;--font-size-xs:.75rem;--font-size-sm:.875rem;--font-size-base:1rem;--font-size-lg:1.125rem;--font-size-xl:1.25rem;--font-size-2xl:1.5rem;--font-size-3xl:2rem;--spacing-1:.25rem;--spacing-2:.5rem;--spacing-3:.75rem;--spacing-4:1rem;--spacing-5:1.25rem;--spacing-6:1.5rem;--spacing-8:2rem;--spacing-10:2.5rem;--spacing-12:3rem;--radius-sm:.375rem;--radius-md:.5rem;--radius-lg:.75rem;--radius-xl:1rem;--radius-2xl:1.25rem;--radius-full:9999px;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / 0.1);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / 0.2);--shadow-lg: 0 10px 25px -3px rgb(0 0 0 / 0.3);--shadow-xl: 0 20px 50px -5px rgb(0 0 0 / 0.5);--transition-fast:150ms ease;--transition-normal:250ms cubic-bezier(.4,0,.2,1);--transition-slow:350ms cubic-bezier(.4,0,.2,1);--transition-spring:500ms cubic-bezier(.34,1.56,.64,1)}[data-theme="light"]{--color-primary:#db2777;--color-primary-dark:#be185d;--color-primary-light:#ec4899;--color-accent:#9333ea;--color-accent-dark:#7e22ce;--color-bg:#fafafa;--color-bg-secondary:#fff;--color-bg-tertiary:#f4f4f5;--color-bg-elevated:#fff;--color-text:#18181b;--color-text-secondary:#52525b;--color-text-muted:#a1a1aa;--color-border:#e4e4e7;--color-border-subtle:#f4f4f5;--card-shadow:0 1px 3px rgba(0,0,0,.06) , 0 0 0 1px rgba(0,0,0,.04);--card-shadow-hover:0 10px 30px rgba(0,0,0,.1) , 0 0 0 1px rgba(0,0,0,.06);--overlay-gradient: linear-gradient(
        0deg,
        rgba(0, 0, 0, 0.75) 0%,
        rgba(0, 0, 0, 0.3) 50%,
        transparent 100%
    );--overlay-gradient-subtle: linear-gradient(
        0deg,
        rgba(0, 0, 0, 0.5) 0%,
        transparent 60%
    );--header-bg:rgba(250,250,250,.85);--header-blur:blur(16px) saturate(180%)}*,*::before,*::after{box-sizing:border-box}*{margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family: var(--font-family);font-size:var(--font-size-base);line-height:1.6;color:var(--color-text);background-color:var(--color-bg);min-height:100vh;display:flex;flex-direction:column}img,picture,video,canvas,svg{display:block;max-width:100%}input,button,textarea,select{font:inherit}a{color:var(--color-primary-light);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary)}.container{width:100%;max-width:1400px;margin:0 auto;padding:0 var(--spacing-4)}.main{flex:1;padding:var(--spacing-6) 0;position:relative;z-index:1;isolation:isolate}.header{background:var(--header-bg);-webkit-backdrop-filter:var(--header-blur);backdrop-filter:var(--header-blur);border-bottom:1px solid var(--color-border-subtle);position:sticky;top:0;z-index:1000;padding-top:constant(safe-area-inset-top);padding-top:env(safe-area-inset-top,0)}.nav{display:flex;align-items:center;gap:var(--spacing-3);height:56px}.nav-brand{font-size:var(--font-size-lg);font-weight:800;letter-spacing:-.03em;background: linear-gradient(
        135deg,
        var(--color-primary),
        var(--color-accent)
    );-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.nav-brand:hover{opacity:.85}.nav-search{flex:1;max-width:360px}.search-form{display:flex;position:relative}.search-input{width:100%;padding:var(--spacing-2) var(--spacing-3);padding-right:70px;background-color:var(--color-bg-tertiary);border:1px solid transparent;border-radius:var(--radius-full);color:var(--color-text);font-size:var(--font-size-sm);transition:all var(--transition-normal)}.search-input:focus{outline:none;border-color:var(--color-primary);background-color:var(--color-bg-secondary);box-shadow:0 0 0 3px rgba(236,72,153,.15)}.search-input::placeholder{color:var(--color-text-muted)}.search-input::-webkit-search-cancel-button{-webkit-appearance:none;display:none}.search-suggestions{display:none;position:absolute;top:100%;left:0;right:0;margin-top:var(--spacing-1);background-color:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);overflow:hidden;z-index:100}.search-suggestion{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-2) var(--spacing-3);color:var(--color-text);font-size:var(--font-size-sm);transition:background-color var(--transition-fast);cursor:pointer}.search-suggestion:hover,.search-suggestion.active{background-color:var(--color-bg-tertiary);color:var(--color-text)}.search-suggestion-name{font-weight:500}.search-suggestion-count{font-size:var(--font-size-xs);color:var(--color-text-muted)}.search-section-label{padding:var(--spacing-2) var(--spacing-3);font-size:var(--font-size-xs);font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--color-border)}.search-suggestion-gif{gap:var(--spacing-2)}.search-suggestion-thumb{width:40px;height:30px;object-fit:cover;border-radius:var(--radius-sm);flex-shrink:0}.search-suggestion-icon{flex-shrink:0;opacity:.5;margin-right:2px}.search-suggestion-stats{display:flex;gap:var(--spacing-2);margin-left:auto;flex-shrink:0}.search-suggestion-stat{font-size:var(--font-size-xs);color:var(--color-text-muted);white-space:nowrap}.search-view-all{border-top:1px solid var(--color-border);justify-content:center;gap:var(--spacing-2);color:var(--color-primary);font-weight:500}.search-view-all .search-suggestion-name{color:var(--color-primary)}.search-button{position:absolute;right:4px;top:50%;transform:translateY(-50%);padding:var(--spacing-1) var(--spacing-3);background: linear-gradient(
        135deg,
        var(--color-primary),
        var(--color-accent)
    );color:#fff;border:none;border-radius:var(--radius-full);cursor:pointer;font-size:var(--font-size-xs);font-weight:600;transition:opacity var(--transition-fast)}.search-button:hover{opacity:.9}.mobile-search{display:none}.nav-links{display:flex;align-items:center;gap:var(--spacing-2);position:fixed;top:0;right:var(--spacing-4);height:56px;z-index:1001;background:transparent}.nav-link{color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:500;padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius-md);transition:all var(--transition-fast)}.nav-link:hover{color:var(--color-text);background-color:var(--color-bg-tertiary)}.nav-link-primary{background: linear-gradient(
        135deg,
        var(--color-primary),
        var(--color-accent)
    );color:#fff;font-weight:600}.nav-link-primary:hover{opacity:.9;color:#fff;background: linear-gradient(
        135deg,
        var(--color-primary),
        var(--color-accent)
    )}.nav-dropdown{position:relative}.nav-dropdown-toggle{background:none;border:none;color:var(--color-text-secondary);font-weight:500;font-size:var(--font-size-sm);cursor:pointer;padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius-md);transition:all var(--transition-fast)}.nav-dropdown-toggle:hover{color:var(--color-text);background-color:var(--color-bg-tertiary)}.nav-dropdown-menu{position:absolute;top: calc(100% + 4px);right:0;min-width:180px;background-color:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-1);opacity:0;visibility:hidden;transform:translateY(-8px) scale(.97);transition:all var(--transition-normal);box-shadow:var(--shadow-xl);z-index:200}.nav-dropdown:hover .nav-dropdown-menu,.nav-dropdown:focus-within .nav-dropdown-menu{opacity:1;visibility:visible;transform:translateY(0) scale(1)}.nav-dropdown-item{display:block;padding:var(--spacing-2) var(--spacing-3);color:var(--color-text-secondary);border-radius:var(--radius-md);font-size:var(--font-size-sm);transition:all var(--transition-fast)}.nav-dropdown-item:hover{background-color:var(--color-bg-tertiary);color:var(--color-text)}.nav-dropdown-item.active{background: linear-gradient(
        135deg,
        var(--color-primary),
        var(--color-accent)
    );color:#fff}.media-filter{display:flex;align-items:center;background-color:var(--color-bg-tertiary);border-radius:var(--radius-full);padding:2px;gap:1px}.media-filter-btn{padding:var(--spacing-1) var(--spacing-3);font-size:var(--font-size-xs);font-weight:500;color:var(--color-text-muted);border-radius:var(--radius-full);transition:all var(--transition-fast);white-space:nowrap}.media-filter-btn:hover{color:var(--color-text)}.media-filter-btn.active{background: linear-gradient(
        135deg,
        var(--color-primary),
        var(--color-accent)
    );color:#fff;box-shadow:0 1px 4px rgba(236,72,153,.3)}.media-filter-btn.active:hover{color:#fff;opacity:.9}.lang-switcher,.theme-switcher{margin-left:0}.lang-toggle{font-size:var(--font-size-xs);font-weight:600;padding:var(--spacing-1) var(--spacing-2);background-color:var(--color-bg-tertiary);border-radius:var(--radius-sm)}.lang-switcher .nav-dropdown-menu{min-width:120px}.theme-toggle{font-size:var(--font-size-sm);padding:var(--spacing-1) var(--spacing-2);background-color:var(--color-bg-tertiary);border-radius:var(--radius-sm);display:flex;align-items:center;gap:var(--spacing-1)}.theme-toggle .icon{width:14px;height:14px}.theme-switcher .nav-dropdown-menu{min-width:140px}.theme-option{display:flex;align-items:center;gap:var(--spacing-2)}.theme-option .icon{width:16px;height:16px;flex-shrink:0}.nav-dropdown-divider{border:none;border-top:1px solid var(--color-border);margin:var(--spacing-1) 0}.nav-dropdown-form{margin:0}.nav-dropdown-button{width:100%;text-align:left;background:none;border:none;cursor:pointer}.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:var(--spacing-2)}.nav-toggle span{display:block;width:20px;height:2px;background-color:var(--color-text);border-radius:1px;transition:transform var(--transition-fast)}.footer{background-color:var(--color-bg-secondary);border-top:1px solid var(--color-border-subtle);padding:var(--spacing-6) 0;text-align:center;color:var(--color-text-muted);font-size:var(--font-size-sm)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-4);font-size:var(--font-size-sm);font-weight:600;border-radius:var(--radius-lg);border:none;cursor:pointer;transition:all var(--transition-normal);text-decoration:none}.btn-primary{background: linear-gradient(
        135deg,
        var(--color-primary),
        var(--color-accent)
    );color:#fff;box-shadow:0 2px 10px rgba(236,72,153,.25)}.btn-primary:hover{box-shadow:0 4px 20px rgba(236,72,153,.35);transform:translateY(-1px);color:#fff}.btn-secondary{background-color:var(--color-bg-tertiary);color:var(--color-text);border:1px solid var(--color-border)}.btn-secondary:hover{background-color:var(--color-border);border-color:var(--color-text-muted)}.btn-success{background-color:var(--color-success);color:#fff}.btn-success:hover{background-color:#16a34a}.btn-danger{background-color:var(--color-error);color:#fff}.btn-danger:hover{background-color:#dc2626}.btn-lg{padding:var(--spacing-3) var(--spacing-6);font-size:var(--font-size-base);border-radius:var(--radius-xl)}.btn-sm{padding:var(--spacing-1) var(--spacing-3);font-size:var(--font-size-xs)}.btn:disabled{opacity:.5;cursor:not-allowed}.form-group{margin-bottom:var(--spacing-5)}.form-label{display:block;margin-bottom:var(--spacing-2);font-weight:500;font-size:var(--font-size-sm);color:var(--color-text)}.form-input,.form-textarea,.form-select{width:100%;padding:var(--spacing-3);background-color:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-text);transition:all var(--transition-normal)}.form-input:focus,.form-textarea:focus,.form-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(236,72,153,.15)}.form-input::placeholder,.form-textarea::placeholder{color:var(--color-text-muted)}.form-textarea{resize:vertical;min-height:100px}.form-hint{margin-top:var(--spacing-1);font-size:var(--font-size-sm);color:var(--color-text-muted)}.form-error{margin-top:var(--spacing-1);font-size:var(--font-size-sm);color:var(--color-error)}.form-checkbox{display:flex;align-items:center;gap:var(--spacing-2)}.form-checkbox input[type="checkbox"]{width:18px;height:18px;accent-color:var(--color-primary)}.card{background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--spacing-6)}.card-title{font-size:var(--font-size-xl);font-weight:600;margin-bottom:var(--spacing-4)}.trending-section{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--spacing-4)}.trending-title{font-size:var(--font-size-base);font-weight:600;margin-bottom:var(--spacing-3);display:flex;align-items:center;gap:var(--spacing-2);color:var(--color-text)}.trending-title::before{content:"";display:inline-block;width:8px;height:8px;background:var(--color-primary);border-radius:50%;animation:trending-pulse 2s ease-in-out infinite}@keyframes trending-pulse {
    0%,
    100% {
        opacity: 1;
    }
    50% {
        opacity: 0.4;
    }
}.results-count{font-size:var(--font-size-sm);font-weight:400;color:var(--color-text-muted);margin-left:auto}.trending-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:var(--spacing-3)}.trending-item{text-decoration:none;color:inherit;border-radius:var(--radius-lg);overflow:hidden;background:var(--color-bg-tertiary);transition:transform var(--transition-fast) , box-shadow var(--transition-fast)}.trending-item:hover{transform:translateY(-2px);box-shadow:var(--card-shadow-hover)}.trending-image{aspect-ratio:1;overflow:hidden}.trending-image img{width:100%;height:100%;object-fit:cover}.trending-image{position:relative}.trending-animated{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity var(--transition-fast)}.trending-item.animated-ready:hover .trending-animated{opacity:1}.trending-item.animated-ready:hover .trending-thumb{opacity:0}.trending-info{padding:var(--spacing-2)}.trending-item-title{font-size:var(--font-size-xs);font-weight:500;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--color-text)}.trending-stats{display:flex;gap:var(--spacing-2);margin-top:var(--spacing-1)}.trending-stat{display:flex;align-items:center;gap:2px;font-size:var(--font-size-xs);color:var(--color-text-muted)}.trending-stat .icon{width:12px;height:12px}@media (max-width:1200px){.trending-grid{grid-template-columns:repeat(4,1fr)}}@media (max-width:768px){.trending-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width:480px){.trending-grid{grid-template-columns:repeat(2,1fr)}}.sort-bar{display:flex;gap:var(--spacing-2);flex-wrap:wrap}.sort-btn{padding:var(--spacing-1) var(--spacing-3);font-size:var(--font-size-sm);color:var(--color-text-secondary);background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-full);text-decoration:none;transition:all var(--transition-fast)}.sort-btn:hover{color:var(--color-text);border-color:var(--color-text-muted)}.sort-btn.active{color:#fff;background:var(--color-primary);border-color:var(--color-primary)}.gif-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:8px;column-gap:var(--spacing-3)}.gif-card{break-inside:avoid;border-radius:var(--radius-xl);overflow:hidden;position:relative;box-shadow:var(--card-shadow);transition:box-shadow var(--transition-normal) , transform var(--transition-normal);background-color:var(--color-bg-tertiary)}.gif-card:hover,.gif-card.touch-active{box-shadow:var(--card-shadow-hover);transform:translateY(-2px)}.gif-card-title{display:none}.gif-card-link{display:block}.gif-card-image{position:relative;overflow:hidden;line-height:0;background-color:var(--color-bg-tertiary)}.gif-card-image img{width:100%;height:auto;display:block}.gif-card-image .gif-card-thumb{transition:transform var(--transition-slow) , opacity var(--transition-fast)}.gif-card-image .gif-card-animated{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity var(--transition-fast);will-change:opacity;transform:translateZ(0);backface-visibility:hidden}.gif-card.animated-loading:hover .gif-card-image::after,.gif-card.animated-loading.touch-active .gif-card-image::after{content:"";position:absolute;top:50%;left:50%;width:32px;height:32px;margin:-16px 0 0 -16px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite;z-index:10}@keyframes spin {
    to {
        transform: rotate(360deg);
    }
}.gif-card.animated-ready:hover .gif-card-image .gif-card-thumb,.gif-card.animated-ready.touch-active .gif-card-image .gif-card-thumb,.gif-card.animated-ready.keyboard-focus .gif-card-image .gif-card-thumb{transform:scale(1.03);opacity:0}.gif-card.animated-ready:hover .gif-card-image .gif-card-animated,.gif-card.animated-ready.touch-active .gif-card-image .gif-card-animated,.gif-card.animated-ready.keyboard-focus .gif-card-image .gif-card-animated{opacity:1}.gif-card:not(.animated-ready):hover .gif-card-image img,
.gif-card:not(.animated-ready).touch-active .gif-card-image img,
.gif-card:not(.animated-ready).keyboard-focus .gif-card-image img {transform:scale(1.03);transition:transform var(--transition-slow)}.gif-card-overlay{position:absolute;bottom:0;left:0;right:0;padding:var(--spacing-4) var(--spacing-3) var(--spacing-3);background:var(--overlay-gradient);display:flex;align-items:flex-end;justify-content:space-between;opacity:0;transition:opacity var(--transition-normal)}.gif-card:hover .gif-card-overlay,.gif-card.touch-active .gif-card-overlay{opacity:1}.gif-card-overlay-title{font-size:var(--font-size-sm);font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0;text-shadow:0 1px 3px rgba(0,0,0,.5)}.gif-card-stats{display:flex;gap:var(--spacing-2);flex-shrink:0;margin-left:var(--spacing-2)}.gif-card-stat{display:flex;align-items:center;gap:3px;font-size:var(--font-size-xs);color:rgba(255,255,255,.9);text-shadow:0 1px 3px rgba(0,0,0,.5)}.gif-card-stat .icon{width:13px;height:13px}.gif-card-matched-tags{position:absolute;top:var(--spacing-2);left:var(--spacing-2);right:var(--spacing-2);display:flex;flex-wrap:wrap;gap:3px;pointer-events:none}.gif-card-matched-tag{display:inline-block;padding:1px 6px;background: linear-gradient(
        135deg,
        var(--color-primary),
        var(--color-accent)
    );color:#fff;font-size:10px;font-weight:600;border-radius:var(--radius-full);line-height:1.4;text-shadow:0 1px 2px rgba(0,0,0,.3);box-shadow:0 1px 3px rgba(0,0,0,.3)}.gif-action{display:flex;align-items:center;gap:var(--spacing-1);background:none;border:none;color:var(--color-text-muted);cursor:pointer;padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius-md);transition:all var(--transition-fast)}.gif-action:hover{color:var(--color-text);background-color:var(--color-bg-tertiary)}.gif-action.active{color:var(--color-primary)}.gif-action-like.active{color:var(--color-success)}.gif-action-dislike.active{color:var(--color-error)}.gif-action .icon{width:18px;height:18px}.gif-action-count{font-size:var(--font-size-sm)}.gif-card-content{padding:var(--spacing-3)}.gif-card-meta{display:flex;align-items:center;gap:var(--spacing-2);margin-top:var(--spacing-1)}.gif-card-actions{display:flex;gap:var(--spacing-2);margin-top:var(--spacing-2)}.gif-card-date{font-size:var(--font-size-xs);color:var(--color-text-muted)}.tag{display:inline-flex;align-items:center;gap:var(--spacing-1);padding:2px var(--spacing-2);background-color:var(--color-bg-tertiary);color:var(--color-text-secondary);font-size:var(--font-size-xs);font-weight:500;border-radius:var(--radius-full);transition:all var(--transition-normal);border:1px solid transparent}.tag:hover{background: linear-gradient(
        135deg,
        var(--color-primary),
        var(--color-accent)
    );color:#fff;border-color:transparent}.tag-active{background: linear-gradient(
        135deg,
        var(--color-primary),
        var(--color-accent)
    );color:#fff}.tag-count{opacity:.7}.tag-cloud{display:flex;flex-wrap:wrap;gap:var(--spacing-1)}.comments-section{background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-2xl);padding:var(--spacing-6)}.comments-header{margin-bottom:var(--spacing-5)}.comments-title{font-size:var(--font-size-lg);font-weight:700}.comments-count{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;padding:0 var(--spacing-2);background: linear-gradient(
        135deg,
        var(--color-primary),
        var(--color-accent)
    );color:#fff;font-size:var(--font-size-xs);font-weight:700;border-radius:var(--radius-full);margin-left:var(--spacing-2);vertical-align:middle}.comment-form{margin-bottom:var(--spacing-5);padding-bottom:var(--spacing-5);border-bottom:1px solid var(--color-border)}.comment-form-inner{display:flex;gap:var(--spacing-3);align-items:flex-start}.comment-form-avatar{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-full);background: linear-gradient(
        135deg,
        var(--color-primary),
        var(--color-accent)
    );color:#fff;font-size:var(--font-size-sm);font-weight:700;flex-shrink:0}.comment-form-body{flex:1}.comment-textarea{width:100%;padding:var(--spacing-3);background-color:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-xl);color:var(--color-text);resize:vertical;font-size:var(--font-size-sm);transition:all var(--transition-normal);min-height:80px}.comment-textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(236,72,153,.1);background-color:var(--color-bg)}.comment-form-actions{margin-top:var(--spacing-2);text-align:right}.comment-login-prompt{padding:var(--spacing-5);background-color:var(--color-bg-tertiary);border-radius:var(--radius-xl);text-align:center;margin-bottom:var(--spacing-5);font-size:var(--font-size-sm);border:1px solid var(--color-border)}.comments-list{display:flex;flex-direction:column;gap:var(--spacing-1)}.comment{display:flex;gap:var(--spacing-3);padding:var(--spacing-4);border-radius:var(--radius-xl);transition:background-color var(--transition-fast)}.comment:hover{background-color:var(--color-bg-tertiary)}.comment-avatar{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-full);background:var(--color-bg-tertiary);color:var(--color-text-secondary);font-size:var(--font-size-xs);font-weight:700;flex-shrink:0;border:1px solid var(--color-border)}.comment-body{flex:1;min-width:0}.comment-header{display:flex;align-items:baseline;gap:var(--spacing-2);margin-bottom:var(--spacing-1)}.comment-author{font-weight:600;color:var(--color-text);font-size:var(--font-size-sm);transition:color var(--transition-fast)}.comment-author:hover{color:var(--color-primary)}.comment-date{font-size:var(--font-size-xs);color:var(--color-text-muted)}.comment-content{color:var(--color-text-secondary);line-height:1.6;font-size:var(--font-size-sm)}.comment-actions{margin-top:var(--spacing-2)}.comment-delete{background:none;border:none;color:var(--color-text-muted);font-size:var(--font-size-xs);cursor:pointer;padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius-md);transition:all var(--transition-fast)}.comment-delete:hover{color:var(--color-error);background-color:rgba(239,68,68,.1)}.comments-empty{text-align:center;color:var(--color-text-muted);padding:var(--spacing-8);font-size:var(--font-size-sm)}.flash-messages{display:flex;flex-direction:column;gap:var(--spacing-3);margin-bottom:var(--spacing-6)}.flash-message{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-3) var(--spacing-4);border-radius:var(--radius-lg);animation:slideIn .3s ease;font-size:var(--font-size-sm);backdrop-filter:blur(8px)}@keyframes slideIn {
    from {
        opacity: 0;
        transform: translateY(-10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}.flash-message-success{background-color:rgba(34,197,94,.12);border:1px solid rgba(34,197,94,.3);color:var(--color-success)}.flash-message-error{background-color:rgba(239,68,68,.12);border:1px solid rgba(239,68,68,.3);color:var(--color-error)}.flash-message-warning{background-color:rgba(245,158,11,.12);border:1px solid rgba(245,158,11,.3);color:var(--color-warning)}.flash-message-info{background-color:rgba(59,130,246,.12);border:1px solid rgba(59,130,246,.3);color:var(--color-info)}.flash-message-close{background:none;border:none;color:inherit;font-size:var(--font-size-xl);cursor:pointer;opacity:.7;line-height:1}.flash-message-close:hover{opacity:1}.pagination{display:flex;justify-content:center;margin-top:var(--spacing-8)}.pagination-list{display:flex;align-items:center;gap:var(--spacing-1);list-style:none}.pagination-link{display:flex;align-items:center;justify-content:center;min-width:40px;height:40px;padding:0 var(--spacing-3);background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-text-secondary);font-size:var(--font-size-sm);transition:all var(--transition-fast)}.pagination-link:hover{background-color:var(--color-bg-tertiary);color:var(--color-text)}.pagination-current{background: linear-gradient(
        135deg,
        var(--color-primary),
        var(--color-accent)
    );border-color:transparent;color:#fff}.pagination-disabled{opacity:.5;cursor:not-allowed}.pagination-ellipsis{padding:0 var(--spacing-2);color:var(--color-text-muted)}.error-page{display:flex;align-items:center;justify-content:center;min-height:60vh;text-align:center}.error-code{font-size:8rem;font-weight:800;background: linear-gradient(
        135deg,
        var(--color-primary),
        var(--color-accent)
    );-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;margin-bottom:var(--spacing-4)}.error-title{font-size:var(--font-size-2xl);margin-bottom:var(--spacing-3)}.error-message{color:var(--color-text-secondary);margin-bottom:var(--spacing-6)}.error-actions{display:flex;gap:var(--spacing-4);justify-content:center}.auth-page{display:flex;align-items:center;justify-content:center;min-height:60vh}.auth-card{width:100%;max-width:400px}.auth-title{text-align:center;margin-bottom:var(--spacing-6)}.auth-footer{text-align:center;margin-top:var(--spacing-4);color:var(--color-text-muted);font-size:var(--font-size-sm)}.upload-dropzone{border:2px dashed var(--color-border);border-radius:var(--radius-xl);padding:var(--spacing-12);text-align:center;cursor:pointer;transition:all var(--transition-normal);background:var(--color-bg-secondary)}.upload-dropzone:hover,.upload-dropzone.dragover{border-color:var(--color-primary);background:rgba(236,72,153,.04);box-shadow:0 0 0 4px rgba(236,72,153,.1)}.upload-dropzone-icon{width:64px;height:64px;margin:0 auto var(--spacing-4);color:var(--color-text-muted)}.upload-dropzone-text{color:var(--color-text-secondary);margin-bottom:var(--spacing-2)}.upload-dropzone-hint{font-size:var(--font-size-sm);color:var(--color-text-muted)}.upload-preview{margin-top:var(--spacing-4)}.upload-preview img{max-width:100%;max-height:300px;border-radius:var(--radius-lg);margin:0 auto}.gif-detail{max-width:900px;margin:0 auto;display:flex;flex-direction:column;gap:var(--spacing-6)}.gif-detail-main{background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-2xl);overflow:hidden;box-shadow:var(--shadow-lg)}.gif-detail-image{background-color:#000;display:flex;align-items:center;justify-content:center;min-height:300px;position:relative}.gif-detail-image img{max-width:100%;max-height:80vh;display:block}.gif-fullscreen-btn{position:absolute;top:var(--spacing-3);right:var(--spacing-3);background:rgba(0,0,0,.6);color:#fff;border:none;border-radius:var(--radius-md);padding:var(--spacing-2);cursor:pointer;opacity:0;transition:opacity var(--transition-fast);display:flex;align-items:center;justify-content:center;z-index:2}.gif-detail-image:hover .gif-fullscreen-btn{opacity:1}.gif-fullscreen-btn:hover{background:rgba(0,0,0,.8)}.gif-detail-content{padding:var(--spacing-5) var(--spacing-6)}.gif-detail-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-4);margin-bottom:var(--spacing-4)}.gif-detail-info{flex:1;min-width:0}.gif-detail-title{font-size:var(--font-size-xl);font-weight:700;margin-bottom:var(--spacing-2);line-height:1.3}.gif-detail-meta{display:flex;align-items:center;flex-wrap:wrap;gap:var(--spacing-2);color:var(--color-text-muted);font-size:var(--font-size-sm)}.gif-detail-author{display:inline-flex;align-items:center;gap:var(--spacing-2);color:var(--color-text);font-weight:600;transition:color var(--transition-fast)}.gif-detail-author:hover{color:var(--color-primary)}.gif-detail-avatar{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--radius-full);background: linear-gradient(
        135deg,
        var(--color-primary),
        var(--color-accent)
    );color:#fff;font-size:var(--font-size-xs);font-weight:700;flex-shrink:0}.gif-detail-dot{width:3px;height:3px;border-radius:50%;background-color:var(--color-text-muted);flex-shrink:0}.gif-detail-actions{display:flex;gap:var(--spacing-2);flex-shrink:0}.gif-detail-action-btn{display:inline-flex;align-items:center;gap:var(--spacing-1);padding:var(--spacing-2) var(--spacing-3);background-color:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-text-secondary);cursor:pointer;font-size:var(--font-size-sm);font-family: var(--font-family);transition:all var(--transition-normal)}.gif-detail-action-btn:hover{background-color:var(--color-border);color:var(--color-text);border-color:var(--color-text-muted)}.gif-detail-action-btn .icon{width:18px;height:18px}.gif-detail-action-btn.gif-action-like.active{background-color:rgba(236,72,153,.12);border-color:rgba(236,72,153,.3);color:var(--color-primary)}.gif-detail-action-btn.gif-action-dislike.active{background-color:rgba(239,68,68,.12);border-color:rgba(239,68,68,.3);color:var(--color-error)}.gif-detail-action-btn.gif-action-report:hover{background-color:rgba(245,158,11,.12);border-color:rgba(245,158,11,.3);color:var(--color-warning)}.report-reason{display:inline-block;padding:2px 8px;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:500}.report-reason-spam{background:rgba(239,68,68,.15);color:var(--color-error)}.report-reason-illegal{background:rgba(239,68,68,.25);color:var(--color-error)}.report-reason-duplicate{background:rgba(245,158,11,.15);color:var(--color-warning)}.report-reason-other{background:rgba(59,130,246,.15);color:var(--color-info)}.report-gif-link{color:var(--color-primary);text-decoration:none;font-weight:500}.report-gif-link:hover{text-decoration:underline}.gif-detail-description{color:var(--color-text-secondary);margin-bottom:var(--spacing-4);line-height:1.7;font-size:var(--font-size-sm)}.gif-detail-tags{display:flex;flex-wrap:wrap;gap:var(--spacing-2)}.tag-wrapper{display:inline-flex;align-items:center;position:relative}.tag-remove-btn{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;background-color:var(--color-error);color:#fff;border:none;border-radius:var(--radius-full);cursor:pointer;margin-left:-6px;margin-right:var(--spacing-1);opacity:0;transform:scale(.8);transition:all var(--transition-fast);padding:0;line-height:1}.tag-wrapper:hover .tag-remove-btn{opacity:1;transform:scale(1)}.tag-remove-btn:hover{background-color:#dc2626;transform:scale(1.1)}.admin-tag-add{margin-top:var(--spacing-2)}.admin-tag-input-wrapper{display:flex;gap:var(--spacing-2);align-items:center;max-width:280px}.admin-tag-input{flex:1;padding:var(--spacing-1) var(--spacing-3);background-color:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-text);font-size:var(--font-size-xs);transition:all var(--transition-normal)}.admin-tag-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(236,72,153,.15)}.admin-tag-input::placeholder{color:var(--color-text-muted)}.admin-tag-submit{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;background: linear-gradient(
        135deg,
        var(--color-primary),
        var(--color-accent)
    );color:#fff;border:none;border-radius:var(--radius-full);cursor:pointer;flex-shrink:0;transition:all var(--transition-fast);padding:0}.admin-tag-submit:hover{transform:scale(1.1);box-shadow:0 2px 8px rgba(236,72,153,.3)}.admin-tag-submit:disabled{opacity:.5;cursor:not-allowed;transform:none}.gif-detail-sidebar{display:flex;flex-direction:column;gap:var(--spacing-6)}.related-gifs{background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-2xl);padding:var(--spacing-6)}.related-gifs-title{font-size:var(--font-size-lg);font-weight:600;margin-bottom:var(--spacing-4)}.related-gifs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:var(--spacing-3)}@media (min-width:768px){.related-gifs-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}}.related-gif-item{position:relative;aspect-ratio:1;border-radius:var(--radius-lg);overflow:hidden;background-color:var(--color-bg-tertiary);transition:transform var(--transition-normal) , box-shadow var(--transition-normal)}.related-gif-item:hover{transform:scale(1.05);box-shadow:0 4px 16px rgba(0,0,0,.3)}.related-gif-item img{width:100%;height:100%;object-fit:cover}.related-gif-thumb{position:absolute;top:0;left:0;z-index:1;transition:opacity var(--transition-normal)}.related-gif-animated{position:absolute;top:0;left:0;z-index:0;opacity:0}.related-gif-item:hover .related-gif-thumb{opacity:0}.related-gif-item:hover .related-gif-animated{opacity:1}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-6)}.admin-title{font-size:var(--font-size-2xl);font-weight:700}.admin-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-4);margin-bottom:var(--spacing-8)}.admin-stat{background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--spacing-5)}.admin-stat-value{font-size:var(--font-size-3xl);font-weight:700;background: linear-gradient(
        135deg,
        var(--color-primary),
        var(--color-accent)
    );-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.admin-stat-label{color:var(--color-text-muted);font-size:var(--font-size-sm)}.table-responsive{overflow-x:auto;-webkit-overflow-scrolling:touch}.admin-table{width:100%;border-collapse:collapse}.admin-table th,.admin-table td{padding:var(--spacing-3) var(--spacing-4);text-align:left;border-bottom:1px solid var(--color-border)}.admin-table th{background-color:var(--color-bg-tertiary);font-weight:600;font-size:var(--font-size-sm)}.admin-table tr:hover td{background-color:var(--color-bg-tertiary)}.admin-actions{display:flex;gap:var(--spacing-2)}.status{display:inline-flex;padding:var(--spacing-1) var(--spacing-2);font-size:var(--font-size-xs);font-weight:600;border-radius:var(--radius-full)}.status-pending{background-color:rgba(245,158,11,.12);color:var(--color-warning)}.status-approved{background-color:rgba(34,197,94,.12);color:var(--color-success)}.status-rejected{background-color:rgba(239,68,68,.12);color:var(--color-error)}.modal-overlay{position:fixed;inset:0;background-color:rgba(0,0,0,.8);display:flex;align-items:center;justify-content:center;z-index:1000;opacity:0;visibility:hidden;transition:all var(--transition-normal);backdrop-filter:blur(4px)}.modal-overlay.active{opacity:1;visibility:visible}.modal{background-color:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-2xl);padding:var(--spacing-6);max-width:400px;width:90%;transform:scale(.95) translateY(10px);transition:transform var(--transition-normal);box-shadow:var(--shadow-xl)}.modal-overlay.active .modal{transform:scale(1) translateY(0)}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-4)}.modal-title{font-size:var(--font-size-lg);font-weight:600}.modal-close{background:none;border:none;color:var(--color-text-muted);font-size:var(--font-size-xl);cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);transition:all var(--transition-fast)}.modal-close:hover{background-color:var(--color-bg-tertiary);color:var(--color-text)}.share-buttons{display:flex;gap:var(--spacing-3);margin-bottom:var(--spacing-4)}.share-button{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--spacing-2);padding:var(--spacing-3);border-radius:var(--radius-lg);color:#fff;font-weight:600;font-size:var(--font-size-sm);transition:all var(--transition-fast)}.share-button:hover{opacity:.9;color:#fff;transform:translateY(-1px)}.share-button-whatsapp{background-color:#25d366}.share-button-twitter{background-color:#1da1f2}.share-button-facebook{background-color:#4267b2}.share-link-input{display:flex;gap:var(--spacing-2)}.share-link-input input{flex:1;padding:var(--spacing-2) var(--spacing-3);background-color:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-text);font-size:var(--font-size-sm)}@media (max-width:1200px){.gif-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width:900px){.gif-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.nav-search{display:none}.nav-links{display:none;position:fixed;top: calc(56px + constant(safe-area-inset-top));top: calc(56px + env(safe-area-inset-top, 0px));left:0;right:0;bottom:0;height:auto;background:var(--color-bg);border-top:1px solid var(--color-border);flex-direction:column;padding:var(--spacing-4);gap:var(--spacing-2);overflow-y:auto;z-index:99999}.nav-links.active{display:flex}.nav-toggle{display:flex;margin-left:auto}.nav-links::before{content:"";display:block}.mobile-search{display:block;margin-bottom:var(--spacing-4);padding-bottom:var(--spacing-4);border-bottom:1px solid var(--color-border)}.mobile-search .search-form{display:flex;position:relative}.mobile-search .search-input{width:100%;padding:var(--spacing-3);padding-right:80px;background-color:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-text);font-size:var(--font-size-base)}.mobile-search .search-button{position:absolute;right:4px;top:50%;transform:translateY(-50%);padding:var(--spacing-2) var(--spacing-4)}.nav-links .media-filter{width:100%;justify-content:center;margin-bottom:var(--spacing-1)}.nav-links .nav-link-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-2);width:100%}.nav-links .nav-link{display:flex;align-items:center;justify-content:center;gap:var(--spacing-2);width:100%;padding:var(--spacing-2) var(--spacing-3);text-align:center;border-radius:var(--radius-lg);background:var(--color-bg-secondary);border:1px solid var(--color-border);font-size:var(--font-size-sm)}.nav-links .nav-link-primary{background: linear-gradient(
            135deg,
            var(--color-primary),
            var(--color-accent)
        );border:none;color:#fff}.nav-links .notification-bell{justify-content:center;gap:var(--spacing-2)}.nav-links .notification-bell .nav-link-label{display:inline}.nav-links .notification-bell .notification-badge{position:static;margin-left:var(--spacing-1)}.nav-dropdown{width:100%}.nav-dropdown-toggle{width:100%;padding:var(--spacing-2) var(--spacing-3);text-align:center;border-radius:var(--radius-lg);background:var(--color-bg-secondary);border:1px solid var(--color-border);position:relative}.nav-dropdown-toggle::after{content:"";display:inline-block;width:6px;height:6px;border-right:2px solid var(--color-text-muted);border-bottom:2px solid var(--color-text-muted);transform:rotate(45deg);margin-left:var(--spacing-2);vertical-align:middle;transition:transform var(--transition-fast)}.nav-dropdown.active .nav-dropdown-toggle::after{transform:rotate(-135deg)}.nav-dropdown-menu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:1px solid var(--color-border);border-top:none;border-radius:0 0 var(--radius-lg) var(--radius-lg);margin-top:-1px;padding:var(--spacing-2);background:var(--color-bg-secondary);display:none}.nav-dropdown.active .nav-dropdown-menu{display:block}.nav-dropdown-item{text-align:center;padding:var(--spacing-2) var(--spacing-3)}.nav-links .mobile-settings-row{display:flex;flex-wrap:wrap;gap:var(--spacing-2);width:100%}.nav-links .mobile-settings-row .theme-switcher,.nav-links .mobile-settings-row .lang-switcher{flex:1;min-width:0;width:auto}.admin-stats{grid-template-columns:1fr}.gif-detail-header{flex-direction:column;gap:var(--spacing-3)}.gif-detail-info{order:2}.gif-detail-actions{order:1;width:100%;justify-content:flex-start;flex-wrap:wrap}.gif-detail-title{font-size:var(--font-size-lg)}.gif-detail-meta{flex-direction:column;align-items:flex-start;gap:var(--spacing-1)}.gif-detail-dot{display:none}}@media (max-width:480px){.gif-grid{grid-template-columns:1fr}.container{padding:0 var(--spacing-3)}.main{padding:var(--spacing-3) 0}.trending-section{padding:var(--spacing-3);border-radius:var(--radius-lg)}.trending-title{font-size:var(--font-size-sm);flex-wrap:wrap}.results-count{font-size:var(--font-size-xs)}.gif-detail-action-btn{flex:1;min-width:0;justify-content:center;padding:var(--spacing-2);font-size:var(--font-size-xs)}.gif-detail-action-btn .icon{width:16px;height:16px}.gif-detail-content{padding:var(--spacing-3) var(--spacing-4)}.comments-section{padding:var(--spacing-4);border-radius:var(--radius-lg)}.comment-form-inner{flex-direction:column;gap:var(--spacing-2)}.comment{padding:var(--spacing-3);gap:var(--spacing-2)}.error-code{font-size:clamp(3rem,20vw,8rem)}.error-title{font-size:var(--font-size-lg)}.error-actions{flex-direction:column;gap:var(--spacing-2)}.search-suggestions{max-height:60vh;overflow-y:auto}.pagination-link{min-width:36px;height:36px;padding:0 var(--spacing-2);font-size:var(--font-size-xs)}.upload-dropzone{padding:var(--spacing-6)}.upload-dropzone-icon{width:48px;height:48px}.notification-item{padding:var(--spacing-3);gap:var(--spacing-2)}.notification-icon{width:32px;height:32px}.related-gifs{padding:var(--spacing-4);border-radius:var(--radius-lg)}.related-gifs-grid{grid-template-columns:repeat(3,1fr);gap:var(--spacing-2)}.card{padding:var(--spacing-4);border-radius:var(--radius-lg)}.my-gifs-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}.collection-grid{grid-template-columns:repeat(2,1fr);gap:var(--spacing-3)}.conversation-preview{font-size:var(--font-size-xs)}.auth-card{padding:0 var(--spacing-2)}.favorite-tags-grid{gap:var(--spacing-2)}.favorite-tag-btn{font-size:var(--font-size-xs);padding:var(--spacing-1) var(--spacing-2)}.bulk-upload-card{max-width:100%}}@media (max-width:375px){.gif-detail-actions{gap:var(--spacing-1)}.gif-detail-action-btn{padding:var(--spacing-1) var(--spacing-2)}.gif-detail-action-btn .gif-action-count{display:none}.trending-grid{grid-template-columns:repeat(2,1fr);gap:var(--spacing-2)}.related-gifs-grid{grid-template-columns:repeat(2,1fr)}.pagination-link{min-width:32px;height:32px}.pagination-ellipsis{padding:0 var(--spacing-1)}.collection-grid{grid-template-columns:1fr}}@media screen and (max-width:768px){input[type="text"],input[type="email"],input[type="password"],input[type="search"],input[type="number"],textarea,select,.search-input,.form-input,.form-textarea,.form-select,.comment-textarea{font-size:16px}}.text-center{text-align:center}.text-right{text-align:right}.text-muted{color:var(--color-text-muted)}.mt-4{margin-top:var(--spacing-4)}.mt-6{margin-top:var(--spacing-6)}.mt-8{margin-top:var(--spacing-8)}.mb-2{margin-bottom:var(--spacing-2)}.mb-4{margin-bottom:var(--spacing-4)}.mb-6{margin-bottom:var(--spacing-6)}.hidden{display:none}.tag-scroll-mobile{margin-bottom:var(--spacing-2)}.tag-scroll-inner{display:flex;overflow-x:auto;gap:8px;-webkit-overflow-scrolling:touch;scrollbar-width:none}.tag-scroll-inner::-webkit-scrollbar{display:none}.tag-scroll-inner .tag{flex-shrink:0;font-size:var(--font-size-sm);padding:4px 14px}@media (max-width:768px){.hidden-mobile{display:none!important}.tag-scroll-inner .tag{font-size:12px;padding:3px 12px}.admin-table th,.admin-table td{padding:var(--spacing-2);font-size:var(--font-size-sm)}.admin-table td code{word-break:break-all}}.my-gifs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));grid-auto-rows:8px;column-gap:var(--spacing-4)}.my-gif-card{background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xl);overflow:hidden;transition:box-shadow var(--transition-normal) , transform var(--transition-normal)}.my-gif-card:hover{box-shadow:var(--card-shadow-hover);transform:translateY(-2px)}.my-gif-card-link{display:block}.my-gif-card-image{position:relative;overflow:hidden;line-height:0;background-color:var(--color-bg-tertiary)}.my-gif-card-image img{width:100%;height:auto;display:block}.my-gif-card-image .gif-card-animated{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity var(--transition-fast)}.my-gif-card.animated-ready:hover .my-gif-card-image .gif-card-thumb{opacity:0}.my-gif-card.animated-ready:hover .my-gif-card-image .gif-card-animated{opacity:1}.my-gif-card-placeholder{width:100%;min-height:150px;display:flex;align-items:center;justify-content:center;background:var(--color-bg-tertiary)}.my-gif-card-placeholder-icon{width:40px;height:40px;color:var(--color-text-muted);opacity:.5}.my-gif-card-status-badge{position:absolute;top:var(--spacing-2);right:var(--spacing-2)}.my-gif-card-info{padding:var(--spacing-3) var(--spacing-4)}.my-gif-card-title{font-size:var(--font-size-sm);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:var(--spacing-1)}.my-gif-card-title a{color:var(--color-text)}.my-gif-card-title a:hover{color:var(--color-primary)}.my-gif-card-date{font-size:var(--font-size-xs);color:var(--color-text-muted)}.my-gif-card-reason{font-size:var(--font-size-xs);color:var(--color-error);margin-top:var(--spacing-1);line-height:1.4;opacity:.8}.spinner{display:inline-block;width:20px;height:20px;border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin {
    to {
        transform: rotate(360deg);
    }
}.bulk-upload-card{max-width:700px;margin:0 auto;position:relative;overflow:hidden}.bulk-steps{display:flex;align-items:center;justify-content:center;gap:var(--spacing-3);margin-bottom:var(--spacing-8)}.bulk-step{display:flex;align-items:center;gap:var(--spacing-2);color:var(--color-text-muted);transition:color var(--transition-fast)}.bulk-step.active{color:var(--color-primary)}.bulk-step-number{width:28px;height:28px;border-radius:var(--radius-full);border:2px solid currentColor;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-sm);font-weight:600}.bulk-step.active .bulk-step-number{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.bulk-step-label{font-size:var(--font-size-sm);font-weight:500}.bulk-step-divider{width:40px;height:2px;background:var(--color-border)}.bulk-dropzone{margin-bottom:var(--spacing-4)}.bulk-file-list{display:flex;flex-direction:column;gap:var(--spacing-2)}.bulk-file-item{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-2) var(--spacing-3);background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md)}.bulk-file-thumb{width:48px;height:48px;border-radius:var(--radius-sm);overflow:hidden;flex-shrink:0}.bulk-file-thumb img{width:100%;height:100%;object-fit:cover}.bulk-file-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.bulk-file-name{font-size:var(--font-size-sm);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bulk-file-size{font-size:var(--font-size-xs);color:var(--color-text-muted)}.bulk-file-remove{background:none;border:none;cursor:pointer;color:var(--color-text-muted);padding:var(--spacing-1);border-radius:var(--radius-sm);transition:color var(--transition-fast) , background var(--transition-fast);flex-shrink:0}.bulk-file-remove:hover{color:var(--color-error);background:rgba(239,68,68,.1)}.bulk-actions{display:flex;justify-content:space-between;align-items:center;margin-top:var(--spacing-6);gap:var(--spacing-4)}.bulk-file-count{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-weight:500}.bulk-detail-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-6);padding-bottom:var(--spacing-4);border-bottom:1px solid var(--color-border)}.bulk-image-counter{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-secondary)}.bulk-detail-item{display:grid;grid-template-columns:200px 1fr;gap:var(--spacing-6)}.bulk-detail-preview{position:relative}.bulk-detail-image{width:100%;border-radius:var(--radius-lg);max-height:240px;object-fit:contain;background:var(--color-bg-tertiary)}.bulk-detail-remove{position:absolute;top:var(--spacing-2);right:var(--spacing-2);background:rgba(0,0,0,.7);border:none;color:#fff;cursor:pointer;padding:var(--spacing-1);border-radius:var(--radius-sm);transition:background var(--transition-fast)}.bulk-detail-remove:hover{background:var(--color-error)}.bulk-detail-fields{display:flex;flex-direction:column;gap:var(--spacing-3)}.bulk-progress-overlay{position:absolute;inset:0;background:rgba(9,9,11,.9);display:flex;align-items:center;justify-content:center;border-radius:var(--radius-xl);z-index:10}[data-theme="light"] .bulk-progress-overlay{background:rgba(250,250,250,.92)}.bulk-progress-content{text-align:center;display:flex;flex-direction:column;align-items:center;gap:var(--spacing-4)}.bulk-progress-text{font-weight:500;color:var(--color-text-secondary)}.bulk-progress-bar-track{width:200px;height:6px;background:var(--color-bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.bulk-progress-bar{height:100%;background:var(--color-primary);border-radius:var(--radius-full);transition:width .3s ease}@media (max-width:640px){.bulk-detail-item{grid-template-columns:1fr}.bulk-detail-image{max-height:180px}.bulk-step-label{display:none}}.analytics-filters{background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--spacing-4) var(--spacing-5)}.analytics-filter-form{display:flex;gap:var(--spacing-6);align-items:center;flex-wrap:wrap}.analytics-filter-group{display:flex;align-items:center;gap:var(--spacing-2)}.analytics-filter-group label{font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-muted)}.analytics-filter-group select{padding:var(--spacing-2) var(--spacing-3);background-color:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-size:var(--font-size-sm);cursor:pointer}.analytics-filter-group select:focus{outline:none;border-color:var(--color-primary)}.analytics-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-6)}.analytics-card{background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--spacing-5);overflow-x:auto}.analytics-card h3{font-size:var(--font-size-lg);font-weight:600;margin-bottom:var(--spacing-4)}.analytics-table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm)}.analytics-table th,.analytics-table td{padding:var(--spacing-2) var(--spacing-3);text-align:left;border-bottom:1px solid var(--color-border)}.analytics-table th{font-weight:600;color:var(--color-text-muted);font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.05em}.analytics-table td a{color:var(--color-primary)}.analytics-table td a:hover{text-decoration:underline}@media (max-width:900px){.analytics-grid{grid-template-columns:1fr}}.notification-bell{position:relative;display:inline-flex;align-items:center}.nav-link-label{display:none}.nav-link-grid,.mobile-settings-row{display:contents}.notification-badge{position:absolute;top:-4px;right:-6px;background:var(--color-error);color:#fff;font-size:10px;font-weight:700;min-width:16px;height:16px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;padding:0 4px;line-height:1}.notification-list{display:flex;flex-direction:column;gap:var(--spacing-2)}.notification-item{display:flex;align-items:flex-start;gap:var(--spacing-3);padding:var(--spacing-4);background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xl);transition:background-color var(--transition-fast)}.notification-item.notification-unread{background-color:var(--color-bg-tertiary);border-left:3px solid var(--color-primary)}.notification-icon{flex-shrink:0;width:36px;height:36px;border-radius:var(--radius-full);background-color:var(--color-bg-tertiary);display:flex;align-items:center;justify-content:center;color:var(--color-text-muted)}.notification-unread .notification-icon{background-color:rgba(99,102,241,.15);color:var(--color-primary)}.notification-content{flex:1;min-width:0}.notification-message{display:block;font-size:var(--font-size-sm);line-height:1.5;color:var(--color-text)}a.notification-message:hover{color:var(--color-primary)}.notification-time{display:block;font-size:var(--font-size-xs);color:var(--color-text-muted);margin-top:var(--spacing-1)}.notification-mark-read{flex-shrink:0;background:none;border:none;color:var(--color-text-muted);cursor:pointer;padding:var(--spacing-1);border-radius:var(--radius-sm);transition:color var(--transition-fast) , background var(--transition-fast)}.notification-mark-read:hover{color:var(--color-success);background:rgba(34,197,94,.1)}.gif-card.keyboard-focus{outline:3px solid var(--color-primary);outline-offset:2px;box-shadow:0 0 0 6px rgba(236,72,153,.2)}.gif-card.keyboard-focus .gif-card-overlay{opacity:1}.back-to-top{position:fixed;bottom:var(--spacing-6);right:var(--spacing-6);width:48px;height:48px;border-radius:var(--radius-full);background: linear-gradient(
        135deg,
        var(--color-primary),
        var(--color-accent)
    );color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-lg);opacity:0;visibility:hidden;transform:translateY(20px);transition:all var(--transition-normal);z-index:90}.back-to-top.visible{opacity:1;visibility:visible;transform:translateY(0)}.back-to-top:hover{transform:translateY(-2px);box-shadow:var(--shadow-xl)}.back-to-top:active{transform:translateY(0)}.gif-card.skeleton-loading .gif-card-image{background: linear-gradient(
        90deg,
        var(--color-bg-tertiary) 0%,
        var(--color-bg-secondary) 50%,
        var(--color-bg-tertiary) 100%
    );background-size:200% 100%;animation:skeleton-shimmer 1.5s infinite}.gif-card.skeleton-loading .gif-card-thumb{opacity:0}@keyframes skeleton-shimmer {
    0% {
        background-position: 200% 0;
    }
    100% {
        background-position: -200% 0;
    }
}.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.95);z-index:1000;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:all var(--transition-normal)}.lightbox.active{opacity:1;visibility:visible}.lightbox-content{max-width:90vw;max-height:80vh;display:flex;align-items:center;justify-content:center}.lightbox-image{max-width:100%;max-height:80vh;object-fit:contain;border-radius:var(--radius-lg)}.lightbox-close{position:absolute;top:var(--spacing-4);right:var(--spacing-4);background:rgba(255,255,255,.1);border:none;color:#fff;font-size:2rem;width:48px;height:48px;border-radius:var(--radius-full);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--transition-fast)}.lightbox-close:hover{background:rgba(255,255,255,.2)}.lightbox-prev,.lightbox-next{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.1);border:none;color:#fff;width:56px;height:56px;border-radius:var(--radius-full);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--transition-fast)}.lightbox-prev{left:var(--spacing-4)}.lightbox-next{right:var(--spacing-4)}.lightbox-prev:hover,.lightbox-next:hover{background:rgba(255,255,255,.2)}.lightbox-info{position:absolute;bottom:var(--spacing-6);left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:var(--spacing-2);color:#fff;text-align:center}.lightbox-title{font-size:var(--font-size-lg);font-weight:600;max-width:80vw;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lightbox-counter{font-size:var(--font-size-sm);color:rgba(255,255,255,.7)}.like-animation{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(0);color:var(--color-primary);z-index:10;pointer-events:none;animation:like-pop .6s ease-out forwards}@keyframes like-pop {
    0% {
        transform: translate(-50%, -50%) scale(0);
        opacity: 1;
    }
    50% {
        transform: translate(-50%, -50%) scale(1.2);
        opacity: 1;
    }
    100% {
        transform: translate(-50%, -50%) scale(1);
        opacity: 0;
    }
}.confetti{position:absolute;width:10px;height:10px;border-radius:2px;pointer-events:none;animation:confetti-burst 1s ease-out forwards}@keyframes confetti-burst {
    0% {
        transform: translate(0, 0) rotate(0deg) scale(1);
        opacity: 1;
    }
    100% {
        transform: translate(var(--x), var(--y)) rotate(var(--r)) scale(0);
        opacity: 0;
    }
}.infinite-scroll-loader{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-3);padding:var(--spacing-6);color:var(--color-text-muted)}.loader-dots{display:flex;gap:var(--spacing-2)}.loader-dots span{width:10px;height:10px;background:var(--color-primary);border-radius:var(--radius-full);animation:loader-bounce 1.4s ease-in-out infinite}.loader-dots span:nth-child(1) {animation-delay:0s}.loader-dots span:nth-child(2) {animation-delay:.2s}.loader-dots span:nth-child(3) {animation-delay:.4s}@keyframes loader-bounce {
    0%,
    80%,
    100% {
        transform: scale(0.6);
        opacity: 0.5;
    }
    40% {
        transform: scale(1);
        opacity: 1;
    }
}.loader-text{font-size:var(--font-size-sm)}@media (max-width:768px){.lightbox-prev,.lightbox-next{width:44px;height:44px}.lightbox-prev{left:var(--spacing-2)}.lightbox-next{right:var(--spacing-2)}.lightbox-info{bottom:var(--spacing-4)}.lightbox-title{font-size:var(--font-size-base)}}.collection-modal .modal{max-width:360px}.collection-modal-content{display:flex;flex-direction:column;gap:var(--spacing-4)}.collection-list{max-height:300px;overflow-y:auto;display:flex;flex-direction:column;gap:var(--spacing-2)}.collection-item{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-3);background:var(--color-bg-tertiary);border-radius:var(--radius-lg);cursor:pointer;transition:background var(--transition-fast)}.collection-item:hover{background:var(--color-border)}.collection-checkbox{width:20px;height:20px;accent-color:var(--color-primary);cursor:pointer;flex-shrink:0}.collection-item-name{flex:1;font-size:var(--font-size-sm);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.collection-item-count{font-size:var(--font-size-xs);color:var(--color-text-muted);background:var(--color-bg-secondary);padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius-full)}.collection-create{display:flex;gap:var(--spacing-2)}.collection-new-name{flex:1}.collection-create-btn{flex-shrink:0;width:44px;padding:0}.collection-loading,.collection-empty,.collection-error{text-align:center;padding:var(--spacing-6);color:var(--color-text-muted);font-size:var(--font-size-sm)}.collection-error{color:var(--color-error)}.collection-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--spacing-4)}.collection-card{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xl);overflow:hidden;transition:all var(--transition-normal)}.collection-card:hover{box-shadow:var(--card-shadow-hover);transform:translateY(-2px)}.collection-card-link{display:block;color:inherit}.collection-card-thumbnail{aspect-ratio: 16/9;background:var(--color-bg-tertiary);position:relative;overflow:hidden}.collection-card-thumbnail img{width:100%;height:100%;object-fit:cover}.collection-card-thumbnail-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--color-text-muted)}.collection-card-thumbnail-placeholder svg{width:48px;height:48px;opacity:.5}.collection-card-info{padding:var(--spacing-4)}.collection-card-name{font-size:var(--font-size-base);font-weight:600;margin-bottom:var(--spacing-1)}.collection-card-meta{display:flex;align-items:center;gap:var(--spacing-3);font-size:var(--font-size-sm);color:var(--color-text-muted)}.collection-card-count{display:flex;align-items:center;gap:var(--spacing-1)}.collection-card-count .icon{width:16px;height:16px}.collection-card-actions{display:flex;gap:var(--spacing-2);padding:0 var(--spacing-4) var(--spacing-4)}.collection-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-4);margin-bottom:var(--spacing-6)}.collection-header-info{flex:1}.collection-title{font-size:var(--font-size-2xl);font-weight:700;margin-bottom:var(--spacing-2)}.collection-description{color:var(--color-text-secondary);margin-bottom:var(--spacing-3)}.collection-stats{display:flex;gap:var(--spacing-4);font-size:var(--font-size-sm);color:var(--color-text-muted)}.collection-header-actions{display:flex;gap:var(--spacing-2)}.toggle-label{display:flex;align-items:center;justify-content:space-between;cursor:pointer}.toggle-switch{position:relative;display:inline-block;width:44px;height:24px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:24px;transition:background-color var(--transition-fast)}.toggle-slider::before{content:"";position:absolute;height:18px;width:18px;left:2px;bottom:2px;background-color:var(--color-text-muted);border-radius:50%;transition:transform var(--transition-fast) , background-color var(--transition-fast)}.toggle-switch input:checked+.toggle-slider{background-color:var(--color-primary);border-color:var(--color-primary)}.toggle-switch input:checked+.toggle-slider::before{transform:translateX(20px);background-color:#fff}.favorite-tags-filter{width:100%;padding:var(--spacing-3);background-color:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-text);font-size:var(--font-size-base);font-family: var(--font-family)}.favorite-tags-filter:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb,168,85,247),.15)}.favorite-tags-grid{display:flex;flex-wrap:wrap;gap:var(--spacing-2)}.favorite-tag-btn{display:inline-flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-3);background-color:var(--color-bg-tertiary);border:2px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-text-secondary);cursor:pointer;font-size:var(--font-size-sm);font-family: var(--font-family);transition:all var(--transition-fast)}.favorite-tag-btn:hover{border-color:var(--color-primary);color:var(--color-text);background-color:var(--color-bg-secondary)}.favorite-tag-btn.active{background: linear-gradient(
        135deg,
        var(--color-primary),
        var(--color-accent)
    );border-color:transparent;color:#fff}.favorite-tag-btn.active:hover{opacity:.9}.favorite-tag-count{font-size:var(--font-size-xs);opacity:.7}.favorite-tag-btn.active .favorite-tag-count{opacity:.85}.favorite-tags-selected{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-3) var(--spacing-4);background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-text-secondary);font-size:var(--font-size-sm)}.favorite-tags-selected-count{font-weight:700;color:var(--color-primary)}.sort-btn-foryou{background: linear-gradient(
        135deg,
        var(--color-primary),
        var(--color-accent)
    );color:#fff!important;border-color:transparent!important}.sort-btn-foryou:hover{opacity:.9}.sort-btn-foryou.active{box-shadow:0 0 0 2px var(--color-primary)}.pending-gifs-list{display:flex;flex-direction:column;gap:var(--spacing-4)}.pending-gif-card{padding:var(--spacing-4)}.pending-gif-row{display:flex;gap:var(--spacing-4);align-items:flex-start}.pending-gif-preview{flex-shrink:0}.pending-gif-preview img{width:120px;height:80px;object-fit:cover;border-radius:var(--radius-sm);display:block}.pending-gif-info{flex:1;min-width:0}.pending-gif-title{font-weight:600;margin-bottom:var(--spacing-1)}.pending-gif-title a{color:var(--color-text);text-decoration:none}.pending-gif-title a:hover{color:var(--color-primary)}.pending-gif-actions{flex-shrink:0;display:flex;gap:var(--spacing-2);align-items:flex-start;flex-wrap:wrap}.pending-reject-form{width:100%}.pending-gif-similar{margin-top:var(--spacing-4);padding-top:var(--spacing-4);border-top:1px solid var(--color-border)}.pending-similar-label{display:flex;align-items:center;gap:var(--spacing-2);font-size:var(--font-size-sm);font-weight:600;color:var(--color-warning);margin-bottom:var(--spacing-3)}.pending-similar-items{display:flex;gap:var(--spacing-3);flex-wrap:wrap}.pending-similar-item{position:relative;display:block;width:100px;height:75px;border-radius:var(--radius-sm);overflow:hidden;border:2px solid var(--color-border);transition:border-color .2s}.pending-similar-item:hover{border-color:var(--color-primary)}.pending-similar-item img{width:100%;height:100%;object-fit:cover;display:block}.pending-similar-score{position:absolute;bottom:0;left:0;right:0;text-align:center;font-size:var(--font-size-xs);font-weight:700;padding:2px 0;color:#fff}.pending-similar-score.score-duplicate{background:rgba(239,68,68,.9)}.pending-similar-score.score-similar{background:rgba(245,158,11,.85)}@media (max-width:640px){.pending-gif-row{flex-direction:column}.pending-gif-preview img{width:100%;height:auto;max-height:200px}.pending-gif-actions{width:100%}}.duplicate-cluster{padding:var(--spacing-4);margin-bottom:var(--spacing-4)}.duplicate-cluster-header{display:flex;align-items:center;gap:var(--spacing-3);margin-bottom:var(--spacing-4);padding-bottom:var(--spacing-3);border-bottom:1px solid var(--color-border)}.duplicate-cluster-badge{display:inline-block;padding:var(--spacing-1) var(--spacing-3);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:600;color:#fff}.badge-duplicate{background:var(--color-error)}.badge-similar{background:var(--color-warning)}.duplicate-cluster-items{display:flex;gap:var(--spacing-4);flex-wrap:wrap}.duplicate-gif-item{display:flex;flex-direction:column;gap:var(--spacing-2);width:200px}.duplicate-gif-preview{display:block;width:200px;height:150px;border-radius:var(--radius-sm);overflow:hidden;border:2px solid var(--color-border);transition:border-color .2s}.duplicate-gif-preview:hover{border-color:var(--color-primary)}.duplicate-gif-preview img{width:100%;height:100%;object-fit:cover;display:block}.duplicate-gif-info{display:flex;flex-direction:column;gap:2px;min-width:0}.duplicate-gif-title{color:var(--color-text);text-decoration:none;font-size:var(--font-size-sm);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.duplicate-gif-title:hover{color:var(--color-primary)}@media (max-width:640px){.duplicate-cluster-items{flex-direction:column}.duplicate-gif-item{width:100%;flex-direction:row;align-items:center}.duplicate-gif-preview{width:100px;height:75px;flex-shrink:0}.duplicate-gif-info{flex:1}}.age-gate{position:fixed;inset:0;z-index:10000;background:rgba(0,0,0,.95);display:flex;align-items:center;justify-content:center;padding:var(--spacing-4)}.age-gate-box{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-8) var(--spacing-8);max-width:440px;width:100%;text-align:center}.age-gate-title{font-size:2rem;font-weight:700;color:var(--color-primary);margin-bottom:var(--spacing-4)}.age-gate-text{color:var(--color-text-secondary);margin-bottom:var(--spacing-2);line-height:1.5}.age-gate-question{font-size:var(--font-size-lg);font-weight:600;color:var(--color-text);margin-bottom:var(--spacing-6)}.age-gate-buttons{display:flex;gap:var(--spacing-3);justify-content:center}.age-gate-buttons .btn{min-width:140px}.admin-sidebar{position:fixed;left:0;top:50%;transform:translateY(-50%);z-index:1000;display:flex;flex-direction:column;align-items:flex-start;gap:0;transition:width .2s ease;width:48px}.admin-sidebar.expanded{width:180px}.admin-sidebar-toggle{width:48px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-left:none;border-radius:0 var(--radius-md) var(--radius-md) 0;color:var(--color-primary);cursor:pointer;transition:background .2s , color .2s;margin-bottom:var(--spacing-1)}.admin-sidebar-toggle:hover{background:var(--color-bg-tertiary);color:var(--color-primary-light)}.admin-sidebar-menu{display:flex;flex-direction:column;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-left:none;border-radius:0 var(--radius-md) var(--radius-md) 0;overflow:hidden;width:100%}.admin-sidebar-item{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-3);color:var(--color-text-secondary);text-decoration:none;font-size:var(--font-size-sm);white-space:nowrap;position:relative;transition:background .15s , color .15s;height:40px;min-width:0}.admin-sidebar-item:hover{background:var(--color-bg-tertiary);color:var(--color-text)}.admin-sidebar-item svg{flex-shrink:0}.admin-sidebar-label{display:none;overflow:hidden}.admin-sidebar.expanded .admin-sidebar-label{display:inline}.admin-sidebar-badge{position:absolute;top:4px;right:4px;background:var(--color-error);color:#fff;font-size:10px;font-weight:700;min-width:18px;height:18px;line-height:18px;text-align:center;border-radius:9px;padding:0 4px}.admin-sidebar.expanded .admin-sidebar-badge{position:static;margin-left:auto}@media (max-width:768px){.admin-sidebar{top:auto;bottom:0;left:0;right:0;transform:none;width:100%;flex-direction:row;align-items:stretch}.admin-sidebar,.admin-sidebar.expanded{width:100%}.admin-sidebar-toggle{display:none}.admin-sidebar-menu{flex-direction:row;border-radius:0;border-left:none;border-right:none;border-bottom:none;width:100%;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:constant(safe-area-inset-bottom);padding-bottom:env(safe-area-inset-bottom,0)}.admin-sidebar-menu::-webkit-scrollbar{display:none}.admin-sidebar-item{flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:var(--spacing-2) var(--spacing-2);height:auto;min-width:56px;flex:1 0 auto;font-size:var(--font-size-xs)}.admin-sidebar-label{display:block;font-size:10px;line-height:1.2;text-align:center}.admin-sidebar.expanded .admin-sidebar-label{display:block}.admin-sidebar-badge{position:absolute;top:2px;right:2px;min-width:16px;height:16px;line-height:16px;font-size:9px;padding:0 3px}.admin-sidebar.expanded .admin-sidebar-badge{position:absolute;margin-left:0}body.has-admin-sidebar{padding-bottom: calc(60px + constant(safe-area-inset-bottom));padding-bottom: calc(60px + env(safe-area-inset-bottom, 0px))}}.conversation-list{display:flex;flex-direction:column;gap:1px;background:var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.conversation-item{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-4);background:var(--color-bg-secondary);text-decoration:none;color:inherit;transition:background-color .15s}.conversation-item:hover{background:var(--color-bg-tertiary)}.conversation-unread{background:var(--color-bg-primary)}.conversation-unread .conversation-username,.conversation-unread .conversation-preview{font-weight:600}.conversation-avatar{width:44px;height:44px;border-radius:50%;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.1rem;flex-shrink:0}.conversation-info{flex:1;min-width:0}.conversation-header{display:flex;justify-content:space-between;align-items:baseline;gap:var(--spacing-2);margin-bottom:2px}.conversation-username{font-weight:500;color:var(--color-text-primary)}.conversation-time{font-size:.8rem;color:var(--color-text-muted);flex-shrink:0}.conversation-preview{font-size:.9rem;color:var(--color-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.conversation-you{color:var(--color-text-muted)}.conversation-badge{background:var(--color-primary);color:#fff;font-size:.75rem;font-weight:700;min-width:22px;height:22px;border-radius:11px;display:flex;align-items:center;justify-content:center;padding:0 6px;flex-shrink:0}.message-page{display:flex;flex-direction:column;height:calc(100vh - 80px);max-height:800px;background:var(--color-bg-secondary);border-radius:var(--radius-lg);overflow:hidden}.message-page-header{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-3) var(--spacing-4);border-bottom:1px solid var(--color-border);background:var(--color-bg-secondary);flex-shrink:0}.message-back-btn{display:inline-flex;align-items:center;gap:var(--spacing-1);font-size:.9rem}.message-page-user{font-weight:600;font-size:1.05rem}.message-page-user a{color:var(--color-text-primary);text-decoration:none}.message-page-user a:hover{color:var(--color-primary)}.message-thread{flex:1;overflow-y:auto;padding:var(--spacing-4);display:flex;flex-direction:column;gap:var(--spacing-3)}.message-empty{display:flex;align-items:center;justify-content:center;flex:1}.message-bubble{max-width:75%;padding:var(--spacing-3);border-radius:var(--radius-lg);word-wrap:break-word;overflow-wrap:break-word}.message-sent{align-self:flex-end;background:var(--color-primary);color:#fff;border-bottom-right-radius:var(--radius-sm)}.message-received{align-self:flex-start;background:var(--color-bg-tertiary);color:var(--color-text-primary);border-bottom-left-radius:var(--radius-sm)}.message-text{line-height:1.5;font-size:.95rem}.message-meta{display:flex;align-items:center;gap:var(--spacing-1);margin-top:var(--spacing-1);font-size:.75rem;opacity:.7}.message-sent .message-meta{justify-content:flex-end}.message-read-status{display:inline-flex}.message-gif-attachment{display:block;margin-bottom:var(--spacing-2);border-radius:var(--radius-md);overflow:hidden;max-width:240px}.message-gif-attachment img{display:block;width:100%;height:auto;border-radius:var(--radius-md)}.message-sent .message-gif-attachment img{border:2px solid rgba(255,255,255,.2)}.message-compose{border-top:1px solid var(--color-border);padding:var(--spacing-3) var(--spacing-4);background:var(--color-bg-secondary);flex-shrink:0}.message-compose-row{display:flex;align-items:flex-end;gap:var(--spacing-2)}.message-gif-btn,.message-send-btn{background:none;border:none;color:var(--color-text-secondary);cursor:pointer;padding:var(--spacing-2);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;transition:color .15s , background-color .15s;flex-shrink:0}.message-gif-btn:hover,.message-send-btn:hover{color:var(--color-primary);background:var(--color-bg-tertiary)}.message-send-btn{color:var(--color-primary)}.message-input{flex:1;background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-2) var(--spacing-3);color:var(--color-text-primary);font-family:inherit;font-size:.95rem;resize:none;line-height:1.5;max-height:120px;outline:none}.message-input:focus{border-color:var(--color-primary)}.message-input::placeholder{color:var(--color-text-muted)}.message-gif-preview{position:relative;display:inline-block;margin-bottom:var(--spacing-2);border-radius:var(--radius-md);overflow:hidden;max-width:120px}.message-gif-preview img{display:block;width:100%;height:auto;border-radius:var(--radius-md)}.message-gif-remove{position:absolute;top:4px;right:4px;width:22px;height:22px;border-radius:50%;background:rgba(0,0,0,.7);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;line-height:1}.gif-picker-modal{max-width:600px;max-height:80vh;display:flex;flex-direction:column}.gif-picker-search{padding:0 var(--spacing-4) var(--spacing-3)}.gif-picker-grid{flex:1;overflow-y:auto;padding:0 var(--spacing-4) var(--spacing-4);display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-2);align-content:start}.gif-picker-grid p{grid-column: 1 / -1;padding:var(--spacing-6) 0}.gif-picker-item{cursor:pointer;border-radius:var(--radius-md);overflow:hidden;aspect-ratio:1;background:var(--color-bg-tertiary);transition:opacity .15s , transform .15s}.gif-picker-item:hover{opacity:.85;transform:scale(1.03)}.gif-picker-item img{display:block;width:100%;height:100%;object-fit:cover}.message-badge{background:var(--color-primary)}@media (max-width:768px){.message-page{height:calc(100vh - 60px);max-height:none;border-radius:0;margin: calc(var(--spacing-4) * -1);margin-top:0}.message-bubble{max-width:85%}.gif-picker-grid{grid-template-columns:repeat(2,1fr)}.conversation-avatar{width:38px;height:38px;font-size:1rem}}.follow-btn{background: linear-gradient(
        135deg,
        var(--color-primary),
        var(--color-accent)
    );color:#fff;border:2px solid transparent;padding:var(--spacing-2) var(--spacing-4);border-radius:var(--radius-full);font-weight:600;font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.follow-btn:hover{opacity:.9;transform:translateY(-1px)}.follow-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.follow-btn.following{background:transparent;color:var(--color-text-secondary);border:2px solid var(--color-border)}.follow-btn.following:hover{border-color:var(--color-error);color:var(--color-error);opacity:1}.follow-btn.btn-sm{padding:var(--spacing-1) var(--spacing-3);font-size:var(--font-size-xs)}.profile-stats{display:flex;align-items:center;gap:var(--spacing-2);margin-top:var(--spacing-2)}.profile-stat{color:var(--color-text-secondary);text-decoration:none;font-size:var(--font-size-sm);transition:color var(--transition-fast)}.profile-stat:hover{color:var(--color-primary)}.profile-stat strong{color:var(--color-text);font-weight:700}.profile-stat-sep{color:var(--color-text-muted)}.follow-list{display:flex;flex-direction:column;gap:1px;background:var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.follow-item{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-3);padding:var(--spacing-4);background:var(--color-bg-secondary);transition:background var(--transition-fast)}.follow-item:hover{background:var(--color-bg-tertiary)}.follow-item-name{font-weight:600;color:var(--color-text);text-decoration:none;font-size:var(--font-size-base)}.follow-item-name:hover{color:var(--color-primary)}.follow-item-meta{display:flex;align-items:center;gap:var(--spacing-3)}@media (max-width:640px){.follow-item{flex-direction:column;align-items:flex-start;gap:var(--spacing-2)}.follow-item-meta{width:100%;justify-content:space-between}}.gif-detail-title-row{display:flex;align-items:center;gap:var(--spacing-2)}.gif-edit-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-normal);flex-shrink:0}.gif-edit-btn:hover{background-color:var(--color-bg-tertiary);color:var(--color-text);border-color:var(--color-text-muted)}.gif-edit-form{width:100%;margin-bottom:var(--spacing-3)}.gif-edit-input,.gif-edit-textarea{width:100%;padding:var(--spacing-2) var(--spacing-3);background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-family: var(--font-family);font-size:var(--font-size-base);transition:border-color var(--transition-normal)}.gif-edit-input{font-size:var(--font-size-xl);font-weight:700;margin-bottom:var(--spacing-2)}.gif-edit-textarea{resize:vertical;min-height:60px;margin-bottom:var(--spacing-2)}.gif-edit-input:focus,.gif-edit-textarea:focus{outline:none;border-color:var(--color-primary)}.gif-edit-actions{display:flex;gap:var(--spacing-2)}.gif-edit-save{padding:var(--spacing-2) var(--spacing-4);background: linear-gradient(
        135deg,
        var(--color-primary),
        var(--color-secondary)
    );border:none;border-radius:var(--radius-md);color:#fff;font-family: var(--font-family);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:opacity var(--transition-normal)}.gif-edit-save:hover{opacity:.9}.gif-edit-save:disabled{opacity:.5;cursor:not-allowed}.gif-edit-cancel{padding:var(--spacing-2) var(--spacing-4);background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);font-family: var(--font-family);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-normal)}.gif-edit-cancel:hover{background-color:var(--color-bg-tertiary);color:var(--color-text)}.block-btn{background:transparent;color:var(--color-text-muted);border:2px solid var(--color-border);padding:var(--spacing-2) var(--spacing-4);border-radius:var(--radius-full);font-weight:600;font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.block-btn:hover{border-color:var(--color-error);color:var(--color-error)}.block-btn:disabled{opacity:.6;cursor:not-allowed}.block-btn.blocked{background-color:rgba(239,68,68,.12);border-color:rgba(239,68,68,.3);color:var(--color-error)}.block-btn.blocked:hover{background-color:transparent;border-color:var(--color-border);color:var(--color-text-muted)}.profile-blocked-notice{display:inline-flex;align-items:center;padding:var(--spacing-2) var(--spacing-4);background-color:rgba(239,68,68,.12);border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-full);color:var(--color-error);font-size:var(--font-size-sm);font-weight:500}.breadcrumbs{display:flex;align-items:center;flex-wrap:wrap;gap:var(--spacing-1);margin-bottom:var(--spacing-4);font-size:var(--font-size-sm);color:var(--color-text-muted)}.breadcrumbs a{color:var(--color-text-muted);text-decoration:none;transition:color .15s}.breadcrumbs a:hover{color:var(--color-primary)}.breadcrumbs .separator{margin:0 var(--spacing-1);opacity:.5}.breadcrumbs .current{color:var(--color-text);font-weight:500}