.skip-link{position:absolute;top:-100px;left:0;background:#2c3e2f;color:#fff;padding:.5rem 1rem;z-index:100;text-decoration:none;border-radius:0 0 .5rem 0;font-size:.9rem}
.skip-link:focus{top:0}
*{margin:0;padding:0;box-sizing:border-box}
body{background:#f9f3e7;font-family:'Segoe UI',Roboto,'Helvetica Neue',sans-serif;line-height:1.6;color:#2c241a;padding:1.5rem 1rem}
.container{max-width:1200px;margin:0 auto;background:#fffef7;border-radius:1.5rem;box-shadow:0 16px 30px -10px rgba(0,0,0,.08);overflow:hidden}
header,main,footer{padding:1.5rem 2rem}
header{background:#2c3e2f;color:#fff;border-bottom:4px solid #e6b422}
h1{font-size:1.9rem;letter-spacing:-.01em;font-weight:700;line-height:1.2}
h1 .subtitle{font-size:.95rem;font-weight:400;opacity:.85;display:block;margin-top:.25rem}
.cat-generator-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;margin-bottom:1.5rem}
@media(max-width:1200px){
.cat-generator-grid{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:1000px){
.cat-generator-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:500px){
.cat-generator-grid{grid-template-columns:1fr}
.cat-name{font-size:1.8rem}
canvas{max-width:220px}
}
.generator-card{background:#fff;border-radius:1.5rem;box-shadow:0 8px 16px rgba(0,0,0,.04);padding:1rem;border:1px solid #f0e2d0;display:flex;flex-direction:column;align-items:center}
.name-area{text-align:center;margin-bottom:.6rem;width:100%}
.cat-role{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;padding:.15rem .6rem;border-radius:20px;display:inline-block;margin-bottom:.3rem}
.cat-role.warrior{background:#e8f5e9;color:#2e7d32}
.cat-role.medicine{background:#e3f2fd;color:#1565c0}
.cat-role.apprentice{background:#fff3e0;color:#e65100}
.cat-role.elder{background:#f3e5f5;color:#6a1b9a}
.cat-role.kit{background:#fffde7;color:#f9a825}
.cat-role.leader{background:#ffebee;color:#c62828}
.cat-role.loner{background:#eceff1;color:#37474f}
.cat-role.queen{background:#fce4ec;color:#ad1457}
.cat-name{font-size:1.3rem;font-weight:800;background:linear-gradient(135deg,#2c3e2f,#6b4c3b);-webkit-background-clip:text;background-clip:text;color:transparent;letter-spacing:.5px;word-break:break-word}
.visual-panel{display:flex;justify-content:center;align-items:center;margin-top:.5rem;width:100%}
.canvas-container{flex:0 0 auto;text-align:center;width:100%}
canvas{background:#efe1cf;border-radius:16px;box-shadow:0 8px 16px rgba(0,0,0,.08);width:100%;max-width:120px;display:block;margin:0 auto}
.image-description{max-width:100%;background:#faf5ea;padding:.5rem .7rem;border-radius:.75rem;margin-top:.5rem;font-size:.78rem;color:#3a2a1f;border-left:3px solid #e6b422;text-align:left;margin-left:auto;margin-right:auto}
.description-text{font-style:italic}
.generate-btn{background:#c97e5a;border:none;color:#fff;font-weight:700;font-size:1.2rem;padding:.85rem 2rem;border-radius:50px;cursor:pointer;transition:transform .1s,background .2s;box-shadow:0 4px 8px rgba(0,0,0,.1);margin-top:.75rem;width:100%;max-width:280px;font-family:inherit}
.generate-btn:hover{background:#b45a35;transform:scale(.98)}
.generate-wrapper{text-align:center;margin-bottom:1.5rem}
.share-card{background:#fff;border-radius:1.5rem;box-shadow:0 8px 16px rgba(0,0,0,.04);padding:1.6rem;margin:0 auto 1.5rem auto;border:1px solid #f0e2d0;max-width:600px;text-align:center}
.share-buttons{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}
.share-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.55rem 1rem;border-radius:50px;font-size:.9rem;font-weight:600;text-decoration:none;color:#fff;transition:transform .1s,opacity .2s;border:none;cursor:pointer;font-family:inherit}
.share-btn:hover{transform:scale(.98);opacity:.9}
.share-btn.x{background:#1a1a1a}
.share-btn.facebook{background:#1877f2}
.share-btn.pinterest{background:#bd081c}
.share-btn.reddit{background:#ff4500}
.share-btn.copy{background:#6b4c3b}
.info-section{display:grid;grid-template-columns:1fr;gap:1.5rem}
.info-card{background:#fef9f0;border-radius:1.25rem;padding:1.2rem 1.4rem;border:1px solid #f1e2cf}
h2{font-size:1.4rem;margin-bottom:.7rem;color:#2c3e2f;border-left:4px solid #e6b422;padding-left:.7rem;line-height:1.3}
h3{font-size:1.1rem;margin:.8rem 0 .4rem;color:#5a3e2b}
h4{font-size:1rem;margin:.6rem 0 .3rem;color:#5a3e2b}
p,li{color:#2f2a24;font-size:.95rem}
ul,ol{padding-left:1.3rem;margin:.4rem 0}
footer{background:#2c3e2f;color:#e9e2d4;text-align:center;font-size:.82rem;border-top:1px solid #e6b422}
footer p{color:#e9e2d4}
footer a{color:#f7d98c;text-decoration:none}
footer a:hover{text-decoration:underline}
.internal-links{margin-top:.5rem;display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.internal-links a{color:#b45a35}
hr{margin:1.2rem 0;border:none;border-top:1px solid #eedbc8}
.anchor-section{scroll-margin-top:1rem;margin-top:1.5rem}
.copy-btn{background:#fff;border:1px solid #d8c59f;border-radius:.35rem;padding:.2rem .5rem;font-size:.75rem;cursor:pointer;color:#2c241a;transition:background .2s,border-color .2s}
.copy-btn:hover{background:#fef9f0;border-color:#e6b422}
.copy-btn.copied{background:#e8f5e9;border-color:#4caf50;color:#2e7d32}
.name-row{display:flex;align-items:center;gap:.5rem;justify-content:space-between}
.faq-section{background:#fef9f0;border-radius:1.25rem;padding:1.2rem 1.4rem;border:1px solid #f1e2cf}
.faq-item{border-bottom:1px solid #eedbc8;padding:.6rem 0}
.faq-item:last-child{border-bottom:none}
.faq-toggle{width:100%;display:flex;justify-content:space-between;align-items:center;background:none;border:none;font-size:1rem;font-weight:600;color:#2c3e2f;cursor:pointer;padding:.4rem 0;font-family:inherit;text-align:left}
.faq-toggle:hover{color:#b45a35}
.faq-icon{font-size:1.2rem;font-weight:700;color:#b45a35;min-width:1.5rem;text-align:center}
.faq-answer{padding:.4rem 0 .6rem 0}
.faq-answer p{font-size:.95rem;color:#2f2a24;margin:0}
.languages-section{margin-top:2rem;text-align:center}
.languages-title{font-size:1.1rem;color:#2c3e2f;margin-bottom:.8rem;font-weight:600;border-left:none;padding-left:0}
.languages-grid{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center;align-items:center}
.lang-card{background:#fff;border:1px solid #d8c59f;border-radius:.6rem;padding:.5rem .8rem;text-decoration:none;color:#2c241a;font-weight:500;transition:border-color .2s,background .2s;display:flex;align-items:center;gap:.4rem;font-size:.9rem}
.lang-card:hover{background:#fef9f0;border-color:#e6b422}
.lang-flag{font-size:1.1rem}