/* ── CalShare — paper wall aesthetic ────────────────────────────────────── */
@import url('/static/fonts/fonts.css');

:root{
  --paper:#F3EEE4;          /* warm ground            */
  --paper-2:#FBF8F1;        /* card surface           */
  --ink:#23211C;            /* near-black text        */
  --ink-soft:#6B655A;       /* muted text             */
  --line:#D9D1C2;           /* hairlines              */
  --accent:#C2410C;         /* burnt orange ink-stamp */
  --accent-soft:#F1DDCF;    /* event chip wash        */
  --shadow:0 1px 0 var(--line), 0 12px 30px -18px rgba(35,33,28,.4);
  --r:14px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:'Inter',system-ui,sans-serif;
  line-height:1.45;
  -webkit-font-smoothing:antialiased;
  /* faint ruled-paper texture */
  background-image:repeating-linear-gradient(transparent 0 31px, rgba(217,209,194,.35) 31px 32px);
}

.wrap{max-width:560px;margin:0 auto;padding:clamp(20px,5vw,52px) 20px 60px;min-height:100dvh}
.wrap.narrow{max-width:440px}
.wrap.wide{max-width:920px}

/* ── Masthead ──────────────────────────────────────────────────────────── */
.masthead{margin-bottom:28px}
.mark{
  font-size:30px;color:var(--accent);line-height:1;
  border:2px solid var(--accent);width:54px;height:54px;border-radius:50%;
  display:grid;place-items:center;margin-bottom:18px;
}
h1{
  font-family:'Fraunces',serif;font-weight:600;
  font-size:clamp(34px,8vw,52px);line-height:.98;letter-spacing:-.02em;margin:0;
}
.sub{color:var(--ink-soft);margin:.6em 0 0;font-size:15px;max-width:38ch}

/* ── Tabs ──────────────────────────────────────────────────────────────── */
.tabs{display:flex;gap:6px;margin:0 0 18px;border-bottom:1px solid var(--line)}
.tab{
  appearance:none;border:0;background:none;cursor:pointer;
  font:600 14px 'Inter',sans-serif;color:var(--ink-soft);
  padding:10px 14px;margin-bottom:-1px;border-bottom:2px solid transparent;
}
.tab.is-active{color:var(--ink);border-bottom-color:var(--accent)}

/* ── Panels / forms ────────────────────────────────────────────────────── */
.panel{
  background:var(--paper-2);border:1px solid var(--line);border-radius:var(--r);
  box-shadow:var(--shadow);padding:22px;
}
.hidden{display:none!important}
form{display:flex;flex-direction:column;gap:16px}
label{display:flex;flex-direction:column;gap:6px;font-weight:600;font-size:13px;color:var(--ink)}
label em{font-style:normal;font-weight:400;color:var(--ink-soft)}
input,textarea{
  font:400 16px 'Inter',sans-serif;color:var(--ink);
  background:#fff;border:1px solid var(--line);border-radius:9px;padding:11px 12px;width:100%;
}
input:focus,textarea:focus{outline:2px solid var(--accent);outline-offset:1px;border-color:transparent}
textarea{resize:vertical}
.row{display:flex;gap:12px}
.row label{flex:1}
.check{flex-direction:row;align-items:center;gap:9px;font-weight:500;color:var(--ink-soft)}
.check input{width:auto;accent-color:var(--accent)}

.go{
  appearance:none;cursor:pointer;border:0;border-radius:10px;
  background:var(--accent);color:#fff;font:600 16px 'Inter',sans-serif;
  padding:13px 16px;transition:transform .06s ease, filter .15s ease;
}
.go:hover{filter:brightness(1.06)}
.go:active{transform:translateY(1px)}
.go:disabled{background:var(--line);color:var(--ink-soft);cursor:not-allowed}

/* ── Drop zone ─────────────────────────────────────────────────────────── */
.drop{
  align-items:center;justify-content:center;text-align:center;cursor:pointer;
  border:2px dashed var(--line);border-radius:var(--r);padding:34px 18px;gap:6px;
  background:#fff;transition:border-color .15s, background .15s;font-weight:500;
}
.drop.over{border-color:var(--accent);background:var(--accent-soft)}
.drop-line{font-size:16px}
.drop-line strong{color:var(--accent)}
.drop-sub{font-size:13px;color:var(--ink-soft)}

/* ── Messages / footer ─────────────────────────────────────────────────── */
.msg{min-height:1.4em;margin:16px 2px 0;font-size:14px;color:var(--accent);font-weight:500}
.msg.err{color:var(--accent)}
.foot{margin-top:34px;font-size:14px}
.foot a{color:var(--ink-soft);text-decoration:none;border-bottom:1px solid var(--line);padding-bottom:1px}
.foot a:hover{color:var(--accent);border-color:var(--accent)}

