/* Travelbuddy — travel-journal aesthetic */
:root{
  --paper:#f1ebdd;
  --paper-2:#eae2cf;
  --ink:#15120d;
  --ink-2:#3a342a;
  --terra:#b8472a;
  --olive:#5a6836;
  --stamp:#951f1a;
  --teal:#2f5d5d;
  --gold:#c69343;
  --rule:#2a2418;
  --danger:#951f1a;
  --ok:#5a6836;
  --shadow: 0 1px 0 rgba(0,0,0,.04), 0 20px 40px -20px rgba(21,18,13,.25);
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--paper);color:var(--ink);font-family:"Instrument Sans",sans-serif;-webkit-font-smoothing:antialiased}
body{
  min-height:100vh;
  background-image:
    radial-gradient(circle at 20% 10%, rgba(184,71,42,.05), transparent 40%),
    radial-gradient(circle at 80% 90%, rgba(90,104,54,.07), transparent 45%),
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.08 0 0 0 0 0.07 0 0 0 0 0.05 0 0 0 .1 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  background-size:auto,auto,240px 240px;
}

.serif{font-family:"Fraunces",serif;font-optical-sizing:auto}
.mono{font-family:"JetBrains Mono",monospace;letter-spacing:.02em}
.tiny{font-size:10.5px;text-transform:uppercase;letter-spacing:.22em}

a{color:inherit;text-decoration:none}
a:hover{color:var(--terra)}

.wrap{max-width:720px;margin:0 auto;padding:20px 18px 96px}

/* top bar */
.topbar{
  display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:12px;
  padding:14px 18px;border-bottom:1px solid var(--rule);
}
.topbar .wordmark{
  font-family:"Fraunces",serif;font-weight:500;font-size:20px;letter-spacing:-.02em;text-align:center
}
.topbar .wordmark em{font-style:italic;color:var(--terra);font-weight:400}
.topbar .left,.topbar .right{display:flex;gap:8px;align-items:center}
.topbar .right{justify-content:flex-end}
.topbar .crumb{font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-2)}

/* typography */
h1,h2,h3{font-family:"Fraunces",serif;font-weight:380;letter-spacing:-.015em;line-height:1.05}
h1{font-size:40px}h1 em{font-style:italic;color:var(--terra);font-weight:340}
h2{font-size:26px}
h3{font-size:20px}

.kicker{font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--ink-2);margin-bottom:6px}

.dek{color:var(--ink-2);margin-top:6px;line-height:1.55}

.rule{height:1px;background:repeating-linear-gradient(90deg,var(--rule) 0 4px,transparent 4px 8px);margin:18px 0}
.divider{height:1px;background:repeating-linear-gradient(90deg,var(--rule) 0 3px,transparent 3px 7px);margin:10px 0}

/* cards */
.card{
  background:#faf4e6;border:1px solid var(--rule);border-radius:14px;padding:14px;
  box-shadow:var(--shadow);
}
.card.tight{padding:10px 12px}

/* ticket (trip card) */
.ticket{
  background:var(--paper-2);border:1px solid var(--rule);border-radius:14px;padding:14px;
  position:relative;overflow:hidden
}
.ticket::before,.ticket::after{
  content:"";position:absolute;width:14px;height:14px;background:var(--paper);border-radius:50%;
  top:50%;transform:translateY(-50%);border:1px solid var(--rule)
}
.ticket::before{left:-8px}.ticket::after{right:-8px}
.ticket .row1{display:flex;justify-content:space-between;align-items:center;font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-2)}
.ticket .route{display:flex;justify-content:space-between;align-items:center;margin-top:8px}
.ticket .route .code{font-family:"Fraunces",serif;font-size:30px;font-weight:400;letter-spacing:-.01em}
.ticket .route .arr{flex:1;margin:0 10px;display:flex;align-items:center;gap:6px;color:var(--ink-2)}
.ticket .route .arr .ln{flex:1;height:1px;background:repeating-linear-gradient(90deg,var(--rule) 0 3px,transparent 3px 6px)}

