:root{
    --orange:#FD6144; --red:#FD3244; --purple:#AE3A8D; --green:#25D366;
    --dark:#161212; --soft:#7A6868; --border:#E8E0E0;
    --bg:#FFFFFF; --bg2:#F9F6F6; --bg3:#F3EEEE;
}
*{margin:0;padding:0;box-sizing:border-box}
html,body{
    font-family:'DM Sans',system-ui,sans-serif;
    background:var(--bg2);
    color:var(--dark);
    -webkit-font-smoothing:antialiased;
    min-height:100vh;
}
.font-display{font-family:'Playfair Display',Georgia,serif;letter-spacing:-0.01em}
a{color:var(--orange);text-decoration:none}
a:hover{text-decoration:underline}

/* ── Header dark ── */
.aloia-header{background:var(--dark);padding:0 32px;height:56px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid rgba(255,255,255,0.06)}
.aloia-header-left{display:flex;align-items:center;gap:14px;min-width:0}
.aloia-header-left img{height:20px;width:auto}
.aloia-header-tag{font-size:10px;font-weight:600;letter-spacing:0.16em;text-transform:uppercase;color:var(--orange);background:rgba(253,97,68,0.1);padding:4px 10px;border-radius:100px}
.aloia-header-right{display:flex;align-items:center;gap:20px}
.aloia-header-user{display:flex;align-items:center;gap:10px;color:rgba(255,255,255,0.85);font-size:12px;font-weight:500}
.aloia-header-user .avatar{width:26px;height:26px;border-radius:50%;background:linear-gradient(135deg,#FD6144,#FD3244,#AE3A8D);display:inline-flex;align-items:center;justify-content:center;color:white;font-size:11px;font-weight:700}
.aloia-header-link{color:rgba(255,255,255,0.5);font-size:12px;font-weight:500;text-decoration:none;transition:color .2s}
.aloia-header-link:hover{color:white;text-decoration:none}

/* ── Tabs nav ── */
.aloia-tabs{background:var(--dark);padding:0 24px;display:flex;gap:4px;border-bottom:1px solid rgba(255,255,255,0.06);overflow-x:auto;scrollbar-width:none}
.aloia-tabs::-webkit-scrollbar{display:none}
.aloia-tab{background:none;border:none;color:rgba(255,255,255,0.45);font-family:'DM Sans',sans-serif;font-size:11px;font-weight:600;padding:14px 18px;cursor:pointer;border-bottom:2px solid transparent;transition:all .2s;letter-spacing:0.1em;text-transform:uppercase;display:inline-flex;align-items:center;gap:8px;white-space:nowrap;text-decoration:none}
.aloia-tab:hover{color:white;text-decoration:none}
.aloia-tab.active{color:var(--orange);border-bottom-color:var(--orange)}

/* ── Main ── */
.aloia-main{max-width:1100px;margin:0 auto;padding:28px 24px 60px;animation:aloiaFade .22s ease}

/* ── Títulos ── */
.page-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:24px;gap:16px;flex-wrap:wrap}
.page-head h1{
    font-family:'Playfair Display',Georgia,serif;
    font-size:36px;font-weight:700;line-height:1.1;letter-spacing:-0.015em;
}
.page-head h1 .accent{background:linear-gradient(135deg,#FD6144,#FD3244,#AE3A8D);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.page-head .subtitle{font-size:13px;color:var(--soft);margin-top:4px}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:10px;font-weight:700;color:var(--orange);text-transform:uppercase;letter-spacing:0.14em;margin-bottom:10px}
.eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--orange);box-shadow:0 0 0 4px rgba(253,97,68,0.15)}
.crumb{font-size:12px;color:var(--soft);margin-bottom:10px;text-transform:uppercase;letter-spacing:0.08em;font-weight:600}
.crumb a{color:var(--soft);text-decoration:none}
.crumb a:hover{color:var(--orange);text-decoration:none}

/* ── Botones ── */
.aloia-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 22px;font-family:inherit;font-size:13px;font-weight:700;border-radius:100px;border:none;cursor:pointer;text-decoration:none;transition:all .2s;letter-spacing:0.02em}
.aloia-btn-primary{background:linear-gradient(135deg,#FD6144,#FD3244,#AE3A8D);color:white;box-shadow:0 8px 20px -4px rgba(253,50,68,0.35)}
.aloia-btn-primary:hover{transform:translateY(-1px);box-shadow:0 12px 26px -4px rgba(253,50,68,0.45);text-decoration:none;color:white}
.aloia-btn-ghost{background:white;color:var(--dark);border:1px solid var(--border)}
.aloia-btn-ghost:hover{border-color:var(--orange);color:var(--orange);text-decoration:none}
.aloia-btn-sm{padding:8px 16px;font-size:12px}

/* ── Cards ── */
.aloia-card{background:white;border:1px solid var(--border);border-radius:14px;padding:22px;box-shadow:0 2px 14px rgba(22,18,18,0.04)}

/* ── Grid proyectos ── */
.grid-proj{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}
.card-proj{
    background:white;border:1px solid var(--border);border-radius:14px;
    padding:22px;color:var(--dark);
    display:block;
    box-shadow:0 2px 14px rgba(22,18,18,0.04);
    transition:all .18s cubic-bezier(.4,0,.2,1);
    text-decoration:none;
    position:relative;overflow:hidden;
}
.card-proj::before{
    content:'';position:absolute;top:0;left:0;right:0;height:3px;
    background:linear-gradient(90deg,#FD6144,#FD3244,#AE3A8D);
    opacity:0;transition:opacity .2s;
}
.card-proj:hover{border-color:transparent;transform:translateY(-2px);box-shadow:0 12px 28px -8px rgba(22,18,18,0.12);text-decoration:none}
.card-proj:hover::before{opacity:1}
.card-proj .card-title{font-family:'Playfair Display',serif;font-weight:700;font-size:20px;line-height:1.2;margin-bottom:14px;color:var(--dark)}
.card-proj .card-meta{display:flex;justify-content:space-between;color:var(--soft);font-size:12px;font-weight:500}
.card-proj .card-meta .count{color:var(--orange);font-weight:700}

/* ── Dropzone ── */
.dropzone{
    background:white;border:2px dashed var(--border);border-radius:14px;
    padding:48px 20px;text-align:center;cursor:pointer;
    transition:all .2s;margin-bottom:20px;
}
.dropzone:hover,.dropzone.dragover{
    border-color:var(--orange);
    background:rgba(253,97,68,0.03);
}
.dropzone .dz-icon{
    width:56px;height:56px;border-radius:50%;
    background:linear-gradient(135deg,#FD6144,#FD3244,#AE3A8D);
    color:white;display:inline-flex;align-items:center;justify-content:center;
    margin-bottom:14px;box-shadow:0 8px 20px -4px rgba(253,50,68,0.3);
}
.dropzone p{margin:4px 0;font-size:14px;font-weight:500}
.dropzone strong{color:var(--dark)}
.dropzone .hint{color:var(--soft);font-size:12px;font-weight:400}

/* ── Upload list ── */
.upload-list{margin-bottom:24px;display:flex;flex-direction:column;gap:8px}
.upload-item{
    background:white;border:1px solid var(--border);border-radius:12px;
    padding:14px 18px;display:flex;justify-content:space-between;align-items:center;gap:14px;
}
.upload-item .name{flex:1;font-size:13.5px;font-weight:500;word-break:break-all;min-width:0}
.upload-item .bar{width:110px;height:4px;background:var(--bg3);border-radius:100px;overflow:hidden;flex-shrink:0}
.upload-item .bar div{height:100%;background:linear-gradient(90deg,#FD6144,#FD3244,#AE3A8D);width:0;transition:width .2s;border-radius:100px}
.upload-item .status{font-size:11px;font-weight:600;color:var(--soft);text-transform:uppercase;letter-spacing:0.06em;min-width:110px;text-align:right;flex-shrink:0}
.upload-item.ok .status{color:var(--green)}
.upload-item.err .status{color:var(--red)}

/* ── Listado transcripciones ── */
.sub-title{font-size:11px;font-weight:700;color:var(--soft);text-transform:uppercase;letter-spacing:0.14em;margin:28px 0 12px}
.trans-list{display:flex;flex-direction:column;gap:8px}
.trans-item{
    background:white;border:1px solid var(--border);border-radius:12px;
    padding:16px 20px;display:flex;justify-content:space-between;align-items:center;gap:16px;
    transition:border-color .15s;
}
.trans-item:hover{border-color:rgba(253,97,68,0.3)}
.trans-main{flex:1;min-width:0}
.trans-name{font-weight:600;font-size:14px;margin-bottom:4px;word-break:break-all;color:var(--dark)}
.trans-meta{color:var(--soft);font-size:12px;font-weight:500}
.trans-actions{display:flex;gap:8px;flex-shrink:0}

.tag{
    display:inline-block;padding:2px 10px;border-radius:100px;font-size:10px;font-weight:700;
    background:var(--bg3);color:var(--soft);text-transform:uppercase;letter-spacing:0.08em;
}
.tag.ok{background:rgba(37,211,102,0.12);color:var(--green)}
.tag.err{background:rgba(253,50,68,0.12);color:var(--red)}
.tag.warn{background:rgba(253,97,68,0.12);color:var(--orange)}

/* ── Empty ── */
.empty{
    background:white;border:1px dashed var(--border);border-radius:14px;
    padding:48px 24px;text-align:center;color:var(--soft);font-size:14px;
}

/* ── Texto ── */
.texto{
    background:white;border:1px solid var(--border);border-radius:14px;
    padding:32px 36px;
    white-space:pre-wrap;word-break:break-word;
    font-size:15.5px;line-height:1.75;color:var(--dark);
    box-shadow:0 2px 14px rgba(22,18,18,0.04);
}

/* ── Alerts ── */
.alert{
    padding:12px 16px;border-radius:10px;font-size:13px;font-weight:500;
    margin-bottom:16px;display:flex;align-items:center;gap:10px;
}
.alert.err{background:rgba(253,50,68,0.08);border:1px solid rgba(253,50,68,0.2);color:var(--red)}
.alert.info{background:rgba(253,97,68,0.08);border:1px solid rgba(253,97,68,0.2);color:var(--orange)}

/* ── Login ── */
.login-body{min-height:100vh;display:flex;flex-direction:column}
.login-topbar{background:var(--dark);height:56px;padding:0 32px;display:flex;align-items:center;gap:14px}
.login-topbar img{height:20px}
.login-topbar .tag{font-size:10px;font-weight:600;letter-spacing:0.16em;text-transform:uppercase;color:var(--orange);background:rgba(253,97,68,0.1);padding:4px 10px;border-radius:100px}
.login-wrap{flex:1;display:flex;align-items:center;justify-content:center;padding:40px 20px;position:relative;overflow:hidden}
.login-wrap::before{content:'';position:absolute;width:480px;height:480px;border-radius:50%;background:radial-gradient(circle,rgba(253,97,68,0.14),transparent 60%);top:-120px;right:-120px;pointer-events:none}
.login-wrap::after{content:'';position:absolute;width:380px;height:380px;border-radius:50%;background:radial-gradient(circle,rgba(174,58,141,0.12),transparent 60%);bottom:-100px;left:-100px;pointer-events:none}
.login-card{position:relative;z-index:1;width:100%;max-width:420px;background:white;border:1px solid var(--border);border-radius:18px;padding:40px 36px;box-shadow:0 20px 50px -12px rgba(22,18,18,0.12)}
.login-card h1{font-family:'Playfair Display',Georgia,serif;font-size:34px;font-weight:700;line-height:1.1;letter-spacing:-0.015em;margin-bottom:6px}
.login-card h1 .accent{background:linear-gradient(135deg,#FD6144,#FD3244,#AE3A8D);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.login-card .subtitle{font-size:13px;color:var(--soft);margin-bottom:28px}
.login-foot{text-align:center;font-size:11px;color:var(--soft);padding:18px;letter-spacing:0.02em}

/* ── Form fields ── */
.field{margin-bottom:16px}
.field label{display:block;font-size:11px;font-weight:600;color:var(--soft);text-transform:uppercase;letter-spacing:0.08em;margin-bottom:6px}
.field input[type=text],
.field input[type=password],
dialog input[type=text]{
    width:100%;padding:12px 14px;
    font-family:inherit;font-size:14px;font-weight:500;color:var(--dark);
    background:var(--bg2);border:1px solid var(--border);border-radius:10px;
    transition:all .18s;
}
.field input:focus,
dialog input:focus{outline:none;background:white;border-color:var(--orange);box-shadow:0 0 0 4px rgba(253,97,68,0.12)}

/* ── Dialog ── */
dialog{
    background:white;border:1px solid var(--border);border-radius:18px;
    padding:32px;min-width:380px;max-width:90vw;
    box-shadow:0 20px 50px -12px rgba(22,18,18,0.2);
    color:var(--dark);
}
dialog::backdrop{background:rgba(22,18,18,0.5);backdrop-filter:blur(4px)}
dialog h3{font-family:'Playfair Display',serif;font-size:22px;font-weight:700;margin-bottom:18px}
.dlg-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:22px}

/* ── Checkbox trans-item ── */
.trans-item.sel{cursor:pointer;user-select:none}
.trans-item input.chk-trans{
    width:18px;height:18px;flex-shrink:0;cursor:pointer;accent-color:var(--orange);
    margin:0;
}
.trans-item .chk-placeholder{width:18px;flex-shrink:0}
.trans-item.sel:has(input.chk-trans:checked){
    border-color:var(--orange);
    background:rgba(253,97,68,0.04);
}

/* ── Barra flotante de agrupación ── */
.agrup-bar{
    position:fixed;bottom:24px;left:50%;transform:translateX(-50%);
    z-index:40;animation:aloiaFade .2s ease;
}
.agrup-bar-inner{
    background:var(--dark);color:white;
    border-radius:100px;padding:10px 14px;
    display:flex;align-items:center;gap:12px;
    box-shadow:0 20px 40px -8px rgba(22,18,18,0.4);
}
.agrup-count{font-size:13px;font-weight:600;padding:0 10px}
.agrup-bar .aloia-btn-ghost{background:rgba(255,255,255,0.08);border-color:rgba(255,255,255,0.15);color:white}
.agrup-bar .aloia-btn-ghost:hover{background:rgba(255,255,255,0.15);color:white;border-color:rgba(255,255,255,0.25)}

/* ── Textarea ── */
.field textarea{
    width:100%;padding:12px 14px;
    font-family:inherit;font-size:14px;font-weight:400;color:var(--dark);
    background:var(--bg2);border:1px solid var(--border);border-radius:10px;
    transition:all .18s;resize:vertical;min-height:72px;
}
.field textarea:focus{outline:none;background:white;border-color:var(--orange);box-shadow:0 0 0 4px rgba(253,97,68,0.12)}

/* ── Spinner ── */
.spinner{
    display:inline-block;width:14px;height:14px;
    border:2px solid rgba(255,255,255,0.35);
    border-top-color:#fff;border-radius:50%;
    animation:spin .7s linear infinite;vertical-align:-2px;
}
.aloia-btn-ghost .spinner{border-color:rgba(22,18,18,0.2);border-top-color:var(--dark)}
.aloia-btn[disabled]{opacity:0.85;cursor:wait;pointer-events:none}

/* ── Overlay de procesamiento ── */
.proc-overlay{
    position:fixed;inset:0;z-index:60;
    background:rgba(249,246,246,0.85);backdrop-filter:blur(6px);
    display:flex;align-items:center;justify-content:center;
    animation:aloiaFade .2s ease;
}
.proc-card{
    background:white;border:1px solid var(--border);border-radius:18px;
    padding:36px 44px;text-align:center;
    box-shadow:0 20px 50px -12px rgba(22,18,18,0.15);
    display:flex;flex-direction:column;align-items:center;gap:14px;
}
.proc-card .ring{
    width:48px;height:48px;
    border:3px solid var(--bg3);
    border-top-color:transparent;
    border-radius:50%;position:relative;
    background:conic-gradient(from 0deg,#FD6144,#FD3244,#AE3A8D,#FD6144);
    -webkit-mask:radial-gradient(circle 22px at center,transparent 98%,black 100%);
            mask:radial-gradient(circle 22px at center,transparent 98%,black 100%);
    animation:spin 1.1s linear infinite;
}
.proc-card .title{font-family:'Playfair Display',serif;font-size:20px;font-weight:700}
.proc-card .sub{font-size:13px;color:var(--soft);max-width:260px;line-height:1.5}

@keyframes spin{to{transform:rotate(360deg)}}

/* ── Anim ── */
@keyframes aloiaFade{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}

/* ── Mobile ── */
@media (max-width: 900px){
    .aloia-header{padding:0 16px}
    .aloia-main{padding:20px 16px 40px}
    .page-head h1{font-size:28px}
    .texto{padding:22px}
}
