.rank-path{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:var(--gap-md);list-style:none;margin:0;padding:0}.rank-path__card{position:relative;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--padding-md);display:flex;flex-direction:column;gap:var(--gap-xs);overflow:hidden;transition:border-color .2s ease,box-shadow .2s ease}.rank-path__card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--border);border-radius:var(--radius-md) var(--radius-md) 0 0}.rank-path__card--reached:before{background:var(--success)}.rank-path__card--current:before{background:var(--primary)}.rank-path__card--next:before{background:color-mix(in srgb,var(--primary) 50%,var(--border))}.rank-path__card--current{border-color:color-mix(in srgb,var(--primary) 40%,var(--border));background:color-mix(in srgb,var(--primary) 4%,var(--surface))}.rank-path__card--reached{border-color:color-mix(in srgb,var(--success) 30%,var(--border))}.rank-path__card--locked{opacity:.7}.rank-path__card-header{display:flex;align-items:center;justify-content:space-between;gap:var(--gap-xs)}.rank-path__label{font-size:var(--text-body-sm);font-weight:var(--font-bold);color:var(--titles);line-height:1}.rank-path__card--current .rank-path__label{color:var(--primary)}.rank-path__card--reached .rank-path__label{color:var(--success)}.rank-path__card--locked .rank-path__label{color:var(--muted)}.rank-path__state-pill{display:inline-flex;align-items:center;font-size:var(--text-tiny);font-weight:var(--font-semibold);padding:var(--gap-2xs) var(--gap-xs);border-radius:var(--radius-full);flex-shrink:0;white-space:nowrap}.rank-path__state-pill--reached{background:color-mix(in srgb,var(--success) 15%,var(--surface));color:var(--success)}.rank-path__state-pill--current{background:color-mix(in srgb,var(--primary) 15%,var(--surface));color:var(--primary)}.rank-path__state-pill--next{background:color-mix(in srgb,var(--primary) 8%,var(--surface));color:var(--muted)}.rank-path__state-pill--locked{background:var(--bg);color:var(--muted)}.rank-path__description{font-size:var(--text-tiny);color:var(--muted);line-height:var(--leading-relaxed);display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;flex:1}.rank-path__threshold{font-size:var(--text-tiny);color:var(--muted);font-weight:var(--font-medium);margin-top:var(--gap-xs)}.rank-path__progress-track{width:100%;height:4px;background:color-mix(in srgb,var(--primary) 15%,var(--bg));border-radius:var(--radius-full);overflow:hidden;margin-top:var(--gap-xs)}.rank-path__progress-fill{height:100%;background:var(--primary);border-radius:var(--radius-full);transition:width .5s cubic-bezier(.4,0,.2,1);min-width:4px}@media (max-width:640px){.rank-path{grid-template-columns:1fr 1fr}}@media (max-width:380px){.rank-path{grid-template-columns:1fr}}.badge-card{position:relative;background:var(--surface);border:1px solid var(--badge-card-border,var(--border));border-radius:var(--radius-md);padding:var(--padding-md);display:flex;flex-direction:column;gap:var(--gap-sm);transition:border-color .2s ease,transform .2s ease,box-shadow .2s ease;overflow:hidden}.badge-card--featured{padding:var(--padding-lg);gap:var(--gap-md);background:color-mix(in srgb,var(--badge-card-accent,var(--primary)) 4%,var(--surface))}.badge-card--featured:not(.badge-card--locked):hover{transform:translateY(-2px);box-shadow:0 8px 24px color-mix(in srgb,var(--badge-card-accent,var(--primary)) 20%,transparent)}.badge-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--badge-card-accent,transparent);border-radius:var(--radius-md) var(--radius-md) 0 0}.badge-card--obtained{--badge-card-border:var(--success);--badge-card-accent:var(--success);--badge-card-progress-fill:var(--success)}.badge-card--in_progress{--badge-card-border:var(--primary);--badge-card-accent:var(--primary);--badge-card-progress-fill:var(--primary)}.badge-card--locked{--badge-card-border:var(--border);--badge-card-accent:transparent;--badge-card-progress-fill:var(--muted);opacity:.75}.badge-card--locked:hover{transform:none;border-color:var(--border)}.badge-card:not(.badge-card--locked):hover{transform:translateY(-1px)}.badge-card__header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--gap-sm)}.badge-card__header-left{display:flex;align-items:center;gap:var(--gap-sm);flex:1;min-width:0}.badge-card__icon{font-size:1.5rem;flex-shrink:0;line-height:1}.badge-card--featured .badge-card__icon{font-size:2.25rem}.badge-card--locked .badge-card__icon{filter:grayscale(.8) opacity(.55)}.badge-card__title{font-size:var(--text-body-sm);font-weight:var(--font-semibold);color:var(--titles);line-height:var(--leading-tight);overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical}.badge-card--featured .badge-card__title{font-size:var(--text-h5);font-weight:var(--font-bold)}.badge-card--locked .badge-card__title{color:var(--muted)}.badge-card__status-pill{flex-shrink:0;font-size:var(--text-tiny);font-weight:var(--font-semibold);padding:var(--gap-2xs) var(--gap-xs);border-radius:var(--radius-full);line-height:1.4;white-space:nowrap}.badge-card__status-pill--obtained{background:var(--success);color:var(--bg)}.badge-card__status-pill--in_progress{background:var(--primary);color:var(--on-primary,var(--bg))}.badge-card__status-pill--locked{background:var(--border);color:var(--muted)}.badge-card__progress{display:flex;flex-direction:column;gap:var(--gap-xs)}.badge-card__progress-label{font-size:var(--text-tiny);color:var(--muted)}.badge-card__progress-track{width:100%;height:5px;background:color-mix(in srgb,var(--badge-card-progress-fill,var(--primary)) 12%,var(--bg));border:1px solid color-mix(in srgb,var(--badge-card-progress-fill,var(--primary)) 20%,var(--border));border-radius:var(--radius-full);overflow:hidden}.badge-card--featured .badge-card__progress-track{height:8px}.badge-card__progress-fill{height:100%;background:var(--badge-card-progress-fill,var(--primary));border-radius:var(--radius-full);transition:width .4s cubic-bezier(.4,0,.2,1);min-width:2px}.badge-card__description{font-size:var(--text-tiny);color:var(--muted);line-height:var(--leading-relaxed);display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.badge-card--featured .badge-card__description{font-size:var(--text-body-sm);-webkit-line-clamp:3;line-clamp:3}.badge-card--compact .badge-card__description{display:none}.badge-detail-card{position:relative;background:var(--surface);border:1px solid var(--badge-detail-border,var(--border));border-radius:var(--radius-lg);padding:var(--padding-lg);transition:border-color .2s ease,box-shadow .2s ease,transform .2s ease;overflow:hidden;height:100%}.badge-detail-card,.badge-detail-card__body{display:flex;flex-direction:column;gap:var(--gap-md)}.badge-detail-card__body{flex:1}.badge-detail-card__chapters-section{margin-top:auto;display:flex;flex-direction:column;gap:var(--gap-xs)}.badge-detail-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--badge-detail-accent,var(--border));border-radius:var(--radius-lg) var(--radius-lg) 0 0}.badge-detail-card--obtained{--badge-detail-border:color-mix(in srgb,var(--success) 35%,var(--border));--badge-detail-accent:var(--success);--badge-detail-progress-fill:var(--success);--badge-detail-pill-bg:color-mix(in srgb,var(--success) 15%,var(--surface));--badge-detail-pill-color:var(--success)}.badge-detail-card--in_progress{--badge-detail-border:color-mix(in srgb,var(--primary) 35%,var(--border));--badge-detail-accent:var(--primary);--badge-detail-progress-fill:var(--primary);--badge-detail-pill-bg:color-mix(in srgb,var(--primary) 15%,var(--surface));--badge-detail-pill-color:var(--primary)}.badge-detail-card--locked{--badge-detail-border:var(--border);--badge-detail-accent:transparent;--badge-detail-progress-fill:var(--muted);--badge-detail-pill-bg:var(--bg);--badge-detail-pill-color:var(--muted)}.badge-detail-card--in_progress:hover,.badge-detail-card--obtained:hover{transform:translateY(-1px);box-shadow:0 4px 16px color-mix(in srgb,var(--badge-detail-accent,var(--primary)) 12%,transparent)}.badge-detail-card__header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--gap-sm)}.badge-detail-card__header-left{display:flex;align-items:center;gap:var(--gap-sm);flex:1;min-width:0}.badge-detail-card__icon,.badge-detail-card__locked-icon{font-size:1.75rem;line-height:1;flex-shrink:0}.badge-detail-card__locked-icon{opacity:.35}.badge-detail-card__label{font-size:var(--text-h6);font-weight:var(--font-bold);color:var(--titles);line-height:var(--leading-tight);overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical}.badge-detail-card--locked .badge-detail-card__label{color:var(--text)}.badge-detail-card__status-pill{display:inline-flex;align-items:center;font-size:var(--text-tiny);font-weight:var(--font-semibold);padding:var(--gap-2xs) var(--gap-sm);border-radius:var(--radius-full);background:var(--badge-detail-pill-bg,var(--bg));color:var(--badge-detail-pill-color,var(--muted));border:1px solid color-mix(in srgb,var(--badge-detail-pill-color,var(--muted)) 35%,transparent);flex-shrink:0;white-space:nowrap;line-height:1.4}.badge-detail-card__category{font-size:var(--text-tiny);font-weight:var(--font-semibold);color:var(--muted);text-transform:uppercase;letter-spacing:.08em}.badge-detail-card__description{font-size:var(--text-body-sm);color:var(--text);line-height:var(--leading-relaxed)}.badge-detail-card--locked .badge-detail-card__description{color:var(--text);opacity:.7}.badge-detail-card__progress{display:flex;flex-direction:column;gap:var(--gap-xs)}.badge-detail-card__progress-label{font-size:var(--text-tiny);color:var(--muted);font-weight:var(--font-medium)}.badge-detail-card--in_progress .badge-detail-card__progress-label{color:var(--primary)}.badge-detail-card--obtained .badge-detail-card__progress-label{color:var(--success)}.badge-detail-card__progress-track{width:100%;height:5px;background:color-mix(in srgb,var(--badge-detail-progress-fill,var(--border)) 18%,var(--bg));border-radius:var(--radius-full);overflow:hidden}.badge-detail-card__progress-fill{height:100%;background:var(--badge-detail-progress-fill,var(--muted));border-radius:var(--radius-full);transition:width .5s cubic-bezier(.4,0,.2,1);min-width:3px}.badge-detail-card__next-step{font-size:var(--text-tiny);color:var(--primary);font-weight:var(--font-medium);padding:var(--gap-xs) var(--gap-sm);background:color-mix(in srgb,var(--primary) 8%,var(--surface));border-radius:var(--radius-sm);border-left:2px solid var(--primary)}.badge-detail-card--locked .badge-detail-card__next-step{color:var(--muted);border-left-color:var(--border);background:var(--bg)}.badge-detail-card__divider{height:1px;background:var(--border);opacity:.5}.badge-detail-card__chapters-label{font-size:var(--text-tiny);font-weight:var(--font-semibold);color:var(--muted);text-transform:uppercase;letter-spacing:.08em}.badge-collection__filters{display:flex;flex-direction:column;gap:var(--gap-md);margin-bottom:var(--gap-xl);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--padding-md)}.badge-collection__filter-group{display:flex;flex-wrap:wrap;gap:var(--gap-xs);align-items:center}.badge-collection__filter-group+.badge-collection__filter-group{padding-top:var(--gap-md);border-top:1px solid var(--border)}.badge-collection__filter-group-label{font-size:var(--text-tiny);font-weight:var(--font-semibold);color:var(--muted);text-transform:uppercase;letter-spacing:var(--tracking-wider);width:5rem;flex-shrink:0}.badge-collection__filter-btn{display:inline-flex;align-items:center;font-size:var(--text-body-sm);font-weight:var(--font-medium);padding:var(--gap-xs) var(--gap-md);border-radius:var(--radius-full);background:var(--bg);border:1px solid var(--border);color:var(--muted);cursor:pointer;transition:background .15s ease,border-color .15s ease,color .15s ease;white-space:nowrap;line-height:1.4}.badge-collection__filter-btn:hover{background:color-mix(in srgb,var(--primary) 8%,var(--surface));border-color:color-mix(in srgb,var(--primary) 30%,var(--border));color:var(--text)}.badge-collection__filter-btn--active{background:color-mix(in srgb,var(--primary) 14%,var(--surface));border-color:var(--primary);color:var(--primary);font-weight:var(--font-semibold);box-shadow:0 0 0 1px color-mix(in srgb,var(--primary) 25%,transparent)}.badge-collection__result-count{font-size:var(--text-tiny);color:var(--muted);font-weight:var(--font-medium);letter-spacing:var(--tracking-wide);padding-top:var(--gap-md);border-top:1px solid var(--border)}.badge-collection__grid{margin-top:var(--gap-lg)}.badge-collection__grid .grid-item{height:100%;display:flex;flex-direction:column}.badge-collection__category-heading{font-size:var(--text-body-sm);font-weight:var(--font-semibold);color:var(--muted);text-transform:uppercase;letter-spacing:.08em;padding-bottom:var(--gap-sm);border-bottom:1px solid var(--border);margin-bottom:var(--gap-lg);position:relative}.badge-collection__category-heading:before{content:"";position:absolute;left:0;bottom:-1px;width:2.5rem;height:2px;background:var(--primary);border-radius:var(--radius-full)}.badge-collection__empty{display:flex;flex-direction:column;align-items:center;gap:var(--gap-md);padding:var(--padding-2xl) var(--padding-lg);text-align:center;color:var(--muted)}.badge-collection__empty-icon{font-size:2.5rem;line-height:1;opacity:.3}.badge-collection__empty-text{font-size:var(--text-body-sm);color:var(--muted)}@media (max-width:640px){.badge-collection__filter-group-label{width:100%}.badge-collection__filter-group+.badge-collection__filter-group{padding-top:var(--gap-sm)}}.badges-page-header{margin-bottom:var(--gap-xl);padding-bottom:var(--gap-xl);border-bottom:1px solid var(--border)}.badges-page-header__eyebrow{display:block;font-size:var(--text-tiny);font-weight:var(--font-semibold);color:var(--primary);text-transform:uppercase;letter-spacing:var(--tracking-wider);margin-bottom:var(--gap-sm)}.badges-page-header__title{font-size:var(--text-h1);font-weight:var(--font-extrabold);color:var(--titles);line-height:var(--leading-tight);letter-spacing:var(--tracking-tight);margin-bottom:var(--gap-sm)}.badges-page-header__subtitle{font-size:var(--text-body);color:var(--muted);max-width:44rem;line-height:var(--leading-relaxed)}.badges-page-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--gap-sm);margin-bottom:var(--gap-xl)}@media (max-width:640px){.badges-page-stats{grid-template-columns:repeat(2,1fr)}}.badges-page-stat{position:relative;overflow:hidden;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--padding-lg);display:flex;flex-direction:column;gap:var(--gap-xs);transition:transform .15s ease,box-shadow .15s ease}.badges-page-stat:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--badge-stat-accent,var(--border));border-radius:var(--radius-md) var(--radius-md) 0 0}.badges-page-stat--obtained{--badge-stat-accent:var(--success);border-color:color-mix(in srgb,var(--success) 25%,var(--border))}.badges-page-stat--in_progress{--badge-stat-accent:var(--primary);border-color:color-mix(in srgb,var(--primary) 25%,var(--border))}.badges-page-stat--in_progress:hover,.badges-page-stat--obtained:hover{transform:translateY(-1px);box-shadow:0 4px 12px color-mix(in srgb,var(--badge-stat-accent,var(--primary)) 10%,transparent)}.badges-page-stat__icon{font-size:1.25rem;line-height:1}.badges-page-stat__value{font-size:var(--text-h3);font-weight:var(--font-extrabold);color:var(--titles);line-height:1}.badges-page-stat--obtained .badges-page-stat__value{color:var(--success)}.badges-page-stat--in_progress .badges-page-stat__value{color:var(--primary)}.badges-page-stat__label{font-size:var(--text-tiny);color:var(--muted);font-weight:var(--font-medium);letter-spacing:var(--tracking-wide)}.badges-page-explainer{background:color-mix(in srgb,var(--primary) 5%,var(--surface));border:1px solid color-mix(in srgb,var(--primary) 18%,var(--border));border-left:3px solid var(--primary);border-radius:var(--radius-md);padding:var(--padding-md) var(--padding-lg);margin-bottom:var(--gap-xl)}.badges-page-explainer__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--gap-sm)}.badges-page-explainer__list li{font-size:var(--text-body-sm);color:var(--muted);line-height:var(--leading-relaxed);padding-left:var(--padding-md);position:relative}.badges-page-explainer__list li:before{content:"→";position:absolute;left:0;color:var(--primary);font-weight:var(--font-semibold)}.badges-page-explainer__link{color:var(--primary);font-weight:var(--font-semibold);text-decoration:none}.badges-page-explainer__link:hover{text-decoration:underline}.badges-page-cta{margin-top:var(--gap-xl);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--padding-xl);display:flex;flex-direction:column;align-items:flex-start;gap:var(--gap-md)}.badges-page-cta__eyebrow{font-size:var(--text-tiny);font-weight:var(--font-semibold);color:var(--primary);text-transform:uppercase;letter-spacing:var(--tracking-widest)}.badges-page-cta__title{font-size:var(--text-h4);font-weight:var(--font-bold);color:var(--titles);line-height:var(--leading-tight)}.badges-page-cta__description{font-size:var(--text-body-sm);color:var(--muted);line-height:var(--leading-relaxed);max-width:36rem}.chapter-progress{display:flex;flex-direction:column;gap:var(--gap-xs)}.chapter-progress__item{display:flex;flex-direction:column;gap:var(--gap-2xs);padding:var(--gap-xs) 0}.chapter-progress__item-row{display:flex;align-items:center;gap:var(--gap-sm)}.chapter-progress__indicator{width:1rem;height:1rem;border-radius:var(--radius-full);border:1px solid var(--border);flex-shrink:0;display:flex;align-items:center;justify-content:center}.chapter-progress__indicator--validated{background:var(--success);border-color:var(--success);color:var(--bg);font-size:.6rem;line-height:1}.chapter-progress__indicator--in-progress{background:var(--primary);border-color:var(--primary)}.chapter-progress__indicator--pending{background:transparent;border-color:var(--border)}.chapter-progress__label{font-size:var(--text-tiny);color:var(--text);line-height:1.4;flex:1}.chapter-progress__label--validated{color:var(--muted);text-decoration:line-through;text-decoration-color:var(--success)}.chapter-progress__sub{font-size:var(--text-tiny);color:var(--muted);white-space:nowrap;margin-left:auto}.chapter-progress__bar-track{height:3px;background:color-mix(in srgb,var(--border) 60%,transparent);border-radius:var(--radius-full);overflow:hidden;margin-left:calc(1rem + var(--gap-sm))}.chapter-progress__bar-fill{height:100%;background:var(--border);border-radius:var(--radius-full);transition:width .4s cubic-bezier(.4,0,.2,1);min-width:0}.chapter-progress__bar-fill--validated{background:var(--success)}.chapter-progress__bar-fill--in-progress{background:var(--primary)}.badge-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:var(--gap-md)}.badge-grid--featured{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--gap-lg)}.badge-grid--compact{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:var(--gap-sm)}@media (max-width:768px){.badge-grid--featured{grid-template-columns:1fr;gap:var(--gap-md)}}@media (max-width:640px){.badge-grid,.badge-grid--compact{grid-template-columns:1fr 1fr}.badge-grid--compact{gap:var(--gap-xs)}}.parcours-section{display:flex;flex-direction:column;gap:var(--gap-md)}.parcours-section-label{display:flex;align-items:center;gap:var(--gap-sm);font-size:var(--text-tiny);font-weight:var(--font-semibold);color:var(--muted);text-transform:uppercase;letter-spacing:.1em}.parcours-section-label:before{content:"";display:block;width:3px;height:.875rem;background:var(--primary);border-radius:var(--radius-full);flex-shrink:0}.parcours-next-step{background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--primary);border-radius:var(--radius-lg);padding:var(--padding-lg);display:grid;grid-template-columns:1fr auto;align-items:center;gap:var(--gap-lg)}.parcours-next-step__body{display:flex;flex-direction:column;gap:var(--gap-xs);min-width:0}.parcours-next-step__eyebrow{font-size:var(--text-tiny);font-weight:var(--font-semibold);color:var(--primary);text-transform:uppercase;letter-spacing:.1em}.parcours-next-step__breadcrumb{display:flex;align-items:center;gap:var(--gap-xs);flex-wrap:wrap}.parcours-next-step__theme{font-size:var(--text-tiny);color:var(--muted)}.parcours-next-step__sep{font-size:var(--text-tiny);color:var(--border);-webkit-user-select:none;-moz-user-select:none;user-select:none}.parcours-next-step__chapter{font-size:var(--text-tiny);color:var(--muted)}.parcours-next-step__lesson-name{font-size:var(--text-h5);font-weight:var(--font-bold);color:var(--titles);line-height:var(--leading-tight);overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical}.parcours-next-step__empty{font-size:var(--text-body-sm);color:var(--muted);padding:var(--padding-md)}@media (max-width:640px){.parcours-next-step{grid-template-columns:1fr;gap:var(--gap-md)}}.parcours-livrables-placeholder{display:flex;align-items:center;gap:var(--gap-md);padding:var(--padding-lg);border:1px dashed var(--border);border-radius:var(--radius-md);background:var(--surface)}.parcours-livrables-placeholder__icon{font-size:1.5rem;line-height:1;opacity:.4;flex-shrink:0}.parcours-livrables-placeholder__text{font-size:var(--text-body-sm);color:var(--muted)}.parcours-cockpit-header{margin-bottom:var(--gap-xl)}.parcours-cockpit-title{font-size:var(--text-h1);font-weight:var(--font-extrabold);color:var(--titles);line-height:var(--leading-tight);letter-spacing:var(--tracking-tight)}.parcours-cockpit-subtitle{font-size:var(--text-body);color:var(--muted);margin-top:var(--gap-xs)}.parcours-cta{display:flex;flex-direction:column;align-items:flex-start;gap:var(--gap-md);padding:var(--padding-lg);background:color-mix(in srgb,var(--primary) 5%,var(--surface));border:1px solid color-mix(in srgb,var(--primary) 25%,var(--border));border-radius:var(--radius-lg)}.parcours-cta__eyebrow{font-size:var(--text-tiny);font-weight:var(--font-semibold);color:var(--primary);text-transform:uppercase;letter-spacing:.1em}.parcours-cta__title{font-size:var(--text-h5);font-weight:var(--font-bold);color:var(--titles);line-height:var(--leading-tight)}.parcours-cta__desc{font-size:var(--text-body-sm);color:var(--muted);max-width:32rem}.parcours-badges-empty{display:flex;align-items:center;gap:var(--gap-md);padding:var(--padding-lg);background:var(--surface);border:1px dashed var(--border);border-radius:var(--radius-md)}.parcours-badges-empty__icon{font-size:1.5rem;line-height:1;opacity:.4;flex-shrink:0}.parcours-badges-empty__text{font-size:var(--text-body-sm);color:var(--muted)}.ressources-page-header{margin-bottom:var(--gap-xl);padding-bottom:var(--gap-xl);border-bottom:1px solid var(--border)}.ressources-page-header__title{font-size:var(--text-h1);font-weight:var(--font-extrabold);color:var(--titles);line-height:var(--leading-tight);letter-spacing:var(--tracking-tight);margin-bottom:var(--gap-sm)}.ressources-page-header__subtitle{font-size:var(--text-body);color:var(--muted);max-width:44rem;line-height:var(--leading-relaxed)}.ressources-callout{background:color-mix(in srgb,var(--primary) 5%,var(--surface));border:1px solid color-mix(in srgb,var(--primary) 18%,var(--border));border-left:3px solid var(--primary);border-radius:var(--radius-md);padding:var(--padding-md) var(--padding-lg);margin-bottom:var(--gap-xl)}.ressources-callout__text{font-size:var(--text-body-sm);color:var(--muted);line-height:var(--leading-relaxed)}.ressources-section{margin-bottom:var(--gap-xl)}.ressources-section__title{font-size:var(--text-h3);font-weight:var(--font-bold);color:var(--titles);line-height:var(--leading-tight);margin-bottom:var(--gap-sm)}.ressources-section__subtitle{font-size:var(--text-body-sm);color:var(--muted);line-height:var(--leading-relaxed);margin-bottom:var(--gap-lg)}.ressources-categories{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--gap-md);margin-bottom:var(--gap-xl)}@media (max-width:640px){.ressources-categories{grid-template-columns:1fr}}.ressources-category-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--padding-lg);display:flex;flex-direction:column;gap:var(--gap-xs)}.ressources-category-card__icon{font-size:1.5rem;line-height:1;margin-bottom:var(--gap-xs)}.ressources-category-card__name{font-size:var(--text-body);font-weight:var(--font-semibold);color:var(--titles)}.ressources-category-card__status{display:inline-flex;align-items:center;gap:var(--gap-xs);font-size:var(--text-tiny);font-weight:var(--font-medium);color:var(--muted);background:color-mix(in srgb,var(--muted) 10%,var(--surface));border:1px solid color-mix(in srgb,var(--border) 60%,transparent);border-radius:var(--radius-full);padding:.125rem var(--padding-sm);width:-moz-fit-content;width:fit-content;margin-top:var(--gap-xs)}.ressources-tools-group{margin-bottom:var(--gap-lg)}.ressources-tools-group__label{font-size:var(--text-tiny);font-weight:var(--font-semibold);color:var(--primary);text-transform:uppercase;letter-spacing:var(--tracking-wider);margin-bottom:var(--gap-sm)}.ressources-tools-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gap-md)}@media (max-width:768px){.ressources-tools-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:480px){.ressources-tools-grid{grid-template-columns:1fr}}.ressources-tool-link{display:block;text-decoration:none;border-radius:var(--radius-md);transition:transform .15s ease,box-shadow .15s ease}.ressources-tool-link:hover{transform:translateY(-1px);box-shadow:0 4px 12px color-mix(in srgb,var(--primary) 8%,transparent)}.ressources-badges-preview{background:color-mix(in srgb,var(--surface) 60%,var(--bg));border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--padding-xl);margin-bottom:var(--gap-xl)}.ressources-badges-preview__label{display:inline-flex;align-items:center;gap:var(--gap-xs);font-size:var(--text-tiny);font-weight:var(--font-semibold);color:var(--muted);background:color-mix(in srgb,var(--muted) 10%,var(--surface));border:1px solid var(--border);border-radius:var(--radius-full);padding:.125rem var(--padding-sm);margin-bottom:var(--gap-md)}.ressources-badges-preview__title{font-size:var(--text-h4);font-weight:var(--font-bold);color:var(--titles);line-height:var(--leading-tight);margin-bottom:var(--gap-sm)}.ressources-badges-preview__description{font-size:var(--text-body-sm);color:var(--muted);line-height:var(--leading-relaxed);max-width:40rem}.ressources-cta{margin-top:var(--gap-xl);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--padding-xl);display:flex;flex-direction:column;align-items:flex-start;gap:var(--gap-md)}.ressources-cta__eyebrow{font-size:var(--text-tiny);font-weight:var(--font-semibold);color:var(--primary);text-transform:uppercase;letter-spacing:var(--tracking-widest)}.ressources-cta__title{font-size:var(--text-h4);font-weight:var(--font-bold);color:var(--titles);line-height:var(--leading-tight)}.ressources-cta__description{font-size:var(--text-body-sm);color:var(--muted);line-height:var(--leading-relaxed);max-width:36rem}.ressources-cta__actions{display:flex;flex-wrap:wrap;gap:var(--gap-sm)}.achievement{--achievement-glow:var(--primary);--achievement-locked:var(--muted);--achievement-size:6rem;display:inline-flex;flex-direction:column;align-items:center;gap:var(--gap-sm,.5rem);cursor:default;-webkit-user-select:none;-moz-user-select:none;user-select:none}.achievement--sm{--achievement-size:4rem}.achievement--md{--achievement-size:6rem}.achievement--lg{--achievement-size:8rem}.achievement__visual{position:relative;width:var(--achievement-size);height:var(--achievement-size);display:flex;align-items:center;justify-content:center}.achievement__base-glow{position:absolute;inset:0;border-radius:50%;background:radial-gradient(ellipse 60% 60% at 50% 55%,color-mix(in srgb,var(--achievement-glow) 32%,transparent) 0,color-mix(in srgb,var(--achievement-glow) 10%,transparent) 48%,transparent 68%);opacity:0;transition:opacity .35s ease;pointer-events:none}.achievement--rank .achievement__base-glow{border-radius:14%}.achievement--unlocked .achievement__base-glow{opacity:1}.achievement--unlocked .achievement__base-image{filter:drop-shadow(0 0 3px color-mix(in srgb,var(--achievement-glow) 45%,transparent)) drop-shadow(0 0 6px color-mix(in srgb,var(--achievement-glow) 18%,transparent))}.achievement__base{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}.achievement__base-image{width:100%;height:100%;-o-object-fit:contain;object-fit:contain;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-user-drag:none}.achievement__symbol{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:50%;height:50%;display:flex;align-items:center;justify-content:center;transition:filter .35s ease}.achievement--rank .achievement__symbol{top:48%;width:46%;height:46%}.achievement-symbol{width:100%;height:100%;overflow:visible}.achievement-symbol__accent,.achievement-symbol__body{fill:none}.achievement-symbol__fill-accent,.achievement-symbol__fill-body{fill:var(--achievement-locked);stroke:none}.achievement--locked .achievement-symbol__body{stroke:var(--achievement-locked);opacity:.55}.achievement--locked .achievement-symbol__accent{stroke:var(--achievement-locked);opacity:.35}.achievement--locked .achievement-symbol__fill-body{fill:var(--achievement-locked);opacity:.55}.achievement--locked .achievement-symbol__fill-accent{fill:var(--achievement-locked);opacity:.35}.achievement--unlocked .achievement-symbol__body{stroke:color-mix(in srgb,var(--achievement-glow) 65%,var(--muted))}.achievement--unlocked .achievement-symbol__accent{stroke:var(--achievement-glow)}.achievement--unlocked .achievement-symbol__fill-body{fill:color-mix(in srgb,var(--achievement-glow) 65%,var(--muted));opacity:1}.achievement--unlocked .achievement-symbol__fill-accent{fill:var(--achievement-glow);opacity:1}.achievement--unlocked .achievement__symbol{filter:drop-shadow(0 0 3px var(--achievement-glow)) drop-shadow(0 0 9px color-mix(in srgb,var(--achievement-glow) 50%,transparent))}.achievement__label{font-size:var(--text-tiny,.625rem);font-weight:var(--font-semibold,600);color:var(--achievement-locked);text-align:center;line-height:var(--leading-tight,1.25);max-width:calc(var(--achievement-size) * 1.25);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.achievement--unlocked .achievement__label{color:var(--achievement-glow)}@media (prefers-reduced-motion:reduce){.achievement__base-glow,.achievement__symbol{transition:none!important}}.error-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:var(--gap-xl);text-align:center}.error-page-code{font-size:6rem;font-weight:700;color:var(--primary);line-height:1;margin-bottom:var(--gap-md)}.error-page-title{font-size:2rem;font-weight:600;color:var(--foreground);margin-bottom:var(--gap-md)}.error-page-description{font-size:1rem;color:var(--muted-foreground);max-width:32rem;margin-bottom:var(--gap-xl);line-height:1.6}.error-page-actions{display:flex;gap:var(--gap-md);flex-wrap:wrap;justify-content:center}.theme-toggle{display:inline-flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;border-radius:var(--radius-md);background-color:var(--background);border:1px solid var(--border);cursor:pointer;transition:all .2s ease}.theme-toggle:hover{background-color:var(--accent);border-color:var(--primary)}.theme-toggle-icon{width:1.25rem;height:1.25rem;color:var(--foreground)}.brand-theme-selector{display:flex;gap:var(--gap-md);padding:var(--gap-md);background-color:var(--muted);border-radius:var(--radius-md)}.brand-swatch{width:2rem;height:2rem;border-radius:var(--radius-sm);border:2px solid transparent;cursor:pointer;transition:all .2s ease}.brand-swatch:hover{transform:scale(1.1)}.brand-swatch--active{border-color:var(--foreground);box-shadow:0 0 0 2px var(--background),0 0 0 4px var(--foreground)}.loading-boundary{display:flex;align-items:center;justify-content:center;min-height:20rem;padding:var(--padding-section-sm)}.loading-boundary-spinner{width:3rem;height:3rem;border:3px solid var(--muted);border-top-color:var(--primary);border-radius:var(--radius-full);animation:spin 1s linear infinite}.loading-boundary-text{margin-top:var(--gap-md);font-size:.875rem;color:var(--muted-foreground)}.prompt-editor{display:flex;flex-direction:column;gap:var(--gap-md)}.prompt-editor-toolbar{justify-content:space-between;flex-wrap:wrap}.prompt-editor-actions,.prompt-editor-toolbar{display:flex;align-items:center;gap:var(--gap-sm)}.prompt-editor-button{font-size:.75rem}.prompt-editor-icon{width:1rem;height:1rem;margin-right:var(--gap-xs)}.prompt-editor-stats{font-size:.75rem;color:var(--muted)}.prompt-editor-history,.prompt-editor-presets{max-height:15rem;overflow-y:auto}.prompt-editor-panel-title{font-size:.875rem;font-weight:500;color:var(--titles);margin:0 0 var(--gap-md)}.prompt-editor-category{margin-bottom:var(--gap-md)}.prompt-editor-category:last-child{margin-bottom:0}.prompt-editor-category-title{font-size:.75rem;font-weight:500;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin:0 0 var(--gap-sm)}.prompt-editor-history-list,.prompt-editor-preset-list{display:flex;flex-direction:column;gap:var(--gap-sm)}.prompt-editor-history-item,.prompt-editor-preset{width:100%;text-align:left;padding:var(--gap-md);background:rgba(255,255,255,.05);border:none;border-radius:var(--radius-sm);cursor:pointer;transition:all .2s ease}.prompt-editor-history-item:hover,.prompt-editor-preset:hover{background:rgba(255,255,255,.1)}.prompt-editor-history-header,.prompt-editor-preset-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--gap-sm)}.prompt-editor-preset-name{font-size:.875rem;font-weight:500;color:var(--titles);margin:0}.prompt-editor-preset:hover .prompt-editor-preset-name{color:var(--primary)}.prompt-editor-preset-tags{display:flex;gap:var(--gap-xs)}.prompt-editor-tag{font-size:.75rem;background:rgba(255,255,255,.1);color:var(--muted)}.prompt-editor-history-text,.prompt-editor-preset-text{font-size:.75rem;color:var(--muted);line-height:1.4;margin:0;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.prompt-editor-history-item:hover .prompt-editor-history-text{color:var(--primary)}.prompt-editor-history-date{font-size:.75rem;color:var(--muted)}.prompt-editor-history-badge{font-size:.75rem;background:rgba(34,197,94,.15);color:var(--success)}.prompt-editor-save-title{font-size:.875rem;font-weight:500;color:var(--titles);margin:0 0 var(--gap-md)}.prompt-editor-save-form{display:flex;gap:var(--gap-sm)}.prompt-editor-save-input{flex:1;padding:var(--gap-sm) var(--gap-md);background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--titles);font-size:.875rem}.prompt-editor-save-input::-moz-placeholder{color:var(--muted)}.prompt-editor-save-input::placeholder{color:var(--muted)}.prompt-editor-save-input:focus{outline:none;border-color:var(--primary)}.prompt-editor-main{position:relative}.prompt-editor-textarea{min-height:7.5rem;resize:none}.prompt-editor-generate{position:absolute;bottom:var(--gap-md);right:var(--gap-md)}.prompt-editor-generate-button{box-shadow:var(--shadow-4)}.prompt-editor-spinner{width:1rem;height:1rem;margin-right:var(--gap-sm);animation:spin 1s linear infinite}.prompt-editor-spinner-track{opacity:.25}.prompt-editor-spinner-fill{opacity:.75}.model-selector{display:flex;flex-direction:column;gap:var(--gap-md)}.model-card{position:relative;cursor:pointer}.model-card:hover{border-color:rgba(255,255,255,.1)}.model-card--selected{border-color:var(--primary);box-shadow:0 0 0 2px color-mix(in srgb,var(--primary) 20%,transparent)}.model-card--disabled{opacity:.5;cursor:not-allowed}.model-card-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--gap-md)}.model-card-info{flex:1}.model-card-title-row{display:flex;align-items:center;gap:var(--gap-sm);margin-bottom:var(--gap-xs);flex-wrap:wrap}.model-card-name{font-size:.875rem;font-weight:500;color:var(--titles);margin:0}.model-card-badge{font-size:.75rem}.model-type--audio{background:rgba(59,130,246,.15);color:var(--info)}.model-type--vocal{background:var(--primary-muted);color:var(--primary)}.model-type--instrumental{background:rgba(34,197,94,.15);color:var(--success)}.model-type--mastering{background:rgba(245,158,11,.15);color:var(--warning)}.model-quality--standard{background:rgba(107,114,128,.15);color:var(--muted)}.model-quality--premium{background:rgba(245,158,11,.15);color:var(--warning)}.model-quality--pro{background:rgba(239,68,68,.15);color:var(--destructive)}.model-badge--beta{background:rgba(59,130,246,.15);color:var(--info)}.model-badge--unavailable{background:rgba(239,68,68,.15);color:var(--destructive)}.model-card-description{margin:0 0 var(--gap-sm);line-height:1.4}.model-card-description,.model-card-meta{font-size:.75rem;color:var(--muted)}.model-card-pricing{text-align:right;flex-shrink:0}.model-card-price{font-size:.875rem;font-weight:500;color:var(--titles)}.model-card-unit{font-size:.75rem;color:var(--muted)}.model-card-capabilities{margin-bottom:var(--gap-md)}.model-card-capabilities-title{font-size:.75rem;font-weight:500;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin:0 0 var(--gap-sm)}.model-card-capabilities-list{display:flex;flex-wrap:wrap;gap:var(--gap-xs)}.model-capability{padding:var(--gap-xs) var(--gap-sm);font-size:.75rem;background:rgba(255,255,255,.05);color:var(--muted);border-radius:var(--radius-sm)}.model-card-selected{position:absolute;top:var(--gap-md);right:var(--gap-md)}.model-card-checkmark{width:1.25rem;height:1.25rem;background:var(--primary);border-radius:50%;display:flex;align-items:center;justify-content:center}.model-card-check-icon{width:.75rem;height:.75rem;color:white}.model-selector-empty{text-align:center;padding:var(--gap-xl) var(--gap-md)}.model-selector-empty-text{font-size:.875rem;color:var(--muted)}.asset-tile{position:relative;cursor:pointer}.asset-tile--selected{border-color:var(--primary);box-shadow:0 0 0 2px color-mix(in srgb,var(--primary) 20%,transparent)}.asset-tile--clickable:hover{border-color:rgba(255,255,255,.1)}.asset-tile-media{position:relative;margin-bottom:var(--gap-md)}.asset-tile-image{width:100%;-o-object-fit:cover;object-fit:cover}.asset-tile-image,.asset-tile-placeholder{aspect-ratio:16/9;border-radius:var(--radius-sm);background:rgba(255,255,255,.05)}.asset-tile-placeholder{display:flex;align-items:center;justify-content:center}.asset-tile-icon{width:1.25rem;height:1.25rem;font-size:1.5rem}.asset-tile-icon--audio{color:var(--info)}.asset-tile-icon--video{color:var(--primary)}.asset-tile-icon--image{color:var(--success)}.asset-tile-icon--document{color:var(--warning)}.asset-tile-icon--preset{color:var(--destructive)}.asset-tile-status{position:absolute;top:var(--gap-sm);right:var(--gap-sm);font-size:.75rem}.asset-status--processing{background:rgba(59,130,246,.15);color:var(--info)}.asset-status--ready{background:rgba(34,197,94,.15);color:var(--success)}.asset-status--error{background:rgba(239,68,68,.15);color:var(--destructive)}.asset-status--draft{background:rgba(107,114,128,.15);color:var(--muted)}.asset-tile-play{position:absolute;inset:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s ease;border-radius:var(--radius-sm);border:none;cursor:pointer}.asset-tile:hover .asset-tile-play{opacity:1}.asset-tile-play-icon{width:2rem;height:2rem;color:white;background:rgba(255,255,255,.2);border-radius:50%;padding:var(--gap-sm)}.asset-tile-content{display:flex;flex-direction:column;gap:var(--gap-sm)}.asset-tile-header{display:flex;align-items:flex-start;justify-content:space-between}.asset-tile-name{font-size:.875rem;font-weight:500;color:var(--titles);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding-right:var(--gap-sm);margin:0}.asset-tile-type{font-size:.75rem;flex-shrink:0}.asset-tile-meta{display:flex;align-items:center;justify-content:space-between;font-size:.75rem}.asset-tile-date,.asset-tile-details,.asset-tile-meta{color:var(--muted)}.asset-tile-actions{position:absolute;top:var(--gap-sm);left:var(--gap-sm);opacity:0;transition:opacity .2s ease;display:flex;gap:var(--gap-xs)}.asset-tile:hover .asset-tile-actions{opacity:1}.asset-tile-action{width:2rem;height:2rem;background:rgba(0,0,0,.5);color:white;border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background-color .2s ease}.asset-tile-action:hover{background:rgba(0,0,0,.7)}.asset-tile-action--delete:hover{background:rgba(239,68,68,.7)}.asset-tile-action-icon{width:1rem;height:1rem}.login-form{width:100%;max-width:28rem;display:flex;flex-direction:column;gap:var(--gap-md)}.login-form-header{text-align:center;margin-bottom:var(--gap-sm)}.login-form-title{font-size:var(--text-h4);font-weight:var(--font-semibold);color:var(--foreground);margin-bottom:var(--gap-xs)}.login-form-subtitle{font-size:var(--text-small);color:var(--muted)}.login-form-error{display:flex;align-items:center;gap:var(--gap-sm);padding:var(--gap-md);background-color:var(--error);color:var(--error-foreground);border-radius:var(--radius-md);font-size:var(--text-small)}.login-form-error .icon{width:1.25rem;height:1.25rem;flex-shrink:0}.login-form-social{display:flex;flex-direction:column;gap:var(--gap-sm)}.login-form-social-btn{display:flex;align-items:center;justify-content:center;gap:var(--gap-sm);padding:var(--gap-md);background-color:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--foreground);font-size:var(--text-small);font-weight:var(--font-medium);cursor:pointer;transition:var(--transition-colors)}.login-form-social-btn:hover:not(:disabled){background-color:var(--muted);border-color:var(--muted-foreground)}.login-form-social-btn:disabled{opacity:.5;cursor:not-allowed}.login-form-social-btn .icon{width:1.25rem;height:1.25rem}.login-form-divider{position:relative;text-align:center;margin:var(--gap-md) 0}.login-form-divider:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background-color:var(--border)}.login-form-divider span{position:relative;display:inline-block;padding:0 var(--gap-md);background-color:var(--bg);color:var(--muted);font-size:var(--text-tiny);text-transform:uppercase;letter-spacing:.05em}.login-form-fields{display:flex;flex-direction:column;gap:var(--gap-md)}.login-form-field{display:flex;flex-direction:column;gap:var(--gap-xs)}.login-form-label{font-size:var(--text-small);font-weight:var(--font-medium);color:var(--foreground)}.login-form-label-row{display:flex;justify-content:space-between;align-items:center}.login-form-password{position:relative}.login-form-password input{padding-right:5rem}.login-form-password-toggle{position:absolute;right:var(--gap-sm);top:50%;transform:translateY(-50%);padding:var(--gap-xs);background:none;border:none;color:var(--muted);cursor:pointer;transition:var(--transition-colors);border-radius:var(--radius-sm);font-size:var(--text-small)}.login-form-password-toggle:hover:not(:disabled){color:var(--foreground);background-color:var(--muted)}.login-form-password-toggle:disabled{opacity:.5;cursor:not-allowed}.login-form-password-toggle .icon{width:1.25rem;height:1.25rem}.login-form-checkbox,.login-form-remember{display:flex;align-items:center}.login-form-checkbox{gap:var(--gap-sm);font-size:var(--text-small);color:var(--foreground);cursor:pointer}.login-form-checkbox input[type=checkbox]{width:1rem;height:1rem;cursor:pointer}.login-form-submit{width:100%;display:flex;align-items:center;justify-content:center;gap:var(--gap-sm)}.login-form-submit .icon{width:1.25rem;height:1.25rem}.login-form-footer{text-align:center;font-size:var(--text-small);color:var(--muted)}.login-form-footer-text{margin-right:var(--gap-xs)}.login-form-link{background:none;border:none;color:var(--primary);font-size:var(--text-small);font-weight:var(--font-medium);cursor:pointer;transition:var(--transition-colors);text-decoration:none}.login-form-link:hover:not(:disabled){text-decoration:underline}.login-form-link:disabled{opacity:.5;cursor:not-allowed}.register-form{width:100%;max-width:28rem;display:flex;flex-direction:column;gap:var(--gap-md)}.register-form-header{text-align:center;margin-bottom:var(--gap-sm)}.register-form-title{font-size:var(--text-h4);font-weight:var(--font-semibold);color:var(--foreground);margin-bottom:var(--gap-xs)}.register-form-subtitle{font-size:var(--text-small);color:var(--muted)}.register-form-error{display:flex;align-items:center;gap:var(--gap-sm);padding:var(--gap-md);background-color:var(--error);color:var(--error-foreground);border-radius:var(--radius-md);font-size:var(--text-small)}.register-form-error .icon{width:1.25rem;height:1.25rem;flex-shrink:0}.register-form-social{display:flex;flex-direction:column;gap:var(--gap-sm)}.register-form-social-btn{display:flex;align-items:center;justify-content:center;gap:var(--gap-sm);padding:var(--gap-md);background-color:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--foreground);font-size:var(--text-small);font-weight:var(--font-medium);cursor:pointer;transition:var(--transition-colors)}.register-form-social-btn:hover:not(:disabled){background-color:var(--muted);border-color:var(--muted-foreground)}.register-form-social-btn:disabled{opacity:.5;cursor:not-allowed}.register-form-social-btn .icon{width:1.25rem;height:1.25rem}.register-form-divider{position:relative;text-align:center;margin:var(--gap-md) 0}.register-form-divider:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background-color:var(--border)}.register-form-divider span{position:relative;display:inline-block;padding:0 var(--gap-md);background-color:var(--bg);color:var(--muted);font-size:var(--text-tiny);text-transform:uppercase;letter-spacing:.05em}.register-form-fields{display:flex;flex-direction:column;gap:var(--gap-md)}.register-form-field{display:flex;flex-direction:column;gap:var(--gap-xs)}.register-form-label{font-size:var(--text-small);font-weight:var(--font-medium);color:var(--foreground)}.register-form-field-error{font-size:var(--text-tiny);color:var(--error)}.register-form-password{position:relative}.register-form-password input{padding-right:5rem}.register-form-password-toggle{position:absolute;right:var(--gap-sm);top:50%;transform:translateY(-50%);padding:var(--gap-xs);background:none;border:none;color:var(--muted);cursor:pointer;transition:var(--transition-colors);border-radius:var(--radius-sm);font-size:var(--text-small)}.register-form-password-toggle:hover:not(:disabled){color:var(--foreground);background-color:var(--muted)}.register-form-password-toggle:disabled{opacity:.5;cursor:not-allowed}.register-form-password-toggle .icon{width:1.25rem;height:1.25rem}.register-form-password-strength{display:flex;align-items:center;gap:var(--gap-sm);margin-top:var(--gap-xs)}.register-form-password-strength-bar{flex:1;height:.25rem;background-color:var(--muted);border-radius:var(--radius-full);overflow:hidden}.register-form-password-strength-fill{height:100%;transition:width .3s ease,background-color .3s ease;border-radius:var(--radius-full)}.register-form-password-strength-fill--weak{background-color:var(--error)}.register-form-password-strength-fill--medium{background-color:var(--warning)}.register-form-password-strength-fill--strong{background-color:var(--success)}.register-form-password-strength-text{font-size:var(--text-tiny);font-weight:var(--font-medium);color:var(--muted);min-width:3rem}.register-form-checkbox,.register-form-terms{display:flex;align-items:flex-start}.register-form-checkbox{gap:var(--gap-sm);font-size:var(--text-tiny);color:var(--muted);cursor:pointer;line-height:1.5}.register-form-checkbox input[type=checkbox]{width:1rem;height:1rem;margin-top:.125rem;cursor:pointer;flex-shrink:0}.register-form-submit{width:100%;display:flex;align-items:center;justify-content:center;gap:var(--gap-sm)}.register-form-submit .icon{width:1.25rem;height:1.25rem}.register-form-footer{text-align:center;font-size:var(--text-small);color:var(--muted)}.register-form-footer-text{margin-right:var(--gap-xs)}.register-form-link{background:none;border:none;color:var(--primary);font-size:inherit;font-weight:var(--font-medium);cursor:pointer;transition:var(--transition-colors);text-decoration:none}.register-form-link:hover:not(:disabled){text-decoration:underline}.register-form-link:disabled{opacity:.5;cursor:not-allowed}.otp-input{display:flex;gap:var(--gap-sm);justify-content:center}.otp-input-digit{width:3rem;height:3.5rem;font-size:var(--text-h4);font-weight:var(--font-semibold);text-align:center;background-color:var(--surface);border:2px solid var(--border);border-radius:var(--radius-md);color:var(--foreground);transition:var(--transition-all);outline:none}.otp-input-digit:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-muted)}.otp-input-digit:disabled{opacity:.5;cursor:not-allowed;background-color:var(--muted)}.otp-input-digit--filled{border-color:var(--primary);background-color:var(--primary-muted)}.otp-input-digit--error{border-color:var(--error);background-color:var(--error-muted)}.otp-input-digit--error:focus{box-shadow:0 0 0 3px var(--error-muted)}@media (max-width:640px){.otp-input-digit{width:2.5rem;height:3rem;font-size:var(--text-h5)}.otp-input{gap:var(--gap-xs)}}@keyframes otp-fill{0%{transform:scale(.95)}50%{transform:scale(1.05)}to{transform:scale(1)}}.otp-input-digit--filled{animation:otp-fill .2s ease}.password-strength{display:flex;flex-direction:column;gap:var(--gap-sm);margin-top:var(--gap-xs)}.password-strength-indicator{display:flex;align-items:center;gap:var(--gap-md)}.password-strength-bars{flex:1;display:flex;gap:var(--gap-xs);height:.5rem;background:var(--bg);border-radius:var(--radius-full);padding:.125rem;overflow:hidden}.password-strength-bar{flex:1;background-color:transparent;border-radius:var(--radius-full);transition:all .3s cubic-bezier(.4,0,.2,1);transform-origin:left}.password-strength-bar--weak{background-color:var(--error);box-shadow:0 0 6px color-mix(in srgb,var(--error) 40%,transparent)}.password-strength-bar--medium{background-color:var(--warning);box-shadow:0 0 6px color-mix(in srgb,var(--warning) 40%,transparent)}.password-strength-bar--strong{background-color:var(--success);box-shadow:0 0 6px color-mix(in srgb,var(--success) 40%,transparent)}.password-strength-bar--very-strong{background:linear-gradient(90deg,var(--success),color-mix(in srgb,var(--success) 80%,white));box-shadow:0 0 10px color-mix(in srgb,var(--success) 50%,transparent)}.password-strength-label{font-size:var(--text-tiny);font-weight:var(--font-bold);min-width:5rem;text-align:right;text-transform:uppercase;letter-spacing:var(--tracking-wide);transition:color .3s ease}.password-strength-label--weak{color:var(--error)}.password-strength-label--medium{color:var(--warning)}.password-strength-label--strong{color:var(--success)}.password-strength-label--very-strong{color:var(--success);text-shadow:0 0 8px color-mix(in srgb,var(--success) 30%,transparent)}.password-strength-requirements{padding:var(--gap-md);background:linear-gradient(135deg,var(--surface) 0,color-mix(in srgb,var(--surface) 95%,var(--primary)) 100%);border:1px solid color-mix(in srgb,var(--border) 80%,var(--primary));border-radius:var(--radius-md);backdrop-filter:blur(10px)}.password-strength-requirements-title{font-size:var(--text-small);font-weight:var(--font-bold);color:var(--titles);margin-bottom:var(--gap-md);letter-spacing:var(--tracking-wide)}.password-strength-requirements-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--gap-sm)}.password-strength-requirement{display:flex;align-items:center;gap:var(--gap-sm);font-size:var(--text-small);color:var(--muted);transition:all .3s cubic-bezier(.4,0,.2,1);padding:var(--gap-xs) 0}.password-strength-requirement .icon{width:1.125rem;height:1.125rem;flex-shrink:0;opacity:.5;transition:all .3s ease}.password-strength-requirement--met{color:var(--success);font-weight:var(--font-medium)}.password-strength-requirement--met .icon{color:var(--success);opacity:1;transform:scale(1.1)}@keyframes strength-pulse{0%,to{opacity:1}50%{opacity:.7}}.password-strength-bar--very-strong{animation:strength-pulse 2s ease-in-out infinite}.two-factor-auth{width:100%;max-width:28rem;display:flex;flex-direction:column;gap:var(--gap-lg)}.two-factor-auth-header{text-align:center}.two-factor-auth-icon{display:inline-flex;align-items:center;justify-content:center;width:4rem;height:4rem;margin-bottom:var(--gap-md);background-color:var(--primary-muted);border-radius:var(--radius-full);color:var(--primary)}.two-factor-auth-icon .icon{width:2rem;height:2rem}.two-factor-auth-title{font-size:var(--text-h4);font-weight:var(--font-semibold);color:var(--foreground);margin-bottom:var(--gap-xs)}.two-factor-auth-description{font-size:var(--text-small);color:var(--muted)}.two-factor-auth-error{display:flex;align-items:center;gap:var(--gap-sm);padding:var(--gap-md);background-color:var(--error);color:var(--error-foreground);border-radius:var(--radius-md);font-size:var(--text-small)}.two-factor-auth-error .icon{width:1.25rem;height:1.25rem;flex-shrink:0}.two-factor-auth-input{display:flex;justify-content:center;padding:var(--gap-md) 0}.two-factor-auth-resend{text-align:center}.two-factor-auth-resend-timer{font-size:var(--text-small);color:var(--muted)}.two-factor-auth-resend-btn{background:none;border:none;color:var(--primary);font-size:var(--text-small);font-weight:var(--font-medium);cursor:pointer;transition:var(--transition-colors);text-decoration:none}.two-factor-auth-resend-btn:hover:not(:disabled){text-decoration:underline}.two-factor-auth-resend-btn:disabled{opacity:.5;cursor:not-allowed}.two-factor-auth-methods{padding-top:var(--gap-md);border-top:1px solid var(--border)}.two-factor-auth-methods-title{font-size:var(--text-tiny);font-weight:var(--font-medium);color:var(--muted);text-align:center;margin-bottom:var(--gap-sm)}.two-factor-auth-methods-list{display:flex;gap:var(--gap-sm);justify-content:center}.two-factor-auth-method-btn{display:flex;align-items:center;gap:var(--gap-xs);padding:var(--gap-sm) var(--gap-md);background-color:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--foreground);font-size:var(--text-tiny);font-weight:var(--font-medium);cursor:pointer;transition:var(--transition-colors)}.two-factor-auth-method-btn:hover:not(:disabled){background-color:var(--muted);border-color:var(--primary)}.two-factor-auth-method-btn:disabled{opacity:.5;cursor:not-allowed}.two-factor-auth-method-btn .icon{width:1rem;height:1rem}.two-factor-auth-loading{display:flex;align-items:center;justify-content:center;gap:var(--gap-sm);padding:var(--gap-md);color:var(--muted);font-size:var(--text-small)}.two-factor-auth-loading .icon{width:1.25rem;height:1.25rem}.animate-spin{animation:spin 1s linear infinite}.auth-card-header{text-align:center;margin-bottom:var(--gap-xl)}.auth-card-header-logo{display:flex;justify-content:center;align-items:center;margin-bottom:var(--gap-md)}.auth-card-header-heading{margin-bottom:var(--gap-xs);font-size:var(--text-h4);font-weight:var(--font-semibold);color:var(--text)}.auth-card-header-subtitle{font-size:var(--text-body);color:var(--muted)}.cookie-banner{position:fixed;bottom:0;left:0;right:0;background:var(--surface);border-top:1px solid var(--border);box-shadow:0 -4px 12px rgba(0,0,0,.1);z-index:9999;padding:var(--space-24);animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.cookie-banner-content{max-width:1200px;margin:0 auto}.cookie-banner-text{margin-bottom:var(--space-16)}.cookie-banner-title{font-size:1.25rem;font-weight:var(--font-semibold);color:var(--text);margin:0 0 var(--space-8)}.cookie-banner-description{font-size:.875rem;color:var(--muted);margin:0;line-height:1.5}.cookie-banner-link{background:none;border:none;color:var(--primary);text-decoration:underline;cursor:pointer;font-size:.875rem;margin-left:var(--space-4);padding:0}.cookie-banner-link:hover{text-decoration:none}.cookie-preferences{display:grid;gap:var(--space-12);margin:var(--space-16) 0;padding:var(--space-16);background:var(--bg);border-radius:var(--radius-md)}.cookie-preference-item,.cookie-preference-label{display:flex;align-items:flex-start}.cookie-preference-label{gap:var(--space-12);cursor:pointer;width:100%}.cookie-preference-checkbox{margin-top:2px;cursor:pointer}.cookie-preference-checkbox:disabled{cursor:not-allowed;opacity:.5}.cookie-preference-description{font-size:.8125rem;color:var(--muted);margin:var(--space-4) 0 0}.cookie-banner-actions{display:flex;gap:var(--space-12);flex-wrap:wrap}.cookie-btn{padding:var(--space-12) var(--space-24);border-radius:var(--radius-md);font-size:.875rem;font-weight:var(--font-medium);cursor:pointer;transition:var(--transition-all);border:none}.cookie-btn-primary{background:var(--primary);color:var(--bg)}.cookie-btn-primary:hover{opacity:.9}.cookie-btn-secondary{background:var(--surface);color:var(--text);border:1px solid var(--border)}.cookie-btn-secondary:hover{background:var(--bg)}.cookie-btn-ghost{background:transparent;color:var(--muted)}.cookie-btn-ghost:hover{color:var(--text)}@media (max-width:768px){.cookie-banner{padding:var(--space-16)}.cookie-banner-actions{flex-direction:column}.cookie-btn{width:100%}}.audio-tool-results{display:flex;flex-direction:column;gap:var(--gap-xl);padding:var(--padding-section-md);background-color:var(--surface);border-radius:var(--radius-lg)}@media (max-width:768px){.audio-tool-results{padding:var(--padding-section-sm)}}.audio-tool-metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--gap-md)}.audio-tool-metrics--2x2{grid-template-columns:repeat(2,1fr)}@media (max-width:768px){.audio-tool-metrics,.audio-tool-metrics--2x2{grid-template-columns:1fr}}.audio-tool-actions{display:flex;gap:var(--gap-md);justify-content:center;flex-wrap:wrap}.audio-tool-actions .btn{flex:1;min-width:12rem}@media (max-width:768px){.audio-tool-actions{flex-direction:column}.audio-tool-actions .btn{width:100%}}.audio-drop-zone{border:2px dashed var(--border);border-radius:var(--radius-lg);padding:var(--padding-section-md);text-align:center;cursor:pointer;transition:all var(--transition-base);background-color:var(--surface);position:relative}.audio-drop-zone:hover{border-color:var(--primary);background-color:var(--surface)}.audio-drop-zone-input{position:absolute;inset:0;opacity:0;cursor:pointer}.audio-drop-zone-icon{display:inline-flex;align-items:center;justify-content:center;width:4rem;height:4rem;margin-bottom:var(--gap-md);color:var(--primary)}.audio-drop-zone-title{font-size:var(--text-h4);font-weight:var(--font-semibold);color:var(--titles);margin-bottom:var(--gap-sm)}.audio-drop-zone-subtitle{font-size:var(--text-body);color:var(--text);margin-bottom:var(--gap-xs)}.audio-drop-zone-formats{font-size:var(--text-sm);color:var(--muted)}.audio-analyzing{text-align:center;padding:var(--padding-section-md)}.audio-analyzing-spinner{width:3rem;height:3rem;margin:0 auto var(--gap-md);border:3px solid var(--border);border-top-color:var(--primary);border-radius:var(--radius-full);animation:spin 1s linear infinite}.audio-analyzing-title{font-size:var(--text-h4);font-weight:var(--font-semibold);color:var(--titles);margin-bottom:var(--gap-sm)}.audio-analyzing-subtitle{font-size:var(--text-body);color:var(--text);margin-bottom:var(--gap-md);word-break:break-word}.audio-analyzing-progress{width:100%;max-width:24rem;height:.5rem;background-color:var(--border);border-radius:var(--radius-full);overflow:hidden;margin:0 auto var(--gap-sm)}.audio-analyzing-progress-bar{height:100%;background-color:var(--primary);transition:width var(--transition-base)}.audio-analyzing-percent{font-size:var(--text-sm);color:var(--muted)}.metric-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--gap-lg);text-align:center;display:flex;flex-direction:column;gap:var(--gap-xs)}.metric-card-label{font-size:var(--text-sm);color:var(--muted);font-weight:var(--font-medium);text-transform:uppercase;letter-spacing:.05em}.metric-card-value{font-size:var(--text-h3);font-weight:var(--font-bold);color:var(--primary);line-height:1}.metric-card-unit{font-size:var(--text-body);color:var(--muted);font-weight:var(--font-medium)}.key-bpm-finder-tool{width:100%;max-width:48rem;margin:0 auto}.key-bpm-finder-upload{border:2px dashed var(--border);border-radius:var(--radius-lg);padding:var(--padding-section-md);text-align:center;cursor:pointer;transition:all var(--transition-base);background-color:var(--surface)}.key-bpm-finder-upload:hover{border-color:var(--primary);background-color:var(--surface)}.key-bpm-finder-upload-icon{display:inline-flex;align-items:center;justify-content:center;width:4rem;height:4rem;margin-bottom:var(--gap-md);color:var(--primary)}.key-bpm-finder-upload-title{font-size:var(--text-h4);font-weight:var(--font-semibold);color:var(--titles);margin-bottom:var(--gap-sm)}.key-bpm-finder-upload-subtitle{font-size:var(--text-body);color:var(--text);margin-bottom:var(--gap-xs)}.key-bpm-finder-upload-formats{font-size:var(--text-sm);color:var(--muted)}.key-bpm-finder-analyzing{text-align:center;padding:var(--padding-section-md)}.key-bpm-finder-spinner{width:3rem;height:3rem;margin:0 auto var(--gap-md);border:3px solid var(--border);border-top-color:var(--primary);border-radius:var(--radius-full);animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.key-bpm-finder-analyzing-title{font-size:var(--text-h4);font-weight:var(--font-semibold);color:var(--titles);margin-bottom:var(--gap-sm)}.key-bpm-finder-analyzing-subtitle{font-size:var(--text-body);color:var(--text);margin-bottom:var(--gap-md);word-break:break-word}.key-bpm-finder-progress{width:100%;height:.5rem;background-color:var(--border);border-radius:var(--radius-full);overflow:hidden;margin-bottom:var(--gap-sm)}.key-bpm-finder-progress-bar{height:100%;background-color:var(--primary);transition:width var(--transition-base)}.key-bpm-finder-analyzing-stage{font-size:var(--text-sm);color:var(--muted)}.key-bpm-finder-results{padding:var(--padding-section-md);background-color:var(--surface);border-radius:var(--radius-lg)}.key-bpm-finder-results-header{text-align:center;margin-bottom:var(--gap-xl)}.key-bpm-finder-results-title{font-size:var(--text-h4);font-weight:var(--font-semibold);color:var(--titles);margin-bottom:var(--gap-sm)}.key-bpm-finder-results-file{font-size:var(--text-body);color:var(--text);word-break:break-word}.key-bpm-finder-results-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--gap-md);margin-bottom:var(--gap-xl)}@media (min-width:640px){.key-bpm-finder-results-grid{grid-template-columns:repeat(4,1fr)}}.key-bpm-finder-result-card{text-align:center;padding:var(--gap-lg);background-color:var(--bg);border:1px solid var(--border);border-radius:var(--radius-md)}.key-bpm-finder-result-label{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--gap-xs)}.key-bpm-finder-result-value{font-size:var(--text-h3);font-weight:var(--font-bold);color:var(--primary)}.key-bpm-finder-results-actions{display:flex;gap:var(--gap-md);justify-content:center;flex-wrap:wrap}.key-bpm-finder-results-actions .btn{flex:1;min-width:12rem}@media (max-width:640px){.key-bpm-finder-results-actions{flex-direction:column}.key-bpm-finder-results-actions .btn{width:100%}}