/* ── Calendar header ───────────────────────────────────────────────────── */
.calhead{display:flex;justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:22px;flex-wrap:wrap}
.caltitle{font-size:clamp(28px,6vw,42px)}
.navbtns{display:flex;align-items:center;gap:6px}
.navbtns button,.navbtns .logout{
  appearance:none;cursor:pointer;border:1px solid var(--line);background:var(--paper-2);
  color:var(--ink);font:600 14px 'Inter',sans-serif;border-radius:9px;padding:8px 12px;text-decoration:none;
}
.navbtns button:hover,.navbtns .logout:hover{border-color:var(--accent);color:var(--accent)}
.navbtns .logout{color:var(--ink-soft)}

/* ── Month grid ────────────────────────────────────────────────────────── */
.grid-head{
  display:grid;grid-template-columns:repeat(7,1fr);gap:6px;margin-bottom:6px;
  font:500 11px 'JetBrains Mono',monospace;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.08em;
}
.grid-head span{text-align:center}
.grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.cell{
  background:var(--paper-2);border:1px solid var(--line);border-radius:10px;
  min-height:84px;padding:6px;display:flex;flex-direction:column;gap:3px;cursor:default;
  transition:border-color .12s;
}
.cell.other{opacity:.42}
.cell.has{cursor:pointer}
.cell.has:hover{border-color:var(--accent)}
.cell.today{border-color:var(--accent);box-shadow:inset 0 0 0 1px var(--accent)}
.daynum{font:500 12px 'JetBrains Mono',monospace;color:var(--ink-soft)}
.cell.today .daynum{color:var(--accent);font-weight:600}
.chip{
  background:var(--accent-soft);color:#7c2d12;border-radius:6px;padding:2px 6px;
  font-size:11px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  cursor:pointer;
}
.chip:hover{filter:brightness(.93)}
.chip-start {border-radius:6px 2px 2px 6px}
.chip-mid   {border-radius:2px}
.chip-end   {border-radius:2px 6px 6px 2px}
.chip-single{border-radius:6px}
.more{font-size:10px;color:var(--ink-soft);padding-left:2px}

/* mobile: tighter cells */
@media(max-width:620px){
  .cell{min-height:58px;padding:4px;border-radius:8px}
  .chip{font-size:0;padding:3px}
  .chip::before{content:"";display:block;width:5px;height:5px;border-radius:50%;background:var(--accent)}
.more{display:none}
}

/* ── Agenda (upcoming list) ────────────────────────────────────────────── */
.agenda{margin-top:30px;display:flex;flex-direction:column;gap:2px}
.agenda h3{font:500 11px 'JetBrains Mono',monospace;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.08em;margin:18px 0 8px}
.ev{
  display:flex;gap:14px;align-items:baseline;padding:11px 4px;border-bottom:1px solid var(--line);
}
.ev-when{font:500 13px 'JetBrains Mono',monospace;color:var(--accent);min-width:96px;white-space:nowrap}
.ev-body{flex:1}
.ev-title{font-weight:600}
.ev-meta{font-size:13px;color:var(--ink-soft)}

/* ── Day sheet (modal) ─────────────────────────────────────────────────── */
.sheet{position:fixed;inset:0;background:rgba(35,33,28,.4);display:grid;place-items:end center;z-index:20}
.sheet-card{
  background:var(--paper-2);width:100%;max-width:560px;border-radius:18px 18px 0 0;
  padding:24px 22px 34px;box-shadow:0 -10px 40px -16px rgba(0,0,0,.5);position:relative;
  max-height:80dvh;overflow:auto;
}
@media(min-width:620px){.sheet{place-items:center}.sheet-card{border-radius:18px}}
.sheet-x{position:absolute;top:16px;right:16px;border:0;background:none;font-size:18px;cursor:pointer;color:var(--ink-soft)}
.sheet h2{font-family:'Fraunces',serif;font-size:24px;margin:0 0 12px}
.del-btn{
  appearance:none;border:1px solid var(--line);background:none;color:var(--ink-soft);
  font:500 12px 'Inter',sans-serif;border-radius:6px;padding:4px 10px;cursor:pointer;
  align-self:flex-start;margin-top:4px;transition:background .15s,color .15s,border-color .15s;
  white-space:nowrap;
}
.del-btn:hover{border-color:var(--accent);color:var(--accent)}
.del-btn.del-confirm{background:var(--accent);color:#fff;border-color:var(--accent)}
.ev-gps{cursor:pointer;user-select:all}
.ev-gps:hover{color:var(--accent)}
.ev-attachments{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}
.att-link{font-size:12px;color:var(--accent);text-decoration:none;background:var(--accent-soft);border-radius:6px;padding:2px 8px;white-space:nowrap}
.att-link:hover{text-decoration:underline}
