/*
  CrackinShare — app.css
  Light & airy palette from logo:
    Rose-gold:  #C07860  (primary buttons, accents)
    Rose-dark:  #A05A44  (hover)
    Blush:      #D8A8A8  (soft highlights)
    Rose-border:#EDD8D0  (card borders)
    Grey-text:  #787878  (secondary text — logo script colour)
    Warm-muted: #A89898  (placeholder / light text)
    Page bg:    #FFFFFF  (white)
    Card bg:    #FFFAF9  (just-off-white)
    Section bg: #FDF6F4  (very light blush section)
*/
:root{
  --rose:#C07860;
  --rose-dk:#A05A44;
  --rose-lt:#EDD8D0;
  --blush:#D8A8A8;
  --grey:#787878;
  --grey-lt:#A89898;
  --dark:#4A3535;
  --text:#5A4040;
  --border:#EDD8D0;
  --bg:#FFFFFF;
  --bg-card:#FFFAF9;
  --bg-section:#FDF6F4;
}
*,*::before,*::after{box-sizing:border-box}
body{margin:0;font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;font-size:14px;color:var(--text);background:var(--bg);min-height:100vh;display:flex;flex-direction:column}

/* ── Nav ── */
/* ── Nav bar ── */
.cs-nav{background:#fff;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:200}
.cs-nav-inner{max-width:1200px;margin:0 auto;padding:0 20px;height:64px;display:flex;align-items:center;justify-content:space-between;gap:12px}
.cs-nav-logo img{height:52px;display:block}
@media(max-width:680px){.cs-nav-logo img{height:44px}}
.cs-nav-right{display:flex;align-items:center;gap:20px}
.cs-nav-name{font-size:13px;color:var(--grey-lt)}
.cs-nav-link{font-size:13px;font-weight:500;color:var(--grey);text-decoration:none;transition:color .15s}
.cs-nav-link:hover,.cs-nav-link-active{color:var(--rose)}
.cs-nav-link-active{font-weight:700}
.cs-nav-btn{background:linear-gradient(135deg,var(--rose),var(--rose-dk));color:#fff;font-size:13px;font-weight:700;padding:8px 18px;border-radius:8px;text-decoration:none;transition:opacity .15s;box-shadow:0 2px 8px rgba(192,120,96,.25)}
.cs-nav-btn:hover{opacity:.88}
.cs-nav-btn-outline{border:1.5px solid var(--border);color:var(--grey);font-size:13px;font-weight:500;padding:7px 16px;border-radius:8px;text-decoration:none;transition:border-color .15s,color .15s}
.cs-nav-btn-outline:hover{border-color:var(--rose);color:var(--rose)}

/* ── Hamburger ── */
.cs-hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;width:40px;height:40px;
  background:none;border:none;cursor:pointer;padding:8px;border-radius:8px;flex-shrink:0;order:-1}
.cs-hamburger:hover{background:var(--bg-section)}
.cs-hamburger span{display:block;width:22px;height:2px;background:var(--dark);border-radius:2px;transition:all .25s}

/* Desktop/mobile visibility */
.cs-nav-desktop{display:flex}
.cs-nav-mobile-right{display:none}

@media(max-width:680px){
  .cs-hamburger{display:flex}
  .cs-nav-desktop{display:none}
  .cs-nav-mobile-right{display:flex;align-items:center;gap:10px;margin-left:auto}
  .cs-nav-logo{position:absolute;left:50%;transform:translateX(-50%)}
  .cs-nav-inner{position:relative}
}

/* ── Off-canvas overlay ── */
.cs-offcanvas-overlay{display:none;position:fixed;inset:0;background:rgba(74,53,53,.45);z-index:499;
  opacity:0;transition:opacity .3s}

/* ── Off-canvas drawer ── */
.cs-offcanvas{position:fixed;top:0;left:0;width:min(300px,85vw);height:100dvh;background:#fff;
  z-index:500;transform:translateX(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);
  display:flex;flex-direction:column;box-shadow:4px 0 40px rgba(74,53,53,.15);overflow-y:auto}
.cs-offcanvas.open{transform:translateX(0)}

.cs-oc-header{display:flex;align-items:center;justify-content:space-between;
  padding:16px 20px;border-bottom:1px solid var(--border);flex-shrink:0}
.cs-oc-logo{height:32px}
.cs-oc-close{background:none;border:none;cursor:pointer;font-size:16px;color:var(--grey-lt);
  width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  transition:background .15s,color .15s;padding:0}
.cs-oc-close:hover{background:var(--bg-section);color:var(--dark)}

.cs-oc-user{display:flex;align-items:center;gap:12px;padding:20px;border-bottom:1px solid var(--border);flex-shrink:0}
.cs-oc-avatar{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--rose),var(--rose-dk));
  color:#fff;font-size:16px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.cs-oc-uname{font-size:14px;font-weight:700;color:var(--dark)}
