.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1.25rem;font-size:.9375rem;font-weight:500;line-height:1.25;text-decoration:none;border:1px solid transparent;border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast),box-shadow var(--transition-fast);white-space:nowrap}.btn:focus-visible{outline:2px solid var(--ring);outline-offset:2px}.btn.disabled,.btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.btn-primary{background-color:var(--primary);color:var(--primary-foreground);border-color:var(--primary)}.btn-primary:hover{background-color:#2d6fd9;border-color:#2d6fd9;color:var(--primary-foreground)}.btn-secondary{background-color:var(--secondary);color:var(--secondary-foreground);border-color:var(--border)}.btn-secondary:hover{background-color:var(--muted);color:var(--foreground)}.btn-outline{background-color:var(--background);color:var(--foreground);border-color:var(--border)}.btn-outline:hover{background-color:var(--muted)}.btn-ghost{background-color:transparent;color:var(--foreground);border-color:transparent}.btn-ghost:hover{background-color:var(--muted)}.btn-destructive{background-color:var(--destructive);color:var(--destructive-foreground);border-color:var(--destructive)}.btn-destructive:hover{background-color:#d93c3c;border-color:#d93c3c}.btn-link{background-color:transparent;color:var(--primary);border-color:transparent;padding:0;text-decoration:underline;text-underline-offset:4px}.btn-link:hover{color:var(--accent-foreground)}.btn-sm{padding:.375rem .875rem;font-size:.8125rem;border-radius:var(--radius-sm)}.btn-lg{padding:.875rem 1.75rem;font-size:1rem;border-radius:var(--radius-lg)}.btn-icon{padding:.5rem;width:2.5rem;height:2.5rem}.btn-icon.btn-sm{width:2rem;height:2rem;padding:.375rem}.btn-icon.btn-lg{width:3rem;height:3rem;padding:.625rem}.btn-full{width:100%}.card{background-color:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden;transition:box-shadow var(--transition-base),transform var(--transition-base)}.card:hover{box-shadow:var(--shadow-md)}.card-link{display:block;text-decoration:none;color:inherit}.card-link:hover{color:inherit}.card-image{position:relative;overflow:hidden;aspect-ratio:16/10}.card-image img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-slow)}.card:hover .card-image img{transform:scale(1.03)}.card-body{padding:1.25rem}.card-header{padding:1.25rem;border-bottom:1px solid var(--border)}.card-footer{padding:1rem 1.25rem;border-top:1px solid var(--border);background-color:var(--muted)}.card-title{font-size:1.125rem;font-weight:600;line-height:1.3;margin-bottom:.5rem}.card-title a{color:inherit}.card-title a:hover{color:var(--primary)}.card-description{color:var(--muted-foreground);font-size:.9375rem;line-height:1.5}.card-meta{display:flex;align-items:center;gap:.75rem;font-size:.8125rem;color:var(--muted-foreground)}.card-meta-item{display:flex;align-items:center;gap:.25rem}.form-group{margin-bottom:1.25rem}.form-label{display:block;font-size:.875rem;font-weight:500;margin-bottom:.5rem;color:var(--foreground)}.form-label-required::after{content:" *";color:var(--destructive)}.form-input,.form-select,.form-textarea{display:block;width:100%;padding:.625rem .875rem;font-size:.9375rem;line-height:1.5;color:var(--foreground);background-color:var(--background);border:1px solid var(--input);border-radius:var(--radius-md);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:0;border-color:var(--ring);box-shadow:0 0 0 3px rgba(57,129,246,.15)}.form-input::placeholder,.form-textarea::placeholder{color:var(--muted-foreground);opacity:.7}.form-input:disabled,.form-select:disabled,.form-textarea:disabled{background-color:var(--muted);cursor:not-allowed;opacity:.5}.form-input.is-invalid,.form-select.is-invalid,.form-textarea.is-invalid{border-color:var(--destructive)}.form-input.is-invalid:focus,.form-select.is-invalid:focus,.form-textarea.is-invalid:focus{box-shadow:0 0 0 3px rgba(241,68,68,.15)}.form-textarea{min-height:120px;resize:vertical}.form-select{appearance:none;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right .75rem center;background-repeat:no-repeat;background-size:1rem;padding-right:2.5rem}.form-check{display:flex;align-items:flex-start;gap:.5rem}.form-check-input{width:1rem;height:1rem;margin-top:.25rem;accent-color:var(--primary);cursor:pointer}.form-check-label{font-size:.9375rem;color:var(--foreground);cursor:pointer}.form-helper{margin-top:.375rem;font-size:.8125rem;color:var(--muted-foreground)}.form-error{margin-top:.375rem;font-size:.8125rem;color:var(--destructive)}.badge{display:inline-flex;align-items:center;padding:.25rem .625rem;font-size:.75rem;font-weight:500;line-height:1;border-radius:var(--radius-full);white-space:nowrap}.badge-primary{background-color:var(--primary);color:var(--primary-foreground)}.badge-secondary{background-color:var(--secondary);color:var(--secondary-foreground)}.badge-accent{background-color:var(--accent);color:var(--accent-foreground)}.badge-success{background-color:#10b981;color:#fff}.badge-warning{background-color:#f59e0b;color:#fff}.badge-destructive{background-color:var(--destructive);color:var(--destructive-foreground)}.badge-outline{background-color:transparent;border:1px solid var(--border);color:var(--foreground)}.alert{display:flex;gap:.75rem;padding:1rem;border-radius:var(--radius-lg);border:1px solid transparent}.alert-icon{flex-shrink:0;width:1.25rem;height:1.25rem}.alert-content{flex:1}.alert-title{font-weight:600;margin-bottom:.25rem}.alert-description{font-size:.9375rem}.alert-info{background-color:var(--accent);border-color:var(--primary);color:var(--accent-foreground)}.alert-success{background-color:#d1fae5;border-color:#10b981;color:#065f46}.alert-warning{background-color:#fef3c7;border-color:#f59e0b;color:#92400e}.alert-destructive{background-color:#fee2e2;border-color:var(--destructive);color:#991b1b}.avatar{position:relative;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-full);overflow:hidden;background-color:var(--muted);color:var(--muted-foreground);font-weight:500}.avatar img{width:100%;height:100%;object-fit:cover}.avatar-sm{width:2rem;height:2rem;font-size:.75rem}.avatar-md{width:2.5rem;height:2.5rem;font-size:.875rem}.avatar-lg{width:3rem;height:3rem;font-size:1rem}.avatar-xl{width:4rem;height:4rem;font-size:1.25rem}.separator{height:1px;width:100%;background-color:var(--border)}.separator-vertical{width:1px;height:auto;align-self:stretch}.tabs{display:flex;flex-direction:column}.tabs-list{display:flex;gap:.25rem;border-bottom:1px solid var(--border);margin-bottom:1.5rem;list-style:none}.tabs-trigger{display:inline-flex;align-items:center;justify-content:center;padding:.625rem 1rem;font-size:.9375rem;font-weight:500;color:var(--muted-foreground);background:0 0;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:color var(--transition-fast),border-color var(--transition-fast);margin-bottom:-1px}.tabs-trigger:hover{color:var(--foreground)}.tabs-trigger.active,.tabs-trigger[aria-selected=true]{color:var(--primary);border-bottom-color:var(--primary)}.tabs-content{display:none}.tabs-content.active{display:block}.dropdown{position:relative;display:inline-block}.dropdown-menu{position:absolute;top:100%;left:0;z-index:var(--z-dropdown);min-width:12rem;padding:.375rem;background-color:var(--popover);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);opacity:0;visibility:hidden;transform:translateY(-.5rem);transition:opacity var(--transition-fast),visibility var(--transition-fast),transform var(--transition-fast)}.dropdown.open .dropdown-menu{opacity:1;visibility:visible;transform:translateY(0)}.dropdown-item{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;font-size:.9375rem;color:var(--popover-foreground);text-decoration:none;border-radius:var(--radius-sm);cursor:pointer;transition:background-color var(--transition-fast)}.dropdown-item:hover{background-color:var(--muted);color:var(--foreground)}.dropdown-separator{height:1px;margin:.375rem 0;background-color:var(--border)}.pagination{display:flex;justify-content:center;align-items:center;gap:.25rem;list-style:none}.pagination-item a,.pagination-item span{display:inline-flex;align-items:center;justify-content:center;min-width:2.5rem;height:2.5rem;padding:0 .75rem;font-size:.9375rem;color:var(--foreground);text-decoration:none;border:1px solid var(--border);border-radius:var(--radius-md);transition:background-color var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast)}.pagination-item a:hover{background-color:var(--muted);color:var(--foreground)}.pagination-item.active span{background-color:var(--primary);border-color:var(--primary);color:var(--primary-foreground)}.pagination-item.disabled span{opacity:.5;cursor:not-allowed}.breadcrumb{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;list-style:none;font-size:.9375rem;margin-bottom:1rem}.breadcrumb-item{display:flex;align-items:center;gap:.5rem}.breadcrumb-item:not(:last-child)::after{content:"/";color:var(--muted-foreground)}.breadcrumb-item a{color:var(--muted-foreground)}.breadcrumb-item a:hover{color:var(--foreground)}.breadcrumb-item:last-child{color:var(--foreground);font-weight:500}.hero{padding:4rem 0;text-align:center;position:relative}.bg-dot-pattern{background-image:radial-gradient(circle,var(--border) 1px,transparent 1px);background-size:24px 24px}.bg-grid-pattern{background-image:linear-gradient(to right,var(--border) 1px,transparent 1px),linear-gradient(to bottom,var(--border) 1px,transparent 1px);background-size:40px 40px}.bg-dot-pattern-fade{background-image:radial-gradient(circle,rgba(0,0,0,.12) 1px,transparent 1px);background-size:20px 20px}.dark .bg-dot-pattern-fade{background-image:radial-gradient(circle,rgba(255,255,255,.12) 1px,transparent 1px)}@media (min-width:768px){.hero{padding:5rem 0}}@media (min-width:1024px){.hero{padding:6rem 0}}.hero-content{max-width:48rem;margin:0 auto}.hero-eyebrow{display:inline-block;font-size:.875rem;font-weight:500;color:var(--primary);text-transform:uppercase;letter-spacing:.1em;margin-bottom:1rem}.hero-title{margin-bottom:1.25rem}.hero-description{font-size:1.125rem;color:var(--muted-foreground);margin-bottom:2rem}@media (min-width:768px){.hero-description{font-size:1.25rem}}.hero-actions{display:flex;flex-wrap:wrap;justify-content:center;gap:.75rem}.section-header{text-align:center;max-width:48rem;margin:0 auto 3rem}.section-eyebrow{display:inline-block;font-size:.8125rem;font-weight:600;color:var(--primary);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.75rem}.section-title{margin-bottom:.75rem}.section-description{color:var(--muted-foreground);font-size:1.0625rem}.feature-card{padding:1.5rem;background-color:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg)}.feature-icon{display:inline-flex;align-items:center;justify-content:center;width:3rem;height:3rem;margin-bottom:1rem;background-color:var(--accent);color:var(--primary);border-radius:var(--radius-md)}.feature-title{font-size:1.125rem;font-weight:600;margin-bottom:.5rem}.feature-description{color:var(--muted-foreground);font-size:.9375rem}.pricing-grid{display:grid;gap:1.5rem}@media (min-width:768px){.pricing-grid{grid-template-columns:repeat(3,1fr);align-items:start}}.pricing-card{background-color:var(--card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:1.5rem;position:relative}.pricing-card.featured{border-color:var(--primary);box-shadow:var(--shadow-lg)}.pricing-badge{position:absolute;top:-.75rem;right:1.5rem;padding:.25rem .75rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;background-color:var(--primary);color:var(--primary-foreground);border-radius:var(--radius-full)}.pricing-header{text-align:center;padding-bottom:1.5rem;border-bottom:1px solid var(--border);margin-bottom:1.5rem}.pricing-name{font-size:1.25rem;font-weight:600;margin-bottom:.5rem}.pricing-price{display:flex;align-items:baseline;justify-content:center;gap:.25rem}.pricing-amount{font-size:2.5rem;font-weight:700;line-height:1}.pricing-period{font-size:.9375rem;color:var(--muted-foreground)}.pricing-description{margin-top:.5rem;font-size:.875rem;color:var(--muted-foreground)}.pricing-features{list-style:none;margin-bottom:1.5rem}.pricing-features li{display:flex;align-items:flex-start;gap:.5rem;padding:.5rem 0;font-size:.9375rem}.pricing-features li::before{content:"";flex-shrink:0;width:1.25rem;height:1.25rem;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='%2310b981'%3e%3cpath fill-rule='evenodd' d='M16.704 4.153a.75.75 0 01.143 1.052l-8 10.5a.75.75 0 01-1.127.075l-4.5-4.5a.75.75 0 011.06-1.06l3.894 3.893 7.48-9.817a.75.75 0 011.05-.143z' clip-rule='evenodd'/%3e%3c/svg%3e");background-size:contain}.pricing-cta{width:100%}.author-box{display:flex;gap:1rem;padding:1.5rem;background-color:var(--muted);border-radius:var(--radius-lg)}@media (min-width:640px){.author-box{gap:1.5rem}}.author-avatar{flex-shrink:0}.author-info{flex:1}.author-name{font-size:1.125rem;font-weight:600;margin-bottom:.25rem}.author-bio{font-size:.9375rem;color:var(--muted-foreground);margin-bottom:.75rem}.author-links{display:flex;gap:.75rem}.author-link{color:var(--muted-foreground);font-size:.875rem}.author-link:hover{color:var(--primary)}.reading-progress{position:fixed;top:0;left:0;width:0%;height:3px;background-color:var(--primary);z-index:var(--z-fixed);transition:width .1s ease-out}.toc{padding:1.25rem;background-color:var(--muted);border-radius:var(--radius-lg);margin-bottom:2rem}.toc-title{font-size:.9375rem;font-weight:600;margin-bottom:.75rem}.toc-list{list-style:none}.toc-list li{margin-bottom:.375rem}.toc-list a{display:block;padding:.25rem 0;font-size:.9375rem;color:var(--muted-foreground)}.toc-list a:hover{color:var(--primary)}.toc-list .toc-h3{padding-left:1rem}.toc-list .toc-h4{padding-left:2rem}.social-share{display:flex;gap:.5rem}.social-share-btn{display:inline-flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;border-radius:var(--radius-full);background-color:var(--secondary);color:var(--foreground);transition:background-color var(--transition-fast),color var(--transition-fast)}.social-share-btn:hover{background-color:var(--primary);color:var(--primary-foreground)}.skeleton{background:linear-gradient(90deg,var(--muted) 25%,var(--border) 50%,var(--muted) 75%);background-size:200% 100%;animation:skeleton-loading 1.5s infinite;border-radius:var(--radius-md)}@keyframes skeleton-loading{0%{background-position:200% 0}100%{background-position:-200% 0}}.skeleton-text{height:1rem;margin-bottom:.5rem}.skeleton-title{height:1.5rem;width:60%;margin-bottom:.75rem}.skeleton-avatar{width:3rem;height:3rem;border-radius:var(--radius-full)}.skeleton-image{aspect-ratio:16/10}