/* components.css - kartu & komponen UI reusable */
@import url('./design-tokens.css');
.btn{--btn-bg:var(--color-brand-primary);--btn-color:#fff;--btn-bg-hover:var(--color-brand-secondary);display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:14px;padding:10px 18px;border-radius:var(--radius-md);background:var(--btn-bg);color:var(--btn-color);border:0;cursor:pointer;transition:var(--transition-fast);} .btn:hover{background:var(--btn-bg-hover);} 
.btn-alt{--btn-bg:var(--gray-100);--btn-color:var(--gray-700);--btn-bg-hover:var(--gray-200);} 
.btn--soft{--btn-bg:#fff;--btn-color:var(--color-brand-primary);--btn-bg-hover:#f1f5f9;} 
.badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;font-size:11px;font-weight:600;border-radius:var(--radius-pill);background:var(--gray-100);color:var(--gray-600);} 
.card{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:var(--space-5);box-shadow:var(--shadow-sm);position:relative;} .card:hover{box-shadow:var(--shadow-md);} 
.news-card-v2,.project-card-v2,.unified-card{ /* already styled in homepage-specific file; minimal fallback */ }
.tab-switch button{cursor:pointer;} 
.inline-info{display:flex;gap:14px;background:linear-gradient(135deg,var(--color-brand-primary),var(--color-brand-secondary));padding:var(--space-5);border-radius:var(--radius-lg);color:#fff;align-items:flex-start;box-shadow:var(--shadow-md);} 
.inline-info i{font-size:26px;} .inline-info p{margin:0;font-size:14px;line-height:1.5;} 
/* Elevation utility for any card-like pattern */
.elevate-hover{transition:box-shadow .35s,transform .35s;} .elevate-hover:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px);} 