/* pills & tags */
.pill{
  display:inline-flex;align-items:center;gap:6px;border:1px solid var(--rule);
  padding:3px 9px;border-radius:999px;font-family:"JetBrains Mono",monospace;font-size:9.5px;
  letter-spacing:.16em;text-transform:uppercase;color:var(--ink)
}
.pill .live{width:5px;height:5px;background:var(--terra);border-radius:50%;box-shadow:0 0 0 3px rgba(184,71,42,.2)}
.tag{
  display:inline-block;font-family:"JetBrains Mono",monospace;font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;
  padding:2px 7px;border-radius:3px;background:var(--paper-2);color:var(--ink-2)
}
.tag.ok{background:var(--olive);color:var(--paper)}
.tag.warn{background:var(--terra);color:var(--paper)}
.tag.gold{background:var(--gold);color:var(--ink)}

/* member avatars */
.members{display:flex;align-items:center}
.av{
  width:32px;height:32px;border-radius:50%;border:2px solid var(--paper);
  margin-left:-8px;display:grid;place-items:center;font-family:"Fraunces",serif;font-size:13px;color:#fff;font-weight:500
}
.av:first-child{margin-left:0}

/* forms */
form .field{margin-bottom:14px}
label{display:block;font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-2);margin-bottom:4px}
input[type=text],input[type=email],input[type=password],input[type=date],input[type=time],input[type=number],input[type=file],select,textarea{
  width:100%;padding:11px 12px;border:1px solid var(--rule);border-radius:10px;background:#faf4e6;
  font-family:"Instrument Sans",sans-serif;font-size:15px;color:var(--ink)
}
input:focus,select:focus,textarea:focus{outline:2px solid var(--terra);outline-offset:1px;border-color:var(--terra)}
textarea{min-height:80px;resize:vertical}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  background:var(--ink);color:var(--paper);border:none;border-radius:10px;padding:12px 16px;
  font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.24em;text-transform:uppercase;
  cursor:pointer;text-decoration:none;width:100%
}
.btn:hover{background:var(--terra);color:var(--paper)}
.btn.ghost{background:transparent;color:var(--ink);border:1px solid var(--rule)}
.btn.ghost:hover{background:var(--ink);color:var(--paper)}
.btn.sm{padding:8px 12px;width:auto}

.errors{
  background:rgba(149,31,26,.08);border:1px solid var(--danger);color:var(--danger);
  padding:10px 12px;border-radius:10px;font-size:13px;margin-bottom:14px
}
.messages{margin-bottom:14px}
.messages li{
  list-style:none;padding:10px 12px;border:1px solid var(--rule);border-radius:10px;margin-bottom:6px;
  background:#faf4e6;font-size:13px
}
.messages li.success{border-color:var(--olive)}
.messages li.error{border-color:var(--danger);color:var(--danger)}

/* tab bar (mobile bottom nav) */
.tabbar{
  position:fixed;bottom:10px;left:10px;right:10px;max-width:680px;margin:0 auto;padding:10px 12px;
  border:1px solid var(--rule);border-radius:18px;background:var(--paper-2);
  display:grid;grid-template-columns:repeat(5,1fr);gap:4px;
  font-family:"JetBrains Mono",monospace;font-size:9px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--ink-2);z-index:50;box-shadow:var(--shadow)
}
.tabbar .item{display:flex;flex-direction:column;align-items:center;gap:4px;padding:6px 0;border-radius:10px}
.tabbar .item.active{background:var(--ink);color:var(--paper)}

/* timeline (itinerary) */
.timeline{position:relative;padding-left:52px}
.timeline::before{
  content:"";position:absolute;left:40px;top:6px;bottom:6px;width:1px;
  background:repeating-linear-gradient(180deg,var(--rule) 0 3px,transparent 3px 6px)
}
.tl-item{position:relative;margin-bottom:14px}
.tl-item .t{
  position:absolute;left:-52px;top:2px;width:40px;text-align:right;
  font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--ink);line-height:1.1
}
.tl-item .t .ap{display:block;font-size:9px;color:var(--ink-2);letter-spacing:.15em}
.tl-item::before{
  content:"";position:absolute;left:-14px;top:7px;width:10px;height:10px;border-radius:50%;
  background:var(--paper);border:1.5px solid var(--ink)
}
.tl-item.now::before{background:var(--terra);border-color:var(--terra);box-shadow:0 0 0 4px rgba(184,71,42,.2)}
.tl-card{
  border:1px solid var(--rule);border-radius:12px;padding:10px 12px;background:#faf4e6
}
.tl-card h4{font-family:"Fraunces",serif;font-weight:420;font-size:16px;letter-spacing:-.005em;line-height:1.2}
.tl-card .loc{font-size:11px;color:var(--ink-2);margin-top:3px}
.tl-card .meta{display:flex;gap:6px;margin-top:7px;flex-wrap:wrap}

