/* jscss/style.css */
:root {
    --main-bg: #e7e7e7;
    --white: #fff;
    --main-txt: #3e3d3d;

    /* ACCENTS */
    --primary: #4b2197;
    --primary-2: #2f1164;

    --secondary: #4b2197;
    --secondary-2: #4b2197;

    /* FORMS */
    --legend: #838383;
    --light: #ecf0f1;
    --success: #007a64;
    --danger: #860d8a;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
body { font-family: 'Segoe UI', Tahoma, sans-serif;
    background: var(--main-bg);
    color: var(--main-txt);
    line-height: 1.6;
}

.wrapper {
    max-width: 98vw;
    margin: 0 auto;
    padding: 0 .5rem;
}
@media (min-width: 40rem) {
    .wrapper { max-width: 1200px;}
}

/* --------------  Structure ---------------- */
.row {
  display: flex;
  flex-direction: column;
  padding: 0;
  width: 100%;
}
.row .column {
  display: block;
  flex: 1 1 auto;
  margin-left: 0;
  max-width: 100%;
  width: 100%;
}
@media (min-width: 40rem) {
  .row {
    flex-direction: row;
    margin-left: 0 auto;
    width: calc(100% + 0rem);
  }
  .row .column {
    margin-bottom: inherit;
    padding: 0 1.0rem;
  }
}

/* --------------  Typography ---------------- */

p {
  margin-top: 0;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-weight: 300;
  letter-spacing: -.1rem;
  margin-bottom: 2.0rem;
  margin-top: 0;
}

h1 {
  font-size: 2.6rem;
  line-height: 1.2;
}

h2 {
  font-size: 1.8rem;
  line-height: 1.25;
}

h3 {
  font-size: 1.6rem;
  line-height: 1.3;
}

h4 {
  font-size: 1.2rem;
  letter-spacing: -.08rem;
  line-height: 1.35;
}

h5 {
  font-size: 1.1rem;
  letter-spacing: -.05rem;
  line-height: 1.5;
}

h6 {
  font-size: 1.1rem;
  letter-spacing: 0;
  line-height: 1.4;
}

img {
  max-width: 100%;
}

/* --------------  Button ---------------- */

.button, button, input[type='button'], input[type='reset'], input[type='submit'] {
  background-color: var(--primary);
  border: 0rem solid var(--primary);
  border-radius: .4rem;
  color: var(--white);
  cursor: pointer;
  display: inline-block;
  height: 2rem;
  line-height: 2rem;
  padding: 0 3.0rem;
  text-align: center;
  text-decoration: none;
  white-space: nowrap;
}

.button:focus, .button:hover, button:focus, button:hover, input[type='button']:focus, input[type='button']:hover, input[type='reset']:focus, input[type='reset']:hover, input[type='submit']:focus, input[type='submit']:hover {
  background-color: var(--primary-2);
  color: var(--white);
  outline: 0;
}

/* --------------  Accordeon ---------------- */

.acc { border:1px solid #e5e7eb; border-radius:8px; margin:12px 0; background:var(--white); }
.acc > summary { cursor:pointer; padding:10px 12px; font-weight:600; list-style:none; }
.acc[open] > summary { border-bottom:1px solid #e5e7eb; }
.acc .acc-body { padding:12px; }
.color-row { display:flex; gap:8px; align-items:center; }
.color-row input[type="text"] { flex:1; }

/* --------------  Forms --------------  */

input[type='color'],
input[type='date'],
input[type='datetime'],
input[type='datetime-local'],
input[type='email'],
input[type='month'],
input[type='number'],
input[type='password'],
input[type='search'],
input[type='tel'],
input[type='text'],
input[type='url'],
input[type='week'],
input:not([type]),
textarea,
select {
  -webkit-appearance: none;
  background-color: transparent;
  border: 0.1rem solid #d1d1d1;
  border-radius: .4rem;
  box-shadow: none;
  box-sizing: inherit;
  padding: .6rem 1.0rem .7rem;
  width: 100%;
}

input[type='color']:focus,
input[type='date']:focus,
input[type='datetime']:focus,
input[type='datetime-local']:focus,
input[type='email']:focus,
input[type='month']:focus,
input[type='number']:focus,
input[type='password']:focus,
input[type='search']:focus,
input[type='tel']:focus,
input[type='text']:focus,
input[type='url']:focus,
input[type='week']:focus,
input:not([type]):focus,
textarea:focus,
select:focus {
  border-color: #9b4dca;
  outline: 0;
}

select {
  background: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 30 8" width="30"><path fill="%23d1d1d1" d="M0,0l6,8l6-8"/></svg>') center right no-repeat;
  padding-right: 3.0rem;
}

select:focus {
  background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 30 8" width="30"><path fill="%239b4dca" d="M0,0l6,8l6-8"/></svg>');
}

select[multiple] {
  background: none;
  height: auto;
}

textarea {
  min-height: 6.5rem;
}

label,
legend {
  display: block;
  font-size: .9rem;
  margin-bottom: .5rem;
  color: var(--legend);
}

fieldset {
  border-width: 0;
  padding: 0;
}

input[type='checkbox'],
input[type='radio'] {
  display: inline;
}

.label-inline {
  display: inline-block;
  font-weight: normal;
  margin-left: .5rem;
}

/* --------------  Header ---------------- */
.site-header { background: var(--primary-2); color: var(--light); padding: 1rem 0; box-shadow: 0 2px 5px rgba(0,0,0,0.1); }
.nav { display: flex; justify-content: space-between; align-items: center; }
.logo { font-size: 1.5rem; font-weight: bold; color: var(--light); text-decoration: none; }
.nav-links { display: flex; gap: 1.5rem; align-items: center; }
.nav-links a { color: var(--light); text-decoration: none; font-weight: 500; }
.nav-links a:hover { color: var(--primary); }

.user-menu { position: relative; }
.username { color: var(--light); font-weight: 500; }
.dropdown {
    display: none; position: absolute; right: 0; top: 100%;
    background: var(--white-bg); min-width: 180px; box-shadow: 0 5px 15px rgba(0,0,0,0.2);
    border-radius: 5px; z-index: 100; margin-top: 5px;
}
.dropdown a { display: block; padding: 10px 15px; color: #333; text-decoration: none; }
.dropdown a:hover { background:var(--light); }
.user-menu:hover .dropdown { display: block; }

/* --------------  Foote --------------   */
.site-footer { background: var(--primary-2); color: var(--light); text-align: center; padding: 2rem 0; margin-top: 4rem; font-size: 0.9rem; }


/* --------------  Messages --------------  */
.msg { padding: 10px; border-radius: 5px; margin: 15px 0; }
.success { background: #d4edda; color: #155724; }
.error { background: #f8d7da; color: #721c24; }






@media (max-width: 768px) {
    .nav { flex-direction: column; gap: 1rem; }
    .nav-links { flex-direction: column; }
}



/* PROFILE */

    .msg.success { background:#e6ffed; border:1px solid #34d399; color:#065f46; padding:10px; border-radius:8px; }
    .color-row{display:grid;grid-template-columns: 1fr auto;gap:8px;align-items:center;}
    .color-row input[type="color"]{width:100%;min-height:40px;border:1px solid #e5e7eb;border-radius:6px;padding:0;}
    .color-row .color-hex{font-family:ui-monospace, SFMono-Regular, Menlo, monospace;
    background:#f3f4f6;border:1px solid #e5e7eb;border-radius:6px;padding:6px 8px;min-width:92px;text-align:center;}
    .avatar-card{
    display:inline-flex; align-items:center; justify-content:center;
    width:140px; height:140px; border:1px solid #e5e7eb; border-radius:12px;
    background:#f9fafb; cursor:pointer; position:relative; overflow:hidden;
    }
    .avatar-card:focus{ outline:2px solid #3b82f6; outline-offset:2px; }
    .avatar-preview{ display:block; width:100%; height:100%; object-fit:cover; }
    .avatar-fallback{
    width:100%; height:100%;
    display:flex; align-items:center; justify-content:center;
    font-weight:700; font-size:42px; color:#374151; background:#e5e7eb;
    }
    .avatar-hint{
    position:absolute; bottom:6px; right:6px; font-size:.75rem;
    background:rgba(0,0,0,.65); color:var(--white); padding:2px 6px; border-radius:999px;
    }
    .avatar-card.ring{ outline:2px dashed #3b82f6; outline-offset:4px; }
