@import url('https://fonts.googleapis.com/css2?family=EB+Garamond:ital,wght@0,400;0,500;1,400&family=DM+Mono:wght@300;400&family=DM+Sans:wght@300;400;500&display=swap');
:root{--noir:#080808;--noir-2:#0f0f0f;--surface:#141414;--surface-2:#1c1c1c;--bordure:#252525;--bordure-2:#303030;--ivoire:#ede6d8;--ivoire-2:#d4ccbc;--texte:#b8b0a0;--texte-doux:#7a7268;--texte-muted:#3e3a34;--ambre:#c88218;--ambre-doux:#a86c12;--ambre-pale:rgba(200,130,24,0.18);--font-titre:'EB Garamond',Georgia,serif;--font-mono:'DM Mono','Courier New',monospace;--font-corps:'DM Sans',sans-serif;--radius:2px;--gap:2rem;}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{font-size:16px;scroll-behavior:smooth;}
body{background:var(--noir);color:var(--texte);font-family:var(--font-corps);font-weight:300;line-height:1.8;min-height:100vh;}
a{color:inherit;text-decoration:none;transition:color 0.3s ease;}
img{max-width:100%;display:block;}
.container{max-width:1140px;margin:0 auto;padding:0 2.5rem;}
.site-header{position:sticky;top:0;z-index:100;background:rgba(8,8,8,0.96);border-bottom:1px solid var(--bordure);}
.site-header .container{display:flex;align-items:center;justify-content:space-between;height:60px;gap:2rem;}
.logo{font-family:var(--font-titre);font-size:1.05rem;font-weight:400;letter-spacing:0.22em;color:var(--ivoire);text-transform:uppercase;}
.site-header nav{display:flex;gap:2.5rem;align-items:center;}
.site-header nav a{font-family:var(--font-mono);font-size:0.62rem;font-weight:300;letter-spacing:0.22em;text-transform:uppercase;color:var(--texte-doux);transition:color 0.3s ease;}
.site-header nav a:hover{color:var(--texte);}
.header-actions{display:flex;align-items:center;gap:1.5rem;}
.header-actions a{font-family:var(--font-mono);font-size:0.62rem;letter-spacing:0.18em;text-transform:uppercase;color:var(--texte-doux);}
.header-actions a:hover{color:var(--texte);}
.btn-primary{display:inline-block;font-family:var(--font-mono);font-size:0.60rem;font-weight:400;letter-spacing:0.20em;text-transform:uppercase;color:var(--noir)!important;background:var(--ambre);padding:0.65rem 1.6rem;border-radius:var(--radius);transition:background 0.3s;border:none;cursor:pointer;}
.btn-primary:hover{background:var(--ambre-doux);}
.btn-primary.btn-large{font-size:0.65rem;padding:0.8rem 2rem;}
.btn-secondary{display:inline-block;font-family:var(--font-mono);font-size:0.60rem;letter-spacing:0.18em;text-transform:uppercase;color:var(--ambre)!important;background:transparent;padding:0.6rem 1.2rem;border:1px solid rgba(200,130,24,0.35);border-radius:var(--radius);transition:border-color 0.3s,color 0.3s;}
.btn-secondary:hover{border-color:var(--ambre);}
.btn-outline{display:inline-block;font-family:var(--font-mono);font-size:0.60rem;letter-spacing:0.18em;text-transform:uppercase;color:var(--texte-doux)!important;background:transparent;padding:0.6rem 1.2rem;border:1px solid var(--bordure-2);border-radius:var(--radius);transition:border-color 0.3s,color 0.3s;}
.btn-outline:hover{border-color:var(--texte-muted);color:var(--texte)!important;}
.hero{padding:8rem 0 7rem;position:relative;}
.hero-label{display:inline-block;font-family:var(--font-mono);font-size:0.58rem;letter-spacing:0.28em;text-transform:uppercase;color:var(--ambre);opacity:0.7;margin-bottom:2rem;}
.hero h1{font-family:var(--font-titre);font-size:clamp(2rem,4vw,3.2rem);font-weight:400;line-height:1.2;letter-spacing:0.04em;color:var(--ivoire);margin-bottom:1.5rem;max-width:600px;}
.hero h1 em{font-style:italic;color:var(--ivoire-2);}
.hero p{font-size:0.92rem;color:var(--texte-doux);max-width:440px;margin-bottom:3rem;line-height:1.9;letter-spacing:0.02em;}
.hero-actions{display:flex;gap:1.2rem;align-items:center;}
section{padding:5rem 0;}
.section-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:3rem;padding-bottom:1.2rem;border-bottom:1px solid var(--bordure);}
.section-header h2{font-family:var(--font-titre);font-size:1.5rem;font-weight:400;letter-spacing:0.06em;color:var(--ivoire);}
.section-label{font-family:var(--font-mono);font-size:0.58rem;letter-spacing:0.24em;text-transform:uppercase;color:var(--ambre);opacity:0.65;margin-bottom:0.6rem;display:block;}
.samples-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1px;background:var(--bordure);}
.sample-card{background:var(--noir);padding:1.5rem;transition:background 0.3s ease;cursor:pointer;}
.sample-card:hover{background:var(--surface);}
.sample-cover{aspect-ratio:1;background:var(--surface);overflow:hidden;position:relative;margin-bottom:1.2rem;}
.sample-cover img{width:100%;height:100%;object-fit:cover;transition:transform 0.6s ease;filter:grayscale(20%);}
.sample-card:hover .sample-cover img{transform:scale(1.03);filter:grayscale(0%);}
.cover-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--surface-2);color:var(--texte-muted);font-family:var(--font-mono);font-size:0.58rem;letter-spacing:0.2em;text-transform:uppercase;}
.play-btn{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(8,8,8,0.55);opacity:0;transition:opacity 0.3s ease;color:var(--ivoire);font-size:1.4rem;}
.sample-card:hover .play-btn{opacity:1;}
.genre-badge{display:inline-block;font-family:var(--font-mono);font-size:0.55rem;letter-spacing:0.18em;text-transform:uppercase;color:var(--ambre);opacity:0.65;margin-bottom:0.4rem;}
.sample-info h3{font-family:var(--font-titre);font-size:1rem;font-weight:400;color:var(--ivoire-2);margin-bottom:0.4rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.sample-meta{display:flex;gap:1rem;font-family:var(--font-mono);font-size:0.60rem;color:var(--texte-muted);letter-spacing:0.1em;margin-bottom:1rem;}
.sample-footer{display:flex;align-items:center;justify-content:space-between;padding-top:1rem;border-top:1px solid var(--bordure);}
.price{font-family:var(--font-mono);font-size:0.78rem;font-weight:400;color:var(--ivoire);letter-spacing:0.08em;}
.empty-state{text-align:center;padding:6rem 2rem;color:var(--texte-muted);font-family:var(--font-mono);font-size:0.62rem;letter-spacing:0.18em;text-transform:uppercase;border:1px solid var(--bordure);}
.auth-page{min-height:calc(100vh - 60px);display:flex;align-items:center;justify-content:center;padding:3rem 1rem;}
.auth-card{width:100%;max-width:400px;background:var(--surface);border:1px solid var(--bordure);padding:3rem;}
.auth-header{text-align:center;margin-bottom:2.5rem;}
.auth-header h1{font-family:var(--font-titre);font-size:1.6rem;font-weight:400;letter-spacing:0.06em;color:var(--ivoire);margin:0.8rem 0 0.5rem;}
.auth-header p{font-size:0.82rem;color:var(--texte-doux);}
.alert{padding:1rem 1.2rem;margin-bottom:1.5rem;font-size:0.80rem;font-family:var(--font-mono);letter-spacing:0.04em;border-left:2px solid;}
.alert-error{background:rgba(180,40,40,0.08);border-color:rgba(180,40,40,0.4);color:#e08080;}
.alert p{margin:0;}
.alert p+p{margin-top:0.3rem;}
.auth-form{display:flex;flex-direction:column;gap:1.4rem;}
.form-group{display:flex;flex-direction:column;gap:0.5rem;}
.form-group label{font-family:var(--font-mono);font-size:0.58rem;font-weight:400;letter-spacing:0.2em;text-transform:uppercase;color:var(--texte-doux);}
.form-group input,.form-group select,.form-group textarea{background:var(--noir);border:1px solid var(--bordure-2);border-radius:var(--radius);padding:0.75rem 1rem;color:var(--ivoire);font-family:var(--font-corps);font-size:0.88rem;font-weight:300;outline:none;transition:border-color 0.3s ease;width:100%;}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:rgba(200,130,24,0.5);}
.form-group input::placeholder{color:var(--texte-muted);}
.btn-full{width:100%;text-align:center;margin-top:0.5rem;}
.auth-footer{text-align:center;margin-top:2rem;font-size:0.78rem;font-family:var(--font-mono);letter-spacing:0.06em;color:var(--texte-muted);}
.auth-footer a{color:var(--ambre);opacity:0.8;}
.auth-footer a:hover{opacity:1;}
.site-footer{border-top:1px solid var(--bordure);padding:2rem 0;margin-top:6rem;}
.site-footer .container{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;}
.site-footer p{font-family:var(--font-mono);font-size:0.55rem;letter-spacing:0.16em;text-transform:uppercase;color:var(--texte-muted);}
@media(max-width:768px){.site-header nav{display:none;}.hero{padding:5rem 0 4rem;}.samples-grid{grid-template-columns:1fr 1fr;}.section-header{flex-direction:column;gap:1rem;}}
@keyframes fadeUp{from{opacity:0;transform:translateY(16px);}to{opacity:1;transform:translateY(0);}}
.hero>.container>*{animation:fadeUp 0.8s ease both;}
.hero>.container>*:nth-child(1){animation-delay:0.1s;}
.hero>.container>*:nth-child(2){animation-delay:0.25s;}
.hero>.container>*:nth-child(3){animation-delay:0.4s;}
.hero>.container>*:nth-child(4){animation-delay:0.55s;}