/* drop zone */
.drop{
  border:1.5px dashed var(--rule);border-radius:14px;padding:24px;text-align:center;background:#faf4e6;
  position:relative;overflow:hidden;cursor:pointer
}
.drop::before{
  content:"";position:absolute;inset:6px;border-radius:10px;pointer-events:none;
  background:repeating-linear-gradient(45deg,transparent 0 8px, rgba(90,104,54,.05) 8px 10px)
}
.drop .icon{
  width:56px;height:56px;margin:0 auto;border:1.5px solid var(--ink);border-radius:8px;
  display:grid;place-items:center;position:relative;z-index:1;background:var(--paper);
  font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.18em
}
.drop h3{margin-top:12px;position:relative}
.drop p{position:relative;font-size:12px;color:var(--ink-2);margin-top:4px}
.drop input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer}

/* parsed table */
.parsed{border:1px solid var(--rule);border-radius:12px;overflow:hidden;background:#faf4e6}
.parsed .ph{
  padding:8px 12px;display:flex;justify-content:space-between;align-items:center;
  background:var(--ink);color:var(--paper);
  font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.18em;text-transform:uppercase
}
.parsed .row{
  display:grid;grid-template-columns:54px 1fr auto;padding:8px 12px;gap:10px;align-items:center;
  border-top:1px dashed var(--rule);font-size:13px
}
.parsed .row:first-of-type{border-top:none}
.parsed .row .t{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--ink-2)}
.parsed .row .a{font-family:"Fraunces",serif;font-size:15px;letter-spacing:-.005em}
.parsed .row .a small{display:block;font-family:"Instrument Sans",sans-serif;font-size:11px;color:var(--ink-2);margin-top:1px;font-style:italic}
.parsed .row .s{font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.15em}
.parsed .row .s.ok{color:var(--ok)}
.parsed .row .s.warn{color:var(--terra)}

/* food cards */
.food-card{
  border:1px solid var(--rule);border-radius:12px;padding:12px;background:#faf4e6;
  display:grid;grid-template-columns:44px 1fr auto;gap:12px;align-items:start;margin-bottom:10px
}
.food-card .mk{
  width:44px;height:44px;border-radius:10px;display:grid;place-items:center;
  font-family:"Fraunces",serif;font-size:18px;color:#fff;font-weight:500
}
.food-card h4{font-family:"Fraunces",serif;font-weight:420;font-size:16px;letter-spacing:-.005em;line-height:1.15}
.food-card .sub{font-size:11.5px;color:var(--ink-2);margin-top:3px;display:flex;gap:6px;flex-wrap:wrap}
.food-card .rating{text-align:right}
.food-card .rating .r{font-family:"Fraunces",serif;font-size:18px;font-weight:500;line-height:1}
.food-card .rating .c{font-family:"JetBrains Mono",monospace;font-size:9.5px;color:var(--ink-2);letter-spacing:.1em;margin-top:3px}
.food-card .tags{grid-column:1/-1;display:flex;gap:4px;margin-top:8px;flex-wrap:wrap}

/* filters */
.filters{display:flex;gap:6px;overflow-x:auto;padding-bottom:4px;margin-bottom:10px}
.filters a{
  padding:6px 10px;border:1px solid var(--rule);border-radius:999px;background:var(--paper-2);
  font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-2);white-space:nowrap
}
.filters a.active{background:var(--ink);color:var(--paper);border-color:var(--ink)}

/* stamp */
.stamp{
  display:inline-block;border:2px solid var(--stamp);color:var(--stamp);
  padding:6px 10px;border-radius:6px;font-family:"Fraunces",serif;font-style:italic;font-weight:500;
  transform:rotate(-4deg);letter-spacing:.02em
}

/* reveal */
@keyframes rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.reveal{animation:rise .7s cubic-bezier(.2,.7,.2,1) both}

@media (max-width:520px){
  h1{font-size:32px}
}

/* logout — form button styled as a plain link/tab */
.logout-form{display:inline;margin:0;padding:0}
.logout-btn{
  background:none;border:0;padding:0;margin:0;cursor:pointer;
  font:inherit;color:inherit;letter-spacing:inherit;text-transform:inherit;
}
.logout-btn:hover{opacity:.7}
.tabbar .logout-btn{
  /* make the form-wrapped button line up with the other .item links in the tabbar */
  display:inline-block;text-align:center;
}