.cs-oc-uemail{font-size:11px;color:var(--grey-lt);margin-top:1px;word-break:break-all}

.cs-oc-nav{display:flex;flex-direction:column;padding:12px 12px;flex:1}
.cs-oc-link{display:flex;align-items:center;gap:10px;padding:13px 16px;border-radius:10px;
  font-size:14px;font-weight:600;color:var(--dark);text-decoration:none;transition:background .15s,color .15s;margin-bottom:2px}
.cs-oc-link:hover{background:var(--bg-section);color:var(--rose)}
.cs-oc-link-cta{background:linear-gradient(135deg,var(--rose),var(--rose-dk));color:#fff!important;
  margin-top:8px;justify-content:center;box-shadow:0 2px 8px rgba(192,120,96,.3)}
.cs-oc-link-cta:hover{opacity:.9;background:linear-gradient(135deg,var(--rose),var(--rose-dk))}

.cs-oc-footer{padding:16px 20px;border-top:1px solid var(--border);flex-shrink:0}
.cs-oc-signout{display:block;text-align:center;padding:11px;border:1.5px solid var(--border);
  border-radius:9px;font-size:13px;font-weight:600;color:var(--grey);text-decoration:none;transition:all .15s}
.cs-oc-signout:hover{border-color:var(--rose);color:var(--rose);background:var(--bg-section)}

/* ── Flash ── */
.cs-flash{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 24px;font-size:14px;font-weight:500}
.cs-flash button{background:none;border:none;cursor:pointer;font-size:16px;opacity:.6;padding:0 4px}
.cs-flash-success{background:#f0fdf4;color:#15803d;border-bottom:1px solid #bbf7d0}
.cs-flash-error{background:#fef2f2;color:#dc2626;border-bottom:1px solid #fecaca}
.cs-main{flex:1}

/* ── Footer ── */
.cs-footer{background:var(--bg-section);border-top:1px solid var(--border);padding:32px 24px;margin-top:auto}
.cs-footer-inner{max-width:1200px;margin:0 auto;text-align:center}
.cs-footer-logo{height:32px;display:block;margin:0 auto 12px;opacity:.7}
.cs-footer p{font-size:12px;color:var(--grey-lt);margin:4px 0}
.cs-footer a{color:var(--rose);text-decoration:none}
.cs-footer a:hover{color:var(--rose-dk)}

/* ── Auth cards ── */
.auth-wrap{min-height:calc(100vh - 130px);display:flex;align-items:center;justify-content:center;padding:40px 20px;background:var(--bg-section)}
.auth-card{background:#fff;border:1px solid var(--border);border-radius:20px;padding:40px;width:100%;max-width:440px;box-shadow:0 4px 32px rgba(192,120,96,.10)}
.auth-logo{text-align:center;margin-bottom:28px}
.auth-logo img{height:44px}
.auth-title{font-family:'Playfair Display',Georgia,serif;font-size:22px;font-weight:700;color:var(--dark);text-align:center;margin:0 0 8px}
.auth-sub{font-size:13px;color:var(--grey-lt);text-align:center;margin:0 0 28px;line-height:1.6}
.auth-error{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;border-radius:8px;padding:12px 16px;font-size:13px;margin-bottom:20px}
.auth-form{display:flex;flex-direction:column;gap:16px}
.auth-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.auth-field{display:flex;flex-direction:column;gap:6px}
.auth-field label{font-size:11px;font-weight:700;color:var(--grey);letter-spacing:.06em;text-transform:uppercase}
.auth-field input{border:1.5px solid var(--border);border-radius:10px;padding:11px 14px;font-size:14px;font-family:inherit;transition:border-color .15s,box-shadow .15s;outline:none;width:100%;color:var(--dark);background:#fff}
.auth-field input:focus{border-color:var(--rose);box-shadow:0 0 0 3px rgba(192,120,96,.12)}
.auth-btn{background:linear-gradient(135deg,var(--rose),var(--rose-dk));color:#fff;border:none;border-radius:10px;padding:13px;font-size:14px;font-weight:700;font-family:inherit;cursor:pointer;transition:opacity .15s,transform .1s;display:block;width:100%;text-align:center;text-decoration:none;box-shadow:0 4px 16px rgba(192,120,96,.3)}
.auth-btn:hover{opacity:.88;transform:translateY(-1px)}
.auth-switch{font-size:13px;color:var(--grey-lt);text-align:center;margin:16px 0 0}
.auth-switch a{color:var(--rose);font-weight:600;text-decoration:none}
@media(max-width:480px){.auth-card{padding:28px 20px}.auth-row{grid-template-columns:1fr}}