:root{--brand: #009688;--ink: #101418;--bg: #f5f7f8;--line: #e5e7eb}*{box-sizing:border-box}html,body{height:100%}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;color:var(--ink);background:var(--bg)}.container{width:min(100%,960px);margin:0 auto;padding:16px}.header{background:#fff;border-bottom:1px solid var(--line)}.header__bar{display:flex;align-items:center;justify-content:space-between;padding:12px 16px}.logo{font-weight:800;letter-spacing:.2px}.logo em{color:var(--brand);font-style:normal}.nav{display:flex;align-items:center;flex-wrap:nowrap}.nav a{display:inline-block;text-decoration:none;color:var(--ink);padding:8px 10px;border-radius:10px;margin-left:6px}.nav a:hover{background:#eef6f5}.nav a.nav-account-btn{background:var(--brand);color:#fff;font-weight:600;padding:8px 16px}.nav a.nav-account-btn:hover{background:#00796b}main{padding:16px}.card{background:#fff;border:1px solid var(--line);border-radius:12px;padding:20px}.btn{display:inline-block;border:0;border-radius:12px;padding:10px 16px;background:var(--brand);color:#fff;font-weight:600;cursor:pointer}.btn:focus{outline:3px solid #b8ebe4;outline-offset:2px}.btn--noble{background:linear-gradient(180deg,#fff,#f3f7f6);color:var(--brand);border:1px solid rgba(0,0,0,.06);box-shadow:0 6px 18px #03211a0f,inset 0 -2px #00000008;padding:10px 16px;border-radius:12px;font-weight:700}.btn--noble:hover{transform:translateY(-1px);box-shadow:0 10px 26px #03211a14,inset 0 -2px #00000005}.btn--noble:focus{outline:3px solid rgba(0,150,136,.12);outline-offset:2px}pre.output{background:#f4f6f8;border:1px solid var(--line);border-radius:10px;padding:12px;margin-top:12px;overflow:auto}.page.hidden{display:none}.nav a.active{background:#e9f6f4;box-shadow:inset 0 0 0 1px var(--brand)}.row{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}.row input{border:1px solid var(--line);border-radius:10px;padding:10px 12px;outline:none}.row input:focus{box-shadow:0 0 0 3px #b8ebe4;border-color:var(--brand)}.list{list-style:none;margin:12px 0 0;padding:0}.list li{display:flex;align-items:center;justify-content:space-between;gap:12px;background:#fff;border:1px solid var(--line);border-radius:10px;padding:10px 12px;margin-bottom:8px}.small-btn{border:0;border-radius:10px;padding:6px 10px;background:#ef4444;color:#fff;cursor:pointer;font-weight:600}.small-btn:focus{outline:3px solid #ffd5d5;outline-offset:1px}.subsection{margin-top:16px;font-size:.95rem}.subsection__title{font-weight:600;opacity:.8;margin:4px 0 8px}#page-trip .form-main{align-items:flex-start}#page-trip .form-main input{flex:1 1 180px}#page-trip .form-actions{margin-top:16px;align-items:center}.field{display:flex;flex-direction:column;gap:6px}.field__label{font-size:.85rem;opacity:.75}.route-section{margin-top:24px}.route-steps{display:flex;flex-direction:column;gap:10px}.route-step{display:grid;grid-template-columns:28px 1fr;column-gap:18px;align-items:stretch}.route-step__track{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center}.route-step--point .route-step__track{justify-content:flex-start;padding-top:6px}.route-dot{width:14px;height:14px;border-radius:50%;background:var(--brand);display:block}.route-dot--stop{border:4px solid var(--brand);background:#fff;width:12px;height:12px}.route-dot--end{margin-bottom:6px}.route-step--transport .route-step__track{padding:8px 0}.route-line{width:4px;flex:1;border-radius:999px;background:var(--brand)}.route-add{position:absolute;right:-18px;top:50%;transform:translate(50%,-50%);width:28px;height:28px;border-radius:50%;border:2px solid var(--brand);background:#fff;color:var(--brand);font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 1px 2px #10141814}.route-add:hover{background:#e9f6f4}.route-step__body{display:flex;flex-direction:column;gap:6px}.route-point-controls{display:flex;gap:8px;align-items:flex-start}.route-point-controls .field{flex:1}.route-remove{border:0;border-radius:10px;background:#fee2e2;color:#b91c1c;padding:6px 12px;font-size:.85rem;cursor:pointer}.route-remove:hover{background:#fecaca}.route-point-controls{display:grid;grid-template-columns:1fr auto auto auto;align-items:start;gap:8px}.route-photos{display:flex;flex-direction:column;gap:6px;width:220px}.route-photos__list{display:flex;gap:6px;overflow-x:auto;padding-bottom:2px}.route-photo-box{position:relative;width:60px;height:45px;border:1px solid var(--line);border-radius:8px;overflow:hidden;background:#fff}.route-photo{width:100%;height:100%;object-fit:cover;display:block}.route-photo-remove{position:absolute;top:2px;right:2px;border:0;border-radius:6px;background:#ffffffe6;color:#b91c1c;font-size:12px;line-height:1;padding:2px 4px;cursor:pointer}.route-photo-add{border:0;border-radius:10px;background:#e9f6f4;color:var(--brand);padding:6px 10px;font-size:.85rem;cursor:pointer;font-weight:600}.route-photo-add:hover{background:#dff2ef}.route-card{border:0;border-radius:10px;background:#e9f6f4;color:var(--brand);padding:6px 12px;font-size:.85rem;cursor:pointer;font-weight:600}.route-card:hover{background:#dff2ef}.route-attendance{border:0;border-radius:10px;padding:6px 12px;font-size:.85rem;cursor:pointer;font-weight:600;transition:all .2s ease}.route-attendance--attending{background:#dcfce7;color:#16a34a}.route-attendance--attending:hover{background:#bbf7d0}.route-attendance--not-attending{background:#fef2f2;color:#dc2626}.route-attendance--not-attending:hover{background:#fecaca}.small-btn--noble{background:linear-gradient(180deg,#fff,#f7faf9);color:var(--brand);border:1px solid rgba(0,0,0,.06);box-shadow:0 6px 14px #03211a0a;padding:6px 10px;border-radius:10px;font-weight:700}.small-btn--noble:hover{transform:translateY(-1px)}.route-attendance--attending,.todo-attendance--attending{background:linear-gradient(180deg,#fff,#f3f7f6);color:var(--brand);border:1px solid rgba(0,0,0,.06)}.route-attendance--attending:hover,.todo-attendance--attending:hover{box-shadow:0 8px 20px #03211a0f}.point-attendance-controls{margin:8px 0}.transport-select{display:flex;flex-direction:column;gap:6px}.transport-select select{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--line);border-radius:12px;padding:10px 42px 10px 14px;font-size:.95rem;font-family:inherit;background:#fff url("data:image/svg+xml,%3csvg xmlns=%22http://www.w3.org/2000/svg%22 width=%2210%22 height=%226%22 viewBox=%220 0 10 6%22%3e%3cpath fill=%22%23009688%22 d=%22M1 .75L5 4.25 9 .75V2L5 5.5 1 2z%22/%3e%3c/svg%3e") no-repeat right 14px center/12px;cursor:pointer}.transport-select select:hover{border-color:var(--brand)}.transport-select select:focus{outline:3px solid #b8ebe4;outline-offset:1px;border-color:var(--brand)}.field textarea{border:1px solid var(--line);border-radius:10px;padding:10px 12px;outline:none;font-family:inherit;resize:vertical}.field textarea:focus{box-shadow:0 0 0 3px #b8ebe4;border-color:var(--brand)}.todo-list{display:flex;flex-direction:column;gap:8px;margin:8px 0}.todo-item{display:grid;grid-template-columns:24px 1fr auto auto;align-items:center;column-gap:10px}.todo-check{width:18px;height:18px;accent-color:var(--brand)}.todo-text{border:1px solid var(--line);border-radius:10px;padding:8px 10px;outline:none}.todo-text:focus{box-shadow:0 0 0 3px #b8ebe4;border-color:var(--brand)}.todo-remove{border:0;border-radius:10px;background:#fee2e2;color:#b91c1c;padding:6px 10px;font-size:.85rem;cursor:pointer}.todo-remove:hover{background:#fecaca}.todo-attendance{border:0;border-radius:8px;padding:4px 8px;font-size:.75rem;cursor:pointer;font-weight:600;transition:all .2s ease}#page-chats{margin:-16px}.chat-layout{display:flex;height:calc(100vh - 120px);min-height:480px;background:#fff;border-radius:16px;border:1px solid var(--line, #e8ecf0);box-shadow:0 2px 12px #10141812;overflow:hidden}.chat-sidebar{width:280px;min-width:220px;display:flex;flex-direction:column;border-right:1px solid var(--line, #e8ecf0);background:#fafbfc}.chat-sidebar__header{padding:20px 16px 12px;border-bottom:1px solid var(--line, #e8ecf0)}.chat-sidebar__title{display:block;font-size:1.15rem;font-weight:700;color:#111827;margin-bottom:10px}.chat-sidebar__invite{display:flex;gap:6px;align-items:center}.chat-sidebar__invite input{flex:1;border:1px solid var(--line, #e8ecf0);border-radius:8px;padding:7px 10px;font-size:.8rem;outline:none;background:#fff;color:#374151}.chat-sidebar__invite input:focus{border-color:var(--brand, #14b8a6);box-shadow:0 0 0 3px #14b8a61f}.chat-sidebar__invite button{width:32px;height:32px;border:none;border-radius:8px;background:var(--brand, #14b8a6);color:#fff;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s}.chat-sidebar__invite button:hover{background:#0d9488}.chat-sidebar__list{flex:1;overflow-y:auto;padding:8px 0}.chat-user{display:flex;align-items:flex-start;gap:12px;padding:12px 16px;cursor:pointer;transition:background .12s;position:relative}.chat-user:hover{background:#f0f4f8}.chat-user.active{background:#eef6ff;border-left:3px solid #3b82f6}.chat-user.active .chat-user__avatar{margin-left:-3px}.chat-user__avatar{width:42px;height:42px;border-radius:50%;background:#e2e8f0;display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden;font-weight:700;font-size:.9rem;color:#64748b}.chat-user__avatar svg{opacity:.55}.chat-user__avatar--group{background:#dbeafe;color:#1d4ed8}.chat-user__body{flex:1;min-width:0}.chat-user__top{display:flex;align-items:baseline;justify-content:space-between;gap:4px}.chat-user__name{font-weight:600;font-size:.88rem;color:#111827;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-user__time{font-size:.73rem;color:#9ca3af;flex-shrink:0}.chat-user__preview{font-size:.78rem;color:#6b7280;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}.chat-pane{flex:1;display:flex;flex-direction:column;min-width:0;background:#fff}.chat-pane__header{display:flex;align-items:center;gap:12px;padding:14px 20px;border-bottom:1px solid var(--line, #e8ecf0);background:#fff;flex-shrink:0}.chat-pane__header-avatar{width:42px;height:42px;border-radius:50%;background:#3b82f6;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.9rem;flex-shrink:0}.chat-pane__header-info{flex:1;min-width:0}.chat-pane__header-name{font-weight:700;font-size:.95rem;color:#111827}.chat-pane__header-sub{font-size:.78rem;color:#9ca3af;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-pane__messages{flex:1;overflow-y:auto;padding:20px 20px 8px;display:flex;flex-direction:column;gap:4px;background:#f9fafb}.chat-msg-group{display:flex;flex-direction:column;gap:2px;margin-bottom:12px}.chat-msg-group--you{align-items:flex-end}.chat-msg-group--them{align-items:flex-start}.chat-msg-group__sender{font-size:.75rem;font-weight:600;color:#374151;margin-bottom:4px;padding:0 4px}.chat-bubble{max-width:65%;padding:9px 14px;border-radius:18px;font-size:.88rem;line-height:1.45;word-break:break-word}.chat-bubble--them{background:#f3f4f6;color:#111827;border-bottom-left-radius:4px}.chat-bubble--you{background:#3b82f6;color:#fff;border-bottom-right-radius:4px}.chat-bubble__time{display:block;font-size:.68rem;margin-top:4px;opacity:.6;text-align:right}.chat-msg-group--them .chat-bubble__time{text-align:left}.chat-date-separator{text-align:center;font-size:.72rem;color:#9ca3af;margin:12px 0 8px;position:relative}.chat-date-separator:before,.chat-date-separator:after{content:"";position:absolute;top:50%;width:30%;height:1px;background:#e5e7eb}.chat-date-separator:before{left:0}.chat-date-separator:after{right:0}.chat-empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#9ca3af;font-size:.88rem;gap:8px;padding:40px}.chat-pane__input-bar{display:flex;align-items:center;gap:8px;padding:12px 16px;border-top:1px solid var(--line, #e8ecf0);background:#fff;flex-shrink:0}.chat-pane__input-bar input{flex:1;border:1px solid var(--line, #e8ecf0);border-radius:24px;padding:10px 16px;font-size:.88rem;outline:none;background:#f9fafb;color:#111827;min-width:0}.chat-pane__input-bar input:focus{border-color:var(--brand, #14b8a6);background:#fff;box-shadow:0 0 0 3px #14b8a61a}.chat-attach-btn{width:38px;height:38px;border:none;background:none;cursor:pointer;color:#9ca3af;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .12s,color .12s;flex-shrink:0}.chat-attach-btn:hover{background:#f3f4f6;color:#374151}.chat-send-btn{padding:9px 20px;border:none;border-radius:24px;background:#3b82f6;color:#fff;font-size:.88rem;font-weight:600;cursor:pointer;flex-shrink:0;transition:background .15s;white-space:nowrap}.chat-send-btn:hover{background:#2563eb}@media (max-width: 768px){body{padding-top:env(safe-area-inset-top,24px)}.header{padding-top:8px}.chat-layout{position:fixed;top:calc(60px + env(safe-area-inset-top,24px));left:0;right:0;bottom:0;border-radius:0;height:auto;flex-direction:column;min-height:unset}.chat-sidebar{width:100%;min-width:unset;border-right:none;border-bottom:1px solid var(--line, #e8ecf0);flex:0 0 auto;max-height:30vh}.chat-pane{flex:1;overflow:hidden}.chat-pane__messages{padding-bottom:70px;-webkit-overflow-scrolling:touch}.chat-pane__input-bar{position:fixed;bottom:env(safe-area-inset-bottom,0);left:0;right:0;padding-bottom:calc(12px + env(safe-area-inset-bottom,0));box-shadow:0 -2px 12px #00000014;z-index:100}.chat-pane__input-bar input{font-size:16px}}.todo-attendance--attending{background:#dcfce7;color:#16a34a}.todo-attendance--attending:hover{background:#bbf7d0}.todo-attendance--not-attending{background:#fef2f2;color:#dc2626}.todo-attendance--not-attending:hover{background:#fecaca}.todo-actions{margin:4px 0 8px}.modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#10141866;display:none;align-items:center;justify-content:center;padding:16px;z-index:1000}.modal.open{display:flex}.modal__dialog{background:#fff;width:min(100%,900px);border-radius:12px;border:1px solid var(--line);box-shadow:0 10px 30px #1014182e;display:flex;flex-direction:column}.modal__header{font-weight:700;padding:14px 16px;border-bottom:1px solid var(--line)}.modal__controls{display:flex;gap:8px;align-items:center;padding:10px 16px;border-bottom:1px solid var(--line)}.modal__controls input{flex:1;border:1px solid var(--line);border-radius:10px;padding:10px 12px;outline:none}.modal__controls input:focus{box-shadow:0 0 0 3px #b8ebe4;border-color:var(--brand)}#map-canvas{width:100%;height:460px}.modal__footer{display:flex;gap:8px;justify-content:flex-end;padding:12px 16px;border-top:1px solid var(--line)}.map-error{display:none;color:#b91c1c;padding:8px 16px}.map-error.show{display:block}.modal__body{padding:16px}.btn--danger{background:#dc2626}.btn--danger:hover{background:#b91c1c}@media (max-width: 480px){.route-point-controls{grid-template-columns:1fr}.route-point-controls .field,.route-point-controls button{grid-column:1 / -1;width:100%}}.attendance-badge{display:inline-block;margin-left:8px;background:#eef2ff;color:#3730a3;padding:2px 6px;border-radius:10px;font-size:12px;cursor:pointer}.modal--tiny .modal__header,.modal--tiny .modal__body{padding:8px 12px;font-size:.95rem}.participant-row{display:flex;gap:8px;align-items:center;padding:6px 0;border-bottom:1px solid var(--line)}.participant-row:last-child{border-bottom:none}.participant-mark{width:20px;text-align:center;font-size:14px}.participant-name{flex:1;font-size:13px;color:var(--ink)}.participant-me{font-weight:700;color:var(--brand)}.trips-toolbar{padding:16px 0 14px}.trips-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;padding-bottom:32px}.trip-card{background:#fff;border-radius:16px;overflow:hidden;border:1px solid var(--line);box-shadow:0 2px 8px #10141812;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease}.trip-card:hover{transform:translateY(-3px);box-shadow:0 10px 24px #10141821}.trip-card:focus-visible{outline:3px solid var(--brand);outline-offset:2px}.trip-card__photo{width:100%;aspect-ratio:4 / 3;object-fit:cover;display:block}.trip-card__photo-placeholder{width:100%;aspect-ratio:4 / 3;background:linear-gradient(135deg,#b2dfdb,#009688);display:block}.trip-card__body{padding:10px 12px 12px}.trip-card__title{font-weight:700;font-size:.93rem;margin:0 0 3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--ink)}.trip-card__dates{font-size:.76rem;color:#6b7280;margin:0 0 6px}.trip-card__role{display:inline-block;font-size:.71rem;color:#374151;background:#f3f4f6;border-radius:6px;padding:2px 7px;margin-bottom:8px;line-height:1.5}.trip-card__avatars{display:flex;flex-wrap:nowrap}.trip-card__avatar{width:26px;height:26px;border-radius:50%;border:2px solid #fff;background:#d1d5db;font-size:10px;display:flex;align-items:center;justify-content:center;font-weight:700;color:#4b5563;overflow:hidden;flex-shrink:0;margin-right:-6px;text-transform:uppercase}.trip-card__avatar:last-child{margin-right:0}.trip-card__empty{grid-column:1 / -1;text-align:center;padding:56px 16px;color:#6b7280;font-size:1rem}@media (max-width: 900px){.trips-grid{grid-template-columns:repeat(3,1fr);gap:12px}}@media (max-width: 620px){.trips-grid{grid-template-columns:repeat(2,1fr);gap:10px}}.trip-detail-layout{display:grid;grid-template-columns:340px 1fr;gap:16px;align-items:start;padding:16px 0 32px}.trip-page-title{display:block;width:100%;box-sizing:border-box;font-size:1.1rem;font-weight:600;color:var(--ink);margin:0 0 12px;line-height:1.4;word-break:break-word;background:#fff;border:1px solid var(--line);border-radius:10px;padding:10px 12px;outline:none;cursor:text;transition:border-color .15s,box-shadow .15s;min-height:1.4em;white-space:nowrap;overflow:hidden}.trip-page-title:hover{border-color:#c0c4cc}.trip-page-title:focus{border-color:var(--brand);box-shadow:0 0 0 3px #b8ebe4}.trip-page-title:empty:before{content:"Название поездки";color:#9ca3af;pointer-events:none;font-weight:400}.trip-detail-card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:20px 16px}.trip-detail-heading{font-size:1.1rem;font-weight:700;margin:0 0 16px;color:var(--ink)}#page-trip .route-steps{display:flex;flex-direction:column;gap:0}.trip-point-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px 14px 12px;box-shadow:0 1px 4px #1014180f}.trip-point-card__type{display:flex;align-items:center;gap:7px;margin-bottom:8px}.trip-point-card__dot{width:11px;height:11px;border-radius:50%;background:var(--brand);flex-shrink:0;box-shadow:0 0 0 3px #00968826}.trip-point-card__type-label{font-size:.78rem;font-weight:600;color:var(--brand);text-transform:uppercase;letter-spacing:.03em}.trip-point-card__location-row{display:flex;align-items:center;gap:6px;margin-bottom:10px}.trip-point-card__location-icon{color:#9ca3af;font-size:.85rem;flex-shrink:0}.trip-point-card__location-input{flex:1;border:none;border-bottom:1px solid var(--line);padding:3px 0 4px;font-size:1rem;font-weight:600;color:var(--ink);outline:none;background:transparent;min-width:0}.trip-point-card__location-input:focus{border-bottom-color:var(--brand)}.trip-point-card__location-input::placeholder{color:#d1d5db;font-weight:400}.trip-point-card__datetime{display:flex;gap:8px;margin-bottom:12px}.trip-point-card__field{display:flex;flex-direction:column;gap:3px;flex:1}.trip-point-card__field-label{font-size:.7rem;color:#9ca3af;font-weight:500}.trip-point-card__date-input,.trip-point-card__time-input{border:1px solid var(--line);border-radius:8px;padding:5px 8px;font-size:.82rem;outline:none;color:var(--ink);background:#f9fafb;width:100%;font-family:inherit}.trip-point-card__date-input:focus,.trip-point-card__time-input:focus{border-color:var(--brand);box-shadow:0 0 0 2px #00968826;background:#fff}.trip-point-card__actions{display:flex;gap:6px;flex-wrap:wrap}.trip-point-card__actions .route-card,.trip-point-card__actions .route-attendance,.trip-point-card__actions .route-remove{flex:0 0 auto;font-size:.77rem;padding:5px 10px;border-radius:8px}.trip-point-card__actions .route-card--primary{font-size:.9rem;padding:8px 18px;border-radius:10px;background:var(--brand);color:#fff;font-weight:700;min-width:90px}.trip-point-card__actions .route-card--primary:hover{background:#0d9977}.trip-transport-connector{display:flex;flex-direction:column;align-items:center;position:relative;padding:2px 0;z-index:0}.trip-transport-connector__line-top,.trip-transport-connector__line-bottom{width:2px;height:10px;background:#d1d5db}.trip-transport-connector__content{display:flex;align-items:center;gap:24px}.trip-transport-connector__badge{display:flex;align-items:center;gap:5px;background:#f9fafb;border:1px solid var(--line);border-radius:20px;padding:3px 12px;font-size:.77rem;color:#6b7280;cursor:pointer;transition:background .15s,color .15s,border-color .15s;white-space:nowrap}.trip-transport-connector__badge:hover{background:#e9f6f4;color:var(--brand);border-color:var(--brand)}.trip-transport-connector__icon{font-size:.95rem}.trip-transport-connector__select{display:none;position:absolute;top:100%;left:50%;transform:translate(-50%);z-index:10;background:#fff;border:1px solid var(--line);border-radius:10px;box-shadow:0 4px 16px #1014181f;padding:4px;min-width:140px}.trip-transport-connector__select.open{display:block}.trip-transport-connector__option{display:flex;align-items:center;gap:8px;width:100%;border:none;background:transparent;padding:7px 10px;font-size:.85rem;color:var(--ink);cursor:pointer;border-radius:7px;text-align:left;transition:background .12s}.trip-transport-connector__option:hover{background:#e9f6f4;color:var(--brand)}.trip-transport-connector__option.selected{background:#e9f6f4;color:var(--brand);font-weight:600}.trip-transport-connector__add-btn{border:none;background:#f0fdf4;color:#16a34a;border-radius:6px;padding:2px 8px;font-size:.75rem;font-weight:700;cursor:pointer;white-space:nowrap}.trip-transport-connector__add-btn:hover{background:#dcfce7}.trip-detail-right{display:flex;flex-direction:column;gap:12px;position:sticky;top:16px}.trip-map-wrapper{background:#e8eaf0;border-radius:14px;overflow:hidden;border:1px solid var(--line);box-shadow:0 1px 4px #1014180f}.trip-map-search-bar{padding:8px 12px;background:#fff;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:8px}.trip-map-search-icon{color:#9ca3af;font-size:.95rem}.trip-map-search-bar input{flex:1;border:none;outline:none;font-size:.88rem;background:transparent;color:var(--ink)}.trip-map-canvas{width:100%;height:280px;background:#dde2eb;position:relative}.trip-map-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;color:#9ca3af;font-size:.88rem}.trip-sidebar{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;box-shadow:0 1px 4px #1014180f}.trip-sidebar__header{padding:12px 16px;font-weight:700;font-size:.92rem;border-bottom:1px solid var(--line);color:var(--ink)}.trip-sidebar__section{padding:12px 16px;border-bottom:1px solid var(--line)}.trip-sidebar__section:last-child{border-bottom:none}.trip-sidebar__section-title{font-weight:600;font-size:.82rem;color:#374151;margin-bottom:10px}.trip-sidebar-participants{display:flex;flex-direction:column;gap:8px;margin-bottom:10px}.sidebar-participant{display:flex;align-items:center;gap:10px}.sidebar-participant__avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,#b2dfdb,#009688);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem;color:#fff;flex-shrink:0;overflow:hidden}.sidebar-participant__avatar img{width:100%;height:100%;object-fit:cover}.sidebar-participant__name{font-size:.85rem;color:var(--ink);font-weight:500}.trip-sidebar-manage-btn{border:1px dashed var(--line);background:transparent;border-radius:8px;padding:5px 10px;font-size:.78rem;color:#6b7280;cursor:pointer;width:100%;text-align:center}.trip-sidebar-manage-btn:hover{background:#f9fafb;color:var(--brand);border-color:var(--brand)}.trip-sidebar-manage-btn--active{background:#e6faf8;color:var(--brand);border-color:var(--brand);border-style:solid}.sidebar-participant-panel{animation:sidebarPanelIn .18s ease}@keyframes sidebarPanelIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.sidebar-participant-panel__title{font-weight:600;font-size:.8rem;color:#374151;margin-bottom:8px}.sidebar-participant-panel__input-row{display:flex;gap:6px;margin-bottom:6px}.sidebar-participant-panel__input{flex:1;border:1px solid var(--line);border-radius:8px;padding:6px 10px;font-size:.8rem;outline:none;background:#f9fafb;font-family:inherit;min-width:0}.sidebar-participant-panel__input:focus{border-color:var(--brand);background:#fff}.sidebar-participant-panel__add-btn{flex-shrink:0;border:none;background:var(--brand);color:#fff;border-radius:8px;padding:6px 12px;font-size:.78rem;font-weight:600;cursor:pointer;font-family:inherit}.sidebar-participant-panel__add-btn:hover{background:#00796b}.sidebar-participant-panel__msg{font-size:.76rem;min-height:16px;margin-bottom:4px}.sidebar-participant-panel__list{display:flex;flex-direction:column;gap:5px;margin-bottom:6px}.sidebar-participant-panel__item{display:flex;align-items:center;justify-content:space-between;gap:6px;padding:4px 6px;border-radius:6px;background:#f3f4f6}.sidebar-participant-panel__item-name{font-size:.79rem;color:var(--ink);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-participant-panel__remove-btn{border:none;background:transparent;color:#9ca3af;cursor:pointer;font-size:.75rem;padding:2px 5px;border-radius:4px;flex-shrink:0;line-height:1}.sidebar-participant-panel__remove-btn:hover{background:#fee2e2;color:#b91c1c}.sidebar-participant-panel__hint{font-size:.72rem;color:#9ca3af;margin:0;line-height:1.4}.trip-sidebar__chat-title{display:flex;align-items:center;justify-content:space-between;font-weight:600;font-size:.82rem;color:#374151;margin-bottom:10px}.trip-sidebar__chat-open-btn{border:none;background:#e5e7eb;border-radius:6px;width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;font-size:.7rem;color:#6b7280;padding:0}.trip-sidebar__chat-open-btn:hover{background:#e9f6f4;color:var(--brand)}.trip-sidebar-messages{background:#f9fafb;border-radius:10px;padding:8px;min-height:80px;max-height:200px;overflow-y:auto;margin-bottom:10px;display:flex;flex-direction:column;gap:5px}.sidebar-chat-empty{font-size:.78rem;color:#9ca3af;text-align:center;padding:14px 0}.sidebar-msg-row{display:flex;justify-content:flex-start}.sidebar-msg-row--me{justify-content:flex-end}.sidebar-msg-bubble{max-width:82%;padding:6px 10px;border-radius:14px;font-size:.78rem;line-height:1.4;word-break:break-word}.sidebar-msg-bubble--them{background:#fff;border:1px solid #e5e7eb;border-bottom-left-radius:4px}.sidebar-msg-bubble--me{background:var(--brand, #14b8a6);color:#fff;border-bottom-right-radius:4px}.sidebar-msg-sender{font-size:.68rem;font-weight:700;color:#6b7280;margin-bottom:2px}.sidebar-msg-text{display:block}.sidebar-msg-time{display:block;font-size:.62rem;margin-top:3px;opacity:.55;text-align:right}.trip-sidebar-input-row{display:flex;gap:7px;align-items:center}.trip-sidebar-input-row input{flex:1;border:1px solid var(--line);border-radius:20px;padding:7px 14px;font-size:.82rem;outline:none;background:#f9fafb;font-family:inherit;min-width:0}.trip-sidebar-input-row input:focus{border-color:var(--brand);background:#fff}.trip-sidebar-send-btn{width:32px;height:32px;border-radius:50%;border:none;background:var(--brand);color:#fff;font-size:.8rem;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;padding:0}.trip-sidebar-send-btn:hover{background:#00796b}.trip-detail-actions{margin-top:16px;padding-top:12px;border-top:1px solid var(--line);display:flex;gap:8px;align-items:center}@media (max-width: 900px){.trip-detail-layout{grid-template-columns:300px 1fr;gap:12px}}@media (max-width: 700px){.trip-detail-layout{grid-template-columns:1fr}.trip-detail-right{position:static;order:-1}.trip-map-canvas{height:200px}}.point-card-overlay{display:flex;align-items:flex-start;justify-content:center;min-height:calc(100vh - 80px);padding:24px 16px 32px}.point-card{width:100%;max-width:620px;background:#fff;border-radius:20px;box-shadow:0 8px 40px #10141821;border:1px solid var(--line, #e8ecf0);overflow:hidden}.point-card-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 12px;border-bottom:1px solid var(--line, #e8ecf0)}.point-card-title{font-size:1.15rem;font-weight:700;color:var(--text, #1a2633);margin:0}.point-card-close{width:32px;height:32px;border:none;background:#f3f4f6;border-radius:50%;font-size:1rem;line-height:1;cursor:pointer;color:#6b7280;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s;flex-shrink:0}.point-card-close:hover{background:#e5e7eb;color:#374151}.point-card-body{padding:20px 24px 0}.point-section{margin-bottom:20px}.point-section__title{font-size:.82rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px}.point-notes-input{width:100%;box-sizing:border-box;border:1px solid var(--line, #e8ecf0);border-radius:10px;padding:10px 12px;font-size:.95rem;font-family:inherit;color:var(--text, #1a2633);resize:vertical;outline:none;min-height:70px}.point-notes-input::placeholder{color:#b0b8c1}.point-notes-input:focus{border-color:var(--brand, #009688);box-shadow:0 0 0 3px #00968821}.point-two-col{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:20px}.point-col{min-width:0}.point-col .todo-list{gap:10px;margin:0 0 10px}.point-col .todo-item{grid-template-columns:22px 1fr auto;column-gap:8px;position:relative}.point-col .todo-item .todo-attendance{display:none}.point-col .todo-item .todo-remove{padding:0;width:22px;height:22px;font-size:.85rem;border-radius:50%;display:flex;align-items:center;justify-content:center}.point-add-task-btn{background:none;border:none;color:var(--brand, #009688);font-size:.9rem;font-weight:600;cursor:pointer;padding:4px 0;display:flex;align-items:center;gap:4px}.point-add-task-btn:hover{color:#007a6e;text-decoration:underline}.point-add-task-btn__icon{font-size:1.1rem;line-height:1}.point-attendance-row{margin-bottom:12px}.point-toggle-btn{display:inline-flex;align-items:center;gap:10px;background:none;border:none;cursor:pointer;padding:0;font-family:inherit}.point-toggle-track{width:44px;height:24px;border-radius:12px;background:#d1d5db;position:relative;transition:background .2s ease;flex-shrink:0}.point-toggle-thumb{position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#fff;box-shadow:0 1px 4px #0000002e;transition:left .2s ease}.notify-item{display:flex;gap:12px;align-items:flex-start;padding:12px 14px;border-radius:10px;background:#fff;border:1px solid var(--line, #e5e7eb);margin-bottom:8px;transition:background .15s,box-shadow .15s}.notify-item:hover{background:#f0faf9;box-shadow:0 2px 8px #00968814}.notify-item--read{opacity:.55;background:#fafafa}.notify-item--read:hover{opacity:.75;background:#f5f5f5}.notify-icon{font-size:22px;line-height:1;flex-shrink:0;margin-top:2px}.notify-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}.notify-title{font-size:14px;font-weight:600;color:var(--ink, #101418);word-break:break-word}.notify-body{font-size:13px;color:#4b5563;word-break:break-word;line-height:1.4}.notify-meta{font-size:11px;color:#9ca3af;margin-top:2px}#notify-count{animation:notif-pop .25s ease}@keyframes notif-pop{0%{transform:scale(.5)}60%{transform:scale(1.3)}to{transform:scale(1)}}point-toggle-btn--on .point-toggle-track{background:var(--brand, #009688)}.point-toggle-btn--on .point-toggle-thumb{left:23px}.point-toggle-label{font-size:.92rem;font-weight:600;color:var(--text, #1a2633)}.point-participants-list{font-size:.88rem;color:#374151;line-height:1.6}.point-participants-label{font-weight:600;color:#6b7280}.point-photos-grid{display:flex;flex-wrap:wrap;gap:8px;align-items:flex-start}.point-photos-thumbs{display:contents}.point-photos-thumbs .route-photo-box{width:90px;height:68px;border-radius:10px;overflow:hidden;position:relative;cursor:pointer;flex-shrink:0}.point-photos-thumbs .route-photo{width:100%;height:100%;object-fit:cover;display:block}.point-photos-thumbs .route-photo-remove{position:absolute;top:3px;right:3px;width:18px;height:18px;border-radius:50%;background:#ef4444d9;border:none;color:#fff;font-size:.75rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s}.point-photos-thumbs .route-photo-box:hover .route-photo-remove{opacity:1}.point-photo-upload-btn{width:90px;height:68px;border:2px dashed var(--line, #e0e5ea);border-radius:10px;background:#f9fafb;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;cursor:pointer;color:#6b7280;font-size:.75rem;font-family:inherit;text-align:center;transition:border-color .15s,background .15s;flex-shrink:0}.point-photo-upload-btn:hover{border-color:var(--brand, #009688);background:#f0faf9;color:var(--brand, #009688)}.point-photo-upload-icon{font-size:1.4rem;line-height:1}.point-card-footer{display:flex;justify-content:flex-end;gap:10px;padding:16px 24px 20px;border-top:1px solid var(--line, #e8ecf0);margin:20px -24px 0}.btn--gray{background:#f3f4f6;color:#374151;border:1px solid #e5e7eb}.btn--gray:hover{background:#e5e7eb}@media (max-width: 540px){.point-two-col{grid-template-columns:1fr;gap:0}.point-card-header,.point-card-body{padding-left:16px;padding-right:16px}.point-card-footer{margin-left:-16px;margin-right:-16px;padding:14px 16px 16px}.point-photos-thumbs .route-photo-box,.point-photo-upload-btn{width:80px;height:60px}}.trip-mob-tabs,.trip-mob-fab{display:none}body.is-native .trip-mob-tabs{display:flex;position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid var(--line);z-index:200;padding-bottom:env(safe-area-inset-bottom,0);box-shadow:0 -2px 12px #10141812}body.is-native .trip-mob-tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:9px 4px 8px;border:none;background:transparent;cursor:pointer;color:#9ca3af;font-family:inherit;transition:color .15s;min-height:54px;-webkit-tap-highlight-color:transparent}body.is-native .trip-mob-tab--active{color:var(--brand)}body.is-native .trip-mob-tab__icon{font-size:1.25rem;line-height:1}body.is-native .trip-mob-tab__label{font-size:.67rem;font-weight:600;letter-spacing:.01em}body.is-native .trip-mob-fab{display:flex;align-items:center;justify-content:center;position:fixed;bottom:calc(60px + env(safe-area-inset-bottom,0px));right:20px;width:52px;height:52px;border-radius:50%;border:none;background:var(--brand);color:#fff;font-size:1.6rem;line-height:1;box-shadow:0 4px 16px #00968866;cursor:pointer;z-index:201;transition:background .15s,transform .15s,box-shadow .15s;-webkit-tap-highlight-color:transparent}body.is-native .trip-mob-fab:active{transform:scale(.94);box-shadow:0 2px 8px #00968859}body.is-native #page-trip.mob-tab--plan .trip-mob-fab{display:flex}body.is-native #page-trip:not(.mob-tab--plan) .trip-mob-fab{display:none}body.is-native #page-trip .trip-detail-layout{grid-template-columns:1fr;gap:0;padding-bottom:calc(70px + env(safe-area-inset-bottom,0px))}body.is-native #page-trip .trip-detail-right{position:static;flex-direction:column;gap:0}body.is-native #page-trip .trip-detail-left{display:block}body.is-native #page-trip .trip-detail-right{display:none}body.is-native #page-trip.mob-tab--plan .trip-detail-left{display:block}body.is-native #page-trip.mob-tab--plan .trip-detail-right,body.is-native #page-trip.mob-tab--map .trip-detail-left{display:none}body.is-native #page-trip.mob-tab--map .trip-detail-right{display:flex}body.is-native #page-trip.mob-tab--map .trip-sidebar{display:none}body.is-native #page-trip.mob-tab--map .trip-map-canvas{height:55vh}body.is-native #page-trip.mob-tab--people .trip-detail-left{display:none}body.is-native #page-trip.mob-tab--people .trip-detail-right{display:flex}body.is-native #page-trip.mob-tab--people .trip-map-wrapper,body.is-native #page-trip.mob-tab--people .trip-sidebar__chat-section{display:none}body.is-native #page-trip.mob-tab--people #sidebar-participant-panel{display:none!important}body.is-native #page-trip.mob-tab--people .trip-sidebar{border-radius:0;border-left:none;border-right:none;box-shadow:none}body.is-native #page-trip.mob-tab--people .trip-sidebar__header,body.is-native #page-trip.mob-tab--chat .trip-detail-left{display:none}body.is-native #page-trip.mob-tab--chat .trip-detail-right{display:flex}body.is-native #page-trip.mob-tab--chat .trip-map-wrapper{display:none}body.is-native #page-trip.mob-tab--chat .trip-sidebar__section:not(.trip-sidebar__chat-section){display:none}body.is-native #page-trip.mob-tab--chat .trip-sidebar{border-radius:0;border-left:none;border-right:none;box-shadow:none}body.is-native #page-trip.mob-tab--chat .trip-sidebar__header{display:none}body.is-native #page-trip.mob-tab--chat .trip-sidebar-messages{max-height:calc(100vh - 180px);padding-bottom:60px}body.is-native #page-trip.mob-tab--chat .trip-sidebar-input-row{position:fixed;bottom:calc(58px + env(safe-area-inset-bottom,0px));left:0;right:0;background:#fff;padding:8px 12px;border-top:1px solid var(--line);z-index:190;gap:8px}body.is-native #page-trip.mob-tab--chat .trip-sidebar-input-row input{font-size:16px}
